:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);position:relative;overflow:hidden;padding:20px}.login-bg-decoration{position:absolute;inset:0;pointer-events:none;z-index:0}.login-bg-circle{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3;animation:floatCircle 20s ease-in-out infinite}.login-bg-circle-1{width:500px;height:500px;background:#3b82f6;top:-150px;right:-100px;animation-delay:0s}.login-bg-circle-2{width:400px;height:400px;background:#06b6d4;bottom:-100px;left:-80px;animation-delay:-7s}.login-bg-circle-3{width:300px;height:300px;background:#8b5cf6;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s}@keyframes floatCircle{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-30px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(15px,15px) scale(1.02)}}.login-card{position:relative;z-index:1;width:100%;max-width:440px;background:#ffffff0d;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:48px 40px;box-shadow:0 25px 50px #0000004d,0 0 0 1px #ffffff0d inset;animation:cardAppear .6s cubic-bezier(.16,1,.3,1) forwards;opacity:0;transform:translateY(20px)}@keyframes cardAppear{to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:36px}.login-logo{margin-bottom:16px}.login-logo-icon{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:20px;background:linear-gradient(135deg,#3b82f6,#06b6d4);font-size:36px;box-shadow:0 8px 24px #3b82f659;animation:logoPulse 3s ease-in-out infinite}@keyframes logoPulse{0%,to{box-shadow:0 8px 24px #3b82f659}50%{box-shadow:0 8px 32px #3b82f680}}.login-title{font-size:28px;font-weight:700;color:#f1f5f9;margin:0;letter-spacing:-.5px}.login-subtitle{font-size:14px;color:#94a3b8;margin:6px 0 0;font-weight:400}.login-form{display:flex;flex-direction:column;gap:20px}.login-error{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#ef44441f;border:1px solid rgba(239,68,68,.25);border-radius:12px;color:#fca5a5;font-size:14px;animation:shakeError .4s ease-in-out}.login-error-icon{font-size:16px;flex-shrink:0}@keyframes shakeError{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.login-field{display:flex;flex-direction:column;gap:8px}.login-label{font-size:13px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.login-input-wrapper{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:14px;font-size:16px;z-index:1;opacity:.6}.login-input{width:100%;padding:14px 14px 14px 44px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#f1f5f9;font-size:15px;font-family:inherit;transition:all .2s ease;outline:none}.login-input::placeholder{color:#64748b}.login-input:hover{border-color:#fff3;background:#ffffff14}.login-input:focus{border-color:#3b82f6;background:#ffffff14;box-shadow:0 0 0 3px #3b82f626}.login-input:disabled{opacity:.5;cursor:not-allowed}.login-toggle-password{position:absolute;right:12px;background:none;border:none;cursor:pointer;font-size:16px;padding:4px;opacity:.5;transition:opacity .2s}.login-toggle-password:hover{opacity:.9}.login-submit{width:100%;padding:14px;margin-top:8px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:16px;font-weight:600;font-family:inherit;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.login-submit:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,.1) 100%);opacity:0;transition:opacity .2s}.login-submit:hover:not(:disabled):before{opacity:1}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #3b82f659}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{cursor:not-allowed;opacity:.7}.login-submit-loading{pointer-events:none}.login-spinner{display:inline-block;width:22px;height:22px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;margin-top:32px;color:#475569;font-size:12px}@media (max-width: 500px){.login-card{padding:36px 24px;border-radius:20px}.login-title{font-size:24px}.login-logo-icon{width:60px;height:60px;font-size:30px}}.dental-clinic-calendar{height:100vh;width:100%;display:flex;flex-direction:column;background-color:#f8f9fa;overflow-x:hidden}.header{background:#fff;border-bottom:1px solid #e9ecef;padding:12px 20px;display:flex;justify-content:space-between;align-items:center;height:60px;position:relative}.header-left{display:flex;align-items:center}.logo{display:flex;align-items:center;gap:8px}.logo-icon{font-size:24px}.logo-text{font-size:18px;font-weight:600;color:#333}.header-center{display:flex;align-items:center}.calendar-controls{display:flex;align-items:center;gap:16px}.nav-btn{background:#f8f9fa;border:1px solid #dadce0;font-size:18px;cursor:pointer;padding:8px 12px;border-radius:6px;transition:all .2s;color:#5f6368;font-weight:500;min-width:36px;display:flex;align-items:center;justify-content:center}.nav-btn:hover{background-color:#f1f3f4;border-color:#bdc1c6;color:#333}.current-date{font-size:18px;font-weight:500;color:#333;margin:0;min-width:200px;text-align:center}.clickable-date{cursor:pointer;padding:8px 12px;border-radius:6px;transition:background-color .2s}.clickable-date:hover{background-color:#f1f3f4}.date-picker-container{position:relative}.date-picker-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%);background:#fff;border:1px solid #dadce0;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;margin-top:8px;padding:16px;min-width:280px}.date-picker-header{text-align:center;margin-bottom:16px;font-weight:600;color:#333}.date-picker-month{font-size:16px}.date-picker-calendar{display:flex;flex-direction:column}.date-picker-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.weekday-header{text-align:center;font-size:12px;font-weight:500;color:#5f6368;padding:8px 4px}.date-picker-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;border-radius:4px;transition:all .2s;color:#333}.calendar-day.other-month{color:#9aa0a6}.calendar-day.today{background-color:#e8f0fe;color:#1976d2;font-weight:600}.calendar-day.selected{background-color:#1976d2;color:#fff;font-weight:600}.calendar-day.selected:hover{background-color:#1565c0}.today-btn{background:#e3f2fd;border:1px solid #2196f3;color:#1976d2;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.header-right{display:flex;align-items:center;gap:12px}.zoom-controls-container{position:relative}.zoom-btn{background:#f8f9fa;border:1px solid #dadce0;color:#5f6368;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;transition:background-color .2s}.zoom-btn:hover{background:#f1f3f4}.zoom-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid #dadce0;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:12px;min-width:200px;z-index:1000}.zoom-header{text-align:center;padding-bottom:8px;margin-bottom:8px;border-bottom:1px solid #e9ecef}.zoom-level-text{font-size:16px;font-weight:600;color:#333}.zoom-controls{display:flex;align-items:center;gap:8px;justify-content:center}.zoom-control-btn{background:#f8f9fa;border:1px solid #dadce0;color:#5f6368;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;min-width:40px;transition:all .2s}.zoom-control-btn:hover:not(:disabled){background:#e8eaed;border-color:#bdc1c6}.zoom-control-btn:disabled{opacity:.4;cursor:not-allowed}.zoom-reset-btn{background:#fff;border:1px solid #dadce0;color:#5f6368;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;transition:all .2s}.zoom-reset-btn:hover{background:#f8f9fa;border-color:#bdc1c6}.zoom-icon{font-size:18px;line-height:1}.view-selector-container{position:relative}.view-selector-btn{background:#f8f9fa;border:1px solid #dadce0;color:#5f6368;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:8px;transition:background-color .2s}.view-selector-btn:hover{background:#f1f3f4}.view-icon{font-size:14px}.dropdown-arrow{font-size:10px;color:#9aa0a6}.view-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #dadce0;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;z-index:1000;margin-top:4px;padding:8px 0}.view-option{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;font-size:14px;transition:background-color .2s}.view-option:hover{background-color:#f8f9fa}.view-option.active{background-color:#e8f0fe;color:#1976d2}.view-option-icon{font-size:14px;margin-right:12px}.view-option-label{flex:1}.view-option-shortcut{font-size:12px;color:#5f6368;background:#f1f3f4;padding:2px 6px;border-radius:4px;font-family:monospace}.view-separator{height:1px;background:#e9ecef;margin:8px 0}.clinic-selector-container{position:relative}.clinic-selector-btn{background:#f8f9fa;border:1px solid #dadce0;color:#5f6368;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:8px;transition:background-color .2s}.clinic-selector-btn:hover{background:#f1f3f4}.clinic-icon{font-size:14px}.clinic-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #dadce0;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:220px;z-index:1000;margin-top:4px;padding:8px 0}.clinic-option{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;font-size:14px;transition:background-color .2s}.clinic-option:hover{background-color:#f8f9fa}.clinic-option.active{background-color:#e8f0fe;color:#1976d2}.clinic-option-icon{margin-right:12px;font-size:16px}.clinic-option-label{flex:1;font-weight:500}.clinic-option-city{font-size:12px;color:#9aa0a6;margin-left:8px}.clinic-separator{height:1px;background:#e9ecef;margin:8px 0}.toggle-switch{position:relative;display:inline-block;width:36px;height:20px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:20px}.toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.toggle-slider{background-color:#1976d2}input:checked+.toggle-slider:before{transform:translate(16px)}.clinic-scheduler-btn{background:#f1f3f4;border:1px solid #dadce0;color:#5f6368;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;margin-right:8px;position:relative;z-index:10;min-width:40px;height:40px}.clinic-scheduler-btn:hover{background:#e8eaed;border-color:#c1c7cd;transform:scale(1.05)}.clinic-scheduler-btn:active{background:#d2d4d7;transform:scale(.95)}.multi-clinic-overview-btn{background:#f1f3f4;border:1px solid #dadce0;color:#5f6368;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;margin-right:8px;position:relative;z-index:10;min-width:40px;height:40px}.multi-clinic-overview-btn:hover{background:#e8eaed;border-color:#c1c7cd;transform:scale(1.05)}.multi-clinic-overview-btn:active{background:#d2d4d7;transform:scale(.95)}.payment-system-btn{background:#f1f3f4;border:1px solid #dadce0;color:#5f6368;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;margin-right:8px;position:relative;z-index:10;min-width:40px;height:40px}.payment-system-btn:hover{background:#e8eaed;border-color:#c1c7cd;transform:scale(1.05)}.payment-system-btn:active{background:#d2d4d7;transform:scale(.95)}.share-btn{background:#f1f3f4;border:1px solid #dadce0;color:#5f6368;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:6px}.add-menu-container{position:relative}.add-btn{background:#1976d2;color:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.add-btn:hover{background:#1565c0}.add-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #dadce0;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;z-index:1000;margin-top:4px}.dropdown-item{padding:12px 16px;cursor:pointer;display:flex;align-items:center;gap:12px;font-size:14px;transition:background-color .2s}.dropdown-item:hover{background-color:#f8f9fa}.dropdown-item:first-child{border-radius:8px 8px 0 0}.dropdown-item:last-child{border-radius:0 0 8px 8px}.dropdown-icon{font-size:16px}.dropdown-overlay{position:fixed;inset:0;z-index:999}.main-content{flex:1;display:flex;overflow:hidden;width:100%;max-width:100%}.sidebar{width:280px;background:#fff;border-right:1px solid #e9ecef;padding:20px;overflow-y:auto;display:flex;flex-direction:column}.sidebar-section{margin-bottom:24px}.sidebar-section h3,.sidebar-section h4{font-size:14px;font-weight:600;margin-bottom:12px;color:#5f6368}.calendar-filter{display:flex;align-items:center;gap:8px;margin-bottom:16px}.calendar-filter input[type=checkbox]{width:16px;height:16px}.calendar-filter label{font-size:14px;color:#333;cursor:pointer}.search-box{margin-bottom:16px}.search-box input{width:100%;padding:8px 12px;border:1px solid #dadce0;border-radius:6px;font-size:14px;background:#f8f9fa}.doctor-list{display:flex;flex-direction:column;gap:8px}.doctor-item{display:flex;align-items:center;gap:8px}.doctor-item input[type=checkbox]{width:16px;height:16px}.doctor-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#333;cursor:pointer}.doctor-initial,.team-initial{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#333}.team-initial{background-color:#f1f3f4}.doctor-initial-dr-grace{background-color:#e3f2fd}.doctor-initial-dr-sani{background-color:#f3e5f5}.doctor-initial-dr-maria{background-color:#e8f5e8}.doctor-initial-dr-vicky{background-color:#fff3e0}.doctor-initial-dr-harry{background-color:#fce4ec}.doctor-initial-dr-paul{background-color:#e0f7fa}.doctor-initial-dr-denis{background-color:#f1f8e9}.doctor-initial-dr-paula{background-color:#ede7f6}.sidebar-footer{margin-top:auto;padding-top:20px}.booking-link-btn{background:none;border:none;color:#1976d2;font-size:14px;cursor:pointer;display:flex;align-items:center;gap:8px;padding:8px 0}.sidebar-user-section{padding:16px 0;border-top:1px solid #e9ecef;border-bottom:1px solid #e9ecef;margin-bottom:16px}.sidebar-user-info{display:flex;align-items:center;gap:10px;margin-bottom:10px}.sidebar-user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#06b6d4);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.sidebar-user-name{font-size:14px;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout-btn{width:100%;padding:8px 12px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;color:#666;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s ease;font-family:inherit}.sidebar-logout-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.calendar-container{flex:1;display:flex;flex-direction:column;background:#fff;overflow:hidden;width:100%;max-width:100%}.calendar-header{border-bottom:1px solid #e9ecef;display:flex;background:#fff;position:sticky;top:0;z-index:10}.time-column{width:80px;background:#fff;border-right:1px solid #e9ecef;display:flex;align-items:center;justify-content:center;position:relative}.payment-status-toggle{background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:8px 12px;font-size:18px;cursor:pointer;transition:all .2s ease;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.payment-status-toggle:hover{background:#f5f5f5;border-color:#2196f3;transform:translate(-50%,-50%) scale(1.1)}.payment-status-toggle.active{background:#2196f3;border-color:#2196f3;color:#fff}.payment-status-toggle.active:hover{background:#1976d2;border-color:#1976d2}.doctor-header{flex:1;text-align:center;padding:16px 8px;font-size:14px;font-weight:500;color:#333;border-right:1px solid #f1f3f4;min-width:200px}.calendar-body{flex:1;display:flex;overflow:auto;min-height:2720px}.time-column{display:flex;flex-direction:column}.time-slot{height:160px;min-height:160px;display:flex;align-items:center;justify-content:center;font-size:12px;color:#5f6368;border-top:1px solid #d0d0d0;flex-shrink:0;box-sizing:border-box}.calendar-grid{flex:1;display:flex;position:relative}.doctor-column{flex:1;position:relative;border-right:1px solid #f1f3f4;min-width:200px}.time-grid{position:absolute;top:0;left:0;right:0;height:100%;pointer-events:none;will-change:transform}.time-line{position:absolute;left:0;right:0;height:160px;border-top:1px solid #d0d0d0;pointer-events:none;box-sizing:border-box}.appointment{position:absolute;left:4px;right:4px;border-radius:6px;padding:4px 8px;font-size:11px;cursor:pointer;border-left:4px solid;background:#ffffffe6;box-shadow:0 1px 3px #0000001f;transition:background .3s,box-shadow .2s;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start;line-height:1.2}.appointment.appointment-status-default{background:#ffffffe6!important}.appointment.appointment-status-yellow{background:#ffeb3b80!important}.appointment.appointment-status-blue{background:#2196f380!important}.appointment:hover{box-shadow:0 2px 8px #00000026}.appointment:hover .appointment-resize-handle{opacity:1}.appointment.resizing{box-shadow:0 4px 16px #00000040;z-index:20}.appointment-resize-handle{position:absolute;bottom:0;left:0;right:0;height:8px;cursor:ns-resize;opacity:0;transition:opacity .2s;background:linear-gradient(to bottom,transparent,rgba(0,0,0,.1));border-bottom-left-radius:6px;border-bottom-right-radius:6px}.appointment-resize-handle:after{content:"";position:absolute;bottom:1px;left:50%;transform:translate(-50%);width:30px;height:3px;background:#0000004d;border-radius:2px}.appointment-drag-handle{position:absolute;top:0;left:0;right:0;height:20px;cursor:grab;opacity:0;transition:opacity .2s;background:linear-gradient(to bottom,rgba(0,0,0,.1),transparent);border-top-left-radius:6px;border-top-right-radius:6px;z-index:1}.appointment:hover .appointment-drag-handle{opacity:1}.appointment-drag-handle:before{content:"⋮⋮";position:absolute;top:2px;left:50%;transform:translate(-50%);font-size:10px;color:#0006;letter-spacing:-2px}.appointment-content{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;width:100%}.appointment-info{flex:1;min-width:0}.appointment-title{font-weight:600;margin-bottom:2px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.appointment-payment-status{font-size:10px;font-weight:600;margin-bottom:2px;padding:2px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appointment-payment-status.payment-paid{color:#4caf50}.appointment-payment-status.payment-partial{color:#ff9800}.appointment-payment-status.payment-unpaid{color:#f44336}.appointment-payment-status.payment-none{color:#9e9e9e}.appointment-time{color:#5f6368;font-size:11px;flex-shrink:0}.appointment-status-btn{background:none;border:none;cursor:pointer;padding:4px;font-size:18px;line-height:1;transition:transform .2s;flex-shrink:0;min-width:24px;height:24px;display:flex;align-items:center;justify-content:center}.appointment-status-btn:hover{transform:scale(1.3)}.appointment-status-btn.status-default{color:#ff5722!important}.appointment-status-btn.status-yellow{color:#ffc107!important}.appointment-status-btn.status-blue{color:#2196f3!important}.appointment-patient{color:#333;font-size:11px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-height:0;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}.appointment.compact .appointment-patient,.week-appointment.compact .appointment-patient{display:none}.appointment.compact .appointment-time,.week-appointment.compact .appointment-time{margin-top:1px}.appointment-dr-grace{border-left-color:#2196f3;background-color:#e3f2fd}.appointment-dr-sani{border-left-color:#9c27b0;background-color:#f3e5f5}.appointment-dr-maria{border-left-color:#4caf50;background-color:#e8f5e8}.appointment-dr-vicky{border-left-color:#ff9800;background-color:#fff3e0}.appointment-dr-harry{border-left-color:#e91e63;background-color:#fce4ec}.appointment-dr-paul{border-left-color:#00bcd4;background-color:#e0f7fa}.appointment-dr-denis{border-left-color:#8bc34a;background-color:#f1f8e9}.appointment-dr-paula{border-left-color:#673ab7;background-color:#ede7f6}.appointment-preview{position:absolute;left:4px;right:4px;border-radius:6px;padding:8px;background:#fffffff2;border:2px dashed #4285f4;color:#333;font-size:12px;pointer-events:none;z-index:10;box-shadow:0 2px 4px #0000001a}.preview-time{font-weight:600;margin-bottom:2px}.preview-doctor{color:#5f6368;font-size:11px}.floating-time-selector{position:fixed;background:#fff;color:#333;padding:6px 12px;border-radius:4px;font-size:14px;font-weight:400;pointer-events:none;z-index:1000;box-shadow:0 2px 8px #00000026;border:1px solid #333;min-width:80px;text-align:center}.current-time-indicator{position:absolute;left:0;right:0;z-index:100;pointer-events:none}.current-time-label{position:absolute;left:-75px;top:-10px;background:#333;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap}.current-time-line{position:absolute;left:0;right:0;height:2px;background:#333;box-shadow:0 1px 3px #0000004d}.modal-overlay{position:fixed;inset:0;background:transparent;display:flex;align-items:flex-start;justify-content:center;z-index:2000;pointer-events:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.modal-content{background:#fff;border-radius:12px;width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 24px #0003;animation:slideInRight .2s ease-out;pointer-events:auto;position:relative;margin-top:80px}.modal-header{padding:20px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center}.modal-header h3{font-size:18px;font-weight:600;margin:0}.close-btn{background:none;border:none;font-size:16px;cursor:pointer;padding:4px;border-radius:4px;color:#5f6368}.close-btn:hover{background:#f1f3f4}.modal-body{padding:20px}.tabs{display:flex;gap:0;margin-bottom:20px;position:relative}.tab{background:none;border:none;padding:12px 16px;cursor:pointer;font-size:14px;color:#5f6368;border-bottom:2px solid transparent;transition:all .2s}.tab.active{color:#1976d2;border-bottom-color:#1976d2}.label-select{position:absolute;right:0;top:50%;transform:translateY(-50%);border:1px solid #dadce0;border-radius:6px;padding:6px 12px;font-size:12px;background:#fff;color:#5f6368}.patient-search-container{position:relative;display:flex;align-items:center;gap:12px;padding:12px;border:1px solid #e9ecef;border-radius:8px;transition:border-color .2s}.patient-search-container:hover{border-color:#dadce0}.patient-search-input{border:none;background:none;flex:1;font-size:14px;color:#333;outline:none}.patient-search-input::placeholder{color:#9aa0a6}.clear-patient-search{background:none;border:none;color:#9aa0a6;cursor:pointer;padding:4px;font-size:16px;line-height:1;transition:color .2s}.clear-patient-search:hover{color:#333}.patient-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:240px;overflow-y:auto;z-index:1000}.patient-option{padding:12px;cursor:pointer;border-bottom:1px solid #f1f3f4;transition:background-color .2s}.patient-option:last-child{border-bottom:none}.patient-option:hover{background-color:#f8f9fa}.patient-name{font-size:14px;color:#333;font-weight:500;margin-bottom:4px}.patient-phone{font-size:12px;color:#9aa0a6}.patient-option-empty{padding:12px;text-align:center;color:#9aa0a6;font-size:14px}.service-selector,.guest-input,.video-input,.notes-input,.provider-select,.title-input,.date-input,.reception-input,.custom-service-input{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid #e9ecef;border-radius:8px;transition:border-color .2s}.service-selector:hover,.guest-input:hover,.video-input:hover,.provider-select:hover,.title-input:hover,.reception-input:hover,.custom-service-input:hover{border-color:#dadce0}.custom-service-input{border-color:#4285f4;background-color:#f8f9ff}.custom-service-input input{border:none;background:none;flex:1;font-size:14px;color:#333;outline:none}.custom-service-input input::placeholder{color:#9aa0a6}.service-icon,.guest-icon,.video-icon,.notes-icon,.provider-icon,.title-icon,.date-icon,.reception-icon{font-size:16px;color:#5f6368;flex-shrink:0}.service-select,.guest-input input,.video-input input,.title-input input,.provider-select select,.reception-input input{border:none;background:none;flex:1;font-size:14px;color:#333;outline:none}.guest-input input::placeholder,.video-input input::placeholder,.title-input input::placeholder,.reception-input input::placeholder{color:#9aa0a6}.datetime-group{display:flex;gap:12px;align-items:center}.date-input{flex:1}.date-input input[type=date]{border:none;background:none;font-size:14px;color:#333}.repeat-text{font-size:12px;color:#5f6368;margin-left:auto}.time-inputs{display:flex;align-items:center;gap:8px}.time-inputs input[type=time]{border:1px solid #e9ecef;border-radius:6px;padding:8px 12px;font-size:14px}.time-inputs span{color:#5f6368}.notes-input{align-items:flex-start}.notes-input textarea{border:none;background:none;flex:1;font-size:14px;color:#333;resize:vertical;min-height:60px;font-family:inherit;outline:none}.notes-input textarea::placeholder{color:#9aa0a6}.modal-footer{padding:20px;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end}.create-btn{background:#333;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.create-btn:hover:not(:disabled){background:#555}.create-btn:disabled{background:#ccc;cursor:not-allowed}.error-message{background:#ffebee;color:#c62828;padding:12px;border-radius:6px;margin-bottom:16px;font-size:14px;border:1px solid #ffcdd2}.loading-container,.error-container{display:flex;align-items:center;justify-content:center;height:100vh;font-size:18px}.loading-spinner{color:#1976d2}.error-message{color:#c62828;text-align:center}.retry-btn{background:#1976d2;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;margin-left:12px}.week-view{flex:1;display:flex;flex-direction:column;background:#fff;overflow:hidden;width:calc(100vw - 280px);max-width:calc(100vw - 280px)}.week-header{border-bottom:1px solid #e9ecef;display:flex;background:#fff;position:sticky;top:0;z-index:10}.time-column-header{width:80px;background:#fff;border-right:1px solid #e9ecef}.day-header{flex:1;text-align:center;padding:16px 8px;border-right:1px solid #f1f3f4;min-width:140px}.day-header:last-child{border-right:none}.day-number{font-size:24px;font-weight:600;color:#333;margin-bottom:4px}.day-name{font-size:12px;color:#5f6368;text-transform:uppercase;font-weight:500}.week-body{flex:1;display:flex;overflow:auto}.week-grid{flex:1;display:flex;position:relative;min-height:900px}.day-column{flex:1;position:relative;border-right:1px solid #f1f3f4;min-width:140px}.day-column:last-child{border-right:none}.day-column.today{background-color:#fafbff}.week-appointment{position:absolute;left:4px;right:4px;border-radius:6px;padding:4px 8px;font-size:10px;cursor:pointer;border-left:4px solid;background:#ffffffe6;box-shadow:0 1px 3px #0000001f;transition:box-shadow .2s;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start;line-height:1.2}.week-appointment:hover{box-shadow:0 2px 8px #00000026}.week-appointment .appointment-title{font-weight:600;margin-bottom:2px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.week-appointment .appointment-time{color:#5f6368;font-size:10px;flex-shrink:0}.week-appointment .appointment-patient{color:#333;font-size:10px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-height:0;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}.week-appointment .appointment-drag-handle{position:absolute;top:0;left:0;right:0;height:18px;cursor:grab;opacity:0;transition:opacity .2s;background:linear-gradient(to bottom,rgba(0,0,0,.08),transparent);border-top-left-radius:6px;border-top-right-radius:6px;z-index:1}.week-appointment:hover .appointment-drag-handle{opacity:1}.week-appointment .appointment-drag-handle:before{content:"⋮⋮";position:absolute;top:1px;left:50%;transform:translate(-50%);font-size:9px;color:#0006;letter-spacing:-2px}.week-appointment.appointment-dr-grace{border-left-color:#2196f3;background-color:#e3f2fd}.week-appointment.appointment-dr-sani{border-left-color:#9c27b0;background-color:#f3e5f5}.week-appointment.appointment-dr-maria{border-left-color:#4caf50;background-color:#e8f5e8}.week-appointment.appointment-dr-vicky{border-left-color:#ff9800;background-color:#fff3e0}.week-appointment.appointment-dr-harry{border-left-color:#e91e63;background-color:#fce4ec}.week-appointment.appointment-dr-paul{border-left-color:#00bcd4;background-color:#e0f7fa}.week-appointment.appointment-dr-denis{border-left-color:#8bc34a;background-color:#f1f8e9}.week-appointment.appointment-dr-paula{border-left-color:#673ab7;background-color:#ede7f6}.day-header-with-doctors{flex:1;border-right:1px solid #e9ecef;display:flex;flex-direction:column}.day-header-with-doctors:last-child{border-right:none}.day-header-with-doctors .day-header{padding:8px;text-align:center;border-bottom:1px solid #f1f3f4;background:#fafbfc}.day-header-with-doctors .day-name{font-size:11px;font-weight:600;color:#5f6368;text-transform:uppercase;margin-bottom:2px}.day-header-with-doctors .day-number{font-size:11px;font-weight:500;color:#333}.doctor-headers{display:flex;background:#fff}.doctor-header{flex:1;padding:6px 4px;text-align:center;font-size:10px;font-weight:600;color:#5f6368;border-right:1px solid #f1f3f4;min-width:40px}.doctor-header:last-child{border-right:none}.day-column-with-doctors{flex:1;position:relative;border-right:1px solid #e9ecef;display:flex}.day-column-with-doctors:last-child{border-right:none}.day-column-with-doctors.today{background-color:#fafbff}.day-column-with-doctors .time-grid{position:absolute;inset:0;pointer-events:none;z-index:0}.doctor-column{flex:1;position:relative;border-right:1px solid #f1f3f4;min-width:40px}.doctor-column:last-child{border-right:none}.month-view{flex:1;display:flex;flex-direction:column;background:#fff;overflow:hidden;width:calc(100vw - 280px);max-width:calc(100vw - 280px)}.month-header{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid #e9ecef;background:#fff}.month-day-header{padding:16px 8px;text-align:center;font-size:14px;font-weight:600;color:#5f6368;text-transform:uppercase;border-right:1px solid #f1f3f4}.month-day-header:last-child{border-right:none}.month-grid{flex:1;overflow:auto}.month-week{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid #f1f3f4}.month-week:last-child{border-bottom:none}.month-day{min-height:120px;padding:8px;border-right:1px solid #f1f3f4;cursor:pointer;transition:background-color .2s}.month-day:last-child{border-right:none}.month-day:hover{background-color:#f8f9fa}.month-day.other-month{background-color:#fafafa;color:#9aa0a6}.month-day.today{background-color:#e8f0fe}.month-day.selected{background-color:#1976d2;color:#fff}.month-day.selected .day-number{color:#fff}.day-number{font-size:16px;font-weight:600;margin-bottom:8px;color:#333}.day-appointments{display:flex;flex-direction:column;gap:2px}.month-appointment{padding:2px 6px;border-radius:4px;font-size:11px;cursor:pointer;border-left:3px solid;background:#ffffffe6;transition:opacity .2s;display:flex;align-items:center;gap:4px}.month-appointment:hover{opacity:.8}.month-appointment .appointment-time{font-weight:600;flex-shrink:0}.month-appointment .appointment-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.more-appointments{font-size:10px;color:#5f6368;margin-top:2px;cursor:pointer}.more-appointments:hover{color:#1976d2}.month-appointment-dr-grace{border-left-color:#2196f3;background-color:#e3f2fd}.month-appointment-dr-sani{border-left-color:#9c27b0;background-color:#f3e5f5}.month-appointment-dr-maria{border-left-color:#4caf50;background-color:#e8f5e8}.month-appointment-dr-vicky{border-left-color:#ff9800;background-color:#fff3e0}.month-appointment-dr-harry{border-left-color:#e91e63;background-color:#fce4ec}.month-appointment-dr-paul{border-left-color:#00bcd4;background-color:#e0f7fa}.month-appointment-dr-denis{border-left-color:#8bc34a;background-color:#f1f8e9}.month-appointment-dr-paula{border-left-color:#673ab7;background-color:#ede7f6}.appointment-detail-modal{background:#fff;border-radius:12px;width:400px;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #00000026;pointer-events:auto;z-index:2001}.appointment-detail-header{padding:20px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center}.appointment-detail-header h3{font-size:18px;font-weight:600;margin:0}.appointment-detail-tabs{display:flex;border-bottom:1px solid #e9ecef}.detail-tab{background:none;border:none;padding:16px 24px;cursor:pointer;font-size:14px;color:#5f6368;border-bottom:2px solid transparent;transition:all .2s}.detail-tab.active{color:#1976d2;border-bottom-color:#1976d2}.appointment-detail-content{padding:20px}.appointment-title-section{display:flex;align-items:center;gap:12px;margin-bottom:20px}.appointment-color-dot{width:12px;height:12px;border-radius:50%}.appointment-title-text{font-size:16px;font-weight:500;color:#333}.appointment-info-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.info-icon{font-size:16px;color:#5f6368;flex-shrink:0;margin-top:2px}.doctor-icon{background:#f1f3f4;border-radius:4px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#333;margin-top:0}.appointment-datetime{display:flex;flex-direction:column;gap:2px}.date-text{font-size:14px;color:#333;font-weight:500}.time-text{font-size:14px;color:#5f6368}.doctor-name,.patient-name,.service-name{font-size:14px;color:#333}.booking-info{display:flex;flex-direction:column;gap:2px}.booking-info div:first-child{font-size:14px;color:#333}.booking-id{font-size:12px;color:#5f6368}.status-section{display:flex;align-items:center;gap:8px;font-size:14px;color:#333}.status-select{border:none;background:none;font-size:14px;font-weight:500;cursor:pointer;outline:none}.notes-section{display:flex;flex-direction:column;gap:4px}.notes-label{font-size:14px;color:#333;font-weight:500}.notes-text{font-size:14px;color:#5f6368;line-height:1.4}.video-link{color:#1976d2;text-decoration:none;font-size:14px}.video-link:hover{text-decoration:underline}.appointment-history{padding:0}.history-item{display:flex;flex-direction:column;gap:4px;padding:12px 0;border-bottom:1px solid #f1f3f4}.history-item:last-child{border-bottom:none}.history-date{font-size:12px;color:#5f6368}.history-action{font-size:14px;color:#333}.appointment-detail-footer{padding:20px;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end}.action-buttons{display:flex;align-items:center;gap:12px}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.calendar-nav{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px;color:#5f6368;transition:background-color .2s}.calendar-nav:hover{background-color:#f1f3f4}.calendar-month{font-size:14px;font-weight:500;color:#333}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.calendar-weekday{text-align:center;font-size:12px;color:#5f6368;font-weight:500;padding:8px 4px}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day{background:none;border:none;padding:8px 4px;text-align:center;cursor:pointer;font-size:14px;border-radius:4px;transition:background-color .2s;color:#333;min-height:32px;display:flex;align-items:center;justify-content:center}.calendar-day:hover{background-color:#f1f3f4}.calendar-day.other-month{color:#bdc1c6}.calendar-day.selected{background-color:#4285f4;color:#fff}.calendar-day.selected:hover{background-color:#3367d6}.date-picker-button{background:none;border:1px solid #dadce0;border-radius:4px;padding:8px 12px;font-size:14px;cursor:pointer;color:#333;transition:border-color .2s,box-shadow .2s;min-width:140px;text-align:left}.date-picker-button:hover{border-color:#1a73e8}.date-picker-button:focus{outline:none;border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e833}.booking-calendar-picker{width:280px}.date-input{position:relative}.date-input .date-picker-overlay{position:absolute;top:calc(100% + 4px);left:0;z-index:1000;background:#fff;border:1px solid #dadce0;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:16px}.time-inputs{display:flex;align-items:center;gap:12px}.time-picker-container{position:relative}.time-picker-button{background:#fff;border:1px solid #dadce0;border-radius:20px;padding:8px 16px;font-size:14px;cursor:pointer;color:#333;transition:all .2s;min-width:80px;text-align:center}.time-picker-button:hover{border-color:#1a73e8;background-color:#f8f9fa}.time-picker-button:focus{outline:none;border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e833}.time-separator{color:#5f6368;font-weight:500}.time-picker-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:1000;background:#fff;border:1px solid #dadce0;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:200px;overflow-y:auto;min-width:100px}.time-option{background:none;border:none;width:100%;padding:8px 16px;font-size:14px;cursor:pointer;color:#333;text-align:left;transition:background-color .2s}.time-option:hover{background-color:#f1f3f4}.time-option:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.time-option:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.options-container{position:relative}.options-btn{background:none;border:none;font-size:20px;color:#5f6368;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s}.options-btn:hover{background:#f1f3f4}.options-dropdown{position:absolute;bottom:100%;right:0;background:#fff;border:1px solid #dadce0;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:180px;z-index:1000;margin-bottom:4px}.option-item{display:block;width:100%;background:none;border:none;padding:12px 16px;text-align:left;cursor:pointer;font-size:14px;color:#333;transition:background-color .2s}.option-item:hover{background:#f8f9fa}.option-item:first-child{border-radius:8px 8px 0 0}.option-item:last-child{border-radius:0 0 8px 8px}.delete-option{color:#d32f2f}.delete-option:hover{background:#ffebee}.edit-btn{background:none;border:none;font-size:16px;color:#5f6368;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s}.edit-btn:hover{background:#f1f3f4}.dropdown-overlay-small{position:fixed;inset:0;z-index:999}.add-team-modal{width:600px;max-height:90vh}.team-member-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px;position:relative}.member-inputs{flex:1;display:flex;gap:12px;align-items:flex-start}.input-group{flex:1;position:relative}.member-input{width:100%;padding:12px 16px;border:1px solid #dadce0;border-radius:8px;font-size:14px;transition:border-color .2s}.member-input:focus{outline:none;border-color:#1976d2}.member-input.error{border-color:#d32f2f}.field-error{color:#d32f2f;font-size:12px;margin-top:4px;position:absolute;left:0;top:100%}.permission-group{min-width:160px}.permission-selector{position:relative}.permission-btn{width:100%;padding:12px 16px;border:1px solid #dadce0;border-radius:8px;background:#fff;cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:2px;transition:border-color .2s}.permission-btn:hover{border-color:#bdc1c6}.permission-label{font-size:12px;color:#5f6368}.permission-value{font-size:14px;color:#333;font-weight:500}.permission-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #dadce0;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1001;margin-top:4px;padding:8px;max-height:300px;overflow-y:auto}.permission-option{display:flex;align-items:flex-start;gap:12px;padding:12px;cursor:pointer;border-radius:6px;transition:background-color .2s}.permission-option:hover{background-color:#f8f9fa}.permission-option.selected{background-color:#e8f0fe}.permission-radio{margin-top:2px}.permission-radio input[type=radio]{width:16px;height:16px}.permission-details{flex:1}.permission-title{font-size:14px;font-weight:500;color:#333;margin-bottom:2px}.permission-description{font-size:12px;color:#5f6368;line-height:1.4}.remove-member-btn{background:none;border:none;color:#5f6368;cursor:pointer;padding:8px;border-radius:4px;margin-top:12px;transition:all .2s;font-size:16px}.remove-member-btn:hover{background-color:#f8f9fa;color:#d32f2f}.add-more-btn{background:none;border:none;color:#1976d2;cursor:pointer;font-size:14px;padding:8px 0;margin-bottom:20px;transition:color .2s}.add-more-btn:hover{color:#1565c0}.info-message{display:flex;align-items:flex-start;gap:8px;padding:12px 16px;background-color:#f8f9fa;border-radius:8px;margin-bottom:20px}.info-icon{font-size:16px;margin-top:1px}.info-message{font-size:13px;color:#5f6368;line-height:1.4}.cancel-btn{background:none;border:1px solid #dadce0;color:#5f6368;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:14px;margin-right:12px;transition:all .2s}.cancel-btn:hover{background-color:#f8f9fa;border-color:#bdc1c6}.invite-btn{background:#1976d2;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.invite-btn:hover:not(:disabled){background:#1565c0}.invite-btn:disabled{background:#ccc;cursor:not-allowed}@media (max-width: 768px){.sidebar{position:fixed;left:-280px;top:60px;height:calc(100vh - 60px);z-index:1000;transition:left .3s}.sidebar.open{left:0}.calendar-container{margin-left:0}.header-center{flex:1;justify-content:center}.current-date{min-width:150px;font-size:16px}.nav-btn{padding:6px 10px;font-size:18px}.today-btn{padding:6px 12px;font-size:12px}.modal-content{width:90%;margin:20px}.datetime-group{flex-direction:column;align-items:stretch}}.patient-detail-modal{background:#fff;border-radius:12px;width:500px;max-width:95vw;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 40px #00000026}.patient-header{padding:20px 20px 0;position:relative}.patient-header .close-btn{position:absolute;top:10px;right:15px;background:none;border:none;font-size:20px;cursor:pointer;color:#666;padding:5px;border-radius:4px}.patient-header .close-btn:hover{background-color:#f0f0f0;color:#333}.patient-info{display:flex;align-items:center;gap:15px;margin-bottom:20px}.patient-avatar{width:50px;height:50px;border-radius:50%;background-color:#e0e0e0;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;color:#666}.patient-details{flex:1}.patient-name{font-size:22px;font-weight:600;color:#333;margin:0 0 5px}.patient-location{color:#666;font-size:14px}.patient-tabs{border-bottom:1px solid #e0e0e0;display:flex;padding:0 20px}.patient-tab{background:none;border:none;padding:12px 16px;cursor:pointer;font-size:14px;color:#666;border-bottom:2px solid transparent;transition:all .2s}.patient-tab.active{color:#007bff;border-bottom-color:#007bff}.patient-content{padding:20px;min-height:300px}.patient-details{display:flex;flex-direction:column;gap:20px}.contact-info{display:flex;flex-direction:column;gap:10px}.contact-item{display:flex;align-items:center;gap:10px}.contact-icon{font-size:16px;width:20px}.contact-text{flex:1;color:#333}.add-email-btn{background:none;border:none;color:#007bff;cursor:pointer;text-decoration:underline;font-size:14px}.add-email-btn:hover{color:#0056b3}.patient-info-section{border-top:1px solid #f0f0f0;padding-top:20px}.patient-info-section h3{margin:0 0 15px;font-size:16px;font-weight:600;color:#333}.info-grid{display:flex;flex-direction:column;gap:10px}.info-item{display:flex;flex-direction:column;gap:2px}.info-label{font-size:12px;color:#666;font-weight:500}.info-value{font-size:14px;color:#333}.info-input,.contact-input{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;color:#333;background:#fff;transition:border-color .2s}.info-input:focus,.contact-input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d21a}.info-textarea{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;color:#333;background:#fff;font-family:inherit;resize:vertical;min-height:80px;transition:border-color .2s}.info-textarea:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d21a}.info-item-checkbox{display:flex;align-items:center}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label span{font-size:14px;color:#333}.info-item-full{grid-column:1 / -1}.inline-edit-actions{display:flex;gap:10px;margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.inline-edit-actions button{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.inline-edit-actions button:first-child{background:#1976d2;color:#fff}.inline-edit-actions button:first-child:hover{background:#1565c0}.inline-edit-actions button:first-child:disabled{background:#90caf9;cursor:not-allowed}.inline-edit-actions button:last-child{background:#f5f5f5;color:#666;border:1px solid #ddd}.inline-edit-actions button:last-child:hover{background:#e0e0e0}.patient-notes{display:flex;flex-direction:column;gap:15px}.notes-section h3{margin:0 0 10px;font-size:16px;font-weight:600;color:#333}.notes-content{background-color:#f8f9fa;padding:15px;border-radius:8px;border:1px solid #e9ecef}.notes-content p{margin:0;color:#333;line-height:1.5}.no-notes{color:#666;font-style:italic}.patient-appointments h3{margin:0 0 15px;font-size:16px;font-weight:600;color:#333}.appointments-list{display:flex;flex-direction:column;gap:15px}.appointment-item{background-color:#f8f9fa;padding:15px;border-radius:8px;border:1px solid #e9ecef}.appointment-date{font-size:12px;color:#666;font-weight:500;margin-bottom:8px}.appointment-details{display:flex;flex-direction:column;gap:4px}.appointment-title{font-size:14px;font-weight:600;color:#333}.appointment-time{font-size:13px;color:#666}.appointment-doctor{font-size:13px;color:#007bff}.appointment-service{font-size:12px;color:#666;font-style:italic}.appointment-status{font-size:12px;font-weight:500;text-transform:capitalize;padding:2px 8px;border-radius:12px;display:inline-block;margin-top:5px}.appointment-status.status-scheduled{background-color:#fff3cd;color:#856404}.appointment-status.status-confirmed{background-color:#d4edda;color:#155724}.appointment-status.status-completed{background-color:#e2e3f7;color:#383d41}.appointment-status.status-cancelled{background-color:#f8d7da;color:#721c24}.no-appointments{color:#666;font-style:italic;text-align:center;padding:40px 0}.patient-updates h3{margin:0 0 15px;font-size:16px;font-weight:600;color:#333}.updates-list{display:flex;flex-direction:column;gap:10px}.update-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f0f0f0}.update-item:last-child{border-bottom:none}.update-date{font-size:12px;color:#666}.update-text{font-size:14px;color:#333}.clickable-patient{background:none;border:none;color:#007bff;cursor:pointer;text-decoration:underline;font-size:inherit;padding:0;text-align:left}.clickable-patient:hover{color:#0056b3;text-decoration:none}.sidebar-navigation{border-bottom:1px solid #e0e0e0;padding:10px 0;margin-bottom:20px}.nav-menu{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 20px;background:none;border:none;text-align:left;cursor:pointer;color:#666;font-size:14px;transition:all .2s;border-radius:8px;margin:0 10px}.nav-item:hover{background-color:#f5f5f5;color:#333}.nav-item.active{background-color:#e3f2fd;color:#1976d2;font-weight:500}.nav-icon{font-size:16px;width:20px;text-align:center}.patient-page{flex:1;background:#fff;display:flex;flex-direction:column;height:100%}.patient-page-header{display:flex;align-items:center;justify-content:space-between;padding:20px 30px;border-bottom:1px solid #e0e0e0;background:#fff}.back-btn{background:none;border:none;color:#666;cursor:pointer;font-size:14px;padding:8px 12px;border-radius:6px;transition:background-color .2s}.back-btn:hover{background-color:#f5f5f5}.page-title-section{display:flex;align-items:center;gap:15px;flex:1;justify-content:center}.page-title-section h1{margin:0;font-size:24px;font-weight:600;color:#333}.add-customer-btn{width:32px;height:32px;border-radius:50%;background:#1976d2;color:#fff;border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.add-customer-btn:hover{background:#1565c0}.page-actions{display:flex;align-items:center;gap:15px}.edit-btn,.menu-btn{background:none;border:none;font-size:18px;cursor:pointer;color:#666;padding:8px;border-radius:6px}.edit-btn:hover,.menu-btn:hover{background-color:#f5f5f5}.book-appointment-btn{background:#1976d2;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;cursor:pointer;font-weight:500}.book-appointment-btn:hover{background:#1565c0}.patient-page-content{display:flex;flex:1;overflow:hidden}.patient-search-section{width:300px;border-right:1px solid #e0e0e0;padding:20px;background:#fafafa}.search-bar{position:relative;margin-bottom:20px}.search-input{width:100%;padding:10px 15px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff;color:#333}.search-input:focus{outline:none;border-color:#1976d2}.clear-search{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:#999;cursor:pointer;font-size:14px}.search-results{display:flex;flex-direction:column;gap:5px}.search-result-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:6px;cursor:pointer;transition:background-color .2s}.search-result-item:hover{background-color:#e3f2fd}.search-result-item.active{background-color:#1976d2;color:#fff}.result-initial{width:32px;height:32px;border-radius:50%;background:#e0e0e0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#666}.search-result-item.active .result-initial{background:#fff3;color:#fff}.result-name{font-size:14px;font-weight:500}.patient-details-section{flex:1;padding:30px;overflow-y:auto}.patient-main-info{display:flex;align-items:center;gap:20px;margin-bottom:30px}.patient-avatar-large{width:80px;height:80px;border-radius:50%;background:#e0e0e0;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:600;color:#666}.patient-info h2{margin:0 0 8px;font-size:28px;font-weight:600;color:#333}.patient-location{color:#666;font-size:16px}.patient-tabs{border-bottom:1px solid #e0e0e0;display:flex;margin-bottom:30px}.patient-tab{background:none;border:none;padding:15px 20px;cursor:pointer;font-size:16px;color:#666;border-bottom:3px solid transparent;transition:all .2s}.patient-tab:hover{color:#333}.patient-tab.active{color:#1976d2;border-bottom-color:#1976d2;font-weight:500}.patient-content{max-width:1200px}.photo-upload-section{display:flex;justify-content:center;margin:30px 0}.photo-placeholder{width:120px;height:120px;background:#f5f5f5;border:2px dashed #ddd;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.photo-placeholder:hover{background:#eee;border-color:#ccc}.camera-icon{font-size:40px;color:#999}@media (max-width: 768px){.patient-page-content{flex-direction:column}.patient-search-section{width:100%;border-right:none;border-bottom:1px solid #e0e0e0}.patient-details-section{padding:20px}.patient-main-info{flex-direction:column;text-align:center}.page-title-section{justify-content:flex-start}}.patient-edit-modal{width:600px;max-width:95vw}.form-row{display:flex;gap:20px}.form-row .form-group{flex:1}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#333;font-size:14px}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.form-group textarea{resize:vertical;min-height:80px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px;border-top:1px solid #e0e0e0;background:#fafafa}.cancel-btn{background:none;border:1px solid #ddd;color:#666;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.cancel-btn:hover{background:#f5f5f5;border-color:#ccc}.save-btn{background:#1976d2;border:none;color:#fff;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.save-btn:hover{background:#1565c0}.save-btn:disabled,.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#ffebee;color:#c62828;padding:12px;border-radius:6px;margin-bottom:20px;border-left:4px solid #f44336;font-size:14px}.customers-page{flex:1;background:#fff;display:flex;flex-direction:column;height:100%;overflow:hidden}.customers-header{display:flex;align-items:center;justify-content:space-between;padding:20px 30px;border-bottom:1px solid #e0e0e0;background:#fff}.customers-content{flex:1;padding:20px 30px;overflow-y:auto}.customers-search{margin-bottom:20px}.customers-list{display:flex;flex-direction:column;gap:15px}.contact-item{display:flex;align-items:center;gap:15px;padding:15px;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s;background:#fff}.contact-item:hover{border-color:#1976d2;box-shadow:0 2px 8px #1976d21a}.contact-avatar{width:50px;height:50px;border-radius:50%;background:#e0e0e0;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;color:#666;flex-shrink:0}.contact-info{flex:1}.contact-name{margin:0 0 5px;font-size:16px;font-weight:600;color:#333}.contact-details{margin:0;font-size:14px;color:#666}.no-customers{text-align:center;padding:40px 20px;color:#666;font-style:italic}.nav-item,.nav-item:hover{text-decoration:none;color:inherit}.appointment-charting{display:flex;flex-direction:column;gap:15px;max-height:400px;overflow-y:auto}.charting-header-small{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.charting-header-small h4{margin:0;color:#333;font-size:16px}.btn-small{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s}.appointment-chart-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:15px}.quick-tooth-selector{grid-column:1 / -1;background:#f8f9fa;border-radius:6px;padding:12px}.quick-tooth-selector h5{margin:0 0 10px;font-size:14px;color:#333}.tooth-selector-grid{display:flex;flex-direction:column;gap:8px;align-items:center}.teeth-row-compact{display:flex;gap:3px;justify-content:center}.tooth-compact{display:flex;flex-direction:column;align-items:center;cursor:pointer;padding:2px;border-radius:3px;transition:background-color .2s}.tooth-compact:hover{background-color:#e3f2fd}.tooth-compact.upper{flex-direction:column}.tooth-compact.lower{flex-direction:column-reverse}.tooth-icon{font-size:12px;margin:1px}.tooth-number-small{font-size:8px;color:#666;font-weight:500}.appointment-treatments{background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:12px}.appointment-treatments h5{margin:0 0 10px;font-size:14px;color:#333}.treatment-list{display:flex;flex-direction:column;gap:8px}.treatment-item{display:grid;grid-template-columns:60px 1fr 80px 60px;gap:8px;padding:8px;background-color:#f8f9fa;border-radius:4px;align-items:center;font-size:12px}.treatment-tooth{font-weight:600;color:#333}.treatment-type{color:#333}.treatment-surface{color:#666;font-size:11px}.treatment-status{text-align:center;padding:2px 6px;border-radius:8px;font-size:10px;font-weight:500}.treatment-status.planned{background-color:#fff3cd;color:#856404}.treatment-status.in-progress{background-color:#cce5ff;color:#06c}.treatment-notes-compact{grid-column:1 / -1;background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:12px}.treatment-notes-compact h5{margin:0 0 10px;font-size:14px;color:#333}.notes-grid{display:grid;grid-template-columns:1fr;gap:10px}.note-field{display:flex;flex-direction:column;gap:4px}.note-field label{font-size:12px;color:#666;font-weight:500}.note-field textarea{border:1px solid #ddd;border-radius:4px;padding:6px;font-size:12px;resize:vertical;min-height:40px}.note-field textarea:focus{outline:none;border-color:#007bff}.treatment-summary{background:#f8f9fa;border-radius:6px;padding:12px}.treatment-summary h5{margin:0 0 10px;font-size:14px;color:#333}.summary-items{display:flex;flex-direction:column;gap:6px}.summary-item{display:flex;justify-content:space-between;align-items:center;font-size:12px}.summary-label{color:#666;font-weight:500}.summary-value{color:#333;font-weight:500}.summary-value.status-scheduled{color:#856404}.summary-value.status-confirmed{color:#155724}.summary-value.status-in_progress{color:#06c}.summary-value.status-completed{color:#6f42c1}@media (max-width: 768px){.appointment-chart-grid{grid-template-columns:1fr}.teeth-row-compact{gap:2px}.tooth-icon{font-size:10px}.tooth-number-small{font-size:7px}.treatment-item{grid-template-columns:1fr;gap:4px;text-align:center}}.clinical-card{display:flex;flex-direction:column;gap:20px;background:#fff;border-radius:8px;overflow:hidden}.clinical-card-header{background:#f8f9fa;padding:15px 20px;border-bottom:1px solid #e0e0e0}.card-controls{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}.card-actions{display:flex;align-items:center;gap:15px}.card-tools{display:flex;align-items:center;gap:10px}.card-nav{display:flex;align-items:center;gap:15px}.btn-icon{background:none;border:none;cursor:pointer;font-size:16px;padding:4px;border-radius:4px;transition:background-color .2s}.btn-icon:hover{background-color:#e9ecef}.questionnaires,.reviews,.treatment-plan,.add-entry,.nav-text{font-size:14px;color:#007bff;cursor:pointer;text-decoration:none}.questionnaires:hover,.reviews:hover,.treatment-plan:hover,.add-entry:hover,.nav-text:hover{text-decoration:underline}.toggle-container{display:flex;align-items:center;gap:8px;cursor:pointer}.toggle-container input[type=checkbox]{width:40px;height:20px;appearance:none;background-color:#ccc;border-radius:10px;position:relative;cursor:pointer;transition:background-color .3s}.toggle-container input[type=checkbox]:checked{background-color:#4caf50}.toggle-container input[type=checkbox]:before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background-color:#fff;top:1px;left:1px;transition:transform .3s}.toggle-container input[type=checkbox]:checked:before{transform:translate(20px)}.toggle-text{font-size:13px;color:#666}.clinical-card-table{display:flex;flex-direction:column}.table-header{display:grid;grid-template-columns:180px 150px 1fr 150px 150px 100px;gap:15px;padding:15px 20px;background:#f8f9fa;border-bottom:2px solid #e0e0e0;font-weight:600;font-size:14px;color:#333}.table-body{display:flex;flex-direction:column}.table-row{display:grid;grid-template-columns:180px 150px 1fr 150px 150px 100px;gap:15px;padding:20px;border-bottom:1px solid #e0e0e0;align-items:start}.table-row:hover{background-color:#f8f9fa}.col-date{display:flex;align-items:flex-start;gap:10px}.date-info{display:flex;flex-direction:column;gap:2px}.day{font-size:13px;color:#666}.date{font-size:13px;color:#007bff;font-weight:500}.time-icon{font-size:14px;color:#666;margin-top:5px}.doctor-info{display:flex;align-items:center;gap:8px}.doctor-name{font-size:13px;color:#007bff;font-weight:500}.edit-btn{background:none;border:none;cursor:pointer;font-size:12px;color:#666;padding:2px}.task-list{display:flex;flex-direction:column;gap:8px;margin-bottom:15px}.task-item{display:flex;align-items:center;gap:8px;padding:6px;background:#f8f9fa;border-radius:4px}.tooth-icon{font-size:14px}.task-text{flex:1;font-size:13px;color:#333}.task-options{background:none;border:none;cursor:pointer;font-size:12px;color:#666}.expanded-details{background:#e8f4f8;border:1px solid #b8e6ff;border-radius:6px;padding:12px;margin-top:10px}.task-detail{margin-bottom:8px}.task-detail:last-child{margin-bottom:0}.detail-label{font-size:12px;color:#666;font-weight:500}.detail-content{font-size:12px;color:#333;margin-top:2px;line-height:1.4}.diagnosis-content,.recommendations-content{min-height:30px}.amount-value{background:#d4edda;color:#155724;padding:4px 8px;border-radius:4px;font-size:13px;font-weight:500;text-align:center}.amount-breakdown{display:flex;flex-direction:column;gap:4px}.amount-item{background:#d4edda;color:#155724;padding:4px 8px;border-radius:4px;font-size:13px;font-weight:500;text-align:center}.clinical-card-footer{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f8f9fa;border-top:1px solid #e0e0e0}.pagination{display:flex;gap:5px}.page-btn{padding:6px 12px;border:1px solid #ddd;background:#fff;cursor:pointer;border-radius:4px;font-size:13px;transition:all .2s}.page-btn:hover{background-color:#f8f9fa}.page-btn.active{background-color:#007bff;color:#fff;border-color:#007bff}.summary-info{display:flex;align-items:center;gap:20px;font-size:13px}.activate-windows{color:#666}.settings-note{color:#666;font-size:12px}.total-amount{font-weight:600;color:#333;font-size:14px}.per-page{color:#666}@media (max-width: 768px){.card-controls{flex-direction:column;gap:10px}.table-header,.table-row{grid-template-columns:1fr;gap:10px}.table-header>div,.table-row>div{padding:5px 0;border-bottom:1px solid #eee}.table-header>div:before{content:attr(class);font-weight:700;display:block;text-transform:capitalize;margin-bottom:5px}.clinical-card-footer{flex-direction:column;gap:15px}.summary-info{flex-direction:column;gap:10px;text-align:center}}.appointment-status-toggle{background:none;border:none;cursor:pointer;padding:0;margin:0;font-size:16px;line-height:1;transition:transform .2s;flex-shrink:0;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:#666;outline:none}.appointment-status-toggle:hover{transform:scale(1.2)}.appointment-status-toggle:focus{outline:none}.appointment-payment{padding:20px}.payment-summary-section{margin-bottom:30px}.payment-summary-section h4{font-size:16px;font-weight:600;margin-bottom:15px;color:#333}.payment-info{background:#f8f9fa;border-radius:8px;padding:15px}.payment-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e9ecef}.payment-row:last-child{border-bottom:none}.payment-row.total{border-top:2px solid #dee2e6;margin-top:8px;padding-top:12px;font-weight:600;font-size:16px}.payment-row.outstanding{color:#dc3545;font-weight:600}.payment-label{color:#666;font-size:14px}.payment-value{color:#333;font-size:14px;font-weight:500}.payment-value.paid{color:#28a745}.payment-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:30px}.btn-payment{padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-payment.btn-primary{background:#4285f4;color:#fff}.btn-payment.btn-primary:hover{background:#357ae8}.btn-payment.btn-secondary{background:#f8f9fa;color:#333;border:1px solid #dadce0}.btn-payment.btn-secondary:hover{background:#e9ecef}.payment-history-section h4{font-size:16px;font-weight:600;margin-bottom:15px;color:#333}.payment-history-empty{text-align:center;padding:30px;color:#999;font-size:14px;background:#f8f9fa;border-radius:8px}.expand-btn{background:#f8f9fa;border:1px solid #dadce0;padding:8px 12px;border-radius:50%;cursor:pointer;font-size:18px;transition:all .2s;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.expand-btn:hover{background:#e9ecef;transform:scale(1.05)}.chart-actions{display:flex;gap:8px}.expanded-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:3000;padding:20px;pointer-events:auto;overflow:visible}.expanded-modal-content{background:#fff;border-radius:12px;width:90%;max-width:1200px;height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;overflow:visible;pointer-events:auto}.expanded-modal-header{padding:20px 30px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center;background:#f8f9fa}.expanded-modal-header h2{margin:0;font-size:24px;color:#333}.close-btn-expanded{background:none;border:none;font-size:28px;cursor:pointer;color:#666;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-btn-expanded:hover{background:#e9ecef;color:#333}.expanded-modal-tabs{display:flex;padding:0 30px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.expanded-tab{padding:15px 24px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:15px;font-weight:500;color:#666;transition:all .2s}.expanded-tab:hover{color:#333;background:#00000005}.expanded-tab.active{color:#4285f4;border-bottom-color:#4285f4;background:#fff}.expanded-modal-body{flex:1;overflow-y:auto;overflow-x:visible;padding:30px;background:#fff;position:relative}.expanded-modal-body .appointment-details,.expanded-modal-body .appointment-charting,.expanded-modal-body .appointment-payment,.expanded-modal-body .appointment-history{max-width:900px;margin:0 auto}.expanded-modal-body .appointment-info-row{padding:15px 0;font-size:16px}.expanded-modal-body .appointment-title-section{font-size:20px;margin:20px 0}.expanded-modal-body .info-icon{font-size:24px}.expanded-modal-body .appointment-charting{max-height:none;overflow-y:visible}.expanded-modal-body input[type=date],.expanded-modal-body input[type=time]{position:relative;z-index:9999;cursor:pointer!important}.expanded-modal-body .form-group{position:relative;z-index:auto}input[type=date],input[type=time]{cursor:pointer!important}.modal-header .header-actions{display:flex;align-items:center;gap:10px}.modal-header .expand-btn{background:#f8f9fa;border:1px solid #dadce0;padding:6px 10px;border-radius:50%;cursor:pointer;font-size:16px;transition:all .2s;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.modal-header .expand-btn:hover{background:#e9ecef;transform:scale(1.05)}.patient-account{padding:20px;background:#f5f5f5}.account-header-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:20px}.account-title{display:flex;align-items:center;gap:10px;margin-bottom:20px}.account-icon{font-size:24px}.account-name{font-size:18px;font-weight:600;color:#333}.btn-set-debtor{margin-left:auto;padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;color:#666}.btn-set-debtor:hover{background:#f5f5f5}.account-summary-boxes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.summary-box{text-align:center;padding:15px}.summary-label{font-size:14px;color:#666;margin-bottom:8px}.summary-amount{font-size:24px;font-weight:700;color:#2e7d32}.account-tabs-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;background:#fff;padding:10px 20px;border-radius:8px}.account-subtabs{display:flex;gap:10px}.account-subtab{padding:8px 16px;background:transparent;border:none;cursor:pointer;font-size:14px;color:#666;border-bottom:2px solid transparent}.account-subtab.active{color:#1976d2;border-bottom-color:#1976d2;font-weight:600}.account-actions{display:flex;gap:10px}.btn-action{padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;color:#666;display:flex;align-items:center;gap:5px}.btn-action:hover{background:#f5f5f5}.account-filters{display:flex;gap:10px;margin-bottom:20px}.filter-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:14px;color:#666;cursor:pointer}.invoices-table-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.invoices-table{width:100%;border-collapse:collapse}.invoices-table thead{background:#f5f5f5}.invoices-table th{padding:12px 16px;text-align:left;font-size:14px;font-weight:600;color:#666;border-bottom:1px solid #e0e0e0}.invoices-table td{padding:16px;font-size:14px;color:#333;border-bottom:1px solid #f0f0f0}.invoices-table tbody tr:hover{background:#f9f9f9}.no-invoices-cell{text-align:center;padding:60px 20px!important}.no-invoices-message h4{font-size:18px;font-weight:600;color:#333;margin-bottom:10px}.no-invoices-message p{font-size:14px;color:#666;line-height:1.5}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.status-draft{background:#e3f2fd;color:#1976d2}.status-badge.status-sent{background:#fff3e0;color:#f57c00}.status-badge.status-paid{background:#e8f5e9;color:#2e7d32}.status-badge.status-overdue{background:#ffebee;color:#c62828}.patient-recalls{padding:20px}.recalls-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.recalls-header-row h3{font-size:24px;font-weight:600;color:#333}.btn-create-recall{padding:10px 20px;background:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500}.btn-create-recall:hover{background:#1565c0}.recall-form-modal{background:#fff;border:1px solid #ddd;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a}.recall-form h4{font-size:18px;font-weight:600;margin-bottom:20px;color:#333}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;margin-bottom:20px}.form-item{display:flex;flex-direction:column}.form-item-full{grid-column:1 / -1}.form-item label{font-size:14px;font-weight:500;color:#555;margin-bottom:5px}.form-input,.form-textarea{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;color:#333}.form-textarea{resize:vertical;font-family:inherit}.form-actions{display:flex;gap:10px;justify-content:flex-end}.btn-primary{padding:10px 20px;background:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500}.btn-secondary{padding:10px 20px;background:#fff;color:#666;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px}.btn-secondary:hover{background:#f5f5f5}.recalls-summary{margin-bottom:20px}.recall-info-banner{display:flex;align-items:center;gap:10px;padding:15px;background:#e3f2fd;border-left:4px solid #1976d2;border-radius:4px;margin-bottom:10px}.info-icon{font-size:20px}.recall-text{font-size:14px;color:#333;line-height:1.5}.recalls-table-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.recalls-table{width:100%;border-collapse:collapse}.recalls-table thead{background:#f5f5f5}.recalls-table th{padding:12px 16px;text-align:left;font-size:14px;font-weight:600;color:#666;border-bottom:1px solid #e0e0e0}.recalls-table td{padding:16px;font-size:14px;color:#333;border-bottom:1px solid #f0f0f0}.recalls-table tbody tr:hover{background:#f9f9f9}.delete-icon-btn{background:transparent;border:none;cursor:pointer;font-size:18px;padding:4px 8px}.delete-icon-btn:hover{opacity:.7}.status-badge-recall{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-badge-recall.pending{background:#fff3e0;color:#f57c00}.status-badge-recall.sent{background:#e3f2fd;color:#1976d2}.status-badge-recall.scheduled{background:#f3e5f5;color:#7b1fa2}.status-badge-recall.completed{background:#e8f5e9;color:#2e7d32}.btn-send-reminder{padding:6px 12px;background:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px}.btn-send-reminder:hover{background:#1565c0}.no-recalls-message{text-align:center;padding:40px 20px;color:#666}.patient-perio{padding:20px;display:flex;justify-content:center;align-items:center;min-height:400px}.perio-empty-state{text-align:center;max-width:500px;padding:40px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.perio-icon{font-size:64px;margin-bottom:20px;filter:grayscale(.3)}.perio-empty-state h3{font-size:22px;font-weight:600;color:#333;margin-bottom:12px}.perio-empty-state p{font-size:14px;color:#666;line-height:1.5;margin-bottom:24px}.btn-create-exam{padding:12px 24px;background:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.btn-create-exam:hover{background:#1565c0}.patient-prsi{padding:20px;background:#f5f5f5}.prsi-subtabs{display:flex;gap:5px;margin-bottom:20px;background:#fff;padding:10px 20px;border-radius:8px 8px 0 0}.prsi-subtab{padding:8px 16px;background:transparent;border:none;cursor:pointer;font-size:14px;color:#666;border-radius:4px;transition:all .2s}.prsi-subtab.active{background:#e3f2fd;color:#1976d2;font-weight:500}.prsi-subtab:hover{background:#f5f5f5}.prsi-content{background:#fff;border-radius:0 0 8px 8px;padding:0}.prsi-claims-table-container{overflow-x:auto}.prsi-claims-table{width:100%;border-collapse:collapse;min-width:1200px}.prsi-claims-table thead{background:#f9f9f9;border-bottom:2px solid #e0e0e0}.prsi-claims-table th{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:#555;white-space:nowrap}.prsi-claims-table td{padding:16px;font-size:14px;color:#333;border-bottom:1px solid #f0f0f0}.prsi-empty-cell{text-align:center;padding:80px 20px!important;background:#fff}.prsi-empty-message{font-size:16px;color:#666;font-weight:400}.patient-tasks{padding:20px;background:#fff}.tasks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.tasks-header h3{font-size:20px;font-weight:600;color:#333;margin:0}.btn-add-task{padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;color:#333;transition:all .2s}.btn-add-task:hover{background:#f5f5f5;border-color:#ccc}.tasks-content{min-height:300px;display:flex;align-items:center;justify-content:center}.tasks-empty-message{font-size:16px;color:#666;text-align:center}.patient-audit{padding:20px;background:#f5f5f5}.audit-header{margin-bottom:15px}.audit-header h3{font-size:22px;font-weight:600;color:#333;margin:0}.audit-subtabs{display:flex;gap:0;margin-bottom:20px;background:#fff;border-bottom:1px solid #e0e0e0}.audit-subtab{padding:12px 20px;background:transparent;border:none;cursor:pointer;font-size:14px;color:#666;border-bottom:2px solid transparent;transition:all .2s}.audit-subtab.active{color:#333;border-bottom-color:#333;font-weight:500}.audit-subtab:not(.active){color:#999}.audit-filters{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:15px 20px;background:#fff;border-radius:4px;flex-wrap:wrap}.audit-filter-select{padding:8px 30px 8px 12px;border:1px solid #ddd;border-radius:4px;background:#fff url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12"><path fill="%23666" d="M6 9L1 4h10z"/></svg>') no-repeat right 10px center;background-size:12px;font-size:14px;color:#333;cursor:pointer;appearance:none;min-width:140px}.audit-date-filters{display:flex;align-items:center;gap:8px}.audit-date-filters label{font-size:14px;color:#555;font-weight:400}.audit-date-input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;color:#333;background:#fff}.btn-export-selection{padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;color:#333;margin-left:auto;transition:all .2s}.btn-export-selection:hover{background:#f5f5f5;border-color:#ccc}.audit-table-container{background:#fff;border-radius:4px;overflow-x:auto}.audit-table{width:100%;border-collapse:collapse;min-width:1000px}.audit-table thead{background:#fafafa;border-bottom:1px solid #e0e0e0}.audit-table th{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:#666;white-space:nowrap}.audit-table td{padding:14px 16px;font-size:13px;color:#333;border-bottom:1px solid #f0f0f0}.audit-table tbody tr:hover{background:#f9f9f9}.audit-user{display:flex;align-items:center;gap:8px}.audit-user-avatar{font-size:18px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#e91e63;border-radius:4px}.audit-badge{display:inline-block;padding:4px 10px;border-radius:3px;font-size:12px;font-weight:500;margin-right:10px}.audit-badge.audit-updated{background:#4fc3f7;color:#fff}.audit-badge.audit-created{background:#66bb6a;color:#fff}.audit-view-link{color:#1976d2;text-decoration:none;font-size:13px}.audit-view-link:hover{text-decoration:underline}.daily-summary-report{padding:20px;background:#fff;border-radius:8px}.date-selector{display:flex;align-items:center;gap:10px}.date-selector label{font-weight:500;color:#555}.date-selector input[type=date]{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.date-selector .btn-success{background:#4caf50;color:#fff;padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.date-selector .btn-success:hover:not(:disabled){background:#43a047}.date-selector .btn-success:disabled{background:#c8e6c9;cursor:not-allowed;opacity:.6}.date-selector .btn-secondary{background:#757575;color:#fff;padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px}.report-date-title{text-align:center;font-size:18px;font-weight:600;color:#333;margin-bottom:20px;padding:12px;background:#f5f5f5;border-radius:6px}.summary-table-container{overflow-x:auto;margin-bottom:30px}.daily-summary-table{width:100%;border-collapse:collapse;box-shadow:0 2px 4px #0000001a}.daily-summary-table th{background:#1976d2;color:#fff;padding:12px;text-align:left;font-weight:600;text-transform:uppercase;font-size:13px}.daily-summary-table td{padding:12px;border-bottom:1px solid #e0e0e0}.daily-summary-table tbody tr:hover{background:#f9f9f9}.doctor-name{font-weight:600;color:#1976d2}.totals-row{background:#f5f5f5;font-weight:700}.totals-row td{border-top:2px solid #1976d2;border-bottom:2px solid #1976d2}.notes{font-size:12px}.prsi-refund-badge{display:inline-block;padding:3px 8px;background:#ff9800;color:#fff;border-radius:3px;font-size:11px;font-weight:600}.has-notes-badge{margin-left:5px;font-size:14px}.has-notes-badge.clickable{cursor:pointer;padding:4px 8px;border-radius:4px;background:#e3f2fd;transition:all .2s ease;-webkit-user-select:none;user-select:none}.has-notes-badge.clickable:hover{background:#1976d2;color:#fff;transform:scale(1.05)}.notes-expanded-row{background:#f5f5f5}.notes-expanded-row td{padding:15px 20px!important}.notes-details{background:#fff;padding:15px;border-radius:6px;border-left:4px solid #1976d2}.notes-details strong{color:#1976d2;margin-bottom:10px;display:block}.notes-details ul{margin:10px 0 0;padding-left:20px}.notes-details li{margin-bottom:8px;color:#333;line-height:1.6}.no-data{text-align:center;color:#999;font-style:italic;padding:40px!important}.doctor-payment-details{margin-top:30px;padding:20px;background:#fafafa;border-radius:8px;border-left:4px solid #1976d2}.doctor-payment-details h3{margin-top:0;color:#1976d2;font-size:16px}.payment-details-table{width:100%;border-collapse:collapse;background:#fff;margin-top:10px}.payment-details-table th{background:#f5f5f5;padding:10px;text-align:left;font-weight:600;border-bottom:2px solid #ddd;font-size:13px}.payment-details-table td{padding:10px;border-bottom:1px solid #eee;font-size:13px}.method-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600}.method-cash{background:#4caf50;color:#fff}.method-card{background:#2196f3;color:#fff}.method-prsi{background:#ff9800;color:#fff}.method-medical_card{background:#9c27b0;color:#fff}.method-other{background:#757575;color:#fff}.prsi-claimed{font-size:13px}.refund-tag{color:#f44336;font-weight:600}.payment-notes{color:#666;font-size:12px}.daily-summary-loading{text-align:center;padding:40px;color:#999}@media print{.report-header{border-bottom:2px solid #000}.date-selector{display:none}.daily-summary-table th{background:#ddd!important;color:#000!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.amount{font-weight:600}}.monthly-doctor-report{padding:20px;background:#fff;border-radius:8px}.report-period-title{text-align:center;font-size:20px;font-weight:700;color:#1976d2;margin-bottom:30px;padding:15px;background:#e3f2fd;border-radius:8px}.doctor-report-section{margin-bottom:40px;padding:20px;background:#fafafa;border-radius:8px;border-left:5px solid #1976d2}.doctor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #ddd}.doctor-header h3{margin:0;color:#1976d2;font-size:22px}.doctor-totals{display:flex;align-items:center;gap:10px;background:#1976d2;color:#fff;padding:10px 20px;border-radius:6px}.total-label{font-weight:500}.total-value{font-size:24px;font-weight:700}.monthly-table-container{overflow-x:auto;margin-bottom:20px}.monthly-report-table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 2px 4px #0000001a}.monthly-report-table th{background:#424242;color:#fff;padding:10px;text-align:left;font-weight:600;font-size:12px;text-transform:uppercase}.monthly-report-table td{padding:10px;border-bottom:1px solid #e0e0e0;font-size:13px}.monthly-report-table tbody tr:hover{background:#f9f9f9}.date-cell{font-weight:600;color:#333;white-space:nowrap}.prsi-amount{background:#fff3e0}.mc-amount{background:#e3f2fd}.total-amount{background:#e8f5e9;font-weight:700}.totals-row{background:#f5f5f5}.totals-row td{border-top:3px solid #1976d2;border-bottom:3px solid #1976d2;padding:12px 10px}.no-data{text-align:center;color:#999;font-style:italic;padding:30px!important}.method-breakdown{margin-top:20px;padding:20px;background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a}.method-breakdown h4{margin-top:0;margin-bottom:15px;color:#333;font-size:16px}.breakdown-bars{display:flex;flex-direction:column;gap:12px}.breakdown-item{display:grid;grid-template-columns:120px 1fr 120px 80px;align-items:center;gap:10px}.method-label{font-weight:600;color:#555;font-size:14px}.bar-container{height:30px;background:#e0e0e0;border-radius:4px;overflow:hidden}.bar{height:100%;transition:width .3s ease;border-radius:4px 0 0 4px}.cash-bar{background:linear-gradient(90deg,#4caf50,#66bb6a)}.card-bar{background:linear-gradient(90deg,#2196f3,#42a5f5)}.prsi-bar{background:linear-gradient(90deg,#ff9800,#ffa726)}.mc-bar{background:linear-gradient(90deg,#9c27b0,#ab47bc)}.other-bar{background:linear-gradient(90deg,#757575,#9e9e9e)}.method-value{font-weight:600;color:#333;font-size:14px;text-align:right}.method-percent{color:#666;font-size:13px;text-align:right}.no-data-message{text-align:center;padding:60px 20px;color:#999;font-size:16px}.monthly-report-loading{text-align:center;padding:40px;color:#999}@media (max-width: 768px){.report-header{flex-direction:column;gap:15px;align-items:flex-start}.period-selector{flex-direction:column;align-items:flex-start;width:100%}.doctor-header{flex-direction:column;gap:10px;align-items:flex-start}.breakdown-item{grid-template-columns:1fr;gap:5px}.method-value,.method-percent{text-align:left}}@media print{.report-header{border-bottom:2px solid #000}.period-selector{display:none}.monthly-report-table th{background:#ddd!important;color:#000!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.doctor-report-section{page-break-inside:avoid;border-left-color:#000}.method-breakdown{display:none}}.monthly-overview-report{padding:20px;background:#fff;border-radius:8px}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e0e0e0}.report-header h2{margin:0;color:#1976d2}.period-selector{display:flex;align-items:center;gap:15px}.selector-group{display:flex;align-items:center;gap:8px}.selector-group label{font-weight:500;color:#555}.selector-group select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;min-width:120px}.period-selector .btn-success{background:#4caf50;color:#fff;padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.period-selector .btn-success:hover:not(:disabled){background:#43a047}.period-selector .btn-success:disabled{background:#c8e6c9;cursor:not-allowed;opacity:.6}.period-selector .btn-secondary{background:#757575;color:#fff;padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px}.report-period-title{text-align:center;font-size:20px;font-weight:700;color:#1976d2;margin-bottom:20px;padding:15px;background:#e3f2fd;border-radius:8px}.overview-table-container{overflow-x:auto;margin-bottom:20px}.overview-table{width:100%;border-collapse:collapse;font-size:12px;background:#fff;box-shadow:0 2px 4px #0000001a}.overview-table th{padding:8px 6px;text-align:center;font-weight:600;border:1px solid #ddd;white-space:nowrap}.date-header,.total-header{background:#1976d2;color:#fff;font-size:13px}.doctor-header{background:#424242;color:#fff;font-size:11px;text-transform:uppercase}.method-header{background:#616161;color:#fff;font-size:10px;font-weight:600;padding:6px 4px}.overview-table td{padding:6px 4px;border:1px solid #e0e0e0;font-size:11px}.date-cell{font-weight:600;color:#333;white-space:nowrap;background:#f9f9f9;text-align:left;padding-left:8px;position:sticky;left:0;z-index:1}.amount{text-align:right;font-family:Courier New,monospace;font-weight:500}.cash-col{background:#e8f5e9}.card-col{background:#e3f2fd}.prsi-col{background:#fff3e0}.mc-col{background:#f3e5f5}.total-col{background:#fff9c4;font-weight:700}.empty-row{opacity:.5}.empty-row .amount{color:#999}.totals-row{background:#fff59d}.totals-row td{border-top:3px solid #1976d2;border-bottom:3px solid #1976d2;padding:10px 4px;font-weight:700}.grand-total{background:#ffd740!important;font-size:13px}.monthly-overview-loading{text-align:center;padding:40px;color:#999}.error-message{padding:12px;background:#ffebee;color:#c62828;border-radius:4px;margin-bottom:15px}@media (max-width: 1200px){.overview-table{font-size:10px}.overview-table th,.overview-table td{padding:4px 2px}.doctor-header{font-size:9px}.method-header{font-size:8px}}@media print{.report-header{border-bottom:2px solid #000}.period-selector{display:none}.overview-table th{background:#ddd!important;color:#000!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.totals-row{background:#ffd740!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}}.payment-system{min-height:100vh;background:#f5f5f5;padding:20px;max-width:1400px;margin:0 auto;box-sizing:border-box}.payment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.payment-header-left{display:flex;align-items:center;gap:20px}.payment-header h1{margin:0;color:#1976d2;font-size:28px}.back-btn{background:#f1f3f4;border:1px solid #dadce0;color:#5f6368;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:6px;transition:all .2s ease}.back-btn:hover{background:#e8eaed}.payment-header-actions{display:flex;gap:12px}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.btn-primary{background:#1976d2;color:#fff}.btn-primary:hover{background:#1565c0}.btn-secondary{background:#f1f3f4;color:#5f6368;border:1px solid #dadce0}.btn-secondary:hover{background:#e8eaed}.payment-tabs{display:flex;gap:4px;margin-bottom:20px;background:#fff;border-radius:8px;padding:4px;box-shadow:0 2px 4px #0000001a;width:100%;box-sizing:border-box}.tab{flex:1;padding:12px 20px;border:none;background:transparent;color:#5f6368;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s ease}.tab.active{background:#1976d2;color:#fff}.tab:hover:not(.active){background:#f1f3f4}.payment-content{width:100%;box-sizing:border-box}.payment-dashboard{display:flex;flex-direction:column;gap:20px;width:100%;max-width:100%}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;width:100%}.stat-card{background:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:16px}.stat-card.warning{border-left:4px solid #f44336}.stat-icon{font-size:32px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border-radius:50%}.stat-value{font-size:28px;font-weight:700;color:#1976d2;margin-bottom:4px}.stat-label{color:#666;font-size:14px}.dashboard-charts{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;width:100%}@media (max-width: 1024px){.dashboard-charts{grid-template-columns:1fr}}.chart-card{background:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 4px #0000001a;width:100%;min-width:0}.chart-card h3{margin:0 0 20px;color:#333;font-size:18px}.recent-list{display:flex;flex-direction:column;gap:12px}.recent-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#f9f9f9;border-radius:6px}.recent-info{flex:1}.recent-title{font-weight:500;color:#333}.recent-subtitle{font-size:13px;color:#666}.recent-amount{font-weight:700;color:#1976d2;margin-right:12px}.status-badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;text-transform:uppercase;color:#fff}.status-badge.draft{background:#9e9e9e}.status-badge.sent{background:#ff9800}.status-badge.paid{background:#4caf50}.status-badge.partially_paid{background:#2196f3}.status-badge.overdue{background:#f44336}.status-badge.cancelled{background:#795548}.status-badge.pending{background:#ff9800}.status-badge.completed{background:#4caf50}.status-badge.failed{background:#f44336}.invoices-list,.payments-list{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:24px}.invoices-header,.payments-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.invoices-header h2,.payments-header h2{margin:0;color:#333}.invoices-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px;padding:16px;background:#f9f9f9;border-radius:6px}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-group label{font-size:13px;font-weight:500;color:#666}.filter-group select,.filter-group input{padding:8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.invoices-table-container,.payments-table-container{overflow-x:auto}.invoices-table,.payments-table{width:100%;border-collapse:collapse;margin-top:16px}.invoices-table th,.payments-table th{background:#f5f5f5;padding:12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.invoices-table td,.payments-table td{padding:12px;border-bottom:1px solid #e0e0e0;vertical-align:middle}.invoices-table tr:hover,.payments-table tr:hover{background:#f9f9f9}.invoice-number,.patient-name{font-weight:500;color:#1976d2}.amount,.amount-paid,.amount-outstanding{font-weight:500;text-align:right}.overdue-date{color:#f44336;font-weight:500}.actions{text-align:center}.action-buttons{display:flex;gap:8px;justify-content:center}.btn-icon{background:none;border:none;padding:6px;border-radius:4px;cursor:pointer;font-size:16px;transition:background .2s ease}.btn-icon:hover{background:#f1f3f4}.payment-btn:hover{background:#e8f5e8}.payment-method{display:flex;align-items:center;gap:8px}.method-icon{font-size:18px}.invoice-modal,.payment-modal{max-width:700px;width:90vw;max-height:90vh;overflow-y:auto}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-row.three-col{grid-template-columns:1fr 1fr 1fr}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:14px;font-weight:500;color:#333}.form-group input,.form-group select,.form-group textarea{padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d233}.form-hint{font-size:12px;color:#666;margin-top:2px}.invoice-calculation{background:#f9f9f9;padding:16px;border-radius:6px;margin:16px 0}.calc-row{display:flex;justify-content:space-between;padding:4px 0}.calc-row.total{border-top:1px solid #ddd;margin-top:8px;padding-top:8px;font-size:16px}.invoice-info{margin:16px 0}.info-card{background:#f0f8ff;border:1px solid #1976d2;border-radius:6px;padding:16px}.info-card h4{margin:0 0 12px;color:#1976d2}.info-row{display:flex;justify-content:space-between;padding:4px 0}.info-row.outstanding{border-top:1px solid #1976d2;margin-top:8px;padding-top:8px}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-icon{font-size:48px;margin-bottom:16px}.empty-state h3{margin:0 0 8px;color:#333}.payment-reports{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:24px}.reports-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.report-card{background:linear-gradient(135deg,#1976d2,#2196f3);color:#fff;padding:24px;border-radius:8px}.report-card h3{margin:0 0 16px;font-size:18px}.revenue-amount{font-size:32px;font-weight:700;margin-bottom:8px}.revenue-change{font-size:14px;opacity:.9}.method-stats{display:flex;flex-direction:column;gap:8px}.method-item{display:flex;justify-content:space-between;align-items:center}.loading-message{text-align:center;padding:60px 20px;font-size:18px;color:#666}.error-message{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:4px;margin-bottom:16px;border-left:4px solid #f44336}@media (max-width: 768px){.payment-header{flex-direction:column;gap:16px;align-items:stretch}.payment-header-left{flex-direction:column;gap:12px}.dashboard-charts,.form-row,.form-row.three-col,.invoices-filters,.reports-grid{grid-template-columns:1fr}}.financial-report-container{padding:24px;max-width:1400px;margin:0 auto;background-color:#f5f7fa;min-height:100vh}.financial-report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;background-color:#fff;padding:20px 24px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.financial-report-header h1{font-size:28px;color:#1a202c;margin:0}.view-analysis-btn{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px #667eea4d}.view-analysis-btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #667eea66}.view-analysis-btn:active{transform:translateY(0)}.financial-report-filters{display:flex;gap:16px}.report-period{background-color:#fff;padding:12px 24px;border-radius:8px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a;font-size:14px;color:#4a5568}.grand-totals-section{background-color:#fff;padding:24px;border-radius:8px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.grand-totals-section h2{font-size:20px;color:#1a202c;margin:0 0 20px}.grand-totals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.total-appointments{text-align:center;padding:16px;background-color:#f7fafc;border-radius:6px;font-size:16px;color:#2d3748}.doctor-reports-section{margin-top:24px}.doctor-reports-section h2{font-size:20px;color:#1a202c;margin-bottom:16px}.doctor-report-card{background-color:#fff;border-radius:8px;padding:24px;margin-bottom:16px;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s}.doctor-report-card:hover{box-shadow:0 4px 6px #0000001a}.doctor-report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #e2e8f0}.doctor-report-header h3{font-size:18px;color:#2d3748;margin:0}.appointment-count{background-color:#edf2f7;color:#4a5568;padding:6px 12px;border-radius:20px;font-size:14px;font-weight:500}.doctor-totals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}.doctor-total-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#f7fafc;border-radius:6px;border-left:3px solid #cbd5e0}.doctor-total-item .label{color:#4a5568;font-size:14px}.doctor-total-item .value{font-weight:600;color:#2d3748;font-size:16px}.financial-report-loading,.financial-report-error{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:18px;color:#4a5568}.financial-report-error{color:#e53e3e}@media (max-width: 768px){.financial-report-header{flex-direction:column;align-items:flex-start;gap:16px}.financial-report-filters{width:100%;flex-direction:column}.filter-group{width:100%}.filter-group select{flex:1}.grand-totals-grid,.doctor-totals-grid{grid-template-columns:1fr}.doctor-report-header{flex-direction:column;align-items:flex-start;gap:8px}.appointments-table{font-size:12px}.appointments-table th,.appointments-table td{padding:8px 6px}}.data-analysis-container{padding:24px;max-width:1600px;margin:0 auto;background-color:#f5f7fa;min-height:100vh}.data-analysis-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;background-color:#fff;padding:20px 24px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.header-left-section{display:flex;align-items:center;gap:16px}.data-analysis-header h1{font-size:28px;color:#1a202c;margin:0}.view-report-btn{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px #667eea4d}.view-report-btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #667eea66}.view-report-btn:active{transform:translateY(0)}.data-analysis-filters{display:flex;gap:16px}.filter-group{display:flex;align-items:center;gap:8px}.filter-group label{font-weight:500;color:#4a5568}.filter-group select{padding:8px 12px;border:1px solid #cbd5e0;border-radius:6px;font-size:14px;background-color:#fff;cursor:pointer;transition:border-color .2s}.filter-group select:hover{border-color:#4299e1}.filter-group select:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}.month-summary-section{background:#fff;border-radius:8px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.month-summary-section h2{font-size:20px;color:#1a202c;margin:0 0 20px}.month-totals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.total-card{background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;border-radius:8px;color:#fff;transition:transform .2s}.total-card:hover{transform:translateY(-2px)}.total-card.highlight{background:linear-gradient(135deg,#f093fb,#f5576c);font-size:1.1em}.total-label{font-size:14px;opacity:.9;margin-bottom:8px}.total-amount{font-size:24px;font-weight:700}.total-amount.negative{color:#fed7d7}.day-selector-section{background:#fff;border-radius:8px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.day-selector-section h2{font-size:20px;color:#1a202c;margin:0 0 20px}.day-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.day-button{background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:16px;cursor:pointer;transition:all .2s;min-height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center}.day-button:hover{border-color:#4299e1;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.day-button.selected{border-color:#4299e1;background:linear-gradient(135deg,#e6f7ff,#bae7ff)}.day-button.no-data{opacity:.5;cursor:not-allowed}.day-button.no-data:hover{border-color:#e2e8f0;transform:none;box-shadow:none}.day-number{font-size:28px;font-weight:700;color:#2d3748;margin-bottom:8px}.day-info{display:flex;flex-direction:column;gap:4px;font-size:12px;text-align:center}.day-count{color:#4a5568;font-weight:500}.day-amount{color:#48bb78;font-weight:600}.day-details-section{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a}.day-details-section h2{font-size:22px;color:#1a202c;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid #e2e8f0}.day-total{color:#48bb78;font-weight:700}.daily-totals-card{background:linear-gradient(135deg,#f5f7fa,#e8ecf1);border-radius:8px;padding:20px;margin-bottom:20px}.daily-totals-card h3{font-size:16px;color:#2d3748;margin:0 0 16px}.daily-totals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}.daily-total-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#fff;border-radius:6px;border-left:3px solid #cbd5e0}.daily-total-item.highlight{background:linear-gradient(135deg,#ffecd2,#fcb69f);border-left-color:#f5576c;font-weight:600}.daily-total-item .label{color:#4a5568;font-size:14px}.daily-total-item .value{font-weight:600;color:#2d3748;font-size:16px}.daily-total-item .value.negative{color:#e53e3e}.total-appointments-info{text-align:center;padding:12px;background-color:#fff;border-radius:6px;font-size:14px;color:#2d3748}.doctor-daily-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:20px;margin-bottom:16px}.doctor-daily-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #e2e8f0}.doctor-daily-header h3{font-size:18px;color:#2d3748;margin:0}.doctor-appointment-count{background-color:#edf2f7;color:#4a5568;padding:6px 12px;border-radius:20px;font-size:14px;font-weight:500}.doctor-daily-totals{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px}.doctor-total-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background-color:#f7fafc;border-radius:6px;border-left:3px solid #cbd5e0}.doctor-total-item.highlight{background:linear-gradient(135deg,#ffecd2,#fcb69f);border-left-color:#f5576c;font-weight:600}.doctor-total-item .label{color:#4a5568;font-size:13px}.doctor-total-item .value{font-weight:600;color:#2d3748;font-size:15px}.doctor-total-item .value.negative{color:#e53e3e}.appointments-details{margin-top:16px;border-top:1px solid #e2e8f0;padding-top:16px}.appointments-details summary{cursor:pointer;font-weight:500;color:#4299e1;padding:8px 0;-webkit-user-select:none;user-select:none;list-style:none}.appointments-details summary::-webkit-details-marker{display:none}.appointments-details summary:before{content:"▶";display:inline-block;margin-right:8px;transition:transform .2s}.appointments-details[open] summary:before{transform:rotate(90deg)}.appointments-details summary:hover{color:#2c5282}.appointments-table-container{margin-top:16px;overflow-x:auto;border-radius:6px;border:1px solid #e2e8f0}.appointments-table{width:100%;border-collapse:collapse;font-size:14px}.appointments-table thead{background-color:#edf2f7}.appointments-table th{padding:12px;text-align:left;font-weight:600;color:#2d3748;border-bottom:2px solid #cbd5e0}.appointments-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .2s}.appointments-table tbody tr:hover{background-color:#f7fafc}.appointments-table td{padding:12px;color:#4a5568}.appointments-table .total-cell{font-weight:600;color:#2d3748}.appointments-table .negative{color:#e53e3e}.prsi-claimed{color:#48bb78;font-weight:700;margin-left:4px}.data-analysis-loading,.data-analysis-error{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:18px;color:#4a5568}.data-analysis-error{color:#e53e3e}.no-data{text-align:center;padding:40px;color:#718096;font-size:16px;background-color:#f7fafc;border-radius:8px}@media (max-width: 768px){.data-analysis-header{flex-direction:column;align-items:flex-start;gap:16px}.data-analysis-filters{width:100%;flex-direction:column}.filter-group{width:100%}.filter-group select{flex:1}.month-totals-grid,.daily-totals-grid,.doctor-daily-totals{grid-template-columns:1fr}.day-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.day-button{min-height:80px;padding:12px}.day-number{font-size:24px}.appointments-table{font-size:12px}.appointments-table th,.appointments-table td{padding:8px 6px}}.appointment-list-container{flex:1;padding:24px;background-color:#f5f5f5;overflow-y:auto;height:calc(100vh - 60px)}.appointment-list-header{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.appointment-list-title{display:flex;align-items:baseline;gap:12px}.appointment-list-title h1{margin:0;font-size:28px;font-weight:600;color:#333}.appointment-count{font-size:14px;color:#666;font-weight:400}.appointment-list-controls{display:flex;gap:12px;align-items:center}.search-box{position:relative}.search-input{padding:10px 16px;border:1px solid #ddd;border-radius:8px;font-size:14px;width:300px;transition:all .2s ease}.search-input:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.status-filter{padding:10px 16px;border:1px solid #ddd;border-radius:8px;font-size:14px;background-color:#fff;cursor:pointer;transition:all .2s ease}.status-filter:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.appointment-table-wrapper{background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.appointment-table{width:100%;border-collapse:collapse}.appointment-table thead{background-color:#f8f9fa;border-bottom:2px solid #e0e0e0}.appointment-table th{padding:16px;text-align:left;font-weight:600;font-size:13px;color:#666;text-transform:uppercase;letter-spacing:.5px}.appointment-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.appointment-table th.sortable:hover{background-color:#eee}.appointment-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.appointment-table tbody tr.appointment-row{cursor:pointer}.appointment-table tbody tr.appointment-row:hover{background-color:#f8f9fa}.appointment-table td{padding:16px;font-size:14px;color:#333}.date-cell .date-info{display:flex;flex-direction:column;gap:4px}.date-cell .date{font-weight:600;color:#333}.date-cell .time{font-size:13px;color:#666}.patient-cell .patient-info{display:flex;flex-direction:column;gap:4px}.patient-cell .patient-name{font-weight:500;color:#333}.patient-cell .patient-contact{font-size:13px;color:#666}.doctor-cell .doctor-badge{display:inline-block;padding:6px 12px;border-radius:6px;color:#fff;font-size:13px;font-weight:500}.service-cell{color:#555}.status-badge{display:inline-block;padding:6px 12px;border-radius:6px;color:#fff;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.duration-cell{color:#666;font-weight:500}.actions-cell{display:flex;gap:8px;justify-content:flex-start}.action-btn{padding:6px 10px;border:none;background-color:transparent;cursor:pointer;font-size:16px;border-radius:6px;transition:all .2s ease}.action-btn:hover{background-color:#f0f0f0;transform:scale(1.1)}.action-btn.edit-btn:hover{background-color:#e3f2fd}.action-btn.delete-btn:hover{background-color:#ffebee}.no-appointments{text-align:center;padding:48px 24px;color:#999;font-size:16px}.financial-summary{display:flex;gap:12px;flex-wrap:wrap;padding:16px;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.summary-card{flex:1;min-width:140px;padding:16px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:10px;display:flex;flex-direction:column;gap:8px;box-shadow:0 2px 4px #0000000d;transition:transform .2s ease,box-shadow .2s ease}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.summary-card.total{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.summary-card.total .summary-label,.summary-card.total .summary-value{color:#fff}.summary-label{font-size:12px;font-weight:500;color:#666;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:20px;font-weight:700;color:#333}.payment-details-cell .payment-breakdown{display:flex;flex-direction:column;gap:4px;max-width:200px}.payment-item{font-size:12px;color:#555;padding:2px 0}.payment-item.lab-fee{color:#f44336;font-weight:500}.no-payment{font-size:12px;color:#999;font-style:italic}.total-income-cell{font-weight:600;color:#333}.total-amount{font-size:16px;color:#4caf50;font-weight:700}@media (max-width: 1024px){.appointment-list-controls{width:100%;flex-direction:column}.search-input,.status-filter{width:100%}.financial-summary{flex-direction:column}.summary-card{min-width:100%}}@media (max-width: 768px){.appointment-list-container{padding:16px}.appointment-table-wrapper{overflow-x:auto}.appointment-table{min-width:1200px}.appointment-list-title h1{font-size:24px}.financial-summary,.summary-card{padding:12px}.summary-value{font-size:18px}}.clinic-scheduler{min-height:100vh;background-color:#f8f9fa;padding:20px}.clinic-scheduler-loading,.clinic-scheduler-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;font-size:18px;color:#666}.clinic-scheduler-header{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a}.clinic-tabs{display:flex;gap:12px;flex-wrap:wrap}.clinic-tab{flex:1;min-width:250px;display:flex;align-items:center;gap:12px;padding:16px 20px;background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;transition:all .3s}.clinic-tab:hover{background:#e8f0fe;border-color:#1976d2;transform:translateY(-2px);box-shadow:0 4px 12px #1976d233}.clinic-tab.active{background:#1976d2;border-color:#1976d2;color:#fff}.clinic-tab-icon{font-size:32px}.clinic-tab-info{flex:1;display:flex;flex-direction:column;gap:4px}.clinic-tab-name{font-weight:600;font-size:16px}.clinic-tab-city{font-size:13px;opacity:.8}.clinic-tab.active .clinic-tab-city{opacity:.9}.clinic-tab-count{font-size:12px;padding:4px 8px;background:#fff;border-radius:4px;font-weight:500}.clinic-tab.active .clinic-tab-count{background:#fff3;color:#fff}.clinic-info-bar{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000001a}.clinic-info-left h2{margin:0 0 8px;color:#333;font-size:24px}.clinic-info-left p{margin:4px 0;color:#666;font-size:14px}.clinic-info-right{text-align:right}.clinic-stats{font-size:16px;color:#666}.clinic-stats strong{color:#1976d2;font-size:20px}.clinic-calendar-controls{display:flex;align-items:center;justify-content:center;gap:20px;background:#fff;padding:16px;border-radius:12px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a}.current-week{margin:0;font-size:18px;font-weight:600;color:#333;min-width:250px;text-align:center}.nav-btn{padding:10px 16px;background:#f8f9fa;border:1px solid #dadce0;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;color:#5f6368;transition:all .2s}.today-btn{padding:10px 20px;background:#1976d2;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;color:#fff;transition:all .2s}.clinic-schedule-grid{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.schedule-header{display:grid;grid-template-columns:200px repeat(7,1fr);background:#f8f9fa;border-bottom:2px solid #e9ecef}.doctor-column-header{padding:16px;font-weight:600;color:#333;border-right:1px solid #e9ecef}.day-column-header{padding:12px 16px;text-align:center;border-right:1px solid #e9ecef}.day-column-header:last-child{border-right:none}.day-name{font-weight:600;color:#333;font-size:14px}.day-date{font-size:13px;color:#666;margin-top:4px}.schedule-body{display:flex;flex-direction:column}.no-doctors{padding:40px;text-align:center;color:#999}.doctor-row{display:grid;grid-template-columns:200px repeat(7,1fr);border-bottom:1px solid #e9ecef}.doctor-row:last-child{border-bottom:none}.doctor-row:hover{background:#f8f9fa}.doctor-cell{padding:16px;display:flex;align-items:center;gap:12px;border-right:1px solid #e9ecef}.doctor-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:20px;color:#fff;flex-shrink:0}.doctor-avatar.dr-grace{background:#4285f4}.doctor-avatar.dr-sani{background:#9c27b0}.doctor-avatar.dr-maria{background:#0f9d58}.doctor-avatar.dr-vicky{background:#ff9800}.doctor-avatar.dr-harry{background:#e91e63}.doctor-avatar.dr-paul{background:#00bcd4}.doctor-avatar.dr-denis{background:#8bc34a}.doctor-avatar.dr-paula{background:#673ab7}.doctor-info{flex:1;display:flex;flex-direction:column;gap:4px}.doctor-name{font-weight:600;color:#333;font-size:14px}.doctor-specialty{font-size:12px;color:#666}.day-cell{padding:12px;border-right:1px solid #e9ecef;min-height:80px}.day-cell:last-child{border-right:none}.appointments-list{display:flex;flex-direction:column;gap:6px}.appointment-item{padding:6px 10px;border-radius:6px;font-size:12px;display:flex;flex-direction:column;gap:2px;cursor:pointer;transition:all .2s;border-left:3px solid}.appointment-item.dr-grace{background:#e8f0fe;border-color:#4285f4;color:#1967d2}.appointment-item.dr-sani{background:#f3e5f5;border-color:#9c27b0;color:#7b1fa2}.appointment-item.dr-maria{background:#e8f5e9;border-color:#0f9d58;color:#0d7d48}.appointment-item.dr-vicky{background:#fff3e0;border-color:#ff9800;color:#e65100}.appointment-item.dr-harry{background:#fce4ec;border-color:#e91e63;color:#c2185b}.appointment-item.dr-paul{background:#e0f7fa;border-color:#00bcd4;color:#00838f}.appointment-item.dr-denis{background:#f1f8e9;border-color:#8bc34a;color:#689f38}.appointment-item.dr-paula{background:#ede7f6;border-color:#673ab7;color:#512da8}.appointment-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.apt-time{font-weight:600;font-size:11px}.apt-patient{font-size:11px;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.no-appointments{color:#ccc;text-align:center;font-size:24px;padding:20px 0}.schedule-legend{background:#fff;border-radius:12px;padding:20px;margin-top:20px;box-shadow:0 2px 8px #0000001a}.schedule-legend h4{margin:0 0 16px;color:#333;font-size:16px}.legend-items{display:flex;flex-wrap:wrap;gap:16px}.legend-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#666}.legend-color{width:20px;height:20px;border-radius:4px}.legend-color.dr-grace{background:#4285f4}.legend-color.dr-sani{background:#9c27b0}.legend-color.dr-maria{background:#0f9d58}.legend-color.dr-vicky{background:#ff9800}.legend-color.dr-harry{background:#e91e63}.legend-color.dr-paul{background:#00bcd4}.legend-color.dr-denis{background:#8bc34a}.legend-color.dr-paula{background:#673ab7}@media (max-width: 1200px){.clinic-tabs{flex-direction:column}.clinic-tab{min-width:100%}.schedule-header,.doctor-row{grid-template-columns:180px repeat(7,1fr)}}@media (max-width: 768px){.clinic-info-bar{flex-direction:column;gap:16px}.clinic-info-right{text-align:left}.schedule-header,.doctor-row{grid-template-columns:150px repeat(7,minmax(100px,1fr));overflow-x:auto}.clinic-schedule-grid{overflow-x:auto}}.multi-clinic-overview{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e9ecef);padding:20px;max-width:100vw;overflow-x:hidden}.multi-clinic-loading{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:18px;color:#666}.overview-header{background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:12px;padding:20px 24px;margin-bottom:20px;box-shadow:0 4px 16px #00000014;border:1px solid #e9ecef}.overview-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.overview-header h1{margin:0;color:#333;font-size:22px}.overview-date-controls{display:flex;align-items:center;justify-content:center;gap:20px}.current-date-display{margin:0;font-size:16px;font-weight:600;color:#333;min-width:200px;text-align:center}.nav-btn{padding:8px 12px;background:#f8f9fa;border:1px solid #dadce0;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;color:#5f6368;transition:all .2s}.nav-btn:hover{background:#e8f0fe;border-color:#1976d2;color:#1976d2}.today-btn{padding:8px 16px;background:#1976d2;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;color:#fff;transition:all .2s}.today-btn:hover{background:#1565c0;box-shadow:0 4px 12px #1976d24d}.settings-btn{padding:8px 16px;background:#f8f9fa;border:1px solid #dadce0;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:#5f6368;transition:all .2s}.settings-btn:hover{background:#e8f0fe;border-color:#1976d2;color:#1976d2}.month-calendar-container{background:#fff;border-radius:12px;overflow:auto;box-shadow:0 4px 12px #00000014;margin-bottom:20px;max-height:calc(100vh - 280px);width:100%;border:1px solid #e9ecef}.month-calendar-grid{display:grid;grid-auto-rows:auto;grid-auto-flow:row;width:100%}.month-grid-header{display:contents}.date-column-header{padding:16px 10px;background:linear-gradient(180deg,#f8f9fa,#f1f3f5);border-right:2px solid #dee2e6;border-bottom:2px solid #dee2e6;font-weight:700;font-size:14px;color:#495057;text-align:center;position:sticky;left:0;z-index:20;box-shadow:2px 0 4px #0000000d;display:flex;align-items:center;justify-content:center}.date-column-header.header-date-span{grid-row:span 2}.clinic-section-header{background:linear-gradient(135deg,#1976d2,#1565c0);border-bottom:3px solid #0d47a1;border-right:1px solid rgba(255,255,255,.2);padding:24px 12px;display:flex;align-items:center;justify-content:center;color:#fff;z-index:15;font-weight:700;font-size:15px;letter-spacing:.5px;text-shadow:0 1px 2px rgba(0,0,0,.2);box-shadow:0 2px 4px #0000001a}.month-doctors-row{display:contents}.doctor-column-header{padding:24px 12px;background:linear-gradient(180deg,#fff,#f8f9fa);border-right:1px solid #dee2e6;border-bottom:2px solid #dee2e6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;z-index:10;transition:all .2s}.doctor-column-header:hover{background:linear-gradient(180deg,#f8f9fa,#e9ecef)}.doctor-column-header.empty-column{background:#fafafa;border-right:1px solid #dee2e6;border-bottom:2px solid #dee2e6}.empty-column-content{display:flex;align-items:center;justify-content:center;height:100%}.empty-column-text{color:#ccc;font-size:18px;font-weight:300}.doctor-avatar-small{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:#fff;box-shadow:0 2px 6px #00000026;border:2px solid white}.doctor-avatar-small.dr-grace{background:#4285f4}.doctor-avatar-small.dr-sani{background:#9c27b0}.doctor-avatar-small.dr-maria{background:#0f9d58}.doctor-avatar-small.dr-vicky{background:#ff9800}.doctor-avatar-small.dr-harry{background:#e91e63}.doctor-avatar-small.dr-paul{background:#00bcd4}.doctor-avatar-small.dr-denis{background:#8bc34a}.doctor-avatar-small.dr-paula{background:#673ab7}.doctor-header-info{text-align:center;width:100%}.doctor-header-name{font-weight:600;font-size:13px;color:#212529;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.3px}.doctor-number-label{font-weight:600;font-size:14px;color:#495057;text-align:center;letter-spacing:.5px}.date-label-wrapper{grid-row:span 2;padding:0;background:linear-gradient(90deg,#f8f9fa,#f1f3f5);border-right:2px solid #dee2e6;border-bottom:1px solid #e9ecef;position:sticky;left:0;z-index:5;box-shadow:2px 0 4px #0000000d;transition:all .2s;display:flex;align-items:center;justify-content:center;min-height:110px}.date-label-wrapper:hover{background:linear-gradient(90deg,#e9ecef,#dee2e6)}.date-label-wrapper.today{background:linear-gradient(90deg,#e3f2fd,#bbdefb);border-right:3px solid #1976d2}.date-label-content-center{display:flex;flex-direction:column;align-items:center;gap:3px}.date-label-number{font-size:18px;font-weight:700;line-height:1;color:#212529}.date-label-wrapper.today .date-label-number{color:#1976d2}.date-label-day{font-size:9px;opacity:.7;text-transform:uppercase;letter-spacing:.5px;font-weight:600;color:#495057}.date-label-wrapper.today .date-label-day{color:#1976d2;opacity:.85}.period-tag{position:absolute;right:6px;font-size:9px;font-weight:700;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.period-tag.am-tag{top:8px;background:#2196f326;color:#1976d2}.period-tag.pm-tag{bottom:8px;background:#ff980026;color:#f57c00}.work-status-cell{border-right:1px solid #e9ecef;border-bottom:1px solid #e9ecef;background:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s;position:relative;min-height:55px;padding:8px 4px}.work-status-cell.am-cell{border-bottom:1px dashed #dee2e6}.work-status-cell.pm-cell{border-bottom:1px solid #e9ecef}.work-status-cell:hover{background:#f8f9fa;box-shadow:inset 0 0 0 1px #dee2e6}.work-status-cell.working{background:linear-gradient(135deg,#e8f5e9,#f1f8f4)}.work-status-cell.working:hover{background:linear-gradient(135deg,#c8e6c9,#e8f5e9);box-shadow:inset 0 0 0 1px #81c784}.work-status-cell.working.today{background:linear-gradient(135deg,#b3e5fc,#e1f5fe)}.work-status-cell.working.dr-grace{background:linear-gradient(135deg,#e3f2fd,#f1f8ff);border-left:3px solid #4285f4}.work-status-cell.working.dr-grace:hover{background:linear-gradient(135deg,#bbdefb,#e3f2fd);box-shadow:inset 0 0 0 1px #4285f4}.work-status-cell.working.dr-sani{background:linear-gradient(135deg,#f3e5f5,#faf4fc);border-left:3px solid #9c27b0}.work-status-cell.working.dr-sani:hover{background:linear-gradient(135deg,#e1bee7,#f3e5f5);box-shadow:inset 0 0 0 1px #9c27b0}.work-status-cell.working.dr-maria{background:linear-gradient(135deg,#e8f5e9,#f1f8f4);border-left:3px solid #0f9d58}.work-status-cell.working.dr-maria:hover{background:linear-gradient(135deg,#c8e6c9,#e8f5e9);box-shadow:inset 0 0 0 1px #0f9d58}.work-status-cell.working.dr-vicky{background:linear-gradient(135deg,#fff3e0,#fffaf5);border-left:3px solid #ff9800}.work-status-cell.working.dr-vicky:hover{background:linear-gradient(135deg,#ffe0b2,#fff3e0);box-shadow:inset 0 0 0 1px #ff9800}.work-status-cell.working.dr-harry{background:linear-gradient(135deg,#fce4ec,#fef5f8);border-left:3px solid #e91e63}.work-status-cell.working.dr-harry:hover{background:linear-gradient(135deg,#f8bbd0,#fce4ec);box-shadow:inset 0 0 0 1px #e91e63}.work-status-cell.working.dr-paul{background:linear-gradient(135deg,#e0f7fa,#f1fcfd);border-left:3px solid #00bcd4}.work-status-cell.working.dr-paul:hover{background:linear-gradient(135deg,#b2ebf2,#e0f7fa);box-shadow:inset 0 0 0 1px #00bcd4}.work-status-cell.working.dr-denis{background:linear-gradient(135deg,#f1f8e9,#f9fcf5);border-left:3px solid #8bc34a}.work-status-cell.working.dr-denis:hover{background:linear-gradient(135deg,#dcedc8,#f1f8e9);box-shadow:inset 0 0 0 1px #8bc34a}.work-status-cell.working.dr-paula{background:linear-gradient(135deg,#ede7f6,#f7f4fb);border-left:3px solid #673ab7}.work-status-cell.working.dr-paula:hover{background:linear-gradient(135deg,#d1c4e9,#ede7f6);box-shadow:inset 0 0 0 1px #673ab7}.work-status-cell.today{background:linear-gradient(135deg,#e3f2fd,#f1f8ff)}.work-status-cell.empty-column-cell{background:#fafafa;cursor:not-allowed}.work-status-cell.conflict{background:linear-gradient(135deg,#ffebee,#ffcdd2)!important;border:2px solid #f44336!important;animation:pulse-red 2s infinite}.work-status-cell.conflict:hover{background:linear-gradient(135deg,#ffcdd2,#ef9a9a)!important;box-shadow:inset 0 0 0 2px #f44336!important}@keyframes pulse-red{0%,to{box-shadow:0 0 #f44336b3}50%{box-shadow:0 0 0 4px #f4433600}}.conflict-warning{font-size:16px;animation:shake .5s infinite;margin-top:2px}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}.work-status-content{display:flex;flex-direction:column;align-items:center;gap:4px}.doctor-name-label{font-size:11px;font-weight:600;color:#495057;text-align:center;line-height:1.2;max-width:100%;word-wrap:break-word;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.work-indicator{font-size:16px;filter:drop-shadow(0 2px 3px rgba(0,0,0,.15));animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.work-indicator.morning-indicator{color:#2196f3;background:radial-gradient(circle,rgba(33,150,243,.15) 0%,transparent 70%);border-radius:50%;padding:4px}.work-indicator.afternoon-indicator{color:#ff9800;background:radial-gradient(circle,rgba(255,152,0,.15) 0%,transparent 70%);border-radius:50%;padding:4px}.month-legend{background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:12px;padding:20px 24px;box-shadow:0 4px 12px #00000014;border:1px solid #e9ecef;display:flex;gap:40px;justify-content:center;align-items:center}.legend-item{display:flex;align-items:center;gap:10px;font-size:14px;color:#495057;font-weight:500;padding:8px 12px;border-radius:8px;transition:all .2s}.legend-item:hover{background:#1976d20d;transform:translateY(-1px)}.not-work-indicator{font-size:18px;color:#dee2e6}.legend-item.conflict-legend{color:#f44336;font-weight:600}.legend-item.conflict-legend.clickable{cursor:pointer;transition:all .2s}.legend-item.conflict-legend.clickable:hover{background:#f443361a;transform:translateY(-2px);box-shadow:0 4px 8px #f4433633}.conflict-indicator{font-size:18px;animation:shake .5s infinite}.highlight-flash{animation:flashHighlight 2s ease-in-out}@keyframes flashHighlight{0%,to{box-shadow:0 0 #f4433600}25%{box-shadow:0 0 0 8px #f44336b3}50%{box-shadow:0 0 #f4433600}75%{box-shadow:0 0 0 8px #f44336b3}}.settings-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.settings-modal{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d}.settings-modal-header{padding:20px 24px;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;align-items:center}.settings-modal-header h2{margin:0;color:#333;font-size:24px}.close-btn{background:none;border:none;font-size:32px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-btn:hover{background:#f1f3f4;color:#333}.settings-modal-content{padding:24px;overflow-y:auto;flex:1}.settings-description{margin:0 0 24px;color:#666;font-size:14px;line-height:1.5}.settings-clinic-item{margin-bottom:32px;padding:20px;background:#f8f9fa;border-radius:8px}.settings-clinic-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.settings-clinic-header h3{margin:0;color:#1976d2;font-size:18px;font-weight:600}.doctor-count-badge{background:#e3f2fd;color:#1976d2;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.settings-control{margin-bottom:16px}.settings-control label{display:block;margin-bottom:8px;color:#333;font-size:14px;font-weight:500}.settings-slider-container{display:flex;align-items:center;gap:16px}.settings-slider{flex:1;height:6px;border-radius:3px;background:#e0e0e0;outline:none;-webkit-appearance:none}.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:#1976d2;cursor:pointer}.settings-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#1976d2;cursor:pointer;border:none}.settings-value{min-width:30px;text-align:center;font-weight:600;font-size:16px;color:#1976d2}.settings-doctors-preview{margin-top:12px}.settings-doctors-preview small{display:block;margin-bottom:8px;color:#666;font-size:12px}.preview-doctors{display:flex;flex-wrap:wrap;gap:8px}.preview-doctor-tag{padding:6px 12px;border-radius:16px;font-size:12px;font-weight:500;color:#fff}.preview-doctor-tag.dr-grace{background:#4285f4}.preview-doctor-tag.dr-sani{background:#9c27b0}.preview-doctor-tag.dr-maria{background:#0f9d58}.preview-doctor-tag.dr-vicky{background:#ff9800}.preview-doctor-tag.dr-harry{background:#e91e63}.preview-doctor-tag.dr-paul{background:#00bcd4}.preview-doctor-tag.dr-denis{background:#8bc34a}.preview-doctor-tag.dr-paula{background:#673ab7}.preview-doctor-tag.empty-tag{background:#e0e0e0;color:#666;border:1px dashed #999}.settings-modal-footer{padding:16px 24px;border-top:2px solid #e9ecef;display:flex;justify-content:flex-end;gap:12px}.cancel-btn,.save-btn{padding:10px 24px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.cancel-btn{background:#f8f9fa;color:#5f6368;border:1px solid #dadce0}.cancel-btn:hover{background:#e8eaed}.save-btn{background:#1976d2;color:#fff}.save-btn:hover{background:#1565c0;box-shadow:0 4px 12px #1976d24d}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f8f9fa;color:#333}.App{min-height:100vh}.medical-history{padding:20px;max-width:none!important;width:100%}.medical-history-section{margin-top:20px;max-width:none!important;width:100%}.medical-history-section h3{font-size:18px;font-weight:600;margin-bottom:20px;color:#333}.medical-questions-list{display:flex;flex-direction:column;gap:2px;width:100%;max-width:100%}.medical-question-row{display:flex;align-items:center;padding:16px 20px;gap:12px;transition:opacity .2s ease;flex-wrap:nowrap;width:100%;min-width:0}.medical-question-row:hover{opacity:.9}.answer-no-row{background-color:#90ee90;color:#000}.answer-yes-row{background-color:#ffb6c1;color:#000}.question-number{font-weight:600;min-width:30px;flex-shrink:0;font-size:15px}.question-text{flex:1;line-height:1.5;font-size:15px;white-space:normal;word-wrap:break-word}.answer-label{font-weight:600;font-size:15px;margin-left:auto;padding-left:20px;flex-shrink:0;min-width:50px;text-align:right}.details-section{background-color:#f9f9f9;padding:20px;margin-bottom:2px}.details-label{display:block;font-weight:500;margin-bottom:10px;color:#555;font-size:14px}.details-textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;resize:vertical;background-color:#fff}.details-textarea:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px #4caf501a}.comments-section{margin-top:30px;padding:20px;background-color:#fff;border:1px solid #e0e0e0;border-radius:6px}.comments-section h3{font-size:16px;font-weight:600;margin-bottom:16px;color:#333}.comment-item{margin-bottom:16px}.comment-item label{display:block;font-weight:500;margin-bottom:8px;color:#555}.comment-textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;resize:vertical}.comment-textarea:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px #4caf501a}.patient-appointments{padding:20px}.appointments-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.appointments-title-group{display:flex;align-items:center;gap:12px}.appointments-header h3{font-size:24px;font-weight:600;margin:0}.whats-new-badge{background-color:#e91e63;color:#fff;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:500}.appointments-actions{display:flex;gap:10px}.appointments-stats{display:flex;gap:30px;padding:20px;background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:30px}.stat-item{font-size:14px;color:#666}.stat-item strong{color:#000;font-weight:600}.appointments-section{margin-bottom:30px}.appointments-section h4{font-size:18px;font-weight:600;margin-bottom:15px;color:#333}.appointments-table{border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}.appointments-table-header{display:grid;grid-template-columns:200px 80px 180px 120px 180px 150px 80px 80px 150px 50px;background-color:#f5f5f5;border-bottom:1px solid #e0e0e0;font-weight:600;font-size:14px;padding:12px 15px;color:#333}.appointments-table-body{background-color:#fff}.appointment-row{display:grid;grid-template-columns:200px 80px 180px 120px 180px 150px 80px 80px 150px 50px;padding:15px;border-bottom:1px solid #f0f0f0;align-items:center;font-size:14px}.appointment-row:last-child{border-bottom:none}.appointment-row:hover{background-color:#f9f9f9}.appointment-when{display:flex;flex-direction:column;gap:4px}.when-date{color:#1976d2;font-weight:500}.when-time{color:#666;font-size:13px}.when-location{color:#999;font-size:12px;margin-top:2px}.btn-icon{background:none;border:none;cursor:pointer;font-size:18px;padding:4px;opacity:.6}.btn-icon:hover{opacity:1}.practitioner-info{display:flex;align-items:center;gap:8px}.practitioner-avatar{width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.status-badge{padding:4px 12px;border-radius:4px;font-size:13px;font-weight:500;display:inline-block}.status-dropdown{padding:6px 24px 6px 12px;border-radius:4px;font-size:13px;font-weight:500;border:none;cursor:pointer;appearance:none;background-repeat:no-repeat;background-position:right 8px center;background-size:12px;background-image:url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="6 9 12 15 18 9"></polyline></svg>')}.status-dropdown:focus{outline:none;box-shadow:0 0 0 2px #1976d233}.status-dropdown.status-scheduled{background-color:#e3f2fd;color:#1976d2}.status-dropdown.status-confirmed,.status-dropdown.status-completed{background-color:#c8e6c9;color:#2e7d32}.status-dropdown.status-cancelled{background-color:#ffebee;color:#c62828}.status-dropdown.status-no_show{background-color:#fff3e0;color:#e65100}.status-dropdown.status-in_progress{background-color:#fff9c4;color:#f57f17}.status-dropdown.status-pending{background-color:#fff3e0;color:#f57c00}.status-badge.status-scheduled{background-color:#e3f2fd;color:#1976d2}.status-badge.status-confirmed,.status-badge.status-completed{background-color:#c8e6c9;color:#2e7d32}.status-badge.status-cancelled{background-color:#ffebee;color:#c62828}.status-badge.status-no_show{background-color:#fff3e0;color:#e65100}.status-badge.status-in_progress{background-color:#fff9c4;color:#f57f17}.no-appointments{text-align:center;padding:60px 20px;color:#666}.no-appointments p{margin-bottom:20px;font-size:16px}
