@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: rgba(17, 24, 39, .7);--bg-glass: rgba(255, 255, 255, .03);--bg-glass-hover: rgba(255, 255, 255, .06);--border-glass: rgba(255, 255, 255, .08);--border-glass-hover: rgba(255, 255, 255, .15);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent-primary: #6366f1;--accent-primary-hover: #818cf8;--accent-primary-glow: rgba(99, 102, 241, .25);--accent-success: #10b981;--accent-success-glow: rgba(16, 185, 129, .2);--accent-warning: #f59e0b;--accent-warning-glow: rgba(245, 158, 11, .2);--accent-danger: #ef4444;--accent-danger-glow: rgba(239, 68, 68, .2);--accent-info: #06b6d4;--accent-info-glow: rgba(6, 182, 212, .2);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 40px rgba(99, 102, 241, .15);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--sidebar-width: 260px;--header-height: 70px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden;max-width:100vw}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;width:100%}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(6,182,212,.06) 0%,transparent 50%),radial-gradient(ellipse at 50% 80%,rgba(16,185,129,.05) 0%,transparent 50%);pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100vh}a{text-decoration:none;color:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.glass-card{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:24px;transition:all var(--transition-normal);width:100%;box-sizing:border-box}.glass-card:hover{background:var(--bg-glass-hover);border-color:var(--border-glass-hover);box-shadow:var(--shadow-glow)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-sm);font-family:Inter,sans-serif;font-weight:500;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);outline:none}.btn-primary{background:var(--accent-primary);color:#fff;box-shadow:0 2px 12px var(--accent-primary-glow)}.btn-primary:hover{background:var(--accent-primary-hover);box-shadow:0 4px 20px var(--accent-primary-glow);transform:translateY(-1px)}.btn-success{background:var(--accent-success);color:#fff;box-shadow:0 2px 12px var(--accent-success-glow)}.btn-success:hover{transform:translateY(-1px)}.btn-danger{background:transparent;color:var(--accent-danger);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef44441a}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-glass)}.btn-ghost:hover{background:var(--bg-glass-hover);color:var(--text-primary);border-color:var(--border-glass-hover)}.btn-sm{padding:6px 14px;font-size:.8rem}.input-group{display:flex;flex-direction:column;gap:6px}.input-group label{font-size:.8rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.input-field{padding:10px 14px;background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Inter,sans-serif;font-size:.9rem;outline:none;transition:all var(--transition-fast)}.input-field:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}.input-field::placeholder{color:var(--text-muted)}select.input-field{cursor:pointer;appearance:auto;background-color:#ffffff0d;font-weight:500;border-radius:var(--radius-md);padding-right:32px}select.input-field:hover{background-color:#ffffff14}select.input-field option{background:var(--bg-secondary);color:var(--text-primary);font-weight:400}.custom-select-trigger{cursor:pointer;position:relative;-webkit-user-select:none;user-select:none;display:flex;align-items:center}.custom-select-trigger:after{content:"▼";position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:.7rem;color:var(--text-muted)}.custom-select-dropdown{position:absolute;top:100%;left:0;right:0;background:#111827;border:1px solid var(--border-glass-hover);border-radius:var(--radius-sm);margin-top:4px;max-height:250px;overflow-y:auto;z-index:100;box-shadow:0 8px 32px #0006}.custom-select-option{padding:10px 14px;cursor:pointer;color:var(--text-primary);border-bottom:1px solid var(--border-glass);font-size:.9rem;transition:background .15s ease}.custom-select-option:last-child{border-bottom:none}.custom-select-option:hover{background:#ffffff1a}.custom-select-option.selected{background:#3b82f633;color:var(--accent-primary)}.custom-select-option.plan-all-option{color:var(--accent-success);font-weight:600}.custom-select-group{padding:8px 14px;font-size:.75rem;font-weight:600;color:var(--text-muted);background:var(--bg-glass);text-transform:uppercase;letter-spacing:.05em}textarea.input-field{resize:vertical;min-height:80px}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-glass);border-radius:var(--radius-xl);padding:32px;width:90%;max-width:520px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h2{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:4px;line-height:1;transition:color var(--transition-fast)}.modal-close:hover{color:var(--text-primary)}.modal-form{display:flex;flex-direction:column;gap:16px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.table-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{width:100%;border-collapse:collapse;min-width:600px}.data-table th{text-align:left;padding:12px 16px;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-glass)}.data-table td{padding:14px 16px;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.03)}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-glass-hover)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:500}.badge-planned{background:var(--accent-info-glow);color:var(--accent-info)}.badge-completed{background:var(--accent-success-glow);color:var(--accent-success)}.badge-cancelled{background:var(--accent-danger-glow);color:var(--accent-danger)}.badge-income{background:var(--accent-success-glow);color:var(--accent-success)}.badge-expense{background:var(--accent-danger-glow);color:var(--accent-danger)}.stat-card{display:flex;flex-direction:column;gap:8px}.stat-card .stat-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:4px}.stat-card .stat-value{font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.stat-card .stat-label{font-size:.8rem;color:var(--text-muted);font-weight:500}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.page-header h1{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-muted);text-align:center}.empty-state .empty-icon{font-size:3rem;margin-bottom:16px;opacity:.5}.empty-state p{font-size:.95rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.fade-in{animation:fadeIn .4s ease}.slide-up{animation:slideUp .4s ease}@media(max-width:768px){:root{--sidebar-width: 0px}.glass-card{padding:16px}.page-header{flex-direction:column;align-items:flex-start;gap:12px;margin-top:24px}.modal-content{padding:20px;width:95%}.input-group label{font-size:.75rem}}@media(max-width:480px){body{overflow-x:hidden}.glass-card{padding:12px}}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);height:100vh;position:fixed;top:0;left:0;z-index:100;display:flex;flex-direction:column;background:#0a0e1af2;border-right:1px solid var(--border-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:24px 16px;transition:transform var(--transition-normal)}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:8px 12px;margin-bottom:32px}.logo-icon{font-size:1.75rem}.logo-text{font-size:1.4rem;font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-info));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.03em}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;font-size:.9rem;transition:all var(--transition-fast)}.nav-item:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.nav-item--active{background:var(--accent-primary-glow);color:var(--accent-primary-hover)}.nav-item--active .nav-icon{color:var(--accent-primary)}.nav-icon{font-size:1.15rem;display:flex}.sidebar-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 8px 0;border-top:1px solid var(--border-glass);margin-top:16px}.user-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-info));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-clinic{font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px;border-radius:var(--radius-sm);display:flex;font-size:1.1rem;transition:all var(--transition-fast)}.logout-btn:hover{color:var(--accent-danger);background:var(--accent-danger-glow)}.main-content{flex:1;margin-left:var(--sidebar-width);padding:32px;min-height:100vh}.sidebar-toggle{display:none;position:fixed;top:16px;left:16px;z-index:999;background:var(--bg-secondary);border:1px solid var(--border-glass);color:var(--text-primary);padding:10px;border-radius:var(--radius-sm);cursor:pointer;font-size:1.2rem;line-height:1}.sidebar-overlay{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%);width:260px}.sidebar--open{transform:translate(0)}.sidebar-toggle{display:flex}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:90}.main-content{margin-left:0;padding:60px 20px 20px;width:100%;max-width:100vw}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-container{display:flex;width:100%;max-width:900px;min-height:560px;border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--border-glass);background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-lg);animation:slideUp .5s ease}.login-branding{flex:1;background:linear-gradient(135deg,#1e1b4b,#0f172a,#0c1222);padding:48px 40px;display:flex;align-items:center;position:relative;overflow:hidden}.login-branding:before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.2) 0%,transparent 70%);top:-50px;right:-50px}.login-branding:after{content:"";position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(6,182,212,.15) 0%,transparent 70%);bottom:-30px;left:-30px}.branding-content{position:relative;z-index:1}.branding-icon{font-size:3rem;display:block;margin-bottom:16px}.branding-content h1{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--accent-primary-hover),var(--accent-info));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}.branding-content p{font-size:1.05rem;color:var(--text-secondary);line-height:1.5;margin-bottom:32px}.branding-features{display:flex;flex-direction:column;gap:12px}.feature{font-size:.9rem;color:var(--text-secondary);display:flex;align-items:center;gap:10px}.login-form-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:48px 40px;background:#11182780}.login-form{width:100%;max-width:340px;display:flex;flex-direction:column;gap:18px}.form-header h2{font-size:1.5rem;font-weight:700;margin-bottom:4px}.form-header p{font-size:.85rem;color:var(--text-muted)}.form-error{background:var(--accent-danger-glow);border:1px solid rgba(239,68,68,.3);color:var(--accent-danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:.85rem}.login-submit{width:100%;justify-content:center;padding:12px;font-size:.95rem;margin-top:4px}.form-switch{text-align:center;font-size:.85rem;color:var(--text-muted)}.form-switch button{background:none;border:none;color:var(--accent-primary);cursor:pointer;font-size:.85rem;font-weight:500}.form-switch button:hover{color:var(--accent-primary-hover);text-decoration:underline}@media(max-width:768px){.login-container{flex-direction:column}.login-branding,.login-form-wrapper{padding:32px 24px}}.dashboard .page-subtitle{font-size:.9rem;color:var(--text-muted);margin-top:4px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:28px}.page-loading{display:flex;align-items:center;justify-content:center;height:60vh;color:var(--text-muted);font-size:1rem}.upcoming-section h2{font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:20px}.upcoming-list{display:flex;flex-direction:column;gap:8px}.upcoming-item{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-glass);border-radius:var(--radius-md);border:1px solid var(--border-glass);transition:all var(--transition-fast)}.upcoming-item:hover{background:var(--bg-glass-hover);border-color:var(--border-glass-hover)}.upcoming-time{font-size:.8rem;color:var(--accent-info);font-weight:500;min-width:120px}.upcoming-info{flex:1;display:flex;flex-direction:column}.upcoming-patient{font-weight:600;font-size:.9rem}.upcoming-treatment{font-size:.8rem;color:var(--text-muted)}.upcoming-cost{font-weight:600;color:var(--accent-success);font-size:.9rem}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card .stat-value{font-size:1.2rem}.stat-card .stat-icon{width:36px;height:36px;font-size:1rem}.upcoming-item{flex-direction:column;align-items:flex-start;gap:8px;padding:10px 12px}.upcoming-time{min-width:auto;font-size:.75rem}.upcoming-cost{font-size:.8rem}}.search-bar{display:flex;align-items:center;gap:12px;padding:12px 18px;margin-bottom:24px}.search-bar svg{color:var(--text-muted);font-size:1.1rem}.search-input{flex:1;background:none;border:none;color:var(--text-primary);font-family:Inter,sans-serif;font-size:.9rem;outline:none}.search-input::placeholder{color:var(--text-muted)}.patients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.patient-card{display:flex;align-items:center;gap:16px;cursor:pointer;padding:20px}.patient-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary-glow),rgba(6,182,212,.2));display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--accent-primary);flex-shrink:0}.patient-info{flex:1;min-width:0}.patient-info h3{font-size:.95rem;font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.patient-detail{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-muted)}.patient-actions{display:flex;flex-direction:column;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.patient-card:hover .patient-actions{opacity:1}.patient-detail{display:flex;flex-direction:column;width:100%;max-width:100%;gap:0}.back-btn{margin-bottom:16px;align-self:flex-start}.patient-header-card{display:flex;align-items:center;gap:20px;margin-bottom:16px;padding:20px 24px;width:100%}.patient-header-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-info));display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0}.patient-header-info h1{font-size:1.35rem;font-weight:700;margin-bottom:6px}.patient-meta{display:flex;flex-wrap:wrap;gap:16px}.patient-meta span,.meta-link{display:flex;align-items:center;gap:5px;font-size:.82rem;color:var(--text-secondary);text-decoration:none}.meta-link:hover{color:var(--accent-primary)}.detail-tabs{display:flex;gap:4px;margin-bottom:16px;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none;width:100%}.detail-tabs::-webkit-scrollbar{display:none}.tab-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:var(--radius-md);color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.82rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.tab-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.tab-btn--active{background:var(--accent-primary-glow);border-color:var(--accent-primary);color:var(--accent-primary-hover)}.tab-badge{background:var(--accent-primary);color:#fff;border-radius:10px;padding:1px 7px;font-size:.68rem;font-weight:600}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-title{font-size:1rem;font-weight:600;display:flex;align-items:center;gap:8px;margin:0}.dental-chart-card{padding:24px;width:100%;overflow-x:auto}.chart-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:24px}.tooth-legend{display:flex;flex-wrap:wrap;gap:8px}.legend-item{display:flex;align-items:center;gap:4px;font-size:.7rem;color:var(--text-muted)}.legend-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.jaw-section{margin-bottom:20px}.jaw-section:last-of-type{margin-bottom:0}.jaw-label{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;text-align:center}.jaw-row{display:flex;justify-content:center;align-items:flex-end;gap:0}.jaw-half{display:flex;gap:3px;align-items:flex-end}.jaw-half--right{justify-content:flex-end}.jaw-half--left{justify-content:flex-start}.jaw-divider{width:2px;height:60px;background:linear-gradient(to bottom,var(--accent-primary) 0%,transparent 100%);margin:0 8px;border-radius:1px;align-self:center}.tooth-visual{display:flex;flex-direction:column;align-items:center;cursor:pointer;padding:4px 2px;border-radius:6px;transition:all .15s ease;position:relative;min-width:32px}.tooth-visual:hover{background:#6366f114;transform:translateY(-2px)}.tooth-visual--selected{background:#6366f126;transform:translateY(-3px);box-shadow:0 4px 16px #6366f140}.tooth-visual--missing{opacity:.5}.tooth-num{font-size:.6rem;font-weight:700;color:var(--text-muted);margin-bottom:2px;line-height:1}.tooth-svg{display:block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));transition:filter .15s ease}.tooth-visual:hover .tooth-svg{filter:drop-shadow(0 2px 6px rgba(99,102,241,.3))}.tooth-visual--selected .tooth-svg{filter:drop-shadow(0 2px 8px rgba(99,102,241,.4))}.tooth-badges{display:flex;gap:1px;margin-top:2px;flex-wrap:wrap;justify-content:center;max-width:42px}.tooth-badge{font-size:.5rem;font-weight:700;color:#fff;padding:0 3px;border-radius:3px;line-height:1.3;white-space:nowrap}.tooth-badge--more{background:#475569!important}.diagnosis-panel{margin-top:24px;padding:20px;background:#0f172a99;border:1px solid var(--border-glass);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.diagnosis-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.diagnosis-panel-header h3{font-size:.95rem;font-weight:600}.diagnosis-hint{font-size:.7rem;color:var(--text-muted);font-weight:400}.btn-icon{width:32px;height:32px;border-radius:8px;border:1px solid var(--border-glass);background:var(--bg-glass);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.diagnosis-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:6px;margin-bottom:12px}.diagnosis-btn{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.diagnosis-btn:hover{background:color-mix(in srgb,var(--diag-color) 10%,transparent);border-color:var(--diag-color)}.diagnosis-btn--active{background:color-mix(in srgb,var(--diag-color) 15%,transparent);border-color:var(--diag-color);color:var(--text-primary)}.diagnosis-icon{width:24px;height:24px;border-radius:6px;border:1.5px solid var(--border-glass);display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:var(--text-muted);flex-shrink:0;transition:all var(--transition-fast)}.diagnosis-btn--active .diagnosis-icon{color:#fff}.diagnosis-label{font-weight:500}.current-diagnoses{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--border-glass)}.current-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.current-tag{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:12px;border:1px solid}.plans-list{display:flex;flex-direction:column;gap:16px}.plan-card{padding:24px}.plan-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}.plan-header h3{font-size:1.05rem;font-weight:600;margin-bottom:4px}.plan-cost{font-size:1.15rem;font-weight:700;color:var(--accent-success)}.plan-progress{display:flex;align-items:center;gap:10px;margin-bottom:14px}.progress-bar{flex:1;height:5px;background:#ffffff0d;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-success));border-radius:3px;transition:width var(--transition-normal)}.progress-text{font-size:.72rem;color:var(--text-muted)}.plan-items{display:flex;flex-direction:column;gap:4px}.plan-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-glass);border-radius:var(--radius-sm);border:1px solid var(--border-glass)}.plan-item--done{opacity:.55}.plan-item--done .item-title{text-decoration:line-through}.item-check{width:26px;height:26px;border-radius:50%;border:2px solid var(--border-glass);background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;font-size:.75rem;transition:all var(--transition-fast)}.plan-item--done .item-check{background:var(--accent-success);border-color:var(--accent-success);color:#fff}.item-step{font-size:.65rem;font-weight:700}.item-info{flex:1}.item-title{font-size:.82rem;font-weight:500}.item-tooth{display:block;font-size:.68rem;color:var(--text-muted)}.item-cost{font-size:.82rem;font-weight:600;color:var(--text-secondary)}.input-group-label{font-size:.78rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;display:block}.plan-items-form{margin-bottom:8px}.plan-item-row{display:flex;align-items:center;gap:6px;margin-bottom:6px}.item-num{width:22px;height:22px;border-radius:50%;background:var(--accent-primary-glow);color:var(--accent-primary);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;flex-shrink:0}.input-cost{width:90px;flex-shrink:0}.input-tooth{width:65px;flex-shrink:0}.plan-total{padding:10px 14px;background:var(--bg-glass);border-radius:var(--radius-sm);font-size:.88rem;margin-bottom:8px}.modal-wide{max-width:620px}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:16px}.photo-card{padding:20px}.photo-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.photo-card-header h3{font-size:.95rem;font-weight:600}.photo-date{font-size:.72rem;color:var(--text-muted)}.photo-tooth{display:inline-block;font-size:.72rem;color:var(--accent-info);background:var(--accent-info-glow);padding:2px 10px;border-radius:10px;margin-bottom:10px}.photo-comparison{display:flex;align-items:stretch;gap:10px;margin-bottom:10px}.photo-slot{flex:1;display:flex;flex-direction:column;align-items:center}.photo-label{font-size:.65rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}.photo-img{width:100%;max-height:180px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-glass)}.photo-placeholder{width:100%;height:120px;display:flex;align-items:center;justify-content:center;background:var(--bg-glass);border:1px dashed var(--border-glass);border-radius:var(--radius-sm);color:var(--text-muted);font-size:1.2rem}.photo-arrow{display:flex;align-items:center;font-size:1.3rem;color:var(--text-muted);flex-shrink:0}.photo-notes{font-size:.82rem;color:var(--text-muted);margin-bottom:10px}.photo-upload-group{display:flex;gap:12px}.photo-upload{flex:1;display:flex;flex-direction:column;gap:4px}.photo-upload label{font-size:.78rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.upload-btn{padding:12px;background:var(--bg-glass);border:1px dashed var(--border-glass);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.82rem;cursor:pointer;transition:all var(--transition-fast);text-align:center}.upload-btn:hover{background:var(--bg-glass-hover);border-color:var(--accent-primary)}.patient-detail .glass-card{margin-bottom:16px;width:100%}.patient-detail>.glass-card:hover{transform:none}.slide-up{animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.patient-header-card{flex-direction:column;text-align:center}.patient-meta{justify-content:center}.jaw-half{gap:1px}.tooth-visual{min-width:24px;padding:2px 1px}.tooth-num{font-size:.5rem}.tooth-svg{width:20px;height:30px}.diagnosis-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.photos-grid{grid-template-columns:1fr}.photo-upload-group,.chart-header{flex-direction:column}}.week-nav{display:flex;align-items:center;gap:12px;padding:12px 18px;margin-bottom:24px}.week-range{font-weight:600;font-size:1rem;flex:1;text-align:center}.calendar-container{display:flex;overflow-x:auto;overflow-y:auto;min-height:600px;max-height:75vh;position:relative;background:var(--bg-glass)}.time-axis{display:flex;flex-direction:column;min-width:60px;border-right:1px solid var(--border-glass);background:#ffffff05;position:sticky;left:0;z-index:10}.time-header-spacer{height:60px;border-bottom:1px solid var(--border-glass)}.time-labels-container{position:relative;height:960px;width:100%}.time-slot-label-abs{position:absolute;left:0;right:0;display:flex;justify-content:center;transform:translateY(-50%);z-index:10;pointer-events:none}.time-label-text{background:var(--bg-glass);padding:2px 4px;font-size:.75rem;color:var(--text-secondary);border-radius:4px}.days-grid{display:flex;flex:1;min-width:800px}.calendar-day-col{flex:1;display:flex;flex-direction:column;min-width:120px;border-right:1px solid var(--border-glass)}.calendar-day-col:last-child{border-right:none}.day-header{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60px;border-bottom:1px solid var(--border-glass);background:#ffffff0d;position:sticky;top:0;z-index:5}.day-today .day-header{background:rgba(var(--accent-primary-rgb),.1)}.day-schedule-body{position:relative;height:960px;background:transparent}.grid-hour-line{height:60px;border-top:1px solid var(--border-glass);box-sizing:border-box}.grid-hour-line:first-child{border-top:none}.appt-block{position:absolute;left:4px;right:4px;border-radius:var(--radius-sm);padding:4px 8px;overflow:hidden;box-shadow:0 2px 8px #00000026;transition:transform var(--transition-fast),box-shadow var(--transition-fast);z-index:2;cursor:pointer;display:flex;flex-direction:column;gap:2px;border-left:3px solid transparent}.appt-block:hover{transform:scale(1.02);z-index:3;box-shadow:0 4px 12px #00000040}.appt-block-time{font-size:.7rem;font-weight:700;opacity:.8}.appt-block-title{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appt-block-desc{font-size:.75rem;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appt-block-actions{display:flex;gap:4px;margin-top:auto}.appt-planned{background:#2b58cc26;border:1px solid rgba(43,88,204,.3);border-left-color:var(--accent-info)}.appt-completed{background:#21c55d26;border:1px solid rgba(33,197,93,.3);border-left-color:var(--accent-success)}.appt-cancelled{background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-left-color:var(--accent-danger);opacity:.6}.appt-cancelled:hover{opacity:1}.multi-select-container{display:flex;flex-direction:column;gap:8px}.selected-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{display:inline-flex;align-items:center;gap:6px;background:rgba(var(--accent-primary-rgb),.15);color:var(--accent-primary);padding:4px 8px;border-radius:var(--radius-sm);font-size:.8rem;font-weight:500;border:1px solid rgba(var(--accent-primary-rgb),.3)}.tag-remove{background:none;border:none;color:currentColor;cursor:pointer;font-size:1.1rem;line-height:1;padding:0;opacity:.7;display:flex;align-items:center;justify-content:center;transition:opacity var(--transition-fast)}.tag-remove:hover{opacity:1}@media(max-width:768px){.appointments-page .page-header{flex-direction:column;gap:12px;align-items:flex-start}.week-nav{padding:8px 12px;gap:8px}.week-range{font-size:.85rem}.calendar-container{min-height:400px;max-height:65vh}.days-grid{min-width:500px}.calendar-day-col{min-width:70px}.time-axis{min-width:45px}.time-label-text{font-size:.65rem}.day-header{height:48px}.day-name{font-size:.7rem}.day-number{font-size:.85rem}.appt-block{left:2px;right:2px;padding:2px 4px}.appt-block-time{font-size:.6rem}.appt-block-title{font-size:.65rem}.appt-block-desc,.appt-block-actions{display:none}.modal-content{width:95vw;max-height:90vh;overflow-y:auto;margin:5vh auto}.modal-form .input-group{margin-bottom:12px}.custom-select-dropdown{max-height:200px;overflow-y:auto}}.finance-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.summary-card{display:flex;align-items:center;gap:16px;padding:20px 24px}.summary-icon{font-size:1.4rem}.summary-income .summary-icon{color:var(--accent-success)}.summary-expense .summary-icon{color:var(--accent-danger)}.summary-profit .summary-icon{color:var(--accent-primary)}.summary-label{display:block;font-size:.75rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.summary-value{display:block;font-size:1.3rem;font-weight:700;letter-spacing:-.02em;word-break:break-all}.finance-filters-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.time-selectors{display:flex;gap:12px}.time-selectors select{min-width:140px}.finance-filters{display:flex;gap:8px}.yearly-stats-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;margin-bottom:24px;background:#ffffff05;flex-wrap:wrap;gap:16px}.yearly-stats-bar .stat-label{font-weight:600;font-size:1.1rem;color:var(--text-primary)}.stat-pills{display:flex;gap:12px;flex-wrap:wrap}.pill{padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:600}.pill-income{background:var(--accent-success-glow);color:var(--accent-success);border:1px solid rgba(16,185,129,.3)}.pill-expense{background:var(--accent-danger-glow);color:var(--accent-danger);border:1px solid rgba(239,68,68,.3)}.pill-profit{background:var(--accent-primary-glow);color:var(--accent-primary);border:1px solid rgba(99,102,241,.3)}.td-description{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-muted)}.td-amount{font-weight:600;white-space:nowrap}.amount-positive{color:var(--accent-success)}.amount-negative{color:var(--accent-danger)}.catalog-page{display:flex;flex-direction:column;gap:20px}.catalog-list{display:flex;flex-direction:column;gap:16px}.catalog-category-group{padding:24px}.category-title{display:flex;align-items:center;gap:10px;font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:20px;border-bottom:1px solid var(--border-glass);padding-bottom:12px}.catalog-items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}.catalog-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.catalog-item:hover{background:var(--bg-glass-hover)}.item-details{display:flex;justify-content:space-between;align-items:center;flex:1;padding-right:24px}.item-name{font-weight:500;color:var(--text-primary);font-size:1.05rem}.item-price{font-weight:700;color:var(--accent-success);font-size:1.1rem}.item-actions{display:flex;gap:8px}
