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}html{background-color:#282c34}body,html{height:100%}body{color:blue}.fullscreen{height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.forward{z-index:2}#root,#root>div,body,html{height:100%}#Main{display:flex;flex-direction:row;height:calc(100vh - 56px)}.App{height:100%;width:100%}#data_controls{display:inline-block;margin:auto;padding:0 8px}#Model-Render{background-color:#282c34;display:flex;flex-direction:column;flex-grow:2;flex-shrink:2;height:100%}.draggable{cursor:move;cursor:grab}.draggable:active{cursor:grabbing}#SidePannel{box-sizing:border-box;flex-grow:1;flex-shrink:1;float:left;height:calc(100vh - 56px);overflow-x:hidden;overflow-y:auto;padding:8px;position:relative;width:33.33%}form{align-items:baseline;display:inline}div.rdg-cell{padding:0}.rdg-cell>div{height:100%;padding:0 8px;width:100%}.rdg{display:inline-block;height:250px!important;min-width:404px;width:100%}#Model-Render>div.fulllHeight{flex:1 1 auto}.row:after{clear:both;content:"";display:table}#Model-Name{color:#006eff;display:block;font-size:1.25em;font-weight:700;line-height:250%;text-align:center;text-overflow:ellipsis}.container{border-style:solid;border-width:5px;color:#fafafa}#data-controls>div:not(.rdg){padding:8px}label.error{color:red}#disclaimer{font-size:smaller;margin:auto}#threshold_selector_pane{text-align:center}ThresholdSelector>*{align-items:center;background-color:#3667db;display:flex;flex-direction:row;justify-content:center;padding:5%}ThresholdSelector>input[type=color]{background-color:#3667db;padding:10%;width:20%}.component-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 20px #00000026;max-height:90vh;max-width:90vw;min-width:200px;overflow:visible;transition:box-shadow .2s ease,border-color .2s ease}.component-container.dragging{border-color:#007bff;box-shadow:0 8px 32px #00000040;transform:scale(1.02)}.component-container.minimized{min-width:250px}.container-title-bar{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6;cursor:grab;display:flex;justify-content:space-between;min-height:32px;padding:8px 12px;-webkit-user-select:none;user-select:none}.container-title-bar:active{cursor:grabbing}.title-content{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0}.container-icon{flex-shrink:0;font-size:16px}.container-title{color:#495057;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dev-label{background:#ffc107;border-radius:3px;color:#212529;flex-shrink:0;font-size:10px;font-weight:700;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase}.title-controls{display:flex;flex-shrink:0;gap:4px}.minimize-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:14px;height:24px;justify-content:center;min-width:24px;padding:4px 6px;transition:background-color .2s ease}.minimize-btn:hover{background:#0000001a}.minimize-btn:active{background:#0003}.container-content{max-height:calc(90vh - 40px);overflow:auto;padding:0;transition:opacity .2s ease}.component-container{border-left:4px solid #9979e5}.component-container:before{border-color:#0000 #9979e5 #0000 #0000;border-style:solid;border-width:0 20px 20px 0;content:"";height:0;position:absolute;right:0;top:0;width:0;z-index:1}@media (max-width:768px){.component-container{max-height:85vh;max-width:95vw}.container-title-bar{padding:6px 10px}.container-title{font-size:13px}.dev-label{font-size:9px;padding:1px 4px}}.component-container.minimized{max-height:48px;transition:max-height .3s ease}.component-container.minimized .container-content{max-height:0;opacity:0;overflow:hidden;pointer-events:none;transition:opacity .2s ease,max-height .3s ease}.minimize-btn:focus{outline:2px solid #007bff;outline-offset:1px}.odontogram{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;padding:16px;-webkit-user-select:none;user-select:none}.odontogram-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.odontogram-header h3{color:#495057;font-size:18px;font-weight:600;margin:0}.numbering-system-toggle{align-items:center;display:flex;gap:16px}.numbering-system-toggle label{align-items:center;color:#495057;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px}.numbering-system-toggle input[type=radio]{cursor:pointer;margin:0}.selection-info{align-items:center;color:#6c757d;display:flex;font-size:14px;gap:12px}.clear-selection-btn{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:4px 8px;transition:background-color .2s}.clear-selection-btn:hover{background:#c82333}.odontogram-grid{display:flex;flex-direction:column;gap:24px}.lower-arch,.upper-arch{display:flex;gap:32px;justify-content:center}.quadrant{align-items:center;display:flex;flex-direction:column;gap:8px}.quadrant-label{color:#6c757d;font-size:12px;font-weight:600;min-width:24px;text-align:center}.teeth-row{display:flex;gap:4px}.tooth-button{align-items:center;background:#fff;border:2px solid #ced4da;border-radius:6px;color:#495057;cursor:pointer;display:flex;font-size:11px;font-weight:600;height:36px;justify-content:center;position:relative;transition:all .2s ease;width:36px}.tooth-button.hovered,.tooth-button:hover{background:#e3f2fd;border-color:#007bff;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.tooth-button.selected{background:#007bff;border-color:#0056b3;box-shadow:0 2px 4px #007bff4d;color:#fff}.tooth-button.selected:hover{background:#0056b3;border-color:#004085}.tooth-button.anchor{position:relative}.tooth-button.anchor:after{background:#ffc107;border:1px solid #fff;border-radius:50%;box-shadow:0 1px 2px #0003;content:"";height:8px;position:absolute;right:-3px;top:-3px;width:8px}.tooth-button.selected.anchor:after{background:#fff;border-color:#007bff}.upper-right .teeth-row{flex-direction:row-reverse}.upper-left .teeth-row{flex-direction:row}.lower-left .teeth-row{flex-direction:row-reverse}.lower-right .teeth-row{flex-direction:row}.selection-help{border-top:1px solid #e9ecef;color:#6c757d;margin-top:16px;padding-top:12px;text-align:center}.selection-help strong{color:#495057}@media (max-width:768px){.odontogram{padding:12px}.odontogram-header{align-items:flex-start;flex-direction:column;gap:12px}.numbering-system-toggle{gap:12px}.lower-arch,.upper-arch{gap:16px}.tooth-button{font-size:10px;height:32px;width:32px}.teeth-row{gap:2px}}.tooth-button:focus{outline:2px solid #007bff;outline-offset:2px}.tooth-button:focus:not(:focus-visible){outline:none}.clear-selection-btn:focus{outline:2px solid #dc3545;outline-offset:2px}.numbering-system-toggle input[type=radio]:focus{outline:2px solid #007bff;outline-offset:2px}.treatment-option-card-container{margin-bottom:12px;position:relative;transition:all .3s ease}.treatment-option-card{align-items:center;background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;min-height:80px;padding:16px;position:relative;transition:all .3s ease}.treatment-option-card.hovered{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.treatment-option-card.viable.hovered{border-color:#1e7e34;box-shadow:0 8px 25px #28a74533;transform:translateY(-2px)}.treatment-option-card.selected{border:2px solid #2196f3;box-shadow:0 4px 15px #2196f34d}.treatment-option-card.viable{border-color:#28a745;box-shadow:0 2px 4px #28a7451a}.treatment-option-card.not-viable{background:#f8f9fa;border-color:#dc3545;cursor:not-allowed;opacity:.7}.treatment-option-card.viable.hovered,.treatment-option-card.viable:hover{border-color:#1e7e34;box-shadow:0 4px 12px #28a74533;transform:translateY(-2px)}.treatment-option-card.not-viable:hover{box-shadow:none;transform:none}.card-thumbnail{align-items:center;background:#f8f9fa;border-radius:6px;display:flex;flex-shrink:0;height:60px;justify-content:center;margin-right:16px;overflow:hidden;width:60px}.thumbnail-image{height:100%;object-fit:cover;width:100%}.thumbnail-placeholder{align-items:center;background:linear-gradient(135deg,#e9ecef,#dee2e6);display:flex;height:100%;justify-content:center;width:100%}.card-icon{font-size:24px;opacity:.7}.card-content{flex:1 1;min-width:0}.card-title{color:#212529;font-size:16px;font-weight:600;line-height:1.2;margin:0 0 4px}.card-title.editable{border-radius:4px;cursor:pointer;padding:2px 4px;transition:background-color .2s ease}.card-title.editable:hover{background-color:#f8f9fa}.card-title-input{background:#fff;border:2px solid #2196f3;border-radius:4px;color:#212529;font-size:16px;font-weight:600;margin:0 0 4px;outline:none;padding:2px 4px;width:100%}.card-description{color:#6c757d;font-size:14px;line-height:1.3;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.not-viable-indicator{margin-top:4px}.not-viable-indicator span{color:#dc3545;font-size:12px;font-weight:500}.card-indicators{align-items:center;display:flex;gap:4px;position:absolute;right:8px;top:8px;z-index:2}.selection-indicator{align-items:center;background-color:#28a745;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:24px;justify-content:center;width:24px}@keyframes checkmark-appear{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.sub-options-menu{animation:slideInRight .2s ease-out;background:#fff;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 4px 16px #00000026;left:100%;margin-left:12px;min-width:250px;position:absolute;top:0;z-index:1000}@keyframes slideInRight{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.sub-option-item{align-items:center;border-bottom:1px solid #f8f9fa;cursor:pointer;display:flex;padding:12px 16px;transition:all .15s ease}.sub-option-item:last-child{border-bottom:none}.sub-option-item.viable:hover{background:#f8f9fa}.sub-option-item.not-viable{cursor:not-allowed;opacity:.6}.sub-option-icon{font-size:18px;margin-right:12px;opacity:.8}.sub-option-title{color:#212529;flex:1 1;font-size:14px;font-weight:500}@media (max-width:768px){.treatment-option-card{min-height:70px;padding:12px}.card-thumbnail{height:50px;margin-right:12px;width:50px}.card-icon{font-size:20px}.card-title{font-size:15px}.card-description{font-size:13px}.sub-options-menu{bottom:20px;left:20px;margin-left:0;min-width:auto;position:fixed;right:20px;top:auto}}.quick-setup-inline{align-items:center;border-top:1px solid #9c27b026;display:flex;gap:8px;margin-top:12px;opacity:.6;padding-top:12px;transition:opacity .2s ease}.quick-setup-inline:hover{opacity:1}.quick-setup-label{color:#666;font-size:11px;font-weight:500;white-space:nowrap}.quick-setup-buttons{display:flex;flex-wrap:wrap;gap:6px}.quick-setup-btn{background:#9c27b00d;border:1px solid #9c27b040;border-radius:14px;color:#666;cursor:pointer;font-size:11px;font-weight:500;padding:4px 12px;transition:all .2s ease;white-space:nowrap}.quick-setup-btn:hover{background:#9c27b026;border-color:#9c27b066;color:#4a148c}.quick-setup-btn.active{background:#9c27b033;border-color:#9c27b080;color:#6a1b9a}.quick-setup-btn.active:hover{background:#9c27b04d}.quick-setup-btn:focus{outline:2px solid #9c27b080;outline-offset:1px}@media (max-width:768px){.quick-setup-inline{margin-top:10px;padding-top:10px}.quick-setup-label{font-size:10px}.quick-setup-btn{border-radius:12px;font-size:10px;padding:3px 10px}}.help-section{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-bottom:1px solid #dee2e6;flex-shrink:0;overflow:visible;transition:all .3s ease}.help-section.minimized{max-height:50px}.help-section.expanded{max-height:400px}.help-header{align-items:center;cursor:pointer;display:flex;gap:8px;padding:12px 20px;position:relative;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.help-header:hover{background:#ffffff1a}.help-controls{flex-shrink:0;justify-content:center}.help-controls,.help-title{align-items:center;display:flex}.help-title{color:#4a148c;flex:1 1;font-size:14px;font-weight:600;gap:8px}.help-icon{font-size:16px}.help-content{overflow:visible;padding:0 20px 16px;transition:opacity .3s ease,transform .3s ease,max-height .3s ease}.help-content.expanded{max-height:400px;opacity:1;transform:translateY(0)}.help-content.collapsed{max-height:0;opacity:0;padding-bottom:0;padding-top:0;transform:translateY(-10px)}.help-step{align-items:flex-start;background:#fff9;border-left:3px solid #9c27b0;border-radius:6px;display:flex;gap:12px;margin-bottom:12px;padding:8px}.step-number{align-items:center;background:#9c27b0;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:600;height:24px;justify-content:center;margin-top:2px;width:24px}.step-content{color:#4a148c;flex:1 1;font-size:13px;line-height:1.4}.step-content strong{color:#6a1b9a}.help-tip{align-items:center;background:#9c27b01a;border-radius:6px;color:#4a148c;display:flex;font-size:12px;font-style:italic;gap:8px;margin-top:16px;padding:8px 12px}.tip-icon{flex-shrink:0;font-size:14px}.save-plan-dialog-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.save-plan-dialog{animation:dialogSlideIn .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:450px;overflow:hidden;width:90%}@keyframes dialogSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dialog-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px 24px}.dialog-header h3{color:#333;font-size:1.25rem;font-weight:600;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.close-btn:hover{background-color:#f5f5f5;color:#666}.dialog-content{padding:24px}.dialog-content p{color:#555;line-height:1.5;margin:0 0 12px}.dialog-content p:last-child{margin-bottom:0}.dialog-content strong{color:#6a1b9a;font-weight:600}.dialog-actions{background-color:#f9f9f9;border-top:1px solid #e0e0e0;display:flex;gap:12px;padding:16px 24px}.dialog-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:.95rem;font-weight:500;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s}.dialog-btn-primary{background-color:#6a1b9a;color:#fff}.dialog-btn-primary:hover{background-color:#7b1fa2;box-shadow:0 4px 12px #6a1b9a4d;transform:translateY(-1px)}.dialog-btn-secondary{background-color:#fff;border:2px solid #6a1b9a;color:#6a1b9a}.dialog-btn-secondary:hover{background-color:#f3e5f5;transform:translateY(-1px)}.dialog-btn:active{transform:translateY(0)}.treatment-options-overlay{background:#fff;border-radius:8px;display:flex;flex-direction:column;height:100%;max-width:33.33vw;min-width:320px;overflow:visible;transition:width .3s ease,height .3s ease}.treatment-options-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #dee2e6;display:flex;flex-shrink:0;justify-content:space-between;padding:16px 20px}.overlay-title{color:#212529;font-size:18px;font-weight:600;margin:0}.header-actions{display:flex;gap:8px}.clear-btn,.refresh-btn{align-items:center;background:#fff;border:1px solid #dee2e6;border-radius:6px;color:#6c757d;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.refresh-btn:hover:not(:disabled){background:#007bff;border-color:#007bff;color:#fff}.clear-btn:hover:not(:disabled){background:#dc3545;border-color:#dc3545;color:#fff}.clear-btn:disabled,.refresh-btn:disabled{cursor:not-allowed;opacity:.5}.loading-state{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:40px;margin-bottom:16px;width:40px}.loading-state p{color:#6c757d;font-size:14px;margin:0}.treatment-options-content{flex:1 1;overflow-x:visible;overflow-y:auto;padding:0 20px 20px;transition:all .3s ease}.empty-state{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;min-height:300px;padding:40px 20px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state h3{color:#495057;font-size:18px;margin:0 0 8px}.empty-state p{color:#6c757d;font-size:14px;line-height:1.4;margin:0 0 24px}.refresh-empty-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s ease}.refresh-empty-btn:hover{background:#0056b3;transform:translateY(-1px)}.options-list{overflow:visible;padding:22px 0 20px}.calculation-info{border-top:1px solid #f8f9fa;margin-top:20px;padding:16px 0 8px;text-align:center}.calculation-info small{color:#6c757d;font-size:12px}.treatment-options-content::-webkit-scrollbar{width:6px}.treatment-options-content::-webkit-scrollbar-track{background:#f8f9fa}.treatment-options-content::-webkit-scrollbar-thumb{background:#dee2e6;border-radius:3px}.treatment-options-content::-webkit-scrollbar-thumb:hover{background:#adb5bd}.ui-mode-toggle{cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-track{background:#dee2e6;border:1px solid #ced4da;border-radius:13px;height:26px;position:relative;transition:all .3s ease;width:50px}.toggle-track.active{background:#6c757d;border-color:#5a6268}.toggle-thumb{align-items:center;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;display:flex;font-size:10px;height:22px;justify-content:center;left:1px;line-height:1;overflow:hidden;position:absolute;top:1px;transition:all .3s ease;width:22px}.dual-arch-icon{flex-direction:column;gap:0}.dual-arch-icon,.single-arch-icon{align-items:center;display:flex;justify-content:center;width:100%}.upper-arch-tooth{display:inline-block;transform:rotate(180deg)}.toggle-track.active .toggle-thumb{transform:translateX(24px)}.ui-mode-toggle:hover .toggle-track{box-shadow:0 0 0 3px #6c757d1a}.ui-mode-toggle:hover .toggle-track.active{box-shadow:0 0 0 3px #6c757d26}.ui-mode-indicator{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6;display:flex;flex-shrink:0;justify-content:space-between;padding:12px 20px}.mode-info{display:flex;flex-direction:column;gap:2px}.mode-label{color:#495057;font-size:14px;font-weight:600}.mode-description{color:#6c757d;font-size:12px;font-style:italic}.ui-controls{align-items:center;display:flex;gap:12px}.quick-extract-wrapper{align-items:center;display:flex;position:relative;z-index:20}.per-arch-mode{display:flex;flex-direction:column;gap:24px}.arch-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:16px;transition:all .3s ease}.arch-title{border-bottom:2px solid #007bff;color:#495057;display:inline-block;font-size:16px;font-weight:600;margin:0 0 16px;padding-bottom:8px}.arch-options{gap:12px}.arch-options,.dual-arch-mode{display:flex;flex-direction:column}.dual-arch-mode{gap:16px}.treatment-option-wrapper{overflow:visible;position:relative;will-change:transform,opacity}.treatment-option-wrapper.skeleton{pointer-events:none}.treatment-option-wrapper.skeleton .treatment-option-card{box-shadow:none;transform:none}.treatment-option-card.skeleton-card{background:#fff;border-color:#e9ecef}.skeleton-block,.skeleton-line{animation:skeleton-shimmer 1.2s ease-in-out infinite;background:linear-gradient(90deg,#f1f3f5,#e9ecef 50%,#f1f3f5);background-size:200% 100%}.skeleton-line{border-radius:6px;height:12px;margin:6px 0}.skeleton-title{height:14px;width:55%}.skeleton-desc{width:85%}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.treatment-option-wrapper.animate-in{animation:slideInFromTop .3s ease-out;transform-origin:top}.treatment-option-wrapper.morphing{pointer-events:none;z-index:10}.treatment-options-content.transitioning{overflow:visible;position:relative}.treatment-options-content.transitioning .treatment-option-wrapper{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transform:none}.treatment-options-content.transitioning .treatment-option-card{pointer-events:none}.treatment-option-card{will-change:transform,opacity}.ui-mode-toggle{transition:opacity .2s ease,transform .2s ease}.ui-mode-toggle:disabled,.ui-mode-toggle[style*="pointer-events: none"]{opacity:.7;transform:scale(.98)}@keyframes slideInFromTop{0%{max-height:0;opacity:0;transform:translateY(-20px) scaleY(0)}to{max-height:200px;opacity:1;transform:translateY(0) scaleY(1)}}@keyframes cardSplit{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes cardMerge{0%{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width:768px){.treatment-options-header{padding:12px 16px}.overlay-title{font-size:16px}.treatment-options-content{padding:0 16px 16px}.options-list{padding-top:16px}.empty-state{min-height:250px;padding:30px 16px}.empty-icon{font-size:40px}.empty-state h3{font-size:16px}.ui-mode-indicator{align-items:flex-start;flex-direction:column;gap:4px}.per-arch-mode{gap:16px}.arch-section{padding:12px}.arch-title{font-size:14px}}.save-plan-btn{align-items:center;background:#f9fafb;border:1px dashed #d1d5db;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;margin-top:8px;padding:12px 16px;transition:all .2s ease;width:100%}.save-plan-btn:hover{background:#f3f4f6;border-color:#9ca3af;color:#4b5563}.save-plan-btn:active{background:#e5e7eb}.save-plan-btn .save-icon{font-size:16px;opacity:.7}.save-plan-btn .save-text{opacity:.9}.category-header{align-items:center;color:#6c757d;display:flex;font-size:14px;font-weight:600;gap:8px;letter-spacing:.5px;margin:16px 0 8px;text-transform:uppercase}.category-header:first-child{margin-top:0}.category-header:after{background:#e9ecef;content:"";flex:1 1;height:1px}.current-state-section{background:#fff;border-bottom:2px dashed #e9ecef;margin-bottom:8px;padding-bottom:20px;position:relative;z-index:5}.current-state-section .category-header{color:#495057;font-weight:700}.current-state-section .category-header:after{background:#007bff;opacity:.2}.ui-mode-toggle.emphasized .toggle-track{animation:pulse-emphasis 2s infinite;border-color:#007bff}.ui-mode-toggle.emphasized .toggle-track.active{border-color:#007bff}.options-list:empty{display:none}.tooth-state-controls{background:#0000}.state-controls-section{background:#f8f9fa80;border-top:1px solid #e9ecef;padding:16px}.state-controls-section h4{color:#495057;font-size:14px;font-weight:600;margin:0 0 12px}.state-buttons.inline-layout{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}.state-buttons.grid-layout{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr)}.state-control-button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:8px 12px;transition:all .2s ease}.state-control-button:hover:not(:disabled){background:#0056b3;box-shadow:0 2px 4px #007bff4d;transform:translateY(-1px)}.state-control-button.disabled,.state-control-button:disabled{background:#adb5bd;box-shadow:none;color:#6c757d;cursor:not-allowed;opacity:.6;transform:none}.connector-controls-section{background:#0000;padding:16px}.connector-controls-section h4{color:#495057;font-size:14px;font-weight:600;margin:0 0 12px}.connector-controls{max-height:200px;overflow-y:auto;padding-right:4px}.connector-control-group{background:#f8f9facc;border:1px solid #e9ecef;border-radius:6px;margin-bottom:8px;padding:10px}.connector-label{color:#495057;font-size:12px;font-weight:600;margin-bottom:6px}.connector-buttons{display:flex;gap:6px}.connector-button{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;flex:1 1;font-size:11px;font-weight:500;padding:6px 8px;transition:all .2s ease}.connector-button:hover{background:#5a6268;transform:translateY(-1px)}.connector-button.active{background:#28a745}.connector-button.active:hover{background:#218838}@media (max-width:768px){.connector-controls-section,.state-controls-section{padding:12px}.state-buttons.inline-layout{gap:6px;grid-template-columns:repeat(2,1fr)}.state-buttons.grid-layout{gap:8px;grid-template-columns:1fr}.state-control-button{font-size:11px;padding:6px 10px}}.connector-button:focus,.state-control-button:focus{outline:2px solid #007bff;outline-offset:2px}.control-panel{display:flex;flex-direction:column;gap:8px;pointer-events:none;position:fixed;right:16px;top:70px;z-index:999}.control-panel-section{display:flex;flex-direction:column;gap:6px;pointer-events:auto}.control-panel-section--visibility:before{background:#fff3;content:"";display:block;height:1px;margin:4px auto 8px;width:24px}.control-panel-section--dev:before{background:#ffc8004d;content:"";display:block;height:1px;margin:4px auto 8px;width:24px}.dev-controls,.session-controls,.visibility-controls{align-items:center;display:flex;flex-direction:column;gap:6px}.control-divider{background:#fff3;height:1px;margin:4px 0;width:24px}.control-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:none;border-radius:50%;box-shadow:0 2px 8px #00000026;color:#ffffffb3;cursor:pointer;display:flex;justify-content:center;padding:0;transition:all .2s ease}.control-btn--small{font-size:14px;height:32px;width:32px}.control-btn--medium{font-size:18px;height:40px;width:40px}.control-btn--large{font-size:22px;height:48px;width:48px}.control-btn:hover{background:#fffffff2;box-shadow:0 4px 12px #0003;color:#333;transform:translateX(-2px)}.control-btn:active{transform:translateX(0)}.control-btn--active{background:#667eeae6;box-shadow:0 2px 8px #667eea66;color:#fff}.control-btn--active:hover{background:#667eea;box-shadow:0 4px 12px #667eea80;color:#fff}.control-btn--primary{background:#667eeacc;color:#fff}.control-btn--primary:hover{background:#667eea;color:#fff}.control-btn--danger{background:#dc2626cc;color:#fff}.control-btn--danger:hover{background:#dc2626;color:#fff}.control-btn--success{background:#22c55ecc;color:#fff}.control-btn--success:hover{background:#22c55e;color:#fff}.control-btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.control-btn-icon{line-height:1}.control-btn-icon,.control-btn-spinner{align-items:center;display:flex;justify-content:center}.control-btn-spinner{animation:spin 1s linear infinite}.dev-control-btn{border:1px dashed #ffc8004d}.dev-control-btn:hover{border-color:#ffc80099}@media (max-width:768px){.control-panel{right:12px;top:56px}.control-btn--medium{font-size:16px;height:36px;width:36px}}.control-btn--deemphasized{opacity:.5}.control-btn--deemphasized:hover{opacity:1}.control-btn--deemphasized.control-btn--active{opacity:.7}.control-btn--deemphasized.control-btn--active:hover{opacity:1}.control-btn.emphasized{animation:pulse-emphasis 2s infinite}.control-btn--deemphasized.emphasized{animation:pulse-emphasis 2s infinite;opacity:1!important}@keyframes pulse-emphasis{0%{box-shadow:0 2px 8px #667eea66;transform:scale(1)}50%{box-shadow:0 0 0 10px #667eea00,0 2px 12px #667eea99;transform:scale(1.05)}to{box-shadow:0 2px 8px #667eea66;transform:scale(1)}}.gingival-slider{-webkit-user-drag:none;--progress:75%;-webkit-appearance:none;appearance:none;background:linear-gradient(to right,#ff96aae6 0,#ff96aae6 var(--progress),#ffffff40 var(--progress),#ffffff40 100%);border-radius:4px;cursor:pointer;height:8px;outline:none;touch-action:none;-webkit-user-select:none;user-select:none;width:100px}.gingival-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #0000001a;border-radius:3px;box-shadow:0 2px 6px #0006;cursor:grab;height:22px;width:10px}.gingival-slider::-webkit-slider-thumb:hover{background:#f5f5f5}.gingival-slider::-webkit-slider-thumb:active{background:#eee;cursor:grabbing}.gingival-slider::-moz-range-thumb{background:#fff;border:1px solid #0000001a;border-radius:3px;box-shadow:0 2px 6px #0006;cursor:grab;height:22px;width:10px}.gingival-slider::-moz-range-thumb:active{cursor:grabbing}.gingival-slider::-moz-range-track{background:#ffffff40;border-radius:4px;height:8px}.gingival-slider::-moz-range-progress{background:#ff96aae6;border-radius:4px 0 0 4px;height:8px}.expandable-control-wrapper{align-items:center;display:flex;justify-content:center;position:relative;z-index:10}.expandable-main-control{position:relative;z-index:2}.expandable-content{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1e1e1ef2;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 4px 12px #0003;display:flex;gap:8px;opacity:0;padding:6px;pointer-events:none;position:absolute;transition:all .3s cubic-bezier(.4,0,.2,1);visibility:hidden;z-index:1}.expandable-content.visible{opacity:1;pointer-events:all;visibility:visible}.expandable-content.direction-left{margin-right:12px;right:100%;top:50%;transform:translateY(-50%) translateX(10px)}.expandable-content.direction-left.visible{transform:translateY(-50%) translateX(0)}.expandable-content input[type=range]{-webkit-appearance:none;appearance:none;background:#fff3;border-radius:2px;cursor:pointer;height:4px;outline:none;width:120px}.expandable-content input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#fff;border-radius:50%;cursor:pointer;height:12px;-webkit-transition:transform .1s;transition:transform .1s;width:12px}.expandable-content input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.expanded-mini-btn{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.expanded-mini-btn:hover{background:#fff3;transform:scale(1.1)}.expanded-mini-btn.active{background:#d2b48ccc;box-shadow:0 0 8px #d2b48c66;color:#1a1a1a}.control-btn[title],.nav-btn[title]{position:relative}.control-btn:after,.nav-btn:after{background:#000000d9;border-radius:6px;color:#fff;content:attr(title);font-size:12px;max-width:200px;opacity:0;overflow:hidden;padding:6px 10px;pointer-events:none;position:absolute;right:calc(100% + 8px);text-overflow:ellipsis;top:50%;transform:translateY(-50%);transition:opacity .2s ease,visibility .2s ease;visibility:hidden;white-space:nowrap;z-index:1000}.control-btn:hover:after,.nav-btn:hover:after{opacity:1;visibility:visible}.control-btn--tooltip-high:after{top:0;transform:translateY(-110%)}.nav-btn:after{left:50%;right:auto;top:auto;top:calc(100% + 8px)}.nav-btn:after,.nav-btn:hover:after{transform:translateX(-50%)}.top-nav-bar{padding:12px 16px;pointer-events:none;position:fixed;right:0;top:0;z-index:1000}.nav-buttons{gap:8px;pointer-events:auto}.nav-btn,.nav-buttons{align-items:center;display:flex}.nav-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:none;border-radius:50%;box-shadow:0 2px 8px #0000001a;color:#fff9;cursor:pointer;height:40px;justify-content:center;transition:all .2s ease;width:40px}.nav-btn:hover{background:#fffffff2;box-shadow:0 4px 12px #00000026;color:#333;transform:translateY(-1px)}.nav-btn:active{transform:translateY(0)}.share-btn svg{transition:transform .2s ease}.share-btn:hover svg{transform:scale(1.1)}.account-dropdown-container{position:relative}.account-btn{overflow:hidden;padding:0}.account-avatar,.account-avatar-placeholder{border-radius:50%;height:100%;object-fit:cover;width:100%}.account-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:16px;font-weight:600;justify-content:center}.account-dropdown{animation:dropdownSlideIn .2s ease;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;min-width:280px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px)}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;gap:12px;padding:16px}.dropdown-user-avatar{flex-shrink:0}.dropdown-avatar-image,.dropdown-avatar-placeholder{border-radius:50%;height:48px;object-fit:cover;width:48px}.dropdown-avatar-placeholder{align-items:center;background:#fff3;display:flex;font-size:20px;font-weight:600;justify-content:center}.dropdown-user-info{flex:1 1;min-width:0}.dropdown-user-name{font-size:16px;font-weight:600;margin-bottom:4px}.dropdown-user-email,.dropdown-user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-user-email{font-size:13px;opacity:.9}.dropdown-divider{background:#e5e7eb;height:1px}.dropdown-actions{padding:8px}.dropdown-action-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 16px;text-align:left;transition:background .15s ease;width:100%}.dropdown-action-btn:hover{background:#f3f4f6}.dropdown-icon{font-size:18px;text-align:center;width:24px}.logout-btn{color:#dc2626}.logout-btn:hover{background:#fee2e2}.share-dropdown-container{position:relative}.share-modal{animation:dropdownSlideIn .2s ease;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;min-width:220px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px)}.share-modal-divider{background:#e5e7eb;height:1px}.share-unavailable{align-items:center;animation:shareUnavailableFadeIn .2s ease;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;gap:6px;padding:20px 16px;text-align:center}@keyframes shareUnavailableFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.share-unavailable-icon{font-size:28px}.share-unavailable-text{font-size:15px;font-weight:600}.share-unavailable-subtext{font-size:13px;opacity:.92}.share-options{padding:8px}.share-option-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:10px 12px;text-align:left;transition:background .15s ease;width:100%}.share-option-btn:hover{background:#f3f4f6}.share-option-icon{flex-shrink:0;font-size:18px;text-align:center;width:24px}.feedback-dropdown-container{position:relative}.feedback-modal{animation:dropdownSlideIn .2s ease;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:320px}.feedback-modal-inner{padding:12px}.feedback-title{color:#111827;font-size:14px;font-weight:600;margin-bottom:8px}.feedback-textarea{border:1px solid #e5e7eb;border-radius:10px;box-sizing:border-box;color:#111827;font-size:14px;min-height:96px;outline:none;padding:10px 12px;resize:vertical;width:100%}.feedback-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.feedback-error{color:#dc2626;font-size:13px;margin-top:8px}.feedback-success{color:#065f46;font-size:13px;margin-top:8px}.feedback-success a{color:#065f46;text-decoration:underline}.feedback-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}.feedback-action-btn{border:none;border-radius:10px;cursor:pointer;font-size:13px;font-weight:600;padding:8px 10px}.feedback-action-btn:disabled{cursor:not-allowed;opacity:.6}.feedback-cancel{background:#f3f4f6;color:#374151}.feedback-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}@media (max-width:768px){.top-nav-bar{padding:8px 12px}.nav-btn{height:36px;width:36px}.account-dropdown{min-width:260px}.share-modal{min-width:280px}.feedback-modal{width:280px}}.recent-sessions-toggle{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:none;border-radius:50%;box-shadow:0 4px 12px #00000026;color:#ffffffb3;cursor:pointer;display:flex;height:48px;justify-content:center;position:fixed;transition:all .2s ease;width:48px;z-index:999}.recent-sessions-toggle--top{right:120px;top:12px}.recent-sessions-toggle--bottom{bottom:24px;right:24px}.recent-sessions-toggle:hover{background:#fffffff2;box-shadow:0 6px 16px #0003;color:#374151;transform:scale(1.05)}.recent-sessions-toggle:active{transform:scale(.98)}.recent-sessions-badge{align-items:center;background:#ef4444;border-radius:10px;box-shadow:0 2px 6px #ef444466;color:#fff;display:flex;font-size:11px;font-weight:600;height:20px;justify-content:center;min-width:20px;padding:0 6px;position:absolute;right:-4px;top:-4px}.recent-sessions-backdrop{background:#0000004d;inset:0;opacity:0;position:fixed;transition:opacity .3s ease,visibility .3s ease;visibility:hidden;z-index:1000}.recent-sessions-backdrop--visible{opacity:1;visibility:visible}.recent-sessions-drawer{background:#1a1d24;bottom:0;box-shadow:-4px 0 24px #0000004d;display:flex;flex-direction:column;max-width:90vw;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:380px;z-index:1001}.recent-sessions-drawer--open{transform:translateX(0)}.recent-sessions-drawer__header{align-items:flex-start;border-bottom:1px solid #ffffff14;display:flex;flex-shrink:0;justify-content:space-between;padding:20px 20px 16px}.recent-sessions-drawer__header-content{display:flex;flex-direction:column;gap:4px}.recent-sessions-drawer__title{align-items:center;color:#f9fafb;display:flex;font-size:18px;font-weight:600;gap:10px;margin:0}.recent-sessions-drawer__count{background:#ffffff1a;border-radius:12px;color:#ffffffb3;font-size:13px;font-weight:500;padding:2px 8px}.recent-sessions-drawer__lifetime{color:#ffffff80;cursor:pointer;display:inline-block;font-size:13px;font-weight:500;transition:all .15s ease}.recent-sessions-drawer__lifetime:hover{color:#ffffffb3}.recent-sessions-drawer__lifetime-count{color:#14b8a6;font-size:14px;font-weight:600}.recent-sessions-drawer__lifetime:hover .recent-sessions-drawer__lifetime-count{color:#5eead4}.recent-sessions-drawer__close{align-items:center;background:#ffffff0d;border:none;border-radius:50%;color:#ffffff80;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .15s ease;width:36px}.recent-sessions-drawer__close:hover{background:#ffffff1a;color:#f9fafb}.recent-sessions-drawer__content{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:16px}.recent-sessions-drawer__loading{align-items:center;color:#ffffff80;display:flex;flex-direction:column;font-size:14px;gap:12px;height:200px;justify-content:center}.recent-sessions-drawer__spinner{animation:spin .8s linear infinite;border:3px solid #ffffff1a;border-radius:50%;border-top-color:#ffffff80;height:32px;width:32px}@keyframes spin{to{transform:rotate(1turn)}}.recent-sessions-drawer__empty{align-items:center;color:#fff6;display:flex;flex-direction:column;height:280px;justify-content:center;text-align:center}.recent-sessions-drawer__empty svg{margin-bottom:16px;opacity:.5}.recent-sessions-drawer__empty-title{color:#ffffffb3;font-size:16px;font-weight:600;margin-bottom:4px}.recent-sessions-drawer__empty-subtitle{font-size:14px}.recent-sessions-drawer__list{display:flex;flex-direction:column;gap:12px}.session-card{background:#ffffff08;border:1px solid #ffffff0f;border-radius:12px;overflow:hidden;transition:all .2s ease}.session-card:hover{background:#ffffff0d;border-color:#ffffff1a}.session-card--processing{opacity:.5;pointer-events:none}.session-card__thumbnail{align-items:center;background:#0003;display:flex;height:140px;justify-content:center;position:relative;width:100%}.session-card__thumbnail-container{height:100%;position:relative;width:100%}.session-card__thumbnail-img{height:100%;object-fit:cover;width:100%}.session-card__thumbnail-close{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ef444480;border:none;border-radius:50%;box-shadow:0 2px 8px #ef44444d;color:#fff;cursor:pointer;display:flex;font-size:14px;height:24px;justify-content:center;opacity:0;position:absolute;right:8px;top:8px;transition:all .15s ease;visibility:hidden;width:24px}.session-card__thumbnail-close:hover{background:#ef4444e6;box-shadow:0 3px 12px #ef444466;transform:scale(1.1)}.session-card__thumbnail-close:active{transform:scale(.95)}.session-card:hover .session-card__thumbnail-close{opacity:1;visibility:visible}.session-card__thumbnail-placeholder{color:#ffffff26}.session-card__thumbnail-placeholder--fallback{align-items:center;display:flex;height:100%;justify-content:center;left:0;position:absolute;top:0;width:100%}.session-card__meta{border-bottom:1px solid #ffffff0d;padding:12px 14px}.session-card__time{color:#fff9;font-size:13px;font-weight:500;margin-bottom:4px}.session-card__clinical-summary{color:#f9fafb;font-size:15px;font-weight:600;line-height:1.3;margin-bottom:4px}.session-card__clinical-summary--empty{color:#ffffff4d;font-style:italic;font-weight:400}.session-card__plan-count{color:#fff6;font-size:12px}.session-card__actions{display:flex;gap:6px;padding:8px}.session-card__btn{align-items:center;background:#ffffff0a;border:1px solid #0000;border-radius:8px;color:#ffffffb3;cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:4px;padding:10px 8px;transition:all .15s ease}.session-card__btn:disabled{cursor:not-allowed;opacity:.4}.session-card__btn-icon{font-size:18px;line-height:1}.session-card__btn-label{font-size:10px;font-weight:600;letter-spacing:.03em;opacity:.8;text-transform:uppercase}.session-card__btn:hover:not(:disabled){background:#ffffff14;border-color:#ffffff1a;color:#f9fafb;transform:translateY(-1px)}.session-card__btn:active:not(:disabled){transform:translateY(0)}.session-card__btn--scheduling{border-color:#14b8a633}.session-card__btn--scheduling:hover:not(:disabled){background:#14b8a61f;border-color:#14b8a64d;color:#5eead4}.session-card__btn--prepared{border-color:#60a5fa33}.session-card__btn--prepared:hover:not(:disabled){background:#60a5fa1f;border-color:#60a5fa4d;color:#93c5fd}.session-card__btn--considering{border-color:#a855f733}.session-card__btn--considering:hover:not(:disabled){background:#c793f81f;border-color:#a855f74d;color:#c4b5fd}.session-card__btn--declined{border-color:#ffffff1a}.session-card__btn--declined:hover:not(:disabled){background:#ffffff0f;border-color:#ffffff26;color:#ffffffe6}.session-card__plan-select{background:#14b8a60d;border-top:1px solid #14b8a61a;padding:12px}.session-card__plan-select-header{align-items:center;color:#ffffffb3;display:flex;font-size:13px;font-weight:500;justify-content:space-between;margin-bottom:10px}.session-card__plan-select-close{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff9;cursor:pointer;display:flex;font-size:14px;height:24px;justify-content:center;transition:all .15s ease;width:24px}.session-card__plan-select-close:hover{background:#ffffff26;color:#ffffffe6}.session-card__plan-list{display:flex;flex-direction:column;gap:6px}.session-card__plan-item{align-items:flex-start;background:#14b8a614;border:1px solid #14b8a633;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;padding:10px 12px;text-align:left;transition:all .15s ease}.session-card__plan-item:hover:not(:disabled){background:#14b8a626;border-color:#14b8a64d}.session-card__plan-item:disabled{cursor:not-allowed;opacity:.5}.session-card__plan-item-label{color:#14b8a6;font-size:14px;font-weight:600;margin-bottom:2px}.session-card__plan-item-type{color:#ffffff80;font-size:11px;text-transform:capitalize}.drawer-toast{align-items:center;animation:toastSlideIn .3s ease;border-radius:8px;bottom:16px;box-shadow:0 4px 12px #0000004d;display:flex;font-size:14px;font-weight:500;gap:10px;left:16px;padding:12px 16px;position:absolute;right:16px}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.drawer-toast--success{background:#065f46;color:#d1fae5}.drawer-toast--error{background:#991b1b;color:#fecaca}.drawer-toast__icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:20px;justify-content:center;width:20px}.drawer-toast--success .drawer-toast__icon{background:#10b981;color:#fff}.drawer-toast--error .drawer-toast__icon{background:#ef4444;color:#fff}.drawer-toast__message{flex:1 1}.drawer-toast__close{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:inherit;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;line-height:1;transition:background .15s ease;width:24px}.drawer-toast__close:hover{background:#fff3}@keyframes slideOut{0%{opacity:1;transform:translateX(0) scale(1)}70%{opacity:.8;transform:translateX(20px) scale(.98)}to{opacity:0;transform:translateX(60px) scale(.95)}}.session-card--exiting{animation:slideOut .4s ease-out forwards;pointer-events:none}@keyframes outcomeSuccess{0%{opacity:1;transform:scale(1)}30%{background:#ffffff0f;opacity:1;transform:scale(1.01)}to{opacity:0;transform:scale(.96) translateX(30px)}}.session-card--success{animation:outcomeSuccess .4s ease-out forwards;pointer-events:none;position:relative}.session-card--success:after{animation:checkmarkPop .25s ease-out;color:#5eead499;content:"✓";font-size:56px;left:50%;pointer-events:none;position:absolute;text-shadow:0 2px 12px #5eead466;top:50%;transform:translate(-50%,-50%)}@keyframes checkmarkPop{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}60%{opacity:.8;transform:translate(-50%,-50%) scale(1.15)}to{opacity:.6;transform:translate(-50%,-50%) scale(1)}}.session-card--current{background:#60a5fa0d;border-color:#60a5fa4d}.session-card--current:hover{background:#60a5fa14;border-color:#60a5fa66}.session-card__thumbnail-placeholder--loading{background:#60a5fa1a}.session-card__thumbnail-spinner{animation:spin .8s linear infinite;border:2px solid #60a5fa33;border-radius:50%;border-top-color:#60a5facc;height:24px;width:24px}@media (max-width:480px){.recent-sessions-drawer{max-width:100%;width:100%}.recent-sessions-toggle--bottom{bottom:16px;right:16px}.session-card__thumbnail{height:120px}.session-card__btn-label{font-size:10px}}.auth-container{background-color:#1e2125;color:#fff;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;min-height:100vh}.auth-split-layout{display:flex;flex:1 1;min-height:0;width:100%}.auth-info-side{align-items:flex-start;background-color:#282c34;border-right:1px solid #3a3f4b;box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;justify-content:center;min-height:100vh;min-width:350px;padding:60px;position:relative}.auth-brand-container{align-items:center;display:flex;gap:15px;left:60px;position:absolute;top:40px}.auth-logo{filter:drop-shadow(0 0 5px rgba(52,152,219,.3));height:auto;width:40px}.auth-app-name{color:#8da6b8;font-size:14px;font-weight:600;letter-spacing:1.5px;margin:0;text-transform:uppercase}.auth-hero-container{margin-top:0;max-width:520px;text-align:left}.auth-hero-title{color:#fff;font-size:42px;font-weight:700;line-height:1.2;margin-bottom:32px}.auth-problem-text{color:#aabbc9;font-size:18px;font-weight:400;line-height:1.75;margin-bottom:24px}.auth-divider-line{background-color:#3498db;height:2px;margin-bottom:24px;opacity:.5;width:60px}.auth-mission-text{color:#fff;font-size:18px;font-weight:500;line-height:1.75}.auth-form-side{align-items:center;background-color:#1e2125;box-sizing:border-box;display:flex;flex:1 1;justify-content:center;min-width:350px;padding:20px}.auth-form-card{box-sizing:border-box;max-width:400px;padding:40px;width:100%}.auth-form-title{color:#fff;font-size:28px;font-weight:700;margin-bottom:8px}.auth-form-subtitle{color:#8b949e;font-size:16px;margin-bottom:32px}.auth-footer{bottom:30px;display:flex;gap:24px;left:60px;padding:0;position:absolute;z-index:10}.auth-footer-link{color:#6e7681;font-size:12px;font-weight:500;text-decoration:none;transition:color .2s}.auth-footer-link:hover{color:#8b949e}.auth-form{gap:20px}.auth-form,.auth-input-group{display:flex;flex-direction:column;width:100%}.auth-input-group{gap:8px}.auth-label{color:#ccc;font-size:14px;font-weight:500;text-align:left}.auth-input{background-color:#333;border:1px solid #444;border-radius:8px;box-sizing:border-box;color:#fff;font-size:16px;outline:none;padding:12px 16px;transition:border-color .2s;width:100%}.auth-input:hover{border-color:#555}.auth-input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.auth-input:disabled{cursor:not-allowed;opacity:.6}.auth-password-container{position:relative;width:100%}.auth-password-container .auth-input{padding-right:48px}.auth-eye-button{background:none;border:none;cursor:pointer;font-size:20px;opacity:.6;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:opacity .2s}.auth-eye-button:hover{opacity:1}.auth-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .2s;width:100%}.auth-button:hover:not(:disabled){box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.auth-button-primary{background-color:#3498db;color:#fff}.auth-button-primary:hover:not(:disabled){background-color:#2980b9}.auth-button-google{background-color:#fff;border:1px solid #ddd;color:#333}.auth-button-google:hover:not(:disabled){background-color:#f8f8f8}.auth-button-secondary{background-color:initial;border:1px solid #555;color:#aaa}.auth-button-secondary:hover:not(:disabled){border-color:#777;color:#ccc}.auth-button:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.auth-google-icon{height:20px;width:20px}.auth-or-divider{align-items:center;color:#666;display:flex;justify-content:center;margin:24px 0;position:relative;width:100%}.auth-or-divider:before{background-color:#444;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.auth-or-divider span{background-color:#1e2125;color:#888;font-size:14px;padding:0 16px;position:relative;z-index:1}.auth-error-box{background-color:#ff6b6b1a;border:1px solid #ff6b6b;border-radius:8px;color:#ff6b6b}.auth-error-box,.auth-success-box{font-size:14px;margin-bottom:20px;padding:12px 16px}.auth-success-box{background-color:#4caf501a;border:1px solid #4caf50;border-radius:8px;color:#4caf50}.auth-link{color:#3498db;font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-text-link{background:none;border:none;color:#3498db;cursor:pointer;font-family:inherit;font-size:inherit;font-weight:600;padding:0;text-decoration:none}.auth-text-link:hover{text-decoration:underline}.auth-footer-section{font-size:14px;margin-top:24px;text-align:center}.auth-footer-text{color:#888}.auth-password-requirements{background-color:#ffffff0d;border-radius:6px;font-size:13px;padding:12px}.auth-requirement-title{color:#888;font-weight:500;margin:0 0 8px}.auth-requirement-list{list-style:none;margin:0;padding-left:20px}.auth-requirement{color:#666;margin-bottom:4px}.auth-requirement-met{color:#4caf50;margin-bottom:4px}.auth-icon-container{display:flex;justify-content:center;margin-bottom:24px}.auth-icon{color:#3498db;height:64px;width:64px}.auth-success-icon{align-items:center;background-color:#4caf50;border-radius:50%;color:#fff;display:flex;font-size:32px;height:60px;justify-content:center;margin:0 auto 24px;width:60px}@keyframes auth-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.auth-spinner{animation:auth-spin 1s linear infinite;border:4px solid #ffffff1a;border-radius:50%;border-top-color:#3498db;height:64px;width:64px}@media (max-width:1024px){.auth-info-side{padding:40px}.auth-brand-container{left:40px;top:30px}.auth-hero-title{font-size:36px}.auth-mission-text,.auth-problem-text{font-size:16px}.auth-hero-container{margin-top:50px}}@media (max-width:768px){.auth-split-layout{flex-direction:column}.auth-info-side{display:none}.auth-info-side.auth-show-mobile{border-bottom:1px solid #3a3f4b;border-right:none;display:flex;min-height:auto;min-width:100%;padding:24px}.auth-info-side.auth-show-mobile .auth-brand-container{margin-bottom:16px;position:static}.auth-info-side.auth-show-mobile .auth-hero-container{display:none}.auth-info-side.auth-show-mobile .auth-footer{flex-wrap:wrap;justify-content:center;margin-top:16px;position:static}.auth-form-side{flex:1 1;min-height:0;min-width:100%;overflow-y:auto;padding:24px}.auth-form-card{max-width:100%;padding:20px 0}.auth-form-title{font-size:24px;text-align:center}.auth-form-subtitle{margin-bottom:24px;text-align:center}.auth-button{padding:14px 20px}}.auth-mobile-header{background-color:#282c34;border-bottom:1px solid #3a3f4b;display:none;padding:20px 24px}.auth-mobile-footer{background-color:#282c34;border-top:1px solid #3a3f4b;display:none;padding:16px 24px}@media (max-width:768px){.auth-mobile-header{align-items:center;display:flex;flex-shrink:0;gap:12px}.auth-mobile-header .auth-logo{width:32px}.auth-mobile-header .auth-app-name{font-size:12px}.auth-mobile-footer{display:flex;flex-shrink:0;flex-wrap:wrap;gap:20px;justify-content:center}.auth-split-layout{flex:1 1;overflow-y:auto}}.auth-form-side{max-height:100vh;overflow-y:auto}.auth-form-scrollable{display:flex;flex-direction:column;min-height:min-content;padding-bottom:40px}@media (max-height:700px){.auth-info-side{padding-bottom:60px;padding-top:80px}.auth-hero-title{font-size:32px;margin-bottom:20px}.auth-mission-text,.auth-problem-text{font-size:15px;line-height:1.6;margin-bottom:16px}.auth-hero-container{margin-top:40px}.auth-form-card{padding:24px}.auth-form{gap:16px}.auth-or-divider{margin:16px 0}.auth-footer-section{margin-top:16px}}@media (max-height:600px){.auth-info-side{display:none}.auth-form-side{min-width:100%}}
/*# sourceMappingURL=main.ca61d636.css.map*/