@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--color-primary:#10b981;--color-primary-hover:#059669;--color-primary-dim:#10b9811f;--color-primary-border:#10b9814d;--color-primary-text:#070c1a;--color-bg:#070c1a;--color-bg-secondary:#0d1526;--color-surface:#ffffff0a;--color-surface-hover:#ffffff12;--color-surface-elevated:#ffffff0f;--color-border:#ffffff14;--color-border-hover:#ffffff24;--color-text:#f0f4f8;--color-text-secondary:#a0aec0;--color-text-muted:#718096;--color-success:#22c55e;--color-success-dim:#22c55e1f;--color-warning:#f59e0b;--color-warning-dim:#f59e0b1f;--color-danger:#ef4444;--color-danger-dim:#ef44441f;--color-info:#3b82f6;--color-info-dim:#3b82f61f;--tooth-healthy:#22c55e;--tooth-caries:#ef4444;--tooth-missing:#6b7280;--tooth-crown:#f59e0b;--tooth-root_canal:#8b5cf6;--tooth-implant:#3b82f6;--tooth-bridge:#06b6d4;--tooth-filling:#ec4899;--tooth-extraction_needed:#f97316;--tooth-fractured:#dc2626;--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:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #10b98126;--color-topbar-bg:#070c1ad9;--color-modal-overlay:#000000b3;--sidebar-width:240px;--topbar-height:64px;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif}[data-theme=light]{--color-bg:#f8fafc;--color-bg-secondary:#fff;--color-surface:#fff;--color-surface-hover:#f1f5f9;--color-surface-elevated:#fff;--color-border:#e2e8f0;--color-border-hover:#cbd5e1;--color-text:#0f172a;--color-text-secondary:#334155;--color-text-muted:#475569;--color-primary:#059669;--color-primary-hover:#047857;--color-primary-dim:#05966926;--color-primary-border:#05966966;--color-primary-text:#fff;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-glow:0 0 20px #05966933;--color-topbar-bg:#ffffffd9;--color-modal-overlay:#0f172a80;--color-success-dim:#22c55e26;--color-warning-dim:#f59e0b26;--color-danger-dim:#ef444426;--color-info-dim:#3b82f626}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;width:100%;font-size:16px}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;width:100%;min-height:100dvh;line-height:1.6}@media (display-mode:standalone){body{overscroll-behavior-y:none}}a,button,[role=button]{touch-action:manipulation}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}h1{font-size:2rem;font-weight:700;line-height:1.2}h2{font-size:1.5rem;font-weight:700;line-height:1.3}h3{font-size:1.25rem;font-weight:600;line-height:1.3}h4{font-size:1.1rem;font-weight:600;line-height:1.4}h5{font-size:1rem;font-weight:600;line-height:1.4}h6{font-size:.875rem;font-weight:600;line-height:1.4}p{color:var(--color-text-secondary)}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-hover)}.app-layout{width:100%;min-height:100dvh;display:flex;overflow-x:hidden}.main-content{margin-left:var(--sidebar-width);width:100%;min-width:0;min-height:100dvh;transition:margin-left var(--transition-slow);flex-direction:column;flex:1;display:flex;overflow-x:hidden}.page-content{padding:var(--space-8);padding-top:calc(var(--topbar-height) + var(--space-8));flex:1;width:100%;min-width:0;max-width:1600px;margin:0 auto}.sidebar{height:100dvh;width:var(--sidebar-width);background:var(--color-bg-secondary);border-right:1px solid var(--color-border);z-index:100;transition:transform var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.sidebar-logo{padding:var(--space-4) var(--space-4);align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.sidebar-logo-icon{background:var(--color-primary-dim);border:1px solid var(--color-primary-border);border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logo-text{color:var(--color-text);letter-spacing:-.01em;font-size:1.15rem;font-weight:700}.sidebar-nav{padding:var(--space-2) var(--space-3);flex-direction:column;flex:1;gap:2px;display:flex}.sidebar-section-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-3) var(--space-3) var(--space-2);margin-top:var(--space-3);font-size:.6875rem;font-weight:600}.sidebar-link{align-items:center;gap:var(--space-3);padding:6px var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;width:100%;font-size:.9rem;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-link:hover{background:var(--color-surface-hover);color:var(--color-text)}.sidebar-link.active{background:var(--color-primary-dim);color:var(--color-primary);font-weight:600}.sidebar-link.active:before{content:"";background:var(--color-primary);border-radius:0 2px 2px 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link svg{flex-shrink:0;width:18px;height:18px}.sidebar-footer{padding:var(--space-3) var(--space-3);border-top:1px solid var(--color-border);flex-shrink:0}.sidebar-user{align-items:center;gap:var(--space-3);padding:6px var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer;display:flex}.sidebar-user:hover{background:var(--color-surface-hover)}.user-avatar{border-radius:var(--radius-full);background:var(--color-primary-dim);border:1px solid var(--color-primary-border);width:34px;height:34px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.user-info{flex:1;overflow:hidden}.user-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.user-role{color:var(--color-text-muted);text-transform:capitalize;font-size:.75rem}.capitalize-name{text-transform:capitalize}.topbar{top:0;right:0;left:var(--sidebar-width);height:var(--topbar-height);background:var(--color-topbar-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);padding:0 var(--space-8);z-index:99;transition:left var(--transition-slow);justify-content:space-between;align-items:center;min-width:0;max-width:100%;display:flex;position:fixed}.topbar-title{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:1.1rem;font-weight:700;overflow:hidden}.topbar-subtitle{color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;margin-top:1px;font-size:.8rem;overflow:hidden}.topbar-right{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.topbar>.flex{min-width:0}.mobile-menu-btn{background:var(--color-surface);border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;display:none}.mobile-menu-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);min-width:0;transition:border-color var(--transition-fast), box-shadow var(--transition-fast)}.card:hover{border-color:var(--color-border-hover)}.card-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.card-title{color:var(--color-text);font-size:1rem;font-weight:600}.card-subtitle{color:var(--color-text-muted);margin-top:var(--space-1);font-size:.8rem}.stat-grid{gap:var(--space-4);margin-bottom:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.stat-grid-4x3{gap:var(--space-4);margin-bottom:var(--space-8);grid-template-columns:repeat(4,1fr);display:grid}@media (max-width:1024px){.stat-grid-4x3{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.stat-grid-4x3{grid-template-columns:1fr}}.stat-grid-3x4{gap:var(--space-4);grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(3,1fr);height:calc(100vh - 240px);margin-bottom:0;display:grid}@media (max-width:1024px){.stat-grid-3x4{grid-template-columns:repeat(2,1fr);min-height:auto}}@media (max-width:480px){.stat-grid-3x4{grid-template-columns:1fr}}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);align-items:flex-start;gap:var(--space-4);transition:all var(--transition-fast);cursor:pointer;display:flex}.stat-card-tall{padding:0 var(--space-6);align-items:center;height:100%}.stat-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-icon.primary{background:var(--color-primary-dim);color:var(--color-primary)}.stat-icon.success{background:var(--color-success-dim);color:var(--color-success)}.stat-icon.warning{background:var(--color-warning-dim);color:var(--color-warning)}.stat-icon.danger{background:var(--color-danger-dim);color:var(--color-danger)}.stat-icon.info{background:var(--color-info-dim);color:var(--color-info)}.stat-value{color:var(--color-text);font-size:1.75rem;font-weight:800;line-height:1}.stat-label{color:var(--color-text-muted);margin-top:var(--space-1);font-size:.8rem}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;font-size:.9rem;font-weight:600;line-height:1;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:16px;height:16px}.btn-primary{background:var(--color-primary);color:var(--color-primary-text);border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:var(--color-primary-text);box-shadow:0 4px 16px var(--color-primary-border);transform:translateY(-1px)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-hover);color:var(--color-text)}.btn-danger{background:var(--color-danger-dim);color:var(--color-danger);border-color:#ef44444d}.btn-danger:hover:not(:disabled){background:var(--color-danger);color:#fff}.btn-ghost{color:var(--color-text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:.8rem}.btn-lg{padding:var(--space-4) var(--space-8);font-size:1rem}.btn-icon{padding:var(--space-2);width:36px;height:36px}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.form-label span.required{color:var(--color-danger);margin-left:2px}.form-input,.form-select,.form-textarea{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-sans);padding:var(--space-3) var(--space-4);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);min-font-size:16px;outline:none;font-size:.9rem}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-dim)}.form-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a97a8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-select option{background:var(--color-bg-secondary);color:var(--color-text)}.form-textarea{resize:vertical;min-height:80px}.form-error{color:var(--color-danger);font-size:.8rem}.form-hint{color:var(--color-text-muted);font-size:.8rem}.form-grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.form-grid-3{gap:var(--space-4);grid-template-columns:1fr 1fr 1fr;display:grid}.search-bar{align-items:center;display:flex;position:relative}.search-bar svg{left:var(--space-3);color:var(--color-text-muted);pointer-events:none;width:16px;height:16px;position:absolute}.search-bar input{padding-left:calc(var(--space-3) + 16px + var(--space-2))}.table-container{border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{background:var(--color-surface);padding:var(--space-3) var(--space-4);text-align:left;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-border);white-space:nowrap;font-size:.75rem;font-weight:600}.table td{padding:var(--space-4);color:var(--color-text);border-bottom:1px solid var(--color-border);vertical-align:middle;font-size:.875rem}.table tr:last-child td{border-bottom:none}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--color-surface-hover)}.table-clickable{cursor:pointer}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-full);letter-spacing:.03em;white-space:nowrap;font-size:.7rem;font-weight:600;display:inline-flex}.badge-success{background:var(--color-success-dim);color:var(--color-success)}.badge-warning{background:var(--color-warning-dim);color:var(--color-warning)}.badge-danger{background:var(--color-danger-dim);color:var(--color-danger)}.badge-info{background:var(--color-info-dim);color:var(--color-info)}.badge-primary{background:var(--color-primary-dim);color:var(--color-primary)}.badge-neutral{color:var(--color-text-secondary);background:#ffffff0f}.modal-overlay{background:var(--color-modal-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;padding:var(--space-4);justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-lg);animation:.2s slideUp;overflow-y:auto}.modal-lg{max-width:720px}.modal-xl{max-width:900px}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-title{color:var(--color-text);font-size:1.1rem;font-weight:700}.modal-body{padding:var(--space-6);gap:var(--space-4);flex-direction:column;display:flex}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);display:flex}.page-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.page-header-left h1{color:var(--color-text);font-size:1.5rem;font-weight:800}.page-header-left p{color:var(--color-text-muted);margin-top:var(--space-1);font-size:.875rem}.empty-state{padding:var(--space-16);text-align:center;justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.empty-icon{background:var(--color-surface);border-radius:var(--radius-xl);width:64px;height:64px;color:var(--color-text-muted);justify-content:center;align-items:center;display:flex}.empty-state h3{color:var(--color-text-secondary)}.empty-state p{color:var(--color-text-muted);font-size:.875rem}.login-page{min-height:100dvh;padding:var(--space-4);background:radial-gradient(ellipse at 30% 20%, #00d4aa0d 0%, transparent 60%), radial-gradient(ellipse at 70% 80%, #3b82f60d 0%, transparent 60%), var(--color-bg);justify-content:center;align-items:center;display:flex}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10);width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-logo{align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);display:flex}.login-logo-icon{background:var(--color-primary-dim);border:1px solid var(--color-primary-border);border-radius:var(--radius-md);width:44px;height:44px;color:var(--color-primary);justify-content:center;align-items:center;display:flex}.login-form{gap:var(--space-4);flex-direction:column;display:flex}.login-btn{margin-top:var(--space-2);width:100%;padding:var(--space-4);font-size:.95rem}.dashboard-grid{gap:var(--space-6);grid-template-columns:2fr 1fr;display:grid}.grid-4{gap:var(--space-4);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.analytics-chart-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(min(100%,400px),1fr));display:grid}.calendar-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.calendar-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.calendar-nav{align-items:center;gap:var(--space-2);display:flex}.calendar-grid{grid-template-columns:repeat(7,1fr);display:grid}.calendar-day-label{padding:var(--space-3);text-align:center;color:var(--color-text-muted);text-transform:uppercase;border-bottom:1px solid var(--color-border);font-size:.75rem;font-weight:600}.calendar-cell{min-height:90px;padding:var(--space-2);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);cursor:pointer}.calendar-cell:hover{background:var(--color-surface-hover)}.calendar-cell:nth-child(7n){border-right:none}.calendar-date{color:var(--color-text-secondary);border-radius:var(--radius-full);justify-content:center;align-items:center;width:24px;height:24px;font-size:.8rem;font-weight:600;display:flex}.calendar-date.today{background:var(--color-primary);color:#070c1a;font-weight:700}.calendar-date.other-month{color:var(--color-text-muted)}.calendar-event{background:var(--color-primary-dim);border-left:2px solid var(--color-primary);padding:2px var(--space-2);color:var(--color-primary);white-space:nowrap;text-overflow:ellipsis;cursor:pointer;transition:background var(--transition-fast);border-radius:3px;margin-top:2px;font-size:.7rem;overflow:hidden}.calendar-event:hover{background:#00d4aa33}.calendar-event.completed{background:var(--color-success-dim);border-color:var(--color-success);color:var(--color-success)}.calendar-event.cancelled{background:var(--color-danger-dim);border-color:var(--color-danger);color:var(--color-danger);text-decoration:line-through}.dental-chart-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}.dental-chart-legend{gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.legend-item{align-items:center;gap:var(--space-2);color:var(--color-text-secondary);font-size:.75rem;display:flex}.legend-dot{border-radius:var(--radius-full);width:10px;height:10px}.dental-arch{align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.dental-row{justify-content:center;gap:3px;display:flex}.tooth-wrapper{cursor:pointer;flex-direction:column;align-items:center;gap:3px;display:flex}.tooth-number{color:var(--color-text-muted);font-size:.6rem;font-weight:600}.odontogram-surface{transition:all var(--transition-fast);cursor:pointer}.odontogram-surface:hover{filter:brightness(1.5);stroke:var(--color-primary);stroke-width:1.2px}.tooth-crown{transition:all var(--transition-fast)}.tooth-crown:hover{transform:scale(1.05)}.tooth-tooltip{background:var(--color-bg-secondary);border:1px solid var(--color-border);padding:var(--space-3);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;opacity:0;visibility:hidden;min-width:160px;transition:all var(--transition-fast);pointer-events:none;position:absolute;bottom:100%;left:50%;transform:translate(-50%)translateY(4px)}.tooth-wrapper{cursor:pointer;flex-direction:column;align-items:center;gap:3px;display:flex;position:relative}.tooth-wrapper:hover .tooth-tooltip{opacity:1;visibility:visible;transform:translate(-50%)translateY(-8px)}.tooltip-title{border-bottom:1px solid var(--color-border);padding-bottom:var(--space-2);margin-bottom:var(--space-2);color:var(--color-text);text-align:center;font-size:.8rem;font-weight:700}.tooltip-condition-item{justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:4px;font-size:.75rem;display:flex}.tooltip-surface{color:var(--color-text-muted);font-weight:600}.tooltip-status{text-align:right;font-weight:600}.arch-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-2) 0;font-size:.7rem;font-weight:600}.dental-divider{background:var(--color-border);width:100%;max-width:500px;height:1px;margin:var(--space-3) 0}.condition-grid{gap:var(--space-2);grid-template-columns:1fr 1fr;display:grid}.condition-btn{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;transition:all var(--transition-fast);text-align:left;display:flex}.condition-btn:hover{border-color:var(--color-border-hover);background:var(--color-surface-hover)}.condition-btn.selected{border-color:var(--color-primary);background:var(--color-primary-dim)}.condition-dot{border-radius:var(--radius-full);flex-shrink:0;width:12px;height:12px}.condition-name{color:var(--color-text);font-size:.8rem;font-weight:500}.patient-header{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);align-items:flex-start;gap:var(--space-6);margin-bottom:var(--space-6);display:flex}.patient-avatar-large{border-radius:var(--radius-full);background:var(--color-primary-dim);border:2px solid var(--color-primary-border);width:64px;height:64px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;font-size:1.4rem;font-weight:700;display:flex}.patient-info-grid{gap:var(--space-4);margin-top:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.patient-info-item label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-1);font-size:.75rem;display:block}.patient-info-item span{color:var(--color-text);font-size:.9rem;font-weight:500}.tabs{border-bottom:1px solid var(--color-border);margin-bottom:var(--space-6);gap:0;display:flex;overflow-x:auto}.tab-btn{padding:var(--space-3) var(--space-5);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;font-size:.875rem;font-weight:600}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.invoice-items-table{border-collapse:collapse;width:100%}.invoice-items-table th{color:var(--color-text-muted);text-transform:uppercase;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border);text-align:left;font-size:.75rem;font-weight:600}.invoice-items-table td{padding:var(--space-3);color:var(--color-text);border-bottom:1px solid var(--color-border);font-size:.875rem}.invoice-total-row{padding:var(--space-3) 0;justify-content:space-between;font-size:.875rem;display:flex}.invoice-total-row.grand-total{color:var(--color-primary);border-top:1px solid var(--color-border);margin-top:var(--space-2);padding-top:var(--space-4);font-size:1.1rem;font-weight:700}.clinic-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-fast);cursor:pointer}.clinic-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.clinic-card.inactive{opacity:.6}.clinic-icon{background:var(--color-primary-dim);border:1px solid var(--color-primary-border);border-radius:var(--radius-md);width:48px;height:48px;color:var(--color-primary);margin-bottom:var(--space-4);justify-content:center;align-items:center;display:flex}.clinic-name{color:var(--color-text);margin-bottom:var(--space-1);font-size:1rem;font-weight:700}.clinic-meta{gap:var(--space-1);flex-direction:column;display:flex}.clinic-meta-item{align-items:center;gap:var(--space-2);color:var(--color-text-muted);font-size:.8rem;display:flex}.clinic-meta-item svg{width:13px;height:13px}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--radius-full);width:32px;height:32px;animation:.7s linear infinite spin}.spinner-sm{border-width:2px;width:16px;height:16px}.loader-screen{justify-content:center;align-items:center;gap:var(--space-4);background:var(--color-bg);flex-direction:column;min-height:100dvh;display:flex}.alert{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);border:1px solid;font-size:.875rem;display:flex}.alert-error{background:var(--color-danger-dim);color:var(--color-danger);border-color:#ef44444d}.alert-success{background:var(--color-success-dim);color:var(--color-success);border-color:#22c55e4d}.alert-warning{background:var(--color-warning-dim);color:var(--color-warning);border-color:#f59e0b4d}.breadcrumb{align-items:center;gap:var(--space-2);color:var(--color-text-muted);margin-bottom:var(--space-6);font-size:.8rem;display:flex}.breadcrumb a{color:var(--color-text-muted);transition:color var(--transition-fast);text-decoration:none}.breadcrumb a:hover{color:var(--color-text)}.breadcrumb-sep{color:var(--color-text-muted);opacity:.4}.breadcrumb-current{color:var(--color-text-secondary);font-weight:500}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:.2s fadeIn}.animate-slide-up{animation:.2s slideUp}.animate-pulse{animation:2s ease-in-out infinite pulse}.skeleton{background:linear-gradient(90deg, var(--color-surface) 0%, var(--color-surface-hover) 50%, var(--color-surface) 100%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.tooltip-wrapper{display:inline-flex;position:relative}.tooltip-wrapper:hover .tooltip{opacity:1;pointer-events:auto;transform:translateY(-4px)}.tooltip{color:var(--color-text);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:all var(--transition-fast);z-index:500;background:#000000e6;font-size:.75rem;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)translateY(0)}.divider{background:var(--color-border);height:1px;margin:var(--space-4) 0}@media (max-width:1024px){:root{--sidebar-width:72px}.sidebar-logo-text,.sidebar-logo-subtitle,.sidebar-section-label,.sidebar-link span,.user-info{display:none}.sidebar-link{padding:var(--space-3);justify-content:center}.sidebar-logo{padding:var(--space-4);justify-content:center}.sidebar-user{justify-content:center}.sidebar-footer{padding:var(--space-3)}.dashboard-grid{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid{grid-template-columns:1fr}.form-grid-3{grid-template-columns:1fr 1fr}.topbar{left:72px}.main-content{margin-left:72px}.bottom-nav{display:none}.sidebar-desktop-only{display:block}}@media (max-width:768px){:root{--sidebar-width:0px;--topbar-height:56px;--bottom-nav-height:64px}.sidebar-desktop-only{display:none!important}.sidebar{width:min(280px,100vw - 32px);padding-top:env(safe-area-inset-top);padding-bottom:calc(env(safe-area-inset-bottom) + var(--bottom-nav-height));z-index:300;transform:translate(-100%)}.sidebar.mobile-open{box-shadow:var(--shadow-lg);transform:translate(0)}.mobile-overlay{z-index:299;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;position:fixed;inset:0}.sidebar-logo-text,.sidebar-logo-subtitle,.sidebar-section-label,.sidebar-link span,.user-info{display:block}.sidebar-link{padding:var(--space-3) var(--space-4);justify-content:flex-start;min-height:52px}.sidebar-logo{padding:var(--space-6);justify-content:flex-start}.sidebar-user{justify-content:flex-start}.mobile-menu-btn{display:flex}.has-bottom-nav .mobile-menu-btn{display:none}.topbar{min-height:calc(var(--topbar-height) + env(safe-area-inset-top));height:calc(var(--topbar-height) + env(safe-area-inset-top));padding-top:env(safe-area-inset-top);padding-left:max(var(--space-4), env(safe-area-inset-left));padding-right:max(var(--space-4), env(safe-area-inset-right));gap:var(--space-3);padding-bottom:0;left:0}.main-content{max-width:100%;margin-left:0}.page-content{padding-top:calc(var(--topbar-height) + env(safe-area-inset-top) + var(--space-4));padding-left:max(var(--space-4), env(safe-area-inset-left));padding-right:max(var(--space-4), env(safe-area-inset-right));padding-bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom) + var(--space-4));width:100%;max-width:100%;overflow-x:hidden}.card{padding:var(--space-4)}.topbar-title{max-width:55vw;font-size:1rem}.topbar-subtitle{max-width:55vw}.btn,.form-select,.form-input,.calendar-cell,.tab-btn,.sidebar-link{min-height:48px}.form-input,.form-select,.form-textarea{font-size:16px}.btn-block{width:100%}.calendar-nav .btn,.topbar-right .btn{width:auto;min-height:40px}.btn-icon{width:44px;height:44px;min-height:44px}.stat-card:hover,.clinic-card:hover{transform:none}.stat-grid{grid-template-columns:1fr 1fr}.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.analytics-chart-grid{gap:var(--space-4)}.form-grid,.form-grid-3,.dashboard-grid,.condition-grid{grid-template-columns:1fr}.page-header{align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-5);flex-direction:column}.page-header>div:not(.page-header-left){gap:var(--space-2);flex-wrap:wrap;width:100%}.page-header>div:not(.page-header-left) .btn{min-width:calc(50% - var(--space-2));padding:var(--space-2) var(--space-3);flex:1;justify-content:center;min-height:44px;font-size:.8rem}.calendar-header{gap:var(--space-3);flex-direction:column}.calendar-nav{justify-content:space-between;width:100%}.table-container{border-radius:var(--radius-md);-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.calendar-container{-webkit-overflow-scrolling:touch;width:100%;padding-bottom:var(--space-4);overflow-x:auto}.calendar-grid{min-width:600px}.modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-width:100%;max-height:92dvh}.modal-overlay{align-items:flex-end;padding:0}.login-card{padding:var(--space-6)}.patient-header{flex-direction:column}}@media (max-width:480px){.stat-grid,.grid-4{grid-template-columns:1fr}.login-page{padding:calc(var(--space-4) + env(safe-area-inset-top)) var(--space-4) calc(var(--space-4) + env(safe-area-inset-bottom));align-items:flex-start}.login-card{padding:var(--space-6)}}.bottom-nav{display:none}@media (max-width:768px){.bottom-nav{height:calc(64px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:var(--color-bg-secondary);border-top:1px solid var(--color-border);z-index:200;-webkit-backdrop-filter:blur(20px);display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{padding:var(--space-2) var(--space-1);color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;min-height:48px;text-decoration:none;display:flex;position:relative}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-icon{border-radius:var(--radius-full);width:44px;height:28px;transition:background var(--transition-fast), transform var(--transition-fast);justify-content:center;align-items:center;display:flex}.bottom-nav-item.active .bottom-nav-icon{background:var(--color-primary-dim)}.bottom-nav-item:active .bottom-nav-icon{transform:scale(.9)}.bottom-nav-label{letter-spacing:.02em;white-space:nowrap;font-size:.65rem;font-weight:600;line-height:1}.bottom-nav-indicator{display:none}.sidebar-desktop-only{display:none!important}}.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-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.flex-1{flex:1}.w-full{width:100%}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.hidden{display:none}.pwa-install-banner{bottom:calc(var(--bottom-nav-height,0px) + env(safe-area-inset-bottom) + var(--space-4));left:var(--space-4);right:var(--space-4);background:var(--color-bg-secondary);border:1px solid var(--color-primary-border);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-5);align-items:center;gap:var(--space-3);box-shadow:var(--shadow-lg), 0 0 0 1px var(--color-primary-border);z-index:500;max-width:480px;display:flex;position:fixed}@media (min-width:769px){.pwa-install-banner{bottom:var(--space-6);left:auto;right:var(--space-6)}}.pwa-banner-icon{background:var(--color-primary-dim);border:1px solid var(--color-primary-border);border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.pwa-banner-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.pwa-banner-text strong{color:var(--color-text);font-size:.875rem;font-weight:700}.pwa-banner-text span{color:var(--color-text-muted);font-size:.75rem}.pwa-banner-install-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-primary);color:#070c1a;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;transition:background var(--transition-fast);touch-action:manipulation;border:none;flex-shrink:0;font-size:.8rem;font-weight:700;display:inline-flex}.pwa-banner-install-btn:hover:not(:disabled){background:var(--color-primary-hover)}.pwa-banner-install-btn:disabled{opacity:.7;cursor:not-allowed}.pwa-banner-close{width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);touch-action:manipulation;transition:color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.pwa-banner-close:hover{color:var(--color-text)}.topbar-install-btn{white-space:nowrap}@media (max-width:400px){.topbar-install-label{display:none}.topbar-install-btn{padding:var(--space-2);width:36px;height:36px}}details[open] summary .expand-icon{transform:rotate(180deg)}.expand-icon{color:var(--color-text-muted);transition:transform .2s}.universal-search-trigger{align-items:center;gap:var(--space-2);padding:.35rem var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:.875rem;display:flex}.universal-search-trigger:hover{background-color:var(--color-surface-hover);border-color:var(--color-border-hover);color:var(--color-text)}.universal-search-kbd{margin-left:var(--space-2);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;justify-content:center;align-items:center;padding:.1rem .3rem;font-size:.65rem;font-weight:600;display:flex}@media (max-width:640px){.universal-search-trigger .search-text,.universal-search-trigger .universal-search-kbd{display:none}}.search-result-item{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast);display:flex}.search-result-item:hover{background-color:var(--color-surface-hover)}.search-section-title{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2);padding:0 var(--space-2);font-size:.75rem;font-weight:600}.dashboard-main-grid{gap:var(--space-6);flex-direction:column;min-height:500px;display:flex}@media (min-width:1024px){.dashboard-main-grid{flex-direction:row;height:calc(100vh - 260px)}.dashboard-main-grid>:first-child,.dashboard-main-grid>:last-child{flex:1}}.cursor-pointer{cursor:pointer}.patient-row-hover:hover{background-color:var(--color-surface-hover);border-color:var(--color-primary)}
