*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-height:100vh;color:#1f2937;background-color:#f5f7fa}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}p{margin:0}a{text-decoration:none;color:inherit}button{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.layout-container{min-height:100vh;background-color:#f5f7fa}.navbar{background-color:#fff;box-shadow:0 2px 4px #0000001a;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.nav-brand h1{margin:0;color:#3b82f6;font-size:1.5rem;font-weight:700}.nav-brand p{margin:0;color:#6b7280;font-size:.875rem}.nav-links{display:flex;gap:1rem}.nav-links a{text-decoration:none;color:#4b5563;padding:.5rem 1rem;border-radius:.375rem;font-weight:500;transition:all .2s}.nav-links a:hover{background-color:#f3f4f6;color:#3b82f6}.nav-links a.active{background-color:#3b82f6;color:#fff}.nav-user{display:flex;align-items:center;gap:1rem}.nav-user span{color:#4b5563;font-size:.875rem}.btn-logout{background-color:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-weight:500;transition:background-color .2s}.btn-logout:hover{background-color:#dc2626}.main-content{padding:2rem;max-width:1400px;margin:0 auto}.nav-brand{display:flex;align-items:center;gap:.75rem}.nav-logo{width:90px;height:90px;object-fit:contain}.brand-text{display:flex;flex-direction:column;line-height:1.1}.dashboard{animation:fadeIn .3s ease-in}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{margin:0 0 .5rem;color:#1f2937;font-size:2rem}.dashboard-header p{margin:0;color:#6b7280}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;gap:1rem}.stat-icon{width:3rem;height:3rem;border-radius:.75rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.stat-content h3{margin:0;font-size:2rem;color:#1f2937}.stat-content p{margin:.25rem 0 0;color:#6b7280;font-size:.875rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem}.dashboard-section{background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.section-header h2{margin:0;color:#1f2937;font-size:1.25rem}.view-all{color:#3b82f6;text-decoration:none;font-size:.875rem;font-weight:500}.view-all:hover{text-decoration:underline}.children-list{display:flex;flex-direction:column;gap:1rem}.child-card{display:flex;gap:1rem;padding:1rem;border:1px solid #e5e7eb;border-radius:.5rem;transition:box-shadow .2s}.child-card:hover{box-shadow:0 4px 6px #0000000d}.child-avatar{width:3rem;height:3rem;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0}.child-info h3{margin:0 0 .5rem;color:#1f2937;font-size:1.125rem}.child-info p{margin:.25rem 0;color:#6b7280;font-size:.875rem}.allergies{color:#dc2626!important;font-weight:500}.items-list{display:flex;flex-direction:column;gap:.75rem}.item-card{padding:1rem;border:1px solid #e5e7eb;border-radius:.5rem;transition:box-shadow .2s}.item-card:hover{box-shadow:0 2px 4px #0000000d}.item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.item-title{font-weight:600;color:#1f2937}.item-child{margin:.25rem 0;color:#6b7280;font-size:.875rem}.item-date{margin:.25rem 0 0;color:#9ca3af;font-size:.75rem}.no-data{text-align:center;color:#9ca3af;padding:2rem;font-style:italic}.doctor-dashboard{animation:fadeIn .3s ease-in}.doctor-info{color:#6b7280;font-size:.875rem;margin-top:.25rem}.patients-list{display:flex;flex-direction:column;gap:1rem}.patient-card{display:flex;gap:1rem;padding:1rem;border:1px solid #e5e7eb;border-radius:.5rem;transition:box-shadow .2s}.patient-card:hover{box-shadow:0 4px 6px #0000000d}.patient-avatar{width:3rem;height:3rem;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0}.patient-info h3{margin:0 0 .5rem;color:#1f2937;font-size:1.125rem}.patient-info p{margin:.25rem 0;color:#6b7280;font-size:.875rem}.message-card{padding:1rem;border:1px solid #e5e7eb;border-radius:.5rem;transition:box-shadow .2s}.message-card:hover{box-shadow:0 2px 4px #0000000d}.message-card.unread{background-color:#fef3c7;border-left:3px solid #f59e0b}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.unread-indicator{color:#f59e0b;font-size:1rem}.message-subject{font-weight:500;color:#374151;margin:.5rem 0;font-size:.9375rem}.message-preview{color:#6b7280;font-size:.875rem;margin:.5rem 0}.message-date{color:#9ca3af;font-size:.75rem;margin:.5rem 0 0}.item-detail{color:#6b7280;font-size:.75rem;margin-top:.5rem;font-weight:500}.today-appointments-section,.appointment-calendar-section{grid-column:1 / -1}.date-badge{background-color:#dbeafe;color:#1e40af;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.calendar-subtitle{color:#6b7280;font-size:.875rem;font-weight:400}.appointment-card{display:flex;gap:1rem;padding:1.25rem;border:2px solid #e5e7eb;border-radius:.75rem;transition:all .2s;background:#fff}.appointment-card:hover{box-shadow:0 4px 6px #0000001a;border-color:#3b82f6}.appointment-time{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:80px;padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:.5rem;color:#fff}.appointment-time .time{font-size:1.25rem;font-weight:700;line-height:1}.appointment-time .duration{font-size:.75rem;margin-top:.25rem;opacity:.9}.appointment-details{flex:1}.appointment-details h3{margin:0 0 .5rem;color:#1f2937;font-size:1.125rem}.parent-name{color:#6b7280;font-size:.875rem;margin:.25rem 0}.appointment-reason{color:#374151;font-weight:500;margin:.5rem 0}.appointment-type-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize;margin-top:.5rem}.appointment-type-badge.checkup{background-color:#dbeafe;color:#1e40af}.appointment-type-badge.followup{background-color:#fef3c7;color:#92400e}.appointment-type-badge.sick-visit{background-color:#fee2e2;color:#991b1b}.appointment-type-badge.vaccination{background-color:#dcfce7;color:#166534}.appointment-notes{grid-column:1 / -1;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb;font-size:.875rem;color:#6b7280}.notes-label{font-weight:600;color:#374151}.no-appointments{text-align:center;padding:3rem 1rem;color:#9ca3af;font-style:italic}.calendar-appointments{display:flex;flex-direction:column;gap:.75rem}.calendar-appointment-card{display:flex;gap:1rem;padding:1rem;border:1px solid #e5e7eb;border-radius:.5rem;transition:all .2s;background:#fff}.calendar-appointment-card:hover{box-shadow:0 2px 4px #0000000d;border-color:#d1d5db}.calendar-date{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:70px;padding:.75rem;background-color:#f9fafb;border-radius:.5rem;border:2px solid #e5e7eb}.calendar-date .day{font-size:1.75rem;font-weight:700;color:#1f2937;line-height:1}.calendar-date .month{font-size:.75rem;color:#6b7280;text-transform:uppercase;margin-top:.25rem}.calendar-date .weekday{font-size:.75rem;color:#9ca3af;margin-top:.125rem}.calendar-appointment-info{flex:1}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.calendar-header h4{margin:0;color:#1f2937;font-size:1rem}.calendar-time{font-weight:600;color:#3b82f6;font-size:.875rem}.calendar-reason{color:#6b7280;font-size:.875rem;margin:.25rem 0 .5rem}.calendar-meta{display:flex;gap:.75rem;align-items:center}.type-badge{padding:.125rem .5rem;border-radius:9999px;font-size:.6875rem;font-weight:500;text-transform:capitalize}.type-badge.checkup{background-color:#dbeafe;color:#1e40af}.type-badge.followup{background-color:#fef3c7;color:#92400e}.type-badge.sick-visit{background-color:#fee2e2;color:#991b1b}.type-badge.vaccination{background-color:#dcfce7;color:#166534}.calendar-duration{color:#9ca3af;font-size:.75rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2)}.login-backdrop{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;filter:brightness(.7);z-index:0}.login-container{position:relative;z-index:1;width:100%;max-width:400px;padding:2rem}.login-card{background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;padding:2.5rem;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:140px;height:140px;object-fit:contain;display:block;margin:0 auto .75rem}.login-header h1{color:#3b82f6;margin:0 0 .5rem;font-size:2rem}.login-header p{color:#6b7280;margin:0;font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#374151;font-weight:500;font-size:.875rem}.form-group input{padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#3b82f6}.form-group input:disabled{background-color:#f3f4f6;cursor:not-allowed}.error-message{background-color:#fee2e2;color:#dc2626;padding:.75rem;border-radius:.5rem;font-size:.875rem}.btn-login{background-color:#3b82f6;color:#fff;border:none;padding:.75rem;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-login:hover:not(:disabled){background-color:#2563eb}.btn-login:disabled{background-color:#9ca3af;cursor:not-allowed}.login-demo{margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb;text-align:center}.login-demo p{color:#6b7280;font-size:.875rem;margin:.25rem 0}.login-demo>p:first-child{font-weight:600;color:#374151;margin-bottom:1rem;font-size:1rem}.demo-section{margin:1rem 0;padding:.75rem;background-color:#f9fafb;border-radius:.5rem}.demo-role{font-weight:600;color:#3b82f6!important;margin-bottom:.5rem!important}.timeline-page{animation:fadeIn .3s ease-in}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.timeline-header h1{margin:0 0 .5rem;color:#1f2937;font-size:2rem}.timeline-header p{margin:0;color:#6b7280}.timeline-filters{background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;display:flex;gap:2rem;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.filter-group label{font-weight:500;color:#374151;font-size:.875rem}.filter-select{padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;background:#fff;cursor:pointer}.filter-select:focus{outline:none;border-color:#3b82f6}.timeline-container{background:#fff;padding:2rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.timeline-item{display:flex;gap:1.5rem;position:relative}.timeline-marker{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.timeline-icon{width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;border:3px solid white;box-shadow:0 2px 4px #0000001a;z-index:1}.timeline-line{width:2px;flex:1;background:linear-gradient(to bottom,#e5e7eb,transparent);margin-top:.5rem}.timeline-content{flex:1;padding-bottom:2rem}.timeline-card{border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;transition:box-shadow .2s}.timeline-card:hover{box-shadow:0 4px 6px #0000000d}.timeline-card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem;gap:1rem}.timeline-card-header h3{margin:0;color:#1f2937;font-size:1.25rem}.timeline-type{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;background-color:#f3f4f6;color:#4b5563;text-transform:capitalize;white-space:nowrap}.timeline-child{font-weight:600;color:#3b82f6;margin:.5rem 0}.timeline-date{color:#6b7280;font-size:.875rem;margin:.5rem 0}.timeline-description{color:#4b5563;margin:1rem 0 .5rem;line-height:1.6}.timeline-location,.timeline-treatment{color:#6b7280;font-size:.875rem;margin:.5rem 0}.no-timeline-data{text-align:center;padding:4rem 2rem;color:#9ca3af}.no-timeline-data p{font-size:1.125rem;font-style:italic}.symptoms-page{animation:fadeIn .3s ease-in}.symptoms-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.symptoms-header h1{margin:0 0 .5rem;color:#1f2937;font-size:2rem}.symptoms-header p{margin:0;color:#6b7280}.btn-add{background-color:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-add:hover{background-color:#2563eb}.symptom-form-container{background:#fff;padding:2rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.symptom-form{display:flex;flex-direction:column;gap:1.5rem}.btn-submit{background-color:#10b981;color:#fff;border:none;padding:.75rem 2rem;border-radius:.5rem;font-weight:500;font-size:1rem;cursor:pointer;transition:background-color .2s;align-self:flex-start}.btn-submit:hover{background-color:#059669}.symptoms-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.symptom-card{background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s}.symptom-card:hover{box-shadow:0 4px 6px #0000001a}.symptom-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.symptom-header h3{margin:0 0 .5rem;color:#1f2937;font-size:1.25rem}.symptom-child{color:#3b82f6;font-weight:500;font-size:.875rem;margin:0}.symptom-actions{display:flex;align-items:center;gap:.5rem}.btn-delete{background:none;border:none;cursor:pointer;font-size:1.25rem;padding:.25rem;opacity:.6;transition:opacity .2s}.btn-delete:hover{opacity:1}.symptom-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.detail-item{display:flex;gap:.5rem;font-size:.875rem}.detail-label{font-weight:600;color:#4b5563}.symptom-notes{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.symptom-notes p{margin:.5rem 0 0;color:#6b7280;font-size:.875rem;line-height:1.6}.no-data{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:#9ca3af}.no-data p{font-size:1.125rem;font-style:italic}.milestones-page{animation:fadeIn .3s ease-in}.milestones-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.milestones-header h1{margin:0 0 .5rem;color:#1f2937;font-size:2rem}.milestones-header p{margin:0;color:#6b7280}.milestone-form-container{background:#fff;padding:2rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.milestone-form{display:flex;flex-direction:column;gap:1.5rem}.checkbox-field{display:flex;align-items:center;padding-top:.5rem}.checkbox-field label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-field input[type=checkbox]{width:1.25rem;height:1.25rem;cursor:pointer}.milestones-filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.milestones-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.milestone-card{background:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s}.milestone-card:hover{box-shadow:0 4px 6px #0000001a}.milestone-header{display:flex;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.milestone-icon{width:3rem;height:3rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:.75rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.milestone-header-content{flex:1}.milestone-header-content h3{margin:0 0 .5rem;color:#1f2937;font-size:1.125rem}.milestone-child{color:#3b82f6;font-weight:500;font-size:.875rem;margin:0}.milestone-details{display:flex;flex-direction:column;gap:.75rem}.detail-row{display:flex;gap:.5rem;flex-wrap:wrap}.achieved-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;background-color:#dcfce7;color:#166534}.milestone-notes{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.milestone-notes p{margin:0;color:#6b7280;font-size:.875rem;line-height:1.6}.messages-page{animation:fadeIn .3s ease-in}.messages-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.messages-header h1{margin:0 0 .5rem;color:#1f2937;font-size:2rem}.messages-header p{margin:0;color:#6b7280}.btn-compose{background-color:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-compose:hover{background-color:#2563eb}.messages-container{display:grid;grid-template-columns:350px 1fr;gap:1.5rem;height:calc(100vh - 250px)}.messages-list{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow:hidden;display:flex;flex-direction:column}.messages-list h2{padding:1.5rem;margin:0;border-bottom:1px solid #e5e7eb;color:#1f2937;font-size:1.25rem}.message-item{padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;cursor:pointer;transition:background-color .2s}.message-item:hover{background-color:#f9fafb}.message-item.active{background-color:#eff6ff;border-left:3px solid #3b82f6}.message-item.unread{background-color:#fef3c7}.message-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.message-sender{font-weight:600;color:#1f2937;font-size:.875rem}.unread-badge{color:#3b82f6;font-size:1rem}.message-subject{margin:.5rem 0;color:#374151;font-size:.9375rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message-preview{margin:.5rem 0;color:#6b7280;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message-time{color:#9ca3af;font-size:.75rem}.no-messages{padding:3rem 1.5rem;text-align:center;color:#9ca3af;font-style:italic}.message-detail{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow-y:auto}.compose-form-container{padding:2rem}.compose-form-container h2{margin:0 0 1.5rem;color:#1f2937}.compose-form{display:flex;flex-direction:column;gap:1.5rem}.compose-form .form-field{display:flex;flex-direction:column;gap:.5rem}.compose-form label{font-weight:500;color:#374151;font-size:.875rem}.compose-form input,.compose-form textarea{padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;font-family:inherit}.compose-form input:focus,.compose-form textarea:focus{outline:none;border-color:#3b82f6}.compose-form textarea{resize:vertical}.btn-send{background-color:#10b981;color:#fff;border:none;padding:.75rem 2rem;border-radius:.5rem;font-weight:500;font-size:1rem;cursor:pointer;transition:background-color .2s;align-self:flex-start}.btn-send:hover{background-color:#059669}.message-detail-content{display:flex;flex-direction:column;height:100%}.message-detail-header{padding:2rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:start}.message-detail-header h2{margin:0 0 .75rem;color:#1f2937;font-size:1.5rem}.message-meta{display:flex;flex-direction:column;gap:.25rem;color:#6b7280;font-size:.875rem}.btn-delete-message{background-color:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-weight:500;transition:background-color .2s;white-space:nowrap}.btn-delete-message:hover{background-color:#dc2626}.message-body{padding:2rem;flex:1;overflow-y:auto}.message-body p{color:#374151;line-height:1.7;margin:0;white-space:pre-wrap}.no-selection{display:flex;align-items:center;justify-content:center;height:100%;padding:2rem}.no-selection-content{text-align:center;color:#9ca3af}.no-selection-icon{font-size:4rem;display:block;margin-bottom:1rem}.no-selection-content p{margin:.5rem 0;font-size:1.125rem}.no-selection-hint{font-size:.875rem!important;font-style:italic}@media(max-width:968px){.messages-container{grid-template-columns:1fr}}.appointments-page{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.appointments-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.appointments-header h1{margin:0 0 .5rem;color:#1f2937;font-size:2rem}.appointments-header p{margin:0;color:#6b7280}.btn-book{background-color:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-book:hover{background-color:#2563eb}.booking-form-container{background:#fff;padding:2rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.booking-form-container h2{margin:0 0 1.5rem;color:#1f2937}.booking-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-weight:500;color:#374151;font-size:.875rem}.form-field input,.form-field select,.form-field textarea{padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;font-family:inherit}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:#3b82f6}.form-field textarea{resize:vertical}.btn-submit-appointment{background-color:#10b981;color:#fff;border:none;padding:.75rem 2rem;border-radius:.5rem;font-weight:500;font-size:1rem;cursor:pointer;transition:background-color .2s;align-self:flex-start}.btn-submit-appointment:hover{background-color:#059669}.appointments-filters{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filter-btn{padding:.75rem 1.5rem;border:1px solid #d1d5db;background:#fff;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s}.filter-btn:hover{background-color:#f3f4f6}.filter-btn.active{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.appointments-list{display:flex;flex-direction:column;gap:1rem}.appointment-item{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;overflow:hidden;display:flex;transition:box-shadow .2s}.appointment-item:hover{box-shadow:0 4px 6px #0000001a}.appointment-icon-container{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem}.appointment-icon{font-size:2.5rem}.appointment-content{flex:1;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.appointment-main{display:flex;justify-content:space-between;gap:2rem}.appointment-info h3{margin:0 0 .5rem;color:#1f2937;font-size:1.25rem}.appointment-type-text{color:#6b7280;font-size:.875rem;text-transform:capitalize;margin:.25rem 0;font-weight:500}.appointment-reason-text{color:#374151;margin:.5rem 0 0}.appointment-datetime{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.date-display{display:flex;flex-direction:column;align-items:center;padding:.5rem;background-color:#f9fafb;border-radius:.5rem;border:2px solid #e5e7eb;min-width:70px}.date-day{font-size:1.5rem;font-weight:700;color:#1f2937;line-height:1}.date-month{font-size:.75rem;color:#6b7280;text-transform:uppercase;margin-top:.25rem}.time-display{font-weight:600;color:#3b82f6;font-size:1rem}.duration-display{color:#9ca3af;font-size:.875rem}.appointment-footer{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding-top:1rem;border-top:1px solid #e5e7eb}.status-badge{padding:.375rem .875rem;border-radius:9999px;font-size:.75rem;font-weight:600;color:#fff;text-transform:capitalize}.appointment-notes-text{flex:1;color:#6b7280;font-size:.875rem;margin:0}.btn-cancel-appointment{background-color:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-weight:500;transition:background-color .2s;font-size:.875rem}.btn-cancel-appointment:hover{background-color:#dc2626}.no-appointments-found{text-align:center;padding:4rem 2rem;background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.no-appointments-found p{color:#9ca3af;font-size:1.125rem;margin:0 0 1.5rem}.btn-book-first{background-color:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-book-first:hover{background-color:#2563eb}@media(max-width:768px){.appointment-main{flex-direction:column;gap:1rem}.appointment-datetime{flex-direction:row;align-items:center}.appointment-icon-container{padding:1.5rem 1rem}.appointment-icon{font-size:2rem}}#root{min-height:100vh}.severity-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.severity-badge.mild{background-color:#fef3c7;color:#92400e}.severity-badge.moderate{background-color:#fed7aa;color:#9a3412}.severity-badge.severe{background-color:#fee2e2;color:#991b1b}.category-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;background-color:#dbeafe;color:#1e40af}
