*{box-sizing:border-box;margin:0;padding:0}html{font-size:20px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;color:#212529;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:1rem;line-height:1.6;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@media (max-width:575px){html{font-size:18px}}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}.hospital-logo-wrapper{align-items:center;background:#fff;border-radius:50%;display:flex;justify-content:center;overflow:hidden;transition:all .3s ease}.hospital-logo-wrapper,.hospital-logo-wrapper:hover{box-shadow:none!important;filter:none!important;text-shadow:none!important}.hospital-logo-wrapper:hover{transform:scale(1.05)}.hospital-logo-img{box-shadow:none!important;display:block;filter:none!important;height:100%;object-fit:contain;text-shadow:none!important;width:100%}.logo-small{height:40px;padding:4px;width:40px}.logo-medium{height:60px;padding:6px;width:60px}.logo-large{height:80px;padding:8px;width:80px}.logo-xlarge{height:120px;padding:12px;width:120px}.hospital-logo-wrapper.logo-square{border-radius:12px}.hospital-logo-wrapper.logo-square.logo-small{border-radius:8px}.hospital-logo-wrapper.logo-square.logo-medium{border-radius:10px}.hospital-logo-wrapper.logo-square.logo-large{border-radius:12px}.hospital-logo-wrapper.logo-square.logo-xlarge{border-radius:16px}.hospital-logo-fallback{box-shadow:none!important;display:block;filter:none!important;height:100%;text-shadow:none!important;width:100%}.navigation{background:linear-gradient(180deg,#1e3a5f,#2c3e50);box-shadow:4px 0 20px #00000026;color:#fff;display:flex;flex-direction:column;height:100vh;left:0;overflow-x:hidden;overflow-y:auto;position:fixed;top:0;transition:width .3s ease;width:260px;z-index:1000}.navigation::-webkit-scrollbar{width:6px}.navigation::-webkit-scrollbar-track{background:#ffffff1a}.navigation::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.navigation::-webkit-scrollbar-thumb:hover{background:#ffffff80}.nav-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#1a252f,#1e3a5f);border-bottom:1px solid #ffffff1a;padding:2rem 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.nav-header-logo-wrapper{align-items:center;display:flex;gap:.75rem;margin-bottom:1rem}.nav-header-logo-wrapper .hospital-logo-wrapper{background:#ffffff26;border:1px solid #fff3}.nav-header-logo-wrapper .hospital-logo-wrapper,.nav-header-logo-wrapper .hospital-logo-wrapper img{box-shadow:none!important;filter:none!important;text-shadow:none!important}.nav-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e0e0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:1.5rem;font-weight:700;letter-spacing:.5px;margin:0}.user-info{border-top:1px solid #ffffff1a;display:flex;flex-direction:column;gap:.25rem;padding-top:.75rem}.user-name{color:#fff;font-size:.9rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{background:#ffffff1a;border-radius:4px;color:#ffffffb3;display:inline-block;font-size:.75rem;padding:.25rem .5rem;text-transform:capitalize;width:-webkit-fit-content;width:fit-content}.nav-menu{list-style:none;margin:0;padding:1rem 0}.nav-menu li{margin:.25rem 0}.nav-link{align-items:center;border-left:3px solid #0000;color:#ffffffd9;display:flex;font-weight:500;padding:.875rem 1.5rem;position:relative;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-link:before{background:linear-gradient(90deg,#3498db33,#0000);bottom:0;content:"";left:0;position:absolute;top:0;transition:width .3s ease;width:0}.nav-link:hover{background-color:#ffffff14;border-left-color:#3498db;color:#fff;transform:translateX(2px)}.nav-link:hover:before{width:100%}.nav-link.active{background:linear-gradient(90deg,#3498db33,#0000);border-left-color:#3498db;box-shadow:inset 0 0 20px #3498db1a;color:#fff;font-weight:600}.nav-link.active:before{width:100%}.nav-icon{align-items:center;display:flex;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));font-size:1.25rem;justify-content:center;margin-right:.875rem;text-align:center;width:24px}.nav-label{font-size:.95rem;letter-spacing:.3px}.nav-footer{background:linear-gradient(180deg,#0000,#1e3a5f 10%);border-top:1px solid #ffffff1a;bottom:0;margin-top:auto;padding:1rem 0;position:-webkit-sticky;position:sticky}.nav-logout{align-items:center;background:none;border:none;border-left:3px solid #0000;color:#ffffffd9;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;letter-spacing:.3px;padding:.875rem 1.5rem;position:relative;text-align:left;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.nav-logout:before{background:linear-gradient(90deg,#dc354533,#0000);bottom:0;content:"";left:0;position:absolute;top:0;transition:width .3s ease;width:0}.nav-logout:hover{background-color:#dc35451a;border-left-color:#dc3545;color:#fff;transform:translateX(2px)}.nav-logout:hover:before{width:100%}.mobile-menu-toggle{background:linear-gradient(135deg,#1e3a5f,#2c3e50);border:none;border-radius:8px;box-shadow:0 4px 12px #0000004d;cursor:pointer;display:none;left:1rem;padding:.75rem;position:fixed;top:1rem;transition:all .3s ease;z-index:2000}.mobile-menu-toggle:hover{box-shadow:0 6px 16px #0006;transform:scale(1.05)}.mobile-menu-toggle:focus{outline:2px solid #3498db;outline-offset:2px}.hamburger{display:flex;flex-direction:column;height:18px;justify-content:space-between;width:24px}.hamburger span{background:#fff;border-radius:2px;display:block;height:3px;transform-origin:center;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.hamburger.active span:first-child{transform:translateY(7.5px) rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.active span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}.mobile-menu-overlay{animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:1500}@media (max-width:991px){.mobile-menu-overlay,.mobile-menu-toggle{display:block}body.menu-open{overflow:hidden}.navigation{box-shadow:4px 0 20px #0000004d;left:-260px;position:fixed;top:0;transition:left .3s cubic-bezier(.4,0,.2,1);width:260px;z-index:1600}.navigation.mobile-open{left:0}.nav-header{padding:1.5rem 1.25rem}.nav-header h2{font-size:1.25rem}.nav-link{padding:.875rem 1.25rem}.nav-label{font-size:.9rem}}@media (max-width:767px){.mobile-menu-toggle{left:.75rem;padding:.625rem;top:.75rem}.hamburger{height:16px;width:22px}.navigation{left:-280px;width:280px}.nav-header{padding:1.25rem 1rem}.nav-header h2{font-size:1.125rem}.nav-link{padding:.75rem 1rem}.nav-icon{font-size:1.125rem;margin-right:.75rem}.nav-label{font-size:.875rem}}@media (max-width:575px){.mobile-menu-toggle{left:.5rem;padding:.5rem;top:.5rem}.hamburger{height:15px;width:20px}.hamburger.active span:first-child{transform:translateY(6px) rotate(45deg)}.hamburger.active span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.navigation{left:-100%;max-width:300px;width:100%}.nav-header{padding:1rem .875rem}.nav-header h2{font-size:1rem}.nav-link{padding:.75rem .875rem}.nav-icon{font-size:1rem;margin-right:.625rem;width:20px}.nav-label{font-size:.85rem}}@media (max-width:319px){.mobile-menu-toggle{left:.375rem;padding:.5rem;top:.375rem}.navigation{width:100%}.nav-header{padding:.875rem .75rem}.nav-header h2{font-size:.95rem}}.whatsapp-button{align-items:center;background:#25d366;border:none;border-radius:50%;bottom:2rem;box-shadow:0 4px 20px #25d36666;cursor:pointer;display:flex;display:flex!important;height:64px;justify-content:center;padding:0;position:fixed;right:2rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:64px;z-index:9999}.whatsapp-button,.whatsapp-button.visible{opacity:1;pointer-events:auto;transform:scale(1) translateY(0)}.whatsapp-button:hover{background:#128c7e;box-shadow:0 6px 30px #25d36699;transform:scale(1.1)}.whatsapp-button:active{transform:scale(.95)}.whatsapp-icon{display:block;height:100%;width:100%}.whatsapp-tooltip{animation:fadeInTooltip .3s ease;background:#1e3a5f;border-radius:8px;box-shadow:0 4px 12px #00000026;color:#fff;font-size:.875rem;font-weight:500;padding:.75rem 1rem;right:70px;white-space:nowrap}.whatsapp-tooltip,.whatsapp-tooltip:after{position:absolute;top:50%;transform:translateY(-50%)}.whatsapp-tooltip:after{border:8px solid #0000;border-left-color:#1e3a5f;content:"";left:100%}@keyframes fadeInTooltip{0%{opacity:0;transform:translateY(-50%) translateX(-10px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}.whatsapp-button.visible:before{animation:pulse 2s infinite;background:#25d36666;border-radius:50%;content:"";height:100%;position:absolute;width:100%}@media (max-width:767px){.whatsapp-button{bottom:1.5rem;height:56px;right:1.5rem;width:56px}.whatsapp-icon{height:28px;width:28px}.whatsapp-tooltip{font-size:.8rem;padding:.625rem .875rem;right:65px}}@media (max-width:575px){.whatsapp-button{bottom:1rem;height:52px;right:1rem;width:52px}.whatsapp-icon{height:26px;width:26px}.whatsapp-tooltip{font-size:.75rem;padding:.5rem .75rem;right:60px}}@media (max-width:991px){.whatsapp-button{z-index:9998}}.App{background-color:#f5f7fa;display:flex;min-height:100vh}.main-content{background:linear-gradient(135deg,#f5f7fa,#e9ecef);flex:1 1;margin-left:260px;min-height:100vh;padding:0;transition:margin-left .3s ease}.main-content.login-layout{background:#0000;margin-left:0;padding:0}@media (max-width:991px){.main-content{margin-left:0;padding-top:4rem}}@media (max-width:767px){.main-content{padding-top:3.5rem}}@media (max-width:575px){.main-content{padding-top:3rem}}.btn:active{box-shadow:0 1px 2px #0000001a;transform:translateY(1px)}.btn-primary{border:none}.page-container{margin:0 auto;max-width:1600px;padding:2rem}body,html{overflow-x:hidden}.table-container table{border-collapse:collapse;width:100%}.table-container thead{background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.table-container th{border-bottom:2px solid #dee2e6;color:#495057;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1.25rem 1rem;text-align:left;text-transform:uppercase}.table-container td{border-bottom:1px solid #f1f3f5;color:#495057;padding:1.25rem 1rem}.table-container tbody tr{transition:all .2s ease}.table-container tbody tr:hover{background-color:#f8f9fa;box-shadow:0 2px 4px #0000000d;transform:scale(1.01)}.table-container tbody tr:last-child td{border-bottom:none}.filter-group select,.filter-input{background:#fff;border:2px solid #e9ecef;border-radius:8px;font-size:.95rem;padding:.75rem;transition:all .3s ease}.filter-group select:focus,.filter-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.change-type-badge,.gender-badge,.status-badge{border-radius:20px;box-shadow:0 2px 4px #0000001a;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.3px;padding:.375rem .875rem;text-transform:capitalize}.form-group input,.form-group select,.form-group textarea{border:2px solid #e9ecef;padding:.875rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}@media (min-width:1920px){.page-container{max-width:1800px}}@media (max-width:1199px){.page-container{padding:1.5rem}.page-header{padding:1.25rem 1.5rem}.page-header h1{font-size:1.75rem}}@media (max-width:991px){.page-container,.page-header{padding:1.25rem}.page-header{align-items:flex-start;flex-direction:column;gap:1rem}.page-header h1{font-size:1.5rem;width:100%}.page-header .btn{margin-top:.5rem;width:100%}.filters-section{align-items:stretch;flex-direction:column}.filter-group,.filter-group select,.filter-input{width:100%}.form-row{grid-template-columns:1fr}.modal-content{margin:1rem;max-width:90%}.modal-header{padding:1.5rem}.modal-header h2{font-size:1.5rem}.modal-content form{padding:1.5rem}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}.table-container{-webkit-overflow-scrolling:touch;border-radius:0;margin-left:-1.25rem;margin-right:-1.25rem;overflow-x:auto;position:relative;scrollbar-color:#667eea #f1f1f1;scrollbar-width:thin;width:calc(100% + 2.5rem)}.table-container::-webkit-scrollbar{height:8px}.table-container::-webkit-scrollbar-track{background:#f1f1f1}.table-container::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.table-container::-webkit-scrollbar-thumb:hover{background:#5568d3}.table-container table{min-width:800px}.table-container td,.table-container th{font-size:.875rem;padding:.875rem .75rem}.table-container th{white-space:nowrap}}@media (max-width:767px){.page-container,.page-header{padding:1rem}.page-header h1{font-size:1.375rem;width:100%}.page-header .btn{margin-top:.75rem;width:100%}.btn{font-size:.9rem;padding:.625rem 1.25rem}.form-actions .btn,.modal-actions .btn{width:100%}.btn-sm{font-size:.8rem;padding:.5rem 1rem}.filters-section{padding:1rem}.filter-group label{font-size:.8rem}.filter-group select,.filter-input{font-size:.9rem;padding:.625rem}.alert{align-items:flex-start;flex-direction:column;font-size:.9rem;padding:.875rem 1rem}.loading,.no-data{font-size:1rem;padding:2rem 1rem}.change-type-badge,.gender-badge,.status-badge{font-size:.7rem;padding:.25rem .625rem}.modal-overlay{padding:.5rem}.modal-content{border-radius:12px;max-height:95vh;max-width:100%}.modal-header{flex-wrap:wrap;padding:1.25rem}.modal-header h2{flex:1 1;font-size:1.25rem;min-width:0}.modal-close{font-size:1.5rem;height:32px;width:32px}.modal-content form{padding:1.25rem}.form-group{margin-bottom:1.25rem}.form-group label{font-size:.875rem}.form-group input,.form-group select,.form-group textarea{font-size:.95rem;padding:.75rem}.form-hint{font-size:.8rem}.modal-actions{margin-top:1.5rem;padding-top:1.5rem}.table-container{border-radius:8px;margin-left:-.75rem;margin-right:-.75rem;width:calc(100% + 1.5rem)}.table-container table{min-width:600px}.table-container td,.table-container th{font-size:.8rem;padding:.75rem .5rem}.table-container th{font-size:.75rem;white-space:nowrap}}@media (max-width:575px){.page-container{padding:.75rem}.page-header{border-radius:8px;padding:.875rem}.page-header h1{font-size:1.25rem;width:100%}.page-header .btn{margin-top:.75rem}.btn{font-size:.875rem;padding:.625rem 1rem}.btn-sm{font-size:.75rem;padding:.5rem .875rem}.filters-section{border-radius:8px;padding:.875rem}.filter-group{gap:.375rem}.filter-group label{font-size:.75rem}.filter-group select,.filter-input{font-size:.875rem;padding:.625rem}.alert{border-radius:6px;font-size:.875rem;padding:.75rem}.loading,.no-data{border-radius:8px;font-size:.95rem;padding:1.5rem .75rem}.change-type-badge,.gender-badge,.status-badge{font-size:.65rem;padding:.25rem .5rem}.modal-overlay{padding:0}.modal-content{border-radius:0;height:100vh;max-height:100vh}.modal-header{border-radius:0;padding:1rem}.modal-header h2{font-size:1.125rem}.modal-close{height:36px;width:36px}.modal-content form{padding:1rem}.form-group{margin-bottom:1rem}.form-group label{font-size:.8rem;margin-bottom:.375rem}.form-group input,.form-group select,.form-group textarea{border-radius:6px;font-size:.9rem;padding:.625rem}.form-group textarea{min-height:80px}.form-hint{font-size:.75rem;margin-top:.375rem}.modal-actions{gap:.75rem;margin-top:1rem;padding-top:1rem}.table-container{border-radius:6px;margin-top:1rem}.table-container table{min-width:600px}.table-container th{font-size:.7rem;padding:.625rem .5rem}.table-container td{font-size:.75rem;padding:.625rem .5rem}.action-buttons{flex-direction:column;gap:.375rem;width:100%}.action-buttons .btn{justify-content:center;width:100%}.page-header .btn{margin-top:.5rem;width:100%}}@media (max-width:319px){.page-container{padding:.5rem}.page-header{padding:.75rem}.page-header h1{font-size:1.125rem;width:100%}.page-header .btn{margin-top:.5rem;width:100%}.btn{font-size:.8rem;padding:.5rem .875rem}.modal-header h2{font-size:1rem}.table-container{border-radius:0;margin-left:-.5rem;margin-right:-.5rem}}@media print{.btn,.filters-section,.modal-overlay,.navigation{display:none!important}.main-content{margin-left:0!important}.page-container{max-width:100%;padding:0}.table-container{border:1px solid #ddd;box-shadow:none}}@media (max-width:991px) and (orientation:landscape){.modal-content{max-height:95vh}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.table-container td,.table-container th{border-width:.5px}}@media (hover:none) and (pointer:coarse){.btn{min-width:44px}.btn,.nav-link{min-height:44px}.mobile-menu-toggle,.modal-close{min-height:44px;min-width:44px}}iframe,img,video{height:auto;max-width:100%}@media (max-width:575px){body{-webkit-text-size-adjust:100%}body,input,select,textarea{font-size:16px}}.home-page{background:linear-gradient(135deg,#f5f7fa,#e9ecef);min-height:100vh;position:relative;scroll-behavior:smooth;width:100%}.scroll-to-top{align-items:center;animation:fadeInUp .5s ease;background:linear-gradient(135deg,#1e3a5f,#2c3e50);border:none;border-radius:50%;bottom:2rem;box-shadow:0 4px 12px #1e3a5f40;color:#fff;cursor:pointer;display:flex;height:50px;justify-content:center;position:fixed;right:2rem;transition:all .3s ease;width:50px;z-index:1000}.scroll-to-top:hover{box-shadow:0 6px 20px #1e3a5f59;transform:translateY(-5px) scale(1.1)}.scroll-arrow{animation:bounce 2s infinite;font-size:1.5rem;font-weight:700}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.container{margin:0 auto;max-width:1200px;padding:0 2rem}.hero-section{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2c3e50);box-shadow:0 4px 20px #00000026;color:#fff;display:flex;min-height:100vh;overflow:hidden;padding:6rem 2rem;position:relative;text-align:center}.hero-section:before{animation:patternMove 20s linear infinite;background:url('data:image/svg+xml,<svg width="60" height="60" viewBox="0 0 60 60" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><g fill="%23ffffff" fill-opacity="0.05"><circle cx="30" cy="30" r="2"/></g></svg>');bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}@keyframes patternMove{0%{background-position:0 0}to{background-position:60px 60px}}.hero-background-animation{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.hero-background-animation:after,.hero-background-animation:before{animation:float 6s ease-in-out infinite;background:#ffffff1a;border-radius:50%;content:"";position:absolute}.hero-background-animation:before{animation-delay:0s;height:300px;left:10%;top:10%;width:300px}.hero-background-animation:after{animation-delay:3s;bottom:10%;height:200px;right:10%;width:200px}.hero-content{margin:0 auto;max-width:900px;position:relative;z-index:1}.hero-logo{display:flex;justify-content:center;margin-bottom:2rem;opacity:1}.hero-logo .hospital-logo-wrapper{border:none;height:clamp(160px,22vw,280px);padding:clamp(6px,1.2vw,12px);width:clamp(160px,22vw,280px)}.hero-logo .hospital-logo-wrapper,.hero-logo .hospital-logo-wrapper img{box-shadow:none!important;filter:none!important;text-shadow:none!important}.hero-title{font-size:4rem;font-weight:700;letter-spacing:-1px;line-height:1.2;margin:0 0 1rem;opacity:1}.hero-subtitle{font-size:1.75rem;font-weight:500;margin:0 0 1.5rem;opacity:.95}.hero-description{font-size:1.35rem;line-height:1.8;margin:0 auto 2.5rem;max-width:700px;opacity:.9}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;opacity:1}.btn-hero{align-items:center;border-radius:8px;box-shadow:0 4px 12px #0003;display:inline-flex;font-size:1.25rem;font-weight:600;gap:.5rem;overflow:hidden;padding:1rem 2.5rem;position:relative;text-decoration:none;transition:all .3s ease}.btn-hero:before{background:#fff3;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.btn-hero:hover:before{height:300px;width:300px}.btn-hero:hover{box-shadow:0 8px 20px #0000004d;transform:translateY(-3px) scale(1.05)}.btn-arrow{display:inline-block;transition:transform .3s ease}.btn-hero:hover .btn-arrow{transform:translateX(5px)}.btn-primary.btn-hero{background:#fff;color:#1e3a5f}.btn-primary.btn-hero:hover{background:#f8f9fa;color:#2c3e50}.btn-secondary.btn-hero{background:#fff3;border:2px solid #fff;color:#fff}.btn-secondary.btn-hero:hover{background:#ffffff4d}.animate-fade-in-up{animation:fadeInUp .8s ease forwards;opacity:1}.animate-slide-up{animation:slideUp .8s ease forwards;opacity:1}.animate-scale-in{animation:scaleIn .6s ease forwards;opacity:1}.delay-1{animation-delay:.2s}.delay-2{animation-delay:.4s}.delay-3{animation-delay:.6s}.delay-4{animation-delay:.8s}@keyframes scaleIn{0%{opacity:.5;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.section-visible{opacity:1}.about-section,.contact-info-section,.services-section{opacity:1;padding:5rem 0;transition:opacity .6s ease}.section-header{margin-bottom:3rem;text-align:center}.section-title{font-size:3rem;letter-spacing:-.5px;opacity:1}.section-description{color:#6b7280;font-size:1.35rem;line-height:1.7;margin:0 auto;max-width:700px;opacity:1}.about-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:3rem}.about-card{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;overflow:hidden;padding:3rem;position:relative;text-align:center;transition:all .4s cubic-bezier(.4,0,.2,1)}.about-card:before{background:linear-gradient(90deg,#0000,#667eea1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.about-card:hover:before{left:100%}.about-card:hover{box-shadow:0 12px 32px #667eea33;transform:translateY(-10px) scale(1.02)}.about-icon-wrapper{display:inline-block;margin-bottom:1.5rem;position:relative}.about-icon{font-size:3.5rem;position:relative;transition:transform .3s ease;z-index:2}.about-card:hover .about-icon{transform:scale(1.2) rotate(5deg)}.icon-ripple{background:#667eea33;border-radius:50%;height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.about-card:hover .icon-ripple{height:100px;width:100px}.about-card-title{color:#1e3a5f;font-size:1.85rem;font-weight:700;margin:0 0 1rem}.about-card-text{color:#6b7280;font-size:1.2rem;line-height:1.7;margin:0}.services-section{background:#fff}.services-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:3rem}.service-card{background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #e9ecef;border-radius:12px;cursor:pointer;overflow:hidden;padding:2.5rem;position:relative;text-align:center;transition:all .4s cubic-bezier(.4,0,.2,1)}.service-card:after{background:linear-gradient(135deg,#667eea0d,#764ba20d);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .4s ease}.service-card:hover:after{opacity:1}.service-card:hover{border-color:#1e3a5f;box-shadow:0 12px 32px #1e3a5f40;transform:translateY(-10px) scale(1.03)}.service-icon-wrapper{margin-bottom:1rem}.service-icon,.service-icon-wrapper{display:inline-block;position:relative}.service-icon{font-size:3rem;transition:transform .4s ease;z-index:2}.service-card:hover .service-icon{transform:scale(1.3) rotate(10deg)}.service-icon-bg{background:linear-gradient(135deg,#1e3a5f1a,#2c3e501a);border-radius:50%;height:80px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%) scale(0);transition:transform .4s ease;width:80px;z-index:1}.service-card:hover .service-icon-bg{transform:translate(-50%,-50%) scale(1)}.service-hover-effect{background:linear-gradient(90deg,#1e3a5f,#2c3e50);bottom:0;height:4px;left:0;position:absolute;transition:width .4s ease;width:0}.service-card:hover .service-hover-effect{width:100%}.service-title{color:#1e3a5f;font-size:1.6rem;font-weight:700;margin:0 0 .75rem}.service-description{color:#6b7280;font-size:1.15rem;line-height:1.6;margin:0}.contact-info-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:3rem}.contact-info-card{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;overflow:hidden;padding:3rem;position:relative;text-align:center;transition:all .4s cubic-bezier(.4,0,.2,1)}.contact-info-card:before{background:radial-gradient(circle,#667eea1a 0,#0000 70%);content:"";height:200%;left:-50%;opacity:0;position:absolute;top:-50%;transition:opacity .4s ease;width:200%}.contact-info-card:hover:before{opacity:1}.contact-info-card:hover{box-shadow:0 12px 32px #667eea33;transform:translateY(-10px) scale(1.05)}.contact-info-icon-wrapper{display:inline-block;margin-bottom:1rem;position:relative}.contact-info-icon{font-size:3rem;position:relative;transition:transform .3s ease;z-index:2}.contact-info-card:hover .contact-info-icon{transform:scale(1.2) rotate(-5deg)}.icon-pulse{animation:pulse 2s infinite;border:2px solid #667eea4d;border-radius:50%;height:60px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:60px}.contact-info-title{color:#1e3a5f;font-size:1.6rem;font-weight:700;margin:0 0 .75rem}.contact-info-value{color:#1e3a5f;font-size:1.35rem;font-weight:600;margin:0 0 .5rem}.contact-info-label{color:#6b7280;font-size:1.05rem;margin:0}.contact-cta{margin-top:3rem;text-align:center}.btn-large{align-items:center;display:inline-flex;font-size:1.25rem;gap:.5rem;overflow:hidden;padding:1.125rem 2.5rem;position:relative}.btn-large .btn-arrow{transition:transform .3s ease}.btn-large:hover .btn-arrow{transform:translateX(5px)}.cta-section{background:linear-gradient(135deg,#1e3a5f,#2c3e50);box-shadow:0 4px 20px #00000026;color:#fff;overflow:hidden;padding:5rem 2rem;position:relative;text-align:center}.cta-background-animation{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.cta-background-animation:after,.cta-background-animation:before{animation:float 8s ease-in-out infinite;background:#ffffff1a;border-radius:50%;content:"";height:400px;position:absolute;width:400px}.cta-background-animation:before{animation-delay:0s;left:-100px;top:-100px}.cta-background-animation:after{animation-delay:4s;bottom:-100px;right:-100px}.cta-content{margin:0 auto;max-width:700px}.cta-title{font-size:3rem;font-weight:700;letter-spacing:-.5px;margin:0 0 1rem}.cta-description{font-size:1.35rem;line-height:1.7;margin:0 0 2rem;opacity:.95}.cta-section .btn-primary{background:#fff;color:#1e3a5f}.cta-section .btn-primary:hover{background:#f8f9fa;color:#2c3e50}@media (max-width:991px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.25rem}.section-title{font-size:2rem}.about-grid,.contact-info-grid,.services-grid{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media (max-width:767px){.scroll-to-top{bottom:1.5rem;height:45px;right:1.5rem;width:45px}.scroll-arrow{font-size:1.25rem}.hero-section{min-height:auto;padding:4rem 1.5rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.125rem}.hero-description{font-size:1rem}.hero-actions{align-items:stretch;flex-direction:column}.btn-hero{justify-content:center;width:100%}.container{padding:0 1.5rem}.about-section,.contact-info-section,.cta-section,.services-section{padding:3rem 0}.section-title{font-size:1.75rem}.section-description{font-size:1rem}.about-card,.contact-info-card{padding:2rem}.service-card{padding:1.5rem}.cta-title{font-size:2rem}.cta-description{font-size:1rem}}@media (max-width:575px){.scroll-to-top{bottom:1rem;height:40px;right:1rem;width:40px}.scroll-arrow{font-size:1rem}.hero-section{padding:3rem 1rem}.hero-title{font-size:1.75rem}.hero-subtitle{font-size:1rem}.container{padding:0 1rem}.about-section,.contact-info-section,.cta-section,.services-section{padding:2.5rem 0}.section-title{font-size:1.5rem}.about-grid,.contact-info-grid,.services-grid{grid-template-columns:1fr}.about-card,.contact-info-card,.service-card{padding:1.5rem}.cta-title{font-size:1.75rem}}.login-page{align-items:center;background:radial-gradient(1200px 600px at 20% 10%,#1e3a5f1a 0,#0000 60%),radial-gradient(1000px 600px at 90% 90%,#10b98114 0,#0000 55%),#f8fafc;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:clamp(1rem,3vw,3rem);position:relative;width:100%}.login-container{animation:fadeInScale .6s ease-out;background:#fff;border-radius:22px;box-shadow:0 20px 70px #0206171f;display:grid;grid-template-columns:1fr 1fr;max-width:1100px;min-height:min(680px,calc(100vh - clamp(1rem, 3vw, 3rem)*2));overflow:hidden;width:100%}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.login-branding{background:linear-gradient(135deg,#1e3a5f,#2c3e50);box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;gap:1.5rem;justify-content:flex-start;overflow:hidden;padding:clamp(1.75rem,3vw,3rem);position:relative}.login-branding:before{background:url('data:image/svg+xml,<svg width="60" height="60" viewBox="0 0 60 60" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><g fill="%23ffffff" fill-opacity="0.05"><circle cx="30" cy="30" r="2"/></g></svg>');bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.back-to-home{align-items:center;color:#ffffffe6;display:inline-flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.25rem 0;position:relative;text-decoration:none;transition:all .3s ease;z-index:1}.back-to-home:hover{color:#fff;transform:translateX(-3px)}.back-to-home svg{transition:transform .3s ease}.back-to-home:hover svg{transform:translateX(-3px)}.branding-content{color:#fff;display:flex;flex:1 1;flex-direction:column;justify-content:center;position:relative;z-index:1}.hospital-logo{margin-bottom:1.5rem}.logo-icon{align-items:center;background:#fff3;border:2px solid #ffffff4d;border-radius:20px;box-shadow:0 8px 32px #0000001a;display:flex;font-size:2.5rem;height:80px;justify-content:center;width:80px}.hospital-logo .hospital-logo-wrapper,.logo-icon{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hospital-logo .hospital-logo-wrapper{background:#ffffff29;border:1px solid #ffffff38;height:clamp(120px,14vw,180px);padding:clamp(8px,1vw,14px);width:clamp(120px,14vw,180px)}.hospital-name{font-size:clamp(1.6rem,2.2vw,2.2rem);letter-spacing:-.5px;line-height:1.2;margin:0 0 .75rem}.hospital-tagline{font-size:1.05rem;font-weight:400;margin:0 0 2rem;opacity:.95}.branding-features{display:flex;flex-direction:column;gap:1rem}.feature-item{font-size:.95rem;gap:.75rem;opacity:.9}.feature-icon,.feature-item{align-items:center;display:flex}.feature-icon{background:#fff3;border-radius:50%;flex-shrink:0;font-size:.75rem;font-weight:700;height:24px;justify-content:center;width:24px}.login-form-section{align-items:center;background:linear-gradient(180deg,#fff,#f8fafc);display:flex;justify-content:center;padding:clamp(1.75rem,3vw,3rem)}.login-card{max-width:420px;width:100%}.login-header{margin-bottom:2rem}.login-header h2{color:#1e293b;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0 0 .5rem}.login-header p{color:#64748b;font-size:.95rem;margin:0}.login-error{align-items:center;animation:shake .5s ease-in-out;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#dc2626;display:flex;font-size:.9rem;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.login-error svg{color:#dc2626;flex-shrink:0}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{gap:.5rem}.form-group label{color:#374151;font-size:.875rem}.input-icon{color:#9ca3af}.form-group input{background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:#1f2937;font-family:inherit;font-size:.95rem;padding:.875rem 1rem .875rem 3rem;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#1e3a5f;box-shadow:0 0 0 4px #1e3a5f1a;outline:none}.form-group input:disabled{background:#f9fafb;cursor:not-allowed;opacity:.6}.form-group input::placeholder{color:#9ca3af}.password-toggle{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;justify-content:center;padding:.25rem;position:absolute;right:1rem;transition:color .3s ease;z-index:1}.password-toggle:hover{color:#1e3a5f}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.form-options{font-size:.875rem;justify-content:space-between}.form-options,.remember-me{align-items:center;display:flex}.remember-me{color:#6b7280;cursor:pointer;gap:.5rem;-webkit-user-select:none;user-select:none}.remember-me input[type=checkbox]{accent-color:#1e3a5f;border-radius:4px;cursor:pointer;height:18px;width:18px}.remember-me input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.forgot-password{color:#1e3a5f;font-weight:500;text-decoration:none;transition:color .3s ease}.forgot-password:hover{color:#2c3e50;text-decoration:underline}.btn-login{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2c3e50);border:none;border-radius:12px;box-shadow:0 4px 12px #1e3a5f40;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:.5rem;padding:.875rem 1.5rem;transition:all .3s ease;width:100%}.btn-login:hover:not(:disabled){box-shadow:0 6px 20px #1e3a5f59;transform:translateY(-2px)}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{cursor:not-allowed;opacity:.7;transform:none}.btn-login svg{transition:transform .3s ease}.btn-login:hover:not(:disabled) svg{transform:translateX(3px)}.login-footer{border-top:1px solid #e5e7eb;margin-top:2rem;padding-top:1.5rem;text-align:center}.login-footer p{color:#6b7280;font-size:.875rem;margin:0}.login-footer a{color:#1e3a5f;font-weight:500;text-decoration:none;transition:color .3s ease}.login-footer a:hover{color:#2c3e50;text-decoration:underline}@media (max-width:991px){.login-container{grid-template-columns:1fr;max-width:500px}.login-branding{min-height:300px;padding:2rem}.hospital-name{font-size:1.75rem}.hospital-tagline{font-size:1rem;margin-bottom:2rem}.branding-features{gap:.75rem}.login-form-section{padding:2rem}}@media (max-width:768px){.login-page{padding:1rem}.login-container{border-radius:16px;min-height:auto}.login-branding{min-height:250px;padding:1.5rem}.hospital-name{font-size:1.5rem}.logo-icon{font-size:2rem;height:60px;width:60px}.login-form-section{padding:1.5rem}.login-header h2{font-size:1.75rem}}@media (max-width:480px){.login-page{padding:.5rem}.login-container{border-radius:12px}.login-branding{min-height:200px;padding:1.25rem}.hospital-name{font-size:1.25rem}.hospital-tagline{font-size:.9rem;margin-bottom:1.5rem}.branding-features{gap:.5rem}.feature-item{font-size:.85rem}.login-form-section{padding:1.25rem}.login-header h2{font-size:1.5rem}.form-options{align-items:flex-start;flex-direction:column;gap:.75rem}.back-to-home{font-size:.85rem}}.alert-error{position:relative;z-index:10}.alert-error,.alert-warning{align-items:flex-start;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;font-weight:500;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.5rem}.alert-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border-left:4px solid #f59e0b;color:#92400e}.alert-validation{background:linear-gradient(135deg,#fff5f5,#ffe0e0)}.error-icon{flex-shrink:0;font-size:1.25rem;margin-top:.125rem}.error-content{flex:1 1}.error-content strong{display:block;font-size:1rem;margin-bottom:.5rem}.error-list{list-style-type:disc;margin:.75rem 0 0;padding-left:1.5rem}.error-list li{line-height:1.5;margin-bottom:.5rem}.error-list li:last-child{margin-bottom:0}.dashboard-page{min-height:100vh;padding:2rem;width:100%}.logo-icon{filter:drop-shadow(0 4px 8px rgba(0,0,0,.2));font-size:4rem}.stat-card-indigo{border-left-color:#6366f1}.stat-card-indigo:hover{background:linear-gradient(135deg,#eef2ff,#e0e7ff)}.appointment-doctor{color:#6b7280;font-size:.95rem;margin:0 0 1rem}.department-name{color:#9ca3af;font-size:.875rem}.appointment-details{gap:2rem}@media (max-width:991px){.dashboard-page{padding:1.25rem}.hospital-header{padding:1.5rem}.hospital-name{font-size:2rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:767px){.dashboard-page{padding:1rem}.hospital-header{flex-direction:column;padding:1.25rem;text-align:center}.hospital-name{font-size:1.75rem}.hospital-subtitle{font-size:1rem}.logo-icon{font-size:3rem}.stats-grid{gap:1rem;grid-template-columns:1fr}.stat-card{padding:1.25rem}.stat-icon{font-size:2rem;height:50px;width:50px}.stat-value{font-size:1.75rem}.stat-title{font-size:.85rem}.dashboard-section{padding:1.5rem}.section-header{align-items:flex-start;flex-direction:column;gap:.75rem}.section-header h2{font-size:1.25rem}.appointment-card{align-items:flex-start;flex-direction:column;gap:1rem;padding:1.25rem}.appointment-main h3{font-size:1rem}.appointment-details{flex-direction:column;gap:.75rem;width:100%}.appointment-link{text-align:center;width:100%}.quick-actions{grid-template-columns:1fr}.quick-action-card{padding:1.5rem 1rem}.quick-action-icon{font-size:2rem}}@media (max-width:575px){.dashboard-page{padding:.75rem}.hospital-header{border-radius:12px;padding:1rem}.hospital-name{font-size:1.5rem}.hospital-subtitle{font-size:.9rem}.logo-icon{font-size:2.5rem}.stats-grid{gap:.75rem}.stat-card{padding:1rem}.stat-icon{font-size:1.75rem;height:45px;width:45px}.stat-value{font-size:1.5rem}.stat-title{font-size:.8rem}.dashboard-section{border-radius:10px;padding:1rem}.section-header{padding-bottom:.75rem}.section-header h2{font-size:1.125rem}.appointment-card{padding:1rem}.appointment-main h3{font-size:.95rem}.appointment-doctor{font-size:.875rem}.detail-item{flex-wrap:wrap}.detail-label,.detail-value{font-size:.8rem}.quick-action-card{padding:1.25rem .875rem}.quick-action-icon{font-size:1.75rem;margin-bottom:.5rem}.quick-action-text{font-size:.875rem}}.doctor-dashboard-page{min-height:100vh;padding:2rem;width:100%}.btn-schedule{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2c3e50);border:none;border-radius:8px;box-shadow:0 2px 8px #1e3a5f40;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.875rem 1.75rem;transition:all .3s ease}.btn-schedule:hover{box-shadow:0 4px 12px #1e3a5f59;transform:translateY(-2px)}.btn-schedule .btn-icon{height:20px;width:20px}.hospital-logo .hospital-logo-wrapper,.hospital-logo .hospital-logo-wrapper img{box-shadow:none!important;filter:none!important;text-shadow:none!important}.stat-card-teal{border-left-color:#14b8a6}.stat-card-teal:hover{background:linear-gradient(135deg,#f0fdfa,#ccfbf1)}.stat-icon{border-radius:10px;height:48px;width:48px}.stat-card-blue .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.stat-card-green .stat-icon{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.stat-card-purple .stat-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.stat-card-orange .stat-icon{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.stat-card-teal .stat-icon{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff}.stat-icon svg{height:24px;width:24px}.stat-value{line-height:1}.stat-title{color:#64748b;font-size:.875rem}.stat-arrow{color:#cbd5e1}.stat-card:hover .stat-arrow{color:#1e3a5f;transform:translateX(4px)}.dashboard-section{border-radius:16px}.view-all-link{align-items:center;color:#1e3a5f;display:flex;font-weight:500;gap:.25rem}.view-all-link:hover{color:#2c3e50;transform:translateX(2px)}.schedule-card{align-items:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:2px solid #e2e8f0;border-radius:12px;justify-content:space-between}.schedule-card:hover{border-color:#1e3a5f;box-shadow:0 4px 12px #1e3a5f1a}.schedule-info{flex:1 1}.schedule-day{color:#1e3a5f;font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.schedule-time{align-items:center;color:#64748b;font-size:1rem;margin-bottom:.5rem}.schedule-icon{color:#1e3a5f;height:18px;width:18px}.schedule-patients{color:#64748b;font-size:.875rem}.schedule-link{background:#fff;border:2px solid #1e3a5f;border-radius:8px;color:#1e3a5f;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.schedule-link:hover{background:#1e3a5f;color:#fff;transform:translateX(2px)}.appointment-card{align-items:center;border-left:4px solid #667eea}.appointment-date{color:#6b7280;font-size:.95rem;margin:0 0 1rem}.appointment-details{flex-wrap:wrap;gap:1rem}.detail-item{align-items:center}.detail-label{color:#64748b}.detail-value{font-weight:500}.appointment-link{color:#667eea}.appointment-link:hover{background:#667eea}.no-data-card{align-items:center;display:flex;flex-direction:column;gap:1rem}.no-data-icon{color:#adb5bd;height:48px;width:48px}.no-data-card p{color:#6b7280;font-size:1rem;margin:0}.alert-success{border-left:4px solid #10b981}.loading{font-size:1.125rem}.modal-overlay{background:#00000080}.schedule-modal{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{border-bottom:2px solid #e2e8f0;padding:1.5rem 2rem}.modal-close{border-radius:6px;height:32px;transition:all .3s ease;width:32px}.modal-close:hover{background:#f1f5f9}.form-group label{color:#1e3a5f;font-size:.95rem}.form-group input,.form-group select,.form-group textarea{border-radius:8px;font-size:.95rem;padding:.75rem 1rem}.radio-group{gap:1.5rem}.radio-label{color:#64748b}.radio-label input[type=radio]{accent-color:#1e3a5f;width:auto}.new-patient-section{background:#f8fafc}.section-title{font-size:1.125rem;margin:0 0 1rem}.modal-actions{border-top:2px solid #e2e8f0}.btn-primary{border-color:#1e3a5f}.btn-primary:hover{box-shadow:0 4px 12px #1e3a5f4d}.error-container{align-items:center;display:flex;justify-content:center;min-height:60vh;padding:2rem}.error-card{background:#fff;border:2px solid #fee2e2;border-radius:16px;box-shadow:0 4px 20px #0000001a;max-width:600px;padding:3rem;text-align:center;width:100%}.error-icon{align-items:center;background:#fee2e2;border-radius:50%;color:#ef4444;display:flex;height:64px;justify-content:center;margin:0 auto 1.5rem;width:64px}.error-icon svg{height:32px;width:32px}.error-title{color:#1e3a5f;font-size:1.5rem;font-weight:700;margin:0 0 1rem}.error-message{background:#f8fafc;border-left:4px solid #ef4444;border-radius:8px;margin:1.5rem 0;padding:1.5rem;text-align:left}.error-message p{color:#64748b;font-size:.95rem;line-height:1.6;margin:.5rem 0}.error-message p:first-child{color:#1e3a5f;font-weight:600}.error-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2rem}.error-actions .btn{border:2px solid #0000;border-radius:8px;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.error-actions .btn-primary{background:linear-gradient(135deg,#1e3a5f,#2c3e50);color:#fff}.error-actions .btn-primary:hover{box-shadow:0 4px 12px #1e3a5f4d;transform:translateY(-2px)}.error-actions .btn-secondary{background:#fff;border-color:#1e3a5f;color:#1e3a5f}.error-actions .btn-secondary:hover{background:#f8fafc;transform:translateY(-2px)}@media (max-width:991px){.doctor-dashboard-page{padding:1.5rem}.doctor-header{flex-direction:column;gap:1.5rem;padding:1.5rem;text-align:center}.doctor-header-actions{flex-direction:column;gap:1rem;width:100%}.btn-schedule{justify-content:center;width:100%}.doctor-greeting{font-size:2rem}.schedule-modal{margin:1rem;max-width:95%}.form-row{grid-template-columns:1fr}.stats-grid{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.dashboard-section{padding:1.5rem}.schedule-card{align-items:flex-start;flex-direction:column;gap:1rem}.schedule-link{text-align:center;width:100%}.appointment-card{align-items:flex-start;flex-direction:column;gap:1rem}.appointment-link{text-align:center;width:100%}}@media (max-width:767px){.doctor-dashboard-page{padding:1rem}.doctor-header{padding:1.25rem}.doctor-greeting{font-size:1.75rem}.doctor-subtitle{font-size:1rem}.modal-overlay{padding:1rem}.schedule-modal{max-height:95vh;max-width:100%}.modal-header{padding:1.25rem 1.5rem}.modal-header h2{font-size:1.25rem}.modal-content form{padding:1.5rem}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}.stats-grid{grid-template-columns:1fr}.dashboard-section{padding:1.25rem}.section-header{align-items:flex-start;flex-direction:column;gap:.75rem}.quick-actions{grid-template-columns:1fr}}.pr-dashboard-page{min-height:100vh;padding:2rem;width:100%}.welcome-section{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea4d}.stat-card-orange{border-left-color:#f59e0b}.stat-card-orange:hover{background:linear-gradient(135deg,#fffbeb,#fef3c7)}.notification-badge{fontSize:.875rem}.messages-list{display:flex;flex-direction:column;gap:1rem}.message-card{align-items:flex-start;background:linear-gradient(135deg,#f8f9fa,#fff);border-left:4px solid #667eea;border-radius:10px;box-shadow:0 2px 4px #0000000d;display:flex;justify-content:space-between;padding:1.5rem;transition:all .3s ease}.message-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateX(4px)}.message-info{flex:1 1}.message-main h3{color:#1e3a5f;font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.message-contact{color:#6b7280;font-size:.95rem;margin:0 0 1rem}.message-details{display:flex;flex-direction:column;gap:.75rem}.detail-label{min-width:60px}.message-link{border-radius:6px;color:#667eea;font-weight:600;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease;white-space:nowrap}.message-link:hover{background:#667eea;color:#fff;transform:translateX(4px)}.notification-meta{fontSize:.875rem}.quick-action-card:hover{border-color:#667eea;box-shadow:0 8px 24px #667eea33}@media (max-width:991px){.pr-dashboard-page{padding:1.25rem}.hospital-header{padding:1.5rem}.hospital-name{font-size:2rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.welcome-section h2{font-size:1.75rem}}@media (max-width:767px){.pr-dashboard-page{padding:1rem}.hospital-header{flex-direction:column;padding:1.25rem;text-align:center}.hospital-name{font-size:1.75rem}.hospital-subtitle{font-size:1rem}.welcome-section{padding:1.5rem}.welcome-section h2{font-size:1.5rem}.welcome-section p{font-size:1rem}.stats-grid{gap:1rem;grid-template-columns:1fr}.stat-card{padding:1.25rem}.dashboard-section{padding:1.5rem}.section-header{align-items:flex-start;flex-direction:column;gap:.75rem}.message-card{flex-direction:column;gap:1rem}.message-link{text-align:center;width:100%}.quick-actions{grid-template-columns:1fr}}@media (max-width:575px){.pr-dashboard-page{padding:.75rem}.hospital-header{border-radius:12px;padding:1rem}.hospital-name{font-size:1.5rem}.hospital-subtitle{font-size:.9rem}.welcome-section{padding:1.25rem}.welcome-section h2{font-size:1.25rem}.welcome-section p{font-size:.9rem}.stats-grid{gap:.75rem}.stat-card{padding:1rem}.dashboard-section{border-radius:10px;padding:1rem}.section-header h2{font-size:1.125rem}.message-card{padding:1rem}.quick-action-card{padding:1.25rem .875rem}}.user-dashboard-page{min-height:100vh;padding:2rem;width:100%}.hospital-header{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2c3e50);border-radius:16px;box-shadow:0 4px 20px #00000026;color:#fff;display:flex;justify-content:space-between;margin-bottom:2rem;padding:2rem 2.5rem}.hospital-info{flex:1 1}.hospital-name{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e0e0);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700;letter-spacing:1px;margin:0 0 .5rem;text-transform:uppercase}.hospital-subtitle{color:#ffffffe6;font-size:1.1rem;font-weight:400;letter-spacing:.5px;margin:0}.hospital-logo{align-items:center;display:flex;justify-content:center}.welcome-section{background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;box-shadow:0 4px 15px #10b9814d;color:#fff;margin-bottom:2rem;padding:2rem 2.5rem}.welcome-section h2{font-size:2rem;font-weight:700;margin:0 0 .5rem}.welcome-section p{font-size:1.1rem;margin:0;opacity:.95}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border-left:4px solid #0000;border-radius:12px;box-shadow:0 2px 12px #00000014;color:inherit;display:flex;gap:1rem;overflow:hidden;padding:1.5rem;position:relative;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.stat-card:before{background:linear-gradient(90deg,#0000,#ffffff80,#0000);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:translateX(-100%);transition:transform .6s ease}.stat-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.stat-card:hover:before{transform:translateX(100%)}.stat-card-blue{border-left-color:#3b82f6}.stat-card-blue:hover{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.stat-card-green{border-left-color:#10b981}.stat-card-green:hover{background:linear-gradient(135deg,#ecfdf5,#d1fae5)}.stat-card-purple{border-left-color:#8b5cf6}.stat-card-purple:hover{background:linear-gradient(135deg,#f5f3ff,#ede9fe)}.stat-card-red{border-left-color:#ef4444}.stat-card-red:hover{background:linear-gradient(135deg,#fef2f2,#fee2e2)}.stat-icon{align-items:center;background:linear-gradient(135deg,#0000000d,#00000005);border-radius:12px;display:flex;flex-shrink:0;font-size:2.5rem;height:60px;justify-content:center;width:60px}.stat-content{flex:1 1}.stat-value{color:#1e3a5f;font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:.25rem}.stat-title{color:#6b7280;font-size:.9rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.stat-arrow{color:#9ca3af;font-size:1.5rem;opacity:0;transform:translateX(-10px);transition:all .3s ease}.stat-card:hover .stat-arrow{opacity:1;transform:translateX(0)}.dashboard-section{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;margin-bottom:2rem;padding:2rem}.section-header{align-items:center;border-bottom:2px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.section-header h2{align-items:center;color:#1e3a5f;display:flex;font-size:1.5rem;font-weight:700;gap:.5rem;margin:0}.notification-badge{background-color:#dc3545;border-radius:50%;color:#fff;font-size:.875rem;font-weight:700;padding:.25rem .5rem}.view-all-link{color:#667eea;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .3s ease}.view-all-link:hover{color:#5568d3;transform:translateX(4px)}.appointments-list{display:flex;flex-direction:column;gap:1rem}.appointment-card{align-items:flex-start;background:linear-gradient(135deg,#f8f9fa,#fff);border-left:4px solid #10b981;border-radius:10px;box-shadow:0 2px 4px #0000000d;justify-content:space-between;padding:1.5rem;transition:all .3s ease}.appointment-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateX(4px)}.appointment-info{flex:1 1}.appointment-main h3{color:#1e3a5f;font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.appointment-department{color:#6b7280;font-size:.95rem;margin:0 0 1rem}.appointment-details{display:flex;flex-direction:column;gap:.75rem}.detail-item{align-items:flex-start}.detail-label{color:#6b7280}.detail-value{color:#1e3a5f;font-size:.875rem}.appointment-link{border-radius:6px;color:#10b981;font-weight:600;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease;white-space:nowrap}.appointment-link:hover{background:#10b981;color:#fff;transform:translateX(4px)}.notification-card{background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:1rem;position:relative;transition:all .3s ease}.notification-card.unread{background:#fff5f5;border-color:#dc3545}.notification-card:hover{box-shadow:0 4px 12px #0000001a}.unread-dot{background-color:#dc3545;border-radius:50%;height:10px;position:absolute;right:.5rem;top:.5rem;width:10px}.notification-type{color:#666;font-size:.75rem;font-weight:700;margin-bottom:.5rem;text-transform:uppercase}.notification-message{margin:.5rem 0}.notification-meta{color:#666;font-size:.875rem;margin-top:.5rem}.status-scheduled{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.status-confirmed{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.status-completed{background:linear-gradient(135deg,#cffafe,#a5f3fc);color:#164e63}.status-cancelled{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b}.status-pending{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.status-default{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#374151}.quick-actions{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.quick-action-card{align-items:center;background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #0000;border-radius:12px;box-shadow:0 2px 8px #0000000d;color:#1e3a5f;display:flex;flex-direction:column;justify-content:center;padding:2rem 1.5rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.quick-action-card:hover{background:linear-gradient(135deg,#fff,#f8f9fa);border-color:#10b981;box-shadow:0 8px 24px #10b98133;transform:translateY(-4px)}.quick-action-icon{font-size:2.5rem;margin-bottom:.75rem}.quick-action-text{font-size:.95rem;font-weight:600;text-align:center}.health-tips-section{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd}.health-tips-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.health-tip-card{background:#fff;border:2px solid #0000;border-radius:10px;padding:1.5rem;text-align:center;transition:all .3s ease}.health-tip-card:hover{border-color:#10b981;box-shadow:0 4px 12px #10b98133;transform:translateY(-4px)}.tip-icon{font-size:3rem;margin-bottom:1rem}.health-tip-card h3{color:#1e3a5f;font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.health-tip-card p{color:#6b7280;font-size:.9rem;line-height:1.5;margin:0}.no-data-card{background:#f9fafb;border:2px dashed #e5e7eb;border-radius:10px;color:#6b7280;padding:3rem 2rem;text-align:center}.no-data-icon{color:#9ca3af}.loading{color:#6c757d}@media (max-width:991px){.user-dashboard-page{padding:1.25rem}.hospital-header{padding:1.5rem}.hospital-name{font-size:2rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.welcome-section h2{font-size:1.75rem}.health-tips-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:767px){.user-dashboard-page{padding:1rem}.hospital-header{flex-direction:column;padding:1.25rem;text-align:center}.hospital-name{font-size:1.75rem}.hospital-subtitle{font-size:1rem}.welcome-section{padding:1.5rem}.welcome-section h2{font-size:1.5rem}.welcome-section p{font-size:1rem}.stats-grid{gap:1rem;grid-template-columns:1fr}.stat-card{padding:1.25rem}.dashboard-section{padding:1.5rem}.section-header{align-items:flex-start;flex-direction:column;gap:.75rem}.appointment-card{flex-direction:column;gap:1rem}.appointment-link{text-align:center;width:100%}.health-tips-grid,.quick-actions{grid-template-columns:1fr}}@media (max-width:575px){.user-dashboard-page{padding:.75rem}.hospital-header{border-radius:12px;padding:1rem}.hospital-name{font-size:1.5rem}.hospital-subtitle{font-size:.9rem}.welcome-section{padding:1.25rem}.welcome-section h2{font-size:1.25rem}.welcome-section p{font-size:.9rem}.stats-grid{gap:.75rem}.stat-card{padding:1rem}.dashboard-section{border-radius:10px;padding:1rem}.section-header h2{font-size:1.125rem}.appointment-card{padding:1rem}.quick-action-card{padding:1.25rem .875rem}.health-tip-card{padding:1.25rem}}.report-button-container{display:inline-block;position:relative}.report-button{align-items:center;display:inline-flex;gap:.5rem}.report-menu-overlay{animation:fadeIn .2s ease-in;background:#0000004d;bottom:0;left:0;position:fixed;right:0;top:0;z-index:1000}.report-menu{animation:slideDown .2s ease-out;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;margin-top:.5rem;min-width:250px;position:absolute;right:0;top:100%;z-index:1001}.report-menu-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:1rem}.report-menu-header h4{color:#333;font-size:1rem;margin:0}.report-menu-close{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:1.5rem;height:24px;justify-content:center;padding:0;transition:all .2s;width:24px}.report-menu-close:hover{background:#f0f0f0;color:#333}.report-menu-content{padding:1rem}.time-period-section{border-bottom:1px solid #e0e0e0;margin-bottom:1rem;padding-bottom:1rem}.time-period-label{color:#333;display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.time-period-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.time-period-btn{background:#f0f0f0;border:1px solid #ddd;border-radius:6px;color:#555;cursor:pointer;font-size:.85rem;font-weight:500;min-width:60px;padding:.5rem .75rem;text-align:center;transition:all .2s}.time-period-btn:hover{background:#e0e0e0;border-color:#4caf50;color:#333}.time-period-btn.active{background:#4caf50;border-color:#4caf50;box-shadow:0 2px 4px #4caf504d;color:#fff}.report-info{color:#666;font-size:.9rem;margin:1rem 0}.report-info strong{color:#333}.period-indicator{color:#4caf50;font-size:.85rem;font-weight:600}.report-options{display:flex;flex-direction:column;gap:.5rem}.report-option-btn{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;color:#333;cursor:pointer;display:flex;font-size:.95rem;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:all .2s;width:100%}.report-option-btn:hover{background:#e9ecef;border-color:#4caf50;transform:translateX(4px)}.report-icon{font-size:1.2rem}@media (max-width:768px){.report-menu{left:0;min-width:auto;right:0}}.users-page{margin:0 auto;max-width:1600px;min-height:100vh;padding:2rem}.users-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.users-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2)}.btn-primary:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 6px 12px #667eea66;transform:translateY(-2px)}.btn-secondary{background:linear-gradient(135deg,#6c757d,#5a6268)}.btn-secondary:hover{background:linear-gradient(135deg,#5a6268,#495057);box-shadow:0 4px 8px #6c757d4d}.btn-edit{background:linear-gradient(135deg,#28a745,#20c997)}.btn-edit:hover{background:linear-gradient(135deg,#218838,#1aa179);box-shadow:0 4px 8px #28a7454d;transform:translateY(-2px)}.users-table{border-collapse:collapse;width:100%}.users-table thead{background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.users-table th{border-bottom:2px solid #dee2e6;color:#495057;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1.25rem 1rem;text-align:left;text-transform:uppercase}.users-table td{border-bottom:1px solid #dee2e6;color:#555;padding:1rem}.users-table tbody tr{transition:all .2s ease}.users-table tbody tr:hover{background-color:#f8f9fa;box-shadow:0 2px 4px #0000000d;transform:scale(1.01)}.users-table tbody tr:last-child td{border-bottom:none}.role-badge,.status-badge{box-shadow:0 2px 4px #0000001a;font-size:.75rem;letter-spacing:.3px;padding:.375rem .875rem}.role-badge{border-radius:20px;display:inline-block;font-weight:600;text-transform:capitalize}.role-doctor{background-color:#d1ecf1;color:#0c5460}.role-admin{background-color:#d4edda;color:#155724}.modal-overlay{animation:fadeIn .3s ease;z-index:2000}.modal-content{animation:slideUp .3s ease;border-radius:16px;box-shadow:0 20px 60px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:linear-gradient(135deg,#f8f9fa,#fff);border-bottom:1px solid #e9ecef}.modal-header h2{font-size:1.75rem}.modal-close:hover{color:#212529}.form-group label{color:#495057;font-size:.9rem;font-weight:600}.form-group input,.form-group select{background:#fff;border:2px solid #e9ecef;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:.875rem;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.modal-actions{border-top:1px solid #e9ecef}@media (max-width:768px){.users-page{padding:1rem}.users-header{align-items:flex-start;gap:1rem}.filters-section,.users-header{flex-direction:column}.filter-group,.filter-group select{width:100%}.table-container{overflow-x:scroll}.users-table{min-width:800px}.modal-content{margin:1rem;max-width:100%}}.roles-page{margin:0 auto;max-width:1400px;padding:2rem}.roles-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.roles-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.roles-table{border-collapse:collapse;width:100%}.roles-table thead{background-color:#f8f9fa}.roles-table th{border-bottom:2px solid #dee2e6;color:#333;font-weight:600;padding:1rem;text-align:left}.roles-table td{border-bottom:1px solid #dee2e6;color:#555;padding:1rem}.roles-table tbody tr:hover{background-color:#f8f9fa}.roles-table tbody tr:last-child td{border-bottom:none}.role-name{color:#333;font-weight:600}.role-description{word-wrap:break-word;max-width:400px}@media (max-width:768px){.roles-page{padding:1rem}.roles-header{align-items:flex-start;flex-direction:column;gap:1rem}.table-container{overflow-x:scroll}.roles-table{min-width:700px}.modal-content{margin:1rem;max-width:100%}}.patients-page{margin:0 auto;max-width:1600px;min-height:100vh;padding:3rem}.patients-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2.5rem;padding:2rem 2.5rem}.patients-header h1{color:#1e3a5f;font-size:2.5rem;font-weight:700;letter-spacing:-.5px;margin:0}.btn{font-size:1.2rem;padding:1rem 2rem}.btn-sm{font-size:1rem;padding:.6rem 1.2rem}.search-filters-section{gap:1.5rem;margin-bottom:2rem;padding:2rem}.search-group label{font-size:1.1rem}.search-input{font-size:1.15rem;padding:1rem 3rem 1rem 1rem}.filter-group label{font-size:1.1rem}.filter-group select{border-radius:6px;font-size:1.15rem;min-width:180px;padding:1rem}.alert{font-size:1.1rem;padding:1.25rem}.loading,.no-data{font-size:1.4rem;padding:4rem}.patients-table{border-collapse:collapse;width:100%}.patients-table thead{background-color:#f8f9fa}.patients-table th{border-bottom:2px solid #dee2e6;color:#333;font-size:1.15rem;font-weight:600;padding:1.5rem;text-align:left;white-space:nowrap}.patients-table td{border-bottom:1px solid #dee2e6;color:#555;font-size:1.1rem;padding:1.5rem}.patients-table tbody tr:hover{background-color:#f8f9fa}.patients-table tbody tr:last-child td{border-bottom:none}.patient-name{font-size:1.15rem}.address-cell{max-width:200px}.gender-badge,.origin-badge{font-size:1rem;padding:.5rem 1rem}.origin-badge{border-radius:12px;display:inline-block;font-weight:500;text-transform:capitalize}.origin-rwandan{background-color:#d1e7dd;color:#0f5132}.origin-east-africa,.origin-east-african{background-color:#fff3cd;color:#856404}.origin-african{background-color:#cfe2ff;color:#084298}.origin-rest-of-the-world{background-color:#f8d7da;color:#842029}.origin-unknown{background-color:#e7e7e7;color:#495057}.modal-overlay{padding:2rem}.modal-content{border-radius:12px}.modal-header h2{font-size:2rem}.modal-content form{padding:2rem}.form-group,.form-row{margin-bottom:2rem}.form-group label{font-size:1.1rem;margin-bottom:.75rem}.form-group input,.form-group select,.form-group textarea{border-radius:6px;padding:1rem}.modal-actions{gap:1.5rem;margin-top:2.5rem;padding-top:2rem}@media (max-width:768px){.patients-page{padding:1rem}.patients-header{align-items:flex-start;gap:1rem}.patients-header,.search-filters-section{flex-direction:column}.filter-group,.filter-group select,.search-group,.search-group input{width:100%}.table-container{overflow-x:scroll}.patients-table{min-width:1000px}.modal-content{margin:1rem;max-width:100%}.form-row{grid-template-columns:1fr}}.doctors-page{margin:0 auto;max-width:1600px;min-height:100vh;padding:2rem}.doctors-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.doctors-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.doctors-table{border-collapse:collapse;width:100%}.doctors-table thead{background-color:#f8f9fa}.doctors-table th{border-bottom:2px solid #dee2e6;color:#333;font-weight:600;padding:1rem;text-align:left;white-space:nowrap}.doctors-table td{border-bottom:1px solid #dee2e6;color:#555;padding:1rem}.doctors-table tbody tr:hover{background-color:#f8f9fa}.doctors-table tbody tr:last-child td{border-bottom:none}.gender-badge{border-radius:12px;display:inline-block;font-size:.875rem;font-weight:500;padding:.25rem .75rem;text-transform:capitalize}.gender-male{background-color:#cfe2ff;color:#084298}.gender-female{background-color:#f8d7da;color:#842029}.gender-other{background-color:#e7e7e7;color:#495057}@media (max-width:768px){.doctors-page{padding:1rem}.doctors-header{align-items:flex-start;gap:1rem}.doctors-header,.filters-section{flex-direction:column}.filter-group{width:100%}.table-container{overflow-x:scroll}.doctors-table{min-width:1000px}.modal-content{margin:1rem;max-width:100%}.form-row{grid-template-columns:1fr}}.departments-page{margin:0 auto;max-width:1400px;padding:2rem}.departments-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.departments-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.table-container{position:relative;scrollbar-color:#667eea #f1f1f1;scrollbar-width:thin}.table-container::-webkit-scrollbar{height:6px}.table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.table-container::-webkit-scrollbar-thumb{background:#667eea;border-radius:3px}.table-container::-webkit-scrollbar-thumb:hover{background:#5568d3}.departments-table{border-collapse:collapse;width:100%}.departments-table thead{background-color:#f8f9fa}.departments-table th{border-bottom:2px solid #dee2e6;color:#333;font-weight:600;padding:1rem;text-align:left}.departments-table td{border-bottom:1px solid #dee2e6;color:#555;padding:1rem}.departments-table tbody tr:hover{background-color:#f8f9fa}.departments-table tbody tr:last-child td{border-bottom:none}.department-name{color:#333;font-weight:600}.department-description{word-wrap:break-word;max-width:400px}.status-active{background-color:#d4edda;color:#155724}.status-inactive{background-color:#f8d7da;color:#721c24}@media (max-width:991px){.departments-page{padding:1.25rem}.departments-header{padding:1.25rem 1.5rem}.departments-header h1{font-size:1.75rem}}@media (max-width:767px){.departments-page{padding:1rem}.departments-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:1.25rem}.departments-header h1{font-size:1.5rem;width:100%}.departments-header .btn{margin-top:.75rem;width:100%}.filters-section{flex-direction:column;padding:1rem}.filter-group{width:100%}.filter-group select{min-width:100%;width:100%}.table-container{-webkit-overflow-scrolling:touch;border-radius:0;margin-left:-1rem;margin-right:-1rem;overflow-x:auto;width:calc(100% + 2rem)}.departments-table{min-width:800px}.departments-table td,.departments-table th{font-size:.875rem;padding:.875rem .75rem}.departments-table th{font-size:.8rem;white-space:nowrap}.action-buttons{flex-direction:column;gap:.375rem;width:100%}.action-buttons .btn{justify-content:center;width:100%}.modal-content{margin:1rem;max-width:95%}.modal-header{padding:1.25rem}.modal-header h2{font-size:1.25rem}.modal-content form{padding:1.25rem}}@media (max-width:575px){.departments-page{padding:.75rem}.departments-header{padding:1rem}.departments-header h1{font-size:1.375rem}.table-container{margin-left:-.75rem;margin-right:-.75rem;width:calc(100% + 1.5rem)}.departments-table{min-width:700px}.departments-table th{font-size:.75rem;padding:.75rem .5rem}.departments-table td{font-size:.8rem;padding:.75rem .5rem}.department-description{max-width:200px;word-break:break-word}.modal-content{border-radius:0;height:100vh;margin:0;max-height:100vh;max-width:100%}.modal-header{padding:1rem}.modal-header h2{font-size:1.125rem}.modal-content form{padding:1rem}}.insurances-page{margin:0 auto;max-width:1600px;min-height:100vh;padding:2rem}.insurances-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.insurances-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.search-filters-section{align-items:flex-end;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1.5rem}.search-group{display:flex;flex:1 1;flex-direction:column;gap:.5rem;min-width:250px;position:relative}.search-group label{color:#495057;font-size:.875rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.search-input{background:#fff;border:2px solid #e9ecef;box-sizing:border-box;padding:.75rem 2.5rem .75rem .75rem}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-clear-search{align-items:center;background:none;border:none;border-radius:4px;bottom:8px;color:#6c757d;cursor:pointer;display:flex;font-size:1.5rem;height:24px;justify-content:center;padding:0;position:absolute;right:8px;transition:all .2s ease;width:24px}.btn-clear-search:hover{background-color:#e9ecef;color:#333}.insurances-table{border-collapse:collapse;width:100%}.insurances-table thead{background-color:#f8f9fa}.insurances-table th{border-bottom:2px solid #dee2e6;color:#333;font-weight:600;padding:1rem;text-align:left;white-space:nowrap}.insurances-table td{border-bottom:1px solid #dee2e6;color:#555;padding:1rem}.insurances-table tbody tr:hover{background-color:#f8f9fa}.insurances-table tbody tr:last-child td{border-bottom:none}.insurance-name{color:#333;font-size:1.05rem;font-weight:600}.modal-content{max-width:500px}@media (max-width:768px){.insurances-page{padding:1rem}.insurances-header{align-items:flex-start;gap:1rem}.insurances-header,.search-filters-section{flex-direction:column}.search-group,.search-group input{width:100%}.table-container{overflow-x:scroll}.insurances-table{min-width:600px}.modal-content{margin:1rem;max-width:100%}}.doctor-schedules-page{margin:0 auto;max-width:1400px;padding:2rem}.doctor-schedules-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.doctor-schedules-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.schedules-container{display:flex;flex-direction:column;gap:2rem}.day-schedule-group{background-color:#f8f9fa;border-radius:8px;padding:1.5rem}.day-header{border-bottom:2px solid #dee2e6;color:#333;font-size:1.5rem;font-weight:600;margin:0 0 1rem;padding-bottom:.75rem}.schedules-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.schedule-card{background-color:#fff;border-left:4px solid #007bff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;padding:1.5rem;transition:all .3s ease}.schedule-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.schedule-header{align-items:flex-start;border-bottom:1px solid #e9ecef;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.schedule-doctor-info{flex:1 1;min-width:200px}.doctor-name{color:#333;font-size:1.1rem;margin:0 0 .5rem}.doctor-name.doctor-not-found{color:#dc3545;font-style:italic}.doctor-specialization{background-color:#e7f3ff;color:#06c;font-size:.875rem;margin-right:.5rem}.doctor-specialization,.doctor-warning{border-radius:12px;display:inline-block;font-weight:500;padding:.25rem .75rem}.doctor-warning{background-color:#fff3cd;color:#856404;font-size:.75rem;margin-top:.5rem}.schedule-time{align-items:flex-end;display:flex;flex-direction:column;gap:.5rem}.day-badge{background-color:#6c757d;border-radius:12px;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.time-range{color:#007bff;font-size:1.1rem;font-weight:600;white-space:nowrap}.schedule-details{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1rem}.detail-item{flex-direction:column;gap:.25rem}.detail-label{color:#6c757d;font-size:.875rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.detail-value{font-size:1rem;font-weight:600}.schedule-actions{border-top:1px solid #e9ecef;display:flex;gap:.5rem;padding-top:1rem}@media (max-width:768px){.doctor-schedules-page{padding:1rem}.doctor-schedules-header{align-items:flex-start;flex-direction:column;gap:1rem}.filters-section{flex-direction:column}.filter-group{width:100%}.schedules-list{grid-template-columns:1fr}.schedule-header{flex-direction:column}.schedule-time{align-items:flex-start}.schedule-details{gap:1rem}.schedule-actions,.schedule-details{flex-direction:column}.schedule-actions .btn{width:100%}.modal-content{margin:1rem;max-width:100%}.form-row{grid-template-columns:1fr}}@media (max-width:480px){.schedules-list{grid-template-columns:1fr}}.appointments-page{margin:0 auto;max-width:1600px;min-height:100vh;padding:2rem}.appointments-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.appointments-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.filter-group select,.filter-input{min-width:150px}.table-container{border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:100%;overflow-y:visible;width:100%}.appointments-table{border-collapse:collapse;width:100%}.appointments-table thead{background-color:#f8f9fa}.appointments-table th{border-bottom:2px solid #dee2e6;color:#333;font-weight:600;padding:1rem;text-align:left;white-space:nowrap}.appointments-table td{border-bottom:1px solid #dee2e6;color:#555;padding:1rem}.appointments-table tbody tr:hover{background-color:#f8f9fa}.appointments-table tbody tr:last-child td{border-bottom:none}.address-cell,.contact-cell,.doctor-cell,.patient-cell{min-width:150px}.patient-cell{min-width:180px}.contact-cell{font-size:.9rem;min-width:160px}.address-cell{word-wrap:break-word;max-width:250px;min-width:200px}.doctor-specialization,.patient-email{color:#6c757d;font-size:.875rem;margin-top:.25rem}.datetime-cell{display:flex;flex-direction:column;gap:.25rem}.datetime-cell .time{color:#007bff;font-weight:600}.reason-cell{word-wrap:break-word;max-width:200px}.form-row{grid-gap:1rem;gap:1rem}.radio-group{gap:2rem}.radio-label{align-items:center;color:#495057;display:flex;font-weight:500;gap:.5rem}.radio-label input[type=radio]{accent-color:#667eea;cursor:pointer;height:18px;width:18px}.radio-label span{-webkit-user-select:none;user-select:none}.new-patient-section{background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #e9ecef;border-radius:10px;padding:1.5rem}.section-title{border-bottom:2px solid #e9ecef;font-size:1.2rem;font-weight:600;padding-bottom:.75rem}.disabled-input{background-color:#f8fafc;color:#64748b;cursor:not-allowed}.form-group textarea{min-height:80px}@media (max-width:991px){.appointments-page{padding:1.25rem}.appointments-header{padding:1.25rem 1.5rem}.appointments-header h1{font-size:1.75rem}.filters-section{padding:1.25rem}}@media (max-width:767px){.appointments-page{padding:1rem}.appointments-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:1.25rem}.appointments-header h1{font-size:1.5rem}.filters-section{flex-direction:column;padding:1rem}.filter-group{width:100%}.filter-group select,.filter-input{min-width:100%;width:100%}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.appointments-table{min-width:1000px}.appointments-table td,.appointments-table th{font-size:.875rem;padding:.875rem .75rem}.modal-content{margin:1rem;max-width:95%}.modal-header{padding:1.25rem}.modal-header h2{font-size:1.25rem}.modal-content form{padding:1.25rem}.form-row{grid-template-columns:1fr}.radio-group{flex-direction:column;gap:1rem}.action-buttons{flex-direction:column;width:100%}.action-buttons .btn{width:100%}}@media (max-width:575px){.appointments-page{padding:.75rem}.appointments-header{padding:1rem}.appointments-header h1{font-size:1.375rem}.filters-section{padding:.875rem}.appointments-table{min-width:800px}.appointments-table th{font-size:.75rem;padding:.75rem .5rem}.appointments-table td{font-size:.8rem;padding:.75rem .5rem}.doctor-cell,.patient-cell{min-width:120px}.modal-content{border-radius:0;height:100vh;margin:0;max-height:100vh;max-width:100%}.modal-header{padding:1rem}.modal-header h2{font-size:1.125rem}.modal-content form,.new-patient-section{padding:1rem}.section-title{font-size:1.1rem}}.appointment-status-history-page{margin:0 auto;max-width:1400px;padding:2rem}.history-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.history-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.filter-input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:1rem;padding:.5rem;width:100%}.filter-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.history-list{display:flex;flex-direction:column;gap:1rem}.history-card{background-color:#fff;border-left:4px solid #007bff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;transition:all .3s ease}.history-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.history-header-card{border-bottom:1px solid #e9ecef;margin-bottom:1rem;padding-bottom:1rem}.history-main-info{display:flex;flex-direction:column;gap:1rem}.status-change{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.status-arrow{color:#6c757d;font-size:1.5rem;font-weight:700}.history-meta{color:#6c757d;display:flex;flex-wrap:wrap;font-size:.9rem;gap:1.5rem}.changed-by{color:#495057}.changed-by strong{color:#333;font-weight:600}.history-details{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.history-actions{border-top:1px solid #e9ecef;display:flex;gap:.5rem;padding-top:1rem}.status-badge{border-radius:6px;padding:.5rem 1rem}.status-scheduled{background-color:#cfe2ff;color:#084298}.status-confirmed{background-color:#d1e7dd;color:#0f5132}.status-no-show{background-color:#fff3cd;color:#856404}.form-hint{font-style:italic}@media (max-width:768px){.appointment-status-history-page{padding:1rem}.history-header{align-items:flex-start;gap:1rem}.filters-section,.history-header{flex-direction:column}.filter-group{width:100%}.status-change{align-items:flex-start;flex-direction:column}.status-arrow{margin:.5rem 0;transform:rotate(90deg)}.history-meta{gap:.5rem}.history-actions,.history-meta{flex-direction:column}.history-actions .btn{width:100%}.modal-content{margin:1rem;max-width:100%}}.appointment-changes-page{margin:0 auto;max-width:1400px;padding:2rem}.changes-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.changes-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.filter-group{min-width:200px}.filter-group select,.filter-input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:1rem;padding:.5rem;width:100%}.filter-group select:focus,.filter-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.changes-list{display:flex;flex-direction:column;gap:1rem}.change-card{background-color:#fff;border-left:4px solid #007bff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;transition:all .3s ease}.change-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.change-header-card{border-bottom:1px solid #e9ecef;margin-bottom:1rem;padding-bottom:1rem}.change-main-info{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.change-type-display{flex:1 1}.change-meta{display:flex;font-size:.9rem;gap:1rem}.change-meta,.changed-at{color:#6c757d}.change-details{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.detail-item{display:flex;flex-wrap:wrap;gap:.5rem}.detail-label{color:#495057;font-size:.9rem;font-weight:600;min-width:120px}.detail-value{color:#333;flex:1 1}.reason-text{color:#555;font-style:italic}.change-actions{border-top:1px solid #e9ecef;display:flex;gap:.5rem;padding-top:1rem}.change-type-badge{border-radius:6px;display:inline-block;font-size:.875rem;font-weight:600;padding:.5rem 1rem;text-transform:capitalize}.change-type-rescheduled{background-color:#fff3cd;border-left:3px solid #ffc107;color:#856404}.change-type-cancelled{background-color:#f8d7da;border-left:3px solid #dc3545;color:#721c24}.change-type-doctor_changed{background-color:#cfe2ff;border-left:3px solid #0d6efd;color:#084298}.change-type-time_changed{background-color:#d1e7dd;border-left:3px solid #198754;color:#0f5132}.change-type-date_changed{background-color:#e7f3ff;border-left:3px solid #0dcaf0;color:#055160}.change-type-patient_changed{background-color:#f3d9fa;border-left:3px solid #d63384;color:#6f42c1}.change-type-department_changed{background-color:#ffe5d0;border-left:3px solid #fd7e14;color:#8b4513}.change-type-reason_updated{background-color:#e2e3e5;border-left:3px solid #6c757d;color:#383d41}.change-type-other{background-color:#f8f9fa;border-left:3px solid #adb5bd;color:#495057}@media (max-width:768px){.appointment-changes-page{padding:1rem}.changes-header{align-items:flex-start;gap:1rem}.changes-header,.filters-section{flex-direction:column}.filter-group{width:100%}.change-main-info{align-items:flex-start;flex-direction:column}.change-meta{width:100%}.detail-item{flex-direction:column}.detail-label{min-width:auto}.change-actions{flex-direction:column}.change-actions .btn{width:100%}.modal-content{margin:1rem;max-width:100%}}.scheduled-appointments-page{animation:fadeIn .6s ease-out;background:linear-gradient(135deg,#f8fafc,#e2e8f0);min-height:100vh}.public-header{background:linear-gradient(135deg,#1e3a5f,#2c3e50);box-shadow:0 4px 20px #00000026;margin-bottom:0;position:-webkit-sticky;position:sticky;top:0;transition:all .3s ease;z-index:100}.public-header:hover{box-shadow:0 6px 30px #0003}.public-header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1600px;padding:1.25rem 2rem}.public-header-logo{align-items:center;color:#fff;display:flex;gap:.75rem;text-decoration:none;transition:transform .3s ease}.public-header-logo:hover{transform:translateX(-3px)}.public-header-logo .hospital-logo-wrapper{background:#0000;border:none;transition:transform .3s ease}.public-header-logo .hospital-logo-wrapper,.public-header-logo .hospital-logo-wrapper img{box-shadow:none!important;filter:none!important;text-shadow:none!important}.public-header-logo:hover .hospital-logo-wrapper{transform:rotate(-5deg) scale(1.1)}.public-header-logo .logo-icon{color:#fff;height:32px;transition:transform .3s ease;width:32px}.public-header-logo:hover .logo-icon{transform:rotate(-5deg) scale(1.1)}.public-header-logo h2{color:#fff;font-size:1.5rem;font-weight:700;letter-spacing:-.5px;margin:0}.public-header-nav{align-items:center;display:flex;gap:1rem}.public-nav-link{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;border-radius:8px;color:#fff;display:flex;font-weight:500;gap:.5rem;padding:.625rem 1.5rem;text-decoration:none;transition:all .3s ease}.public-nav-link:hover{background:#ffffff40;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.public-nav-link .nav-icon{height:18px;transition:transform .3s ease;width:18px}.public-nav-link:hover .nav-icon{transform:scale(1.1)}.scheduled-appointments-content{margin:0 auto;max-width:1600px;padding:2rem}.scheduled-appointments-header{align-items:center;animation:slideDown .6s ease-out;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #00000014;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;margin-bottom:2rem;padding:2rem}.btn-home{align-items:center;background:#f8f9fa;border:2px solid #e2e8f0;border-radius:8px;color:#1e3a5f;display:inline-flex;font-size:.95rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.btn-home:hover{background:#e9ecef;border-color:#1e3a5f;box-shadow:0 4px 12px #1e3a5f26;color:#1e3a5f;transform:translateY(-2px)}.btn-home .btn-icon{height:18px;transition:transform .3s ease;width:18px}.btn-home:hover .btn-icon{transform:translateX(-2px)}.btn-book{align-items:center;display:inline-flex;gap:.5rem}.btn-book .btn-icon{height:18px;width:18px}.header-content{align-items:center;gap:1.25rem}.header-icon-wrapper{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2c3e50);border-radius:12px;box-shadow:0 4px 12px #1e3a5f40;display:flex;height:56px;justify-content:center;transition:all .3s ease;width:56px}.header-icon-wrapper:hover{box-shadow:0 6px 20px #1e3a5f59;transform:scale(1.05) rotate(5deg)}.header-icon{color:#fff;height:28px;width:28px}.scheduled-appointments-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.page-subtitle{font-size:.95rem;line-height:1.5;margin:.5rem 0 0}.btn{overflow:hidden;position:relative}.btn:before{background:#fff3;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.btn:hover:before{height:300px;width:300px}.btn-primary{background:linear-gradient(135deg,#1e3a5f,#2c3e50);box-shadow:0 4px 12px #1e3a5f40}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #1e3a5f59;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:#64748b}.btn-secondary:hover:not(:disabled){background:#475569;transform:translateY(-2px)}.btn-sm{padding:.625rem 1.25rem}.btn-book{font-size:1.1rem;font-weight:600;padding:.875rem 2rem}.btn-book-slot{font-weight:600;width:100%}.btn:hover:not(:disabled) .btn-icon:not(.spinner){transform:translateX(3px)}.btn:disabled{cursor:not-allowed;opacity:.6}.alert{padding:1rem 1.25rem}.alert-error{background-color:#fee2e2}.alert-success{align-items:center;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #6ee7b7;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;font-weight:500;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.5rem}.alert-success-fixed{align-items:center;animation:slideDown .4s ease-out;border-radius:12px;box-shadow:0 8px 32px #28a74566;display:flex;font-size:1.1rem;font-weight:600;gap:1rem;justify-content:center;left:50%;max-width:90%;min-width:500px;padding:1.25rem 2rem;position:fixed;text-align:center;top:90px;transform:translateX(-50%);width:auto;z-index:9999}@media (max-width:768px){.alert-success-fixed{max-width:90%;min-width:90%;padding:.875rem 1.25rem;top:80px}}.alert-success .alert-icon{animation:checkmarkPulse 2s ease-in-out infinite;color:#065f46;flex-shrink:0;height:28px;width:28px}@keyframes checkmarkPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.alert-success .alert-close{align-items:center;background:#065f461a;border:none;border-radius:50%;color:#065f46;cursor:pointer;display:flex;font-size:1.5rem;font-weight:700;height:28px;justify-content:center;margin-left:auto;opacity:.8;padding:0;transition:all .2s ease;width:28px}.alert-success .alert-close:hover{background:#065f4633;opacity:1;transform:scale(1.1)}.loading{border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden;padding:4rem 2rem;position:relative;text-align:center}.loading:before{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#1e3a5f1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes shimmer{0%{left:-100%}to{left:100%}}.no-appointments{animation:fadeInUp .6s ease-out;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:4rem 2rem;text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.no-appointments-icon{animation:float 3s ease-in-out infinite;color:#94a3b8;height:80px;margin:0 auto 1.5rem;width:80px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.no-appointments-icon svg{height:100%;width:100%}.no-appointments h3{color:#1e3a5f;font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.no-appointments p{color:#64748b;font-size:1rem;line-height:1.6;margin:0 0 2rem}.appointments-grid{grid-gap:1.5rem;animation:fadeIn .8s ease-out;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));margin-bottom:2rem}.appointment-card{animation:cardAppear .6s ease-out backwards;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #00000014;display:flex;flex-direction:column;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}@keyframes cardAppear{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.appointment-card:first-child{animation-delay:.1s}.appointment-card:nth-child(2){animation-delay:.2s}.appointment-card:nth-child(3){animation-delay:.3s}.appointment-card:nth-child(4){animation-delay:.4s}.appointment-card:nth-child(5){animation-delay:.5s}.appointment-card:nth-child(6){animation-delay:.6s}.appointment-card:before{background:linear-gradient(90deg,#0000,#1e3a5f4d,#0000);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:translateX(-100%);transition:transform .6s ease}.appointment-card:hover:before{transform:translateX(100%)}.appointment-card:hover{border-color:#1e3a5f;box-shadow:0 12px 40px #1e3a5f33;transform:translateY(-8px) scale(1.02)}.appointment-card-header{align-items:flex-start;background:linear-gradient(135deg,#1e3a5f,#2c3e50);color:#fff;display:flex;justify-content:space-between;overflow:hidden;padding:1.5rem;position:relative}.appointment-card-header:after{animation:pulse 3s ease-in-out infinite;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:200%;position:absolute;right:-50%;top:-50%;width:200%}.appointment-date-time{display:flex;flex-direction:column;gap:.5rem;position:relative;z-index:1}.date-display{font-size:1.5rem;font-weight:700;letter-spacing:-.5px}.date-subtitle{font-size:.875rem;font-weight:400;opacity:.9}.time-display{align-items:center;display:flex;font-size:.95rem;gap:.5rem;margin-top:.25rem;opacity:.95}.time-icon{animation:tick 2s ease-in-out infinite;height:16px;width:16px}@keyframes tick{0%,to{transform:rotate(0deg)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.875rem;font-weight:600;gap:.375rem;padding:.5rem .875rem;position:relative;z-index:1}.status-scheduled{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fff3;border:1px solid #ffffff4d;color:#fff}.badge-icon{animation:checkPulse 2s ease-in-out infinite;height:14px;width:14px}@keyframes checkPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.appointment-card-body{background:linear-gradient(180deg,#fff 0,#f8fafc);flex-grow:1;padding:1.5rem}.appointment-info-row{margin-bottom:1.25rem}.appointment-info-row:last-child{margin-bottom:0}.info-item{align-items:flex-start;display:flex;gap:.75rem;transition:transform .3s ease}.appointment-card:hover .info-item{transform:translateX(4px)}.info-icon{color:#1e3a5f;flex-shrink:0;height:20px;margin-top:.125rem;transition:transform .3s ease;width:20px}.appointment-card:hover .info-icon{transform:scale(1.1) rotate(5deg)}.info-content{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.info-label{color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-value{color:#1e3a5f;display:flex;flex-direction:column;font-size:1rem;font-weight:500;gap:.25rem}.info-specialization{color:#64748b;font-size:.875rem;font-weight:400}.appointment-card-footer{background-color:#f8fafc;border-top:1px solid #e2e8f0;padding:1.25rem 1.5rem;transition:background-color .3s ease}.appointment-card:hover .appointment-card-footer{background-color:#fff}.booking-status{align-items:center;animation:fadeIn .5s ease-out;border-radius:8px;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;margin-bottom:.75rem;padding:.75rem;text-align:center}.modal-overlay{animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009}.modal-overlay:has(.success-modal){z-index:2000}.booking-modal,.success-modal{animation:modalSlideUp .3s ease;background-color:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:800px;overflow-y:auto;position:relative;width:100%;z-index:1001}.success-modal{max-width:500px;overflow-y:visible}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{background:#fff;border-bottom:1px solid #e2e8f0;border-radius:16px 16px 0 0;padding:2rem;position:-webkit-sticky;position:sticky;top:0;z-index:5}.modal-header-content{align-items:center;display:flex;gap:1rem}.modal-icon-wrapper{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2c3e50);border-radius:10px;box-shadow:0 4px 12px #1e3a5f40;display:flex;height:48px;justify-content:center;transition:transform .3s ease;width:48px}.modal-header:hover .modal-icon-wrapper{transform:rotate(5deg) scale(1.05)}.modal-icon{color:#fff;height:24px;width:24px}.modal-header h2{color:#1e3a5f;font-size:2.1rem;font-weight:700;letter-spacing:-.5px}.modal-subtitle{color:#64748b;font-size:1.05rem;margin:.25rem 0 0}.modal-close{background:#f1f5f9;border-radius:8px;color:#64748b;height:36px;width:36px}.modal-close:hover{background:#e2e8f0;color:#1e3a5f;transform:rotate(90deg)}.modal-close svg{height:20px;width:20px}.booking-modal form{padding:2rem;position:relative;z-index:1}.booking-modal form .alert-error{box-shadow:0 4px 12px #dc35454d;position:relative;z-index:100}.form-row{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.form-row .form-group{margin-bottom:0}.form-label-with-icon{font-size:1.15rem;margin-bottom:.75rem}.label-icon{transition:transform .3s ease}.form-group:focus-within .label-icon{transform:scale(1.1)}.form-group label:not(.form-label-with-icon){display:block;font-size:1.15rem;margin-bottom:.75rem}.input-icon{transition:all .3s ease}.form-group input,.form-group select,.form-group textarea{background:#fff;font-size:1.15rem}.form-group:focus-within .input-icon{transform:scale(1.1)}.form-hint{align-items:center;color:#64748b;display:flex;font-size:1rem;gap:.375rem}.form-hint.warning-hint{color:#dc2626}.hint-icon{height:14px;width:14px}.radio-group{display:flex;gap:1rem;margin-top:.5rem}.radio-label{cursor:pointer;flex:1 1;transition:all .3s ease}.radio-label input[type=radio]{display:none}.radio-content{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#64748b;display:flex;font-size:1.1rem;font-weight:500;gap:.75rem;padding:1.25rem 1.5rem;transition:all .3s ease}.radio-icon{color:#94a3b8;height:20px;transition:all .3s ease;width:20px}.radio-label:hover .radio-content{background:#f8fafc;border-color:#1e3a5f;box-shadow:0 4px 12px #1e3a5f1a;transform:translateY(-2px)}.radio-label.active .radio-content{background:linear-gradient(135deg,#1e3a5f0d,#2c3e500d);border-color:#1e3a5f;box-shadow:0 4px 12px #1e3a5f26;color:#1e3a5f}.radio-label.active .radio-icon{color:#1e3a5f}.new-patient-section{background:linear-gradient(135deg,#f8fafc,#fff);border:2px solid #e2e8f0;border-radius:12px;margin-bottom:1.5rem;padding:1.75rem;transition:all .3s ease}.new-patient-section:hover{border-color:#1e3a5f;box-shadow:0 4px 12px #1e3a5f1a}.section-title{align-items:center;border-bottom:2px solid #e2e8f0;color:#1e3a5f;display:flex;font-size:1.25rem;font-weight:700;gap:.75rem;margin:0 0 1.5rem;padding-bottom:1rem}.section-icon{color:#1e3a5f;height:24px;width:24px}.modal-actions{background:#fff;border-top:1px solid #e2e8f0;bottom:0;position:-webkit-sticky;position:sticky;z-index:10}@media (max-width:991px){.public-header-content{padding:1rem 1.5rem}.scheduled-appointments-content,.scheduled-appointments-header{padding:1.5rem}.scheduled-appointments-header h1{font-size:1.75rem}.appointments-grid{gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width:767px){.public-header-content{flex-direction:column;gap:1rem;padding:1rem}.public-header-logo h2{font-size:1.25rem}.public-nav-link{justify-content:center;width:100%}.scheduled-appointments-content{padding:1rem}.scheduled-appointments-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:1.5rem}.header-actions{flex-direction:column;gap:.75rem;width:100%}.btn-book,.btn-home{justify-content:center;width:100%}.header-content{align-items:flex-start;flex-direction:column;gap:1rem}.scheduled-appointments-header h1{font-size:1.5rem}.appointments-grid{gap:1rem;grid-template-columns:1fr}.booking-modal{margin:1rem;max-width:95%}.modal-header{padding:1.5rem}.modal-header h2{font-size:1.85rem}.modal-subtitle{font-size:1rem}.booking-modal form{padding:1.5rem}.form-row{grid-template-columns:1fr}.radio-group{flex-direction:column;gap:.75rem}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}@media (max-width:575px){.public-header-content{padding:.875rem}.public-header-logo h2{font-size:1.125rem}.scheduled-appointments-content{padding:.75rem}.scheduled-appointments-header{padding:1.25rem}.scheduled-appointments-header h1{font-size:1.375rem}.btn-book{justify-content:center;width:100%}.appointment-card-body,.appointment-card-header{padding:1.25rem}.booking-modal{border-radius:0;height:100vh;margin:0;max-height:100vh;max-width:100%}.modal-header{padding:1.25rem}.modal-header h2{font-size:1.7rem}.booking-modal form,.new-patient-section{padding:1.25rem}.section-title{font-size:1.35rem}.form-group input,.form-group label:not(.form-label-with-icon),.form-group select,.form-group textarea,.form-label-with-icon{font-size:1.1rem}.form-hint{font-size:.95rem}}.medical-records-page{margin:0 auto;max-width:1400px;padding:2rem}.medical-records-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.medical-records-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.filter-group{flex:1 1;min-width:250px}.filter-group select{width:100%}.records-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.record-card{background-color:#fff;border-left:4px solid #007bff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;padding:1.5rem;transition:all .3s ease}.record-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.record-header{align-items:flex-start;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.record-patient-info{flex:1 1}.patient-name{color:#333;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.patient-details{color:#6c757d;font-size:.9rem}.patient-email{color:#007bff}.patient-phone,.record-date{color:#6c757d}.record-date{font-size:.875rem;margin-left:1rem;white-space:nowrap}.record-content{flex:1 1}.record-content,.record-section{margin-bottom:1rem}.record-section:last-child{margin-bottom:0}.record-label{color:#495057;display:block;font-size:.9rem;font-weight:600;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.record-diagnosis{border-left:3px solid #dc3545;color:#333;font-size:1rem;font-weight:500}.record-diagnosis,.record-notes{background-color:#f8f9fa;border-radius:4px;line-height:1.6;margin:0;padding:.75rem}.record-notes{word-wrap:break-word;border-left:3px solid #17a2b8;color:#555;font-size:.95rem;white-space:pre-wrap}.record-actions{border-top:1px solid #e9ecef;display:flex;gap:.5rem;padding-top:1rem}.modal-content{max-width:700px}@media (max-width:768px){.medical-records-page{padding:1rem}.medical-records-header{align-items:flex-start;flex-direction:column;gap:1rem}.filters-section{flex-direction:column}.filter-group{width:100%}.records-list{grid-template-columns:1fr}.record-header{flex-direction:column}.record-date{margin-left:0;margin-top:.5rem}.record-actions{flex-direction:column}.record-actions .btn{width:100%}.modal-content{margin:1rem;max-width:100%}}@media (max-width:480px){.records-list{grid-template-columns:1fr}}.notifications-page{margin:0 auto;max-width:1400px;padding:2rem}.notifications-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.notifications-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.btn{border-radius:6px;display:inline-block;font-size:1rem;font-weight:500}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3;box-shadow:0 4px 8px #007bff4d;transform:translateY(-1px)}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.btn-info{background-color:#17a2b8;color:#fff}.btn-info:hover{background-color:#138496}.btn-sm{padding:.4rem .8rem}.btn-edit{background-color:#28a745;color:#fff;margin-right:.5rem}.btn-edit:hover{background-color:#218838}.btn-delete{background-color:#dc3545}.btn-delete:hover{background-color:#c82333}.btn-mark-read{background-color:#17a2b8;color:#fff;margin-right:.5rem}.btn-mark-read:hover{background-color:#138496}.filters-section{background-color:#f8f9fa;border-radius:8px;padding:1rem}.filter-group select{border:1px solid #ddd;border-radius:4px;font-size:1rem;min-width:150px;padding:.5rem}.filter-group select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.filter-actions{align-items:flex-end;display:flex;gap:.5rem}.alert{border-radius:6px;margin-bottom:1rem;padding:1rem}.alert-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.notifications-list{display:flex;flex-direction:column;gap:1rem}.notification-item{align-items:flex-start;background-color:#fff;border-left:4px solid #6c757d;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;gap:1rem;justify-content:space-between;padding:1.5rem;transition:all .3s ease}.notification-item:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.notification-item.unread{background-color:#f8f9ff;border-left-width:5px;font-weight:500}.notification-type-info{border-left-color:#17a2b8}.notification-type-success{border-left-color:#28a745}.notification-type-warning{border-left-color:#ffc107}.notification-type-error{border-left-color:#dc3545}.notification-type-appointment{border-left-color:#6f42c1}.notification-type-reminder{border-left-color:#fd7e14}.notification-type-system{border-left-color:#6c757d}.notification-content{flex:1 1}.notification-header{margin-bottom:.75rem}.notification-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.5rem}.notification-type-badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.notification-type-info .notification-type-badge{background-color:#d1ecf1;color:#0c5460}.notification-type-success .notification-type-badge{background-color:#d4edda;color:#155724}.notification-type-warning .notification-type-badge{background-color:#fff3cd;color:#856404}.notification-type-error .notification-type-badge{background-color:#f8d7da;color:#721c24}.notification-type-appointment .notification-type-badge{background-color:#e2d9f3;color:#4a2c5a}.notification-type-reminder .notification-type-badge{background-color:#ffe5d0;color:#8b4513}.notification-type-system .notification-type-badge{background-color:#e2e3e5;color:#383d41}.notification-user{color:#495057;font-weight:600}.notification-date{color:#6c757d;font-size:.9rem}.unread-badge{background-color:#007bff;border-radius:12px;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;padding:.2rem .6rem}.notification-message{color:#333;font-size:1rem;line-height:1.6}.notification-item.unread .notification-message{font-weight:500}.notification-actions{display:flex;flex-shrink:0;gap:.5rem}.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-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h2{color:#333;font-size:1.5rem;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;font-size:2rem;height:30px;justify-content:center;padding:0;transition:all .2s ease;width:30px}.modal-close:hover{background-color:#f8f9fa;color:#333}.modal-content form{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;padding:.75rem;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.form-group textarea{min-height:100px}.form-hint{color:#6c757d;display:block;font-size:.875rem;margin-top:.5rem}.modal-actions{border-top:1px solid #dee2e6;display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem}@media (max-width:768px){.notifications-page{padding:1rem}.notifications-header{align-items:flex-start;flex-direction:column;gap:1rem}.filters-section{flex-direction:column}.filter-group,.filter-group select{width:100%}.filter-actions{flex-direction:column;width:100%}.filter-actions .btn{width:100%}.notification-item{flex-direction:column}.notification-actions{justify-content:flex-start;width:100%}.notification-actions .btn{flex:1 1}.notification-meta{align-items:flex-start;flex-direction:column;gap:.5rem}.modal-content{margin:1rem;max-width:100%}}.reports-page{margin:0 auto;max-width:1600px;padding:2rem}.reports-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.reports-header h1{color:#333;font-size:2rem;margin:0}.reports-actions{display:flex;gap:1rem}.report-type-selector{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.report-type-btn{align-items:center;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s}.report-type-btn:hover{background:#e9ecef;border-color:#4caf50;transform:translateY(-2px)}.report-type-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 12px #667eea4d;color:#fff}.report-type-icon{font-size:1.2rem}.reports-filters{background:#f8f9fa;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.reports-filters h3{color:#333;font-size:1.2rem;margin:0 0 1.5rem}.date-range-section{background:#fff;border:2px solid #4caf50;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.date-range-section h4{color:#333;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.quick-date-buttons{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.quick-date-btn{background:#e9ecef;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.quick-date-btn:hover{background:#4caf50;border-color:#4caf50;box-shadow:0 2px 8px #4caf504d;color:#fff;transform:translateY(-2px)}.custom-date-range{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1rem}.date-input{border:2px solid #ddd;border-radius:6px;font-size:.95rem;padding:.6rem;transition:border-color .2s;width:100%}.date-input:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a;outline:none}.date-range-display{background:#d4edda;border-left:4px solid #4caf50;border-radius:4px;color:#155724;font-size:.95rem;margin-top:.5rem;padding:.75rem}.filter-group label{color:#555;font-size:.9rem;font-weight:500}.filter-group input,.filter-group select{border:1px solid #ddd;border-radius:6px;padding:.5rem;transition:border-color .2s}.filter-group input:focus,.filter-group select:focus{border-color:#4caf50}.filters-actions{display:flex;gap:1rem;margin-top:1rem}.report-summary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.summary-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;text-align:center}.summary-card h3{color:#666;font-size:.9rem;font-weight:500;letter-spacing:.5px;margin:0 0 .5rem;text-transform:uppercase}.summary-value{color:#4caf50;font-size:2rem;font-weight:700;margin:0}.report-preview{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem}.report-preview h3{color:#333;font-size:1.2rem;margin:0 0 1rem}.preview-table-container{overflow-x:auto}.preview-table{border-collapse:collapse;font-size:.9rem;width:100%}.preview-table td,.preview-table th{border-bottom:1px solid #e0e0e0;padding:.75rem;text-align:left}.preview-table th{color:#333;font-weight:600;position:-webkit-sticky;position:sticky;top:0}.preview-table tbody tr:hover,.preview-table th{background-color:#f8f9fa}.status-badge{border-radius:12px;display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .75rem;text-transform:capitalize}.status-scheduled{background-color:#fff3cd;color:#856404}.status-confirmed{background-color:#d1ecf1;color:#0c5460}.status-completed{background-color:#d4edda;color:#155724}.status-cancelled{background-color:#f8d7da;color:#721c24}.status-no-show{background-color:#e2e3e5;color:#383d41}.loading,.no-data{color:#666}.preview-note{background:#fff3cd;border-left:4px solid #ffc107;border-radius:4px;color:#856404;font-size:.9rem;margin-top:1rem;padding:1rem}@media (max-width:768px){.reports-page{padding:1rem}.reports-header{align-items:flex-start}.report-type-selector,.reports-header{flex-direction:column}.report-type-btn{justify-content:center;width:100%}.filters-grid,.report-summary{grid-template-columns:1fr}.preview-table-container{overflow-x:scroll}}.contact-page{background:linear-gradient(135deg,#f8fafc,#e2e8f0);margin:0 auto;max-width:1400px;min-height:100vh;padding:2rem}.contact-navigation{animation:fadeIn .6s ease-out;display:flex;gap:1rem;justify-content:flex-end;margin-bottom:2rem}.nav-btn{align-items:center;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:inline-flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.nav-btn-home{background:#fff;border:2px solid #e2e8f0;color:#1e3a5f}.nav-btn-home:hover{background:#f8fafc;border-color:#1e3a5f;box-shadow:0 4px 12px #1e3a5f26;transform:translateY(-2px)}.nav-btn-login{background:linear-gradient(135deg,#1e3a5f,#2c3e50);border:2px solid #0000;color:#fff}.nav-btn-login:hover{box-shadow:0 4px 12px #1e3a5f59;transform:translateY(-2px)}.nav-btn-icon{height:18px;transition:transform .3s ease;width:18px}.nav-btn:hover .nav-btn-icon{transform:scale(1.1)}.contact-container{grid-gap:3rem;align-items:start;animation:fadeIn .6s ease-out;display:grid;gap:3rem;grid-template-columns:1fr 2fr}.contact-info-section{display:flex;flex-direction:column;gap:2rem}.contact-logo{animation:fadeIn .6s ease-out;display:flex;justify-content:center;margin-bottom:2rem}.contact-logo .hospital-logo-wrapper{border:none}.contact-logo .hospital-logo-wrapper,.contact-logo .hospital-logo-wrapper img{box-shadow:none!important;filter:none!important;text-shadow:none!important}.contact-title{color:#1e3a5f;font-size:2.5rem;font-weight:700;letter-spacing:-.5px;line-height:1.2;margin:0}.contact-description{color:#64748b;font-size:1rem;line-height:1.6;margin:0}.contact-cards{display:flex;flex-direction:column;gap:1rem}.contact-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 20px #00000014;display:flex;gap:1rem;padding:1.25rem;transition:all .3s ease}.contact-card:hover{border-color:#1e3a5f;box-shadow:0 8px 30px #1e3a5f26;transform:translateY(-4px)}.contact-icon-wrapper{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2c3e50);border-radius:10px;box-shadow:0 4px 12px #1e3a5f40;display:flex;flex-shrink:0;height:44px;justify-content:center;transition:all .3s ease;width:44px}.contact-card:hover .contact-icon-wrapper{box-shadow:0 6px 20px #1e3a5f59;transform:scale(1.1)}.contact-icon{color:#fff;height:22px;width:22px}.contact-details{flex:1 1}.contact-label{color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.5px;margin:0 0 .375rem;text-transform:uppercase}.contact-value{color:#1e3a5f;font-size:.9rem;font-weight:500;line-height:1.4;margin:0}.contact-form-section{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:2.5rem}.form-title{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0 0 .5rem}.form-instruction{color:#64748b;font-size:.95rem;line-height:1.6;margin:0 0 2rem}.contact-form{gap:1.5rem}.contact-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.75rem}.form-label-with-icon{align-items:center;color:#1e3a5f;display:flex;font-size:.9rem;font-weight:600;gap:.5rem}.label-icon{color:#1e3a5f;height:18px;width:18px}.form-group label:not(.form-label-with-icon){color:#1e3a5f;font-size:.9rem;font-weight:600}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#94a3b8;height:18px;left:1rem;pointer-events:none;position:absolute;transition:color .3s ease;width:18px;z-index:1}.input-icon.textarea-icon{align-self:flex-start;top:1rem}.form-group input,.form-group select,.form-group textarea{background-color:#fff;border:2px solid #e2e8f0;border-radius:12px;box-sizing:border-box;color:#1e3a5f;font-family:inherit;font-size:1rem;padding:.875rem 1rem .875rem 3rem;transition:all .3s ease;width:100%}.form-group textarea{min-height:120px;padding-top:1rem;resize:vertical}.form-group select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%231e3a5f' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;background-size:12px;cursor:pointer;padding-right:2.5rem}.form-group input::placeholder,.form-group textarea::placeholder{color:#94a3b8}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{background-color:#f8fafc;border-color:#cbd5e1}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background-color:#fff;border-color:#1e3a5f;box-shadow:0 0 0 4px #1e3a5f1a;outline:none}.form-group:focus-within .input-icon{color:#1e3a5f}.checkbox-group{margin-top:.5rem}.checkbox-label{align-items:flex-start;color:#475569;cursor:pointer;display:flex;font-size:.9rem;font-weight:400;gap:.75rem;line-height:1.5;transition:color .3s ease}.checkbox-label:hover{color:#1e3a5f}.checkbox-label input[type=checkbox]{accent-color:#1e3a5f;cursor:pointer;flex-shrink:0;height:20px;margin-top:2px;width:20px}.checkbox-label span{-webkit-user-select:none;user-select:none}.btn-submit{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2c3e50);border:none;border-radius:12px;box-shadow:0 4px 12px #1e3a5f40;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:.5rem;padding:1rem 2rem;transition:all .3s ease}.btn-submit:hover:not(:disabled){box-shadow:0 6px 20px #1e3a5f59;transform:translateY(-2px)}.btn-submit:active:not(:disabled){transform:translateY(0)}.btn-submit:disabled{cursor:not-allowed;opacity:.6}.btn-icon{height:18px;transition:transform .3s ease;width:18px}.btn-submit:hover:not(:disabled) .btn-icon:not(.spinner){transform:translateX(3px)}.alert{animation:slideDown .3s ease-out;border-radius:12px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-error{background:#fee2e2;border:1px solid #fecaca}.alert-success{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}@media (max-width:991px){.contact-navigation{justify-content:flex-end;margin-bottom:1.5rem}.contact-container{gap:2rem;grid-template-columns:1fr}.contact-info-section{order:2}.contact-form-section{order:1}.contact-title{font-size:2rem}.form-title{font-size:1.75rem}}@media (max-width:767px){.contact-page{padding:1.5rem}.contact-navigation{flex-direction:column;gap:.75rem}.nav-btn{justify-content:center;padding:.875rem 1.5rem;width:100%}.contact-title{font-size:1.75rem}.contact-description{font-size:.95rem}.contact-card{padding:1.5rem}.contact-icon-wrapper{height:48px;width:48px}.contact-icon{height:24px;width:24px}.contact-form-section{padding:1.5rem}.form-title{font-size:1.5rem}.form-instruction{font-size:.9rem}.form-group input,.form-group select,.form-group textarea{font-size:.95rem;padding:.75rem .875rem .75rem 2.75rem}.input-icon{height:16px;left:.875rem;width:16px}.btn-submit{font-size:.95rem;padding:.875rem 1.5rem}}@media (max-width:575px){.contact-page{padding:1rem}.contact-title{font-size:1.5rem}.contact-card{gap:1rem;padding:1.25rem}.contact-icon-wrapper{height:44px;width:44px}.contact-icon{height:22px;width:22px}.contact-label{font-size:.8rem}.contact-value{font-size:.9rem}.contact-form-section{padding:1.25rem}.form-title{font-size:1.375rem}.form-group label{font-size:.85rem}.label-icon{height:16px;width:16px}.checkbox-label{font-size:.85rem}.btn-submit{padding:1rem;width:100%}}.contacts-page{margin:0 auto;max-width:1600px;min-height:100vh;padding:2rem}.page-container{padding:0}.page-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem 2rem}.page-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;letter-spacing:-.5px;margin:0}.filters-section{align-items:flex-end;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.filter-group label{color:#495057;letter-spacing:.5px;text-transform:uppercase}.filter-group select{background:#fff;border:2px solid #e9ecef;border-radius:8px;font-size:.95rem;min-width:200px;padding:.75rem;transition:all .3s ease}.filter-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.alert-error{background:linear-gradient(135deg,#fff5f5,#ffe0e0);border-left:4px solid #dc3545;color:#c53030}.alert-success{background:linear-gradient(135deg,#f0fff4,#e0ffe0);border-left:4px solid #28a745;color:#22543d}.loading,.no-data{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;color:#6c757d;font-size:1.1rem;padding:4rem 2rem}.text-muted{color:#6c757d;font-style:italic}.table-container{-webkit-overflow-scrolling:touch;background-color:#fff;box-shadow:0 2px 12px #00000014;margin-top:1.5rem}.contacts-table{border-collapse:collapse;width:100%}.contacts-table thead{background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.contacts-table th{border-bottom:2px solid #dee2e6;color:#495057;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1.25rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.contacts-table td{border-bottom:1px solid #f1f3f5;color:#495057;padding:1.25rem 1rem;vertical-align:top}.contacts-table tbody tr{transition:all .2s ease}.contacts-table tbody tr:hover{background-color:#f8f9fa}.contacts-table tbody tr:last-child td{border-bottom:none}.contact-name{color:#1e3a5f;font-weight:600}.contact-email{color:#667eea;word-break:break-word}.contact-subject{color:#333;font-weight:500;max-width:200px}.contact-message{max-width:300px;position:relative}.message-preview{word-wrap:break-word;line-height:1.5;margin-bottom:.5rem}.btn-view-full{background:none;border:none;color:#667eea;cursor:pointer;font-size:.875rem;padding:.25rem .5rem;text-decoration:underline;transition:color .2s ease}.btn-view-full:hover{color:#5568d3}.service-badge{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:20px;color:#1e40af;display:inline-block;font-size:.75rem;font-weight:600;padding:.375rem .875rem;white-space:nowrap}.action-buttons{display:flex;gap:.5rem}.btn{align-items:center;border:none;box-shadow:0 2px 4px #0000001a;display:inline-flex;gap:.5rem;justify-content:center;letter-spacing:.3px;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-sm{font-size:.875rem;padding:.5rem 1rem}.btn-delete{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff}.btn-delete:hover{background:linear-gradient(135deg,#c82333,#bd2130);box-shadow:0 4px 8px #dc35454d;transform:translateY(-2px)}@media (max-width:991px){.contacts-page{padding:1.25rem}.page-header{padding:1.25rem 1.5rem}.page-header h1{font-size:1.75rem}.filters-section{align-items:stretch;flex-direction:column}.filter-group{width:100%}.filter-group select{min-width:100%;width:100%}.table-container{-webkit-overflow-scrolling:touch;border-radius:0;margin-left:-1.25rem;margin-right:-1.25rem;overflow-x:auto;width:calc(100% + 2.5rem)}.contacts-table{min-width:1000px}.contacts-table td,.contacts-table th{font-size:.875rem;padding:.875rem .75rem}.contacts-table th{font-size:.8rem}}@media (max-width:767px){.contacts-page{padding:1rem}.page-header{padding:1.25rem}.page-header h1{font-size:1.5rem}.filters-section{padding:1rem}.contacts-table{min-width:900px}.action-buttons{flex-direction:column;gap:.375rem}.action-buttons .btn{width:100%}}@media (max-width:575px){.contacts-page{padding:.75rem}.page-header{padding:1rem}.page-header h1{font-size:1.375rem}.table-container{margin-left:-.75rem;margin-right:-.75rem;width:calc(100% + 1.5rem)}.contacts-table{min-width:800px}.contacts-table th{font-size:.75rem;padding:.75rem .5rem}.contacts-table td{font-size:.8rem;padding:.75rem .5rem}.contact-message{max-width:200px}}.audit-logs-page{margin:0 auto;max-width:1800px;min-height:100vh;padding:2rem}.audit-logs-header{margin-bottom:2rem}.header-content{align-items:flex-start;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between}.audit-logs-header h1{color:#1e3a5f;font-size:2rem;font-weight:700;margin:0 0 .5rem}.page-subtitle{color:#64748b;font-size:1rem;margin:0 0 .5rem}.last-update{align-items:center;color:#94a3b8;display:flex;font-size:.875rem;gap:.5rem;margin:0}.monitoring-indicator{animation:pulse 2s infinite;color:#10b981;font-weight:600}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.search-input{border:2px solid #e2e8f0;transition:all .3s ease;width:250px}.search-input:focus{box-shadow:0 0 0 4px #1e3a5f1a}.btn-export,.btn-monitor{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-monitor{background:linear-gradient(135deg,#1e3a5f,#2c3e50);color:#fff}.btn-monitor:hover{box-shadow:0 4px 12px #1e3a5f4d;transform:translateY(-2px)}.btn-monitor.monitoring-active{background:linear-gradient(135deg,#dc2626,#991b1b)}.btn-monitor.monitoring-active:hover{box-shadow:0 4px 12px #dc26264d}.btn-export{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-export:hover{box-shadow:0 4px 12px #10b9814d;transform:translateY(-2px)}.export-icon,.monitor-icon{height:18px;width:18px}.filters-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:2rem;padding:1.5rem}.filters-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{color:#1e3a5f;font-size:.875rem;font-weight:600}.filter-group input,.filter-group select{border:2px solid #e2e8f0;border-radius:8px;font-family:inherit;font-size:.95rem;padding:.75rem;transition:all .3s ease}.filter-group input:focus,.filter-group select:focus{border-color:#1e3a5f;box-shadow:0 0 0 4px #1e3a5f1a;outline:none}.btn-clear-filters{margin-top:.5rem}.alert{align-items:center;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;font-weight:500;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.5rem}.alert-error{background:linear-gradient(135deg,#fee2e2,#fecaca);border-left:4px solid #dc2626;color:#991b1b}.alert-icon{flex-shrink:0;height:20px;width:20px}.table-header-info{background:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:12px 12px 0 0;padding:1rem 1.5rem}.log-count{color:#64748b;font-size:.875rem;font-weight:500}.endpoint-not-available{margin-bottom:2rem}.endpoint-message-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:12px;box-shadow:0 4px 12px #f59e0b26;padding:2rem;text-align:center}.endpoint-icon{color:#d97706;display:block;height:64px;margin:0 auto 1.5rem;width:64px}.endpoint-message-card h2{color:#92400e;font-size:1.5rem;font-weight:700;margin:0 0 1rem}.endpoint-message-card>p{color:#78350f;font-size:1rem;margin:0 0 1.5rem}.endpoint-info{background:#fff;border-radius:8px;margin-top:1.5rem;padding:1.5rem;text-align:left}.endpoint-info p{color:#78350f;font-size:.95rem;margin:0 0 .75rem}.endpoint-info p strong{color:#92400e}.endpoint-info ul{list-style-type:disc;margin:.75rem 0 1rem 1.5rem;padding:0}.endpoint-info li{color:#78350f;font-size:.9rem;margin-bottom:.5rem}.endpoint-info code{background:#fef3c7;border-radius:4px;color:#92400e;font-family:Courier New,monospace;font-size:.85rem;padding:.25rem .5rem}.endpoint-note{color:#92400e!important;font-style:italic;margin-top:1rem!important}.endpoint-note,.endpoint-troubleshoot{border-top:1px solid #fde68a;padding-top:1rem}.endpoint-troubleshoot{margin-top:1.5rem}.endpoint-troubleshoot p{color:#78350f;font-weight:600;margin:0 0 .75rem}.endpoint-troubleshoot ul{list-style-type:disc;margin:.5rem 0 0 1.5rem;padding:0}.endpoint-troubleshoot li{color:#78350f;font-size:.9rem;line-height:1.6;margin-bottom:.75rem}.endpoint-troubleshoot ol{list-style-type:decimal;margin:.5rem 0 0 1.5rem;padding:0}.endpoint-troubleshoot pre.code-block{background:#fef3c7;border:1px solid #f59e0b;border-radius:4px;color:#92400e;font-family:Courier New,monospace;font-size:.85rem;margin:.5rem 0;overflow-x:auto;padding:.5rem}.endpoint-debug{background:#fef3c7;border-left:3px solid #f59e0b;border-radius:4px;color:#78350f!important;font-size:.9rem;margin-top:1rem!important;padding:.75rem}.loading{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;gap:1rem;padding:3rem}.spinner{height:24px;width:24px}.loading,.no-data{color:#64748b;font-size:1.125rem;padding:3rem;text-align:center}.no-data{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.no-data-icon{height:64px;margin:0 auto 1rem;opacity:.5;width:64px}.no-data p{font-size:1rem;margin:0}.table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow-x:auto}.audit-logs-table{border-collapse:collapse;width:100%}.audit-logs-table th{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:2px solid #dee2e6;color:#495057;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1.25rem 1rem;position:-webkit-sticky;position:sticky;text-align:left;text-transform:uppercase;top:0;z-index:10}.audit-logs-table td{border-bottom:1px solid #e2e8f0;color:#555;font-size:.9rem;padding:1rem}.audit-logs-table tbody tr{transition:all .2s ease}.audit-logs-table tbody tr:hover{background-color:#f8fafc;box-shadow:0 2px 4px #0000000d;transform:scale(1.001)}.audit-logs-table tbody tr:last-child td{border-bottom:none}.timestamp-cell{color:#64748b;font-family:Courier New,monospace;font-size:.85rem;white-space:nowrap}.user-cell{color:#1e3a5f;font-weight:500}.entity-id-cell{color:#64748b;font-family:Courier New,monospace;font-size:.85rem}.description-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ip-cell{color:#64748b;font-family:Courier New,monospace;font-size:.85rem}.action-badge{border-radius:20px;box-shadow:0 2px 4px #0000001a;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.3px;padding:.375rem .875rem;text-transform:capitalize}.action-create{background-color:#d1fae5;color:#065f46}.action-update{background-color:#dbeafe;color:#1e40af}.action-delete{background-color:#fee2e2;color:#991b1b}.action-view{background-color:#f3e8ff;color:#6b21a8}.action-login{background-color:#d1fae5;color:#065f46}.action-logout{background-color:#fef3c7;color:#92400e}.action-default{background-color:#e5e7eb;color:#374151}.entity-badge{background-color:#e0e7ff;border-radius:20px;box-shadow:0 2px 4px #0000001a;color:#3730a3;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.3px;padding:.375rem .875rem;text-transform:capitalize}.btn{border:2px solid #0000;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-secondary{background:#fff;border-color:#1e3a5f;color:#1e3a5f}.btn-secondary:hover{background:#f8fafc;box-shadow:0 4px 12px #1e3a5f26;transform:translateY(-2px)}@media (max-width:991px){.audit-logs-page{padding:1.5rem}.filters-grid{grid-template-columns:1fr}.audit-logs-table{font-size:.85rem}.audit-logs-table td,.audit-logs-table th{padding:.75rem .5rem}.description-cell{max-width:200px}}@media (max-width:767px){.audit-logs-page{padding:1rem}.audit-logs-header h1{font-size:1.5rem}.table-container{overflow-x:auto}.audit-logs-table{min-width:800px}}.doctors-chat-page{background:#f8fafc;display:flex;flex-direction:column;height:calc(100vh - 60px)}.chat-header{background:linear-gradient(135deg,#1e3a5f,#2c3e50);box-shadow:0 2px 8px #0000001a;padding:1.5rem 2rem}.chat-header-content{margin:0 auto;max-width:1600px}.chat-header-info{align-items:center;color:#fff;display:flex;gap:1rem}.chat-header-info h1{font-size:1.75rem;font-weight:700;margin:0}.chat-header-info p{font-size:.95rem;margin:.25rem 0 0;opacity:.9}.chat-header-content{align-items:center;display:flex;justify-content:space-between}.chat-header-actions{align-items:center;display:flex;gap:1rem}.btn-back-dashboard{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;border-radius:8px;color:#fff;display:inline-flex;font-size:.95rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.btn-back-dashboard:hover{background:#ffffff40;border-color:#ffffff4d;transform:translateX(-3px)}.btn-back-dashboard .back-icon{height:18px;transition:transform .3s ease;width:18px}.btn-back-dashboard:hover .back-icon{transform:translateX(-2px)}.chat-error-banner{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 2rem}.chat-container{background:#fff;box-shadow:0 2px 12px #00000014;display:flex;flex:1 1;margin:0 auto;max-width:1600px;overflow:hidden;width:100%}.chat-sidebar{background:#f8fafc;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;width:320px}.chat-sidebar-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:1.5rem}.chat-sidebar-header h2{color:#1e3a5f;font-size:1.25rem;font-weight:700;margin:0 0 1rem}.search-box{align-items:center;display:flex;position:relative}.search-icon{color:#94a3b8;height:18px;left:.75rem;pointer-events:none;position:absolute;width:18px}.search-input{border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;padding:.75rem .75rem .75rem 2.5rem;transition:all .2s ease;width:100%}.search-input:focus{border-color:#1e3a5f;box-shadow:0 0 0 3px #1e3a5f1a;outline:none}.doctors-list{flex:1 1;overflow-y:auto;padding:.5rem}.doctor-item{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;margin-bottom:.5rem;padding:1rem;transition:all .2s ease}.doctor-item:hover{background:#e2e8f0}.doctor-avatar,.doctor-item.active{background:linear-gradient(135deg,#1e3a5f,#2c3e50);color:#fff}.doctor-avatar{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:1rem;font-weight:700;height:48px;justify-content:center;width:48px}.doctor-item.active .doctor-avatar{background:#fff3}.doctor-info{flex:1 1;min-width:0}.doctor-name{font-size:.95rem;font-weight:600;margin-bottom:.25rem}.doctor-name,.doctor-specialization{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doctor-specialization{font-size:.85rem;opacity:.7}.no-doctors{color:#94a3b8;padding:2rem;text-align:center}.chat-main{background:#fff;display:flex;flex:1 1;flex-direction:column}.chat-messages-header{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.chat-messages-header-info{align-items:center;display:flex;gap:.75rem}.chat-avatar{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2c3e50);border-radius:50%;color:#fff;display:flex;font-size:.9rem;font-weight:700;height:40px;justify-content:center;width:40px}.chat-messages-header-info h3{color:#1e3a5f;font-size:1rem;font-weight:600;margin:0}.chat-status{color:#10b981;font-size:.85rem;font-weight:500;margin:0}.chat-messages{background:#f8fafc;display:flex;flex:1 1;flex-direction:column;gap:1rem;overflow-y:auto;padding:1.5rem}.message{animation:fadeIn .3s ease;display:flex;max-width:70%}.message-sent{align-self:flex-end;flex-direction:row-reverse}.message-received{align-self:flex-start}.message-content{border-radius:12px;padding:.75rem 1rem;position:relative}.message-sent .message-content{background:linear-gradient(135deg,#1e3a5f,#2c3e50);border-bottom-right-radius:4px;color:#fff}.message-received .message-content{background:#fff;border:1px solid #e2e8f0;border-bottom-left-radius:4px;color:#1e3a5f}.message-content p{word-wrap:break-word;line-height:1.5;margin:0 0 .25rem}.message-time{display:block;font-size:.75rem;opacity:.7}.no-messages{align-items:center;color:#94a3b8;display:flex;height:100%;justify-content:center}.chat-input-form{background:#fff;border-top:1px solid #e2e8f0;display:flex;gap:.75rem;padding:1rem 1.5rem}.chat-input{border:1px solid #e2e8f0;border-radius:24px;flex:1 1;font-size:.95rem;padding:.75rem 1rem;transition:all .2s ease}.chat-input:focus{border-color:#1e3a5f;box-shadow:0 0 0 3px #1e3a5f1a;outline:none}.chat-send-btn{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2c3e50);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:44px;justify-content:center;transition:all .2s ease;width:44px}.chat-send-btn:hover:not(:disabled){box-shadow:0 4px 12px #1e3a5f4d;transform:scale(1.05)}.chat-send-btn:disabled{cursor:not-allowed;opacity:.5}.chat-send-btn svg,.spinner{height:20px;width:20px}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.chat-placeholder{align-items:center;background:#f8fafc;display:flex;flex:1 1;justify-content:center}.placeholder-content{color:#94a3b8;text-align:center}.placeholder-icon{height:80px;margin:0 auto 1.5rem;opacity:.5;width:80px}.placeholder-content h2{color:#64748b;font-size:1.5rem;margin:0 0 .5rem}.placeholder-content p{font-size:1rem;margin:0}.loading{align-items:center;color:#64748b;display:flex;font-size:1.1rem;height:100vh;justify-content:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.chat-container{flex-direction:column}.chat-sidebar{border-bottom:1px solid #e2e8f0;border-right:none;height:200px;width:100%}.chat-main{flex:1 1}.message{max-width:85%}.chat-header-info h1{font-size:1.5rem}}
/*# sourceMappingURL=main.8b2ac2f8.css.map*/