*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#eff4ff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow-x:hidden;position:relative;width:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}img{height:auto;max-width:100%}#root{overflow-x:hidden;width:100%}a,button,input,select,textarea{-webkit-tap-highlight-color:rgba(0,78,235,.1);min-height:44px}input[type=email],input[type=tel],input[type=text],select,textarea{font-size:16px}@media (max-width:768px){body{-webkit-overflow-scrolling:touch}*{-webkit-tap-highlight-color:transparent}}.App{min-height:100vh;overflow-x:hidden;position:relative;text-align:center;width:100%}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.App{font-size:16px}}@media (max-width:480px){.App-header{font-size:calc(8px + 2vmin);padding:1rem}}body{box-sizing:border-box;margin:0;padding:0}.mainDiv{display:flex;flex-direction:column;min-height:100vh}footer{margin-top:auto}.loginButtonContainer{align-items:center;display:flex;position:absolute;right:40px;top:20px;z-index:10}.authUserArea{gap:12px}.authUserArea,.loggedInName{align-items:center;display:flex}.loggedInName{background:#fff;border-radius:20px;box-shadow:0 2px 8px #0000001a;color:#004eeb;font-size:14px;font-weight:600;gap:6px;padding:6px 12px}.roleBadge{background:#004eeb;border-radius:10px;color:#fff;font-size:10px;font-weight:700;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.upperMain{background-color:#eff4ff;overflow:hidden;padding:0}.upperMain,.upperMainComponent{min-height:85vh;position:relative}.upperMainComponent{align-items:center;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;padding:3vh 5vw}.upperMainComponent>div:first-child{position:relative;z-index:2}.upperMainComponent>div:last-child{align-items:center;display:flex;height:100%;justify-content:flex-end;position:absolute;right:0;top:0;width:70%}.buttonContainer{display:flex;flex-wrap:wrap;gap:1rem;justify-content:flex-start}.doctorName{color:#004eeb;font-size:2rem;margin-bottom:.5rem}.mainTitle{color:#333;font-size:2.5rem;line-height:1.2;margin-bottom:1rem}.mainDescription{color:#555;font-size:1.1rem;line-height:1.6;margin-bottom:2rem;max-width:600px}.doctorImage{border-radius:0;height:100%;mask-composite:intersect;-webkit-mask-composite:source-in;mask-image:linear-gradient(90deg,#0000 0,#000 15%,#000 85%,#0000),linear-gradient(180deg,#000 0,#000 85%,#0000);-webkit-mask-image:linear-gradient(90deg,#0000 0,#000 15%,#000 85%,#0000),linear-gradient(180deg,#000 0,#000 85%,#0000);min-height:85vh;object-fit:cover;width:100%}@media (max-width:1024px){.upperMainComponent>div:last-child{width:60%}.upperMainComponent>div:first-child{max-width:35%}.doctorName{font-size:1.75rem}.mainTitle{font-size:2.2rem}.mainDescription{font-size:1rem}}@media (max-width:768px){.upperMain{min-height:auto}.upperMainComponent{flex-direction:column;gap:2rem;min-height:auto;padding:2rem 1.5rem}.upperMainComponent>div:first-child{max-width:100%;text-align:center;width:100%}.upperMainComponent>div:last-child{height:400px;justify-content:center;min-height:400px;position:relative;width:100%}.doctorImage{border-radius:15px;height:400px;mask-image:none;-webkit-mask-image:none;min-height:400px}.buttonContainer{gap:.8rem;justify-content:center}.doctorName{font-size:1.5rem}.mainTitle{font-size:1.9rem}.mainDescription{font-size:.95rem;margin:0 auto 1.5rem;max-width:100%}}@media (max-width:480px){.upperMainComponent{padding:1.5rem 1rem}.doctorImage,.upperMainComponent>div:last-child{height:350px;min-height:350px}.doctorName{font-size:1.3rem;margin-bottom:.4rem}.mainTitle{font-size:1.6rem;margin-bottom:.8rem}.mainDescription{font-size:.9rem;margin-bottom:1.2rem}}.defaultButton{align-items:center;background-color:#004eeb;border:none;border-radius:10px;box-shadow:0 2px 8px #004eeb33;cursor:pointer;display:flex;justify-content:center;min-width:150px;padding:1rem 2rem;transition:all .3s ease}.defaultButton:hover{background-color:#03c;box-shadow:0 4px 12px #004eeb4d;transform:translateY(-2px)}.defaultButton p{color:#fff;font-weight:500;margin:0;text-align:center}.whiteButton{align-items:center;background-color:#fff;border:2px solid #004eeb;border-radius:10px;box-shadow:0 2px 8px #0000000d;cursor:pointer;display:flex;justify-content:center;min-width:150px;padding:1rem 2rem;transition:all .3s ease}.whiteButton:hover{background-color:#f8faff;border-color:#03c;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.whiteButton p{color:#004eeb;font-weight:500;margin:0;text-align:center}@media (max-width:768px){.defaultButton,.whiteButton{min-width:140px;padding:.9rem 1.5rem}.defaultButton p,.whiteButton p{font-size:.95rem}}@media (max-width:480px){.defaultButton,.whiteButton{max-width:200px;min-width:120px;padding:.8rem 1.2rem;width:100%}.defaultButton p,.whiteButton p{font-size:.9rem}}.centerDiv{background-color:#eff4ff}.centerDivContent{align-items:stretch;display:flex;flex-direction:row;gap:2.5rem;justify-content:space-around;margin:0 auto;max-width:1400px;padding:2vh 5vw}.centerDivLeft{display:flex;flex:0.9 1;flex-direction:column;gap:1rem;justify-content:space-between;max-width:380px;padding-top:3.5rem;position:relative}.aboutImage{aspect-ratio:3/5;border:3px solid #fff;border-radius:15px;box-shadow:0 10px 40px #004eeb26,0 2px 8px #0000000d;box-sizing:border-box;object-fit:cover;transition:transform .3s ease,box-shadow .3s ease;width:100%}.aboutImage:hover{box-shadow:0 20px 60px #004eeb33,0 4px 12px #00000014;transform:translateY(-5px)}.philosophySection{background:linear-gradient(135deg,#004eeb,#06f);border-radius:12px;box-shadow:0 4px 15px #004eeb33;box-sizing:border-box;flex-shrink:0;padding:1.2rem;width:100%}.philosophyTitle{color:#fff;font-size:1rem;font-weight:600;margin:0 0 .8rem}.philosophyText{color:#fff;font-size:.95rem;line-height:1.6;margin:0}.philosophyText strong{font-weight:700;text-shadow:0 1px 2px #0000001a}.centerDivRight{display:flex;flex:1.1 1;flex-direction:column;line-height:1.6}.mainHeading{color:#004eeb;font-size:2rem;font-weight:700;margin-bottom:1rem}.introText{color:#333;font-size:1.05rem;line-height:1.7;margin-bottom:1.5rem}.introText strong{color:#004eeb;font-weight:600}.infoSection{background:#fff;border-left:4px solid #004eeb;border-radius:10px;box-shadow:0 2px 8px #0000000a;display:flex;flex-direction:column;flex-grow:1;justify-content:space-between;margin-bottom:0;margin-top:1.3rem;padding:1rem 1.2rem;transition:transform .2s ease,box-shadow .2s ease}.infoSection:hover{box-shadow:0 4px 12px #004eeb1a;transform:translateX(5px)}.infoSection h4{color:#004eeb;font-size:1.1rem;font-weight:600;margin:0 0 .8rem}.infoSection h4:not(:first-child){margin-top:1.5rem}.highlight{background:linear-gradient(120deg,#e8f2ff,#f0f7ff);border-radius:8px;line-height:1.7;margin:0;padding:.8rem}.highlight strong{color:#004eeb;font-weight:600}.credentialsList{line-height:1.7;margin:0;padding-left:1.2rem}.credentialsList li{color:#333;margin-bottom:.6rem}.credentialsList strong{color:#004eeb;font-weight:600}.subText{color:#555;display:block;font-size:.95rem;font-style:italic;line-height:1.6;margin-top:.4rem}@media (max-width:1024px){.centerDivContent{gap:2rem;padding:2vh 3vw}.centerDivLeft{max-width:340px}.mainHeading{font-size:1.75rem}}@media (max-width:768px){.centerDivContent{flex-direction:column;gap:2rem;padding:3rem 1.5rem}.centerDivLeft{flex-direction:row;gap:1.5rem;max-width:100%;padding-top:0;width:100%}.aboutImage{aspect-ratio:3/4;max-width:300px;width:45%}.philosophySection{flex:1 1;width:50%}.centerDivRight{width:100%}.mainHeading{font-size:1.75rem;margin-bottom:1rem}.introText{font-size:1rem}}@media (max-width:600px){.centerDivContent{padding:2rem 1rem}.centerDivLeft{flex-direction:column}.aboutImage{aspect-ratio:4/5;max-width:100%;width:100%}.philosophySection{width:100%}.mainHeading{font-size:1.5rem}.introText{font-size:.95rem}.infoSection{margin-top:1rem;padding:.9rem 1rem}.infoSection h4{font-size:1rem}.philosophyTitle{font-size:.95rem}.philosophyText{font-size:.9rem}}@media (max-width:480px){.centerDivContent{padding:1.5rem .8rem}.mainHeading{font-size:1.4rem;margin-bottom:.8rem}.introText{font-size:.9rem;margin-bottom:1rem}.infoSection{padding:.8rem .9rem}.infoSection h4{font-size:.95rem;margin-bottom:.6rem}.infoSection h4:not(:first-child){margin-top:1.2rem}.credentialsList{font-size:.9rem;padding-left:1rem}.subText{font-size:.85rem}.highlight{font-size:.9rem;padding:.7rem}.philosophySection{padding:1rem}.philosophyTitle{font-size:.9rem;margin-bottom:.6rem}.philosophyText{font-size:.85rem;line-height:1.5}}.footer{align-items:center;background-color:#eff4ff;bottom:0;color:#004eeb;display:flex;flex-wrap:wrap;font-size:.8rem;font-weight:700;gap:2rem;justify-content:center;margin-top:auto;padding:1rem;position:relative;text-align:center;width:100%}.footer p{margin:0}.contact-us-btn{background-color:#004eeb;border:2px solid #004eeb;border-radius:8px;color:#fff;cursor:pointer;font-size:.8rem;font-weight:700;padding:.6rem 1.2rem;text-decoration:none;transition:all .3s ease}.contact-us-btn:hover{background-color:#03c;border-color:#03c;box-shadow:0 4px 12px #004eeb4d;transform:translateY(-2px)}.admin-link{border:2px solid #004eeb;border-radius:8px;color:#004eeb;font-size:.8rem;font-weight:700;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease}.admin-link:hover{background-color:#004eeb;color:#fff;transform:translateY(-2px)}.contact-modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.contact-modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.contact-modal-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;padding:25px 30px}.contact-modal-header h2{color:#004eeb;font-size:24px;margin:0}.contact-modal-close{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;font-size:36px;height:36px;justify-content:center;line-height:1;padding:0;transition:all .3s ease;width:36px}.contact-modal-close:hover{color:#333;transform:rotate(90deg)}.contact-form{gap:20px;padding:30px}.contact-form,.contact-form-field{display:flex;flex-direction:column}.contact-form-field{gap:8px}.contact-form-field label{color:#333;font-size:14px;font-weight:600}.contact-form-field input,.contact-form-field textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 16px;transition:all .3s ease}.contact-form-field input:focus,.contact-form-field textarea:focus{border-color:#004eeb;box-shadow:0 0 0 3px #004eeb1a;outline:none}.contact-form-field input.error,.contact-form-field textarea.error{border-color:red}.contact-form-field textarea{min-height:100px;resize:vertical}.contact-error-message{color:red;font-size:13px;margin-top:-5px}.contact-success-message{background-color:#d4edda;border:1px solid #c3e6cb;border-radius:8px;color:#155724;font-weight:600;padding:15px;text-align:center}.contact-error-message-box{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;font-weight:500}.contact-cooldown-message,.contact-error-message-box{font-size:14px;line-height:1.5;padding:15px;text-align:center}.contact-cooldown-message{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;color:#856404;font-weight:600}.contact-submit-btn{background:linear-gradient(135deg,#004eeb,#06f);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:14px 24px;transition:all .3s ease}.contact-submit-btn:hover:not(:disabled){box-shadow:0 6px 20px #004eeb66;transform:translateY(-2px)}.contact-submit-btn:disabled{background:#ccc;cursor:not-allowed;transform:none}@media (max-width:768px){.footer{flex-direction:column;gap:1rem;padding:.9rem 1rem}.admin-link,.contact-us-btn,.footer{font-size:.75rem}.contact-modal-content{margin:10px}.contact-modal-header{padding:20px}.contact-modal-header h2{font-size:20px}.contact-form{padding:20px}}@media (max-width:480px){.footer{font-size:.7rem;gap:.8rem;line-height:1.4;padding:.8rem .5rem}.admin-link,.contact-us-btn{font-size:.7rem;padding:.4rem .8rem}.contact-modal-overlay{padding:10px}.contact-form{gap:15px;padding:15px}.contact-form-field input,.contact-form-field textarea{font-size:14px;padding:10px 14px}.contact-submit-btn{font-size:15px;padding:12px 20px}}.appointmentFormContainer{background-color:#f9f9f9;border-radius:16px;box-shadow:0 0 15px #0000001a;margin:20px auto;max-width:600px;padding:25px}.appointmentFormContainer h2{color:#004eeb;font-size:24px;margin-bottom:8px;text-align:center}.formSubtitle{color:#666;font-size:14px;line-height:1.6;margin-bottom:15px;text-align:center}.appointmentForm{gap:12px}.appointmentForm,.formField{display:flex;flex-direction:column}.formField{gap:5px}.appointmentForm input,.appointmentForm select,.appointmentForm textarea{border:1px solid #ccc;border-radius:8px;font-family:inherit;font-size:16px;padding:10px 14px;transition:border-color .3s ease}.appointmentForm input:focus,.appointmentForm select:focus,.appointmentForm textarea:focus{border-color:#004eeb;outline:none}.appointmentForm input.error,.appointmentForm select.error,.appointmentForm textarea.error{border-color:#dc3545}.appointmentForm textarea{min-height:80px;resize:vertical}.errorMessage{color:#dc3545;font-size:14px;padding-left:4px}.captcha-field{align-items:center;display:flex;flex-direction:column;gap:8px;margin:15px 0}.captcha-field>div{transform-origin:center}.appointmentForm button,.backBtn,.confirmBookingBtn,.newBookingBtn,.paymentBtn,.reopenCalendlyBtn{background-color:#004eeb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:5px;padding:12px;transition:all .3s ease}.appointmentForm button:hover,.confirmBookingBtn:hover,.newBookingBtn:hover,.paymentBtn:hover,.reopenCalendlyBtn:hover{background-color:#003bb3;box-shadow:0 4px 8px #004eeb4d;transform:translateY(-2px)}.appointmentForm button:disabled,.confirmBookingBtn:disabled,.paymentBtn:disabled{background-color:#ccc;cursor:not-allowed;opacity:.7;transform:none}.formNote{border-top:1px solid #e0e0e0;color:#666;font-size:13px;line-height:1.6;margin-top:8px;padding-top:10px;text-align:center}.schedulingInfo{background-color:#fff;border-left:4px solid #004eeb;border-radius:8px;margin:15px 0;padding:18px}.schedulingInfo p{color:#333;line-height:1.6;margin-bottom:10px}.schedulingInfo ol{margin-bottom:10px;margin-left:20px}.schedulingInfo li{color:#555;margin-bottom:5px}.reopenCalendlyBtn{background-color:#28a745}.reopenCalendlyBtn:hover{background-color:#218838}.backBtn{background-color:#6c757d;margin-top:5px}.backBtn:hover:not(:disabled){background-color:#5a6268;transform:translateY(-2px)}.buttonGroup{display:flex;flex-direction:column;gap:10px;margin-top:8px}.paymentSummary{background-color:#fff;border-radius:8px;margin:15px 0;padding:18px}.summaryItem{border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:10px 0}.summaryItem.total{border-bottom:none;border-top:2px solid #004eeb;font-size:18px;font-weight:700;margin-top:8px;padding-top:12px}.summaryItem .label{color:#666;font-weight:500}.summaryItem .value{word-wrap:break-word;color:#333;max-width:60%;text-align:right}.summaryItem.total .value{color:#004eeb;font-size:24px}.paymentNote{background-color:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;font-size:14px;margin:15px 0;padding:12px;text-align:center}.paymentBtn{background-color:#28a745;font-size:18px;padding:14px}.paymentBtn:hover:not(:disabled){background-color:#218838}.successMessage{padding:25px 15px;text-align:center}.successIcon{align-items:center;animation:scaleIn .5s ease-out;background-color:#28a745;border-radius:50%;color:#fff;display:flex;font-size:42px;height:70px;justify-content:center;margin:0 auto 15px;width:70px}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.successMessage h2{color:#28a745;margin-bottom:15px}.successMessage p{color:#666;line-height:1.6;margin-bottom:15px}.confirmationDetails{list-style:none;margin:15px auto;max-width:400px;padding:0;text-align:left}.confirmationDetails li{background-color:#f8f9fa;border-radius:6px;margin-bottom:6px;padding:8px 8px 8px 35px;position:relative}.confirmationDetails li:before{color:#28a745;content:"✓";font-weight:700;left:10px;position:absolute}.newBookingBtn{margin-top:20px}.fileUploadLabel{color:#333;display:block;font-size:15px;font-weight:600;margin-bottom:8px}.fileUploadArea{margin-bottom:8px;position:relative}.fileInput{display:none}.fileInputLabel{align-items:center;background-color:#fafafa;border:2px dashed #ccc;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:20px 15px;transition:all .3s ease}.fileInputLabel:hover{background-color:#f0f7ff;border-color:#004eeb}.fileInputLabel svg{color:#004eeb;margin-bottom:5px}.fileInputLabel>span:first-of-type{color:#004eeb;font-size:15px;font-weight:500}.fileHint{color:#999;font-size:12px}.uploadedFilesList{background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-top:10px;padding:12px}.uploadedFilesTitle{color:#333;font-size:14px;font-weight:600;margin:0 0 8px}.uploadedFileItem{align-items:center;background-color:#fff;border:1px solid #e0e0e0;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:6px;padding:8px 10px;transition:all .2s ease}.uploadedFileItem:last-child{margin-bottom:0}.uploadedFileItem:hover{border-color:#004eeb;box-shadow:0 2px 4px #004eeb1a}.fileInfo{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0}.fileInfo svg{color:#004eeb;flex-shrink:0}.fileName{color:#333;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fileSize{color:#666;flex-shrink:0;font-size:12px}.removeFileBtn{align-items:center;background-color:#f44;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:24px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:24px}.removeFileBtn:hover{background-color:#c00;transform:scale(1.1)}@media (max-width:768px){.appointmentFormContainer{margin:15px 10px;padding:20px 15px}.summaryItem .value{font-size:14px;max-width:50%}.appointmentFormContainer h2{font-size:24px}.appointmentForm input,.appointmentForm textarea{font-size:16px}}@media (max-width:480px){.appointmentFormContainer{border-radius:12px;margin:15px 10px;padding:20px 15px}.appointmentFormContainer h2{font-size:22px;margin-bottom:8px}.formSubtitle{font-size:13px;margin-bottom:20px}.appointmentForm{gap:12px}.appointmentForm input,.appointmentForm textarea{font-size:16px;padding:12px 14px}.appointmentForm button,.backBtn,.confirmBookingBtn,.newBookingBtn,.paymentBtn,.reopenCalendlyBtn{font-size:15px;min-height:48px;padding:14px 12px}.paymentSummary,.schedulingInfo{padding:18px}.summaryItem{align-items:flex-start;flex-direction:column;gap:5px;padding:10px 0}.summaryItem .value{max-width:100%;text-align:left}.summaryItem.total{flex-direction:row;justify-content:space-between}.successIcon{font-size:40px;height:70px;width:70px}.successMessage h2{font-size:22px}.successMessage p{font-size:15px}.fileUploadLabel{font-size:14px}.fileInputLabel{padding:25px 15px}.fileInputLabel>span:first-of-type{font-size:14px}.fileHint{font-size:11px;text-align:center}.uploadedFilesList{padding:12px}.uploadedFilesTitle{font-size:13px}.uploadedFileItem{padding:8px 10px}.fileName{font-size:13px}.fileSize{font-size:11px}.fileInfo{gap:6px}.removeFileBtn{font-size:20px;height:28px;width:28px}.buttonGroup{gap:12px}}.admin-dashboard{background-color:#f5f7fa;min-height:100vh;padding:20px}.dashboard-header{align-items:center;background:linear-gradient(135deg,#004eeb,#06f);border-radius:12px;box-shadow:0 4px 12px #004eeb33;color:#fff;display:flex;justify-content:space-between;margin-bottom:30px;padding:30px 40px}.header-content h1{font-size:32px;margin:0 0 5px}.header-content p{font-size:16px;margin:0;opacity:.9}.back-home-btn{background-color:#fff;border:none;border-radius:8px;color:#004eeb;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .3s ease}.back-home-btn:hover{box-shadow:0 4px 12px #ffffff4d;transform:translateY(-2px)}.header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.logged-in-info{align-items:center;color:#fff;display:flex;font-size:14px;font-weight:500;gap:8px}.role-pill{border-radius:12px;font-size:11px;font-weight:700;letter-spacing:.5px;padding:3px 10px;text-transform:uppercase}.role-admin{background:#ff6b35;color:#fff}.role-doctor{background:#00b894;color:#fff}.role-patient{background:#6c5ce7;color:#fff}.logout-btn{background:#ffffff26;border:1px solid #ffffff80;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.logout-btn:hover{background:#ffffff4d}.dashboard-controls{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:20px;padding:20px}.search-box{flex:1 1;min-width:250px}.search-input{border:2px solid #e0e0e0;border-radius:8px;font-size:15px;padding:12px 16px;transition:all .3s ease;width:100%}.search-input:focus{border-color:#004eeb;box-shadow:0 0 0 3px #004eeb1a;outline:none}.filter-buttons{display:flex;flex-wrap:wrap;gap:10px}.filter-btn{background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .3s ease}.filter-btn:hover{border-color:#004eeb;color:#004eeb}.filter-btn.active{background-color:#004eeb;border-color:#004eeb;color:#fff}.refresh-btn{background-color:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.refresh-btn:hover{background-color:#218838;transform:translateY(-2px)}.refresh-btn.refreshing{background-color:#6c757d;cursor:not-allowed;transform:none}.refresh-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.appointments-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:20px}.appointments-table-wrapper{overflow-x:auto}.appointments-table{border-collapse:collapse;min-width:1000px;width:100%}.appointments-table thead{background-color:#f8f9fa}.appointments-table th{border-bottom:2px solid #e0e0e0;color:#333;font-size:14px;font-weight:600;padding:15px 12px;text-align:left}.appointments-table td{border-bottom:1px solid #f0f0f0;color:#555;font-size:14px;padding:15px 12px}.appointments-table tbody tr:hover{background-color:#f8f9fa}.status-badge{align-items:center;border:2px solid #0000;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;gap:6px;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.status-icon{font-size:14px}.status-draft{background:linear-gradient(135deg,#fff9e6,#ffe066);border-color:#fc0;color:#cc7a00}.status-scheduled{background:linear-gradient(135deg,#e6f3ff,#66c2ff);border-color:#39f;color:#06c}.status-confirmed{background:linear-gradient(135deg,#e6ffe6,#6f6);border-color:#3c3;color:#060}.status-completed{background:linear-gradient(135deg,#f0e6ff,#c9f);border-color:#93f;color:#60c}.status-cancelled{background:linear-gradient(135deg,#ffe6e6,#f66);border-color:#f33;color:#c00}.status-unknown{background:linear-gradient(135deg,#f0f0f0,#ccc);border-color:#999;color:#666}.view-btn{background-color:#004eeb;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .3s ease}.view-btn:hover{background-color:#03c;transform:translateY(-2px)}.error-container,.loading-container,.no-appointments{padding:60px 20px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#004eeb;height:50px;margin:0 auto 20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.retry-btn{border:none;border-radius:8px;font-weight:600;margin-top:20px;padding:12px 24px}.add-diagnosis-btn,.retry-btn{background-color:#004eeb;color:#fff;cursor:pointer}.add-diagnosis-btn{border:none;border-radius:6px;font-size:13px;font-weight:500;padding:8px 16px;transition:all .3s ease}.add-diagnosis-btn:hover:not(:disabled){background-color:#03c;box-shadow:0 4px 8px #004eeb4d;transform:translateY(-2px)}.add-diagnosis-btn:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6;transform:none}.add-diagnosis-btn:active:not(:disabled){transform:translateY(0)}.modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:800px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;padding:25px 30px}.modal-header h2{color:#004eeb;font-size:24px;margin:0}.modal-close-btn{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;font-size:36px;height:36px;justify-content:center;line-height:1;padding:0;transition:all .3s ease;width:36px}.modal-close-btn:hover{color:#333}.modal-body{padding:30px}.detail-section{margin-bottom:30px}.detail-section:last-child{margin-bottom:0}.detail-section h3{border-bottom:2px solid #f0f0f0;color:#004eeb;font-size:18px;margin:0 0 15px;padding-bottom:10px}.detail-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.detail-item{display:flex;flex-direction:column;gap:5px}.detail-item label{color:#666;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-item span{color:#333;font-size:15px}.description-text{background-color:#f8f9fa;border-radius:8px;color:#555;line-height:1.6;margin:0;padding:15px}.calendly-link{color:#004eeb;font-size:13px;word-break:break-all}.attachments-info{background-color:#fff3cd;border-left:4px solid #ffc107;border-radius:8px;padding:20px}.note-text{color:#856404;line-height:1.6;margin:0 0 10px}.implementation-hint{color:#856404;font-size:14px;line-height:1.6;margin:0}.implementation-hint code{background-color:#fff;border-radius:4px;color:#d63384;font-family:monospace;padding:2px 6px}.modal-footer{border-top:2px solid #f0f0f0;display:flex;justify-content:flex-end;padding:20px 30px}.close-modal-btn{background-color:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .3s ease}.close-modal-btn:hover{background-color:#5a6268;transform:translateY(-2px)}@media (max-width:1024px){.dashboard-header{flex-direction:column;gap:15px;text-align:center}.header-content h1{font-size:28px}.dashboard-controls{align-items:stretch;flex-direction:column}.search-box{width:100%}.filter-buttons{justify-content:center}}@media (max-width:768px){.admin-dashboard{padding:10px}.dashboard-header{padding:20px}.header-content h1{font-size:24px}.header-content p{font-size:14px}.detail-grid{grid-template-columns:1fr}.modal-content{margin:10px}.modal-body,.modal-header{padding:20px}.appointments-table{font-size:13px}.appointments-table td,.appointments-table th{padding:10px 8px}}@media (max-width:480px){.dashboard-header{padding:15px}.header-content h1{font-size:20px}.filter-btn{font-size:13px;padding:8px 14px}.modal-header h2{font-size:20px}.status-badge{font-size:11px;padding:4px 10px}}.appointment-thumbnail{border:2px solid #e1e8ed;border-radius:6px;cursor:pointer;height:60px;object-fit:cover;transition:all .3s ease;width:60px}.appointment-thumbnail:hover{border-color:#004eeb;box-shadow:0 4px 12px #004eeb4d;transform:scale(1.1)}.image-link{display:inline-block;text-decoration:none}.no-image{color:#999;font-size:13px;font-style:italic}.attachments-container,.files-grid{margin-top:15px}.files-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.file-item{background:#f8f9fa;border:2px solid #e1e8ed;border-radius:8px;overflow:hidden;transition:all .3s ease}.file-item:hover{border-color:#004eeb;box-shadow:0 6px 20px #0000001a;transform:translateY(-4px)}.file-preview-link{color:inherit;display:block;text-decoration:none}.file-preview-image{display:block;height:150px;object-fit:cover;width:100%}.file-icon{align-items:center;background:linear-gradient(135deg,#f5f7fa,#e1e8ed);display:flex;font-size:48px;height:150px;justify-content:center;width:100%}.file-info{background:#fff;display:flex;flex-direction:column;gap:4px;padding:12px}.file-name{color:#333;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:#666;font-size:12px}.no-attachments{background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;color:#999;font-size:14px;margin-top:15px;padding:20px;text-align:center}@media (max-width:768px){.files-grid{gap:15px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.appointment-thumbnail{height:50px;width:50px}.file-icon,.file-preview-image{height:120px}.file-icon{font-size:36px}}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.login-container:before{animation:pulse 15s ease-in-out infinite;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:200%;position:absolute;right:-50%;top:-50%;width:200%}@keyframes pulse{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-5%,-5%) scale(1.1)}}.login-form{animation:slideIn .5s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;gap:1.5rem;min-width:400px;padding:2.5rem 3rem;position:relative;z-index:1}@keyframes slideIn{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.back-button{background:#ffffffe6;border:none;border-radius:25px;box-shadow:0 4px 15px #0003;color:#667eea;cursor:pointer;font-size:1rem;font-weight:600;left:2rem;padding:.75rem 1.5rem;position:absolute;top:2rem;transition:all .3s ease;z-index:2}.back-button:hover{background:#fff;box-shadow:0 6px 20px #0000004d;transform:translateX(-5px)}.login-header{margin-bottom:1rem;text-align:center}.login-icon{align-items:center;animation:bounce 2s ease-in-out infinite;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 8px 20px #667eea66;display:flex;height:80px;justify-content:center;margin:0 auto 1rem;width:80px}.login-icon svg{stroke-width:2.5;color:#fff;height:45px;width:45px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-form h2{color:#667eea;font-size:2rem;font-weight:700;margin:.5rem 0}.login-subtitle{color:#666;font-size:.95rem;font-weight:500;margin:0}.input-group{align-items:center;display:flex;position:relative}.input-group input{background:#fff;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;padding:.9rem 1rem;transition:all .3s ease;width:100%}.password-input-group{position:relative}.password-input-group input{padding-right:3rem}.password-toggle{align-items:center;background:#0000;border:none;border-radius:8px;color:#667eea;cursor:pointer;display:flex;justify-content:center;padding:.5rem;position:absolute;right:.75rem;transition:all .2s ease}.password-toggle:hover{background:#667eea1a;color:#764ba2}.password-toggle:active{transform:scale(.95)}.input-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none;transform:translateY(-2px)}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:.5rem;padding:1rem 1.5rem;transition:all .3s ease}.login-button:hover:not(:disabled){box-shadow:0 6px 20px #667eea99;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{background:linear-gradient(135deg,#ccc,#999);cursor:not-allowed;opacity:.6}.login-error{animation:shake .5s ease;background:#fee;border-left:4px solid #d32f2f;border-radius:8px;color:#d32f2f;font-size:.95rem;padding:.75rem 1rem;text-align:center}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.login-footer{margin-top:.5rem;min-height:.5rem;text-align:center}
/*# sourceMappingURL=main.18e62439.css.map*/