@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--bg-primary:#fafafa;--bg-surface:#fff;--bg-surface-elevated:#f5f5f5;--bg-surface-hover:#f0f0f0;--bg-accent-subtle:#f0fdfa;--bg-danger-subtle:#fef2f2;--bg-warning-subtle:#fffbeb;--bg-success-subtle:#f0fdf4;--text-primary:#0a0a0a;--text-secondary:#525252;--text-tertiary:#a3a3a3;--text-inverse:#fff;--text-accent:#0d9488;--text-danger:#dc2626;--text-warning:#d97706;--text-success:#16a34a;--accent:#0d9488;--accent-hover:#0f766e;--accent-active:#115e59;--accent-light:#ccfbf1;--accent-subtle:#f0fdfa;--danger:#dc2626;--danger-hover:#b91c1c;--danger-light:#fee2e2;--warning:#f59e0b;--warning-light:#fef3c7;--success:#16a34a;--success-light:#dcfce7;--info:#2563eb;--info-light:#dbeafe;--border:#e5e5e5;--border-hover:#d4d4d4;--border-focus:#0d9488;--border-danger:#fca5a5;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000000f;--shadow-lg:0 8px 30px #00000014;--shadow-xl:0 16px 50px #0000001f;--shadow-accent:0 4px 14px #0d948840;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"SF Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.8125rem;--text-base:.875rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.2s cubic-bezier(.4, 0, .2, 1);--transition-slow:.3s cubic-bezier(.4, 0, .2, 1);--transition-spring:.4s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width:260px;--header-height:64px;--mobile-nav-height:64px;--max-content-width:1200px}[data-theme=dark]{--bg-primary:#0a0a0a;--bg-surface:#141414;--bg-surface-elevated:#1e1e1e;--bg-surface-hover:#262626;--bg-accent-subtle:#042f2e;--bg-danger-subtle:#450a0a;--bg-warning-subtle:#451a03;--bg-success-subtle:#052e16;--text-primary:#fafafa;--text-secondary:#a3a3a3;--text-tertiary:#737373;--text-inverse:#0a0a0a;--text-accent:#2dd4bf;--text-danger:#f87171;--text-warning:#fbbf24;--text-success:#4ade80;--accent:#2dd4bf;--accent-hover:#14b8a6;--accent-active:#0d9488;--accent-light:#134e4a;--accent-subtle:#042f2e;--danger:#f87171;--danger-light:#450a0a;--warning:#fbbf24;--warning-light:#451a03;--success:#4ade80;--success-light:#052e16;--border:#262626;--border-hover:#404040;--border-focus:#2dd4bf;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 8px 30px #0006;--shadow-xl:0 16px 50px #00000080}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background-color:var(--bg-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:var(--text-accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-hover)}img{max-width:100%;height:auto}input,textarea,select,button{font-family:inherit;font-size:inherit}::selection{background:var(--accent-light);color:var(--text-accent)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);z-index:50;transition:transform var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--border);align-items:center;gap:var(--space-3);display:flex}.sidebar-logo{background:linear-gradient(135deg, var(--accent), var(--accent-hover));border-radius:var(--radius-md);color:#fff;width:36px;height:36px;font-weight:700;font-size:var(--text-lg);justify-content:center;align-items:center;display:flex}.sidebar-brand{font-size:var(--text-md);color:var(--text-primary);letter-spacing:-.02em;font-weight:700}.sidebar-brand span{color:var(--accent)}.sidebar-nav{padding:var(--space-3) var(--space-3);flex:1;overflow-y:auto}.nav-section{margin-bottom:var(--space-6)}.nav-section-title{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1);font-weight:600}.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);font-weight:500;text-decoration:none;display:flex;position:relative}.nav-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-subtle);color:var(--accent);font-weight:600}.nav-item.active:before{content:"";background:var(--accent);border-radius:var(--radius-full);width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.nav-item-icon{text-align:center;flex-shrink:0;width:22px;font-size:1.15rem}.nav-item-badge{background:var(--danger);color:#fff;font-size:var(--text-xs);border-radius:var(--radius-full);text-align:center;min-width:20px;margin-left:auto;padding:1px 7px;font-weight:600}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border)}.sidebar-user{align-items:center;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);display:flex}.sidebar-user:hover{background:var(--bg-surface-hover)}.sidebar-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--accent), var(--accent-hover));color:#fff;width:36px;height:36px;font-weight:600;font-size:var(--text-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-weight:600;font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-user-role{font-size:var(--text-xs);color:var(--text-tertiary)}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-header{padding:var(--space-5) var(--space-8);border-bottom:1px solid var(--border);background:var(--bg-surface);z-index:40;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd9;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}[data-theme=dark] .page-header{background:#141414d9}.page-title{font-size:var(--text-xl);color:var(--text-primary);letter-spacing:-.02em;font-weight:700}.page-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.page-body{padding:var(--space-6) var(--space-8);max-width:var(--max-content-width);flex:1;width:100%}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.card-glass{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffb3;border:1px solid #ffffff4d}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-md);color:var(--text-primary);font-weight:600}.card-description{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.stats-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(90deg, var(--accent), var(--accent-hover));opacity:0;height:3px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.stat-card:hover:before{opacity:1}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-md);width:44px;height:44px;margin-bottom:var(--space-3);justify-content:center;align-items:center;font-size:1.3rem;display:flex}.stat-icon.accent{background:var(--accent-subtle);color:var(--accent)}.stat-icon.danger{background:var(--bg-danger-subtle);color:var(--text-danger)}.stat-icon.warning{background:var(--bg-warning-subtle);color:var(--text-warning)}.stat-icon.success{background:var(--bg-success-subtle);color:var(--text-success)}.stat-value{font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.02em;font-weight:700}.stat-label{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.stat-change{font-size:var(--text-xs);margin-top:var(--space-2);border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 8px;font-weight:600;display:inline-flex}.stat-change.up{background:var(--bg-success-subtle);color:var(--text-success)}.stat-change.down{background:var(--bg-danger-subtle);color:var(--text-danger)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:var(--shadow-accent);transform:translateY(-1px)}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-surface-hover);border-color:var(--border-hover)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-surface-hover);color:var(--text-primary)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-md)}.btn-xl{padding:var(--space-4) var(--space-8);font-size:var(--text-lg);border-radius:var(--radius-lg)}.btn-icon{padding:var(--space-2);width:40px;height:40px}.btn-full{width:100%}.btn .spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}.form-group{margin-bottom:var(--space-4)}.form-label{font-size:var(--text-sm);color:var(--text-primary);margin-bottom:var(--space-1);font-weight:600;display:block}.form-hint{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:var(--space-1)}.form-input{width:100%;padding:var(--space-2) var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-base);transition:all var(--transition-fast);outline:none}.form-input:hover{border-color:var(--border-hover)}.form-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #0d94881a}.form-input::placeholder{color:var(--text-tertiary)}.form-input.error{border-color:var(--danger);box-shadow:0 0 0 3px #dc26261a}.form-error{font-size:var(--text-xs);color:var(--text-danger);margin-top:var(--space-1);align-items:center;gap:4px;display:flex}textarea.form-input{resize:vertical;min-height:100px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23737373' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);letter-spacing:.02em;align-items:center;gap:4px;padding:2px 10px;font-weight:600;display:inline-flex}.badge-accent{background:var(--accent-subtle);color:var(--accent)}.badge-success{background:var(--bg-success-subtle);color:var(--text-success)}.badge-danger{background:var(--bg-danger-subtle);color:var(--text-danger)}.badge-warning{background:var(--bg-warning-subtle);color:var(--text-warning)}.badge-info{background:var(--info-light);color:var(--info)}.badge-neutral{background:var(--bg-surface-elevated);color:var(--text-secondary)}.table-container{border:1px solid var(--border);border-radius:var(--radius-lg);overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.table th{text-align:left;padding:var(--space-3) var(--space-4);font-weight:600;font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;background:var(--bg-surface-elevated);border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--bg-surface-hover)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;animation:fadeIn var(--transition-fast);padding:var(--space-4);background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;animation:slideUp var(--transition-base);overflow-y:auto}.modal-header{padding:var(--space-5) var(--space-5) 0;justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-lg);font-weight:700}.modal-body{padding:var(--space-5)}.modal-footer{padding:0 var(--space-5) var(--space-5);gap:var(--space-3);justify-content:flex-end;display:flex}.toast-container{top:var(--space-4);right:var(--space-4);z-index:200;gap:var(--space-2);flex-direction:column;display:flex;position:fixed}.toast{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-lg);align-items:center;gap:var(--space-3);min-width:320px;max-width:420px;animation:slideInRight var(--transition-base);display:flex}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.warning{border-left:3px solid var(--warning)}.safety-alert{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3);font-size:var(--text-sm);animation:slideDown var(--transition-base);display:flex}.safety-alert.critical{color:#991b1b;background:#fef2f2;border:1px solid #fca5a5}.safety-alert.high{color:#9a3412;background:#fff7ed;border:1px solid #fdba74}.safety-alert.medium{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.safety-alert.low{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.skeleton{background:linear-gradient(90deg, var(--bg-surface-elevated) 25%, var(--bg-surface-hover) 50%, var(--bg-surface-elevated) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.skeleton-text{height:14px;margin-bottom:var(--space-2)}.skeleton-title{width:60%;height:24px;margin-bottom:var(--space-3)}.skeleton-avatar{border-radius:var(--radius-full);width:40px;height:40px}.skeleton-card{height:120px}.timeline{padding-left:var(--space-8);position:relative}.timeline:before{content:"";background:var(--border);width:2px;position:absolute;top:0;bottom:0;left:15px}.timeline-item{padding-bottom:var(--space-6);position:relative}.timeline-dot{background:var(--accent);border:2px solid var(--bg-surface);width:12px;height:12px;box-shadow:0 0 0 3px var(--accent-light);border-radius:50%;position:absolute;top:4px;left:-25px}.timeline-dot.consultation{background:var(--accent)}.timeline-dot.prescription{background:var(--success)}.timeline-dot.report{background:var(--info)}.timeline-content{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4)}.timeline-date{font-size:var(--text-xs);color:var(--text-tertiary);margin-bottom:var(--space-1)}.auth-container{min-height:100vh;padding:var(--space-4);background:linear-gradient(135deg,#f0fdfa 0%,#fafafa 50%,#f5f5f5 100%);justify-content:center;align-items:center;display:flex}.auth-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;max-width:440px;box-shadow:var(--shadow-lg)}.auth-logo{text-align:center;margin-bottom:var(--space-6)}.auth-logo-icon{background:linear-gradient(135deg, var(--accent), var(--accent-hover));border-radius:var(--radius-lg);color:#fff;width:56px;height:56px;margin-bottom:var(--space-3);justify-content:center;align-items:center;font-size:1.75rem;font-weight:800;display:inline-flex}.auth-title{font-size:var(--text-2xl);color:var(--text-primary);text-align:center;margin-bottom:var(--space-1);font-weight:700}.auth-subtitle{font-size:var(--text-sm);color:var(--text-secondary);text-align:center;margin-bottom:var(--space-6)}.auth-divider{align-items:center;gap:var(--space-3);margin:var(--space-5) 0;font-size:var(--text-sm);color:var(--text-tertiary);display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-footer{text-align:center;margin-top:var(--space-5);font-size:var(--text-sm);color:var(--text-secondary)}.role-selector{gap:var(--space-3);margin-bottom:var(--space-5);grid-template-columns:1fr 1fr;display:grid}.role-option{padding:var(--space-4);border:2px solid var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--transition-fast)}.role-option:hover,.role-option.selected{border-color:var(--accent);background:var(--accent-subtle)}.role-option-icon{margin-bottom:var(--space-2);font-size:2rem}.role-option-title{font-weight:600;font-size:var(--text-sm);color:var(--text-primary)}.role-option-desc{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-1)}.mobile-nav{background:var(--bg-surface);border-top:1px solid var(--border);padding:var(--space-2) var(--space-4);z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:none;position:fixed;bottom:0;left:0;right:0}.mobile-nav-items{justify-content:space-around;align-items:center;display:flex}.mobile-nav-item{font-size:var(--text-xs);color:var(--text-tertiary);padding:var(--space-1);transition:color var(--transition-fast);flex-direction:column;align-items:center;gap:2px;text-decoration:none;display:flex}.mobile-nav-item.active{color:var(--accent)}.mobile-nav-item-icon{font-size:1.25rem}@media (max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{padding-bottom:var(--mobile-nav-height);margin-left:0}.mobile-nav{display:block}.page-body,.page-header{padding:var(--space-4)}.stats-grid{gap:var(--space-3);grid-template-columns:1fr 1fr}.auth-card{padding:var(--space-5)}}@media (max-width:480px){.stats-grid,.role-selector{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}.animate-fadeIn{animation:fadeIn var(--transition-base)}.animate-slideUp{animation:slideUp var(--transition-base)}.animate-bounceIn{animation:bounceIn var(--transition-spring)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--text-accent)}.text-danger{color:var(--text-danger)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.hidden{display:none}.w-full{width:100%}
