@import url(https://fonts.googleapis.com/css2?family=Futura+PT:wght@300;400;500;600;700&display=swap);*{margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;color:#2d3748;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1400px;padding:20px}@media (max-width:768px){.container{padding:10px}}@media (max-width:480px){.container{padding:5px}}.header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 6px #0000001a;color:#fff;margin-bottom:30px;padding:30px 0}.header h1{font-size:2.5rem;font-weight:700;margin-bottom:10px}.header p{font-size:1.1rem;opacity:.9}.nav-tabs{border-bottom:2px solid #e2e8f0;gap:10px;margin-bottom:30px;padding-bottom:0}.nav-tab{background:none;border-bottom:3px solid #0000;color:#4a5568;font-size:1rem;padding:12px 24px}.nav-tab:hover{color:#667eea}.nav-tab.active{border-bottom-color:#667eea;color:#667eea}.card{box-shadow:0 2px 8px #0000000d;margin-bottom:24px;padding:24px;transition:box-shadow .3s ease}.card:hover{box-shadow:0 4px 12px #0000001a}.card h2{color:#2d3748;font-size:1.5rem;margin-bottom:16px}.card h3{color:#4a5568;font-size:1.2rem;font-weight:600;margin-bottom:12px}.data-table{margin-top:16px}.data-table td,.data-table th{border-bottom:1px solid #e2e8f0;padding:12px 16px;text-align:left}.data-table th{color:#4a5568;font-size:.875rem;letter-spacing:.05em}.data-table tbody tr:hover,.data-table th{background:#f7fafc}.data-table tbody tr.total-row{background:#edf2f7;font-weight:600}.data-table td.currency,.data-table td.numeric{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.data-table td.currency{text-align:right}.btn{border-radius:6px;font-size:1rem;padding:10px 20px}.btn-primary{background:#667eea}.btn-primary:hover{background:#5a67d8;box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.btn-secondary{background:#718096;color:#fff}.btn-secondary:hover{background:#4a5568}.btn-success{background:#48bb78;color:#fff}.btn-success:hover{background:#38a169}.file-upload-section{align-items:center;display:flex;gap:16px;margin-bottom:16px}.file-input{background:#f7fafc;border:2px dashed #cbd5e0;border-radius:6px;flex:1 1;padding:10px}.alert{border-radius:6px;margin-bottom:16px;padding:16px}.alert-success{background:#c6f6d5;border:1px solid #9ae6b4;color:#22543d}.alert-error{background:#fed7d7;border:1px solid #fc8181;color:#742a2a}.alert-info{background:#bee3f8;border:1px solid #90cdf4;color:#2c5282}.loading-spinner{animation:spin 1s ease-in-out infinite;border:3px solid #667eea4d;border-top-color:#667eea;display:inline-block;height:20px;width:20px}.note-box{background:#fef5e7;border-left:4px solid #f39c12;border-radius:4px;font-size:.95rem;line-height:1.6;margin:16px 0;padding:16px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;padding:20px;text-align:center}.stat-card h4{font-size:.875rem;letter-spacing:.05em;margin-bottom:8px;opacity:.9;text-transform:uppercase}.stat-card .stat-value{font-size:2rem;font-weight:700}.filters{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{color:#4a5568;font-size:.875rem;font-weight:500}.filter-group select{background:#fff;border:1px solid #cbd5e0;border-radius:6px;font-size:1rem;padding:8px 12px}.filter-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}@media (max-width:768px){.header{margin-bottom:20px;padding:20px 0}.header h1{font-size:2rem}.header p{font-size:1rem}.nav-tabs{flex-direction:column;gap:5px;margin-bottom:20px}.nav-tab{font-size:.9rem;padding:10px 16px}.card{margin-bottom:16px;padding:16px}.card h2{font-size:1.3rem}.card h3{font-size:1.1rem}.data-table{font-size:.8rem}.data-table td,.data-table th{padding:8px 12px}.btn{font-size:.9rem;padding:8px 16px}.filters{flex-direction:column;gap:12px}.filter-group{width:100%}.stats-grid{gap:12px;grid-template-columns:1fr}.stat-card{padding:16px}.stat-card .stat-value{font-size:1.5rem}}@media (max-width:480px){.header{margin-bottom:15px;padding:15px 0}.header h1{font-size:1.5rem}.header p{font-size:.9rem}.nav-tabs{gap:3px;margin-bottom:15px}.nav-tab{font-size:.8rem;padding:8px 12px}.card{margin-bottom:12px;padding:12px}.card h2{font-size:1.2rem}.card h3{font-size:1rem}.data-table{font-size:.7rem}.data-table td,.data-table th{padding:6px 8px}.btn{font-size:.8rem;padding:6px 12px}.stats-grid{gap:8px}.stat-card{padding:12px}.stat-card .stat-value{font-size:1.3rem}.note-box{font-size:.9rem;padding:12px}}@media (hover:none) and (pointer:coarse){.btn{min-width:44px}.btn,.data-table tbody tr,.filter-group select,.nav-tab{min-height:44px}}:root{--primary-green:#98cd67;--primary-blue:#007aff;--dark-text:#1b1b1b;--dark-bg:#1b1b1b;--accent-blue:#009ec4;--font-family:"Futura PT",sans-serif}*{box-sizing:border-box}body{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;background-color:#f8f9fa;color:#1b1b1b;color:var(--dark-text);font-family:Futura PT,sans-serif;font-family:var(--font-family);line-height:1.6;margin:0}body,html{overflow-x:hidden}.App{font-family:Futura PT,sans-serif;font-family:var(--font-family);min-height:100vh}.header{background:linear-gradient(135deg,#007aff,#fff);background:linear-gradient(135deg,var(--primary-blue) 0,#fff 100%);box-shadow:0 2px 10px #0000001a;color:#1b1b1b;color:var(--dark-text);padding:1.5rem 2rem}.header-content{gap:2rem;justify-content:space-between}.header-content,.logo{align-items:center;display:flex}.logo{justify-content:center}.tooth-icon{color:#98cd67;color:var(--primary-green);filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:3rem;text-shadow:0 2px 4px #0000001a}.system-title{flex:1 1;text-align:left}.user-info{align-items:center;display:flex;font-size:.9rem;gap:1rem}.user-name{color:#1b1b1b;color:var(--dark-text);font-weight:500}.user-role{color:#1b1b1bb3}.logout-btn,.user-role{font-size:.8rem;letter-spacing:.5px;text-transform:uppercase}.logout-btn{background:#fff3;border:1px solid #1b1b1b33;border-radius:6px;color:#1b1b1b;color:var(--dark-text);cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.logout-btn:hover{background:#ffffff4d;border-color:#1b1b1b4d;transform:translateY(-1px)}.system-title h1{color:#1b1b1b;color:var(--dark-text);font-size:1.8rem;font-weight:600;margin:0}.system-title h1,.system-title p{font-family:Futura PT,sans-serif;font-family:var(--font-family)}.system-title p{color:#1b1b1bcc;font-size:1rem;font-weight:400;margin:.25rem 0 0}.card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 20px #00000014;margin:1rem 0;padding:1.5rem}.card h2{border-bottom:2px solid #98cd67;border-bottom:2px solid var(--primary-green);color:#1b1b1b;color:var(--dark-text);font-size:1.4rem;font-weight:600;margin-bottom:1.5rem;margin-top:0;padding-bottom:.5rem}.data-table{border-collapse:collapse;font-family:Futura PT,sans-serif;font-family:var(--font-family);margin-top:1rem;width:100%}.data-table th{background:linear-gradient(135deg,#98cd67,#7fb85a);background:linear-gradient(135deg,var(--primary-green) 0,#7fb85a 100%);color:#fff;font-size:.9rem;font-weight:600;letter-spacing:.5px;padding:.75rem;text-align:left;text-transform:uppercase}.data-table th.numeric{text-align:right}.data-table td{border-bottom:1px solid #e9ecef;font-size:.9rem;padding:.75rem}.data-table td.numeric{font-weight:500;text-align:right}.data-table tr:hover{background-color:#f8f9fa}.data-table tr.total-row{background-color:#f1f3f4;font-weight:600}.data-table tr.total-row td{border-bottom:2px solid #98cd67;border-bottom:2px solid var(--primary-green);border-top:2px solid #98cd67;border-top:2px solid var(--primary-green)}.btn{background:linear-gradient(135deg,#007aff,#009ec4);background:linear-gradient(135deg,var(--primary-blue) 0,var(--accent-blue) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Futura PT,sans-serif;font-family:var(--font-family);font-size:.9rem;font-weight:500;letter-spacing:.5px;padding:.75rem 1.5rem;text-transform:uppercase;transition:all .3s ease}.btn:hover{box-shadow:0 4px 15px #007aff4d;transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn-secondary{background:linear-gradient(135deg,#98cd67,#7fb85a);background:linear-gradient(135deg,var(--primary-green) 0,#7fb85a 100%)}.btn-secondary:hover{box-shadow:0 4px 15px #98cd674d}.form-group{margin-bottom:1rem}.form-group label{color:#1b1b1b;font-size:.9rem;margin-bottom:.5rem}.form-control{border:2px solid #e9ecef;border-radius:8px;font-family:Futura PT,sans-serif;font-family:var(--font-family);font-size:.9rem;padding:.75rem;transition:border-color .3s ease;width:100%}.form-control:focus{border-color:#007aff;border-color:var(--primary-blue);box-shadow:0 0 0 3px #007aff1a;outline:none}.filters{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 10px #0000000d;margin-bottom:1rem;padding:1.5rem}.filters h3{color:#1b1b1b;color:var(--dark-text);font-size:1.1rem;font-weight:600;margin-bottom:1rem;margin-top:0}.filter-row{align-items:end;display:flex;flex-wrap:wrap;gap:1rem}.filter-group{flex:1 1;min-width:200px}.export-button-group{display:flex;flex-wrap:wrap;gap:.5rem}.export-buttons{margin-top:1rem;width:100%}.btn-primary{background:linear-gradient(135deg,#007aff,#009ec4);background:linear-gradient(135deg,var(--primary-blue) 0,var(--accent-blue) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Futura PT,sans-serif;font-family:var(--font-family);font-size:.9rem;font-weight:500;letter-spacing:.5px;overflow:hidden;padding:.75rem 1.5rem;position:relative;text-transform:uppercase;transition:all .3s ease}.btn-primary:hover:not(:disabled){box-shadow:0 4px 15px #007aff4d;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.7;transform:none}.btn-primary:disabled:after{animation:loading-shimmer 1.5s infinite;background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes loading-shimmer{0%{left:-100%}to{left:100%}}.note-box{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-left:4px solid #98cd67;border-left:4px solid var(--primary-green);border-radius:8px;margin-top:1rem;padding:1rem}.note-box strong{color:#1b1b1b;color:var(--dark-text);font-weight:600}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#007aff;border-top:3px solid var(--primary-blue);height:30px;margin:0 auto;width:30px}.loading-screen{align-items:center;background:linear-gradient(135deg,#007aff,#009ec4);background:linear-gradient(135deg,var(--primary-blue) 0,var(--accent-blue) 100%);display:flex;justify-content:center;min-height:100vh}.loading-screen .loading-spinner{color:#fff;text-align:center}.loading-screen .tooth-icon{color:#fff;font-size:48px;margin-bottom:16px}.loading-screen p{color:#fff;font-size:18px;font-weight:500;margin-top:16px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.header{padding:1rem}.header-content{flex-direction:column;gap:1rem;text-align:center}.logo{justify-content:center}.system-title{text-align:center}.system-title h1{font-size:1.5rem}.tooth-icon{font-size:2.5rem}.user-info{align-items:center;gap:.5rem}.nav-tabs,.user-info{flex-direction:column}.nav-tabs{gap:.25rem}.mobile-menu-toggle{align-self:flex-start;display:flex}.nav-tabs-content{display:none;flex-direction:column;gap:.25rem}.nav-tabs-content.mobile-open{display:flex}.nav-tab{padding:.75rem 1rem}.card{margin:.5rem 0;padding:1rem}.filter-row{flex-direction:column}.filter-group{min-width:100%}.export-button-group{flex-direction:column;gap:.5rem}.export-button-group .btn{width:100%}.data-table{font-size:.8rem}.data-table td,.data-table th{padding:.5rem}}@media (max-width:480px){.header{padding:.75rem}.system-title h1{font-size:1.2rem;line-height:1.3}.system-title p{font-size:.9rem}.tooth-icon{font-size:2rem}.user-info{font-size:.8rem}.logout-btn{font-size:.7rem;padding:.4rem .8rem}.nav-tabs{gap:.125rem;padding:.25rem}.nav-tab{font-size:.8rem;padding:.5rem .75rem}.card{border-radius:8px;margin:.25rem 0;padding:.75rem}.card h2{font-size:1.2rem;margin-bottom:1rem}.data-table{font-size:.7rem}.data-table td,.data-table th{min-width:80px;padding:.4rem .3rem;white-space:nowrap}.data-table td:first-child,.data-table th:first-child{background:#fff;border-right:1px solid #e9ecef;left:0;position:-webkit-sticky;position:sticky;z-index:10}.data-table thead th:first-child{background:linear-gradient(135deg,#98cd67,#7fb85a);background:linear-gradient(135deg,var(--primary-green) 0,#7fb85a 100%);color:#fff}.btn{font-size:.8rem;padding:.6rem 1rem}.form-control{font-size:.9rem;padding:.6rem}.modal-content{margin:.5rem;max-width:95vw}.modal-body,.modal-footer,.modal-header{padding:1rem}.patient-overview-grid{gap:.5rem;grid-template-columns:1fr}.overview-item{padding:.5rem}.overview-value{font-size:1rem}}@media (max-width:768px){.table-responsive{-webkit-overflow-scrolling:touch;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.data-table{margin:0;min-width:600px}.table-responsive::-webkit-scrollbar{height:8px}.table-responsive::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.table-responsive::-webkit-scrollbar-thumb{background:#007aff;background:var(--primary-blue);border-radius:4px}.table-responsive::-webkit-scrollbar-thumb:hover{background:#009ec4;background:var(--accent-blue)}}@media (hover:none) and (pointer:coarse){.btn{min-width:44px}.btn,.nav-tab{min-height:44px;padding:12px 16px}.clickable-data{padding:8px}.clickable-data,.search-result-item{align-items:center;display:flex;min-height:44px}.search-result-item{padding:12px}.mobile-menu-toggle{min-height:44px;min-width:44px}.form-control{min-height:44px;padding:12px}.btn:hover{box-shadow:none;transform:none}.nav-tab:hover{background:#0000;color:#666}.nav-tab.active:hover{background:linear-gradient(135deg,#007aff,#009ec4);background:linear-gradient(135deg,var(--primary-blue) 0,var(--accent-blue) 100%);color:#fff}}@media (max-width:768px){.btn,.clickable-data,.nav-tab{min-height:44px;min-width:44px}.card{margin:.5rem 0}.form-control{font-size:16px}.modal-overlay{padding:.5rem}.modal-content{max-height:95vh;overflow-y:auto}}@media (max-width:768px) and (orientation:landscape){.header{padding:.5rem}.system-title h1{font-size:1.3rem}.nav-tabs{margin:.5rem 0}.card{margin:.25rem 0;padding:.75rem}}.future-case-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-top:20px}.future-case-section{min-width:0}.future-case-section h3{color:#1b1b1b;color:var(--dark-text);font-size:1.1rem;font-weight:600;margin-bottom:1rem}.chart-container{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 20px #00000014;margin:1rem 0;padding:1.5rem}.chart-container h3{border-bottom:2px solid #98cd67;border-bottom:2px solid var(--primary-green);color:#1b1b1b;color:var(--dark-text);font-size:1.2rem;font-weight:600;margin-bottom:1rem;margin-top:0;padding-bottom:.5rem}.status-acceptable{color:#98cd67;color:var(--primary-green);font-weight:600}.status-warning{color:#ffc107;font-weight:600}.status-error{color:#dc3545;font-weight:600}.nav-tabs{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 10px #0000000d;display:flex;gap:.5rem;margin:1rem 0;padding:.5rem;position:relative}.mobile-menu-toggle{align-items:center;background:none;border:none;cursor:pointer;display:none;flex-direction:column;height:44px;justify-content:center;margin-right:.5rem;padding:0;width:44px}.hamburger-line{background-color:#1b1b1b;background-color:var(--dark-text);border-radius:1px;height:2px;margin:2px 0;transition:all .3s ease;width:20px}.mobile-menu-toggle:hover .hamburger-line{background-color:#007aff;background-color:var(--primary-blue)}.nav-tabs-content{display:flex;flex:1 1;gap:.5rem}.nav-tab{background:#0000;border:none;border-radius:8px;color:#666;cursor:pointer;flex:1 1;font-family:Futura PT,sans-serif;font-family:var(--font-family);font-size:.9rem;font-weight:500;letter-spacing:.5px;padding:1rem 1.5rem;text-transform:uppercase;transition:all .3s ease}.nav-tab:hover{background:#f8f9fa;color:#1b1b1b;color:var(--dark-text)}.nav-tab.active{background:linear-gradient(135deg,#007aff,#009ec4);background:linear-gradient(135deg,var(--primary-blue) 0,var(--accent-blue) 100%);box-shadow:0 2px 8px #007aff4d;color:#fff}.text-center{text-align:center}.text-right{text-align:right}.mb-0{margin-bottom:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;width:800px}.modal-header{align-items:center;background:linear-gradient(135deg,#98cd67,#7fb85a);background:linear-gradient(135deg,var(--primary-green) 0,#7fb85a 100%);border-bottom:1px solid #e9ecef;border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h3{font-size:1.2rem;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;transition:background-color .3s ease;width:30px}.modal-close:hover{background-color:#fff3}.modal-body{flex:1 1;overflow-y:auto;padding:1.5rem}.modal-footer{border-top:1px solid #e9ecef;display:flex;justify-content:flex-end;padding:1rem 1.5rem}.clickable-data{border-radius:4px;cursor:pointer;margin:-2px -4px;padding:2px 4px;transition:all .3s ease}.clickable-data:hover{background-color:#98cd67;background-color:var(--primary-green);color:#fff;transform:scale(1.05)}.clickable-data:active{transform:scale(.98)}.search-container{position:relative}.search-results{background-color:#fff;border:1px solid #ddd;border-radius:0 0 4px 4px;border-top:none;box-shadow:0 2px 8px #0000001a;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.search-result-item{border-bottom:1px solid #eee;cursor:pointer;padding:.75rem;transition:background-color .2s ease}.search-result-item:hover{background-color:#f8f9fa}.search-result-item:last-child{border-bottom:none}.treatment-progress{background:linear-gradient(90deg,#e9ecef,#dee2e6);border-left:4px solid #98cd67;border-left:4px solid var(--primary-green);border-radius:8px;margin:.5rem 0;padding:1rem}.treatment-stage{background-color:#f8f9fa;border-radius:4px;display:inline-block;font-size:.9rem;margin:.25rem .5rem .25rem 0;padding:.25rem .5rem}.status-badge{border-radius:12px;font-size:.8rem;font-weight:500;padding:.25rem .5rem;text-transform:uppercase}.status-win{background-color:#d4edda;color:#155724}.status-loss{background-color:#f8d7da;color:#721c24}.status-pending{background-color:#fff3cd;color:#856404}.patient-overview-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1rem}.overview-item{background-color:#f8f9fa;border-left:3px solid #007aff;border-left:3px solid var(--primary-blue);border-radius:4px;padding:.75rem}.overview-label{color:#6c757d;font-size:.8rem;font-weight:500;margin-bottom:.25rem;text-transform:uppercase}.overview-value{color:#1b1b1b;color:var(--dark-text);font-size:1.1rem;font-weight:600}@media (max-width:768px){.patient-overview-grid{grid-template-columns:1fr}.search-results{max-height:150px}.future-case-grid{gap:16px;grid-template-columns:1fr}.future-case-section h3{font-size:1rem}}.user-management{font-family:var(--font-family);margin:0 auto;max-width:1200px;padding:20px}.user-management-header{align-items:center;border-bottom:2px solid #e1e5e9;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.user-management-header h2{color:var(--dark-text);font-size:28px;margin:0}.add-user-btn,.user-management-header h2{font-family:var(--font-family);font-weight:600}.add-user-btn{background:linear-gradient(135deg,var(--primary-blue) 0,var(--accent-blue) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;letter-spacing:.5px;padding:12px 24px;text-transform:uppercase;transition:transform .2s ease,box-shadow .2s ease}.add-user-btn:hover{box-shadow:0 8px 20px #007aff4d;transform:translateY(-2px)}.user-form-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.user-form{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;max-height:90vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}.form-header{align-items:center;border-bottom:1px solid #e1e5e9;display:flex;justify-content:space-between;margin-bottom:25px;padding-bottom:15px}.form-header h3{color:var(--dark-text);font-family:var(--font-family);font-size:20px;font-weight:600;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:background-color .2s ease;width:30px}.close-btn:hover{background-color:#f5f5f5}.form-group input,.form-group select{border:2px solid #e1e5e9;border-radius:8px;box-sizing:border-box;font-size:16px;padding:12px 16px;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #007aff1a;outline:none}.form-actions{display:flex;gap:12px;margin-top:25px}.submit-btn{background:linear-gradient(135deg,var(--primary-blue) 0,var(--accent-blue) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-family:var(--font-family);font-size:16px;font-weight:600;letter-spacing:.5px;padding:14px;text-transform:uppercase;transition:transform .2s ease,box-shadow .2s ease}.submit-btn:hover{box-shadow:0 8px 20px #007aff4d;transform:translateY(-2px)}.cancel-btn{background:#f5f5f5;border:2px solid #e1e5e9;border-radius:8px;color:#666;cursor:pointer;flex:1 1;font-family:var(--font-family);font-size:16px;font-weight:600;letter-spacing:.5px;padding:14px;text-transform:uppercase;transition:background-color .2s ease}.cancel-btn:hover{background:#e9ecef}.users-table{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;overflow:hidden}.users-table table{border-collapse:collapse;width:100%}.users-table th{background:linear-gradient(135deg,var(--primary-green) 0,#7fb85a 100%);border-bottom:2px solid #e1e5e9;color:#fff;font-weight:600;letter-spacing:.5px;text-align:left;text-transform:uppercase}.users-table td,.users-table th{font-family:var(--font-family);font-size:14px;padding:16px 12px}.users-table td{border-bottom:1px solid #e1e5e9}.users-table tr:hover{background-color:#f8f9fa}.role-badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.role-admin{background:#ffeaa7;color:#d63031}.role-manager{background:#a8e6cf;color:#00b894}.role-provider{background:var(--primary-green);color:#fff}.status-badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.status-badge.active{background:#d1f2eb;color:#00b894}.status-badge.inactive{background:#fadbd8;color:#e74c3c}.delete-btn,.edit-btn{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;margin-right:8px;padding:6px 12px;transition:all .2s ease}.edit-btn{background:var(--primary-blue);color:#fff}.edit-btn:hover{background:var(--accent-blue)}.delete-btn{background:#fd79a8;color:#fff}.delete-btn:hover:not(:disabled){background:#e84393}.delete-btn:disabled{background:#ddd;color:#999;cursor:not-allowed}.loading{color:#666;font-size:18px;padding:40px;text-align:center}@media (max-width:768px){.user-management{padding:10px}.user-management-header{align-items:stretch;flex-direction:column;gap:15px}.users-table{overflow-x:auto}.users-table table{min-width:600px}.form-actions{flex-direction:column}}.login-container{align-items:center;background:linear-gradient(135deg,var(--primary-blue) 0,var(--accent-blue) 100%);display:flex;font-family:var(--font-family);justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;max-width:400px;padding:40px;text-align:center;width:100%}.login-header{margin-bottom:30px}.login-header .tooth-icon{font-size:48px;margin-bottom:16px}.login-header h1{color:var(--dark-text);font-family:var(--font-family);font-size:24px;font-weight:600;margin:0 0 8px}.login-header p{color:#1b1b1bcc;font-family:var(--font-family);font-size:14px;margin:0}.login-form{text-align:left}.form-group{margin-bottom:20px}.form-group label{color:var(--dark-text);display:block;font-family:var(--font-family);font-size:14px;font-weight:500;margin-bottom:6px}.form-group input{border:2px solid #e1e5e9;border-radius:8px;box-sizing:border-box;font-size:16px;padding:12px 16px;transition:border-color .3s ease;width:100%}.form-group input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #007aff1a;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-button{background:linear-gradient(135deg,var(--primary-blue) 0,var(--accent-blue) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:var(--font-family);font-size:16px;font-weight:600;letter-spacing:.5px;margin-top:10px;padding:14px;text-transform:uppercase;transition:transform .2s ease,box-shadow .2s ease;width:100%}.login-button:hover:not(:disabled){box-shadow:0 8px 20px #007aff4d;transform:translateY(-2px)}.login-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:6px;color:#c33}.error-message,.success-message{font-size:14px;margin-bottom:20px;padding:12px}.success-message{background-color:#efe;border:1px solid #cfc;border-radius:6px;color:#363}.login-footer{margin-top:24px;text-align:center}.forgot-password-link{background:none;border:none;color:var(--primary-blue);cursor:pointer;font-family:var(--font-family);font-size:14px;text-decoration:none;transition:color .3s ease}.forgot-password-link:hover{color:var(--accent-blue);text-decoration:underline}.back-link{background:none;border:none;color:var(--primary-blue);cursor:pointer;font-family:var(--font-family);font-size:14px;text-decoration:none;transition:color .3s ease}.back-link:hover{color:var(--accent-blue);text-decoration:underline}@media (max-width:480px){.login-container{padding:10px}.login-card{margin:10px;max-width:100%;padding:30px 20px}.login-header h1{font-size:20px}.login-header .tooth-icon{font-size:40px}.form-group input,.login-button{font-size:16px}}@media (max-width:360px){.login-card{margin:5px;padding:20px 15px}.login-header h1{font-size:18px}.login-header .tooth-icon{font-size:36px}}
/*# sourceMappingURL=main.44c05952.css.map*/