:root{--primary: #428bca;--primary-dark: #357abd;--success: #198754;--warning: #fd7e14;--danger: #dc3545;--bg-body: #f5f5f5;--bg-card: #ffffff;--text-primary: #333333;--text-muted: #6c757d;--border: #dee2e6}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-body);color:var(--text-primary);line-height:1.5}.app{max-width:1200px;margin:0 auto;padding:20px}.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.app-header h1{margin:0;font-size:1.75rem}.back-link{display:inline-block;color:var(--primary);text-decoration:none;margin-bottom:5px;font-size:.9rem}.back-link:hover{text-decoration:underline}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{background:var(--bg-card);padding:40px;border-radius:8px;box-shadow:0 2px 10px #0000001a;width:100%;max-width:400px}.auth-card h1{margin:0 0 5px;color:var(--primary);text-align:center}.auth-card h2{margin:0 0 25px;text-align:center;font-weight:400;color:var(--text-muted)}.auth-links{text-align:center;margin-top:20px}.auth-links a{color:var(--primary);text-decoration:none}.auth-links a:hover{text-decoration:underline}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:4px;font-size:1rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #428bca33}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.form-grid .full-width{grid-column:1 / -1}.form-help{display:block;margin-top:4px;font-size:.8rem;color:var(--text-muted)}.btn-primary{background:var(--primary);color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:1rem;width:100%}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border);padding:10px 20px;border-radius:4px;cursor:pointer;font-size:1rem}.btn-secondary:hover{background:var(--bg-body)}.upload-btn{cursor:pointer;display:inline-block}.btn-small{padding:5px 10px;font-size:.85rem;border-radius:4px;border:1px solid var(--border);background:#fff;cursor:pointer;margin-right:5px}.btn-small:hover{background:var(--bg-body)}.btn-warning{border-color:var(--warning);color:var(--warning)}.btn-danger{border-color:var(--danger);color:var(--danger)}.btn-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted)}.user-menu{position:relative}.user-menu-toggle{background:#fff;border:1px solid var(--border);padding:8px 15px;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:8px}.user-menu-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid var(--border);border-radius:4px;box-shadow:0 4px 12px #00000026;min-width:180px;z-index:100}.user-menu-dropdown a,.user-menu-dropdown button{display:block;width:100%;padding:10px 15px;text-align:left;text-decoration:none;color:var(--text-primary);background:none;border:none;cursor:pointer;font-size:.95rem}.user-menu-dropdown a:hover,.user-menu-dropdown button:hover{background:var(--bg-body)}.user-menu-dropdown hr{margin:5px 0;border:none;border-top:1px solid var(--border)}.header-controls{display:flex;align-items:center;gap:10px}.profile-selector{position:relative}.profile-selector-toggle{background:#fff;border:1px solid var(--border);padding:6px 12px;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:.9rem}.profile-selector-toggle:hover{border-color:var(--primary)}.profile-icon{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.profile-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid var(--border);border-radius:4px;box-shadow:0 4px 12px #00000026;min-width:220px;z-index:100;margin-top:4px}.profile-dropdown-header{padding:10px 15px;font-size:.8rem;color:var(--text-muted);text-transform:uppercase;border-bottom:1px solid var(--border)}.profile-option-row{display:flex;align-items:center}.profile-option{display:flex;align-items:center;gap:10px;flex:1;padding:10px 15px;background:none;border:none;cursor:pointer;text-align:left}.profile-option:hover{background:var(--bg-body)}.profile-option.active{background:#e8f4fd}.profile-delete-btn{padding:5px 10px;background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;opacity:.5}.profile-delete-btn:hover{color:var(--danger);opacity:1}.profile-option-details{flex:1;display:flex;flex-direction:column}.profile-option-name{font-weight:500}.profile-option-relationship{font-size:.8rem;color:var(--text-muted)}.check-mark{color:var(--primary);font-weight:700}.profile-add-btn{display:block;width:100%;padding:12px 15px;background:none;border:none;cursor:pointer;text-align:left;color:var(--primary);font-size:.95rem}.profile-add-btn:hover{background:var(--bg-body)}.profile-add-form{padding:15px;display:flex;flex-direction:column;gap:10px}.profile-add-form input{padding:8px 12px;border:1px solid var(--border);border-radius:4px;font-size:.9rem}.profile-add-actions{display:flex;gap:10px;justify-content:flex-end}.profile-add-actions button{padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.9rem}.profile-add-actions button:first-child{background:none;border:1px solid var(--border)}.profile-dropdown hr{margin:5px 0;border:none;border-top:1px solid var(--border)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:var(--bg-card);padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.stat-value{font-size:2rem;font-weight:700;color:var(--primary)}.stat-label{color:var(--text-muted);margin-top:5px}.stat-link{display:inline-block;margin-top:10px;color:var(--primary);text-decoration:none;font-size:.9rem}.section{background:var(--bg-card);padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 1px 3px #0000001a}.section h2{margin:0 0 15px;font-size:1.25rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.section-header h2{margin:0}.section-header a{color:var(--primary);text-decoration:none}.quick-actions{display:flex;flex-wrap:wrap;gap:10px}.action-button{background:var(--primary);color:#fff;padding:10px 20px;border-radius:4px;text-decoration:none;font-size:.9rem}.action-button:hover{background:var(--primary-dark)}.toolbar{display:flex;gap:15px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.checkbox-label{display:flex;align-items:center;gap:5px;cursor:pointer}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px;text-align:left;border-bottom:1px solid var(--border)}th{background:var(--bg-body);font-weight:600}tr:hover{background:#428bca0d}.inactive-row{opacity:.6}.badge-inactive{display:inline-block;background:var(--text-muted);color:#fff;padding:2px 8px;border-radius:10px;font-size:.75rem;margin-left:8px}.actions{display:flex;gap:5px}.portal-link{display:inline-block;margin-left:8px;font-size:.8rem;color:var(--primary);text-decoration:none}.portal-link:hover{text-decoration:underline}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:8px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border)}.modal-header h2{margin:0}.modal-content .form-grid{padding:20px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:20px;border-top:1px solid var(--border)}.modal-footer .btn-primary,.modal-footer .btn-secondary{width:auto}.message{padding:12px 15px;border-radius:4px;margin-bottom:20px;position:fixed;bottom:20px;left:20px;right:20px;z-index:2000;box-shadow:0 4px 12px #0000004d;font-size:1rem;word-wrap:break-word}.message.success{background:#d4edda;color:#155724}.message.error{background:#f8d7da;color:#721c24}.error-message{background:#f8d7da;color:#721c24;padding:10px;border-radius:4px;margin-bottom:15px}.success-message{background:#d4edda;color:#155724;padding:10px;border-radius:4px;margin-bottom:15px}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}.empty-state a{color:var(--primary)}.loading-container{text-align:center;padding:40px;color:var(--text-muted)}.discrepancy-row{background:#fff3cd}.discrepancy-row:hover{background:#ffecb5}.discrepancy-badge{display:inline-block;background:var(--warning);color:#fff;padding:2px 6px;border-radius:4px;font-size:.75rem;margin-top:4px}.balance-due{color:var(--danger);font-size:.85rem;font-weight:500}.status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.8rem;font-weight:500;text-transform:capitalize}.status-pending{background:#fff3cd;color:#856404}.status-paid{background:#d4edda;color:#155724}.status-disputed{background:#f8d7da;color:#721c24}.status-collections{background:#d6d8db;color:#383d41}.stat-card-warning{border-left:4px solid var(--warning)}.stat-detail{font-size:.85rem;color:var(--text-muted);margin-top:4px}.text-muted{color:var(--text-muted);font-size:.85rem}.form-section-header{font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);padding-bottom:8px;margin-top:10px;margin-bottom:5px}.modal-large{max-width:650px}.payment-summary{padding:15px 20px;background:var(--bg-body);border-bottom:1px solid var(--border)}.payment-summary p{margin:5px 0}.balance-highlight{font-weight:600;color:var(--danger)}.settings-section{background:var(--bg-card);padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 1px 3px #0000001a}.settings-section h2{margin:0 0 20px;font-size:1.25rem;padding-bottom:10px;border-bottom:1px solid var(--border)}.settings-section .form-group{max-width:400px}.settings-section .btn-primary{width:auto;margin-top:10px}.info-row{display:flex;padding:10px 0}.info-label{font-weight:500;width:120px;color:var(--text-muted)}.info-value{color:var(--text-primary)}.med-list{display:flex;flex-direction:column;gap:12px}.med-card{background:var(--bg-card);border-radius:8px;padding:15px;box-shadow:0 1px 3px #0000001a}.med-card-inactive{opacity:.6}.med-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px}.med-card-title{font-size:1.1rem}.med-card-title .badge-inactive{margin-left:8px}.med-card-actions{display:flex;gap:5px;flex-shrink:0}.med-card-details{display:flex;flex-wrap:wrap;gap:8px;color:var(--text-muted);font-size:.9rem}.med-detail{background:var(--bg-body);padding:3px 8px;border-radius:4px}.scanner-modal{max-width:500px}.scanner-container{position:relative;background:#000;aspect-ratio:4/3;overflow:hidden}.scanner-video{width:100%;height:100%;object-fit:cover}.scanner-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.scanner-frame{width:80%;height:60%;border:3px solid var(--primary);border-radius:8px;box-shadow:0 0 0 9999px #00000080}.scanner-instructions{text-align:center;padding:15px;color:var(--text-muted);font-size:.9rem}.captured-photos{display:flex;gap:8px;padding:10px;background:var(--bg-body);overflow-x:auto}.captured-thumb{position:relative;flex-shrink:0;width:60px;height:60px;border-radius:4px;overflow:hidden}.captured-thumb img{width:100%;height:100%;object-fit:cover}.thumb-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;background:var(--danger);color:#fff;border:none;font-size:14px;line-height:1;cursor:pointer}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:15px}.insurance-card{background:var(--bg-card);border-radius:8px;padding:15px;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:box-shadow .2s}.insurance-card:hover{box-shadow:0 4px 12px #00000026}.insurance-card-name{font-size:1.1rem;font-weight:600;margin-bottom:8px}.insurance-card-detail{color:var(--text-muted);font-size:.9rem;margin-bottom:4px}.insurance-card-actions{margin-top:12px;display:flex;gap:5px}.card-images{display:flex;flex-direction:column;gap:15px;padding:15px}.card-image-container{text-align:center}.card-image-label{font-weight:500;margin-bottom:8px;color:var(--text-muted)}.card-image{max-width:100%;max-height:250px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.card-image-placeholder{padding:40px;background:var(--bg-body);border-radius:8px;color:var(--text-muted);text-align:center}.card-details{padding:0 20px 20px;display:flex;flex-direction:column;gap:8px}.card-details a{color:var(--primary)}.image-upload{min-height:80px}.image-preview{position:relative;display:inline-block}.image-preview img{max-width:100%;max-height:120px;border-radius:4px}.remove-image{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;background:var(--danger);color:#fff;border:none;font-size:16px;cursor:pointer;line-height:1}.filter-tabs{display:flex;gap:5px}.filter-tab{padding:8px 16px;border:1px solid var(--border);background:#fff;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.filter-tab:hover{background:var(--bg-body)}.filter-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.appointment-list{display:flex;flex-direction:column;gap:12px}.appointment-card{background:var(--bg-card);border-radius:8px;padding:15px;box-shadow:0 1px 3px #0000001a;display:flex;gap:15px;align-items:flex-start}.appointment-card-date{min-width:100px;text-align:center;padding:10px;background:var(--bg-body);border-radius:6px}.appointment-date-main{font-weight:600;font-size:.9rem;color:var(--text-primary)}.appointment-time{font-size:.85rem;color:var(--primary);margin-top:4px}.appointment-card-content{flex:1;min-width:0}.appointment-card-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}.appointment-title{font-size:1.1rem;font-weight:600}.appointment-type-badge{display:inline-block;background:#e8f4fd;color:var(--primary);padding:2px 8px;border-radius:10px;font-size:.75rem}.appointment-doctor{color:var(--text-muted);font-size:.9rem;margin-bottom:4px}.appointment-location{color:var(--text-muted);font-size:.85rem}.appointment-reason{color:var(--text-muted);font-size:.85rem;font-style:italic;margin-top:4px}.appointment-card-actions{display:flex;flex-direction:column;gap:5px}.appointment-card-inactive{opacity:.7}.status-primary{background:#e8f4fd;color:var(--primary)}.status-success{background:#d4edda;color:#155724}.status-muted{background:#e9ecef;color:#6c757d}.status-danger{background:#f8d7da;color:#721c24}.status-warning{background:#fff3cd;color:#856404}.btn-success{border-color:var(--success);color:var(--success)}.btn-success:hover{background:var(--success);color:#fff}.status-filter-select{padding:8px 12px;border:1px solid var(--border);border-radius:4px;font-size:.9rem;background:#fff;cursor:pointer}.status-filter-select:focus{outline:none;border-color:var(--primary)}.status-quick-change{padding:5px 8px;font-size:.8rem;cursor:pointer}.allergy-list{display:flex;flex-direction:column;gap:12px}.allergy-card{background:var(--bg-card);border-radius:8px;padding:15px;box-shadow:0 1px 3px #0000001a;display:flex;gap:15px;align-items:flex-start}.allergy-card-critical{border-left:4px solid var(--danger);background:#fff5f5}.allergy-card-content{flex:1;min-width:0}.allergy-card-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}.allergy-name{font-size:1.1rem;font-weight:600}.allergy-type-badge{display:inline-block;background:#e8f4fd;color:var(--primary);padding:2px 8px;border-radius:10px;font-size:.75rem}.allergy-reaction{color:var(--text-primary);font-size:.9rem;margin-bottom:4px}.allergy-notes{color:var(--text-muted);font-size:.85rem;font-style:italic}.allergy-card-actions{display:flex;flex-direction:column;gap:5px}.severity-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.75rem;font-weight:500}.severity-success{background:#d4edda;color:#155724}.severity-warning{background:#fff3cd;color:#856404}.severity-danger{background:#f8d7da;color:#721c24}.severity-critical{background:#721c24;color:#fff}.stat-card-critical{border-left:4px solid var(--danger)}.vitals-quick-add{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:20px}.vital-stat-card{background:var(--bg-card);border-radius:8px;padding:15px;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s;position:relative}.vital-stat-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.vital-stat-icon{font-size:1.5rem}.vital-stat-content{flex:1;min-width:0}.vital-stat-label{font-size:.8rem;color:var(--text-muted);margin-bottom:2px}.vital-stat-value{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.vital-stat-unit{font-size:.8rem;font-weight:400;color:var(--text-muted)}.vital-stat-date{font-size:.75rem;color:var(--text-muted)}.vital-stat-empty{font-size:.85rem;color:var(--text-muted);font-style:italic}.vital-stat-add{position:absolute;top:8px;right:10px;font-size:1.2rem;color:var(--primary);opacity:0;transition:opacity .2s}.vital-stat-card:hover .vital-stat-add{opacity:1}.vitals-list{display:flex;flex-direction:column;gap:10px}.vital-card{background:var(--bg-card);border-radius:8px;padding:12px 15px;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;gap:12px}.vital-card-icon{font-size:1.25rem}.vital-card-content{flex:1;min-width:0}.vital-card-header{display:flex;align-items:center;gap:10px;margin-bottom:2px}.vital-card-type{font-weight:500;font-size:.9rem}.vital-card-date{font-size:.8rem;color:var(--text-muted)}.vital-card-value{font-size:1.1rem;font-weight:600;color:var(--primary)}.vital-card-unit{font-size:.85rem;font-weight:400;color:var(--text-muted)}.vital-card-notes{font-size:.8rem;color:var(--text-muted);margin-top:4px}.vital-card-actions{display:flex;gap:5px}.immunization-list{display:flex;flex-direction:column;gap:12px}.immunization-card{background:var(--bg-card);border-radius:8px;padding:15px;box-shadow:0 1px 3px #0000001a;display:flex;gap:15px;align-items:flex-start}.immunization-card-content{flex:1;min-width:0}.immunization-card-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}.immunization-name{font-size:1.1rem;font-weight:600}.immunization-type-badge{display:inline-block;background:#e8f4fd;color:var(--primary);padding:2px 8px;border-radius:10px;font-size:.75rem}.immunization-dose-badge{display:inline-block;background:#d4edda;color:#155724;padding:2px 8px;border-radius:10px;font-size:.75rem}.immunization-date{color:var(--text-muted);font-size:.9rem;margin-bottom:4px}.immunization-detail{color:var(--text-muted);font-size:.85rem}.immunization-next-dose{font-size:.9rem;color:var(--primary);margin-top:6px}.immunization-next-dose.overdue{color:var(--danger)}.overdue-badge{display:inline-block;background:var(--danger);color:#fff;padding:2px 6px;border-radius:4px;font-size:.7rem;margin-left:8px}.immunization-notes{color:var(--text-muted);font-size:.85rem;font-style:italic;margin-top:6px}.immunization-card-actions{display:flex;flex-direction:column;gap:5px}.alert-box{padding:12px 15px;border-radius:6px;margin-bottom:15px;font-size:.9rem}.alert-box strong{display:block;margin-bottom:4px}.alert-item{display:inline-block;margin-right:15px}.alert-warning{background:#fff3cd;color:#856404;border-left:4px solid var(--warning)}.alert-info{background:#e8f4fd;color:var(--primary-dark);border-left:4px solid var(--primary)}@media(max-width:768px){.form-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.toolbar{flex-direction:column;align-items:stretch}.app-header{flex-direction:column;align-items:flex-start;gap:10px}.appointment-card{flex-direction:column}.appointment-card-date{width:100%;display:flex;justify-content:space-between;align-items:center}.appointment-card-actions{flex-direction:row;width:100%}.filter-tabs{width:100%;justify-content:stretch}.filter-tab{flex:1;text-align:center}.allergy-card{flex-direction:column}.allergy-card-actions{flex-direction:row;width:100%}.vitals-quick-add{grid-template-columns:repeat(2,1fr)}.vital-card{flex-wrap:wrap}.vital-card-actions{width:100%;justify-content:flex-end;margin-top:8px}.immunization-card{flex-direction:column}.immunization-card-actions{flex-direction:row;width:100%}}
