body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.prompt-thin{font-weight:100}.prompt-extralight,.prompt-thin{font-family:Prompt,sans-serif;font-style:normal}.prompt-extralight{font-weight:200}.prompt-light{font-weight:300}.prompt-light,.prompt-regular{font-family:Prompt,sans-serif;font-style:normal}.prompt-regular{font-weight:400}.prompt-medium{font-weight:500}.prompt-medium,.prompt-semibold{font-family:Prompt,sans-serif;font-style:normal}.prompt-semibold{font-weight:600}.prompt-bold{font-weight:700}.prompt-bold,.prompt-extrabold{font-family:Prompt,sans-serif;font-style:normal}.prompt-extrabold{font-weight:800}.prompt-black{font-family:Prompt,sans-serif;font-style:normal;font-weight:900}.prompt-thin-italic{font-weight:100}.prompt-extralight-italic,.prompt-thin-italic{font-family:Prompt,sans-serif;font-style:italic}.prompt-extralight-italic{font-weight:200}.prompt-light-italic{font-weight:300}.prompt-light-italic,.prompt-regular-italic{font-family:Prompt,sans-serif;font-style:italic}.prompt-regular-italic{font-weight:400}.prompt-medium-italic{font-weight:500}.prompt-medium-italic,.prompt-semibold-italic{font-family:Prompt,sans-serif;font-style:italic}.prompt-semibold-italic{font-weight:600}.prompt-bold-italic{font-weight:700}.prompt-bold-italic,.prompt-extrabold-italic{font-family:Prompt,sans-serif;font-style:italic}.prompt-extrabold-italic{font-weight:800}.prompt-black-italic{font-family:Prompt,sans-serif;font-style:italic;font-weight:900}.header{align-items:center;background-color:#fff;box-shadow:0 4px 4px #0003;display:flex;justify-content:space-between;padding:.75rem 2rem;position:relative;z-index:1000}.logo img{height:40px;transition:transform .2s ease}.logo img:hover{transform:scale(1.05)}.hamburger{background:none;border:none;cursor:pointer;display:none;flex-direction:column;padding:.5rem;z-index:1001}.hamburger span{background-color:#244d67;border-radius:3px;height:3px;margin:3px 0;transition:.3s;width:25px}.hamburger.open span:first-child{transform:rotate(-45deg) translate(-5px,6px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(45deg) translate(-5px,-6px)}.nav{align-items:center;display:flex}.nav-link{background:none;border:none;color:#244d67;cursor:pointer;font-family:Prompt,sans-serif;font-size:1rem;font-weight:400;margin-left:1.5rem;position:relative;transition:all .3s ease}.nav-link:hover{color:#007bff;transform:translateY(-1px)}.nav-link:after{background-color:#007bff;bottom:-5px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:all .3s ease;width:0}.nav-link:hover:after{width:100%}.start-btn{background-color:#20415a;box-shadow:0 4px 6px #0003;font-family:Prompt,sans-serif;font-size:1rem;font-weight:500;margin-left:2rem;padding:.6rem 1.5rem}.start-btn:hover{background-color:#1a374b;box-shadow:0 6px 12px #0000004d}.start-btn:active{box-shadow:0 4px 6px #0003;transform:translateY(0)}.overlay{display:none}@media (max-width:768px){.header{padding:.75rem 1.5rem}.nav-link{font-size:.9rem;margin-left:1rem}.start-btn{font-size:.9rem;margin-left:1.5rem;padding:.5rem 1.2rem}}@media (max-width:640px){.header{padding:.75rem 1rem}.hamburger{display:flex}.nav{align-items:stretch;background-color:#fff;box-shadow:-4px 0 10px #0000001a;flex-direction:column;height:100vh;justify-content:flex-start;padding:5rem 0 2rem;position:fixed;right:-100%;top:0;transition:right .3s ease;width:280px;z-index:1000}.nav.open{right:0}.nav-link{border-bottom:1px solid #f0f0f0;display:block;font-size:1.1rem;margin:0;padding:1rem 2rem;text-align:left;width:100%}.nav-link:hover{background-color:#f8f9fa;color:#007bff;transform:none}.nav-link:after{display:none}.start-btn{font-size:1rem;margin:1.5rem 2rem 0;padding:.8rem 1.5rem;text-align:center;width:auto}.overlay{background-color:#00000080;display:block;height:100vh;left:0;position:fixed;top:0;width:100%;z-index:999}}@media (max-width:480px){.header{padding:.5rem .75rem}.logo img{height:35px}.nav{padding:4rem 0 2rem;width:260px}.nav-link{font-size:1rem;padding:.8rem 1.5rem}.start-btn{font-size:.95rem;margin:1rem 1.5rem 0;padding:.7rem 1.2rem}}@media (prefers-reduced-motion:no-preference){.nav-link,.start-btn{transition:all .3s cubic-bezier(.4,0,.2,1)}}.main-footer{background-color:#2c3e50;color:#ecf0f1;margin-top:3rem;padding:2rem 0 0}.footer-content{display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.footer-logo h3{font-size:1.5rem;margin-bottom:.5rem}.footer-logo img{height:30px}.footer-logo p{color:#bdc3c7}.footer-links{display:flex;gap:3rem}.link-group h4{color:#3498db;font-size:1.1rem;margin-bottom:1rem}.link-group ul{list-style:none;padding:0}.link-group li{cursor:pointer;margin-bottom:.5rem}.link-group li:hover{color:#3498db}.footer-bottom{background-color:#1a252f;margin-top:2rem;padding:1rem;text-align:center}.footer-bottom p{color:#7f8c8d;font-size:.9rem;margin:0}.homepage{align-items:center;background-color:#fdfdfd;display:flex;gap:2rem;justify-content:space-between;min-height:80vh;padding:0 6rem}.content{display:flex;flex:1 1;flex-direction:column;justify-content:center;max-width:60%}.content h1{align-items:center;color:#0d3b66;display:flex;font-size:5rem;line-height:1.2;margin-bottom:1rem;min-height:6rem}.content p{color:#555;font-size:1.3rem;line-height:1.5;margin-bottom:2rem}.start-btn{align-self:flex-start;background-color:#0d3b66;border:none;border-radius:8px;box-shadow:0 4px 6px #0000001a;color:#fff;cursor:pointer;font-size:1.1rem;padding:.8rem 4rem;transition:all .3s ease;width:fit-content}.start-btn:hover{background-color:#155b96;box-shadow:0 6px 8px #00000026;transform:translateY(-2px)}.doc{align-items:center;display:flex;flex:1 1;justify-content:center;max-width:40%}.doc img{height:auto;max-width:450px;object-fit:contain;width:100%}@media (max-width:1200px){.homepage{padding:0 4rem}.content h1{font-size:4rem;min-height:5rem}.content p{font-size:1.2rem}.doc img{max-width:400px}}@media (max-width:992px){.homepage{flex-direction:column;gap:3rem;justify-content:center;padding:0 3rem;text-align:center}.content{align-items:center;max-width:100%}.content h1{font-size:3.5rem;min-height:4.5rem}.content p{font-size:1.1rem;max-width:80%}.start-btn{align-self:center;font-size:1.1rem;padding:1rem 3rem}.doc{max-width:60%}.doc img{max-width:350px}}@media (max-width:768px){.homepage{min-height:90vh;padding:2rem}.content h1{font-size:2.8rem;min-height:3.5rem;text-align:center}.content p{font-size:1rem;margin-bottom:2.5rem;max-width:90%}.start-btn{font-size:1rem;padding:.9rem 2.5rem}.doc{max-width:70%}.doc img{max-width:280px}}@media (max-width:576px){.homepage{padding:1.5rem}.content h1{font-size:2.2rem;min-height:3rem}.content p{font-size:.9rem;max-width:95%}.start-btn{font-size:.95rem;padding:.8rem 2rem}.doc{max-width:80%}.doc img{max-width:240px}}@media (max-width:480px){.homepage{gap:2rem;padding:1rem}.content h1{font-size:1.8rem;min-height:2.5rem}.content p{font-size:.85rem;margin-bottom:2rem}.start-btn{font-size:.9rem;padding:.7rem 1.5rem}.doc img{max-width:200px}}@media (max-width:360px){.homepage{padding:.8rem}.content h1{font-size:1.6rem;min-height:2.2rem}.content p{font-size:.8rem}.start-btn{font-size:.85rem;padding:.6rem 1.2rem}.doc img{max-width:240px}}.simple-page{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:2rem auto;max-width:800px;padding:2rem}.simple-page h1{color:#244d67;margin-bottom:.5rem;text-align:center}.simple-page h2{color:#244d67;margin-bottom:2rem;text-align:center}.simple-page img{display:block;height:40px;margin:0 auto}.page-content{padding:0 1rem}.contact-hours,.contact-info{background:#f8f9fa;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.contact-hours h3,.contact-info h3{color:#244d67;margin-bottom:1rem}.service-card{background:#f8f9fa;border-left:4px solid #244d67;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.service-card h3{color:#244d67;margin-bottom:.5rem}.service-card p{color:#244d67}.login-page{border:1px solid #ddd;border-radius:8px;margin:2rem auto;max-width:400px;padding:2rem}.login-page img{display:block;height:40px;margin:0 auto}.login-page h2{color:#34495e;margin-bottom:1.5rem;text-align:center}.form-group{margin-bottom:1rem}.form-group input{padding:.5rem}.register-link span{color:#3498db;cursor:pointer;margin-left:.5rem}.register-link span:hover{text-decoration:underline}.error-msg{color:red;margin-top:10px}.register-page{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:2rem auto;max-width:500px;padding:2rem}.register-page h1{color:#2c3e50;text-align:center}.register-page img{display:block;height:40px;margin:0 auto}.register-page h2{color:#34495e;margin-bottom:1.5rem;text-align:center}.form-group input{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.8rem;width:100%}.submit-btn{margin-top:1rem;padding:.8rem;width:100%}.submit-btn:hover{background-color:#3498db}.login-link{margin-top:1.5rem;text-align:center}.login-link span{color:#3498db;cursor:pointer;margin-left:.5rem}.login-link span:hover{text-decoration:underline}.role-selection-page{font-family:Inter,sans-serif;margin:2rem auto;max-width:800px;padding:2rem;text-align:center}.role-selection-page h1{color:#2c3e50;margin-bottom:.5rem}.role-selection-page h2{color:#34495e;margin-bottom:2rem}.role-options{gap:2rem;margin-top:2rem}.role-card,.role-options{display:flex;justify-content:center}.role-card{align-items:center;border-radius:8px;box-shadow:0 4px 8px #0000001a;cursor:pointer;flex:1 1;flex-direction:column;max-width:350px;padding:2rem;transition:transform .3s,box-shadow .3s}.role-card:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-5px)}.role-card h3{color:#2c3e50;font-weight:700;margin-bottom:1rem}.role-card p{color:#7f8c8d;font-size:.95rem;line-height:1.5}.patient{background-color:#e8f4fc;border:1px solid #3498db}.doctor{background-color:#f0f8f0;border:1px solid #27ae60}@media (max-width:768px){.role-options{align-items:center;flex-direction:column}.role-card{max-width:90%}}.create-account-page,.verification-page{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:2rem}.create-account-container,.verification-container{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;max-width:400px;padding:3rem;text-align:center;width:100%}h1{color:#2c3e50;font-size:1.8rem;margin-bottom:1rem}.subtitle{color:#7f8c8d;font-size:.95rem;margin-bottom:2rem}.create-account-form,.verification-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{align-items:flex-start;display:flex;flex-direction:column;gap:.5rem}label{color:#34495e;font-size:.9rem;font-weight:500}.code-input,.form-input{border:2px solid #e0e0e0;border-radius:6px;box-sizing:border-box;font-size:1rem;padding:.75rem;transition:border-color .3s;width:100%}.code-input:focus,.form-input:focus{border-color:#3498db;outline:none}.code-input{font-size:1.2rem;font-weight:700;letter-spacing:2px;text-align:center}.create-button,.verify-button{background:#3498db;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:background .3s}.create-button:hover,.verify-button:hover{background:#2980b9}.back-button{background:#0000;color:#7f8c8d;font-size:.9rem;margin-top:1rem;padding:.5rem;transition:color .3s}.back-button:hover{color:#34495e}.error-message{color:#e74c3c;font-size:.8rem;margin-top:.25rem}@media (max-width:768px){.create-account-container,.verification-container{margin:1rem;padding:2rem}}.form-page{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:2rem auto;max-width:800px;padding:4rem}.form-page h1{color:#2c3e50;margin-bottom:.5rem;text-align:center}.form-page img{display:block;height:40px;margin:0 auto}.form-page h2{color:#34495e;margin-bottom:2rem;text-align:center}.form-section{border-bottom:1px solid #eee;margin-bottom:2rem;padding-bottom:1.5rem}.form-section h3{color:#2c3e50;margin-bottom:1.2rem}.form-row{display:flex;gap:2.5rem;margin-bottom:1rem}.form-row .form-group{flex:1 1}.form-group{margin-bottom:1.2rem}.form-group label{color:#34495e;display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.8rem;width:100%}.form-group select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .8rem center;background-repeat:no-repeat;background-size:1rem}.form-actions{margin-top:2rem;text-align:center}.submit-btn{background-color:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.8rem 2rem;transition:background-color .3s}.submit-btn:hover{background-color:#2980b9}.pd-patient-avatar-placeholder{border-radius:50%}.pd-doctor-avatar-placeholder.small{height:40px;width:40px}@media (max-width:768px){.pd-main-content{gap:16px;grid-template-columns:1fr;padding:16px}.pd-content-wrapper{padding-bottom:80px}.pd-left-column,.pd-right-column{gap:16px}.pd-sidebar{align-items:center;border-top:1px solid #e2e8f0;border-top:1px solid var(--pd-border-color);bottom:0;flex-direction:row;height:65px;justify-content:space-around;left:0;padding:0 10px;position:fixed;width:100%;z-index:1000}.pd-sidebar-footer,.pd-sidebar-nav{flex-direction:row;flex-grow:0;gap:16px;margin-top:0}.pd-sidebar-nav{flex-grow:1;justify-content:center}.pd-sidebar-footer{position:absolute;right:16px}.pd-sidebar-nav a:first-child,.pd-sidebar-nav a:nth-child(2),.pd-sidebar-nav a:nth-child(3){flex:1 1;text-align:center}.pd-nav-item{font-size:1.4rem;padding:8px}.pd-app-header{padding:12px 16px}.logo img{margin-left:0}.pd-patient-id{display:none}.pd-header-right{gap:16px}.pd-card{padding:16px}.pd-appointment-item{flex-wrap:wrap;gap:12px}.pd-appt-details{width:calc(100% - 60px)}.pd-analysis-section{gap:16px;grid-template-columns:1fr}.pd-analysis-results-grid{grid-template-columns:repeat(2,1fr)}.pd-camera-icon-wrapper{height:90px;margin-bottom:16px;width:90px}.pd-take-photo-btn{justify-content:center;padding:14px;width:100%}}.calendar-container{width:20r}.pd-card{box-shadow:0 4px 8px #0000000d;display:flex;flex-direction:column;padding:24px}.pd-card-header{font-size:1.25rem;margin-bottom:20px}.pd-analysis-results-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));justify-items:center}.pd-result-image{border-radius:8px;object-fit:cover}.pd-result-icon,.pd-result-image{border:1px solid #ddd;height:100px;margin-bottom:8px;width:100px}.pd-result-icon{align-items:center;border-radius:8px;color:#ccc;display:flex;justify-content:center}.pd-result-icon svg{height:50px;width:50px}.pd-result-item span{color:#555;font-size:.875rem;font-weight:500}.pd-card{background:#fff;box-shadow:0 4px 6px #0000001a;color:#333;font-family:Inter,sans-serif;margin:16px;padding:16px}.pd-card-header{color:#333;font-size:18px}.error-message-box{background:#ffebee;color:#c62828;padding:8px 12px}.error-message-box,.info-message-box{border-radius:4px;font-size:14px;margin-bottom:16px}.info-message-box{background:#e3f2fd;color:#1976d2;padding:12px;text-align:center}.loading-container{gap:8px}.loading-spinner{border:2px solid #1976d2;border-top-color:#0000;height:16px;width:16px}.model-container{position:relative}.model-canvas-wrapper{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;display:flex;height:400px;justify-content:center;overflow:hidden;width:100%}.placeholder-text{color:#666;text-align:center}.placeholder-icon{font-size:48px;margin-bottom:12px}.placeholder-subtext{font-size:14px;margin:4px 0 0;opacity:.7}.model-controls{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:12px}.control-button{border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .2s ease-in-out,transform .1s ease-in-out}.control-button:hover{transform:translateY(-2px)}.reset-button{background-color:#2196f3}.texture-button{background-color:#4caf50}.model-info-text{color:#666}.model-info-text,.session-id-display{font-size:12px;margin-top:8px;text-align:center}.session-id-display{color:#999}.image-modal-backdrop{align-items:center;background-color:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.image-modal-content{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-height:90vh;max-width:90vw;overflow:hidden;position:relative}.modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:16px}.modal-title{font-size:18px;margin:0}.modal-close-button{background:none;border:none;color:#666;cursor:pointer;font-size:24px}.modal-body{align-items:center;display:flex;justify-content:center;padding:16px}.modal-image{aspect-ratio:1/1;border-radius:4px;height:auto;max-height:70vh;max-width:70vw;object-fit:contain;width:auto}:root{--pd-bg-color:#f8f9fa;--pd-sidebar-bg:#1e293b;--pd-card-bg:#fff;--pd-text-primary:#1e293b;--pd-text-secondary:#64748b;--pd-text-light:#f8fafc;--pd-accent-color:#4f46e5;--pd-border-color:#e2e8f0;--pd-status-confirmed-bg:#dcfce7;--pd-status-confirmed-text:#166534;--pd-status-scheduled-bg:#e0e7ff;--pd-status-scheduled-text:#4338ca;--pd-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.pd-main-container{background-color:#f8f9fa;background-color:var(--pd-bg-color);display:flex;font-family:Inter,sans-serif;min-height:100vh}.pd-content-wrapper{display:flex;flex-direction:column;flex-grow:1;height:100vh;overflow-y:auto}.pd-main-content{grid-gap:24px;display:grid;flex-grow:1;gap:24px;grid-template-columns:320px 1fr;padding:24px}.pd-left-column,.pd-right-column{display:flex;flex-direction:column;gap:24px}.pd-card{background-color:#fff;background-color:var(--pd-card-bg);border:1px solid #e2e8f0;border:1px solid var(--pd-border-color);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--pd-shadow);padding:20px}.pd-card-header{color:#1e293b;color:var(--pd-text-primary);font-size:1.1rem;font-weight:600;gap:8px;margin:0 0 16px}.pd-card-header,.pd-sidebar{align-items:center;display:flex}.pd-sidebar{background-color:#1e293b;background-color:var(--pd-sidebar-bg);flex-direction:column;flex-shrink:0;height:100vh;padding:20px 0;position:sticky;top:0;width:80px}.pd-sidebar-logo{align-items:center;background-color:#4f46e5;background-color:var(--pd-accent-color);border-radius:12px;color:#f8fafc;color:var(--pd-text-light);display:flex;font-size:1.8rem;font-weight:700;height:48px;justify-content:center;margin-bottom:40px;width:48px}.pd-sidebar-nav{flex-grow:1;margin-top:3rem}.pd-sidebar-footer,.pd-sidebar-nav{display:flex;flex-direction:column;gap:16px}.pd-nav-item{border-radius:8px;color:#94a3b8;font-size:1.5rem;padding:12px;text-decoration:none;transition:all .2s ease-in-out}.pd-nav-item:hover{background-color:#334155}.pd-nav-item.active,.pd-nav-item:hover{color:#f8fafc;color:var(--pd-text-light)}.pd-nav-item.active{background-color:#4f46e5;background-color:var(--pd-accent-color)}.pd-app-header{align-items:center;background-color:#fff;background-color:var(--pd-card-bg);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--pd-border-color);display:flex;justify-content:space-between;padding:16px 24px;position:sticky;top:0;z-index:10}.logo img{cursor:pointer;height:2.2rem;margin-left:1.5rem}.pd-header-title{font-size:1.5rem;font-weight:700;margin:0}.pd-header-right{align-items:center;display:flex;gap:24px}.pd-patient-id{background-color:#f8f9fa;background-color:var(--pd-bg-color);border-radius:6px;padding:6px 12px}.pd-icon-button{background:none;border:none;color:#64748b;color:var(--pd-text-secondary);cursor:pointer;font-size:1.25rem}.pd-user-profile{align-items:center;display:flex;gap:12px}.pd-user-avatar-placeholder{align-items:center;background-color:#1e293b;background-color:var(--pd-sidebar-bg);border-radius:50%;color:#fff;display:flex;font-weight:600;height:40px;justify-content:center;width:40px}.pd-user-name{font-weight:600}.pd-patient-info-card{align-items:center;display:flex;flex-direction:column;text-align:center}.pd-patient-avatar-placeholder{align-items:center;background-color:#cbd5e1;border-radius:80%;color:#1e293b;color:var(--pd-text-primary);display:flex;font-size:2rem;font-weight:600;height:80px;justify-content:center;margin-bottom:12px;width:80px}.pd-patient-name{font-size:1.2rem;font-weight:600}.pd-patient-role{margin:4px 0 16px}.pd-patient-details,.pd-patient-role{color:#64748b;color:var(--pd-text-secondary);font-size:.9rem}.pd-patient-details{border-top:1px solid #e2e8f0;border-top:1px solid var(--pd-border-color);padding-top:16px;text-align:left;width:100%}.pd-patient-details p{margin:8px 0}.pd-patient-details p strong{color:#1e293b;color:var(--pd-text-primary)}.pd-calendar-header-container{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.pd-calendar-title{font-size:1.1rem;font-weight:600;margin:0}.pd-calendar-month{color:#64748b;color:var(--pd-text-secondary);font-size:.9rem}.pd-calendar-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr);text-align:center}.pd-calendar-day-name{color:#64748b;color:var(--pd-text-secondary);font-size:.8rem;font-weight:500;padding-bottom:8px}.pd-calendar-day{border-radius:50%;cursor:pointer;font-size:.9rem;padding:8px;transition:background-color .2s}.pd-calendar-day:hover{background-color:#f1f5f9}.pd-calendar-day.active{background-color:#1e293b;background-color:var(--pd-sidebar-bg);color:#f8fafc;color:var(--pd-text-light);font-weight:600}.pd-patients-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.pd-add-patient-btn{align-items:center;background-color:#4f46e5;background-color:var(--pd-accent-color);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;padding:8px 16px;transition:background-color .2s}.pd-add-patient-btn:hover{background-color:#3730a3}.pd-search-container{margin-bottom:16px;position:relative}.pd-search-icon{color:#64748b;color:var(--pd-text-secondary);font-size:1rem;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.pd-search-input{background-color:#f8f9fa;background-color:var(--pd-bg-color);border:1px solid #e2e8f0;border:1px solid var(--pd-border-color);border-radius:6px;box-sizing:border-box;font-size:.9rem;padding:10px 12px 10px 40px;width:100%}.pd-search-input:focus{border-color:#4f46e5;border-color:var(--pd-accent-color);outline:none}.pd-patients-list{display:flex;flex-direction:column;gap:12px}.pd-patient-item{grid-gap:16px;align-items:center;background-color:#fdfdff;border:1px solid #e2e8f0;border:1px solid var(--pd-border-color);border-radius:8px;display:grid;gap:16px;grid-template-columns:auto 1fr auto;padding:16px;transition:all .2s ease}.pd-patient-item:hover{background-color:#f8f9fa;border-color:#4f46e5;border-color:var(--pd-accent-color);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.pd-patient-avatar-placeholder.small{align-items:center;background-color:#e2e8f0;border:3px solid #4f46e5;border:3px solid var(--pd-accent-color);border-radius:12px;color:#1e293b;color:var(--pd-text-primary);display:flex;flex-shrink:0;font-size:1.5rem;font-weight:700;height:64px;justify-content:center;width:64px}.pd-patient-info{display:flex;flex-direction:column;gap:4px;min-width:0}.pd-patient-name{color:#1e293b;color:var(--pd-text-primary);font-size:1.1rem;font-weight:700}.pd-patient-id,.pd-patient-name{margin:0;text-overflow:ellipsis;white-space:nowrap}.pd-patient-id{color:#64748b;color:var(--pd-text-secondary);font-size:.9rem;font-weight:500}.pd-patient-actions{display:flex;flex-shrink:0;gap:12px;margin-top:5.5rem}.pd-status-select{background-color:#f8f9fa;border:1px solid #e2e8f0;border:1px solid var(--pd-border-color,#ddd);border-radius:20px;color:#64748b;color:var(--pd-text-secondary,#666);cursor:pointer;font-size:.85rem;font-weight:500;min-width:120px;outline:none;padding:6px 12px;transition:all .3s ease}.pd-status-select.pending{background-color:#f8f9fa;border-color:#dee2e6;color:#6c757d}.pd-status-select.pending:hover{background-color:#e9ecef;border-color:#ced4da}.pd-status-select.in-progress{background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.pd-status-select.in-progress:hover{background-color:#ffecb5;border-color:#ffe082}.pd-status-select.completed{background-color:#d4edda;border-color:#c3e6cb;color:#155724}.pd-status-select.completed:hover{background-color:#c3e6cb;border-color:#b8dabd}.pd-status-select:hover{box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.pd-status-select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff40}.pd-status-select:disabled{cursor:not-allowed;opacity:.6;transform:none}.pd-status-select:disabled:hover{box-shadow:none;transform:none}.pd-history-btn{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--pd-border-color,#ddd);border-radius:50%;color:#64748b;color:var(--pd-text-secondary,#666);cursor:pointer;display:flex;height:32px;justify-content:center;padding:6px;transition:all .3s ease;width:32px}.pd-history-btn:hover{background-color:#f8f9fa;box-shadow:0 2px 4px #0000001a;color:#007bff;transform:translateY(-1px)}.pd-history-btn:active{transform:translateY(0)}@media (max-width:768px){.pd-status-select{font-size:.8rem;min-width:100px;padding:4px 8px}.pd-history-btn{height:28px;width:28px}}.pd-doctor-list{display:flex;flex-direction:column;gap:16px}.pd-doctor-item{align-items:center;display:flex;gap:12px}.pd-doctor-avatar-placeholder{background-color:#e2e8f0;border-radius:50%;flex-shrink:0;height:48px;width:48px}.pd-doctor-info{line-height:1.4}.pd-doctor-name{font-size:.95rem;font-weight:600;margin:0}.pd-doctor-specialty,.pd-doctor-visit{color:#64748b;color:var(--pd-text-secondary);font-size:.85rem;margin:2px 0 0}.pd-appointments-list{display:flex;flex-direction:column;gap:16px}.pd-appointment-item{background-color:#fdfdff;gap:16px;padding:16px}.pd-appointment-item,.pd-appt-date-box{align-items:center;border:1px solid #e2e8f0;border:1px solid var(--pd-border-color);border-radius:8px;display:flex}.pd-appt-date-box{background-color:#fff;background-color:var(--pd-card-bg);flex-shrink:0;font-size:1.2rem;font-weight:600;height:48px;justify-content:center;width:48px}.pd-appt-details{flex-grow:1;line-height:1.4}.pd-appt-title{font-weight:600;margin:0}.pd-appt-doctor,.pd-appt-time{color:#64748b;color:var(--pd-text-secondary);font-size:.9rem;margin:2px 0 0}.pd-appt-status{border-radius:16px;font-size:.8rem;font-weight:500;padding:4px 12px}.pd-appt-status.confirmed{background-color:#dcfce7;background-color:var(--pd-status-confirmed-bg);color:#166534;color:var(--pd-status-confirmed-text)}.pd-appt-status.scheduled{background-color:#e0e7ff;background-color:var(--pd-status-scheduled-bg);color:#4338ca;color:var(--pd-status-scheduled-text)}.pd-skin-analysis-card .pd-analysis-content{align-items:center;display:flex;flex-direction:column;flex-grow:1;justify-content:center;padding:24px 0;text-align:center}.pd-camera-icon-wrapper{background-color:#1e293b;background-color:var(--pd-sidebar-bg);border-radius:50%;height:120px;justify-content:center;margin-bottom:24px;width:120px}.pd-camera-icon-wrapper,.pd-take-photo-btn{align-items:center;color:#f8fafc;color:var(--pd-text-light);display:flex}.pd-take-photo-btn{background-color:#1e293b;background-color:var(--pd-text-primary);border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;gap:8px;padding:12px 24px;transition:background-color .2s}.pd-take-photo-btn:hover{background-color:#334155}.pd-analysis-caption{color:#64748b;color:var(--pd-text-secondary);font-size:.9rem;margin-top:12px}.pd-analysis-section{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.pd-analysis-results-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr;height:80%;min-height:50px}.pd-result-item{align-items:center;background-color:#f8f9fa;border:1px solid #e2e8f0;border:1px solid var(--pd-border-color);border-radius:8px;color:#64748b;color:var(--pd-text-secondary);cursor:pointer;display:flex;flex-direction:column;font-size:.85rem;font-weight:500;gap:8px;justify-content:center;padding:16px;text-align:center}.pd-result-icon{color:#1e293b;color:var(--pd-text-primary);font-size:1.5rem}.pd-skin-model-card .pd-model-placeholder{align-items:center;background-color:#f8f9fa;border:1px solid #e2e8f0;border:1px solid var(--pd-border-color);border-radius:8px;color:#64748b;color:var(--pd-text-secondary);display:flex;flex-direction:column;height:80%;justify-content:center;min-height:120px}.pd-model-icon{font-size:2.5rem;margin-bottom:8px}.pd-model-icon,.pd-model-placeholder p{color:#1e293b;color:var(--pd-text-primary)}.pd-model-placeholder p{font-weight:600;margin:0}.pd-model-placeholder span{font-size:.8rem}.pd-recent-patients-list{display:flex;flex-direction:column;gap:12px}.pd-recent-patient-item{align-items:center;background-color:#fdfdff;border:1px solid #e2e8f0;border:1px solid var(--pd-border-color);border-radius:8px;display:flex;justify-content:space-between;padding:12px}.pd-patient-basic-info{flex-grow:1}.pd-patient-name-recent{font-size:.95rem;font-weight:600;margin:0}.pd-patient-condition{color:#64748b;color:var(--pd-text-secondary);font-size:.85rem;margin:2px 0}.pd-patient-last-visit{color:#64748b;color:var(--pd-text-secondary);font-size:.8rem;margin:2px 0 0}.pd-patient-status-badge{border-radius:12px;font-size:.75rem;font-weight:500;padding:4px 8px;white-space:nowrap}.pd-patient-status-badge.improving{background-color:#dcfce7;background-color:var(--pd-status-confirmed-bg);color:#166534;color:var(--pd-status-confirmed-text)}.pd-patient-status-badge.stable{background-color:#e0e7ff;background-color:var(--pd-status-scheduled-bg);color:#4338ca;color:var(--pd-status-scheduled-text)}.pd-patient-status-badge.under-review{background-color:#fef3c7;color:#92400e}.pd-notes-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.pd-notes-doctor-name{font-weight:600;margin:0}.pd-notes-date{font-size:.9rem;font-weight:400;margin-left:8px}.pd-notes-content,.pd-notes-date{color:#64748b;color:var(--pd-text-secondary)}.pd-notes-content{font-size:.95rem;line-height:1.6}.pd-notes-content p{margin:0 0 1em}.pd-notes-content p:last-child{margin-bottom:0}.pd-notes-content strong{color:#1e293b;color:var(--pd-text-primary)}.pd-medication-list{margin:0;padding-left:20px}.pd-medication-list li{margin-bottom:4px}@media (max-width:768px){.pd-main-content{gap:16px;grid-template-columns:1fr;padding:16px}.pd-content-wrapper{padding-bottom:80px}.pd-left-column,.pd-right-column{gap:16px}.pd-sidebar{align-items:center;border-top:1px solid #e2e8f0;border-top:1px solid var(--pd-border-color);bottom:0;flex-direction:row;height:65px;justify-content:space-around;left:0;padding:0 10px;position:fixed;width:100%;z-index:1000}.pd-sidebar-footer,.pd-sidebar-nav{flex-direction:row;flex-grow:0;gap:16px;margin-top:0}.pd-sidebar-nav{flex-grow:1;justify-content:center}.pd-sidebar-footer{position:absolute;right:16px}.pd-sidebar-nav a:first-child,.pd-sidebar-nav a:nth-child(2),.pd-sidebar-nav a:nth-child(3){flex:1 1;text-align:center}.pd-nav-item{font-size:1.4rem;padding:8px}.pd-app-header{padding:12px 16px}.logo img{margin-left:0}.pd-patient-id{display:none}.pd-header-right{gap:16px}.pd-card{padding:16px}.pd-appointment-item{flex-wrap:wrap;gap:12px}.pd-appt-details{width:calc(100% - 60px)}.pd-analysis-section{gap:16px;grid-template-columns:1fr}.pd-analysis-results-grid{grid-template-columns:repeat(2,1fr)}.pd-camera-icon-wrapper{height:90px;margin-bottom:16px;width:90px}.pd-take-photo-btn{justify-content:center;padding:14px;width:100%}.pd-patients-header{align-items:stretch;flex-direction:column;gap:12px}.pd-add-patient-btn{justify-content:center;width:100%}.pd-status-select{flex-grow:1;margin-right:8px}}@media (max-width:480px){.pd-header-right .pd-user-name{display:none}.pd-header-right{gap:12px}.pd-analysis-results-grid{grid-template-columns:1fr}.pd-sidebar-footer{display:none}.pd-sidebar-nav{justify-content:space-around}}.pd-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.pd-modal-content{animation:slideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 25px 50px -12px #00000040;max-height:90vh;max-width:500px;overflow-y:auto;padding:0;width:90%}.pd-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--pd-border-color);display:flex;justify-content:space-between;padding:24px 24px 16px}.pd-modal-header h3{color:#1e293b;color:var(--pd-text-primary);font-size:1.25rem;font-weight:600;margin:0}.pd-modal-close{background:none;border:none;border-radius:4px;color:#64748b;color:var(--pd-text-secondary);cursor:pointer;font-size:1.5rem;padding:4px;transition:all .2s ease}.pd-modal-close:hover{background-color:#f1f5f9;color:#1e293b;color:var(--pd-text-primary)}.pd-modal-form{padding:24px}.pd-form-group{margin-bottom:20px}.pd-form-group label{color:#1e293b;color:var(--pd-text-primary);display:block;font-size:.9rem;font-weight:500;margin-bottom:8px}.pd-form-group input,.pd-form-group select{border:1px solid #e2e8f0;border:1px solid var(--pd-border-color);border-radius:8px;box-sizing:border-box;font-size:.95rem;padding:12px 16px;transition:border-color .2s ease;width:100%}.pd-form-group input:focus,.pd-form-group select:focus{border-color:#4f46e5;border-color:var(--pd-accent-color);box-shadow:0 0 0 3px #4f46e51a;outline:none}.pd-form-group input::placeholder{color:#64748b;color:var(--pd-text-secondary)}.pd-form-group select{background-color:#fff;cursor:pointer}.pd-modal-actions{border-top:1px solid #e2e8f0;border-top:1px solid var(--pd-border-color);display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:24px}.pd-btn-cancel{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--pd-border-color);border-radius:8px;color:#64748b;color:var(--pd-text-secondary);cursor:pointer;font-size:.95rem;font-weight:500;padding:12px 24px;transition:all .2s ease}.pd-btn-cancel:hover{background-color:#f8f9fa;border-color:#64748b;border-color:var(--pd-text-secondary)}.pd-btn-submit{background:#4f46e5;background:var(--pd-accent-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:12px 24px;transition:all .2s ease}.pd-btn-submit:hover{background-color:#3730a3;transform:translateY(-1px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:768px){.pd-modal-content{margin:20px;width:95%}.pd-modal-header{padding:20px 20px 16px}.pd-modal-form{padding:20px}.pd-modal-actions{flex-direction:column;gap:8px}.pd-btn-cancel,.pd-btn-submit{padding:14px;width:100%}}@media (max-width:480px){.pd-modal-content{margin:10px;max-height:95vh;width:100%}.pd-modal-header{padding:16px 16px 12px}.pd-modal-form{padding:16px}.pd-form-group{margin-bottom:16px}}.pd-date-input-group{align-items:center;display:flex;gap:12px}.pd-date-select{background-color:#fff;border:1px solid #e2e8f0;border:1px solid var(--pd-border-color);border-radius:8px;box-sizing:border-box;cursor:pointer;flex:1 1;font-size:.95rem;min-width:80px;padding:12px 16px;transition:border-color .2s ease}.pd-date-select:focus{border-color:#4f46e5;border-color:var(--pd-accent-color);box-shadow:0 0 0 3px #4f46e51a;outline:none}.pd-date-select option{padding:8px}.pd-code-display-container{align-items:center;display:flex;gap:12px;margin-bottom:20px}.pd-code-display{align-items:center;background-color:#f8f9fa;border:2px solid #e2e8f0;border:2px solid var(--pd-border-color);border-radius:12px;cursor:text;display:flex;flex:1 1;font-family:Courier New,monospace;font-size:1.5rem;font-weight:600;letter-spacing:2px;padding:16px 20px;transition:all .2s ease;-webkit-user-select:all;user-select:all}.pd-code-display:hover{background-color:#f1f5f9;border-color:#4f46e5;border-color:var(--pd-accent-color)}.pd-code-hash{color:#64748b;color:var(--pd-text-secondary);margin-right:4px}.pd-code-text{color:#4f46e5;color:var(--pd-accent-color);font-weight:700}.pd-copy-btn{align-items:center;background-color:#4f46e5;background-color:var(--pd-accent-color);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;height:48px;justify-content:center;min-width:48px;padding:12px;transition:all .2s ease}.pd-copy-btn:hover{background-color:#3730a3;transform:translateY(-1px)}.pd-copy-btn:active{transform:translateY(0)}.pd-code-instruction{background-color:#f8f9fa;border-left:4px solid #4f46e5;border-left:4px solid var(--pd-accent-color);border-radius:8px;color:#64748b;color:var(--pd-text-secondary);font-size:.95rem;line-height:1.6;margin:0 0 24px;padding:16px;text-align:center}@media (max-width:768px){.pd-date-input-group{gap:8px}.pd-date-select{font-size:.9rem;min-width:70px;padding:10px 12px}.pd-code-display{font-size:1.2rem;padding:12px 16px}.pd-code-display-container{flex-direction:column;gap:16px}.pd-copy-btn{font-size:1rem;padding:14px;width:100%}}@media (max-width:480px){.pd-date-input-group{flex-direction:column;gap:12px}.pd-date-select{min-width:auto;width:100%}.pd-code-display{font-size:1.1rem;letter-spacing:1px}}.calendar-page{margin:0 auto;max-width:1200px;padding:20px}.calendar-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.calendar-title h1{color:#333;font-size:2rem;font-weight:600;margin:0}.calendar-title p{color:#666;font-size:.9rem;margin:5px 0 0}.add-appointment-btn{align-items:center;background:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:8px;padding:12px 20px;transition:background .3s}.add-appointment-btn:hover{background:#45a049}.calendar-container{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 400px}.calendar-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:20px}.calendar-nav{justify-content:space-between;margin-bottom:20px}.calendar-nav,.nav-btn{align-items:center;display:flex}.nav-btn{background:#f5f5f5;border:none;border-radius:50%;cursor:pointer;justify-content:center;padding:10px;transition:background .3s}.nav-btn:hover{background:#e0e0e0}.month-year{color:#333;font-size:1.5rem;font-weight:600;margin:0}.calendar-grid{width:100%}.calendar-weekdays{grid-gap:1px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);margin-bottom:10px}.weekday{color:#666;font-size:.9rem;font-weight:600;padding:10px;text-align:center}.calendar-days{grid-gap:1px;background:#f0f0f0;border-radius:8px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);overflow:hidden}.calendar-day{align-items:flex-start;background:#fff;cursor:pointer;display:flex;flex-direction:column;min-height:80px;padding:8px;position:relative;transition:all .3s}.calendar-day.inactive{background:#f9f9f9;cursor:not-allowed}.calendar-day.active:hover{background:#f0f8ff}.calendar-day.selected{background:#e3f2fd;border:2px solid #2196f3}.calendar-day.has-appointments{background:#f0f8ff;border-left:4px solid #4caf50}.day-number{color:#333;font-size:.9rem;font-weight:600}.appointment-indicators{display:flex;flex-wrap:wrap;gap:2px;margin-top:5px}.appointment-dot{background:#4caf50;border-radius:50%;height:6px;width:6px}.appointment-details{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;height:fit-content;padding:20px}.details-header h3{color:#333;font-size:1.2rem;font-weight:600;margin:0 0 20px}.appointments-list{margin-bottom:30px}.appointment-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:15px;padding:16px;transition:all .3s}.appointment-card:hover{box-shadow:0 4px 12px #0000001a}.appointment-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.appointment-header h4{color:#333;font-size:1rem;margin:0}.status{border-radius:4px;font-size:.8rem;font-weight:500;padding:4px 8px;text-transform:uppercase}.status.confirmed{background:#d4edda;color:#155724}.status.scheduled{background:#fff3cd;color:#856404}.appointment-details-info{margin-bottom:15px}.detail-item{align-items:center;color:#666;display:flex;font-size:.9rem;gap:8px;margin-bottom:8px}.detail-icon{color:#888;height:16px;width:16px}.appointment-actions{display:flex;gap:10px}.action-btn{border:none;border-radius:6px;cursor:pointer;font-size:.85rem;padding:8px 16px;transition:all .3s}.action-btn.primary{background:#2196f3;color:#fff}.action-btn.primary:hover{background:#1976d2}.action-btn.secondary{background:#f5f5f5;color:#666}.action-btn.secondary:hover{background:#e0e0e0}.no-appointments,.select-date-prompt{color:#666;padding:40px 20px;text-align:center}.upcoming-section{border-top:1px solid #e0e0e0;padding-top:20px}.upcoming-section h4{color:#333;font-size:1.1rem;margin:0 0 15px}.upcoming-list{display:flex;flex-direction:column;gap:10px}.upcoming-item{background:#f8f9fa;border-radius:6px;display:flex;gap:15px;padding:10px;transition:background .3s}.upcoming-item:hover{background:#e9ecef}.upcoming-date{align-items:center;display:flex;flex-direction:column;min-width:50px}.date-day{color:#333;font-size:1.2rem;font-weight:600}.date-month{color:#666;font-size:.8rem;text-transform:uppercase}.upcoming-info h5{color:#333;font-size:.9rem;margin:0 0 4px}.upcoming-info p{color:#666;font-size:.85rem;margin:0 0 4px}.upcoming-info small{color:#888;font-size:.8rem}@media (max-width:768px){.calendar-container{grid-template-columns:1fr}.calendar-header{align-items:flex-start;flex-direction:column;gap:15px}.calendar-day{min-height:60px}.appointment-details{order:-1}}.camera-container{background-color:#000;height:100vh;overflow:hidden;position:relative;width:100vw}.back-button{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;left:20px;position:absolute;top:20px;transition:all .3s ease;width:48px;z-index:1000}.back-button:hover{background:#000000e6;transform:scale(1.1)}.camera-video{height:100%;object-fit:cover;transform:scaleX(-1);width:100%}.camera-canvas{transform:scaleX(-1)}.camera-canvas,.green-overlay{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.green-overlay{animation:pulse 2s infinite;background:#00ff001a}@keyframes pulse{0%{background:#00ff001a}50%{background:#0f03}to{background:#00ff001a}}.scan-frame-container{align-items:center;display:flex;height:100%;justify-content:center;left:0;pointer-events:none;position:absolute;top:0;width:100%}.scan-frame-wrapper{height:400px;max-height:60vh;max-width:80vw;position:relative;width:300px}.scan-frame{border-radius:20px;height:100%;position:relative;width:100%}.scan-corners{height:100%;left:0;position:absolute;top:0;width:100%}.corner{border-radius:8px;height:40px;position:absolute;transition:all .3s ease;width:40px}.corner-tl{border-left:4px solid;left:-20px}.corner-tl,.corner-tr{border-top:4px solid;top:-20px}.corner-tr{border-right:4px solid;right:-20px}.corner-bl{border-left:4px solid;left:-20px}.corner-bl,.corner-br{border-bottom:4px solid;bottom:-20px}.corner-br{border-right:4px solid;right:-20px}.corner-default{border-color:#fff;opacity:.8}.corner-success{border-color:#0f0;box-shadow:0 0 20px #00ff0080;opacity:1}.frame-border{border:2px solid;border-radius:20px;height:100%;left:0;position:absolute;top:0;transition:all .3s ease;width:100%}.frame-border-default{animation:scanning 2s infinite;border-color:#ffffff80}.frame-border-success{border-color:#0f0;box-shadow:0 0 30px #00ff004d}@keyframes scanning{0%{border-color:#ffffff4d}50%{border-color:#fffc}to{border-color:#ffffff4d}}.direction-text{bottom:-60px;left:50%;position:absolute;text-align:center;transform:translateX(-50%);width:100%}.direction-message{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:25px;display:inline-block;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.direction-default{background:#ffffffe6;color:#333}.direction-success{animation:success-glow 2s infinite;background:#00ff00e6;color:#000}@keyframes success-glow{0%{box-shadow:0 0 20px #00ff004d}50%{box-shadow:0 0 30px #0f09}to{box-shadow:0 0 20px #00ff004d}}.camera-paused{align-items:center;background:#000c;display:flex;height:100%;justify-content:center;left:0;position:absolute;top:0;width:100%;z-index:100}.camera-paused-content{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#000000e6;border-radius:20px;color:#fff;padding:40px;text-align:center}.camera-paused-icon{font-size:48px;margin-bottom:20px}.loading-container{align-items:center;background:linear-gradient(135deg,#1e3c72,#2a5298);color:#fff;display:flex;flex-direction:column;height:100%;justify-content:center;left:0;position:absolute;top:0;width:100%}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:60px;margin-bottom:20px;width:60px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-text{font-size:18px;font-weight:500;opacity:.9;text-align:center}@media (max-width:768px){.scan-frame-wrapper{height:350px;width:280px}.direction-text{bottom:-80px}.direction-message{font-size:14px;padding:10px 20px}.back-button{height:40px;left:15px;top:15px;width:40px}.lighting-indicator{right:15px;top:15px}.countdown-number{font-size:120px}}.countdown-overlay{align-items:center;background:#000000b3;display:flex;flex-direction:column;height:100%;justify-content:center;left:0;position:absolute;top:0;width:100%;z-index:200}.countdown-number{animation:countdown-pulse 1s ease-in-out;color:#fff;font-size:150px;font-weight:700;text-shadow:0 0 30px #fffc}@keyframes countdown-pulse{0%{opacity:.5;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}to{opacity:.9;transform:scale(1)}}.countdown-text{color:#fff;font-size:24px;margin-top:20px;opacity:.9;text-align:center}.captured-image-overlay{align-items:center;animation:fade-in .5s ease-out;background:#000000e6;display:flex;height:100%;justify-content:center;left:0;position:absolute;top:0;width:100%;z-index:300}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.captured-image-container{max-height:90%;max-width:90%;text-align:center}.captured-image{animation:capture-flash .5s ease-out;border-radius:20px;box-shadow:0 0 50px #ffffff4d;max-height:70vh;max-width:100%}@keyframes capture-flash{0%{opacity:0;transform:scale(.8)}50%{opacity:1;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.captured-message{animation:message-slide .5s ease-out .3s both;color:#fff;font-size:20px;font-weight:600;margin-top:20px}@keyframes message-slide{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.lighting-indicator{position:absolute;right:20px;top:20px;z-index:100}.lighting-status{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:25px;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 16px;transition:all .3s ease}.lighting-good{background:#00ff00e6;box-shadow:0 0 20px #00ff004d;color:#000}.lighting-low{background:#ffa500e6;box-shadow:0 0 20px #ffa5004d}.lighting-high,.lighting-low{animation:warning-pulse 2s infinite;color:#000}.lighting-high{background:#ffff00e6;box-shadow:0 0 20px #ffff004d}@keyframes warning-pulse{0%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}to{opacity:.8;transform:scale(1)}}.lighting-icon{font-size:16px}.progress-indicator{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#000000b3;border-radius:20px;color:#fff;left:50%;padding:20px;position:absolute;text-align:center;top:80px;transform:translateX(-50%);z-index:100}.progress-header{margin-bottom:15px}.progress-title{font-size:18px;font-weight:700;margin-bottom:5px}.progress-subtitle{font-size:14px;opacity:.9}.progress-dots{display:flex;gap:10px;justify-content:center}.progress-dot{background:#ffffff4d;border-radius:50%;height:12px;transition:all .3s ease;width:12px}.progress-dot.active{background:#0f0;box-shadow:0 0 10px #00ff0080}.progress-dot.completed{background:#fff}.session-complete-overlay{align-items:center;animation:fade-in .5s ease-out;background:#000000f2;display:flex;height:100%;justify-content:center;left:0;position:absolute;top:0;width:100%;z-index:400}.session-complete-content{color:#fff;max-height:90%;max-width:90%;overflow-y:auto;text-align:center}.session-complete-icon{animation:bounce 1s ease-out;font-size:60px;margin-bottom:20px}@keyframes bounce{0%{transform:scale(.5)}50%{transform:scale(1.2)}to{transform:scale(1)}}.session-complete-title{font-size:24px;font-weight:700;margin-bottom:10px}.session-complete-subtitle{font-size:16px;margin-bottom:30px;opacity:.9}.captured-images-preview{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-bottom:30px}.preview-image-container{text-align:center}.preview-image{border:2px solid #ffffff4d;border-radius:10px;height:100px;object-fit:cover;transition:all .3s ease;width:80px}.preview-image:hover{border-color:#0f0;transform:scale(1.1)}.preview-label{font-size:12px;margin-top:5px;opacity:.8}.session-actions{display:flex;gap:15px;justify-content:center}.session-button{border:none;border-radius:25px;cursor:pointer;font-size:16px;font-weight:600;min-width:120px;padding:12px 24px;transition:all .3s ease}.session-button-retry{background:#fff3;border:2px solid #ffffff80;color:#fff}.session-button-retry:hover{background:#ffffff4d;transform:scale(1.05)}.session-button-finish{background:#0f0;color:#000}.session-button-finish:hover{background:#0c0;transform:scale(1.05)}@media (max-width:768px){.progress-indicator{left:10px;padding:15px;right:10px;top:70px;transform:none}.captured-images-preview{gap:10px}.preview-image{height:80px;width:60px}.session-actions{align-items:center;flex-direction:column}.session-button{width:200px}}@keyframes target-pulse{0%{opacity:.7;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}to{opacity:.7;transform:translate(-50%,-50%) scale(1)}}@keyframes target-success{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.8;transform:translate(-50%,-50%) scale(1.1)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.nose-target{z-index:50}.nose-indicator,.nose-target{pointer-events:none;position:absolute}.nose-indicator{animation:nose-pulse 1s infinite;z-index:60}@keyframes nose-pulse{0%{opacity:.8;transform:translate(-50%,-50%) scaleX(-1) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scaleX(-1) scale(1.2)}to{opacity:.8;transform:translate(-50%,-50%) scaleX(-1) scale(1)}}
/*# sourceMappingURL=main.397650e7.css.map*/