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