@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600;700&display=swap);.login-page{display:flex;flex-direction:column;font-family:Inter,sans-serif;min-height:100vh}.login-container{align-items:center;background:linear-gradient(135deg,#f0fdfa,#ccfbf1 50%,#a7f3d0);display:flex;flex:1 1;justify-content:center;min-height:calc(100vh - 200px);overflow:hidden;padding:40px 20px;position:relative}.background-decoration{height:100%;left:0;overflow:hidden;position:absolute;top:0;width:100%;z-index:1}.floating-shape{animation:float 8s ease-in-out infinite;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:linear-gradient(135deg,#ffffff26,#b2dfdb1f 50%,#80cbc41a);border-radius:50%;box-shadow:0 8px 32px #ffffff1a,inset 0 1px 0 #fff6,0 0 0 1px #ffffff1a;position:absolute}.shape-1{animation-delay:0s;background:linear-gradient(135deg,#b2dfdb33,#80cbc426 50%,#4db6ac1a);box-shadow:0 12px 40px #b2dfdb26,inset 0 2px 0 #ffffff80;height:350px;left:-175px;top:-175px;width:350px}.shape-2{animation:floatReverse 10s ease-in-out infinite;animation-delay:2s;background:linear-gradient(135deg,#80cbc42e,#4db6ac24 50%,#26a69a1a);box-shadow:0 10px 35px #80cbc41f,inset 0 1px 0 #fff6;height:250px;right:-125px;top:55%;width:250px}.shape-3{animation:pulse-bubble 7s ease-in-out infinite;animation-delay:1s;background:linear-gradient(135deg,#4db6ac29,#26a69a1f 50%,#00968814);bottom:15%;box-shadow:0 8px 30px #4db6ac1a,inset 0 1px 0 #ffffff4d;height:180px;left:8%;width:180px}@keyframes float{0%,to{transform:translateY(0) rotate(0deg) scale(1)}33%{transform:translateY(-30px) rotate(120deg) scale(1.05)}66%{transform:translateY(-15px) rotate(240deg) scale(.95)}}@keyframes floatReverse{0%,to{transform:translateY(0) rotate(1turn) scale(1)}50%{transform:translateY(25px) rotate(180deg) scale(1.1)}}@keyframes pulse-bubble{0%,to{opacity:.8;transform:scale(1) rotate(0deg)}25%{opacity:1;transform:scale(1.15) rotate(90deg)}50%{opacity:.6;transform:scale(.9) rotate(180deg)}75%{opacity:.9;transform:scale(1.05) rotate(270deg)}}.shape-4{animation:float 9s ease-in-out infinite;animation-delay:3s;background:linear-gradient(135deg,#ffffff1f,#b2dfdb14);box-shadow:0 6px 25px #ffffff14;height:120px;right:15%;top:10%;width:120px}.shape-5{animation:pulse-bubble 6s ease-in-out infinite;animation-delay:5s;background:linear-gradient(135deg,#80cbc424,#4db6ac1a);bottom:40%;box-shadow:0 4px 20px #80cbc40f;height:80px;right:20%;width:80px}.shape-6{animation:floatReverse 11s ease-in-out infinite;animation-delay:7s;background:linear-gradient(135deg,#4db6ac1a,#26a69a0f);box-shadow:0 3px 15px #4db6ac0a;height:60px;left:20%;top:30%;width:60px}.login-box{animation:slideUp .8s ease-out;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:linear-gradient(145deg,#fffffff7,#f8fdfff0 30%,#f1fbfeeb 70%,#ebf8fee3);border:1px solid #e2e8f099;border-radius:24px;box-shadow:0 20px 40px #00000014,0 10px 20px #0000000d,inset 0 1px 0 #fffc,0 0 0 1px #10b98114;max-width:480px;padding:48px;position:relative;width:100%;z-index:2}.login-box:before{background:linear-gradient(145deg,#f0fdf44d,#ecfdf533 30%,#d1fae51a 70%,#a7f3d00d);border-radius:24px;bottom:-1px;content:"";left:-1px;opacity:0;position:absolute;right:-1px;top:-1px;transition:opacity .3s ease;z-index:-1}@media (prefers-color-scheme:light){.login-box:before{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-header{margin-bottom:40px;text-align:center}.medical-icon{height:80px;justify-content:flex-start;margin:0 auto 20px;width:220px}.heartbeat-container,.medical-icon{align-items:center;display:flex;position:relative}.heartbeat-container{height:50px;justify-content:center;width:50px;z-index:3}.heart-icon{animation:heartbeat 1.5s infinite;color:#e53e3e;filter:drop-shadow(0 4px 8px rgba(229,62,62,.4));height:40px;width:40px;z-index:3}.pulse-ring{animation:pulse-ring 2s ease-out infinite;border:2px solid #e53e3e66;border-radius:50%;height:60px;position:absolute;width:60px}.pulse-ring-2{animation-delay:1s;border-color:#f565654d}.medical-cross{align-items:center;animation:bounce 2s infinite;background:linear-gradient(135deg,#10b981,#059669);border-radius:8px;box-shadow:0 4px 12px #10b98166,inset 0 1px 0 #ffffff4d;display:flex;height:24px;justify-content:center;position:absolute;right:-5px;top:-5px;width:24px;z-index:4}.cross-icon{color:#fff;height:14px;width:14px}.ecg-wave{height:40px;left:85px;overflow:hidden;position:absolute;top:50%;transform:translateY(-50%);width:120px;z-index:2}.ecg-svg{color:#10b981;filter:drop-shadow(0 2px 4px rgba(16,185,129,.3));height:100%;width:100%}.ecg-line{stroke-dasharray:200;stroke-dashoffset:200}.ecg-line,.ecg-line-animated{animation:ecg-draw 3s linear infinite}.ecg-line-animated{stroke:#e53e3e;stroke-dasharray:200;stroke-dashoffset:200;animation-delay:.5s;opacity:.7}.ecg-wave:before{background-image:linear-gradient(#10b9811a 1px,#0000 0),linear-gradient(90deg,#10b9811a 1px,#0000 0);background-size:10px 10px;content:"";height:100%;left:0;position:absolute;top:0;width:100%;z-index:-1}@keyframes heartbeat{0%,to{transform:scale(1)}5%{transform:scale(1.15)}10%{transform:scale(1.05)}15%{transform:scale(1.25)}20%{transform:scale(1)}}@keyframes pulse-ring{0%{opacity:1;transform:scale(.7)}to{opacity:0;transform:scale(1.8)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0) rotate(0deg)}40%{transform:translateY(-6px) rotate(5deg)}60%{transform:translateY(-3px) rotate(-5deg)}}@keyframes ecg-draw{0%{stroke-dashoffset:200;opacity:0}10%{opacity:1}to{stroke-dashoffset:0;opacity:.3}}.login-box h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#065f46,#047857 50%,#059669);-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px;text-shadow:0 2px 4px #10b9811a}.subtitle{color:#065f46;font-size:15px;font-weight:500;line-height:1.5;margin:0;text-shadow:0 1px 2px #0000001a}.login-form{margin-bottom:32px}.input-group{margin-bottom:20px;position:relative}.input-icon{color:#a0aec0;height:20px;left:16px;position:absolute;top:50%;transform:translateY(-50%);transition:color .3s ease;width:20px;z-index:3}.input-icon svg{height:100%;width:100%}.login-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #e2e8f0;border-radius:12px;color:#1a202c;font-size:16px;font-weight:400;outline:none;padding:16px 16px 16px 48px;position:relative;transition:all .3s ease;width:100%}.login-input:focus{background:#f0fdf4cc;border-color:#10b981;box-shadow:0 0 0 3px #10b98126,0 4px 12px #10b9811a;transform:translateY(-1px)}.login-input.has-value+.input-icon,.login-input:focus+.input-icon{color:#10b981}.login-input::placeholder{color:#a0aec0;transition:color .3s ease}.login-input:focus::placeholder{color:#0000}.login-input:disabled{background:#f7fafc;cursor:not-allowed;opacity:.7}.password-toggle{background:none;border:none;color:#a0aec0;cursor:pointer;height:20px;padding:0;position:absolute;right:16px;top:50%;transform:translateY(-50%);transition:color .3s ease;width:20px;z-index:3}.password-toggle:hover{color:#00796b}.password-toggle svg{height:100%;width:100%}.login-button{align-items:center;background:linear-gradient(135deg,#10b981,#059669 25%,#047857 75%,#065f46);border:none;border-radius:12px;box-shadow:0 6px 20px #10b9814d,0 2px 6px #05966933;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;overflow:hidden;padding:16px;position:relative;transition:all .3s ease;width:100%}.login-button:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s;width:100%}.login-button:hover:before{left:100%}.login-button:hover{background:linear-gradient(135deg,#34d399,#10b981 25%,#059669 75%,#047857);box-shadow:0 12px 30px #10b98180,0 6px 15px #0596694d;transform:translateY(-2px)}.login-button:active{transform:translateY(0)}.login-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.login-button.loading{pointer-events:none}.login-button svg,.spinner{height:18px;width:18px}.spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff}.error-message{align-items:center;animation:shake .5s ease-in-out;background:#feb2b21a;border:1px solid #fc818133;border-radius:8px;color:#c53030;display:flex;gap:8px;margin-top:16px;padding:12px 16px}.error-message svg{flex-shrink:0;height:16px;width:16px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.login-footer{border-top:1px solid #e2e8f0;padding-top:24px;text-align:center}.login-footer p{color:#718096;font-size:13px;font-weight:400;margin:0}@media (max-width:640px){.login-container{min-height:calc(100vh - 150px);min-height:calc(100vh - 80px);padding:20px 16px;padding:20px}.login-box{border-radius:20px;margin:20px 0;padding:32px 24px}.medical-icon{height:56px;margin-bottom:16px;width:56px}.medical-icon svg{height:28px;width:28px}.login-box h2{font-size:24px}.subtitle{font-size:14px}.login-input{font-size:15px;padding:14px 14px 14px 44px}.login-button{font-size:15px;padding:14px}.floating-shape{opacity:.5}.shape-1{height:200px;width:200px}.shape-2{height:150px;width:150px}.shape-3{height:100px;width:100px}}@media (max-width:480px){.login-container{min-height:calc(100vh - 120px);padding:16px 12px}.login-box{padding:24px 20px}.login-box h2{font-size:22px}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.login-box{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px)}}@media (prefers-color-scheme:dark){.login-box{background:#1a202cf2;border:1px solid #ffffff1a}.login-box h2{color:#f7fafc}.subtitle{color:#a0aec0}.login-input{background:#2d3748cc;border-color:#4a5568;color:#f7fafc}.login-input:focus{background:#2d3748e6;border-color:#667eea}.login-footer p{color:#a0aec0}}.role-selection{margin-bottom:32px}.role-title{color:#1a202c;font-size:16px;font-weight:600;margin-bottom:16px;text-align:center;text-shadow:0 1px 2px #0000001a}.role-options{display:flex;gap:16px;justify-content:center}.role-option{cursor:pointer;flex:1 1;max-width:180px}.role-option input[type=radio]{display:none}.role-card{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:linear-gradient(135deg,#f8fafcfa,#f1f5f9f2);border:2px solid #cbd5e1cc;border-radius:12px;box-shadow:0 4px 12px #0000000d;overflow:hidden;padding:16px 12px;position:relative;text-align:center;transition:all .3s ease}.role-card:before{background:linear-gradient(90deg,#0000,#00796b1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.role-option.selected .role-card{background:linear-gradient(135deg,#e8f5e8,#d4edda);border-color:#00796b;box-shadow:0 4px 12px #00796b33;transform:translateY(-2px)}.role-option.selected .role-card:before{left:100%}.role-option:hover .role-card{border-color:#00796b;box-shadow:0 2px 8px #00796b1a;transform:translateY(-1px)}.role-icon{align-items:center;border-radius:50%;display:flex;height:40px;justify-content:center;margin:0 auto 12px;transition:all .3s ease;width:40px}.patient-icon{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.insurance-icon{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.role-option.selected .role-icon{box-shadow:0 4px 12px #0003;transform:scale(1.1)}.role-icon svg{height:20px;width:20px}.role-name{color:#1a202c;font-size:14px;font-weight:600;margin-bottom:4px;text-shadow:0 1px 2px #0000001a}.role-desc{color:#4a5568;font-size:12px;line-height:1.3;text-shadow:0 1px 1px #0000000d}.role-option.selected .role-name{color:#00796b}.role-option.selected .role-desc{color:#495057}@media (max-width:480px){.role-options{flex-direction:column;gap:12px}.role-option{max-width:100%}.role-card{padding:14px 10px}.role-icon{height:36px;margin-bottom:10px;width:36px}.role-icon svg{height:18px;width:18px}.role-name{font-size:13px}.role-desc{font-size:11px}}.app-footer{background:linear-gradient(135deg,#00796b,#004d40);box-shadow:0 -4px 20px #00796b26;color:#fff;font-family:Roboto,sans-serif;margin-top:20px;padding:32px 0 16px}.footer-container{margin:0 auto;max-width:1000px;padding:0 20px}.footer-content{display:flex;flex-direction:column;gap:32px}.footer-main{grid-gap:40px;align-items:start;display:grid;gap:40px;grid-template-columns:1fr 2fr}.footer-logo{gap:16px}.footer-logo,.medical-symbol{align-items:center;display:flex}.medical-symbol{animation:pulse 2s infinite;background:#ffffff26;border-radius:12px;height:48px;justify-content:center;width:48px}.medical-symbol svg{color:#ff6b6b;height:28px;width:28px}.footer-title h4{color:#fff;font-size:20px;font-weight:700;margin:0 0 4px}.footer-title span{color:#fffc;font-size:14px;font-weight:400}.footer-info{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.footer-section h5{color:#b2dfdb;font-size:16px;font-weight:600;margin:0 0 12px}.footer-section p{color:#ffffffe6;font-size:14px;line-height:1.5;margin:8px 0}.footer-section a{color:#4fc3f7;font-weight:500;text-decoration:none;transition:color .3s ease}.footer-section a:hover{color:#81d4fa;text-decoration:underline}.footer-bottom{align-items:center;border-top:1px solid #fff3;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding-top:24px}.footer-copyright p{color:#fffc;font-size:13px;line-height:1.4;margin:4px 0}.footer-copyright strong{color:#fff;font-weight:600}.footer-copyright a{color:#4fc3f7;font-weight:500;text-decoration:none}.footer-copyright a:hover{color:#81d4fa;text-decoration:underline}.footer-badges{align-items:center;display:flex;gap:12px}.security-badge,.verified-badge{background:#ffffff1a;border:1px solid #fff3;border-radius:20px;color:#fff;font-size:12px;font-weight:500;padding:6px 12px;transition:all .3s ease}.security-badge:hover,.verified-badge:hover{background:#fff3;transform:translateY(-1px)}.verified-badge{background:#4caf5033;border-color:#4caf5066;color:#c8e6c9}@media (max-width:768px){.app-footer{margin-top:16px;padding:24px 0 12px}.footer-container{padding:0 15px}.footer-main{gap:24px;grid-template-columns:1fr;text-align:center}.footer-logo{justify-content:center}.footer-info{gap:24px;grid-template-columns:1fr;text-align:center}.footer-bottom{flex-direction:column;gap:16px;text-align:center}.footer-badges{flex-wrap:wrap;justify-content:center}}@media (max-width:480px){.app-footer{margin-top:12px;padding:20px 0 10px}.footer-container{padding:0 10px}.footer-content{gap:20px}.footer-title h4{font-size:18px}.footer-title span{font-size:13px}.footer-section h5{font-size:15px}.footer-section p{font-size:13px}.footer-copyright p{font-size:12px}.security-badge,.verified-badge{font-size:11px;padding:4px 8px}}body{background-color:#f0f2f5;color:#333;font-family:Roboto,sans-serif;margin:0;min-height:100vh;padding:20px}.dashboard-container{background-color:#fff;border:1px solid #e1e5e9;border-radius:16px;box-shadow:0 8px 32px #0000000f;margin:0 auto;max-width:1200px;min-height:calc(100vh - 80px);padding:24px}.dashboard-content{max-width:100%;width:100%}.account-info{border-radius:8px;font-size:14px;margin:0 0 16px;padding:10px 14px}.account-role{font-size:13px}.header-left{flex:1 1;gap:16px}.header-right{gap:20px}.hospital-logo{border-radius:12px;box-shadow:0 2px 8px #0000001a;flex-shrink:0;height:80px;object-fit:contain;padding:1px;width:80px}.hospital-info{text-align:left}.hospital-name{line-height:1.2;margin-bottom:4px}.hospital-address{margin-bottom:2px}.hospital-address,.hospital-phone{line-height:1.3;opacity:.9}.logout-button{background:#ffffff1a;border:2px solid #ffffff40;border-radius:10px;padding:10px 18px}.logout-button:hover{background:#fff3;border-color:#fff6;transform:translateY(-1px)}.main-content{padding:0}.diagnosis-section,.history-section,.patient-info,.results-section,.services-section,.tests-section{background:linear-gradient(135deg,#fff,#fafbfc);border:1px solid #e8eaed;border-radius:16px;box-shadow:0 4px 16px #00796b14;margin-bottom:28px;overflow:hidden;padding:32px;position:relative;transition:all .3s ease}.diagnosis-section:hover,.history-section:hover,.patient-info:hover,.results-section:hover,.services-section:hover,.tests-section:hover{box-shadow:0 8px 24px #00796b1f;transform:translateY(-2px)}.diagnosis-section h3,.history-section h3,.patient-info h2,.results-section h3,.services-section h3,.tests-section h3{border-bottom:3px solid #e0f2f1;color:#00695c;font-size:20px;font-weight:700;margin-bottom:24px;margin-top:0;padding-bottom:12px;position:relative}.diagnosis-section h3:after,.history-section h3:after,.patient-info h2:after,.results-section h3:after,.services-section h3:after,.tests-section h3:after{background:linear-gradient(135deg,#00796b,#004d40);border-radius:2px;bottom:-3px;content:"";height:3px;left:0;position:absolute;width:60px}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:16px}.info-grid div{background:#fff;border:1px solid #e0f2f1;border-radius:8px;font-size:16px;padding:12px 16px}.info-grid div strong{color:#00695c;font-weight:600}.service-list{list-style:none;margin:0;padding:0}.service-list li{align-items:center;background:#fff;border:1px solid #e0f2f1;border-radius:12px;box-shadow:0 2px 8px #0000000a;display:flex;justify-content:space-between;margin-bottom:12px;padding:16px 20px;transition:all .3s ease}.service-list li:hover{background:linear-gradient(135deg,#f8fffe,#e0f2f1);box-shadow:0 4px 12px #00796b14;transform:translateX(4px)}.service-name{color:#00695c;flex:1 1;font-size:15px;font-weight:600}.service-date{background:#e0f2f1;border-radius:20px;color:#666;font-size:15px;font-weight:500;padding:6px 12px}.history-table,.results-table,.services-table,.tests-table{background:#fff;border:1px solid #e8eaed;border-collapse:collapse;border-radius:12px;box-shadow:0 4px 16px #0000000f;margin-top:20px;overflow:hidden;width:100%}.history-table th,.results-table th,.services-table th,.tests-table th{background:linear-gradient(135deg,#00796b,#004d40);color:#fff;font-size:15px;font-weight:600;letter-spacing:.5px;padding:18px 16px;text-align:center;text-transform:uppercase}.history-table td,.results-table td,.services-table td,.tests-table td{word-wrap:break-word;border-bottom:1px solid #f0f4f3;color:#333;font-size:14px;-webkit-hyphens:auto;hyphens:auto;line-height:1.4;padding:16px;vertical-align:middle;word-break:break-word}.history-table td:first-child,.results-table td:first-child,.services-table td:first-child,.tests-table td:first-child{color:#2d3748;font-weight:500}.history-table td:not(:first-child):not(:last-child),.results-table td:not(:first-child):not(:last-child),.services-table td:not(:first-child):not(:last-child),.tests-table td:not(:first-child):not(:last-child){max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-table td:not(:first-child):not(:last-child):hover,.results-table td:not(:first-child):not(:last-child):hover,.services-table td:not(:first-child):not(:last-child):hover,.tests-table td:not(:first-child):not(:last-child):hover{background:#fff;box-shadow:0 4px 8px #00000026;overflow:visible;position:relative;white-space:normal;z-index:10}.history-table td:last-child,.history-table th:last-child,.results-table td:last-child,.results-table th:last-child,.services-table td:last-child,.services-table th:last-child,.tests-table td:last-child,.tests-table th:last-child{max-width:140px;min-width:140px;text-align:center;width:140px}.history-table tbody tr:hover,.results-table tbody tr:hover,.services-table tbody tr:hover,.tests-table tbody tr:hover{background:linear-gradient(135deg,#f8fffe,#e8f5e8);transform:scale(1.01);transition:all .2s ease}.history-table tbody tr:last-child td,.results-table tbody tr:last-child td,.services-table tbody tr:last-child td,.tests-table tbody tr:last-child td{border-bottom:none}.download-button,.view-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;justify-content:center;min-width:120px;padding:10px 16px;text-decoration:none;transition:all .3s ease}.view-button{background:linear-gradient(135deg,#2196f3,#1976d2);box-shadow:0 2px 8px #2196f34d;color:#fff}.view-button:hover{background:linear-gradient(135deg,#1976d2,#1565c0);box-shadow:0 4px 12px #2196f366;transform:translateY(-2px)}.download-button{background:linear-gradient(135deg,#4caf50,#388e3c);box-shadow:0 2px 8px #4caf504d;color:#fff}.download-button:hover{background:linear-gradient(135deg,#388e3c,#2e7d32);box-shadow:0 4px 12px #4caf5066;transform:translateY(-2px)}.download-button:active,.view-button:active{transform:translateY(0)}.pagination{align-items:center;display:flex;gap:8px;justify-content:center;margin-top:24px}.pagination li{list-style:none}.pagination li a{border:1px solid #ddd;border-radius:6px;color:#666;font-size:14px;font-weight:500;padding:8px 12px;text-decoration:none;transition:all .2s ease}.pagination li a:hover{background-color:#f5f5f5;border-color:#00796b;color:#00796b}.pagination li.active a{background-color:#00796b;border-color:#00796b;color:#fff}.pagination li.disabled a{color:#ccc;cursor:not-allowed}.error-container{background-color:#fff5f5;border:1px solid #fed7d7;border-radius:12px;color:#c53030}.error-container,.loading{padding:40px;text-align:center}.loading{color:#666;font-size:16px}.diagnosis-section div{background:#fff;border:1px solid #e0f2f1;border-radius:8px;margin-bottom:12px;padding:16px}.diagnosis-section div:last-child{margin-bottom:0}.diagnosis-section p{font-size:16px;line-height:1.4;margin:6px 0}.diagnosis-section strong{color:#00695c;font-weight:600}@media (max-width:768px){body{padding:12px}.dashboard-container{border-radius:12px;margin:0;min-height:calc(100vh - 40px);padding:20px}.dashboard-header{align-items:center;flex-direction:column;gap:16px;padding:20px;text-align:center}.header-left,.header-right{justify-content:center;width:100%}.header-right{flex-direction:column;gap:16px}.hospital-info{text-align:center}.hospital-logo{height:50px;width:50px}.hospital-name{font-size:19px}.hospital-address,.hospital-phone{font-size:14px}.diagnosis-section,.history-section,.patient-info,.results-section,.services-section,.tests-section{margin-bottom:20px;padding:20px}.info-grid{gap:12px;grid-template-columns:1fr}.history-table,.results-table,.services-table,.tests-table{-webkit-overflow-scrolling:touch;border-collapse:collapse;display:block;font-size:13px;min-width:100%;overflow-x:auto;table-layout:auto;white-space:nowrap;width:100%}.history-table thead,.results-table thead,.services-table thead,.tests-table thead{display:table-header-group;width:100%}.history-table tbody,.results-table tbody,.services-table tbody,.tests-table tbody{display:table-row-group;width:100%}.history-table tr,.results-table tr,.services-table tr,.tests-table tr{display:table-row;width:100%}.history-table th,.results-table th,.services-table th,.tests-table th{word-wrap:break-word;display:table-cell;font-size:11px;line-height:1.2;min-width:80px;padding:10px 4px;vertical-align:middle;white-space:normal}.history-table td,.results-table td,.services-table td,.tests-table td{word-wrap:break-word;display:table-cell;font-size:12px;-webkit-hyphens:auto;hyphens:auto;line-height:1.3;min-width:80px;overflow-wrap:break-word;padding:10px 4px;vertical-align:middle;white-space:normal;word-break:break-word}.history-table th:first-child,.results-table th:first-child,.services-table th:first-child,.tests-table th:first-child{min-width:140px;width:140px}.history-table td:first-child,.results-table td:first-child,.services-table td:first-child,.tests-table td:first-child{color:#2d3748;font-weight:600;min-width:140px;width:140px}.history-table th:not(:first-child):not(:last-child),.results-table th:not(:first-child):not(:last-child),.services-table th:not(:first-child):not(:last-child),.tests-table th:not(:first-child):not(:last-child){min-width:90px;width:90px}.history-table td:not(:first-child):not(:last-child),.results-table td:not(:first-child):not(:last-child),.services-table td:not(:first-child):not(:last-child),.tests-table td:not(:first-child):not(:last-child){font-size:11px;min-width:90px;width:90px}.history-table th:last-child,.results-table th:last-child,.services-table th:last-child,.tests-table th:last-child{background:linear-gradient(135deg,#00796b,#004d40);min-width:110px;position:-webkit-sticky;position:sticky;right:0;width:110px;z-index:2}.history-table td:last-child,.results-table td:last-child,.services-table td:last-child,.tests-table td:last-child{background:#fff;box-shadow:-2px 0 4px #0000001a;min-width:110px;position:-webkit-sticky;position:sticky;right:0;text-align:center;width:110px;z-index:1}.download-button,.view-button{border-radius:6px;display:inline-block;font-size:11px;min-width:85px;padding:6px 8px;text-align:center;white-space:nowrap}.history-section,.results-section,.services-section,.tests-section{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (max-width:480px){body{padding:8px}.dashboard-container{border-radius:10px;padding:16px}.dashboard-header{padding:16px}.hospital-name{font-size:17px}.hospital-logo{height:44px;width:44px}.diagnosis-section,.history-section,.patient-info,.results-section,.services-section,.tests-section{margin-bottom:16px;padding:16px}.history-table,.results-table,.services-table,.tests-table{border-collapse:collapse;display:table;font-size:11px;overflow-x:auto;table-layout:fixed;white-space:normal;width:100%}.history-table thead,.results-table thead,.services-table thead,.tests-table thead{display:table-header-group}.history-table tbody,.results-table tbody,.services-table tbody,.tests-table tbody{display:table-row-group}.history-table tr,.results-table tr,.services-table tr,.tests-table tr{display:table-row}.history-table th,.results-table th,.services-table th,.tests-table th{word-wrap:break-word;display:table-cell;font-size:10px;font-weight:700;line-height:1.2;padding:8px 2px;text-align:center;vertical-align:middle;white-space:normal}.history-table td,.results-table td,.services-table td,.tests-table td{word-wrap:break-word;display:table-cell;font-size:10px;-webkit-hyphens:auto;hyphens:auto;line-height:1.3;overflow-wrap:break-word;padding:8px 2px;text-align:center;vertical-align:middle;white-space:normal;word-break:break-word}.history-table th:first-child,.results-table th:first-child,.services-table th:first-child,.tests-table th:first-child{min-width:120px;text-align:left;width:35%}.history-table td:first-child,.results-table td:first-child,.services-table td:first-child,.tests-table td:first-child{color:#2d3748;font-size:11px;font-weight:600;min-width:120px;text-align:left;width:35%}.history-table th:not(:first-child):not(:last-child),.results-table th:not(:first-child):not(:last-child),.services-table th:not(:first-child):not(:last-child),.tests-table th:not(:first-child):not(:last-child){min-width:70px;width:25%}.history-table td:not(:first-child):not(:last-child),.results-table td:not(:first-child):not(:last-child),.services-table td:not(:first-child):not(:last-child),.tests-table td:not(:first-child):not(:last-child){font-size:9px;min-width:70px;width:25%}.history-table th:last-child,.results-table th:last-child,.services-table th:last-child,.tests-table th:last-child{background:linear-gradient(135deg,#00796b,#004d40);min-width:100px;-webkit-position:-webkit-sticky;position:sticky;right:0;width:30%;z-index:2}.history-table td:last-child,.results-table td:last-child,.services-table td:last-child,.tests-table td:last-child{background:#fff;box-shadow:-2px 0 4px #0000001a;min-width:100px;-webkit-position:-webkit-sticky;position:sticky;right:0;text-align:center;width:30%;z-index:1}.download-button,.view-button{border-radius:4px;display:inline-block;font-size:9px;min-width:75px;padding:5px 6px;text-align:center;white-space:nowrap}.download-button span,.view-button span{display:none}.history-section,.results-section,.services-section,.tests-section{overflow-x:auto;padding-right:8px}.pagination{flex-wrap:wrap;gap:4px;margin-top:16px}.pagination li a{font-size:12px;padding:6px 8px}}@media (min-width:769px) and (max-width:1024px){.history-table td:last-child,.history-table th:last-child,.results-table td:last-child,.results-table th:last-child,.services-table td:last-child,.services-table th:last-child,.tests-table td:last-child,.tests-table th:last-child{min-width:130px;width:130px}.download-button,.view-button{font-size:13px;min-width:110px;padding:9px 14px}}.history-table,.results-table,.services-table,.tests-table{scroll-behavior:smooth}@media (max-width:360px){.dashboard-container{padding:12px}.diagnosis-section,.history-section,.patient-info,.results-section,.services-section,.tests-section{margin-bottom:12px;padding:12px}.history-table,.results-table,.services-table,.tests-table{font-size:10px;min-width:320px;width:100%}.history-table th,.results-table th,.services-table th,.tests-table th{font-size:9px;line-height:1.1;padding:6px 1px}.history-table td,.results-table td,.services-table td,.tests-table td{font-size:9px;line-height:1.2;padding:6px 1px}.history-table td:first-child,.history-table th:first-child,.results-table td:first-child,.results-table th:first-child,.services-table td:first-child,.services-table th:first-child,.tests-table td:first-child,.tests-table th:first-child{min-width:110px;width:40%}.history-table td:not(:first-child):not(:last-child),.history-table th:not(:first-child):not(:last-child),.results-table td:not(:first-child):not(:last-child),.results-table th:not(:first-child):not(:last-child),.services-table td:not(:first-child):not(:last-child),.services-table th:not(:first-child):not(:last-child),.tests-table td:not(:first-child):not(:last-child),.tests-table th:not(:first-child):not(:last-child){font-size:8px;min-width:60px;width:20%}.history-table td:last-child,.history-table th:last-child,.results-table td:last-child,.results-table th:last-child,.services-table td:last-child,.services-table th:last-child,.tests-table td:last-child,.tests-table th:last-child{min-width:90px;width:30%}.download-button,.view-button{border-radius:3px;font-size:8px;min-width:65px;padding:4px 5px}.account-info{align-items:flex-start;flex-direction:column;font-size:12px;gap:4px;padding:8px 10px}.account-name{font-size:13px}.account-role{font-size:11px}}@media (max-width:768px){.history-table,.results-table,.services-table,.tests-table{word-wrap:break-word;table-layout:fixed}.history-table td,.results-table td,.services-table td,.tests-table td{box-sizing:border-box;display:table-cell;min-height:40px;vertical-align:middle}.history-table,.results-table,.services-table,.tests-table{border-spacing:0;table-layout:fixed;width:100%}.history-table td,.history-table th,.results-table td,.results-table th,.services-table td,.services-table th,.tests-table td,.tests-table th{word-wrap:break-word;box-sizing:border-box;-webkit-hyphens:auto;hyphens:auto;max-width:0;overflow:hidden;padding:8px 4px;text-overflow:ellipsis;white-space:normal;word-break:break-word}.history-table td:first-child,.results-table td:first-child,.services-table td:first-child,.tests-table td:first-child{overflow-wrap:break-word;white-space:normal;word-break:break-word}.history-table td:first-child,.results-table td:nth-child(3),.services-table td:nth-child(2),.tests-table td:nth-child(3){font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-table td:last-child,.results-table td:last-child,.services-table td:last-child,.tests-table td:last-child{overflow:visible;text-overflow:clip;white-space:nowrap}}@media (hover:hover) and (pointer:fine){.history-table td[title],.results-table td[title],.services-table td[title],.tests-table td[title]{cursor:help}}@media (prefers-contrast:high){.history-table td,.results-table td,.services-table td,.tests-table td{border:1px solid}}@media (prefers-color-scheme:dark){.history-table td:not(:first-child):not(:last-child):hover,.results-table td:not(:first-child):not(:last-child):hover,.services-table td:not(:first-child):not(:last-child):hover,.tests-table td:not(:first-child):not(:last-child):hover{background:#2d3748;color:#fff}}@media (hover:none) and (pointer:coarse){.history-table tbody tr:hover,.results-table tbody tr:hover,.services-table tbody tr:hover,.tests-table tbody tr:hover{background:linear-gradient(135deg,#f8fffe,#e8f5e8);transform:none}.download-button:hover,.view-button:hover{transform:none}}.locked-section{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px dashed #dee2e6;border-radius:12px;margin:20px 0;padding:60px 20px;text-align:center}.lock-icon{color:#6c757d;margin-bottom:20px;opacity:.7}.locked-section p{color:#6c757d;font-size:16px;line-height:1.5;margin-bottom:24px}.unlock-button{background:linear-gradient(135deg,#00796b,#004d40);border:none;border-radius:8px;box-shadow:0 4px 12px #00796b4d;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .3s ease}.unlock-button:hover{box-shadow:0 6px 16px #00796b66;transform:translateY(-2px)}.unlocked-header{align-items:center;background:linear-gradient(135deg,#d4edda,#c3e6cb);border:1px solid #b1e2c0;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.unlocked-header span{color:#155724;font-weight:500}.lock-again-button{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:6px 12px;transition:all .3s ease}.lock-again-button:hover{background:#5a6268;transform:translateY(-1px)}.cccd-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.cccd-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;max-width:440px;overflow:hidden;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{align-items:center;background:linear-gradient(135deg,#00796b,#004d40);color:#fff;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h4{font-size:18px;font-weight:600;margin:0}.close-button{background:none;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:18px;padding:4px;transition:all .2s ease}.close-button:hover{background:#ffffff1a;transform:scale(1.1)}.modal-body{padding:24px}.modal-body p{color:#495057;font-size:15px;line-height:1.5;margin-bottom:20px}.cccd-hint{border:1px solid #dee2e6;border-radius:6px;color:#495057;font-family:Courier New,monospace;font-size:14px;letter-spacing:1px;margin-bottom:16px;padding:8px 12px}.cccd-hint,.cccd-input{background:#f8f9fa;text-align:center}.cccd-input{border:2px solid #dee2e6;border-radius:8px;font-size:16px;font-weight:500;letter-spacing:2px;padding:12px 16px;transition:all .3s ease;width:100%}.cccd-input:focus{background:#fff;border-color:#00796b;box-shadow:0 0 0 3px #00796b1a;outline:none}.error-message{color:#dc3545;font-size:14px;font-weight:500;margin-top:8px;text-align:center}.modal-footer{background:#f8f9fa;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.cancel-button{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .3s ease}.cancel-button:hover{background:#5a6268;transform:translateY(-1px)}.verify-button{background:linear-gradient(135deg,#00796b,#004d40);border:none;border-radius:8px;box-shadow:0 4px 12px #00796b4d;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .3s ease}.verify-button:hover:not(:disabled){box-shadow:0 6px 16px #00796b66;transform:translateY(-1px)}.verify-button:disabled{background:#dee2e6;box-shadow:none;color:#6c757d;cursor:not-allowed}@media (max-width:576px){.cccd-modal{margin:20px;width:95%}.modal-body,.modal-footer,.modal-header{padding:16px 20px}.modal-footer{flex-direction:column}.cancel-button,.verify-button{justify-content:center;width:100%}}@media print{body{background:#fff;padding:0}.dashboard-container{border:none;box-shadow:none;max-width:none}.header{background:#00796b!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.logout-button{display:none}}.dashboard-header{background:linear-gradient(135deg,#00796b,#004d40);border-radius:12px;box-shadow:0 6px 20px #00796b26;color:#fff;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px;padding:24px 28px}.dashboard-header,.header-left{align-items:center;display:flex}.header-left{gap:20px}.header-center{align-items:center;display:flex;flex:1 1;justify-content:center}.header-navigation{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:10px;display:flex;gap:8px;padding:8px}.nav-button{align-items:center;background:#0000;border:none;border-radius:6px;color:#fffc;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:all .3s ease}.nav-button:hover{background:#ffffff26;color:#fff;transform:translateY(-1px)}.nav-button.active{background:#ffffff40;box-shadow:0 2px 8px #0003;color:#fff}.nav-button.disabled,.nav-button:disabled{background:#ffffff0d;color:#ffffff4d;cursor:not-allowed;opacity:.5}.nav-button.disabled:hover,.nav-button:disabled:hover{background:#ffffff0d;color:#ffffff4d;transform:none}.mobile-menu-toggle{-webkit-tap-highlight-color:transparent;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #fff3;border-radius:10px;display:none;font-size:20px;min-height:44px;min-width:44px;padding:12px;transition:all .3s ease}.mobile-menu-toggle:focus,.mobile-menu-toggle:hover{background:#fff3;border-color:#fff6;transform:scale(1.05)}.mobile-menu-toggle:active{background:#ffffff40;transform:scale(.95)}.mobile-nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#00796b,#004d40);border-radius:0 0 16px 16px;border-top:1px solid #ffffff1a;box-shadow:0 8px 32px #00000040,0 4px 16px #00000026,inset 0 1px 0 #ffffff1a;display:none;left:-12px;opacity:0;position:absolute;right:-12px;top:100%;transform:translateY(-20px);transition:all .4s cubic-bezier(.34,1.56,.64,1);z-index:1000}.mobile-nav-open{animation:slideDownFadeIn .4s cubic-bezier(.34,1.56,.64,1) forwards;display:block;opacity:1;transform:translateY(0)}@keyframes slideDownFadeIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.mobile-navigation{display:flex;flex-direction:column;gap:12px;padding:20px 16px}.mobile-nav-button{-webkit-tap-highlight-color:transparent;align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #ffffff26;border-radius:12px;color:#ffffffe6;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:16px;min-height:56px;overflow:hidden;padding:16px 20px;position:relative;text-align:left;transition:all .3s cubic-bezier(.25,.46,.45,.94);width:100%}.mobile-nav-button:before{background:linear-gradient(90deg,#0000,#ffffff1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.mobile-nav-button:focus,.mobile-nav-button:hover{background:#fff3;border-color:#ffffff4d;box-shadow:0 4px 16px #00000026;color:#fff;transform:translateX(4px)}.mobile-nav-button:hover:before{left:100%}.mobile-nav-button:active{transform:translateX(2px) scale(.98)}.mobile-nav-button.active{background:#ffffff40;border-color:#fff6;box-shadow:0 4px 16px #0003,inset 0 1px 0 #fff3;color:#fff}.mobile-nav-button.active:before{background:linear-gradient(90deg,#0000,#ffffff26,#0000)}.mobile-nav-button.disabled,.mobile-nav-button:disabled{background:#ffffff0d;color:#ffffff4d;cursor:not-allowed;opacity:.5}.mobile-nav-button.disabled:hover,.mobile-nav-button:disabled:hover{background:#ffffff0d;color:#ffffff4d}.mobile-menu-divider{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);height:1px;margin:16px 0;position:relative}.mobile-menu-divider:after{background:linear-gradient(90deg,#0000,#0000001a,#0000);content:"";height:1px;left:0;position:absolute;right:0;top:1px}.mobile-nav-button.logout-mobile{background:#dc354526;border:1px solid #dc354566;color:#ff6b7a;font-weight:600}.mobile-nav-button.logout-mobile:focus,.mobile-nav-button.logout-mobile:hover{background:#dc354540;border-color:#dc354599;box-shadow:0 4px 16px #dc354533;color:#ff8a95}.mobile-nav-button.logout-mobile:active{background:#dc354559;transform:translateX(2px) scale(.98)}.hospital-logo{border:2px solid #fff3;border-radius:8px;box-shadow:0 4px 12px #00000026;height:60px;object-fit:cover;width:60px}.hospital-info{display:flex;flex-direction:column;gap:4px}.hospital-name{color:#fff;font-size:22px;font-weight:700;text-shadow:0 2px 4px #0003}.hospital-address{color:#ffffffe6;font-size:14px;font-weight:400}.hospital-phone{color:#ffffffe6;font-size:14px;font-weight:500}.header-right,.logout-button{align-items:center;display:flex}.logout-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .3s ease}.logout-button:hover{background:#ffffff40;border-color:#ffffff80;box-shadow:0 6px 16px #0003;transform:translateY(-2px)}.logout-button:active{transform:translateY(0)}@media (max-width:768px){.dashboard-header{flex-wrap:wrap;gap:16px;padding:20px 16px;position:relative}.header-left{flex:1 1;min-width:0}.header-center.desktop-nav{display:none}.mobile-menu-toggle{display:flex}.header-right{align-items:center;display:flex;gap:12px}.logout-button.desktop-only,.logout-text{display:none}.hospital-info{display:flex;flex-direction:column;gap:2px}.hospital-name{font-size:16px;line-height:1.2}.hospital-address,.hospital-phone{font-size:12px;line-height:1.2}.hospital-logo{height:45px;width:45px}.logout-button{font-size:16px;min-width:auto;padding:10px}}@media (max-width:480px){.dashboard-header{margin-bottom:20px;padding:16px 12px}.header-left{gap:8px}.hospital-logo{height:40px;width:40px}.hospital-name{font-size:14px}.hospital-address,.hospital-phone{font-size:11px}.logout-button{font-size:14px}.logout-button,.mobile-menu-toggle{min-height:44px;min-width:44px;padding:10px}.mobile-menu-toggle{font-size:18px}.mobile-navigation{gap:10px;padding:16px 12px}.mobile-nav-button{font-size:15px;gap:14px;min-height:52px;padding:14px 16px}.mobile-nav{left:-12px;right:-12px}}@media (max-width:600px){.nav-text{display:none}}@media (max-width:768px){.dashboard-header{scroll-behavior:smooth}}@media (hover:none) and (pointer:coarse){.mobile-nav-button:hover{transform:none}.mobile-nav-button:active{background:#ffffff4d;transform:scale(.96)}.mobile-menu-toggle:hover{transform:none}.mobile-menu-toggle:active{background:#ffffff4d;transform:scale(.92)}}.mobile-menu-toggle:focus-visible,.mobile-nav-button:focus-visible{outline:2px solid #fffc;outline-offset:2px}.mobile-nav:not(.mobile-nav-open){animation:slideUpFadeOut .3s ease-in forwards}@keyframes slideUpFadeOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.95)}}.patient-list-header{align-items:center;border-bottom:2px solid #e1e5e9;display:flex;justify-content:space-between;margin-bottom:24px;padding:20px 0}.header-title h2{color:#2c3e50;font-size:28px;font-weight:700;margin:0 0 8px}.account-info{align-items:center;background:linear-gradient(135deg,#e8f5e8,#f1f8e9);border-left:4px solid #00796b;border-radius:6px;display:flex;gap:8px;margin:8px 0;padding:8px 12px}.account-label{color:#666;font-size:13px;font-weight:500}.account-name{color:#00796b;font-size:14px;font-weight:700}.account-role{color:#757575;font-size:12px;font-style:italic;font-weight:500}.stats{display:flex;font-size:14px;gap:16px}.total-count{color:#00796b;font-weight:600}.filtered-count{color:#757575;font-weight:500}.header-actions{display:flex;gap:12px}.add-patient-btn{align-items:center;background:linear-gradient(135deg,#00796b,#004d40);border:none;border-radius:8px;box-shadow:0 4px 12px #00796b4d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:12px 20px;transition:all .3s ease}.add-patient-btn:hover{box-shadow:0 6px 16px #00796b66;transform:translateY(-2px)}.search-filter-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;margin-bottom:24px;padding:20px}.search-bar{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.search-input-group{flex:1 1;min-width:300px;position:relative}.search-icon{color:#6c757d;left:12px;position:absolute;top:50%;transform:translateY(-50%);z-index:2}.search-input{background:#fff;border:2px solid #dee2e6;border-radius:8px;font-size:16px;padding:12px 16px 12px 40px;transition:all .3s ease;width:100%}.search-input:focus{border-color:#00796b;box-shadow:0 0 0 3px #00796b1a;outline:none}.clear-search{background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:all .2s ease}.clear-search:hover{background:#f8f9fa;color:#dc3545}.filter-type-select{background:#fff;border:2px solid #dee2e6;border-radius:8px;cursor:pointer;font-size:14px;min-width:150px;padding:12px 16px;transition:all .3s ease}.filter-type-select:focus{border-color:#00796b;outline:none}.filter-toggle{align-items:center;background:#fff;border:2px solid #dee2e6;border-radius:8px;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:12px 16px;transition:all .3s ease}.filter-toggle:hover{border-color:#00796b;color:#00796b}.filter-toggle.active{background:#00796b;border-color:#00796b;color:#fff}.advanced-filters{border-top:1px solid #dee2e6;margin-top:16px;padding-top:16px}.filter-row{align-items:end;display:flex;flex-wrap:wrap;gap:20px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{color:#495057;font-size:14px;font-weight:600}.filter-group input,.filter-group select{border:1px solid #ced4da;border-radius:6px;font-size:14px;min-width:120px;padding:8px 12px}.age-range,.date-range{align-items:center;display:flex;gap:8px}.age-range input,.date-range input{width:80px}.age-range span,.date-range span{color:#6c757d;font-weight:500}.clear-filters-btn{align-items:center;background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .3s ease}.clear-filters-btn:hover{background:#c82333;transform:translateY(-1px)}.patient-table-section{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 16px #0000000d;overflow:hidden}.table-container{overflow-x:auto}.patient-table{border-collapse:collapse;font-size:14px;width:100%}.patient-table thead{background:linear-gradient(135deg,#00796b,#004d40);color:#fff}.patient-table th{border-bottom:2px solid #004d40;font-size:14px;font-weight:600;padding:16px 12px;text-align:left;white-space:nowrap}.patient-table td{border-bottom:1px solid #e9ecef;color:#333;padding:12px;vertical-align:middle}.patient-table tbody tr{transition:all .2s ease}.patient-table tbody tr:hover{background:#f8f9fa}.patient-table tbody tr:nth-child(2n){background:#fdfdfd}.patient-table tbody tr:nth-child(2n):hover{background:#f8f9fa}.sequence-number{background:#00796b0d;border-right:1px solid #00796b1a;color:#666;font-size:14px;font-weight:600;min-width:60px;text-align:center;width:60px}.patient-id{color:#00796b;font-family:Courier New,monospace;font-weight:600}.patient-table .patient-name,.patient-table tbody tr td.patient-name{color:#2c3e50!important;font-size:13px!important;font-weight:600;text-decoration:none}.gender-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;min-width:40px;padding:4px 8px;text-align:center}.gender-badge.male{background:#e3f2fd;color:#1976d2}.gender-badge.female{background:#fce4ec;color:#c2185b}.phone-number{color:#6c757d}.bhyt-number,.phone-number{font-family:Courier New,monospace}.bhyt-number{color:#28a745;font-weight:500}.address{color:#6c757d;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-data{color:#6c757d;font-size:16px;font-style:italic;padding:40px 12px;text-align:center}.actions{gap:8px}.action-btn,.actions{display:flex;justify-content:center}.action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;font-size:12px;height:32px;transition:all .2s ease;width:32px}.view-btn{background:#17a2b8;color:#fff}.view-btn:hover{background:#138496;transform:scale(1.1)}.pdf-btn{background:#dc3545;color:#fff}.pdf-btn:hover{background:#c82333;transform:scale(1.1)}.delete-btn{background:#dc3545;color:#fff}.delete-btn:hover{background:#c82333;transform:scale(1.1)}.error-container,.loading-container{padding:60px 20px}.loading-spinner{border:4px solid #f3f3f3;height:40px;margin-bottom:16px;width:40px}.error-container button{background:#00796b;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-top:16px;padding:12px 24px;transition:all .3s ease}.error-container button:hover{background:#004d40;transform:translateY(-2px)}@media (max-width:1024px){.patient-list-header{align-items:flex-start;flex-direction:column;gap:16px}.search-bar{align-items:stretch;flex-direction:column}.search-input-group{min-width:100%}.filter-row{align-items:stretch;flex-direction:column;gap:16px}.age-range,.date-range{justify-content:space-between}}@media (max-width:768px){.patient-table td,.patient-table th{font-size:12px;padding:8px 6px}.patient-table .patient-name,.patient-table tbody tr td.patient-name{font-size:12px!important}.address{max-width:120px}.actions{flex-direction:column;gap:4px}.action-btn{font-size:10px;height:28px;width:28px}.search-filter-section{padding:16px}.advanced-filters{margin-top:12px;padding-top:12px}}@media (max-width:480px){.header-title h2{font-size:22px}.stats{flex-direction:column;gap:4px}.patient-table{font-size:11px}.patient-table td,.patient-table th{padding:6px 4px}.patient-table .patient-name,.patient-table tbody tr td.patient-name{font-size:11px!important}.no-data{font-size:14px;padding:30px 12px}}@media print{.actions,.pagination,.search-filter-section{display:none}.patient-table{font-size:12px}.patient-table td,.patient-table th{padding:8px 4px}}.pdf-viewer-container{background:#f5f5f5;font-family:Roboto,sans-serif;height:100vh}.pdf-viewer-container.fullscreen{background:#2c2c2c;height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:9999}.pdf-canvas,.pdf-frame{background:#fff;border:none;border-radius:8px;box-shadow:0 4px 20px #0000001a;height:100%;max-width:1000px;min-height:600px;transition:transform .3s ease;width:100%}.mobile-pdf-frame{-webkit-overflow-scrolling:touch;background:#fff;border-radius:4px;box-shadow:0 2px 8px #0000001a;max-width:100%;min-height:500px;overflow:auto}@media (max-width:768px){.mobile-pdf-frame,.pdf-canvas,.pdf-frame{border-radius:0;box-shadow:none;min-height:calc(100vh - 200px)}.pdf-wrapper{-webkit-overflow-scrolling:touch;align-items:flex-start;overflow-x:auto;overflow-y:auto;padding:10px;scroll-behavior:smooth}.pdf-content,.pdf-wrapper{display:flex;justify-content:center}.pdf-content{touch-action:pan-x pan-y;-ms-touch-action:pan-x pan-y;width:100%}.pdf-canvas{display:block;height:auto!important;margin:0 auto;max-width:100%!important;object-fit:contain;width:auto!important}}.pdf-canvas{cursor:grab;display:block;margin:0 auto}.pdf-canvas:active{cursor:grabbing}.toolbar-divider{margin:0 4px}.mobile-menu{background:linear-gradient(135deg,#00796b,#004d40);border-top:1px solid #ffffff1a;display:none;max-height:0;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.mobile-menu-open{display:block;max-height:500px}.mobile-menu-grid{grid-gap:20px;display:grid;gap:20px;padding:16px}.mobile-menu-section{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;padding:16px}.mobile-menu-section h3{color:#ffffffe6;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.mobile-menu-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;min-height:44px;padding:12px 16px;transition:all .2s ease;width:100%}.mobile-menu-btn:hover:not(:disabled){background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.mobile-menu-btn:disabled{cursor:not-allowed;opacity:.5}.mobile-menu-btn:active{transform:scale(.98)}.mobile-page-controls{align-items:center;display:flex;gap:8px}.mobile-page-controls .mobile-menu-btn{flex:0 0 44px;padding:8px}.mobile-page-info{align-items:center;background:#ffffff1a;border-radius:6px;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:4px;justify-content:center;padding:8px 12px}.mobile-page-input{background:#ffffffe6;border:none;border-radius:4px;color:#333;font-size:14px;font-weight:500;padding:4px 8px;text-align:center;width:50px}.mobile-zoom-controls{align-items:center;display:flex;gap:8px}.mobile-zoom-controls .mobile-menu-btn{flex:0 0 44px;padding:8px}.mobile-zoom-level{background:#ffffff1a;border-radius:6px;flex:1 1;font-size:14px;font-weight:600;padding:8px 12px;text-align:center}.mobile-actions-grid,.mobile-tools-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.mobile-actions-grid .mobile-menu-btn,.mobile-tools-grid .mobile-menu-btn{flex-direction:column;gap:4px;padding:12px 8px;text-align:center}.mobile-actions-grid .mobile-menu-btn span,.mobile-tools-grid .mobile-menu-btn span{font-size:12px;line-height:1.2}.mobile-menu-btn.home-btn{background:#4caf5033;border-color:#4caf5066}.mobile-menu-btn.home-btn:hover{background:#4caf504d}.mobile-menu-btn.print-btn{background:#ffc10733;border-color:#ffc10766}.mobile-menu-btn.print-btn:hover{background:#ffc1074d}.mobile-menu-btn.download-btn{background:#2196f333;border-color:#2196f366}.mobile-menu-btn.download-btn:hover{background:#2196f34d}.error-container,.loading-container{align-items:center;color:#333;display:flex;flex-direction:column;height:100vh;justify-content:center;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:5px solid #e0e0e0;border-radius:50%;border-top-color:#00796b;height:50px;margin-bottom:20px;width:50px}.error-container h2{color:#d32f2f;margin-bottom:16px}.error-actions{display:flex;gap:16px;margin-top:24px}.pdf-toolbar{background:linear-gradient(135deg,#00796b,#004d40);box-shadow:0 2px 8px #0000001a;color:#fff;flex-shrink:0;position:relative}.mobile-toolbar-header{align-items:center;display:none;justify-content:space-between;padding:12px 16px}.mobile-title-section{align-items:center;display:flex;flex:1 1;gap:12px}.mobile-back-btn{align-items:center;background:#ffffff1a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:16px;justify-content:center;min-height:40px;min-width:40px;padding:8px;transition:all .2s ease}.mobile-back-btn:hover{background:#fff3}.mobile-menu-toggle{align-items:center;background:#ffffff1a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:18px;justify-content:center;min-height:40px;min-width:40px;padding:8px;transition:all .2s ease}.mobile-menu-toggle:hover{background:#fff3}.desktop-toolbar{align-items:center;display:flex;justify-content:space-between;padding:12px 20px}.toolbar-left,.toolbar-right{align-items:center;display:flex;gap:8px}.toolbar-center{flex:1 1;text-align:center}.pdf-title{font-size:18px;font-weight:600;margin:0}.file-name{font-size:12px;margin:4px 0 0;opacity:.8}.toolbar-button{align-items:center;background:#ffffff1a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease;white-space:nowrap}.toolbar-button:hover:not(:disabled){background:#fff3;transform:translateY(-1px)}.toolbar-button:disabled{cursor:not-allowed;opacity:.5}.pdf-frame{-webkit-appearance:none;appearance:none}.firefox-pdf-hide{overflow:hidden;position:relative}.firefox-pdf-hide:before{border-bottom:1px solid #ddd;border-radius:8px 8px 0 0;height:40px;top:0}.firefox-pdf-hide:after,.firefox-pdf-hide:before{background:#f5f5f5;content:"";left:0;pointer-events:none;position:absolute;right:0;z-index:100}.firefox-pdf-hide:after{border-top:1px solid #ddd;bottom:0;height:25px}.firefox-pdf-container{background:#fff;border-radius:8px;height:100%;overflow:hidden;position:relative;width:100%}.firefox-toolbar-overlay{background:linear-gradient(180deg,#f8f8f8,#f0f0f0)!important;border-bottom:1px solid #ddd!important;box-shadow:0 2px 4px #0000001a!important;height:35px!important;top:0!important}.firefox-bottom-overlay,.firefox-toolbar-overlay{left:0!important;pointer-events:none;position:absolute!important;right:0!important;user-select:none;-webkit-user-select:none;z-index:9999!important}.firefox-bottom-overlay{background:linear-gradient(0deg,#f8f8f8,#f0f0f0)!important;border-top:1px solid #ddd!important;bottom:0!important;box-shadow:0 -2px 4px #0000001a!important;height:25px!important}@-moz-document url-prefix(){.pdf-frame{border-bottom:20px solid #f5f5f5!important;border-top:32px solid #f5f5f5!important;box-sizing:border-box!important;margin-bottom:-20px!important;margin-top:-32px!important}.firefox-pdf-hide{overflow:hidden!important;position:relative!important}embed[type="application/pdf"]{clip-path:inset(32px 0 20px 0)!important}.firefox-pdf-container{z-index:1}.firefox-toolbar-overlay{background:linear-gradient(180deg,#f5f5f5,#e8e8e8)!important;box-shadow:0 2px 4px #0000001a!important}.firefox-bottom-overlay{background:linear-gradient(0deg,#f5f5f5,#e8e8e8)!important;box-shadow:0 -2px 4px #0000001a!important}}.page-info{align-items:center;border-radius:6px;display:flex;gap:8px;padding:4px 12px}.page-info,.page-input{background:#ffffff1a;font-size:14px;font-weight:500}.page-input{border:1px solid #ffffff4d;border-radius:4px;color:#fff;padding:4px 8px;text-align:center;width:50px}.page-input:focus{background:#fff3;border-color:#00acc1;outline:none}.page-separator{color:#ffffffb3;font-weight:400}.total-pages{color:#ffffffe6;font-weight:500}.toolbar-button.back-btn:hover,.toolbar-button.home-btn:hover{background:#2196f333}.toolbar-button.download-btn:hover{background:#4caf5033}.toolbar-button.print-btn:hover{background:#ff980033}.zoom-level{background:#ffffff26;border-radius:4px;font-weight:600;min-width:50px;padding:6px 12px;text-align:center}.toolbar-divider{background:#ffffff4d;height:24px;margin:0 8px;width:1px}.pdf-content{align-items:center;background:#f5f5f5;justify-content:center;overflow:hidden;padding:20px}.pdf-wrapper{align-items:center;border-radius:8px;box-shadow:0 4px 20px #00000026;display:flex;justify-content:center;max-width:1200px;overflow:hidden;position:relative}.pdf-frame,.pdf-wrapper{background:#fff;height:100%;width:100%}.pdf-frame{border:none;border-radius:8px;box-shadow:0 4px 20px #0000001a;max-width:1000px;min-height:600px;transition:transform .3s ease}.pdf-status-bar{align-items:center;background:#37474f;color:#fff;display:flex;flex-shrink:0;font-size:12px;justify-content:space-between;padding:8px 20px}.file-info,.status-info,.user-role-info{align-items:center;display:flex;gap:12px}.user-role-info{background:#ff6f00;border-radius:12px;color:#fff;font-size:11px;font-weight:500;padding:4px 12px}.back-button,.home-button{align-items:center;background:#00796b;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 20px;transition:all .2s ease}.back-button:hover{background:#2196f3;transform:translateY(-2px)}.home-button:hover{background:#4caf50;transform:translateY(-2px)}@media (max-width:768px){.desktop-toolbar{display:none}.mobile-toolbar-header{display:flex}.mobile-menu{display:block}.pdf-title{font-size:16px;margin:0}.pdf-wrapper{padding:10px}.pdf-status-bar{flex-direction:column;gap:4px;text-align:center}.mobile-menu-btn{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}.mobile-menu-btn,.mobile-page-input{-webkit-user-select:none;user-select:none}.mobile-page-input{-webkit-appearance:none;appearance:none}.loading-container{padding:20px}.mobile-load-tip{font-size:11px;margin-top:12px}.progress-bar{height:6px}}@media (max-width:480px){.mobile-toolbar-header{padding:10px 12px}.pdf-title{font-size:14px}.file-name{font-size:11px}.mobile-menu-grid{gap:16px;padding:12px}.mobile-menu-section{padding:12px}.mobile-menu-section h3{font-size:13px;margin-bottom:10px}.mobile-menu-btn{font-size:13px;min-height:40px;padding:10px 12px}.mobile-actions-grid,.mobile-tools-grid{gap:6px;grid-template-columns:1fr}.mobile-page-info,.mobile-zoom-level{font-size:13px;padding:6px 10px}.mobile-page-input{font-size:13px;padding:3px 6px;width:45px}}@media print{.pdf-status-bar,.pdf-toolbar{display:none!important}.pdf-content,.pdf-viewer-container{height:auto!important}.pdf-content{overflow:visible!important}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.pdf-frame{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}.back-button:focus,.home-button:focus,.mobile-back-btn:focus,.mobile-menu-btn:focus,.mobile-menu-toggle:focus,.toolbar-button:focus{outline:2px solid #fff;outline-offset:2px}.mobile-menu-overlay{background:#0000004d;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:998}@media (max-width:768px){.mobile-menu-open~.mobile-menu-overlay{display:block}body.mobile-menu-open{overflow:hidden}}@media (max-width:768px) and (max-device-width:768px){.pdf-viewer-container{contain:layout style paint}.pdf-wrapper{contain:layout style;will-change:scroll-position}.mobile-pdf-frame{contain:strict;contain-intrinsic-size:100% 600px;content-visibility:auto}}.mobile-pdf-info{background:linear-gradient(135deg,#e8f5e8,#f0f8ff);border:1px solid #c8e6c9;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#2e7d32;font-size:14px;font-weight:600;margin-bottom:16px;padding:12px 16px;text-align:center}.mobile-pdf-iframe-container{height:100%;width:100%}.mobile-pdf-hint{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;box-shadow:0 1px 3px #0000001a;color:#856404;font-size:12px;margin-top:12px;padding:8px 12px;text-align:center}.page-number-indicator{border-radius:15px;margin-bottom:8px;padding:6px 12px;text-align:center}.mobile-pdf-page{box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:12px}.mobile-pdf-image{border-radius:4px;box-shadow:0 1px 4px #0000001a}@media (max-width:480px){.mobile-pdf-frame{contain-intrinsic-size:100% 400px}.loading-container{padding:15px}.progress-bar{height:4px}.mobile-load-tip{font-size:10px}}.loading-container p{animation:pulse 2s ease-in-out infinite;color:#666;font-size:16px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}*{box-sizing:border-box}.pdf-viewer-container *{transition:background-color .2s ease,color .2s ease,transform .2s ease}@media (hover:none) and (pointer:coarse){.mobile-menu-btn:hover{transform:none}.mobile-menu-btn:active{background:#ffffff40!important;transform:scale(.95)}.mobile-back-btn:hover,.mobile-menu-toggle:hover{transform:none}.mobile-back-btn:active,.mobile-menu-toggle:active{background:#ffffff40!important;transform:scale(.95)}.mobile-pdf-frame,.pdf-frame{-webkit-backface-visibility:hidden;backface-visibility:hidden;perspective:1000;transform:translateZ(0)}.pdf-viewer-container *{animation-duration:.2s!important;transition-duration:.2s!important}}.pdf-wrapper::-webkit-scrollbar{height:8px;width:8px}.pdf-wrapper::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.pdf-wrapper::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.pdf-wrapper::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.mobile-pdf-container{-webkit-overflow-scrolling:touch;background:#f5f5f5;height:100%;overflow-y:auto;width:100%}.mobile-pdf-pages{align-items:center;display:flex;flex-direction:column;gap:20px;padding:10px}.mobile-pdf-page{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;max-width:100%;overflow:hidden;position:relative;transition:transform .3s ease;width:100%}.mobile-pdf-page:hover{box-shadow:0 6px 20px #0003;transform:translateY(-2px)}.page-number-indicator{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00796be6;border:1px solid #fff3;border-radius:12px;color:#fff;font-size:12px;font-weight:600;padding:4px 8px;position:absolute;right:10px;top:10px;z-index:10}.mobile-pdf-image{display:block;height:auto;transition:transform .3s ease;width:100%}.mobile-canvas-container{background:#f8f9fa;border-radius:8px;padding:10px;text-align:center}.mobile-pdf-canvas{background:#fff;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 2px 8px #0000001a;display:block;height:auto;margin:0 auto;max-width:100%;transition:transform .3s ease}.mobile-notice{background:#e3f2fd;border:1px solid #bbdefb;border-radius:4px;color:#1565c0;font-size:13px;font-weight:500}.fallback-notice,.mobile-notice{margin-bottom:10px;padding:8px 12px;text-align:center}.fallback-notice{background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;color:#856404;font-size:12px}.mobile-loading-container{align-items:center;background:linear-gradient(135deg,#e8f5e8,#f0f8f0);display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px 20px;text-align:center}.mobile-loading-spinner{animation:spin 1s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#00796b;height:48px;margin-bottom:16px;width:48px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.rendering-progress{margin-top:20px;max-width:300px;width:100%}.progress-bar{background:#e0e0e0;box-shadow:inset 0 2px 4px #0000001a;height:8px;margin-bottom:8px;width:100%}.progress-bar,.progress-fill{border-radius:4px;overflow:hidden}.progress-fill{background:linear-gradient(135deg,#00796b,#004d40);height:100%;position:relative;transition:width .3s ease}.progress-fill:after{animation:progressStripes 1s linear infinite;background:linear-gradient(45deg,#fff3 25%,#0000 0,#0000 50%,#fff3 0,#fff3 75%,#0000 0);background-size:16px 16px;bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes progressStripes{0%{background-position:0 0}to{background-position:16px 0}}.progress-text{color:#666;font-size:14px;font-weight:500;margin-top:4px}@media (max-width:768px){.mobile-pdf-pages{gap:15px;padding:8px}.mobile-pdf-page{border-radius:6px;box-shadow:0 2px 8px #0000001a}.page-number-indicator{font-size:11px;padding:3px 6px;right:8px;top:8px}.mobile-loading-container{padding:30px 15px}.mobile-loading-spinner{border-width:3px;height:40px;width:40px}}@media (max-width:480px){.mobile-pdf-pages{gap:12px;padding:5px}.mobile-pdf-page{border-radius:4px;box-shadow:0 1px 6px #0000001a}.page-number-indicator{border-radius:8px;font-size:10px;padding:2px 5px;right:6px;top:6px}.mobile-loading-container{padding:20px 10px}.progress-text{font-size:13px}}.pdf-viewer-container{background:linear-gradient(135deg,#00796b,#004d40 50%,#00695c)!important;display:flex;flex-direction:column;min-height:100vh;overflow:hidden;position:relative}.pdf-viewer-container:before{background:radial-gradient(circle at 20% 50%,#00796b4d 0,#0000 50%),radial-gradient(circle at 80% 20%,#004d404d 0,#0000 50%),radial-gradient(circle at 40% 80%,#00695c4d 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.single-row-header{align-items:center!important;-webkit-backdrop-filter:blur(25px)!important;backdrop-filter:blur(25px)!important;background:#ffffff26!important;border-bottom:1px solid #fff3!important;border-radius:0 0 15px 15px;box-shadow:0 8px 32px #1f26875e,inset 0 1px 0 #ffffff80!important;display:flex!important;gap:15px;justify-content:space-between!important;margin-bottom:3px;min-height:50px;padding:10px 20px!important;position:relative;z-index:10}.control-btn{background:linear-gradient(135deg,#00796b,#004d40)!important;border-radius:12px!important;box-shadow:0 4px 20px #00796b66,0 2px 8px #0000001a!important;font-weight:600!important;gap:10px!important;overflow:hidden;padding:14px 20px!important;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)!important}.control-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s;width:100%}.control-btn:hover:before{left:100%}.control-btn:hover{background:linear-gradient(135deg,#00897b,#004d40)!important;box-shadow:0 8px 30px #00796b80,0 4px 15px #00000026!important;transform:translateY(-3px) scale(1.02)!important}.control-btn:active{transform:translateY(-1px) scale(.98)!important;transition:all .1s ease!important}.pdf-content{background:#fff!important;border:1px solid #00000014;border-radius:20px!important;box-shadow:0 8px 32px #0000001a,0 4px 16px #0000000d!important;display:flex;flex:1 1;flex-direction:column;margin:8px 20px 15px!important;min-height:calc(100vh - 150px);padding:15px!important;position:relative}.pdf-content:before{background:linear-gradient(90deg,#0000,#00796b4d,#0000);content:"";height:1px;left:0;position:absolute;right:0;top:0}.loading-container{-webkit-backdrop-filter:blur(15px)!important;backdrop-filter:blur(15px)!important;background:#ffffff1a!important;border:1px solid #fff3;border-radius:20px!important;padding:40px!important}.loading-spinner{animation:spin 1.2s cubic-bezier(.4,0,.2,1) infinite!important;border-right:6px solid #fff3!important;border-top:6px solid #fff3!important;border-color:#00796b #004d40 #fff3 #fff3!important;border-style:solid!important;border-width:6px!important;height:60px!important;margin-bottom:25px!important;position:relative;width:60px!important}.loading-spinner:after{animation:spin 2s linear infinite reverse;border:2px solid #0000;border-radius:50%;border-top-color:#ffffff80;bottom:-6px;content:"";left:-6px;position:absolute;right:-6px;top:-6px}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.pdf-viewer-container>*{animation:fadeIn .6s ease-out}.pdf-header{animation:slideInFromTop .8s cubic-bezier(.4,0,.2,1)}@media (max-width:768px){.single-row-header{border-radius:0 0 12px 12px!important;gap:8px!important;margin-bottom:2px!important;min-height:45px!important;padding:8px 12px!important}.nav-btn{font-size:12px!important;padding:6px 8px!important}.nav-btn span{display:none}.patient-name{font-size:16px!important;max-width:200px!important}.compact-toggle{min-width:60px!important;padding:6px 10px!important}.toggle-text{font-size:11px!important}.pdf-content{border-radius:15px!important;margin:5px 10px 10px!important;min-height:calc(100vh - 120px)!important;padding:10px!important}}@media (max-width:480px){.single-row-header{gap:8px!important;padding:10px 12px!important}.header-left-nav{gap:4px!important}.nav-btn{height:32px!important;justify-content:center!important;padding:0!important;width:32px!important}.patient-name{font-size:14px!important;max-width:150px!important}.compact-toggle{height:32px!important;justify-content:center!important;padding:0!important;width:50px!important}.toggle-text{display:none!important}}.pdf-status-bar{-webkit-backdrop-filter:blur(15px)!important;backdrop-filter:blur(15px)!important;background:#ffffff1a!important;border-radius:10px 10px 0 0!important;border-top:1px solid #fff3!important;margin-top:3px!important}.mobile-pdf-info,.pdf-status-bar{font-size:12px!important;padding:6px 12px!important}.mobile-pdf-info{background:linear-gradient(135deg,#00796b,#004d40)!important;border-radius:8px 8px 0 0!important;color:#fff!important;font-weight:600!important;margin:0!important;text-align:center!important}.mobile-notice{background:#ffc1071a!important;border-bottom:1px solid #ffc10733!important;color:#856404!important}.mobile-notice,.mobile-pdf-hint{font-size:11px!important;margin:0!important;padding:4px 12px!important;text-align:center!important}.mobile-pdf-hint{background:#17a2b81a!important;border-radius:0 0 8px 8px!important;color:#0c5460!important}iframe{border-radius:12px!important;overflow:hidden!important}.mobile-pdf-frame,iframe{border:none!important;box-shadow:inset 0 0 0 1px #0000001a!important;flex:1 1!important;min-height:0!important;outline:none!important}.mobile-pdf-iframe-container{display:flex!important;flex:1 1!important;flex-direction:column!important;margin:0!important;min-height:0!important;padding:0!important}.header-left-nav{align-items:center;display:flex;flex-shrink:0;gap:8px}.nav-btn{align-items:center!important;background:#ffffff1a!important;border:1px solid #fff3!important;border-radius:8px!important;color:#fff!important;cursor:pointer!important;display:flex!important;font-size:14px!important;font-weight:500!important;gap:6px!important;padding:8px 12px!important;transition:all .3s ease!important;white-space:nowrap}.nav-btn:hover{background:#fff3!important;transform:translateY(-1px)!important}.nav-btn span{font-size:13px}.header-center-name{align-items:center;display:flex;flex:1 1;justify-content:center;text-align:center}.patient-name{color:#fff!important;font-size:18px!important;font-weight:600!important;margin:0!important;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-right-controls{align-items:center;display:flex;flex-shrink:0}.compact-toggle{align-items:center!important;background:#ffffff1a!important;border:1px solid #fff3!important;border-radius:8px!important;color:#fff!important;cursor:pointer!important;display:flex!important;gap:6px!important;min-width:70px;padding:8px 12px!important;transition:all .3s ease!important}.compact-toggle:hover{background:#fff3!important;transform:translateY(-1px)!important}.toggle-text{font-size:12px;font-weight:500}.inline-controls{-webkit-backdrop-filter:blur(15px)!important;backdrop-filter:blur(15px)!important;border-radius:10px!important;box-shadow:0 2px 12px #0000001a!important;gap:6px!important;padding:6px 12px!important}.control-btn,.inline-controls{align-items:center!important;background:#ffffff1a!important;border:1px solid #fff3!important;display:flex!important}.control-btn{border-radius:6px!important;color:#fff!important;cursor:pointer!important;font-size:14px!important;height:36px!important;justify-content:center!important;transition:all .3s ease!important;width:36px!important}.control-btn:hover{background:#ffffff40!important;box-shadow:0 2px 8px #0003!important;transform:translateY(-1px)!important}.control-btn:active{transform:translateY(0)!important}.zoom-display{background:#fff3!important;border:1px solid #ffffff4d!important;border-radius:6px!important;color:#fff!important;font-size:13px!important;font-weight:600!important;margin:0 3px!important;min-width:50px!important;padding:6px 10px!important;text-align:center!important}.separator{background:#ffffff4d;height:20px;margin:0 3px;width:1px}.enhanced-mobile-menu{-webkit-backdrop-filter:none!important;backdrop-filter:none!important;z-index:1000!important}.menu-overlay{animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;bottom:0;left:0;position:absolute;right:0;top:0}.menu-content{animation:slideUpIn .4s cubic-bezier(.4,0,.2,1);background:linear-gradient(145deg,#fff,#f8f9fa);border-radius:25px 25px 0 0;box-shadow:0 -20px 60px #0000004d,0 -8px 20px #0000001a;max-height:85vh;overflow-y:auto;padding:25px 20px 30px;position:relative;width:100%}.menu-header{border-bottom:2px solid #e9ecef;margin-bottom:25px;padding-bottom:15px;text-align:center}.menu-header h3{color:#00796b;font-size:20px;font-weight:700;margin:0 0 8px}.current-zoom{background:linear-gradient(135deg,#00796b,#004d40);border-radius:20px;color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:6px 15px}.mobile-menu-section{margin-bottom:25px}.section-header{align-items:center;background:linear-gradient(135deg,#e8f5e8,#f1f8e9);border-left:4px solid #00796b;border-radius:12px;display:flex;gap:10px;margin-bottom:15px;padding:10px 15px}.section-header h4,.section-icon{color:#00796b;font-size:16px}.section-header h4{font-weight:700;margin:0}.mobile-menu-grid{grid-gap:12px!important;display:grid!important;gap:12px!important;grid-template-columns:1fr 1fr!important}.mobile-menu-list{display:flex;flex-direction:column;gap:12px}.mobile-menu-btn{background:linear-gradient(135deg,#fff,#f8f9fa)!important;border:2px solid #e9ecef!important;border-radius:15px!important;box-shadow:0 4px 15px #0000000d!important;overflow:hidden!important;padding:15px 12px!important;position:relative!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important}.mobile-menu-btn:hover{border-color:#00796b!important;box-shadow:0 8px 25px #00796b26!important;transform:translateY(-2px) scale(1.02)!important}.mobile-menu-btn:active{transform:translateY(0) scale(.98)!important}.btn-content{align-items:center;display:flex;flex-direction:column;gap:8px}.full-width .btn-content{flex-direction:row;gap:15px;text-align:left}.btn-icon{color:#00796b;font-size:20px;transition:all .3s ease}.mobile-menu-btn:hover .btn-icon{color:#004d40;transform:scale(1.1)}.btn-text{color:#333;font-size:13px;font-weight:600;text-align:center}.btn-subtitle{color:#666;font-size:10px;font-weight:500;text-align:center}.full-width .btn-subtitle,.full-width .btn-text{text-align:left}.btn-info{display:flex;flex-direction:column;gap:2px}.zoom-out-btn:hover{border-color:#f44336!important}.zoom-out-btn:hover .btn-icon{color:#f44336!important}.zoom-in-btn:hover{border-color:#4caf50!important}.zoom-in-btn:hover .btn-icon{color:#4caf50!important}.rotate-left-btn:hover{border-color:#ff9800!important}.rotate-left-btn:hover .btn-icon{color:#ff9800!important}.rotate-right-btn:hover{border-color:#ff9800!important}.rotate-right-btn:hover .btn-icon{color:#ff9800!important}.download-btn:hover{border-color:#2196f3!important}.download-btn:hover .btn-icon{color:#2196f3!important}.print-btn:hover{border-color:#9c27b0!important}.print-btn:hover .btn-icon{color:#9c27b0!important}.fullscreen-btn:hover{border-color:#607d8b!important}.fullscreen-btn:hover .btn-icon{color:#607d8b!important}.menu-footer{border-top:2px solid #e9ecef;margin-top:20px;padding-top:20px;text-align:center}.close-menu-btn{background:linear-gradient(135deg,#f44336,#d32f2f)!important;padding:12px 30px!important;transition:all .3s ease!important}.close-menu-btn:hover{box-shadow:0 6px 20px #f443364d!important}@media (max-width:480px){.menu-content{padding:20px 15px 25px}.mobile-menu-grid{grid-template-columns:1fr!important}.mobile-menu-btn{padding:12px 10px!important}}@keyframes slideUpIn{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-menu-toggle.compact-toggle{-webkit-tap-highlight-color:transparent!important;align-items:center!important;background:#00796be6!important;border:none!important;border-radius:8px!important;box-shadow:0 4px 12px #00796b4d!important;color:#fff!important;cursor:pointer!important;display:flex!important;font-size:16px!important;gap:8px!important;min-height:44px!important;min-width:80px!important;padding:12px 16px!important;position:relative!important;touch-action:manipulation!important;transition:all .2s ease!important;z-index:10!important}.mobile-menu-toggle.compact-toggle:hover{background:#00796b!important;transform:scale(1.05)!important}.mobile-menu-toggle.compact-toggle:active{background:#004d40!important;transform:scale(.95)!important}.enhanced-mobile-menu{align-items:flex-end!important;background:none!important;display:flex!important;justify-content:center!important;opacity:1!important;pointer-events:auto!important;position:fixed!important;visibility:visible!important;z-index:99999!important}.enhanced-mobile-menu,.menu-overlay{bottom:0!important;left:0!important;right:0!important;top:0!important}.menu-overlay{animation:fadeIn .3s ease!important;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important;background:#0009!important;cursor:pointer!important;position:absolute!important;z-index:1!important}.menu-content{animation:slideUpIn .4s cubic-bezier(.4,0,.2,1)!important;background:linear-gradient(145deg,#fff,#f8f9fa)!important;border-radius:25px 25px 0 0!important;box-shadow:0 -20px 60px #0000004d,0 -8px 20px #0000001a!important;max-height:85vh!important;max-width:100vw!important;opacity:1!important;overflow-y:auto!important;padding:25px 20px 30px!important;position:relative!important;visibility:visible!important;width:100%!important;z-index:2!important}.close-menu-btn{-webkit-tap-highlight-color:transparent!important;align-items:center!important;background:linear-gradient(135deg,#00796b,#004d40)!important;border:none!important;border-radius:25px!important;box-shadow:0 4px 12px #00796b4d!important;color:#fff!important;cursor:pointer!important;display:flex!important;font-size:16px!important;font-weight:600!important;gap:8px!important;margin:0 auto!important;min-height:44px!important;padding:12px 24px!important;touch-action:manipulation!important;transition:all .2s ease!important}.close-menu-btn:hover{background:linear-gradient(135deg,#004d40,#00251a)!important;transform:scale(1.05)!important}.close-menu-btn:active{background:linear-gradient(135deg,#00251a,#000)!important;transform:scale(.95)!important}.mobile-menu-btn{-webkit-tap-highlight-color:transparent!important;cursor:pointer!important;min-height:44px!important;touch-action:manipulation!important;transition:all .2s ease!important}.mobile-menu-btn:active{transform:scale(.95)!important}body.mobile-menu-open{overflow:hidden!important;position:fixed!important;top:0!important;width:100%!important}.mobile-menu.enhanced-mobile-menu{background:#ffff004d!important;border:2px solid red!important}.menu-content{background:#fff!important;border:2px solid blue!important;display:block!important}@media (max-width:768px){.enhanced-mobile-menu,.mobile-menu{display:flex!important;opacity:1!important;pointer-events:auto!important;visibility:visible!important}.menu-content,.menu-overlay{display:block!important;opacity:1!important;pointer-events:auto!important;visibility:visible!important}.pdf-header,.single-row-header{position:relative!important;z-index:1!important}}
/*# sourceMappingURL=main.a9ff6294.css.map*/