*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#2563eb;--primary-dark:#1d4ed8;--danger:#dc2626;--success:#16a34a;--bg:#f1f5f9;--card-bg:#fff;--text:#1e293b;--text-muted:#64748b;--border:#e2e8f0;--radius:12px;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow-lg:0 4px 12px #0000001a}html{font-size:16px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}button{cursor:pointer;font-family:inherit;font-size:inherit}input,textarea{font-family:inherit;font-size:1rem}.app-header{background:var(--primary);color:#fff;justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.app-header h1{font-size:1.3rem}.header-left{align-items:center;gap:16px;display:flex}.header-user{align-items:center;gap:12px;font-size:.9rem;display:flex}.btn-small{color:#fff;background:0 0;border:1px solid #fff6;border-radius:6px;padding:6px 14px;font-size:.85rem}.btn-small:hover{background:#ffffff26}.btn-back{color:#fff;background:0 0;border:none;padding:6px 12px;font-size:1rem}.btn-back:hover{text-decoration:underline}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-form{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:40px 32px}.login-title{text-align:center;margin-bottom:4px;font-size:2rem}.login-subtitle{text-align:center;color:var(--text-muted);margin-bottom:28px}.login-form label{margin-top:16px;margin-bottom:4px;font-size:.95rem;font-weight:600;display:block}.login-form input{border:1px solid var(--border);border-radius:8px;width:100%;padding:12px 14px;font-size:1rem}.login-form input:focus{outline:2px solid var(--primary);border-color:#0000}.login-form button[type=submit]{background:var(--primary);color:#fff;border:none;border-radius:8px;width:100%;margin-top:24px;padding:14px;font-size:1.05rem;font-weight:600}.login-form button[type=submit]:hover{background:var(--primary-dark)}.login-form button:disabled{opacity:.6}.login-error{color:var(--danger);margin-top:12px;font-size:.9rem}.login-hint{color:var(--text-muted);text-align:center;margin-top:20px;font-size:.82rem}.search-page{min-height:100vh}.search-main{text-align:center;max-width:640px;margin:60px auto;padding:0 24px}.search-main h2{margin-bottom:8px;font-size:1.8rem}.search-main>p{color:var(--text-muted);margin-bottom:24px}.search-box input{border:2px solid var(--border);width:100%;box-shadow:var(--shadow);border-radius:12px;padding:16px 20px;font-size:1.15rem}.search-box input:focus{border-color:var(--primary);outline:none}.search-results{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);text-align:start;margin-top:12px;overflow:hidden}.search-results ul{list-style:none}.result-item{text-align:start;background:0 0;border:none;align-items:center;gap:16px;width:100%;padding:14px 20px;font-size:1rem;display:flex}.result-item:hover{background:#f0f4ff}.result-avatar{object-fit:cover;border-radius:50%;width:48px;height:48px}.result-meta{color:var(--text-muted);font-size:.85rem;display:block}.no-results{color:var(--text-muted);text-align:center;padding:20px}.patient-page{min-height:100vh;padding-bottom:40px}.patient-header{background:var(--card-bg);border-radius:var(--radius);max-width:1000px;box-shadow:var(--shadow);align-items:center;gap:20px;margin:24px auto;padding:20px 24px;display:flex}.patient-photo{object-fit:cover;border:3px solid var(--primary);border-radius:50%;width:80px;height:80px}.patient-info h2{font-size:1.5rem}.patient-info p{color:var(--text-muted)}.widget-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;max-width:1000px;margin:0 auto;padding:0 24px;display:grid}.widget-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;padding:16px 20px;transition:box-shadow .15s;display:flex}.widget-card:hover{box-shadow:var(--shadow-lg)}.widget-editing{outline:2px solid var(--primary)}.widget-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.widget-icon{font-size:1.5rem}.widget-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.95rem;font-weight:700}.widget-body{flex-direction:column;flex:1;display:flex}.widget-value{flex:1;margin-bottom:10px;font-size:1.05rem}.widget-body textarea{border:1px solid var(--border);resize:vertical;border-radius:8px;width:100%;margin-bottom:8px;padding:10px;font-size:1rem}.widget-body textarea:focus{outline:2px solid var(--primary);border-color:#0000}.widget-actions{gap:8px;display:flex}.btn-edit{border:1px solid var(--border);background:#fff;border-radius:8px;align-self:flex-start;padding:8px 16px;font-size:.9rem}.btn-edit:hover{border-color:var(--primary);background:#f0f4ff}.btn-save{background:var(--success);color:#fff;border:none;border-radius:8px;padding:8px 20px;font-weight:600}.btn-save:hover{filter:brightness(.9)}.btn-cancel{border:1px solid var(--border);background:#fff;border-radius:8px;padding:8px 20px}.btn-cancel:hover{border-color:var(--danger);background:#fef2f2}.btn-save:disabled,.btn-cancel:disabled{opacity:.5}.widget-error{color:var(--danger);margin-bottom:6px;font-size:.85rem}.loading{height:100vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:1.2rem;display:flex}@media (width<=600px){.widget-grid{grid-template-columns:1fr}.patient-header{text-align:center;flex-direction:column}.app-header{flex-direction:column;gap:8px}.admin-tabs{flex-direction:column}.permissions-table-wrapper{overflow-x:auto}}.admin-page{min-height:100vh;padding-bottom:40px}.admin-tabs{border-bottom:2px solid var(--border);gap:0;max-width:1000px;margin:24px auto 0;padding:0 24px;display:flex}.admin-tab{color:var(--text-muted);background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;padding:12px 24px;font-size:1rem;font-weight:600;transition:color .15s,border-color .15s}.admin-tab:hover{color:var(--text)}.admin-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.admin-panel{max-width:1000px;margin:24px auto;padding:0 24px}.admin-section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.admin-section-header h2{font-size:1.4rem}.admin-subtitle{color:var(--text-muted);margin-bottom:16px}.admin-table{border-collapse:collapse;background:var(--card-bg);border-radius:var(--radius);width:100%;box-shadow:var(--shadow);overflow:hidden}.admin-table th,.admin-table td{text-align:right;border-bottom:1px solid var(--border);padding:12px 16px}.admin-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;background:#f8fafc;font-size:.9rem;font-weight:700}.admin-table tbody tr:hover{background:#f0f4ff}.admin-table tbody tr:last-child td{border-bottom:none}.admin-actions{gap:8px;display:flex}.checkbox-cell{text-align:center!important}.checkbox-cell input[type=checkbox]{cursor:pointer;width:20px;height:20px}.widget-icon-small{margin-left:8px}.permissions-table-wrapper{overflow-x:auto}.permissions-table th,.permissions-table td{text-align:center}.permissions-table td:first-child,.permissions-table th:first-child{text-align:right;white-space:nowrap}.admin-form{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);max-width:500px;margin-bottom:24px;padding:24px}.admin-form h3{margin-bottom:16px;font-size:1.2rem}.admin-form label{margin-top:12px;margin-bottom:4px;font-size:.95rem;font-weight:600;display:block}.admin-form input,.admin-form select{border:1px solid var(--border);border-radius:8px;width:100%;padding:10px 14px;font-family:inherit;font-size:1rem}.admin-form input:focus,.admin-form select:focus{outline:2px solid var(--primary);border-color:#0000}.admin-form-actions{gap:8px;margin-top:20px;display:flex}.btn-add{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:.95rem;font-weight:600}.btn-add:hover{background:var(--primary-dark)}.btn-edit-small{border:1px solid var(--border);background:#fff;border-radius:6px;padding:6px 10px;font-size:.9rem}.btn-edit-small:hover{border-color:var(--primary);background:#f0f4ff}.btn-delete{border:1px solid var(--border);background:#fff;border-radius:6px;padding:6px 10px;font-size:.9rem}.btn-delete:hover{border-color:var(--danger);background:#fef2f2}.btn-admin{color:#fff;background:#ffffff26;border:1px solid #fff6;border-radius:6px;padding:6px 14px;font-size:.85rem;font-weight:600}.btn-admin:hover{background:#ffffff4d}.success-message{color:var(--success);background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin-bottom:16px;padding:10px 16px;font-weight:500}.error-message{color:var(--danger);background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px;padding:10px 16px;font-weight:500}.text-muted{color:var(--text-muted)}.widget-config-form{max-width:600px}.options-editor{margin-top:12px}.options-list{margin:8px 0;list-style:none}.option-item{border:1px solid var(--border);background:#f8fafc;border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:6px;padding:8px 12px;display:flex}.option-text{flex:1;font-size:.95rem}.option-actions{gap:4px;display:flex}.btn-icon{border:1px solid var(--border);background:#fff;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;display:flex}.btn-icon:hover{border-color:var(--primary);background:#f0f4ff}.btn-icon:disabled{opacity:.3;cursor:default}.btn-icon-danger:hover{border-color:var(--danger);background:#fef2f2}.option-add-row{gap:8px;margin-top:8px;display:flex}.option-add-row input{flex:1}.btn-add-small{background:var(--primary);color:#fff;white-space:nowrap;border:none;border-radius:8px;padding:8px 16px;font-size:.9rem;font-weight:600}.btn-add-small:hover{background:var(--primary-dark)}.widget-select{border:1px solid var(--border);background:#fff;border-radius:8px;width:100%;margin-bottom:8px;padding:10px 14px;font-family:inherit;font-size:1rem}.widget-select:focus{outline:2px solid var(--primary);border-color:#0000}
