.login-page{align-items:center;background-color:#f4f4f4;display:flex;font-family:Helvetica Neue,sans-serif;justify-content:center;min-height:100vh;padding:20px}.login-container{background-color:#fff;border-radius:10px;box-shadow:0 4px 8px #0000001a;max-width:90%;padding:40px;text-align:center;width:400px}.physicscribe-login-title{color:#333;font-size:1.8rem;font-weight:600;margin-bottom:30px}.error-message{color:#d9534f;font-weight:500;margin-bottom:20px}.login-form{display:flex;flex-direction:column;margin-bottom:20px}.form-group{margin-bottom:20px;position:relative;text-align:left}.form-group input{border:1px solid #ccc;border-radius:6px;box-sizing:border-box;font-size:1rem;padding:12px;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.form-group input::placeholder{color:#999}.login-form button{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:500;margin-bottom:10px;padding:12px 20px;transition:background-color .2s,transform .1s;width:100%}.login-form button:hover{background-color:#0056b3}.resend-verification-button{background-color:#6c757d!important;color:#fff;margin-top:5px}.resend-verification-button:hover{background-color:#5a6268!important}.login-form button:active{transform:scale(.98)}.separator{color:#ccc;font-weight:500;margin:30px 0;position:relative}.separator:after,.separator:before{background-color:#eee;content:"";height:1px;position:absolute;top:50%;width:40%}.separator:before{left:0}.separator:after{right:0}.google-login-button{align-items:center;background-color:#f8f9fa;border:1px solid #ccc;border-radius:6px;color:#333;cursor:pointer;display:flex;font-size:1rem;justify-content:center;margin-bottom:15px;padding:12px 20px;transition:background-color .2s,transform .1s;width:100%}.google-login-button:hover{background-color:#eee}.google-login-button:active{transform:scale(.98)}.google-logo{height:20px;margin-right:10px;width:20px}.links-container{align-items:center;display:flex;font-size:.9rem;gap:10px;justify-content:center;margin-top:25px}.link-text{color:#555}.link-button{background:none;border:none;color:#007bff;cursor:pointer;font:inherit;font-weight:500;outline:inherit;padding:0;transition:color .2s}.link-button:hover{color:#0056b3}.link-container{align-items:center;display:flex;font-size:.9rem;justify-content:center;margin-top:15px}.link-separator{color:#ccc;margin:0 5px}.reset-password-container{background-color:#f9f9f9;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.reset-password-title{color:#333;font-size:1.5rem;font-weight:600;margin-bottom:20px}.reset-form{align-items:center;display:flex;flex-direction:column}.reset-form .form-group{margin-bottom:15px;width:100%}.reset-form input{border:1px solid #ddd;border-radius:5px;font-size:1rem;padding:10px;transition:border-color .2s;width:100%}.reset-form input:focus{border-color:#007bff;outline:none}.reset-button{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px;transition:background-color .2s,transform .1s;width:100%}.reset-button:hover{background-color:#0056b3}.reset-button:active{transform:scale(.98)}.verify-email-container{background-color:#f9f9f9;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:0 auto;max-width:500px;padding:20px;text-align:center}.verify-email-container h2{color:#333;margin-bottom:16px}.verify-email-container p{color:#666;margin-bottom:24px}.primary-button{transition:background-color .3s}.container{align-items:center;background-color:#f4f4f4;display:flex;justify-content:center;min-height:100vh}.form-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:30px;text-align:center;width:400px}.form-container h2{color:#333;margin-bottom:20px}.input-field{margin-bottom:20px;text-align:left}.input-field label{color:#555;display:block;margin-bottom:5px}.input-field input{border:1px solid #ccc;box-sizing:border-box;padding:10px}.input-field input,.primary-button{border-radius:4px;font-size:1rem;width:100%}.primary-button{background-color:#007bff}.primary-button:hover{background-color:#0056b3}.error-message{color:red;margin-bottom:15px}.go-to-login{align-items:center;display:flex;justify-content:space-between;margin-top:10px}.go-to-login button{background:none;border:none;color:#007bff;cursor:pointer;font:inherit;outline:inherit;padding:0}.go-to-login button:hover{color:#0056b3}.sidebar{align-items:stretch;background-color:#f8f9fa;color:#000;display:flex;flex-direction:column;flex-shrink:0;gap:10px;height:100%;justify-content:flex-start;max-width:300px;min-height:0;min-width:300px;overflow:hidden;position:relative;width:300px}.sidebar,.sidebar-section{box-sizing:border-box;padding:10px}.sidebar-section{width:100%}.sidebar-header-section{align-items:center;border-bottom:0 solid #0003;box-sizing:border-box;display:flex;flex:0 0 auto;flex-direction:column;margin-bottom:10px;position:relative}.sidebar-profile-pic{border-radius:50%;height:60px;margin-bottom:10px;object-fit:cover;width:60px}.sidebar-user-icon{font-size:60px;margin-bottom:10px}.sidebar-user-info{box-sizing:border-box;text-align:center}.sidebar-user-name{color:#333;font-size:1.2em;font-weight:700}.sidebar-user-email{color:#555;font-size:.9em}.sidebar-patient-section{box-sizing:border-box;flex-basis:auto;flex-grow:1;min-height:0;overflow-y:auto;scrollbar-gutter:stable}@media (min-width:1024px){.sidebar-patient-section::-webkit-scrollbar{width:8px}.sidebar-patient-section::-webkit-scrollbar-thumb{background-color:#00000040;border-radius:4px}}.sidebar-logo-section{align-items:center;border-top:0 solid #0003;box-sizing:border-box;display:flex;flex:0 0 auto;justify-content:center;padding:15px 10px;text-align:center}.sidebar-logo-image{height:auto;max-height:70px;max-width:100%}.sidebar-user-profile-button{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;margin:0;padding:0;transition:background-color .3s ease,transform .2s ease;width:100%}.sidebar-user-profile-button:hover{background-color:#ffffff1a;transform:translateY(-1px)}.sidebar-user-profile-button:active{transform:translateY(0)}.sidebar-popup-main-menu{background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 2px 8px #0003;box-sizing:border-box;left:50%;margin-top:5px;min-width:180px;padding:8px 0;position:absolute;top:100%;transform:translateX(-50%);z-index:1000}.sidebar-popup-main-menu ul{list-style-type:none;margin:0;padding:0}.sidebar-popup-main-menu li{box-sizing:border-box;cursor:pointer;padding:8px 16px;transition:background-color .3s ease}.sidebar-popup-main-menu li:hover{background-color:#f2f2f2}.upgrade-plan-item{align-items:center!important;display:flex!important;gap:8px!important}.upgrade-plan-icon{color:#f6b93b;font-size:.9em}.upgrade-plan-item.subscribed,.upgrade-plan-item.subscribed .upgrade-plan-icon{color:#6c757d}.upgrade-plan-item.disabled{color:#999;cursor:not-allowed!important;opacity:.6}.upgrade-plan-item.disabled .upgrade-plan-icon{color:#999}.upgrade-plan-item.disabled:hover{background-color:initial!important}.sidebar-session-row-title{border-bottom:1px solid #ddd;box-sizing:border-box;color:#777;font-size:1em;font-weight:400;margin-bottom:.1rem;padding-left:1px;text-align:left;width:100%}.sidebar-session-row{align-items:center;align-self:flex-start;background-color:initial;border:1px solid #ccc;border-radius:4px;box-shadow:0 4px 8px #0003;box-sizing:border-box;display:flex;justify-content:space-between;margin-top:.1rem;padding:2px;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.sidebar-session-row:hover{border-color:#bbb;box-shadow:0 6px 10px #00000040}.sidebar-session-row.recording-active{border-color:#ccc;cursor:not-allowed;opacity:.7}.sidebar-session-row.recording-active:hover{border-color:#ccc;box-shadow:0 4px 8px #0003}.sidebar-selected-option-container{position:relative}.sidebar-selected-option{color:#333;font-weight:700}.sidebar-workspace-title{box-sizing:border-box;color:#777;font-size:1em;font-weight:400;margin-bottom:.1rem;margin-top:1rem;padding-left:1px;text-align:left;width:100%}.add-patient-container{align-items:center;align-self:flex-start;background-color:initial;border:1px solid #ccc;border-radius:4px;box-shadow:0 4px 8px #0003;box-sizing:border-box;display:flex;justify-content:space-between;margin-top:.1rem;padding:2px;transform:perspective(1000px) translateZ(0);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;width:100%}.add-patient-container:hover{border-color:#bbb;box-shadow:0 6px 10px #00000040}.add-patient-container.disabled{cursor:not-allowed;opacity:.7}.add-patient-container.disabled:hover{border-color:#ccc;box-shadow:0 4px 8px #0003;transform:none}.add-patient-text{color:#333;font-weight:700;transition:color .3s ease}.add-patient-text.disabled{font-weight:400;opacity:.7}.add-patient-button{background:none;border:none;color:#333;cursor:pointer}.add-patient-button:hover{color:red;transform:translateY(-1px)}.session-buttons-container{box-sizing:border-box;display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.session-button{align-items:center;background:#0000;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;display:flex;font-weight:700;justify-content:space-between;padding:6px 2px;transition:transform .2s,box-shadow .2s}.session-button:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.session-button-text{flex-grow:1;transition:color .3s ease}.session-button-text.disabled{color:#999}.remove-session-button{background:none;border:none;color:#000;cursor:pointer;margin-left:auto}.remove-session-button:hover{color:red}.remove-session-button.disabled{color:#999;cursor:not-allowed;opacity:.6}.session-button.active{background-color:#007bff;color:#fff}.session-button.active .remove-session-button,.session-button.active .session-button-text{color:#fff}.session-button.disabled{opacity:.6}.session-button.soap-generating{background-color:#007bff1a;border-color:#888;cursor:pointer;opacity:.8;position:relative}.session-button-text.soap-text{color:#666;font-style:italic}.session-button.soap-generating:after{animation:pulse 1s infinite;color:#888;content:"⚡";font-size:14px;position:absolute;right:35px;top:50%;transform:translateY(-50%)}.session-button.active{position:relative}.session-button.active.recording{box-shadow:0 0 8px #dc354580}.session-button.disabled:hover{box-shadow:none;transform:none}.session-button.disabled .remove-session-button{cursor:not-allowed;opacity:.6}.add-patient-button.disabled{background-color:#f5f5f5;border-color:#ddd;color:#999;cursor:not-allowed;opacity:.4}.add-patient-button.disabled:hover{background-color:#f5f5f5;box-shadow:none;color:#999;transform:none}.add-patient-text.disabled{color:#999;opacity:.4}.add-patient-container.disabled{opacity:.6;pointer-events:none}.sidebar-email-mismatch-warning{word-wrap:break-word;background-color:#fff3cd;border:1px solid #ffeeba;border-radius:5px;box-sizing:border-box;color:#856404;font-size:.9em;margin-top:10px;overflow-wrap:break-word;padding:10px;position:relative;width:100%}.close-email-mismatch-warning{background:none;border:none;color:#856404;cursor:pointer;position:absolute;right:10px;top:5px;transition:color .3s ease}.close-email-mismatch-warning:hover{color:darkred}.sidebar-email-mismatch-warning-button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9em;font-weight:600;margin-right:10px;padding:10px 15px;transition:background-color .3s ease,transform .2s ease}.sidebar-email-mismatch-warning-button:hover{background-color:#0056b3;transform:translateY(-1px)}.sidebar-email-update-success{color:green;font-weight:700}.sidebar-email-update-error{color:red}.sidebar-email-mismatch-link{background:none;border:none;color:#007bff;cursor:pointer;font-size:.9em;font-weight:600;padding:0;text-decoration:underline;transition:color .3s ease,transform .2s}.sidebar-email-mismatch-links{display:flex;gap:10px}.sidebar-email-mismatch-link:hover{color:#0056b3;transform:translateY(-1px)}.sidebar-highlight-email{color:#0056b3;font-weight:700}.sidebar-subscription-info{align-items:center;background-color:#f8f9ff;border:1px solid #e1e4f8;border-radius:20px;box-shadow:0 1px 3px #0000000d;color:#4a5568;display:flex;font-size:.8em;justify-content:center;margin-top:5px;padding:4px 10px}.subscription-icon{color:#f6b93b;font-size:.9em;margin-right:5px}.sidebar-checkout-link{display:block;margin-top:15px;text-decoration:none;width:100%}.sidebar-checkout-button{background-color:#4caf50;border:none;border-radius:4px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-weight:700;padding:8px 12px;transition:background-color .3s,transform .2s;width:100%}.sidebar-checkout-button:hover{background-color:#45a049;box-shadow:0 4px 6px #0003;transform:translateY(-2px)}.sidebar-checkout-button.subscribed{background-color:#6c757d;border:1px solid #5a6268}.sidebar-checkout-button.subscribed:hover{background-color:#5a6268}.sidebar-checkout-link.disabled{cursor:not-allowed;pointer-events:none}.sidebar-checkout-button.disabled{background-color:#999!important;border-color:#888;box-shadow:none;color:#ddd;cursor:not-allowed;opacity:.6}.sidebar-checkout-button.disabled:hover{background-color:#999!important;box-shadow:none;transform:none}:root{--modal-backdrop-color:#0000004d;--modal-backdrop-blur:4px;--modal-bg-color:#fff;--modal-border-color:#00000014;--modal-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--modal-border-radius:16px;--modal-border-radius-mobile:12px;--modal-max-width:420px;--modal-padding:24px;--modal-z-index:1000;--text-primary:#111827;--text-secondary:#6b7280;--text-tertiary:#9ca3af;--warning-bg:#fef3c7;--warning-border:#f59e0b;--warning-text:#92400e}@media (prefers-color-scheme:dark){:root{--modal-backdrop-color:#0009;--modal-bg-color:#1f2937;--modal-border-color:#ffffff1a;--modal-shadow:0 20px 25px -5px #0006,0 10px 10px -5px #0003;--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-tertiary:#9ca3af;--warning-bg:#f59e0b1a;--warning-border:#f59e0b;--warning-text:#fcd34d}}@media (prefers-contrast:high){:root{--modal-border-color:#000;--modal-shadow:0 0 0 2px #000;--text-primary:#000}@media (prefers-color-scheme:dark){:root{--modal-border-color:#fff;--modal-shadow:0 0 0 2px #fff;--text-primary:#fff}}}.modal-backdrop{align-items:center;backdrop-filter:blur(4px);backdrop-filter:blur(var(--modal-backdrop-blur));-webkit-backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(var(--modal-backdrop-blur));background-color:#0000004d;background-color:var(--modal-backdrop-color);bottom:0;display:flex;justify-content:center;left:0;opacity:0;overflow-y:auto;padding:16px;position:fixed;right:0;top:0;transition:opacity .2s ease;transition:opacity var(--animation-duration,.2s) var(--animation-easing,ease);z-index:1000;z-index:var(--modal-z-index)}.modal-backdrop--open{opacity:1}.modal-backdrop--closing{opacity:0}.modal-shell{background:#fff;background:var(--modal-bg-color);border:1px solid #00000014;border:1px solid var(--modal-border-color);border-radius:16px;border-radius:var(--modal-border-radius);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--modal-shadow);max-height:calc(100vh - 32px);max-width:420px;max-width:var(--modal-max-width);opacity:0;overflow:hidden;position:relative;transform:scale(.95) translateY(20px);transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--animation-duration,.2s) var(--animation-easing,cubic-bezier(.4,0,.2,1));width:100%}.modal-shell--open{opacity:1;transform:scale(1) translateY(0)}.modal-shell--closing{opacity:0;transform:scale(.95) translateY(20px)}.modal-shell--danger{--animation-duration:250ms}.modal-shell--success{--animation-duration:150ms}@media (prefers-reduced-motion:reduce){.modal-backdrop,.modal-shell{transition-duration:50ms!important}.modal-shell,.modal-shell--closing,.modal-shell--open{transform:none!important}}@media (max-width:640px){.modal-backdrop{align-items:flex-end;padding:8px}.modal-shell{border-radius:12px 12px 0 0;border-radius:var(--modal-border-radius-mobile) var(--modal-border-radius-mobile) 0 0;max-height:90vh;transform:translateY(100%);width:100%}.modal-shell--open{transform:translateY(0)}.modal-shell--closing{transform:translateY(100%)}}.modal-network-warning{align-items:center;background:#fef3c7;background:var(--warning-bg);border-bottom:1px solid #f59e0b;border-bottom:1px solid var(--warning-border);color:#92400e;color:var(--warning-text);display:flex;font-size:13px;font-weight:500;gap:8px;padding:12px 24px;padding:12px var(--modal-padding)}.modal-network-warning__icon{flex-shrink:0;font-size:14px}.modal-network-warning__text{flex:1 1}.modal-content{max-height:calc(90vh - 32px);padding:24px;padding:var(--modal-padding)}.modal-shell:focus-within{outline:2px solid #3b82f6;outline-offset:-2px}@media print{.modal-backdrop{display:none}}.modal-backdrop,.modal-shell{will-change:opacity,transform}.modal-content{-webkit-overflow-scrolling:touch}@supports (border:1px solid canvas){@media (prefers-contrast:high){.modal-shell{border:2px solid canvas}}}.confirmation-modal{display:flex;flex-direction:column;gap:20px;min-width:320px}.confirmation-modal__header{align-items:center;display:flex;gap:12px;margin-bottom:4px}.confirmation-modal__icon{align-items:center;display:flex;flex-shrink:0;font-size:24px;justify-content:center}.confirmation-modal__title{color:var(--text-primary);font-size:18px;font-weight:600;line-height:1.3;margin:0}.confirmation-modal__content{display:flex;flex-direction:column;gap:16px}.confirmation-modal__message{color:var(--text-secondary);font-size:14px;font-weight:400;line-height:1.5;margin:0}.confirmation-modal__consequences{border-radius:8px;color:var(--text-primary);font-size:13px;padding:12px}.confirmation-modal__consequences strong{display:block;font-weight:600;margin-bottom:4px}.confirmation-modal__consequences p{line-height:1.4;margin:0}.confirmation-modal__admin-notice{align-items:center;background:#f59e0b1a;border:1px solid #f59e0b4d;border-radius:6px;color:#92400e;display:flex;font-size:13px;font-weight:500;gap:8px;padding:10px 12px}.confirmation-modal__admin-notice-icon{flex-shrink:0;font-size:16px}.confirmation-modal__password{display:flex;flex-direction:column;gap:8px}.confirmation-modal__password-label{color:var(--text-primary);font-size:13px;font-weight:500}.confirmation-modal__password-input{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:var(--text-primary);font-size:14px;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease}.confirmation-modal__password-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.confirmation-modal__password-input:disabled{background:#f9fafb;color:#6b7280;cursor:not-allowed}.confirmation-modal__countdown{background:#f59e0b1a;border-radius:6px;color:#f59e0b;font-size:13px;font-weight:500;padding:8px;text-align:center}.confirmation-modal__actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end;margin-top:8px}.confirmation-modal__button{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;min-height:40px;padding:10px 20px;position:relative;transition:all .2s ease;white-space:nowrap}.confirmation-modal__button:focus{outline:2px solid #3b82f6;outline-offset:2px}.confirmation-modal__button:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.confirmation-modal__button:not(:disabled):active{transform:scale(.98)}.confirmation-modal__button--cancel{background:#fff;border-color:#d1d5db;color:#374151}.confirmation-modal__button--cancel:not(:disabled):hover{background:#f9fafb;border-color:#9ca3af}.confirmation-modal__button--alternate{background:#f3f4f6;border-color:#d1d5db;color:#4b5563}.confirmation-modal__button--alternate:not(:disabled):hover{background:#e5e7eb;border-color:#9ca3af}.confirmation-modal__button--confirm{color:#fff;font-weight:600}.confirmation-modal__button--danger{background:#dc2626;border-color:#dc2626}.confirmation-modal__button--danger:not(:disabled):hover{background:#b91c1c;border-color:#b91c1c}.confirmation-modal__button--warning{background:#d97706;border-color:#d97706}.confirmation-modal__button--warning:not(:disabled):hover{background:#b45309;border-color:#b45309}.confirmation-modal__button--info{background:#3b82f6;border-color:#3b82f6}.confirmation-modal__button--info:not(:disabled):hover{background:#2563eb;border-color:#2563eb}.confirmation-modal__button--success{background:#10b981;border-color:#10b981}.confirmation-modal__button--success:not(:disabled):hover{background:#059669;border-color:#059669}.confirmation-modal__spinner{animation:confirmation-modal-spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@keyframes confirmation-modal-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (prefers-color-scheme:dark){.confirmation-modal__password-input{background:#374151;border-color:#4b5563;color:#f9fafb}.confirmation-modal__password-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}.confirmation-modal__password-input:disabled{background:#1f2937;color:#9ca3af}.confirmation-modal__button--cancel{background:#374151;border-color:#4b5563;color:#d1d5db}.confirmation-modal__button--cancel:not(:disabled):hover{background:#4b5563;border-color:#6b7280}.confirmation-modal__button--alternate{background:#1f2937;border-color:#374151;color:#9ca3af}.confirmation-modal__button--alternate:not(:disabled):hover{background:#374151;border-color:#4b5563}}@media (prefers-contrast:high){.confirmation-modal__button{border-width:2px}.confirmation-modal__button:focus{outline-width:3px}.confirmation-modal__admin-notice,.confirmation-modal__consequences{border-width:2px}}@media (max-width:640px){.confirmation-modal{min-width:0;min-width:auto}.confirmation-modal__actions{flex-direction:column-reverse;gap:8px}.confirmation-modal__button{justify-content:center;width:100%}.confirmation-modal__title{font-size:16px}.confirmation-modal__icon{font-size:20px}}@media (prefers-reduced-motion:reduce){.confirmation-modal__button{transition:none}.confirmation-modal__button:not(:disabled):active{transform:none}.confirmation-modal__spinner{animation:none;border-top-color:#fffc}}.detail-modal{display:flex;flex-direction:column;gap:20px;max-width:500px;min-width:320px}.detail-modal__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:4px}.detail-modal__icon-title{align-items:center;display:flex;flex:1 1;gap:12px}.detail-modal__icon{align-items:center;display:flex;flex-shrink:0;font-size:24px;justify-content:center}.detail-modal__title{line-height:1.3;margin:0}.detail-modal__content{display:flex;flex-direction:column;gap:16px}.detail-modal__summary{line-height:1.5;margin:0}.detail-modal__expandable{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;transition:border-color .2s ease}.detail-modal__expandable:hover{border-color:#d1d5db}.detail-modal__expand-toggle{align-items:center;background:#f9fafb;border:none;color:#374151;cursor:pointer;display:flex;font-size:14px;font-weight:500;justify-content:space-between;padding:12px 16px;transition:background-color .2s ease;width:100%}.detail-modal__expand-toggle:hover:not(:disabled){background:#f3f4f6}.detail-modal__expand-toggle:focus{outline:2px solid #3b82f6;outline-offset:-2px}.detail-modal__expand-toggle:disabled{cursor:not-allowed;opacity:.6}.detail-modal__expand-text{flex:1 1;text-align:left}.detail-modal__expand-icon{align-items:center;display:flex;font-size:16px;justify-content:center;transition:transform .2s ease}.detail-modal__expanded-content{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1)}.detail-modal__expanded-content--open{max-height:400px}.detail-modal__expanded-inner{background:#fff;border-top:1px solid #e5e7eb;line-height:1.6;padding:16px}.detail-modal__static-content{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;line-height:1.6;padding:16px}.detail-modal__network-warning{align-items:center;background:#f59e0b1a;border:1px solid #f59e0b4d;border-radius:6px;color:#92400e;display:flex;font-size:13px;font-weight:500;gap:8px;padding:10px 12px}.detail-modal__network-warning-icon{flex-shrink:0;font-size:16px}.detail-modal__actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end;margin-top:8px}.detail-modal__button{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;gap:8px;min-height:40px;padding:10px 20px;position:relative;transition:all .2s ease;white-space:nowrap}.detail-modal__button:focus{outline:2px solid #3b82f6;outline-offset:2px}.detail-modal__button:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.detail-modal__button:not(:disabled):active{transform:scale(.98)}.detail-modal__button--secondary{background:#fff;border-color:#d1d5db;color:#374151;font-weight:500}.detail-modal__button--secondary:not(:disabled):hover{background:#f9fafb;border-color:#9ca3af}.detail-modal__button--alternate{background:#f3f4f6;border-color:#d1d5db;color:#4b5563;font-weight:500}.detail-modal__button--alternate:not(:disabled):hover{background:#e5e7eb;border-color:#9ca3af}.detail-modal__button--primary{color:#fff;font-weight:600}.detail-modal__button--danger{background:#ef4444;border-color:#ef4444}.detail-modal__button--danger:not(:disabled):hover{background:#dc2626;border-color:#dc2626}.detail-modal__button--warning{background:#f59e0b;border-color:#f59e0b}.detail-modal__button--warning:not(:disabled):hover{background:#d97706;border-color:#d97706}.detail-modal__button--info{background:#3b82f6;border-color:#3b82f6}.detail-modal__button--info:not(:disabled):hover{background:#2563eb;border-color:#2563eb}.detail-modal__button--success{background:#10b981;border-color:#10b981}.detail-modal__button--success:not(:disabled):hover{background:#059669;border-color:#059669}.detail-modal__spinner{animation:detail-modal-spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@keyframes detail-modal-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (prefers-color-scheme:dark){.detail-modal__expandable{border-color:#4b5563}.detail-modal__expandable:hover{border-color:#6b7280}.detail-modal__expand-toggle{background:#374151;color:#d1d5db}.detail-modal__expand-toggle:hover:not(:disabled){background:#4b5563}.detail-modal__expanded-inner{background:#1f2937;border-top-color:#4b5563}.detail-modal__button--secondary,.detail-modal__static-content{background:#374151;border-color:#4b5563}.detail-modal__button--secondary{color:#d1d5db}.detail-modal__button--secondary:not(:disabled):hover{background:#4b5563;border-color:#6b7280}.detail-modal__button--alternate{background:#1f2937;border-color:#374151;color:#9ca3af}.detail-modal__button--alternate:not(:disabled):hover{background:#374151;border-color:#4b5563}}@media (prefers-contrast:high){.detail-modal__button{border-width:2px}.detail-modal__button:focus{outline-width:3px}.detail-modal__expandable,.detail-modal__static-content{border-width:2px}}@media (max-width:640px){.detail-modal{max-width:none;min-width:0;min-width:auto}.detail-modal__actions{flex-direction:column-reverse;gap:8px}.detail-modal__button{justify-content:center;width:100%}.detail-modal__title{font-size:16px}.detail-modal__icon{font-size:20px}.detail-modal__expanded-content--open{max-height:300px}}@media (prefers-reduced-motion:reduce){.detail-modal__expand-icon,.detail-modal__expanded-content{transition:none}.detail-modal__expanded-content--open{max-height:none}.detail-modal__button{transition:none}.detail-modal__button:not(:disabled):active{transform:none}.detail-modal__spinner{animation:none;border-top-color:#fffc}}.detail-modal__expanded-inner{-webkit-overflow-scrolling:touch;max-height:250px;overflow-y:auto}.detail-modal__expanded-inner::-webkit-scrollbar{width:6px}.detail-modal__expanded-inner::-webkit-scrollbar-track{background:#f3f4f6}.detail-modal__expanded-inner::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.detail-modal__expanded-inner::-webkit-scrollbar-thumb:hover{background:#9ca3af}:root{--sidebar-bg-primary:#fff;--sidebar-bg-secondary:#f9f9f9;--sidebar-bg-subtle:#fafafa;--sidebar-bg-hover:#bfdbfe!important;--sidebar-bg-active:#dbeafe;--sidebar-text-primary:#1f2937;--sidebar-text-secondary:#6b7280;--sidebar-text-muted:#9ca3af;--sidebar-border-light:#e5e7eb;--sidebar-border-active:#3b82f6;--sidebar-shadow-sm:0 1px 2px #0000000d;--sidebar-shadow-hover:0 2px 4px #0000001a;--sidebar-icon-size:16px;--sidebar-gap:10px;--sidebar-padding:12px;--sidebar-radius:6px;--sidebar-indent:16px}.sidebar-action-row{align-items:center;background:#0000;border:none;border-radius:6px;border-radius:var(--sidebar-radius);cursor:pointer;display:flex;gap:10px;gap:var(--sidebar-gap);margin-bottom:4px;padding:12px;padding:var(--sidebar-padding);transition:all .2s ease;-webkit-user-select:none;user-select:none;width:100%}.sidebar-action-row:hover{background:#bfdbfe;background:var(--sidebar-bg-hover)}.sidebar-action-row:active{background:#dbeafe;background:var(--sidebar-bg-active)}.sidebar-action-row.disabled{background:#0000;cursor:not-allowed;opacity:.6}.sidebar-action-row.disabled:hover{background:#0000}.sidebar-action-icon{flex-shrink:0;height:20px;width:20px}.sidebar-action-icon,.sidebar-action-row:hover .sidebar-action-icon{color:#1f2937;color:var(--sidebar-text-primary)}.sidebar-action-row.disabled .sidebar-action-icon{color:#9ca3af;color:var(--sidebar-text-muted)}.sidebar-action-text{color:#1f2937;color:var(--sidebar-text-primary);flex:1 1;font-size:14px;font-weight:700}.sidebar-action-row.disabled .sidebar-action-text{color:#9ca3af;color:var(--sidebar-text-muted)}.sidebar-folder-input-row{align-items:center;background:#fff;background:var(--sidebar-bg-primary);border:2px solid #3b82f6;border:2px solid var(--sidebar-border-active);border-radius:6px;border-radius:var(--sidebar-radius);box-shadow:0 0 0 3px #3b82f61a;display:flex;gap:10px;gap:var(--sidebar-gap);margin-bottom:8px;padding:12px;padding:var(--sidebar-padding);width:100%}.sidebar-folder-input{background:#0000;border:none;color:#1f2937;color:var(--sidebar-text-primary);flex:1 1;font-size:14px;font-weight:500;outline:none}.sidebar-folder-input::placeholder{color:#9ca3af;color:var(--sidebar-text-muted);font-weight:400}.sidebar-folder-hint{color:#9ca3af;color:var(--sidebar-text-muted);font-size:12px;margin-bottom:8px;margin-top:4px;text-align:center}.sidebar-folder-group{margin-bottom:4px}.sidebar-folder-header{align-items:center;border-radius:6px;border-radius:var(--sidebar-radius);cursor:pointer;display:flex;gap:8px;padding:8px 12px;padding:8px var(--sidebar-padding);position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.sidebar-folder-header:hover{background:#bfdbfe;background:var(--sidebar-bg-hover)}.sidebar-folder-header.drag-over{background:#dbeafe;background:var(--sidebar-bg-active);border-left:3px solid #3b82f6;border-left:3px solid var(--sidebar-border-active)}.sidebar-folder-icon{flex-shrink:0;height:24px;transition:color .2s ease;width:24px}.sidebar-folder-icon,.sidebar-folder-icon-collapsed{color:#1f2937;color:var(--sidebar-text-primary)}.sidebar-folder-icon-expanded{color:#3b82f6;color:var(--sidebar-border-active)}.sidebar-folder-name{min-width:0}.sidebar-folder-input-edit,.sidebar-folder-name{color:#1f2937;color:var(--sidebar-text-primary);flex:1 1;font-size:14px;font-weight:700}.sidebar-folder-input-edit{background:#fff;background:var(--sidebar-bg-primary);border:1px solid #e5e7eb;border:1px solid var(--sidebar-border-light);border-radius:4px;outline:none;padding:4px 8px}.sidebar-folder-input-edit:focus{border-color:#3b82f6;border-color:var(--sidebar-border-active);box-shadow:0 0 0 2px #3b82f61a}.sidebar-folder-count{background:#6b728026;border-radius:10px;color:#1f2937;color:var(--sidebar-text-primary);font-size:14px;margin-right:4px;padding:2px 6px}.sidebar-folder-actions{display:flex;gap:2px;opacity:0;transition:opacity .2s ease}.sidebar-folder-header:hover .sidebar-folder-actions{opacity:1}.sidebar-folder-action{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .2s ease;width:28px}.sidebar-folder-action:hover:not(.disabled){background:#0000000d}.sidebar-folder-action.delete:hover:not(.disabled){background:#ef44441a;color:#ef4444}.sidebar-folder-action.disabled{cursor:not-allowed;opacity:.4}.sidebar-folder-action-icon{color:#1f2937;color:var(--sidebar-text-primary);height:18px;width:18px}.sidebar-folder-sessions{overflow:hidden;transition:all .3s ease}.sidebar-folder-sessions.collapsed{max-height:0;opacity:0}.sidebar-folder-sessions.expanded{max-height:1000px;opacity:1}.sidebar-session-item{align-items:center;border-left:3px solid #0000;border-radius:6px;border-radius:var(--sidebar-radius);cursor:pointer;display:flex;justify-content:space-between;margin-bottom:2px;padding:8px 12px;padding:8px var(--sidebar-padding);transition:all .2s ease;-webkit-user-select:none;user-select:none}.sidebar-session-item:hover:not(.disabled){background:#bfdbfe;background:var(--sidebar-bg-hover)}.sidebar-session-item.active{background:#dbeafe;background:var(--sidebar-bg-active);border-left-color:#3b82f6;border-left-color:var(--sidebar-border-active)}.sidebar-session-item.disabled{cursor:not-allowed;opacity:.6}.sidebar-session-item.disabled:hover{background:#0000}.sidebar-session-item.in-folder{margin-left:16px;margin-left:var(--sidebar-indent);padding-left:20px;padding-left:calc(var(--sidebar-padding) + 8px)}.sidebar-session-content{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0}.sidebar-session-name-container{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.sidebar-session-name{color:#1f2937;color:var(--sidebar-text-primary);font-size:14px;font-weight:700}.sidebar-session-name,.sidebar-session-timestamp{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-session-timestamp{color:#6b7280;color:var(--sidebar-text-secondary);font-size:12px;font-weight:400}.sidebar-session-input-edit{background:#fff;background:var(--sidebar-bg-primary);border:1px solid #e5e7eb;border:1px solid var(--sidebar-border-light);border-radius:4px;color:#1f2937;color:var(--sidebar-text-primary);flex:1 1;font-size:14px;font-weight:700;outline:none;padding:4px 8px}.sidebar-session-input-edit:focus{border-color:#3b82f6;border-color:var(--sidebar-border-active);box-shadow:0 0 0 2px #3b82f61a}.sidebar-drag-handle,.sidebar-session-item.disabled .sidebar-session-name{color:#9ca3af;color:var(--sidebar-text-muted)}.sidebar-drag-handle{cursor:grab;flex-shrink:0;height:12px;opacity:0;transition:opacity .2s ease;width:12px}.sidebar-session-item:hover .sidebar-drag-handle{opacity:1}.sidebar-drag-handle:active{cursor:grabbing}.sidebar-session-actions{display:flex;gap:2px;opacity:0;transition:opacity .2s ease}.sidebar-session-item:hover .sidebar-session-actions{opacity:1}.sidebar-session-action{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;height:24px;justify-content:center;transition:all .2s ease;width:24px}.sidebar-session-action:hover:not(.disabled){background:#0000000d}.sidebar-session-action.delete:hover:not(.disabled){background:#ef44441a;color:#ef4444}.sidebar-session-action.disabled{cursor:not-allowed;opacity:.4}.sidebar-session-action-icon{color:#1f2937;color:var(--sidebar-text-primary);height:16px;width:16px}.sidebar-empty-workspace{color:#9ca3af;color:var(--sidebar-text-muted);padding:40px 20px;text-align:center}.sidebar-empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}.sidebar-empty-title{color:#6b7280;color:var(--sidebar-text-secondary);font-size:16px;font-weight:500;margin-bottom:6px}.sidebar-empty-description{color:#9ca3af;color:var(--sidebar-text-muted);font-size:14px;line-height:1.4}.sidebar-empty-folder{background:#f9f9f980;border-radius:4px;color:#9ca3af;color:var(--sidebar-text-muted);font-size:13px;font-style:italic;margin:4px 16px;margin:4px var(--sidebar-indent);padding:12px;text-align:center}.sidebar-loading{align-items:center;color:#6b7280;color:var(--sidebar-text-secondary);display:flex;font-size:14px;justify-content:center;padding:20px}.sidebar-error{background:#fef2f2;border-left:3px solid #dc2626;border-radius:6px;border-radius:var(--sidebar-radius);color:#dc2626;font-size:13px;margin-bottom:12px;padding:12px}.sidebar-drag-overlay{background:#fff;background:var(--sidebar-bg-primary);border:1px solid #e5e7eb;border:1px solid var(--sidebar-border-light);border-radius:6px;border-radius:var(--sidebar-radius);box-shadow:0 4px 12px #00000026;opacity:.9;padding:8px 12px;transform:rotate(2deg);z-index:1000}.sidebar-session-item.dragging{opacity:.5}.sidebar-drop-zone{border-radius:6px;border-radius:var(--sidebar-radius);display:flex;flex:1 1;flex-direction:column;min-height:80px;padding:12px;padding:var(--sidebar-padding);transition:all .2s ease}.sidebar-drop-zone.empty-drop-zone{align-items:center;background:#fafafa;background:var(--sidebar-bg-subtle,#fafafa);border:2px dashed #e5e7eb;border:2px dashed var(--sidebar-border-light);justify-content:center;margin-bottom:8px}.sidebar-drop-zone.empty-drop-zone.drag-over{transform:scale(1.05)!important}.sidebar-drop-zone.drag-over,.sidebar-drop-zone.empty-drop-zone.drag-over{background:#e3f2fd!important;background:var(--primary-light,#e3f2fd)!important;border:3px solid #1976d2!important;border:3px solid var(--primary-color,#1976d2)!important;box-shadow:0 0 0 3px #1976d2,0 0 20px #1976d280!important;box-shadow:0 0 0 3px var(--primary-color,#1976d2),0 0 20px #1976d280!important}.sidebar-drop-zone.drag-over{border-radius:8px!important;transform:scale(1.02)!important;transition:all .2s ease!important}.sidebar-empty-drop-hint{color:#9ca3af;color:var(--sidebar-text-muted);font-size:13px;font-style:italic;text-align:center}.sidebar-separator{background:linear-gradient(90deg,#0000,#6b7280 10%,#6b7280 90%,#0000);background:linear-gradient(90deg,#0000 0,var(--sidebar-text-secondary) 10%,var(--sidebar-text-secondary) 90%,#0000 100%);border-radius:1px;height:2px;margin:16px 12px;margin:16px var(--sidebar-padding);opacity:.8}@media (max-width:768px){.sidebar-action-row{font-size:13px;padding:10px}.sidebar-session-item{padding:6px 10px}.sidebar-drag-handle,.sidebar-folder-actions,.sidebar-session-actions{opacity:1}}.sidebar-drag-handle-icon{color:#9ca3af;color:var(--sidebar-text-muted);cursor:grab;flex-shrink:0;height:16px;height:var(--sidebar-icon-size);opacity:0;transition:opacity .2s ease;width:16px;width:var(--sidebar-icon-size)}.sidebar-session-item:hover .sidebar-drag-handle-icon{opacity:1}.sidebar-drag-handle-icon:active{cursor:grabbing}.sidebar-folder-header.drag-over .sidebar-folder-icon-collapsed{transform:rotateX(30deg) scale(1.1);transition:transform .2s ease-out}.sidebar-folder-header.drag-over .sidebar-folder-icon-expanded{transform:scale(1.15);transition:transform .2s ease-out}.folder-delete-overlay{animation:fadeIn .2s ease-in-out;background-color:#00000080;z-index:1000}.folder-delete-dialog{animation:slideIn .3s ease-out;background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-height:90vh;max-width:480px;overflow-y:auto;width:90%}.folder-delete-header{border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--border-light,#f1f3f4);padding:20px 24px 0}.folder-delete-title{color:#212529;color:var(--text-primary,#212529);font-size:18px;font-weight:600;margin:0 0 16px}.folder-delete-content{padding:20px 24px}.folder-delete-message{color:#212529;color:var(--text-primary,#212529);font-size:14px;line-height:1.5;margin:0 0 12px}.folder-name-highlight{color:#007bff;color:var(--primary-color,#007bff);font-weight:600}.folder-delete-question{color:#495057;color:var(--text-secondary,#495057);font-size:14px;font-weight:500;margin:0}.folder-delete-actions{flex-direction:column;gap:8px;padding:0 24px 20px}.folder-delete-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;justify-content:center;padding:12px 16px;transition:all .2s ease-in-out}.folder-delete-move{background-color:#007bff;background-color:var(--primary-color,#007bff);color:#fff}.folder-delete-move:hover{background-color:#0056b3;background-color:var(--primary-hover,#0056b3)}.folder-delete-all{background-color:#dc3545;background-color:var(--danger-color,#dc3545);color:#fff}.folder-delete-all:hover{background-color:#c82333;background-color:var(--danger-hover,#c82333)}.folder-delete-primary{background-color:#fd7e14;background-color:var(--warning-color,#fd7e14);color:#fff}.folder-delete-primary:hover{background-color:#e8590c;background-color:var(--warning-hover,#e8590c)}.folder-delete-cancel{background-color:#f8f9fa;background-color:var(--bg-secondary,#f8f9fa);border:1px solid #e9ecef;border:1px solid var(--border-secondary,#e9ecef);color:#212529;color:var(--text-primary,#212529)}.folder-delete-cancel:hover{background-color:#e9ecef;background-color:var(--bg-hover,#e9ecef)}@media (max-width:768px){.folder-delete-dialog{margin:20px;width:calc(100% - 40px)}.folder-delete-actions,.folder-delete-content,.folder-delete-header{padding-left:16px;padding-right:16px}}.trash-folder{border-top:1px solid #e1e5e9;border-top:1px solid var(--border-color,#e1e5e9);margin-top:16px;padding-top:12px}.trash-folder-header{justify-content:space-between;transition:background-color .2s ease}.trash-folder.disabled .trash-folder-header{cursor:not-allowed;opacity:.6}.trash-folder.drag-over{border-radius:8px;box-shadow:0 0 0 2px #757575,0 0 12px #7575754d;box-shadow:0 0 0 2px var(--trash-drag-glow,#757575),0 0 12px #7575754d;transition:all .2s ease}.trash-folder.drag-over,.trash-folder.drag-over .trash-folder-header{background-color:#fafafa;background-color:var(--trash-drag-bg,#fafafa)}.trash-folder-title{align-items:center;color:#666;color:var(--text-secondary,#666);display:flex;font-weight:500;gap:8px}.trash-folder-icon{color:#757575;color:var(--trash-color,#757575)}.trash-count{color:#999;color:var(--text-muted,#999);font-size:.85em}.trash-warning-icon{font-size:16px!important;margin-left:4px}.trash-warning-icon.warning{color:#ff9800;color:var(--warning-color,#ff9800)}.trash-warning-icon.expired{color:#f44336;color:var(--error-color,#f44336)}.empty-trash-button{background:#fff;background:var(--bg-color,#fff);border:1px solid #e1e5e9;border:1px solid var(--border-color,#ddd);border-radius:4px;color:#333;color:var(--text-color,#333);cursor:pointer;font-size:.8em;padding:4px 8px;transition:all .2s ease}.empty-trash-button:hover:not(:disabled){background:#f44336;background:var(--error-color,#f44336);border-color:#f44336;border-color:var(--error-color,#f44336);color:#fff}.empty-trash-button:disabled{cursor:not-allowed;opacity:.5}.trash-folder-content{border-left:2px solid #f0f0f0;border-left:2px solid var(--border-light,#f0f0f0);margin-left:16px;padding-left:8px}.trash-empty-message{color:#999;color:var(--text-muted,#999);font-size:.9em;font-style:italic;padding:16px 12px;text-align:center}.trash-session-item{align-items:center;border-left:3px solid #0000;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:4px;padding:8px 12px;transition:all .2s ease}.trash-session-item:hover:not(.disabled){background-color:#f5f5f5;background-color:var(--sidebar-bg-hover,#f5f5f5)}.trash-session-item.active{background-color:#e3f2fd;background-color:var(--primary-light,#e3f2fd);border-left-color:#1976d2;border-left-color:var(--primary-color,#1976d2)}.trash-session-item.disabled{cursor:not-allowed;opacity:.6}.trash-session-item.warning{border-left-color:#ff9800;border-left-color:var(--warning-color,#ff9800)}.trash-session-item.expired{border-left-color:#f44336;border-left-color:var(--error-color,#f44336)}.trash-session-content{flex:1 1;min-width:0}.trash-session-header{align-items:center;display:flex;gap:6px;margin-bottom:2px}.trash-session-name{color:#333;color:var(--text-color,#333);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-warning-icon{flex-shrink:0;font-size:14px!important}.session-warning-icon.warning{color:#ff9800;color:var(--warning-color,#ff9800)}.session-warning-icon.expired{color:#f44336;color:var(--error-color,#f44336)}.trash-session-info{color:#999;color:var(--text-muted,#999);font-size:.8em}.trash-session-date{margin-bottom:2px}.trash-session-warning{font-weight:500}.trash-session-item.warning .trash-session-warning{color:#ff9800;color:var(--warning-color,#ff9800)}.trash-session-item.expired .trash-session-warning{color:#f44336;color:var(--error-color,#f44336)}.trash-folder-group{margin-bottom:16px;opacity:.85;transition:all .2s ease}.trash-folder-group.warning{background:linear-gradient(90deg,#ff98000d,#0000 10%);border-left:3px solid #ff9800;border-left:3px solid var(--warning-color,#ff9800);opacity:.75}.trash-folder-group.expired{background:linear-gradient(90deg,#f443360d,#0000 10%);border-left:3px solid #f44336;border-left:3px solid var(--error-color,#f44336);opacity:.65}.trash-folder-header{align-items:center;background:#fff;background:var(--bg-color,#fff);border:1px solid #e1e5e9;border:1px solid var(--border-color,#e1e5e9);border-radius:6px;cursor:pointer;display:flex;margin-bottom:8px;padding:8px 12px;transition:all .2s ease}.trash-folder-header:hover:not(.disabled){background-color:#f5f5f5;background-color:var(--sidebar-bg-hover,#f5f5f5)}.trash-folder-icon-wrapper{align-items:center;display:flex;margin-right:8px}.trash-folder-icon{color:#666;color:var(--text-secondary,#666);font-size:18px!important;transition:color .2s ease}.trash-folder-group.warning .trash-folder-icon{color:#ff9800;color:var(--warning-color,#ff9800)}.trash-folder-group.expired .trash-folder-icon{color:#f44336;color:var(--error-color,#f44336)}.trash-folder-info{flex:1 1;min-width:0}.trash-folder-name-row{align-items:center;display:flex;gap:6px;margin-bottom:2px}.trash-folder-name{color:#333;color:var(--text-color,#333);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trash-folder-count{color:#999;color:var(--text-muted,#999);flex-shrink:0;font-size:.85em}.trash-folder-warning-icon{align-items:center;display:flex;flex-shrink:0}.trash-folder-warning-icon svg{font-size:16px!important}.trash-folder-warning-icon.warning{color:#ff9800;color:var(--warning-color,#ff9800)}.trash-folder-warning-icon.expired{color:#f44336;color:var(--error-color,#f44336)}.trash-folder-meta{color:#999;color:var(--text-muted,#999);font-size:.8em}.trash-folder-actions{display:flex;flex-shrink:0;gap:4px}.trash-folder-action{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.trash-folder-action.restore{background:#e8f5e8;background:var(--success-light,#e8f5e8);color:#4caf50;color:var(--success-color,#4caf50)}.trash-folder-action.restore:hover:not(:disabled){background:#4caf50;background:var(--success-color,#4caf50);box-shadow:0 0 8px #4caf504d;color:#fff}.trash-folder-action.delete{background:#ffebee;background:var(--error-light,#ffebee);color:#f44336;color:var(--error-color,#f44336)}.trash-folder-action.delete:hover:not(:disabled){background:#f44336;background:var(--error-color,#f44336);box-shadow:0 0 8px #f443364d;color:#fff}.trash-folder-action:disabled{cursor:not-allowed;opacity:.5}.trash-folder-action svg{font-size:16px!important}.trash-folder-sessions{border-left:2px solid #f0f0f0;border-left:2px solid var(--border-light,#f0f0f0);margin-left:16px;padding-left:8px}.trash-session-actions{display:flex;flex-shrink:0;gap:4px}.permanent-delete-button,.restore-button{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.restore-button{background:#e8f5e8;background:var(--success-light,#e8f5e8);color:#4caf50;color:var(--success-color,#4caf50)}.restore-button:hover:not(:disabled){background:#4caf50;background:var(--success-color,#4caf50);color:#fff}.permanent-delete-button{background:#ffebee;background:var(--error-light,#ffebee);color:#f44336;color:var(--error-color,#f44336)}.permanent-delete-button:hover:not(:disabled){background:#f44336;background:var(--error-color,#f44336);color:#fff}.permanent-delete-button:disabled,.restore-button:disabled{cursor:not-allowed;opacity:.5}.permanent-delete-button svg,.restore-button svg{font-size:16px!important}.restore-button:hover:not(:disabled){box-shadow:0 0 8px #4caf504d}.permanent-delete-button:hover:not(:disabled){box-shadow:0 0 8px #f443364d}.empty-trash-message{line-height:1.5}.empty-trash-message p{margin-bottom:12px}.empty-trash-message p:last-child{margin-bottom:0}.age-warnings{background:#fff3cd;background:var(--warning-light,#fff3cd);border:1px solid #ff9800;border:1px solid var(--warning-color,#ff9800);border-radius:6px;margin:16px 0;padding:12px}.warning-message{align-items:center;display:flex;font-weight:500;gap:8px;margin-bottom:8px}.warning-message:last-child{margin-bottom:0}.warning-message.warning{color:#f57c00;color:var(--warning-dark,#f57c00)}.warning-message.expired{color:#d32f2f;color:var(--error-dark,#d32f2f)}.inline-icon{font-size:18px!important}.confirmation-prompt{color:#333;color:var(--text-color,#333);font-weight:500}.trash-animate{animation:trashReceiveItem .6s ease-out}@keyframes trashReceiveItem{0%{transform:translateX(0)}10%{transform:translateX(-4px)}20%{transform:translateX(4px)}30%{transform:translateX(-3px)}40%{transform:translateX(3px)}50%{transform:translateX(-2px)}60%{transform:translateX(2px)}70%{transform:translateX(-1px)}80%{transform:translateX(1px)}90%{transform:translateX(-.5px)}to{transform:translateX(0)}}:root{--trash-color:#757575;--trash-drag-bg:#fafafa;--trash-drag-glow:#757575;--warning-color:#ff9800;--warning-light:#fff3cd;--warning-dark:#f57c00;--error-color:#f44336;--error-light:#ffebee;--error-dark:#d32f2f;--success-color:#4caf50;--success-light:#e8f5e8;--primary-color:#1976d2;--primary-light:#e3f2fd;--text-color:#333;--text-secondary:#666;--text-muted:#999;--bg-color:#fff;--border-color:#e1e5e9;--border-light:#f0f0f0;--sidebar-bg-hover:#f5f5f5}.trash-folder-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;margin-bottom:8px;padding:12px;transition:all .2s ease}.trash-folder-item:hover:not(.disabled){background:#e9ecef;border-color:#dee2e6}.trash-folder-item.active{background:#e3f2fd;border-color:#2196f3}.trash-folder-item.disabled{cursor:not-allowed;opacity:.6}.trash-folder-item-content{align-items:center;display:flex;justify-content:space-between;width:100%}.trash-folder-item-main{align-items:center;display:flex;flex:1 1;gap:12px}.trash-folder-item-icon{color:#6c757d;font-size:20px}.trash-folder-item-info{flex:1 1;min-width:0}.trash-folder-item-name{color:#212529;font-size:14px;font-weight:500;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trash-folder-item-meta{align-items:center;color:#6c757d;display:flex;font-size:12px;gap:8px}.trash-warning{font-weight:500}.trash-warning.warning{color:#f57c00}.trash-warning.expired{color:#d32f2f}.trash-folder-item-actions{display:flex;gap:8px;margin-left:8px}.trash-folder-item-action{align-items:center;background:#0000;border:1px solid #0000;border-radius:4px;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.trash-folder-item-action:hover:not(:disabled){background:#0000000a}.trash-folder-item-action:disabled{cursor:not-allowed;opacity:.4}.trash-folder-item-action.restore{color:#2e7d32}.trash-folder-item-action.restore:hover:not(:disabled){background:#2e7d3214;border-color:#2e7d3233}.trash-folder-item-action.delete{color:#d32f2f}.trash-folder-item-action.delete:hover:not(:disabled){background:#d32f2f14;border-color:#d32f2f33}.trash-folder-item-action svg{font-size:18px}.trash-folder-item-sessions{border-top:1px solid #dee2e6;margin-top:12px;padding-top:12px}.trash-folder-session-preview{align-items:center;background:#ffffff80;border-radius:4px;display:flex;font-size:12px;gap:8px;margin-bottom:4px;padding:6px 8px}.session-number{color:#6c757d;font-weight:500;min-width:20px}.session-name{color:#495057;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trash-folder-session-preview:last-child{margin-bottom:0}.session-list-container{display:flex;flex-direction:column;height:100%;min-height:0}.session-list-header{border-bottom:1px solid #0000001a;flex-grow:0;flex-shrink:0;margin-bottom:10px;padding-bottom:10px}.session-list-content{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;scrollbar-gutter:stable}@media (min-width:1024px){.session-list-content::-webkit-scrollbar{width:8px}.session-list-content::-webkit-scrollbar-thumb{background-color:#00000040;border-radius:4px}}.folders-and-sessions-container{margin-bottom:16px}.unfoldered-sessions{margin-top:16px}.unfoldered-sessions-header{border-bottom:1px solid #f1f3f4;border-bottom:1px solid var(--border-light,#f1f3f4);color:#6c757d;color:var(--text-secondary,#6c757d);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;padding:8px 12px;text-transform:uppercase}.folder-session-item .session-button{background-color:initial;border:none;border-radius:4px;transition:all .2s ease-in-out}.folder-session-item .session-button:hover{background-color:#f8f9fa;background-color:var(--bg-hover,#f8f9fa)}.folder-session-item .session-button.active{background-color:#e3f2fd;background-color:var(--primary-bg,#e3f2fd);border-left:3px solid #1976d2;border-left:3px solid var(--primary-color,#1976d2);color:#1976d2;color:var(--primary-color,#1976d2)}.folders-loading{align-items:center;color:#6c757d;color:var(--text-secondary,#6c757d);display:flex;font-style:italic;justify-content:center;padding:20px}.folders-error{background-color:#f8d7da;background-color:var(--danger-bg,#f8d7da);border-radius:4px;color:#721c24;color:var(--danger-color,#721c24);font-size:13px;margin-bottom:16px;padding:12px}.empty-workspace{color:#adb5bd;color:var(--text-muted,#adb5bd);padding:32px 16px;text-align:center}.empty-workspace-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-workspace-title{color:#6c757d;color:var(--text-secondary,#6c757d);font-size:16px;font-weight:500;margin-bottom:8px}.empty-workspace-description{font-size:14px;line-height:1.4}@media (max-width:768px){.folders-and-sessions-container{margin-bottom:12px}.unfoldered-sessions{margin-top:12px}.unfoldered-sessions-header{font-size:11px;padding:6px 8px}}.session-button.dragging{box-shadow:0 5px 15px #0000004d;opacity:.5;transform:rotate(5deg);z-index:1000}.session-button .drag-handle{align-items:center;color:#adb5bd;color:var(--text-muted,#adb5bd);cursor:grab;display:inline-flex;font-size:12px;line-height:1;margin-right:6px;opacity:0;transition:opacity .2s ease-in-out;-webkit-user-select:none;user-select:none}.session-button:hover .drag-handle{opacity:1}.session-button .drag-handle:active{cursor:grabbing}.session-button.disabled .drag-handle{display:none}.drag-overlay{background:#fff;border:1px solid #dee2e6;border:1px solid var(--border-primary,#dee2e6);border-radius:4px;box-shadow:0 5px 15px #0000004d;opacity:.9;padding:8px 12px;transform:rotate(5deg);z-index:1000}.drop-zone{transition:all .2s ease-in-out}.drop-zone.drag-over{border:2px dashed #007bff;border:2px dashed var(--primary-color,#007bff);border-radius:6px}.drop-zone.drag-over,.folder-header.drag-over{background-color:#f8f9ff;background-color:var(--primary-bg-light,#f8f9ff)}.folder-header.drag-over,.unfoldered-sessions.drag-over{border:2px dashed #007bff;border:2px dashed var(--primary-color,#007bff)}.unfoldered-sessions.drag-over{background-color:#f8f9ff;background-color:var(--primary-bg-light,#f8f9ff);border-radius:6px}.folder-group.auto-expanding .folder-sessions{max-height:1000px;transition:max-height .3s ease-in-out}.drop-zone.invalid-drop{background-color:#fff5f5;background-color:var(--danger-bg-light,#fff5f5);border:2px dashed #dc3545;border:2px dashed var(--danger-color,#dc3545)}.sortable-context{position:relative}.session-button.drag-candidate{background-color:#f8f9fa;background-color:var(--bg-hover,#f8f9fa);border-left:3px solid #007bff;border-left:3px solid var(--primary-color,#007bff)}@media (max-width:768px){.session-button .drag-handle{opacity:1}.drag-overlay{transform:none}}.dashboard-container{--apw:380px;display:grid;grid-template-areas:"sidebar content askphysi";grid-template-columns:300px 1fr 380px;grid-template-columns:300px 1fr var(--apw,380px);height:100vh;height:calc(var(--vh, 1vh)*100);min-width:1024px;overflow:hidden;position:relative;width:100%}.dashboard-container.ap-hidden{grid-template-areas:"sidebar content";grid-template-columns:300px 1fr}.dashboard-container.ap-min{--apw:48px;grid-template-columns:300px 1fr 48px;grid-template-columns:300px 1fr var(--apw,48px)}.sidebar{grid-area:sidebar}.dashboard-container>.sidebar{min-height:0;overflow:hidden}.main-content{display:flex;flex-direction:column;flex-grow:1;flex-shrink:1;grid-area:content;height:100%;min-width:0}.global-controls-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #007bff33;border-radius:8px;box-shadow:0 4px 12px #00000026;gap:12px;padding:8px 12px;position:absolute;right:16px;top:16px;z-index:1000}.global-controls,.global-controls-overlay{align-items:center;background:#fffffff2;display:flex}.global-controls{border-bottom:1px solid #007bff1a;box-shadow:0 2px 4px #0000000d;justify-content:flex-end;min-height:52px;padding:8px 16px;position:relative;z-index:10}.main-content-body{display:flex;flex-direction:column;flex-grow:1;height:100%;overflow:hidden;padding:0 1.5%;width:100%}.review-header{width:100%;z-index:1}.review-main{flex-grow:1}.review-main,.session-header{display:flex;flex-direction:column;width:100%}.session-header{border:0 solid #ff0;z-index:1}.session-main{border:0 solid green;flex-grow:1;width:100%}.askphysi-panel,.session-main{display:flex;flex-direction:column;height:100%}.askphysi-panel{background:#fff;border-left:1px solid #e5e7eb;box-shadow:-2px 0 4px #0000000a;grid-area:askphysi;position:relative;will-change:width}.askphysi-resizer{background:#0000;cursor:col-resize;height:100%;left:-3px;position:absolute;top:0;transition:background .15s;width:6px;z-index:2}.askphysi-resizer:focus,.askphysi-resizer:hover{background:#3b82f61a}.askphysi-resizer:after{background:#3b82f6;content:"";height:100%;left:2px;opacity:0;position:absolute;top:0;transition:opacity .15s;width:2px}.askphysi-resizer:active:after,.askphysi-resizer:focus:after,.askphysi-resizer:hover:after{opacity:1}.dashboard-container.ap-hidden .askphysi-panel{display:none}@media (max-width:1399px){.dashboard-container{grid-template-areas:"sidebar content"!important;grid-template-columns:300px 1fr!important}.askphysi-panel{display:none!important}}.ql-action-buttons-container .ql-action.ql-copy,.ql-toolbar .ql-action.ql-copy{align-items:center!important;border-radius:4px!important;cursor:pointer!important;display:flex!important;font-size:.9em!important;justify-content:center!important;margin:0 2px!important;opacity:1!important;pointer-events:auto!important;position:relative!important;transition:all .2s ease!important}.ql-action-buttons-container .ql-action.ql-copy.copy-button,.ql-toolbar .ql-action.ql-copy.copy-button{background-color:#eee!important;border:none!important;color:inherit!important;height:auto!important;min-height:28px!important;min-width:28px!important;padding:5px 10px!important;width:auto!important}.ql-action-buttons-container .ql-action.ql-copy.copy-button:hover,.ql-toolbar .ql-action.ql-copy.copy-button:hover{background-color:#ddd!important}.ql-action-buttons-container .ql-action.ql-copy.copy-button:active,.ql-toolbar .ql-action.ql-copy.copy-button:active{background-color:#ccc!important}.ql-action-buttons-container .ql-action.ql-copy i,.ql-toolbar .ql-action.ql-copy i{height:16px!important;margin-right:4px!important;width:16px!important}.ql-action-buttons-container .ql-action.ql-copy.copy-button-empty,.ql-action-buttons-container .ql-action.ql-copy:disabled,.ql-toolbar .ql-action.ql-copy.copy-button-empty,.ql-toolbar .ql-action.ql-copy:disabled{cursor:not-allowed!important;opacity:.5!important;pointer-events:none!important}.ql-action-buttons-container .ql-action.ql-copy.copying,.ql-toolbar .ql-action.ql-copy.copying{opacity:.7!important}.ql-action-buttons-container .ql-action.ql-copy.copying i[data-lucide=loader-2],.ql-toolbar .ql-action.ql-copy.copying i[data-lucide=loader-2]{animation:spin 1s linear infinite}.ql-action-buttons-container .ql-action.ql-copy.success,.ql-toolbar .ql-action.ql-copy.success{background-color:#d4edda!important;border-color:#c3e6cb!important;color:#155724!important}.ql-action-buttons-container .ql-action.ql-copy.copy-button.success,.ql-toolbar .ql-action.ql-copy.copy-button.success{background-color:#d4edda!important}.ql-action-buttons-container .ql-action.ql-copy.error,.ql-toolbar .ql-action.ql-copy.error{background-color:#f8d7da!important;border-color:#f5c6cb!important;color:#721c24!important}.ql-action-buttons-container .ql-action.ql-copy.copy-button.error,.ql-toolbar .ql-action.ql-copy.copy-button.error{background-color:#f8d7da!important}@media (max-width:768px){.ql-action.ql-copy.copy-button{font-size:.8em!important;padding:4px 8px!important}.ql-action.ql-copy i{height:14px!important;width:14px!important}}.ql-action.ql-copy:focus{outline:2px solid #007bff!important;outline-offset:2px!important}@media (prefers-contrast:high){.ql-action.ql-copy.copy-button{border:2px solid #000!important}}@media (prefers-reduced-motion:reduce){.ql-action.ql-copy{transition:none!important}.ql-action.ql-copy.copying i[data-lucide=loader-2]{animation:none!important}}.ql-action-buttons-container .ql-action.ql-export,.ql-toolbar .ql-action.ql-export{align-items:center!important;border-radius:4px!important;cursor:pointer!important;display:flex!important;font-size:.9em!important;justify-content:center!important;margin:0 2px!important;opacity:1!important;pointer-events:auto!important;position:relative!important;transition:all .2s ease!important}.ql-action-buttons-container .ql-action.ql-export.export-button,.ql-toolbar .ql-action.ql-export.export-button{background-color:#eee!important;border:none!important;color:inherit!important;height:auto!important;min-height:28px!important;min-width:28px!important;padding:5px 10px!important;width:auto!important}.ql-action-buttons-container .ql-action.ql-export.export-button:hover,.ql-toolbar .ql-action.ql-export.export-button:hover{background-color:#ddd!important}.ql-action-buttons-container .ql-action.ql-export.export-button:active,.ql-toolbar .ql-action.ql-export.export-button:active{background-color:#ccc!important}.ql-action-buttons-container .ql-action.ql-export i,.ql-toolbar .ql-action.ql-export i{height:16px!important;margin-right:4px!important;width:16px!important}.ql-export-container{display:inline-block;position:relative}.ql-action-buttons-container .ql-action.ql-export.export-button-empty,.ql-action-buttons-container .ql-action.ql-export:disabled,.ql-toolbar .ql-action.ql-export.export-button-empty,.ql-toolbar .ql-action.ql-export:disabled{cursor:not-allowed!important;opacity:.5!important;pointer-events:none!important}.ql-action-buttons-container .ql-action.ql-export.exporting,.ql-toolbar .ql-action.ql-export.exporting{opacity:.7!important}.ql-action-buttons-container .ql-action.ql-export.exporting i[data-lucide=loader-2],.ql-toolbar .ql-action.ql-export.exporting i[data-lucide=loader-2]{animation:spin 1s linear infinite}.ql-action-buttons-container .ql-action.ql-export.success,.ql-toolbar .ql-action.ql-export.success{background-color:#d4edda!important;border-color:#c3e6cb!important;color:#155724!important}.ql-action-buttons-container .ql-action.ql-export.export-button.success,.ql-toolbar .ql-action.ql-export.export-button.success{background-color:#d4edda!important}.ql-action-buttons-container .ql-action.ql-export.error,.ql-toolbar .ql-action.ql-export.error{background-color:#f8d7da!important;border-color:#f5c6cb!important;color:#721c24!important}.ql-action-buttons-container .ql-action.ql-export.export-button.error,.ql-toolbar .ql-action.ql-export.export-button.error{background-color:#f8d7da!important}@media (max-width:768px){.ql-action.ql-export.export-button{font-size:.8em!important;padding:4px 8px!important}.ql-action.ql-export i{height:14px!important;width:14px!important}}.ql-action.ql-export:focus{outline:2px solid #007bff!important;outline-offset:2px!important}@media (prefers-contrast:high){.ql-action.ql-export.export-button{border:2px solid #000!important}}@media (prefers-reduced-motion:reduce){.ql-action.ql-export{transition:none!important}.ql-action.ql-export.exporting i[data-lucide=loader-2]{animation:none!important}}.main-session-header{align-items:center;border-bottom:0 solid #ccc;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-left:30px;margin-right:0;margin-top:30px;min-height:60px;padding:10px;position:relative}.create-soap-note-button{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;min-width:160px;min-width:170px;padding:10px 20px;white-space:nowrap}.create-soap-note-button:active:after{animation:newWriting 1s infinite alternate;content:"🖊️";position:absolute;right:10px;top:50%;transform:translateY(-50%)}@keyframes newWriting{0%{transform:translateY(-50%) rotate(0deg)}to{transform:translateY(-50%) rotate(20deg)}}.create-soap-note-button:hover{background-color:#0056b3}.create-soap-note-button.loading{animation:pulse-button 2s ease-in-out infinite;background-color:#666;cursor:default;pointer-events:none;position:relative}@keyframes pulse-button{0%{background-color:#bbb}50%{background-color:#e4e2e2}to{background-color:#f3f2f2}}.create-soap-note-button.loading:before{animation:progress 2s linear infinite;background-color:#007bff;border-bottom-left-radius:5px;border-bottom-right-radius:5px;bottom:0;content:"";height:4px;left:0;position:absolute;width:0}.create-soap-note-button-modern{align-items:center;background:linear-gradient(90deg,#0056b3,#007bff);border:none;border-radius:12px;box-shadow:0 4px 12px #007bff33;color:#fff;display:flex;font-size:15px;font-weight:500;gap:8px;justify-content:center;min-width:120px;padding:10px 22px;position:relative;transition:all .3s ease-in-out}.create-soap-note-button-modern:hover:not(:disabled){background:linear-gradient(90deg,#004080,#06c);transform:scale(1.02)}.create-soap-note-button-modern:disabled{background:#ccc;color:#6c757d;cursor:not-allowed}.create-soap-note-button-modern.loading{animation:pulse-button 1.6s ease-in-out infinite;pointer-events:none}.create-soap-note-button-modern .icon{align-items:center;display:flex;font-size:1.1rem;justify-content:center}@keyframes progress{0%{opacity:.4;width:0}50%{opacity:1}to{opacity:.4;width:100%}}.info-box{align-items:baseline;background-color:initial;border:0 solid #ccc;border-radius:4px;display:flex;gap:10px;max-width:800px;padding:5px;width:100%}.info-label{align-items:center;display:flex;flex-shrink:0;font-weight:700;justify-content:flex-end;text-align:right;white-space:nowrap;width:120px}.info-value{background-color:#d3d3d3;border:none;flex-grow:1;max-width:300px;min-width:120px;outline:none;padding:2px}.info-value:focus{background-color:#fff;border:1px solid #aaa;border-radius:4px}.info-value:is(select){-webkit-appearance:menulist;appearance:menulist;background-image:none;padding-right:1.5rem;position:relative}.info-value:is(select):after{content:"\f078";font-family:Font Awesome\ 6 Free;font-weight:900;pointer-events:none;position:absolute;right:.5rem;top:50%;transform:translateY(-50%)}.main-session-header .button-container{align-items:center!important;display:flex!important;flex-direction:row!important;flex-shrink:1;flex-wrap:wrap!important;gap:8px!important;justify-content:flex-start!important;margin-left:0!important;min-width:0}.main-session-header .button-container>*{flex-shrink:1;margin:0!important;min-width:0}.main-session-header .button-container .consent-checkbox-container{margin-right:16px!important}.main-session-header .button-container .record-button-container{align-items:center!important;display:flex!important;flex-direction:row!important;gap:20px!important}.main-session-header .button-container .create-soap-note-button-modern{margin-left:30px!important}.header-right-rail>*{flex-shrink:1!important}.recording-time-warning{align-items:center;animation:slide-in .3s ease-out;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background-color:#ff3b30e6;border-radius:10px;box-shadow:0 4px 12px #00000026;color:#fff;display:flex;font-weight:500;gap:12px;max-width:400px;padding:8px 14px;position:absolute;right:0;top:-50px;z-index:10000}@keyframes flash-warning{0%{background-color:#ff9500}50%{background-color:#fc0}to{background-color:#ff9500}}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.3}}.warning-message{animation:pulse-text 1s infinite}@keyframes slide-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.warning-message{font-size:14px}.extend-time-button{background-color:#fff;border:none;border-radius:6px;color:#ff3b30;cursor:pointer;font-size:13px;font-weight:600;padding:5px 10px;transition:all .2s}.extend-time-button:hover{background-color:#f2f2f2;transform:scale(1.05)}.recording-indicator-container{align-items:center;display:flex;margin-right:15px;position:relative}.recording-indicator{align-items:center;animation:subtle-scale 2s ease-in-out infinite;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background-color:#ff375f1a;border-radius:4px;box-shadow:0 0 10px #ff375f4d;color:#ff375f;display:flex;font-size:1.6rem;height:26px;justify-content:center;padding:3px;position:relative;transform-origin:center;transition:all .3s ease;width:26px}@keyframes subtle-scale{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.eq-bar{animation-iteration-count:infinite;animation-name:sound-wave;animation-timing-function:linear;background-color:#ff375f;border-radius:1px;bottom:0;position:absolute;width:2px}.eq-bar:first-child{animation-delay:.1s;animation-duration:.7s;height:8px;left:4px}.eq-bar:nth-child(2){animation-delay:0s;animation-duration:.5s;height:15px;left:8px}.eq-bar:nth-child(3){animation-delay:.2s;animation-duration:.6s;height:10px;left:12px}.eq-bar:nth-child(4){animation-delay:.1s;animation-duration:.8s;height:12px;left:16px}.eq-bar:nth-child(5){animation-delay:.15s;animation-duration:.5s;height:7px;left:20px}@keyframes sound-wave{0%,to{height:5px;opacity:.6}50%{height:15px;opacity:1}}.no-active-session-warning{background-color:#f8d7da;border-radius:4px;box-shadow:0 2px 4px #0000001a;color:#721c24;font-size:14px;font-weight:500;left:0;padding:8px 15px;position:absolute;right:0;text-align:center;top:-28px}.info-value:disabled{opacity:.8}.info-value:disabled,button:disabled{background-color:#e9ecef;color:#6c757d;cursor:not-allowed}button:disabled{opacity:.7}.record-button-container{align-items:center;display:flex;flex-direction:row!important;position:relative;z-index:10000}@keyframes fade-transition{0%{opacity:.7;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.session-transition{animation:fade-transition .3s ease-out}.mic-icon{font-size:1.5rem;transition:all .3s ease}.mic-icon.active{animation:micPulse 1s ease-in-out infinite;color:#0f8}.session-header-info{display:flex;flex:1 1 auto;flex-direction:column;gap:5px;margin-bottom:0;max-width:600px;min-width:320px}.header-right-rail{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-left:auto}.header-right-rail,.header-right-rail>*{flex-shrink:1;min-width:0}.wave-slot{contain:paint;flex-shrink:1;height:44px;max-width:200px;min-width:100px;overflow:clip;position:relative;width:150px}.wave-slot>*{inset:0!important;max-height:100%!important;max-width:100%!important;position:absolute!important}@media (max-width:1200px){.main-session-header{gap:8px}.header-right-rail{gap:6px}.wave-slot{min-width:80px;width:120px}}@media (max-width:1000px){.session-header-info{min-width:280px}.wave-slot{min-width:60px;width:100px}.header-right-rail{gap:4px}}@media (max-width:900px){.main-session-header{align-items:stretch;flex-direction:column;gap:15px}.header-right-rail{justify-content:center;margin-left:0;width:100%}.session-header-info{min-width:0;width:100%}.wave-slot{min-width:150px;width:150px}}@media (max-width:600px){.header-right-rail{flex-direction:column;gap:10px}.main-session-header{margin-left:15px;padding:8px}}.record-button{align-items:center;background:linear-gradient(145deg,#ef4444,#b91c1c);border:none;border-radius:50%;box-shadow:0 8px 16px -4px #dc262666,0 4px 8px -2px #0003,inset 0 2px 4px #fff3,inset 0 -2px 4px #0003;cursor:pointer;display:flex;height:4rem;justify-content:center;margin:-.5rem;outline:none;padding:.5rem;position:relative;transform:translateY(0);transition:all .2s ease-in-out;width:4rem}.record-button:hover:not(.record-button--disabled){box-shadow:0 12px 20px -4px #dc262680,0 8px 16px -4px #00000040,inset 0 2px 4px #ffffff4d,inset 0 -2px 4px #0003;transform:translateY(-2px)}.record-button:active:not(.record-button--disabled){box-shadow:0 4px 8px -2px #dc26264d,0 2px 4px -1px #00000026,inset 0 1px 2px #ffffff1a,inset 0 -3px 6px #0000004d;transform:translateY(1px)}.record-button.record-button--disabled{background:#ccc!important;background-color:#ccc!important;background-image:none!important;box-shadow:0 4px 8px -2px #0000001a,0 2px 4px -1px #0000000d,inset 0 1px 2px #ffffff1a,inset 0 -1px 2px #0000001a!important;cursor:not-allowed!important;opacity:.7!important;transform:translateY(0)!important}.record-button__ring{animation:ping 1s cubic-bezier(0,0,.2,1) infinite;background-color:#f8717180;border-radius:50%;inset:0;position:absolute}.record-button__inner{background-color:#fff;border:none;border-radius:50%;display:none;height:2.5rem;transform:scale(1);transition:transform .2s ease-in-out,background-color .2s ease-in-out,border .2s ease-in-out;width:2.5rem}.record-button--recording .record-button__inner{background:linear-gradient(145deg,#dc2626,#991b1b);border:2px solid #fff;box-shadow:inset 0 1px 2px #ffffff4d,inset 0 -1px 2px #0003;display:block;transform:scale(.9)}.record-button--processing .record-button__inner{background:linear-gradient(145deg,#fff,#f3f4f6);box-shadow:inset 0 1px 2px #fff9,inset 0 -1px 2px #0000001a;display:block}.record-button__icon{color:#dc2626;height:1.5rem;position:absolute;transition:color .2s ease-in-out;width:1.5rem}.record-button.record-button--disabled .record-button__icon,.record-button.record-button--disabled .record-button__text{color:#6c757d!important}.record-button--recording .record-button__icon{color:#fff}.record-button__text{color:#fff;font-size:.75rem;font-weight:600;position:absolute;transition:color .2s ease-in-out;-webkit-user-select:none;user-select:none}.record-button--recording .record-button__text{color:#fff}.record-button--processing .record-button__icon{animation:spin 1s linear infinite}.record-button--starting{animation:pulse-green 1s ease-in-out infinite;background:linear-gradient(145deg,#10b981,#047857)!important;box-shadow:0 8px 16px -4px #10b98166,0 4px 8px -2px #0003,inset 0 2px 4px #fff3,inset 0 -2px 4px #0003!important}.record-button--starting .record-button__icon{animation:spin .8s linear infinite;color:#fff}.record-button--stopping{animation:fade-amber .6s ease-in-out infinite alternate;background:linear-gradient(145deg,#f59e0b,#d97706)!important;box-shadow:0 8px 16px -4px #f59e0b66,0 4px 8px -2px #0003,inset 0 2px 4px #fff3,inset 0 -2px 4px #0003!important}.record-button--stopping .record-button__icon{animation:spin-slow 1.2s ease-in-out infinite;color:#fff}@keyframes ping{0%{opacity:.7;transform:scale(1)}75%{opacity:0;transform:scale(2)}to{opacity:0;transform:scale(2)}}@keyframes pulse-green{0%,to{box-shadow:0 8px 16px -4px #10b98166,0 4px 8px -2px #0003,inset 0 2px 4px #fff3,inset 0 -2px 4px #0003}50%{box-shadow:0 12px 24px -4px #10b98199,0 8px 16px -2px #0000004d,inset 0 2px 4px #ffffff4d,inset 0 -2px 4px #0003}}@keyframes fade-amber{0%{opacity:1}to{opacity:.7}}@keyframes spin-slow{to{transform:rotate(1turn)}}.consent-checkbox-container{align-items:center;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;padding:8px 12px;transition:all .2s ease}.consent-checkbox-container:hover{background-color:#f1f3f4;border-color:#dee2e6}.consent-checkbox-label{align-items:center;color:#495057;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;margin:0;-webkit-user-select:none;user-select:none}.consent-checkbox{accent-color:#34c759;cursor:pointer;height:18px;margin:0;width:18px}.consent-checkbox:disabled{cursor:not-allowed;opacity:.6}.consent-checkbox-text{color:#495057;font-size:14px;font-weight:500}.consent-checkbox-label:has(.consent-checkbox:disabled){cursor:not-allowed;opacity:.6}.consent-checkbox-label:has(.consent-checkbox:disabled) .consent-checkbox-text{color:#8e8e93}.consent-checkbox:focus{outline:2px solid #0071e3;outline-offset:2px}.main-session-header .button-container .consent-checkbox-container{margin-right:16px}@media (max-width:768px){.consent-checkbox-container{padding:6px 10px}.consent-checkbox-label{font-size:13px;gap:6px}.consent-checkbox{height:16px;width:16px}.consent-checkbox-text{font-size:13px}}.session-info-display{background:#0000;border:none;box-shadow:none;margin:0;padding:0}.info-layout{align-items:flex-start;display:flex;flex-direction:column;gap:12px}.patient-section{grid-gap:8px;align-items:center;display:grid;gap:8px;grid-template-columns:auto 1fr;margin-bottom:4px;width:67%}.appointment-consent-time-row{align-items:center;display:flex;flex-wrap:nowrap;gap:16px;min-height:32px;width:100%}.appointment-section,.consent-section,.template-section{flex:0 0 auto;min-width:-webkit-fit-content;min-width:fit-content}.consent-section{align-items:center;display:flex}.time-section{align-items:flex-start;display:flex;flex:1 1;min-width:200px}@media (max-width:768px){.appointment-consent-time-row{align-items:flex-start;flex-direction:column;gap:8px}.appointment-section,.consent-section,.template-section,.time-section{flex:none;width:100%}}.gender-badge,.gender-selector{position:relative}.gender-badge{align-items:center;border:none;border-radius:50%;cursor:default;display:flex;font-size:14px;font-weight:600;height:32px;justify-content:center;transition:all .2s ease;width:32px}.gender-badge.clickable{cursor:pointer}.gender-badge.clickable:hover{filter:brightness(.95);transform:translateY(-1px)}.gender-letter{font-family:inherit;line-height:1}.gender-badge .dropdown-arrow{bottom:2px;font-size:8px;position:absolute;right:2px;transition:transform .2s ease}.gender-badge .dropdown-arrow.open{transform:rotate(180deg)}.gender-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #00000026;left:0;margin-top:4px;min-width:140px;overflow:hidden;position:absolute;top:100%;z-index:1000}.gender-option{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:10px 12px;text-align:left;transition:background-color .2s ease;width:100%}.gender-option:hover{background:#f8f9fa}.option-display{font-weight:600;text-align:center;width:20px}.patient-name-editor{align-items:center;display:flex;gap:8px;width:100%}.patient-name-text{color:#1e293b;flex:1 1;font-size:20px;font-weight:600;line-height:1.2;margin:0}.patient-name-text.clickable{border-radius:4px;cursor:pointer;margin:-4px -8px;padding:4px 8px;transition:all .2s ease}.patient-name-text.clickable:hover{background:#3b82f614;color:#1d4ed8}.patient-name-editor.editing{width:100%}.edit-input-container{align-items:center;display:flex;gap:8px;width:100%}.patient-name-input{background:#fff;border:2px solid #3b82f6;border-radius:6px;color:#1e293b;flex:1 1;font-size:20px;font-weight:600;outline:none;padding:8px 12px;transition:border-color .2s ease}.patient-name-input:focus{border-color:#1d4ed8;box-shadow:0 0 0 3px #3b82f61a}.edit-actions{display:flex;gap:4px}.edit-action{background:none;border:none;border-radius:4px;cursor:pointer;padding:6px;transition:all .2s ease}.edit-action.save{color:#059669}.edit-action.save:hover{background:#0596691a}.edit-action.cancel{color:#ef4444}.edit-action.cancel:hover{background:#ef44441a}.appointment-type-selector{position:relative}.appointment-badge{align-items:center;border:none;border-radius:20px;cursor:default;display:inline-flex;font-size:16px;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s ease}.appointment-badge.clickable{cursor:pointer}.appointment-badge.clickable:hover{filter:brightness(.95);transform:translateY(-1px)}.appointment-icon{font-size:12px}.dropdown-arrow{font-size:10px;transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(180deg)}.appointment-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #00000026;left:0;margin-top:4px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.appointment-option{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:10px 12px;text-align:left;transition:background-color .2s ease;width:100%}.appointment-option:hover{background:#f8f9fa}.option-icon{font-size:12px}.option-label{flex:1 1}.selected-indicator{color:inherit;font-weight:600}.template-selector{position:relative}.template-badge{align-items:center;border:none;border-radius:20px;cursor:default;display:inline-flex;font-size:16px;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s ease}.template-badge.clickable{cursor:pointer}.template-badge.clickable:hover{filter:brightness(.95);transform:translateY(-1px)}.template-icon{font-size:12px}.template-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #00000026;left:0;margin-top:4px;min-width:180px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.template-option{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:10px 12px;text-align:left;transition:background-color .2s ease;width:100%}.template-option:hover{background:#f8f9fa}.option-content{display:flex;flex:1 1;flex-direction:column;gap:2px}.option-label{font-weight:500;line-height:1.2}.option-description{color:#6b7280;font-size:12px;line-height:1.2}.session-time-display{display:flex;flex-direction:column;gap:2px;width:100%}.time-status{align-items:center;display:flex;gap:6px;white-space:nowrap}.time-icon{font-size:12px;transition:all .2s ease}.time-icon.recording-pulse{animation:recording-pulse 2s ease-in-out infinite}@keyframes recording-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.time-label{font-size:16px;font-weight:500}.elapsed-time{font-feature-settings:"tnum";color:#1e293b;font-size:16px;font-variant-numeric:tabular-nums;font-weight:600}.time-details{align-items:center;display:flex;gap:4px;margin-left:18px}.time-details,.time-text{font-size:16px;font-weight:700}.time-text{color:#64748b;margin-left:6px}.elapsed-label{color:#64748b;font-size:16px;font-weight:700}.elapsed-label.recording-in-progress{animation:flash-red 1.5s ease-in-out infinite;color:#ef4444;font-weight:700}@keyframes flash-red{0%,to{opacity:1}50%{opacity:.4}}@media (max-width:768px){.info-layout{align-items:flex-start;flex-direction:column;flex-wrap:wrap;gap:12px}.patient-section{max-width:none;min-width:0;min-width:auto;width:80%}.appointment-section,.consent-section,.template-section,.time-section{max-width:none;min-width:0;min-width:auto;width:100%}.patient-name-text{font-size:18px}.patient-name-text.clickable{margin:-6px -10px;padding:6px 10px}.patient-name-input{font-size:18px}.appointment-dropdown{left:0;min-width:200px;right:0}}@media (max-width:480px){.info-layout{gap:8px}.patient-section{width:100%}.patient-name-text{font-size:16px}.patient-name-text.clickable{margin:-8px -12px;padding:8px 12px}.patient-name-input{font-size:16px;padding:6px 10px}.appointment-badge{font-size:13px;padding:4px 10px}.elapsed-time,.time-label{font-size:13px}.time-text{font-size:11px}}.audio-waveform-visualizer{background:#0000;background:var(--background-color,#0000);border-radius:8px;contain:layout style paint;overflow:hidden;position:relative;top:20px}.waveform-canvas{border-radius:inherit;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:optimize-contrast;image-rendering:crisp-edges;pointer-events:none;will-change:auto}.status-display{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif);pointer-events:none;text-shadow:0 1px 3px #0000004d;transition:opacity .7s ease-in-out,transform .3s ease-out;-webkit-user-select:none;user-select:none;z-index:2}.status-display.fade-in{opacity:1;transform:translateY(0)}.status-display.fade-out{opacity:0;transform:translateY(5px)}.status-icon{line-height:1}.status-icon,.status-text{display:inline-block;vertical-align:middle}.status-text{letter-spacing:.025em;line-height:1.2}.error-display{animation:errorPulse 2s infinite;background:#ff44441a;border-radius:6px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif);padding:12px 16px;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:3}@keyframes errorPulse{0%,to{opacity:1}50%{opacity:.7}}@media (max-width:768px){.status-display{font-size:.9rem}.status-icon{font-size:1.1em;margin-right:4px}.error-display{font-size:.8rem;padding:8px 12px}}@media (prefers-contrast:high){.audio-waveform-visualizer{border:2px solid}.status-display{background:#fff;background:var(--background-color,#fff);border-radius:4px;padding:4px 8px;text-shadow:none}.error-display{background:#ffebee;background:var(--error-background,#ffebee);border:2px solid #f44336;border:2px solid var(--error-border,#f44336)}}@media (prefers-reduced-motion:reduce){.status-display{transform:none!important;transition:opacity .2s ease-in-out}.status-display.fade-in,.status-display.fade-out{transform:none}.error-display{animation:none}}@media (prefers-color-scheme:dark){.audio-waveform-visualizer{background:#ffffff0d;background:var(--dark-background-color,#ffffff0d)}.status-display{text-shadow:0 1px 3px #000c}.error-display{background:#f443;border-color:#ff444480;color:#ffcdd2}}.audio-waveform-visualizer:focus-within{outline:2px solid #007acc;outline:2px solid var(--focus-color,#007acc);outline-offset:2px}.audio-waveform-visualizer.loading{background:#0000000d;background:var(--loading-background,#0000000d)}.audio-waveform-visualizer.loading:before{animation:spin 1s linear infinite;border:2px solid #ccc;border-top-color:#007acc;border:2px solid var(--loading-color,#ccc);border-radius:50%;border-top-color:var(--loading-active-color,#007acc);content:"";height:20px;left:50%;margin:-10px 0 0 -10px;position:absolute;top:50%;width:20px}.audio-waveform-visualizer.compact{border-radius:4px}.audio-waveform-visualizer.compact .status-display{font-size:.85rem}.audio-waveform-visualizer.large .status-display{font-size:1.1rem}.audio-waveform-visualizer.large .status-icon{font-size:1.3em}.audio-waveform-bridge{animation:slideInFromTop .4s ease-out;background:linear-gradient(135deg,#007bff08,#007bff03);border-radius:12px;box-sizing:border-box;padding:6px 12px;position:absolute;right:500px;top:25px;transition:all .3s cubic-bezier(.4,0,.2,1);width:300px;z-index:10}.audio-waveform-bridge:hover{background:linear-gradient(135deg,#007bff0d,#007bff05);border-color:#007bff1f;box-shadow:0 2px 8px #007bff14}.session-header-audio-visualizer{--background-color:#0000;--font-family:inherit;--focus-color:#007bff;--border-color:#007bff1a;height:44px!important;width:100%}.session-header-audio-visualizer canvas{height:100%!important}@keyframes slideInFromTop{0%{max-height:0;opacity:0;transform:translateY(-20px)}to{max-height:60px;opacity:1;transform:translateY(0)}}@media (max-width:768px){.audio-waveform-bridge{border-radius:8px;margin:8px 0 12px;padding:8px 12px}.session-header-audio-visualizer{height:40px!important}.session-header-audio-visualizer canvas{height:100%!important}}@media (prefers-contrast:high){.audio-waveform-bridge{background:#007bff1a;border:2px solid #007bff}.audio-waveform-bridge:hover{background:#007bff26}}@media (prefers-reduced-motion:reduce){.audio-waveform-bridge{animation:none;transition:opacity .2s ease}@keyframes slideInFromTop{0%{opacity:0}to{opacity:1}}}@media (prefers-color-scheme:dark){.audio-waveform-bridge{background:linear-gradient(135deg,#ffffff08,#ffffff03);border-color:#ffffff14}.audio-waveform-bridge:hover{background:linear-gradient(135deg,#ffffff0d,#ffffff05);border-color:#ffffff1f;box-shadow:0 2px 8px #ffffff14}}.main-session-frame{border-radius:8px;box-shadow:0 2px 4px #0000001a;box-sizing:border-box;gap:5px;height:calc(100vh - 140px);overflow:hidden;padding-left:30px;width:100%}.main-session-frame,.session-content-container{background-color:#fff;display:flex;flex-direction:column;position:relative}.session-content-container{flex:1 1;min-height:0;padding:0}.tab-labels{background-color:#f5f5f7;border-bottom:1px solid #ddd;min-height:42px;padding:10px 15px}.tab-label,.tab-labels{align-items:center;display:flex;position:relative}.tab-label{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-weight:500;gap:6px;margin-right:10px;padding:8px 16px;transition:all .2s ease}.tab-icon{height:16px;opacity:.7;transition:opacity .2s ease;width:16px}.tab-label.active .tab-icon,.tab-label:hover .tab-icon{opacity:1}.tab-label:not(:last-child):after{background-color:#999;content:"";height:20px;position:absolute;right:-5px;top:50%;transform:translateY(-50%);width:1px}.tab-label:hover{color:#333}.tab-label[data-tab=soap]:hover{background-color:#ebf1ff;background-color:color-mix(in oklch,oklch(.97 .02 260) 92%,#fff)}.tab-label[data-tab=transcript]:hover{background-color:#f1f7ed;background-color:color-mix(in oklch,oklch(.96 .02 100) 92%,#fff)}.tab-label[data-tab=additionalNotes]:hover{background-color:#fbfbef;background-color:color-mix(in oklch,oklch(.97 .015 60) 92%,#fff)}.tab-label.active{background-color:initial;border-bottom:3px solid #2196f3;border-bottom:3px solid var(--active-tab-color,#2196f3);color:#2196f3;color:var(--active-tab-color,#2196f3);font-weight:600}.tab-labels[data-active-tab=soap]{--toolbar-bg:#f0f5ff;--tab-active-bg:#e6eeff;--active-tab-color:#2e5cb8;--toolbar-fg:oklch(0.25 0.03 260);--tab-inactive-bg:oklch(0.95 0.015 260)}@supports (color:oklch(0% 0 0)){.tab-labels[data-active-tab=soap]{--toolbar-bg:oklch(0.97 0.02 260)}}@supports (color:color-mix(in oklch,#000,#fff)){.tab-labels[data-active-tab=soap]{--tab-active-bg:color-mix(in oklch,var(--toolbar-bg) 85%,#fff)}}@supports (color:oklch(0% 0 0)){.tab-labels[data-active-tab=soap]{--active-tab-color:oklch(0.45 0.12 260)}}.tab-labels[data-active-tab=transcript]{--toolbar-bg:#f3f9f1;--tab-active-bg:#eef6ea;--active-tab-color:#60ac39;--toolbar-fg:oklch(0.25 0.03 100);--tab-inactive-bg:oklch(0.94 0.015 100)}@supports (color:oklch(0% 0 0)){.tab-labels[data-active-tab=transcript]{--toolbar-bg:oklch(0.96 0.02 100)}}@supports (color:color-mix(in oklch,#000,#fff)){.tab-labels[data-active-tab=transcript]{--tab-active-bg:color-mix(in oklch,var(--toolbar-bg) 85%,#fff)}}@supports (color:oklch(0% 0 0)){.tab-labels[data-active-tab=transcript]{--active-tab-color:oklch(0.45 0.12 100)}}.tab-labels[data-active-tab=additionalNotes]{--toolbar-bg:#fcfcf3;--tab-active-bg:#fafaeb;--active-tab-color:#c3c322;--toolbar-fg:oklch(0.25 0.03 60);--tab-inactive-bg:oklch(0.95 0.01 60)}@supports (color:oklch(0% 0 0)){.tab-labels[data-active-tab=additionalNotes]{--toolbar-bg:oklch(0.97 0.015 60)}}@supports (color:color-mix(in oklch,#000,#fff)){.tab-labels[data-active-tab=additionalNotes]{--tab-active-bg:color-mix(in oklch,var(--toolbar-bg) 85%,#fff)}}@supports (color:oklch(0% 0 0)){.tab-labels[data-active-tab=additionalNotes]{--active-tab-color:oklch(0.45 0.14 60)}}.tab-content{display:flex;flex:1 1;flex-direction:column;min-height:0}.additional-notes-container,.soap-session-frame-container,.transcript-container{background-color:#fff;display:flex;flex:1 1;flex-direction:column;min-height:0;padding:0;position:relative}.additional-notes-session-quill-container,.quill-editor-container,.transcript-session-quill-container{border:none;display:flex;flex:1 1;flex-direction:column;min-height:0}.additional-notes-session-quill-container .ql-toolbar,.quill-editor-container .ql-toolbar,.transcript-session-quill-container .ql-toolbar{align-items:center;background-color:#f5f5f7;border:none;border-bottom:1px solid #ddd;display:flex;flex-shrink:0;min-height:42px;padding-right:140px;position:relative}.session-quill-editor,.session-quill-editor .ql-container{border:none;display:flex;flex:1 1;flex-direction:column;min-height:0}.session-quill-editor .ql-container{font-size:14px}.session-quill-editor .ql-editor{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:15px}.ql-action-buttons-container{align-items:center;display:flex;gap:8px;height:28px;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.ql-copy-container{display:inline-block;position:relative}.ql-action{align-items:center!important;background-color:#eee!important;border:none!important;border-radius:4px!important;color:inherit!important;cursor:pointer!important;display:flex!important;font-size:.9em!important;height:auto!important;justify-content:center!important;margin:0 2px!important;min-height:28px!important;min-width:28px!important;opacity:1!important;padding:5px 10px!important;pointer-events:auto!important;transition:all .2s ease!important;width:auto!important}.ql-action:hover{background-color:#ddd!important}.ql-action:active{background-color:#ccc!important}.ql-action svg{height:16px;width:16px}.ql-action i,.ql-action svg{margin-right:4px}.readonly-mode .ql-toolbar .ql-formats button:not(.ql-action){cursor:default!important;opacity:.5!important;pointer-events:none!important}.readonly-mode .ql-editor{background-color:#f9f9f9}.notification{background-color:#4caf50;box-shadow:0 2px 10px #0000001a;padding:10px 15px;top:10px}.additional-notes-session-frame,.transcript-session-frame{background-color:#fff;display:flex;flex:1 1;flex-direction:column;min-height:0;padding:0;position:relative}.additional-notes-session-frame .additional-notes-session-quill-container,.transcript-session-frame .transcript-session-quill-container{display:flex;flex:1 1;flex-direction:column;min-height:0}.soap-session-frame{background-color:#fff;flex:1 1;min-height:0;padding:0;position:relative}.soap-editing-container{display:flex;flex:1 1;flex-direction:column;min-height:0}@media (max-width:768px){.tab-labels{flex-wrap:wrap;padding:8px 10px}.tab-label{margin-bottom:4px;margin-right:8px;padding:6px 12px}.ql-action-buttons-container{gap:4px;right:5px}.ql-action{height:24px!important;padding:2px 4px!important;width:24px!important}.ql-action svg{height:14px;width:14px}}.soap-session-frame{border:1px solid #ccc;border-radius:4px;display:flex;flex-direction:column;height:100%;width:100%}.quill-editor-container,.soap-edit-container{display:flex;flex:1 1;flex-direction:column;min-height:0}.soap-edit-container .tiptap-container{border:none;border-radius:0;flex:1 1;min-height:0}.ql-editor ul{list-style:none!important;margin:.5em 0!important;padding-left:0!important}.ql-editor li{display:list-item!important;list-style:none!important;margin-bottom:.3em!important;padding-left:1.4em!important;position:relative!important}.ql-editor li:before{content:"\2022";font-size:.85em;left:.1em;line-height:1;position:absolute;top:.2em}.ql-editor .ql-indent-1{padding-left:2.2em!important}.ql-editor .ql-indent-1:before{content:"\25E6";left:1.1em}.ql-editor .ql-indent-2{padding-left:3.1em!important}.ql-editor .ql-indent-2:before{content:"\25AA";left:2em}.ql-editor .ql-indent-3{padding-left:2em!important}.ql-editor .ql-indent-3:before{content:"\2013";left:2.7em}.ql-editor li>ul,.ql-editor ul ul{display:block!important;list-style-type:none!important;margin:0!important;padding-left:0!important}.ql-editor li p{display:inline!important;margin:0!important}.ql-editor p:has(strong:only-child){margin-bottom:.1em!important}.ql-editor p:has(strong:only-child)+ul{margin-top:.1em!important}.tiptap-container{background:#fff;border:1px solid #e1e5e9;border-radius:4px;display:flex;flex:1 1;flex-direction:column;min-height:0;position:relative;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease}.tiptap-container:focus-within{background:#fafbff;border-color:#4285f4;box-shadow:0 0 0 2px #4285f41a}.tiptap-editor-container{display:flex;flex-direction:column;min-height:0}.tiptap-toolbar{align-items:center;background:#f7f7f9;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;gap:8px;min-height:42px;padding:8px 12px;position:relative;-webkit-user-select:none;user-select:none}.soap-editor .tiptap-toolbar{background:#f0f8ff;border-color:#b3d9ff}.transcript-editor .tiptap-toolbar{background:#f8f8f0;border-color:#d9d9b3}.notes-editor .tiptap-toolbar{background:#fff8f0;border-color:#ffd9b3}.soap-editor .tiptap-container:focus-within{background:#f8fbff;border-color:#2196f3;box-shadow:0 0 0 2px #2196f31f}.transcript-editor .tiptap-container:focus-within{background:#fefffe;border-color:#8bc34a;box-shadow:0 0 0 2px #8bc34a1f}.notes-editor .tiptap-container:focus-within{background:#fffcf8;border-color:#ff9800;box-shadow:0 0 0 2px #ff98001f}.tt-group{align-items:center;border-right:1px solid #e6e6ea;display:inline-flex;gap:4px;margin-right:6px;padding-right:6px}.tt-group:last-of-type{border-right:0;margin-right:0;padding-right:0}.tt-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:6px;color:#6b7280;cursor:pointer;display:inline-flex;height:32px;justify-content:center;transition:background .15s ease,color .15s ease,box-shadow .15s ease;width:32px}.tt-btn:hover{background:#0000000a;color:#374151}.tt-btn.is-active{background:#0000000f;color:#111827}.tt-btn:disabled{cursor:not-allowed;opacity:.4}.tt-btn.ghost{background:#fff;border-color:#d1d5db}.tt-btn.ghost:hover{background:#fff;box-shadow:inset 0 0 0 2px #0000000a}.tt-btn.dictation-active{background:#dc2626!important;color:#fff!important}.tt-btn.dictation-active:hover{background:#b91c1c!important}.tt-btn.dictation-error{background:#f59e0b!important;color:#fff!important}.tt-btn.dictation-button{min-width:32px;padding:0 12px!important;white-space:nowrap;width:auto!important}.tt-btn.dictation-button i{margin-right:6px}.tt-btn.dictation-button.icon-only i{margin-right:0}.tt-btn.dictation-processing{background:#3b82f6!important;color:#fff!important;cursor:not-allowed!important}.tt-btn.dictation-processing:hover{background:#2563eb!important}.tt-btn.dictation-processing i{animation:spin 1s linear infinite}.tt-btn.dictation-active.has-pending{animation:recordingPulse 2s ease-in-out infinite}@keyframes recordingPulse{0%,to{box-shadow:0 0 0 0 #dc262666}50%{box-shadow:0 0 0 8px #dc262600}}.tt-select{align-items:center;display:inline-flex;height:32px;position:relative}.tt-select select{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;font-size:14px;height:32px;line-height:20px;padding:4px 28px 4px 10px}.tt-select .tt-caret{color:#6b7280;font-size:12px;pointer-events:none;position:absolute;right:8px}.tt-color{align-items:center;display:inline-flex;height:32px;justify-content:center;position:relative;width:32px}.tt-color input[type=color]{cursor:pointer;inset:0;opacity:0;position:absolute}.tt-color-dot{background:currentColor;border:2px solid #d1d5db;border-radius:999px;height:14px;width:14px}.toolbar-buttons{display:flex;flex-wrap:wrap;gap:4px}.tiptap-toolbar button:not(.tt-btn){background:#fff;border:1px solid #ddd;border-radius:3px;color:#333;cursor:pointer;font-size:12px;padding:6px 12px;transition:all .2s}.tiptap-toolbar button:not(.tt-btn):hover{background:#f0f0f0;border-color:#ccc}.tiptap-toolbar button:not(.tt-btn).is-active{background:#007bff;border-color:#007bff;color:#fff}.tiptap-toolbar button:not(.tt-btn):disabled{cursor:not-allowed;opacity:.5;pointer-events:none}.action-buttons{align-items:center;gap:8px;position:absolute;right:10px;top:50%;transform:translateY(-50%);z-index:10}.action-buttons button{background:#eee;border:1px solid #ddd;border-radius:2px;cursor:pointer;font-size:11px;padding:4px 8px;transition:all .2s ease}.action-buttons button:hover{background:#ddd;border-color:#ccc}.action-buttons button:active{background:#ccc}.tiptap-editor-wrapper{background:#fafafa;display:block;flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;scrollbar-color:#999 #eee;scrollbar-gutter:stable both-edges;scrollbar-width:thin;transition:background-color .2s ease}.tiptap-container:focus-within .tiptap-editor-wrapper{background:#fafbff}.soap-editor .tiptap-container:focus-within .tiptap-editor-wrapper{background:#f8fbff}.transcript-editor .tiptap-container:focus-within .tiptap-editor-wrapper{background:#fefffe}.notes-editor .tiptap-container:focus-within .tiptap-editor-wrapper{background:#fffcf8}.tiptap-editor-wrapper::-webkit-scrollbar{width:12px}.tiptap-editor-wrapper::-webkit-scrollbar-thumb{background:#00000059;border-radius:8px}.tiptap-editor-wrapper::-webkit-scrollbar-track{background:#00000014}.editor-content{display:block;min-height:0;overflow:visible}.ProseMirror{min-height:200px;outline:none}.ProseMirror p{margin:0 0 8px}.ProseMirror p:last-child{margin-bottom:0}.ProseMirror h1{font-size:1.5em;font-weight:700;margin:16px 0 8px}.ProseMirror h2{font-size:1.3em;font-weight:700;margin:14px 0 8px}.ProseMirror h3{font-size:1.1em;font-weight:700;margin:12px 0 8px}.ProseMirror ol,.ProseMirror ul{margin:8px 0;padding-left:24px}.ProseMirror li{margin:4px 0}.ProseMirror strong{font-weight:700}.ProseMirror em{font-style:italic}.ProseMirror u{text-decoration:underline}.tiptap-editor{font-family:inherit;font-size:14px;line-height:1.5;outline:none;padding:12px}.tiptap-editor:empty:before{color:#999;content:attr(placeholder);pointer-events:none;position:absolute}.editor-content [data-indent="1"]{padding-left:1.25rem}.editor-content [data-indent="2"]{padding-left:2.5rem}.editor-content [data-indent="3"]{padding-left:3.75rem}.editor-content [data-indent="4"]{padding-left:5rem}.editor-content [data-indent="5"]{padding-left:6.25rem}.editor-content [data-indent="6"]{padding-left:7.5rem}.editor-content [data-indent="7"]{padding-left:8.75rem}.notification{animation:slideDown .3s ease;background:#28a745;border-radius:4px;font-size:12px;padding:8px 12px;position:absolute;right:10px;top:-40px}@media (max-width:768px){.tiptap-toolbar{flex-wrap:wrap;padding:6px 8px}.toolbar-buttons{gap:2px}.tiptap-toolbar button:not(.tt-btn){font-size:11px;padding:4px 8px}.action-buttons{justify-content:flex-end;margin-top:4px;position:static;transform:none}.action-buttons button{font-size:10px;min-width:60px;padding:6px 8px}}.additional-notes-session-frame{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;display:flex;flex-direction:column;height:100%;padding:0}.additional-notes-session-tiptap-container{display:flex;flex:1 1;flex-direction:column;min-height:0}.additional-notes-session-frame .tiptap-container{border:none;border-radius:0;flex:1 1;min-height:0}.additional-notes-textarea{background:#fff;border:1px solid #e1e5e9;border-radius:4px;box-sizing:border-box;height:100%;overflow-y:auto;padding:5px;resize:none;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease;width:100%}.additional-notes-textarea:focus{background:#fffcf8;border-color:#ff9800;box-shadow:0 0 0 2px #ff98001f;outline:none}.dictation-controls{align-items:center;background-color:#f8fafc;border-bottom:1px solid #e1e5e9;display:flex;gap:12px;padding:12px 16px}.dictation-button{align-items:center;background-color:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s ease}.dictation-button:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.dictation-button:disabled{cursor:not-allowed;opacity:.6}.dictation-button--active{background-color:#ef4444;border-color:#dc2626;color:#fff}.dictation-button--active:hover:not(:disabled){background-color:#dc2626;border-color:#b91c1c}.dictation-button--error{background-color:#fef2f2;border-color:#fecaca;color:#dc2626}.dictation-error{color:#dc2626;font-size:12px;font-weight:500}.dictation-button svg{height:16px;width:16px}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.editor-status{background-color:#f8fafc;border-top:1px solid #e1e5e9;min-height:32px;padding:8px 16px}.dictation-status,.editor-status{align-items:center;display:flex;font-size:14px}.dictation-status{font-weight:500}.dictation-status.recording{color:#dc2626}.dictation-status.recording-transcribing{color:#7c3aed}.dictation-status.transcribing{color:#0891b2}.dictation-status.processing{color:#059669}.typing-status{color:#3b82f6}.saving-status,.typing-status{font-size:14px;font-weight:500}.saving-status{color:#059669}.status-separator{color:#6b7280;display:inline-block;margin:0 .25rem}.editor-content,.tiptap-editor-wrapper{position:relative}.dictation-beacon{pointer-events:none;position:absolute;transform:translate(-50%,-8px);z-index:999}.dictation-beacon .halo{background:radial-gradient(closest-side,#ef4444b3,#ef444400 70%);border-radius:999px;height:26px;left:0;opacity:0;position:absolute;top:0;transform:scale(.8);width:26px}.dictation-beacon .caret-dot{background:#dc2626;border-radius:999px;box-shadow:0 2px 6px #00000038;height:10px;left:8px;opacity:1;position:absolute;top:8px;width:10px}.dictation-beacon .label{background:#111827;border-radius:10px;box-shadow:0 10px 30px #0000002e;color:#fff;font-size:12px;left:18px;opacity:0;padding:6px 8px;position:absolute;top:-8px;transform:translateY(-8px);white-space:nowrap}.dictation-beacon .underline{background:linear-gradient(90deg,#ef444400,#ef4444cc,#ef444400);background-size:200% 100%;height:2px;left:0;opacity:0;position:absolute;top:22px;width:64px}@keyframes dictation-halo-pulse{0%{opacity:0;transform:scale(.8)}15%{opacity:.9;transform:scale(1)}60%{opacity:.25;transform:scale(1.25)}to{opacity:0;transform:scale(1.35)}}@keyframes dictation-label-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes dictation-label-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}@keyframes dictation-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.dictation-beacon.pulse .halo{animation:dictation-halo-pulse .9s ease-out forwards}.dictation-beacon.show-label .label{animation:dictation-label-in .16s ease-out forwards}.dictation-beacon.hide-label .label{animation:dictation-label-out .18s ease-in forwards}.dictation-beacon .underline.shimmer,.dictation-beacon.shimmer .underline{animation:dictation-shimmer .9s linear infinite;opacity:.8}@media (prefers-reduced-motion:reduce){.dictation-beacon .halo,.dictation-beacon .label,.dictation-beacon .underline{animation:none!important;transition:none!important}.dictation-beacon .halo{opacity:.35;transform:none}.dictation-beacon .label{opacity:1;transform:none}}.dictation-beacon.theme-medical .caret-dot{background:#0369a1}.dictation-beacon.theme-medical .halo{background:radial-gradient(closest-side,#0369a1b3,#0369a100 70%)}.dictation-beacon.theme-medical .underline{background:linear-gradient(90deg,#0369a100,#0369a1,#0369a100);background-size:200% 100%}.transcript-session-frame{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;display:flex;flex-direction:column;height:100%;padding:0}.transcript-session-tiptap-container{display:flex;flex:1 1;flex-direction:column;min-height:0}.transcript-session-frame .tiptap-container{border:none;border-radius:0;flex:1 1;min-height:0}.transcript-textarea{background:#fff;border:1px solid #e1e5e9;border-radius:4px;box-sizing:border-box;height:100%;overflow-y:auto;padding:5px;resize:none;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease;width:100%}.transcript-textarea:focus{background:#fefffe;border-color:#8bc34a;box-shadow:0 0 0 2px #8bc34a1f;outline:none}.transcript-header{color:#666;display:flex;font-size:.85rem;justify-content:space-between;margin-bottom:8px}.transcript-count{font-weight:700}.transcript-instructions{font-style:italic}.microphone-selector-container{display:inline-block;position:relative}.microphone-settings-button{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:36px;justify-content:center;margin-right:10px;overflow:visible;padding:8px;position:relative;transition:transform .2s ease-in-out,color .2s ease-in-out;width:36px}.microphone-settings-button:hover{transform:scale(1.5)}.microphone-settings-button:active{transform:scale(.95)}.microphone-settings-button:disabled{background-color:initial;box-shadow:none;color:#ccc;cursor:not-allowed;opacity:.6;transform:none}.session-transition .microphone-selector-hybrid,.session-transition .microphone-settings-button{transition:none!important}.microphone-settings-button.loading{cursor:wait}.microphone-settings-button.enum-failed,.microphone-settings-button.no-devices,.microphone-settings-button.permission-denied{cursor:pointer}.mic-icon{font-size:18px}.mic-dropdown-icon,.mic-icon{color:#333;transition:color .3s ease}.mic-dropdown-icon{font-size:10px;margin-left:2px}.mic-icon.active{color:#4caf50}.microphone-settings-button .mic-dropdown-icon{color:inherit}.mic-icon.denied{color:#f44336}.mic-icon.error{color:#ff9800}.mic-icon.warning{color:#ffeb3b}.mic-loading-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}@keyframes wave-ring{0%{opacity:.8;opacity:var(--wave-opacity,.8);transform:scale(1)}to{opacity:0;transform:scale(10)}}.mic-button-wrapper{align-items:flex-start;display:flex;flex-direction:column;gap:4px;position:relative;width:auto}.mic-name-above{color:#007bff;font-size:12px;left:50%;min-height:16px;padding:0 4px;position:absolute;text-align:center;top:-20px;transform:translateX(-50%);white-space:nowrap;z-index:1}.microphone-settings-button.recording{--wave-duration:1.5s;--wave-opacity:0.8;--wave-display:none;position:relative}.microphone-settings-button.recording.animation-disabled{--wave-display:none!important}.microphone-settings-button.recording.animation-disabled:after,.microphone-settings-button.recording.animation-disabled:before{display:none!important}.microphone-settings-button.recording:before{animation:wave-ring var(--wave-duration) infinite}.microphone-settings-button.recording:after,.microphone-settings-button.recording:before{border:2px solid #4caf50;border-radius:50%;content:"";display:none;display:var(--wave-display,none);height:18px;left:50%;margin-left:-9px;margin-top:-9px;pointer-events:none;position:absolute;top:50%;transform-origin:center center;width:18px;z-index:-1}.microphone-settings-button.recording:after{animation:wave-ring var(--wave-duration) infinite calc(var(--wave-duration)/3)}.microphone-settings-button.recording .mic-icon{color:#4caf50;transition:color .3s ease}.microphone-settings-button.mic-active .mic-icon{color:#0f8;filter:drop-shadow(0 0 8px rgba(0,255,136,.6))}.microphone-selector-hybrid{align-items:center;background:#fffffff2;border:1px solid #007bff33;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;gap:8px;padding:8px 12px;position:relative;transition:background .2s ease-in-out,border-color .2s ease-in-out,transform .2s ease-in-out,box-shadow .2s ease-in-out;white-space:nowrap}.microphone-selector-hybrid:hover:not(:disabled){background:#007bff0d;border-color:#007bff4d;box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.microphone-selector-hybrid:disabled{background:#f0f0f0f2;border-color:#c8c8c880;box-shadow:none;color:#999;cursor:not-allowed;transform:none}.mic-selector-label{color:#333;font-weight:500;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.microphone-selector-hybrid .mic-dropdown-icon{color:#666;font-size:10px;margin-left:auto}.activity-indicator{animation:pulse 1.5s ease-in-out infinite;background:#0f8;border-radius:50%;box-shadow:0 0 8px #0f89;height:6px;width:6px}.recording-indicator-icon{animation:pulse 1s ease-in-out infinite;color:#ff375f;font-size:14px}.microphone-selector-hybrid.mic-active{border-color:#0f86;box-shadow:0 2px 4px #0f83}.microphone-selector-hybrid.mic-active .mic-selector-label{color:#0a6}.microphone-selector-hybrid.recording{background:#ff375f05;border-color:#ff375f66}.microphone-selector-hybrid.recording .mic-selector-label{color:#ff375f}@media (max-width:768px){.microphone-selector-hybrid{font-size:12px;gap:6px;padding:6px 10px}.mic-device-name{max-width:80px}}.microphone-dropdown-menu{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #007bff33;border-radius:8px;box-shadow:0 8px 32px #007bff26;color:#333;max-width:none;min-width:300px;overflow:hidden;width:-webkit-max-content;width:max-content;z-index:10000}.dropdown-header{align-items:center;background:#007bff0d;border-bottom:1px solid #007bff1a;color:#333;display:flex;font-size:14px;font-weight:600;justify-content:space-between;padding:12px 16px}.refresh-button{background:none;border:none;border-radius:4px;color:#333333b3;cursor:pointer;padding:4px;transition:all .2s ease}.refresh-button:hover{background:#007bff1a;color:#007bff}.dropdown-content{max-height:300px;overflow-x:hidden;overflow-y:auto}.dropdown-item{align-items:center;color:#333;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:all .2s ease}.dropdown-item:hover{background:#007bff1a}.dropdown-item.selected{background:#007bff26;color:#007bff}.dropdown-item.disabled{color:#33333380;cursor:not-allowed;opacity:.6}.device-icon{color:#333333b3;flex-shrink:0;font-size:14px}.device-label{flex:1 1 auto;font-size:14px;min-width:0;white-space:nowrap}.selected-indicator{color:#007bff;flex-shrink:0;font-weight:700}.no-devices-text{color:#33333380;font-style:italic}.device-type-indicator{color:#3339;font-size:12px;font-weight:400;margin-left:4px}.dropdown-item.device-type-external .device-icon{color:#28a745}.dropdown-item.device-type-built-in .device-icon{color:#6c757d}.dropdown-item.device-type-unknown .device-icon{color:#33333380}@media (max-width:768px){.microphone-dropdown-menu{max-width:none;min-width:200px;width:-webkit-max-content;width:max-content}.dropdown-item{padding:10px 12px}.device-label{font-size:13px}}.hotkey-settings{background:#fff;border:1px solid #e2e8f0;border-radius:8px;max-width:600px;padding:16px}.hotkey-settings__title{color:#1e293b;font-size:18px;font-weight:600;margin:0 0 16px}.hotkey-settings__section{display:flex;flex-direction:column;gap:16px}.hotkey-settings__current{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.hotkey-settings__current label{color:#374151;font-weight:500}.hotkey-settings__kbd{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:4px;color:#475569;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;padding:4px 8px;white-space:nowrap}.hotkey-settings__conflicts{color:#dc2626;font-size:14px;font-weight:500}.hotkey-settings__picker{display:flex;flex-wrap:wrap;gap:8px}.hotkey-settings__button{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;padding:8px 12px;transition:all .2s ease}.hotkey-settings__button:hover{background:#f9fafb;border-color:#9ca3af}.hotkey-settings__button:active{background:#f3f4f6}.hotkey-settings__button--capturing{background:#3b82f6;border-color:#2563eb;color:#fff}.hotkey-settings__button--capturing:hover{background:#2563eb}.hotkey-settings__button--danger{background:#fee2e2;border-color:#fecaca;color:#991b1b}.hotkey-settings__button--danger:hover{background:#fecaca}.hotkey-settings__options{background:#f8fafc;border-radius:6px;display:flex;flex-direction:column;gap:12px;padding:16px}.hotkey-settings__input-group{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.hotkey-settings__input-group label{color:#374151;font-weight:500;min-width:160px}.hotkey-settings__input,.hotkey-settings__select{background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;font-size:14px;padding:6px 8px}.hotkey-settings__input:focus,.hotkey-settings__select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.hotkey-settings__context-options{background:#fffbeb;border:1px solid #fed7aa;border-radius:6px;padding:12px}.hotkey-settings__checkbox{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:14px;gap:8px}.hotkey-settings__checkbox input[type=checkbox]{accent-color:#3b82f6;height:16px;width:16px}.hotkey-list{background:#fff;border:1px solid #e2e8f0;border-radius:8px;max-width:600px;padding:16px}.hotkey-list__title{color:#1e293b;font-size:18px;font-weight:600;margin:0 0 16px}.hotkey-list__empty{color:#6b7280;font-style:italic;padding:20px;text-align:center}.hotkey-list__items{display:flex;flex-direction:column;gap:8px}.hotkey-list__item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:12px;padding:8px 12px}.hotkey-list__item-name{color:#374151;flex:1 1;font-weight:500}.hotkey-list__item-shortcut{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:4px;color:#475569;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:11px;padding:2px 6px}.hotkey-list__item-status{color:#6b7280;font-size:12px}@media (max-width:768px){.hotkey-settings__current{align-items:flex-start;flex-direction:column}.hotkey-settings__picker{flex-direction:column}.hotkey-settings__button{text-align:center;width:100%}.hotkey-settings__input-group{align-items:flex-start;flex-direction:column}.hotkey-settings__input-group label{min-width:0;min-width:auto}.hotkey-list__item{align-items:flex-start;flex-direction:column;gap:6px}}.recording-hotkey{position:relative;z-index:1000}.recording-hotkey__error{animation:slideInRight .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fef2f2f2;border:1px solid #fecaca;border-radius:12px;box-shadow:0 10px 25px #0000001a;max-width:400px;position:fixed;right:20px;top:20px;z-index:9999}.recording-hotkey__error-content{align-items:flex-start;display:flex;gap:8px;padding:12px 16px}.recording-hotkey__error-icon{flex-shrink:0;font-size:16px;margin-top:2px}.recording-hotkey__error-text{color:#991b1b;flex:1 1;font-size:14px;line-height:1.4}.recording-hotkey__error-dismiss{background:none;border:none;color:#991b1b;cursor:pointer;flex-shrink:0;font-size:18px;line-height:1;margin:0;opacity:.7;padding:0;transition:opacity .2s ease}.recording-hotkey__error-dismiss:hover{opacity:1}.recording-hotkey__debug{background:#000c;border-radius:6px;bottom:20px;color:#fff;font-family:Monaco,Consolas,monospace;font-size:11px;left:20px;line-height:1.3;padding:8px 12px;position:fixed;z-index:9999}.recording-hotkey-settings{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000000a;padding:24px}.recording-hotkey-settings__title{border-bottom:1px solid #e5e7eb;color:#111827;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.recording-hotkey-settings__section{display:flex;flex-direction:column;gap:16px}.recording-hotkey-settings__current{align-items:center;color:#374151;display:flex;font-size:14px;gap:12px}.recording-hotkey-settings__current label{font-weight:500;margin:0}.recording-hotkey-settings__kbd{background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 1px 2px #0000000d;color:#374151;font-family:Monaco,Consolas,monospace;font-size:12px;padding:4px 8px}.recording-hotkey-settings__picker{display:flex;flex-wrap:wrap;gap:8px}.recording-hotkey-settings__button{background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 1px 2px #0000000d;color:#374151;cursor:pointer;font-size:13px;padding:8px 16px;transition:all .2s ease}.recording-hotkey-settings__button:hover{background:#f9fafb;border-color:#9ca3af}.recording-hotkey-settings__button--capturing{background:#dbeafe;border-color:#60a5fa;color:#1d4ed8}.recording-hotkey-settings__options{display:flex;flex-direction:column;gap:12px;padding-top:8px}.recording-hotkey-settings__input-group{display:flex;flex-direction:column;gap:4px}.recording-hotkey-settings__input-group label{color:#374151;font-size:14px;font-weight:500}.recording-hotkey-settings__input,.recording-hotkey-settings__select{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;font-size:14px;padding:8px 12px;transition:border-color .2s ease}.recording-hotkey-settings__input:focus,.recording-hotkey-settings__select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.recording-hotkey-settings__input:hover,.recording-hotkey-settings__select:hover{border-color:#9ca3af}.recording-hotkey-settings__checkbox{align-items:flex-start;color:#374151;cursor:pointer;display:flex;font-size:14px;gap:8px;margin:0}.recording-hotkey-settings__checkbox input[type=checkbox]{accent-color:#3b82f6;height:16px;margin:2px 0 0;width:16px}.recording-hotkey-settings__checkbox span{line-height:1.5}.recording-hotkey-settings__info{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;margin-top:20px;padding:16px}.recording-hotkey-settings__info p{color:#1e40af;font-size:13px;line-height:1.5;margin:0}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}@media (max-width:640px){.recording-hotkey__error{left:10px;max-width:none;right:10px;top:10px}.recording-hotkey-settings{padding:16px}.recording-hotkey-settings__picker{flex-direction:column}.recording-hotkey-settings__button{justify-content:center;width:100%}}@media (prefers-contrast:high){.recording-hotkey__error{background:#fff;border:2px solid #000}.recording-hotkey__error-text{color:#000}.recording-hotkey-settings__kbd{background:#fff;border:2px solid #000;color:#000}}@media (prefers-reduced-motion:reduce){.recording-hotkey__error{animation:none}.recording-hotkey-settings__button{transition:none}}.askphysi-panel.minimized{background:linear-gradient(180deg,#f8fafc,#f1f5f9)}.ap-header{background:linear-gradient(180deg,#fff,#f9fafb);border-bottom:1px solid #e5e7eb;justify-content:space-between;min-height:48px;padding:12px 16px}.ap-brand,.ap-header{align-items:center;display:flex}.ap-brand{color:#1f2937;font-size:16px;font-weight:600;gap:8px}.ap-logo{color:#3b82f6;flex-shrink:0}.ap-logo.breathing svg{animation:bot-breathing 2s ease-in-out infinite;display:block;transform-origin:center}@keyframes bot-breathing{0%,to{filter:brightness(1);opacity:1;transform:scale(1) rotate(0deg)}50%{filter:brightness(1.4);opacity:.7;transform:scale(1.3) rotate(3deg)}}.ap-actions{display:flex;gap:4px}.ap-icon{background:#0000;border:0;border-radius:6px;color:#6b7280;cursor:pointer;display:grid;height:28px;place-items:center;transition:all .15s;width:28px}.ap-icon:hover{background:#f3f4f6;color:#374151}.ap-icon:focus-visible{outline:2px solid #3b82f6;outline-offset:-2px}.ap-tabs{background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;gap:4px;min-height:40px;padding:8px}.ap-tab{align-items:center;background:#fff;border:1px solid #0000;border-radius:8px;color:#6b7280;cursor:pointer;display:inline-flex;flex:1 1;font-size:13px;gap:6px;justify-content:center;min-width:0;padding:8px 12px;position:relative;transition:all .15s}.ap-tab span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ap-tab:hover{background:#f3f4f6;color:#374151}.ap-tab:focus-visible{outline:2px solid #3b82f6;outline-offset:-2px}.ap-tab.active{background:#eff6ff;border-color:#dbeafe;color:#3b82f6;font-weight:500}.ap-badge{background:#ef4444;border-radius:8px;color:#fff;display:grid;font-size:10px;font-weight:600;height:16px;min-width:16px;padding:0 4px;place-items:center;position:absolute;right:4px;top:4px}.ap-body{background:#fff;flex:1 1;min-height:0;overflow:auto}.ap-rail{align-items:center;display:flex;flex-direction:column;gap:8px;height:100%;padding:12px 0}.ap-rail-logo{background:#eff6ff;border:0;border-radius:8px;color:#3b82f6;cursor:pointer;display:grid;height:36px;place-items:center;transition:all .15s;width:36px}.ap-rail-logo:hover{background:#dbeafe}.ap-rail-logo.breathing svg{animation:bot-breathing 2s ease-in-out infinite;transform-origin:center}.ap-rail-divider{background:#e5e7eb;height:1px;margin:4px 0;width:24px}.ap-rail-btn{background:#0000;border:0;border-radius:8px;color:#6b7280;cursor:pointer;display:grid;height:36px;place-items:center;position:relative;transition:all .15s;width:36px}.ap-rail-btn:hover{background:#f3f4f6;color:#374151}.ap-rail-btn.active{background:#eff6ff;color:#3b82f6}.ap-rail-badge{background:#ef4444;border-radius:50%;height:6px;position:absolute;right:4px;top:4px;width:6px}.ap-rail-spacer{flex:1 1;min-height:20px}.ap-placeholder{color:#9ca3af;font-size:14px;padding:32px;text-align:center}.ap-chat{display:flex;flex-direction:column;height:100%}.ap-chat-welcome{padding:48px 24px;text-align:center}.ap-chat-icon{color:#3b82f6;margin-bottom:16px}.ap-chat-icon.breathing svg{animation:bot-breathing 2s ease-in-out infinite;display:block;transform-origin:center}.ap-chat-welcome h3{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 8px}.ap-chat-welcome p{color:#6b7280;font-size:14px;margin:4px 0}.ap-chat-hint{color:#9ca3af!important;font-style:italic;margin-top:16px!important}.ap-settings{padding:16px}.ap-settings h3{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 16px}.ap-settings label{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:14px;gap:8px;margin:12px 0}.ap-settings input[type=checkbox]{cursor:pointer;height:16px;width:16px}@media (prefers-reduced-motion:reduce){.ap-chat-icon.breathing svg,.ap-logo.breathing svg,.ap-rail-logo.breathing svg{animation:none}}.pricing-page-container{align-items:center;background-color:#f4f4f4;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;padding:2rem;width:100%}.pricing-page-header{margin-bottom:3rem;max-width:800px;text-align:center}.pricing-page-title{color:#333;font-size:2.5rem;font-weight:600;margin-bottom:1rem}.pricing-page-subtitle{color:#666;font-size:1.1rem;line-height:1.6}.pricing-plans-section{display:flex;justify-content:center;margin-bottom:2rem;width:100%}.pricing-plans-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));max-width:1200px;width:100%}.pricing-plan-card{background-color:#fff;border:1px solid #ddd;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;justify-content:space-between;padding:2rem;transition:transform .3s ease-in-out,box-shadow .3s ease-in-out}.pricing-plan-card.popular{border-color:#007bff;box-shadow:0 6px 16px #00000026;transform:translateY(-10px)}.pricing-popular-tag{background-color:#007bff;border-radius:20px;color:#fff;font-size:.8rem;font-weight:500;left:20px;padding:.5rem 1rem;position:absolute;top:-10px}.pricing-plan-details{margin-bottom:1rem;text-align:center}.pricing-plan-name{color:#333;font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.pricing-plan-description{color:#666;font-size:1rem;margin-bottom:1rem}.pricing-amount{align-items:center;color:#333;display:flex;font-size:2rem;font-weight:600;justify-content:center;margin-bottom:1rem}.currency{font-size:1.2rem;margin-right:.2rem}.interval{color:#666;font-size:1rem}.pricing-features-list{margin-bottom:2rem}.pricing-features-list ul{list-style:none;padding:0}.pricing-feature-item{align-items:center;color:#333;display:flex;margin-bottom:.7rem}.check-icon{color:#28a745;margin-right:.5rem}.pricing-select-button{background-color:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.8rem 1.5rem;transition:background-color .3s ease-in-out;width:100%}.pricing-select-button.popular,.pricing-select-button:hover{background-color:#0056b3}.pricing-select-button:disabled{background-color:#ccc;cursor:default}.pricing-dev-mode{background-color:#fff3cd;border:1px solid #ffeeba;border-radius:8px;color:#856404;margin-top:2rem;padding:1rem;text-align:center}.pricing-error{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;margin-bottom:1rem;padding:1rem}.back-button{align-items:center;background-color:initial;border:1px solid #ddd;border-radius:8px;color:#666;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;margin-top:1.5rem;padding:.6rem 1.2rem;transition:all .2s ease}.back-button:hover{background-color:#f8f9fa;color:#333}.spinner{animation:spin 1s linear infinite;border:4px solid #0000001a;border-left-color:#007bff;border-radius:50%;display:inline-block;height:20px;margin-right:.5rem;width:20px}.loading-spinner-large{animation:spin 1.2s linear infinite;border:6px solid #007bff1a;border-left-color:#007bff;border-radius:50%;display:block;height:60px;margin:2rem auto;width:60px}.pricing-test-mode{color:#666;font-size:.8rem;margin-top:.5rem;text-align:center}.alert-overlay{align-items:center;animation:alert-fade-in .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.alert-container{animation:alert-slide-up .3s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001a;max-width:90%;overflow:hidden;width:360px}.alert-content{padding:24px 24px 20px;text-align:center}.alert-icon{align-items:center;border-radius:27px;color:#fff;display:flex;font-size:26px;height:54px;justify-content:center;margin:0 auto 16px;width:54px}.alert-icon.info{background-color:#0071e3}.alert-icon.success{background-color:#34c759}.alert-icon.warning{background-color:#ff9500}.alert-icon.error{background-color:#ff3b30}.alert-title{color:#1d1d1f;font-size:18px;font-weight:600;margin:0 0 8px}.alert-message{color:#1d1d1f;font-size:15px;line-height:1.4;margin:0;max-height:60vh;overflow-y:auto;word-break:break-word}.alert-actions{border-top:1px solid #d2d2d7;display:flex;margin-top:8px}.alert-button{background:none;border:none;color:#0071e3;cursor:pointer;flex:1 1;font-size:15px;font-weight:500;padding:14px;transition:background-color .2s}.alert-button:focus,.alert-button:hover{background-color:#0071e30d;outline:none}.alert-button:focus-visible{box-shadow:0 0 0 2px #fff,0 0 0 4px #0071e3}.alert-info .alert-button.primary{color:#0071e3}.alert-success .alert-button.primary{color:#34c759}.alert-warning .alert-button.primary{color:#ff9500}.alert-error .alert-button.primary{color:#ff3b30}@keyframes alert-fade-in{0%{opacity:0}to{opacity:1}}@keyframes alert-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.alert-container{max-width:340px;width:85%}.alert-title{font-size:16px}.alert-button,.alert-message{font-size:14px}.alert-button{padding:12px}}html.is-zoomed .alert-overlay{height:100vh!important;height:var(--zoom-adjusted-vh,100vh)!important;transform:scale(1);transform:scale(calc(1/var(--zoom-level, 1)));transform-origin:top left;width:100vw!important;width:var(--zoom-adjusted-vw,100vw)!important}*,:after,:before{box-sizing:border-box}:root{--vh:1vh;--zoom-level:1}@supports (-webkit-touch-callout:none){.dashboard-container{height:-webkit-fill-available}}body{font-family:Arial,sans-serif;margin:0;min-width:1024px;overflow-x:auto;touch-action:auto}.primary-button{background-color:#4a90e2;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:background-color .2s}.primary-button:hover{background-color:#3a7ac8}.primary-button:disabled{background-color:#a0c0e8;cursor:not-allowed}.secondary-button{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:5px;color:#212529;cursor:pointer;font-weight:600;padding:10px 20px;transition:background-color .2s}.secondary-button:hover{background-color:#e9ecef}.spinner-border{animation:spinner-border .75s linear infinite;border:.25em solid;border-radius:50%;border-right:.25em solid #0000;display:inline-block;height:2rem;vertical-align:text-bottom;width:2rem}@keyframes spinner-border{to{transform:rotate(1turn)}}.visually-hidden{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.pricing-card{border:1px solid #dee2e6;border-radius:8px;box-shadow:0 2px 10px #0000000d;overflow:hidden;transition:transform .3s,box-shadow .3s}.pricing-card:hover{box-shadow:0 10px 20px #0000001a;transform:translateY(-5px)}.pricing-card .card-title{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.pricing-value{margin:1rem 0}.pricing-currency{font-size:1.2rem;font-weight:600;position:relative;top:.5rem;vertical-align:top}.pricing-amount{font-size:2.5rem;font-weight:700;line-height:1}.pricing-card ul li{padding-left:1.5rem;position:relative}.pricing-card ul li i{color:#28a745;left:0;position:absolute;top:.3rem}.pricing-card.border-primary{transform:scale(1.05)}.pricing-card.border-primary:hover{transform:translateY(-5px) scale(1.05)}@media (max-width:768px){.pricing-card.border-primary{transform:none}.pricing-card.border-primary:hover{transform:translateY(-5px)}}@media (pointer:coarse) and (max-width:100%){.confirmation-dialog,.pricing-card,[class*=scale],[class*=transform]{transform:none!important;transition:opacity .2s ease-out!important}}html.is-zoomed{--zoom-adjusted-vw:calc(100vw/var(--zoom-level, 1));--zoom-adjusted-vh:calc(100vh/var(--zoom-level, 1))}html.desktop-mode-mobile{-webkit-text-size-adjust:100%;overflow-x:scroll}#mobile-desktop-helper{pointer-events:none}#zoom-out-helper{opacity:.9;transition:all .2s ease}#zoom-out-helper:active{transform:scale(.95)}html.is-zoomed .confirmation-dialog-overlay,html.is-zoomed .modal-backdrop,html.is-zoomed [class*=fixed]{height:var(--zoom-adjusted-vh)!important;transform:scale(1);transform:scale(calc(1/var(--zoom-level, 1)));transform-origin:top left;width:var(--zoom-adjusted-vw)!important}.inactivity-warning{background-color:#f44336;border-radius:4px;box-shadow:0 4px 8px #0003;color:#fff;font-family:Arial,sans-serif;max-width:400px;padding:16px;position:fixed;right:20px;top:20px;z-index:10000}.inactivity-warning button{background:#fff;border:none;border-radius:4px;color:#f44336;cursor:pointer;font-weight:700;padding:8px 12px;transition:background-color .2s}.inactivity-warning button:hover{background-color:#f8f8f8}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:1023px){.sidebar{flex-shrink:0!important;min-width:200px!important;width:300px!important}.dashboard-container{flex-wrap:nowrap!important}.main-content,[class*=main-content],[class*=review-main],[class*=session-main]{flex-basis:auto!important;flex-shrink:0!important;width:auto!important}::-webkit-scrollbar{-webkit-appearance:none;height:7px;width:7px}::-webkit-scrollbar-thumb{background-color:#0000004d;border-radius:4px}body::-webkit-scrollbar{background-color:#f0f0f0;height:8px}body::-webkit-scrollbar-thumb{background-color:#999;border-radius:4px}}.mobile-create-account-dialog-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}.mobile-create-account-dialog{-webkit-overflow-scrolling:touch;animation:slideUp .3s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;position:relative;width:100%}.mobile-create-account-dialog-header{align-items:center;border-bottom:none;display:flex;justify-content:space-between;padding:24px 24px 0}.mobile-create-account-dialog-title{color:#1f2937;font-size:28px;font-weight:600;margin:0}.mobile-create-account-dialog-close{align-items:center;background:none;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;font-size:36px;height:44px;justify-content:center;line-height:1;padding:8px;transition:color .2s ease;width:44px}.mobile-create-account-dialog-close:hover{background:#f3f4f6;color:#374151}.mobile-create-account-dialog-content{padding:20px 24px 24px}.mobile-create-account-error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#dc2626;font-size:16px;font-weight:500;margin-bottom:20px;padding:16px;text-align:center}.mobile-create-account-form{display:flex;flex-direction:column}.mobile-create-account-form-group{margin-bottom:20px}.mobile-create-account-input{-webkit-appearance:none;appearance:none;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;box-sizing:border-box;font-size:18px;font-weight:500;padding:16px;transition:all .2s ease;width:100%}.mobile-create-account-input:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.mobile-create-account-input:disabled{cursor:not-allowed;opacity:.6}.mobile-create-account-input::placeholder{color:#9ca3af;font-weight:400}.mobile-create-account-password-requirements{color:#6b7280;font-size:14px;line-height:1.4;margin-bottom:24px;text-align:center}.mobile-create-account-buttons{display:flex;gap:12px;margin-top:8px}.mobile-create-account-button-cancel,.mobile-create-account-button-primary{border:none;border-radius:12px;cursor:pointer;flex:1 1;font-size:18px;font-weight:600;padding:16px 20px;transition:all .2s ease}.mobile-create-account-button-cancel{background:#f3f4f6;border:2px solid #e5e7eb;color:#374151}.mobile-create-account-button-cancel:hover:not(:disabled){background:#e5e7eb;transform:translateY(-1px)}.mobile-create-account-button-primary{background:linear-gradient(135deg,#4f46e5,#7c3aed);box-shadow:0 4px 12px #4f46e54d;color:#fff}.mobile-create-account-button-primary:hover:not(:disabled){box-shadow:0 6px 16px #4f46e566;transform:translateY(-1px)}.mobile-create-account-button-cancel:disabled,.mobile-create-account-button-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.mobile-create-account-button-cancel:active:not(:disabled),.mobile-create-account-button-primary:active:not(:disabled){transform:translateY(0)}@media (max-width:480px){.mobile-create-account-dialog-overlay{padding:10px}.mobile-create-account-dialog{border-radius:16px;max-height:95vh}.mobile-create-account-dialog-header{padding:20px 20px 0}.mobile-create-account-dialog-title{font-size:24px}.mobile-create-account-dialog-close{font-size:32px;height:40px;width:40px}.mobile-create-account-dialog-content{padding:16px 20px 20px}.mobile-create-account-input{border-radius:10px;font-size:16px;padding:14px}.mobile-create-account-form-group{margin-bottom:16px}.mobile-create-account-error-message{border-radius:10px;font-size:14px;padding:12px}.mobile-create-account-password-requirements{font-size:12px;margin-bottom:20px}.mobile-create-account-buttons{flex-direction:column;gap:8px}.mobile-create-account-button-cancel,.mobile-create-account-button-primary{border-radius:10px;font-size:16px;padding:14px 18px}}@media (max-width:375px) and (max-height:700px){.mobile-create-account-dialog-overlay{padding:8px}.mobile-create-account-dialog{border-radius:12px;max-height:97vh}.mobile-create-account-dialog-header{padding:16px 16px 0}.mobile-create-account-dialog-title{font-size:20px}.mobile-create-account-dialog-content{padding:12px 16px 16px}.mobile-create-account-input{font-size:16px;padding:12px}.mobile-create-account-form-group{margin-bottom:14px}.mobile-create-account-password-requirements{margin-bottom:16px}}.mobile-login-page{-webkit-overflow-scrolling:touch;align-items:center;background:url(/static/media/login-background.cf69af04fc81f375d9c8.jpg) 50%/cover no-repeat,linear-gradient(135deg,#667eeacc,#764ba2cc);bottom:0;box-sizing:border-box;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh;height:-webkit-fill-available;justify-content:center;left:0;margin:0;max-width:100vw;min-height:100vh;min-height:-webkit-fill-available;overflow-x:hidden;overflow-y:auto;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0);position:fixed;right:0;top:0;width:100vw}.mobile-login-container{-webkit-overflow-scrolling:touch;align-self:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 8px 32px #0000001a;box-sizing:border-box;flex-shrink:0;margin:20px;max-height:calc(100vh - 40px);max-height:calc(-webkit-fill-available - 40px);max-width:800px;min-width:280px;overflow:hidden;overflow-y:auto;position:relative;width:calc(100% - 40px)}.mobile-login-header{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;flex-shrink:0;padding:20px;text-align:center}.mobile-login-logo{background:#0000;border-radius:24px;height:160px;margin-bottom:24px;object-fit:contain;padding:16px;width:160px}.mobile-login-logo-expanded{background:#0000;border-radius:16px;height:140px;margin-bottom:0;object-fit:contain;object-position:center;padding:10px 12px;width:280px}.mobile-login-content{flex-shrink:0;overflow-y:visible;padding:30px 30px calc(30px + env(safe-area-inset-bottom, 20px))}.mobile-login-subtitle{color:#1f2937;font-size:40px;font-weight:600;margin:0 0 48px;text-align:center}.mobile-error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:16px;color:#dc2626;font-size:28px;font-weight:500;margin-bottom:40px;padding:24px;text-align:center}.mobile-login-form{display:flex;flex-direction:column;margin-bottom:40px}.mobile-form-group{margin-bottom:32px}.mobile-input{-webkit-appearance:none;appearance:none;background:#f9fafb;border:4px solid #e5e7eb;border-radius:24px;box-sizing:border-box;font-size:32px;font-weight:500;padding:32px;transition:all .2s ease;width:100%}.mobile-input:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 6px #4f46e51a;outline:none}.mobile-input::placeholder{color:#9ca3af;font-weight:400}.mobile-primary-button{background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;border-radius:24px;box-shadow:0 8px 24px #4f46e54d;color:#fff;cursor:pointer;font-size:32px;font-weight:600;margin-bottom:24px;padding:32px;transition:all .2s ease;width:100%}.mobile-primary-button:hover{box-shadow:0 12px 32px #4f46e566;transform:translateY(-2px)}.mobile-primary-button:active{transform:translateY(0)}.mobile-primary-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.mobile-secondary-button{background:#6b7280;border:none;border-radius:24px;box-shadow:0 8px 24px #6b72804d;color:#fff;cursor:pointer;font-size:32px;font-weight:600;margin-bottom:24px;padding:32px;transition:all .2s ease;width:100%}.mobile-secondary-button:hover{background:#4b5563;box-shadow:0 12px 32px #6b728066;transform:translateY(-2px)}.mobile-secondary-button:active{transform:translateY(0)}.mobile-secondary-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.mobile-separator{color:#9ca3af;font-size:28px;font-weight:500;margin:48px 0;position:relative;text-align:center}.mobile-separator:after,.mobile-separator:before{background-color:#e5e7eb;content:"";height:2px;position:absolute;top:50%;width:40%}.mobile-separator:before{left:0}.mobile-separator:after{right:0}.mobile-google-button{align-items:center;background:#fff;border:4px solid #e5e7eb;border-radius:24px;color:#374151;cursor:pointer;display:flex;font-size:32px;font-weight:600;justify-content:center;margin-bottom:40px;padding:32px;transition:all .2s ease;width:100%}.mobile-google-button:hover{background:#f9fafb;border-color:#d1d5db;box-shadow:0 8px 24px #0000001a;transform:translateY(-2px)}.mobile-google-button:active{transform:translateY(0)}.mobile-google-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.mobile-google-logo{height:40px;margin-right:24px;width:40px}.mobile-links{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;text-align:center}.mobile-link-button{background:none;border:none;color:#4f46e5;cursor:pointer;font-size:28px;font-weight:500;padding:16px;transition:color .2s ease;white-space:nowrap}.mobile-link-button:hover{color:#3730a3}.mobile-link-separator{color:#9ca3af;font-size:28px;font-weight:300;padding:0 8px}.mobile-reset-container{text-align:center}.mobile-reset-title{color:#1f2937;font-size:40px;font-weight:600;margin:0 0 48px}.mobile-reset-form{align-items:center;display:flex;flex-direction:column}@media (max-width:480px){.mobile-login-page{min-height:calc(100vh - 16px);min-height:calc(100dvh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));padding:max(8px,env(safe-area-inset-top,0px) + 4px) max(8px,env(safe-area-inset-right,0px) + 4px) max(8px,env(safe-area-inset-bottom,0px) + 4px) max(8px,env(safe-area-inset-left,0px) + 4px)}.mobile-login-container{border-radius:12px;margin:8px;max-height:calc(100vh - 32px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));max-width:400px;overflow-x:hidden;overflow-y:auto;width:calc(100vw - 16px)}.mobile-login-header{padding:12px 16px}.mobile-login-logo{height:80px;margin-bottom:12px;padding:8px;width:80px}.mobile-login-logo-expanded{background:#0000;border-radius:12px;height:130px;margin-bottom:0;object-fit:contain;object-position:center;padding:8px 12px;width:260px}.mobile-login-content{padding:16px 16px max(25px,env(safe-area-inset-bottom,0px) + 15px)}.mobile-login-subtitle{font-size:18px;margin-bottom:20px}.mobile-input{border-radius:8px;border-width:2px;font-size:16px;padding:12px 16px}.mobile-form-group,.mobile-input{margin-bottom:16px}.mobile-google-button,.mobile-primary-button,.mobile-secondary-button{border-radius:8px;font-size:16px;margin-bottom:max(12px,env(safe-area-inset-bottom,0px) + 6px);padding:14px 16px}.mobile-separator{font-size:14px;margin:20px 0}.mobile-link-button{font-size:14px;padding:8px 8px max(8px,env(safe-area-inset-bottom,0px) + 4px)}.mobile-link-separator{font-size:14px;padding:0 4px}.mobile-reset-title{font-size:18px;margin-bottom:20px}.mobile-error-message{border-radius:8px;font-size:14px;margin-bottom:16px;padding:12px}.mobile-google-logo{height:20px;margin-right:8px;width:20px}}@media (max-width:375px) and (max-height:700px){.mobile-login-header{padding:16px 12px}.mobile-login-logo{height:60px;margin-bottom:8px;width:60px}.mobile-login-title{font-size:20px}.mobile-login-content{padding:16px 12px max(16px,env(safe-area-inset-bottom,0px) + 8px)}.mobile-login-subtitle{font-size:16px;margin-bottom:16px}.mobile-input{font-size:16px;padding:10px 12px}.mobile-google-button,.mobile-primary-button,.mobile-secondary-button{font-size:15px;margin-bottom:max(10px,env(safe-area-inset-bottom,0px) + 4px);padding:12px 14px}.mobile-separator{font-size:13px;margin:16px 0}.mobile-form-group{margin-bottom:12px}.mobile-link-separator{font-size:13px;padding:0 3px}}@supports (padding:max(0px)){.mobile-login-page{min-height:100vh}.mobile-login-container{max-width:calc(800px - env(safe-area-inset-left) - env(safe-area-inset-right));overflow-x:hidden;width:calc(100vw - env(safe-area-inset-left) - env(safe-area-inset-right) - 40px)}}@supports (-webkit-touch-callout:none){.mobile-login-page{height:100vh;height:-webkit-fill-available;min-height:100vh;min-height:-webkit-fill-available}.mobile-login-container{max-height:calc(100vh - 20px);max-height:calc(-webkit-fill-available - 20px)}}@media screen and (max-height:700px){.mobile-login-header{padding:15px}.mobile-login-logo-expanded{height:120px!important;padding:8px 10px;width:240px!important}.mobile-login-content{padding:20px 20px calc(20px + env(safe-area-inset-bottom, 20px))}.mobile-input{font-size:16px;margin-bottom:12px;padding:14px}.mobile-form-group{margin-bottom:16px}.mobile-google-button,.mobile-primary-button,.mobile-secondary-button{font-size:16px;margin-bottom:12px;padding:14px}.mobile-separator{font-size:14px;margin:16px 0}}@media screen and (max-height:600px){.mobile-login-header{padding:10px}.mobile-login-logo-expanded{height:100px!important;padding:5px 8px;width:200px!important}.mobile-login-content{padding:15px 15px calc(15px + env(safe-area-inset-bottom, 20px))}}.mobile-login-container{animation:slideUp .4s ease-out}.bottom-navigation{align-items:center;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#fffffff2;border-top:1px solid #fff3;bottom:0;box-shadow:0 -2px 20px #0000001a;display:flex;height:80px;justify-content:space-around;left:0;padding:env(safe-area-inset-bottom) 0 0;position:fixed;right:0;transform:translateZ(0);will-change:transform;z-index:1000}@media screen and (-webkit-min-device-pixel-ratio:0){.bottom-navigation{bottom:0!important;position:fixed!important}}.nav-tab{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;align-items:center;-webkit-appearance:none;appearance:none;background:none;border:none;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:44px;min-width:60px;min-width:44px;overflow:hidden;padding:8px 12px;position:relative;touch-action:manipulation;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none}.nav-tab:hover{background:#ffffff1a;transform:translateY(-2px)}.nav-tab.mobile-active{transform:translateY(-4px)}.nav-tab.mobile-active:before{background:#ff4757;background:var(--tab-color-fallback,#ff4757);background:var(--tab-color,var(--tab-color-fallback,#ff4757));border-radius:0 0 3px 3px;content:"";height:3px;left:50%;position:absolute;top:0;transform:translateX(-50%);width:30px}.nav-tab-icon{align-items:center;color:#666;display:flex;font-size:22px;justify-content:center;margin-bottom:4px;transition:all .3s ease}.nav-tab.mobile-active .nav-tab-icon{color:#ff4757;color:var(--tab-color-fallback,#ff4757);color:var(--tab-color,var(--tab-color-fallback,#ff4757));transform:scale(1.1)}.nav-tab-label{color:#666;font-size:11px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;transition:all .3s ease}.nav-tab.mobile-active .nav-tab-label{color:#ff4757;color:var(--tab-color-fallback,#ff4757);color:var(--tab-color,var(--tab-color-fallback,#ff4757));font-weight:600}.nav-tab:after{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .3s,height .3s;width:0}.nav-tab:active:after{height:100px;width:100px}@media (prefers-color-scheme:dark){.bottom-navigation{background:#1e1e1ef2;border-top:1px solid #ffffff1a}.nav-tab-icon,.nav-tab-label{color:#ccc}.nav-tab:hover{background:#ffffff0d}}@supports (padding:max(0px)){.bottom-navigation{height:calc(80px + env(safe-area-inset-bottom));padding-bottom:max(env(safe-area-inset-bottom),8px)}}@supports (-webkit-touch-callout:none){.bottom-navigation{-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0)}.nav-tab{-webkit-tap-highlight-color:rgba(0,0,0,.1);-webkit-touch-callout:none;position:relative;-webkit-user-select:none;user-select:none;z-index:1}.nav-tab:active{background:#0000001a}}@media screen and (-webkit-min-device-pixel-ratio:2){.nav-tab{-webkit-tap-highlight-color:transparent;tap-highlight-color:#0000}}.mobile-tiptap-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;height:100%;overflow:hidden}.mobile-notification{background:#10b981;border-radius:4px;color:#fff;font-size:14px;margin-bottom:8px;padding:8px 12px;text-align:center}.mobile-tiptap-toolbar{-webkit-overflow-scrolling:touch;align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;flex-wrap:nowrap;gap:8px;overflow-x:auto;padding:8px 12px}.mobile-tt-group{align-items:center;display:flex;flex-shrink:0;gap:4px}.mobile-tt-group+.mobile-tt-group{border-left:1px solid #e2e8f0;margin-left:4px;padding-left:8px}.mobile-tt-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;height:44px;justify-content:center;touch-action:manipulation;transition:all .2s ease;width:44px}.mobile-tt-btn:hover{background:#e2e8f0;color:#475569}.mobile-tt-btn:active{background:#cbd5e1;transform:scale(.95)}.mobile-tt-btn.is-active{background:#3b82f6;color:#fff}.mobile-tt-btn.is-active:hover{background:#2563eb}.mobile-tt-btn:disabled{cursor:not-allowed;opacity:.5;pointer-events:none}.mobile-tt-group-undo{margin-left:auto}.mobile-tiptap-editor-wrapper{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.mobile-editor-content{-webkit-overflow-scrolling:touch;flex:1 1;overflow:auto;scroll-padding-bottom:60px;scroll-padding-top:60px}.mobile-tiptap-editor{-webkit-overflow-scrolling:touch;color:#1e293b;font-size:16px;line-height:1.6;min-height:200px;outline:none;padding:16px;touch-action:pan-y}.mobile-tiptap-editor:before{color:#94a3b8;content:attr(data-placeholder);opacity:0;pointer-events:none;position:absolute}.mobile-tiptap-editor.ProseMirror-focused:before,.mobile-tiptap-editor:empty:before{opacity:1}.mobile-tiptap-editor.ProseMirror-focused:not(:empty):before{opacity:0}.mobile-tiptap-editor h1{font-size:1.5em;font-weight:600;line-height:1.3;margin:1.2em 0 .8em}.mobile-tiptap-editor h2{font-size:1.3em;font-weight:600;line-height:1.3;margin:1em 0 .6em}.mobile-tiptap-editor p{margin:.5em 0}.mobile-tiptap-editor ol,.mobile-tiptap-editor ul{margin:.5em 0;padding-left:1.5em}.mobile-tiptap-editor li{margin:.25em 0}.mobile-tiptap-editor strong{font-weight:600}.mobile-tiptap-editor em{font-style:italic}.mobile-tiptap-editor:focus{outline:none}.mobile-tiptap-container:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}@media (max-width:480px){.mobile-tiptap-toolbar{gap:6px;padding:6px 8px}.mobile-tt-btn{height:40px;width:40px}.mobile-tt-group+.mobile-tt-group{margin-left:2px;padding-left:6px}.mobile-tiptap-editor{font-size:16px;padding:12px}}@supports (-webkit-touch-callout:none){.mobile-tiptap-container{height:auto;min-height:200px}.mobile-editor-content{-webkit-overflow-scrolling:touch;overflow-scrolling:touch;scroll-snap-type:none}.mobile-tiptap-editor{font-size:16px!important;-webkit-user-select:text;user-select:text}.mobile-tiptap-container:focus-within{z-index:1000}}@media screen and (max-width:768px){.mobile-tiptap-container{position:relative}.mobile-editor-content{overscroll-behavior:contain;scroll-padding-bottom:100px}.mobile-tiptap-editor{font-size:16px;touch-action:pan-y}.mobile-tiptap-container:focus-within .mobile-editor-content{max-height:calc(100vh - 200px);max-height:calc(100dvh - 200px)}}@media (prefers-color-scheme:dark){.mobile-tiptap-container{background:#1e293b;border-color:#475569}.mobile-tiptap-toolbar{background:#334155;border-color:#475569}.mobile-tt-btn{color:#cbd5e1}.mobile-tt-btn:hover{background:#475569;color:#f1f5f9}.mobile-tiptap-editor{color:#f1f5f9}.mobile-tiptap-editor:before{color:#64748b}}.mobile-notes-container{box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;height:100%;overflow:hidden;padding:10px 4px;width:100%}.mobile-notes-tiptap-container{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.mobile-notes-tiptap-container .ProseMirror{-webkit-overflow-scrolling:touch!important;border:1px solid #ccc;border-radius:8px;box-sizing:border-box;font-size:16px;height:100%;line-height:1.5;overflow-y:auto!important;padding:12px;touch-action:pan-y!important}.mobile-notes-header{align-items:center;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:12px;box-shadow:0 2px 8px #8b5cf633;display:flex;margin-bottom:16px;padding:12px 16px}.mobile-notes-header-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;font-size:24px;height:40px;justify-content:center;margin-right:12px;width:40px}.mobile-notes-header-text{color:#fff;flex:1 1}.mobile-notes-header-text h3{font-size:18px;font-weight:600;line-height:1.2;margin:0}.mobile-notes-header-text small{font-size:13px;font-weight:400;opacity:.9}.mobile-notes-textarea{-webkit-appearance:none;background-color:#fff;border:1px solid #ccc;border-radius:8px;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:16px;height:100%;line-height:1.5;outline:none;overflow-y:auto;padding:12px;resize:none;touch-action:pan-y;width:100%}.mobile-notes-textarea:focus{border-color:#007aff;box-shadow:0 0 0 3px #007aff1a}.mobile-notes-textarea:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.mobile-notes-textarea::placeholder{color:#999;font-style:italic}body.safari-mobile .mobile-notes-container{padding:2px 4px 10px!important}@supports (-webkit-touch-callout:none){.mobile-notes-container{padding:4px 4px 10px}.mobile-notes-textarea{font-size:16px;padding-bottom:12px;transform:translateZ(0);-webkit-transform:translateZ(0)}}.mobile-transcript{box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;height:100%;overflow:hidden;padding:10px 4px;position:relative;width:100%}.mobile-transcript-tiptap-container{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.mobile-transcript-tiptap-container .ProseMirror{-webkit-overflow-scrolling:touch!important;border:1px solid #ccc;border-radius:8px;box-sizing:border-box;font-size:16px;height:100%;line-height:1.5;overflow-y:auto!important;padding:12px;touch-action:pan-y!important}.mobile-transcript-header{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;box-shadow:0 2px 8px #10b98133;display:flex;margin-bottom:16px;padding:12px 16px}.mobile-transcript-header-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;font-size:24px;height:40px;justify-content:center;margin-right:12px;width:40px}.mobile-transcript-header-text{color:#fff;flex:1 1}.mobile-transcript-header-text h3{font-size:18px;font-weight:600;line-height:1.2;margin:0}.mobile-transcript-header-text small{font-size:13px;font-weight:400;opacity:.9}.mobile-transcript-textarea{-webkit-appearance:none;background-color:#fff;border:1px solid #ccc;border-radius:8px;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:16px;height:100%;line-height:1.5;outline:none;overflow-y:auto;padding:12px;resize:none;touch-action:pan-y;width:100%}.mobile-transcript-textarea:focus{border-color:#007aff;box-shadow:0 0 0 3px #007aff1a}.mobile-transcript-textarea::placeholder{color:#999;font-style:italic}.mobile-transcript-textarea.editing{background-color:#fffbeb;border-color:#f59e0b}.mobile-transcript-saving-indicator{background-color:#f59e0b;border-radius:4px;box-shadow:0 2px 4px #0000001a;color:#fff;font-size:12px;font-weight:500;padding:4px 8px;position:absolute;right:8px;top:8px;z-index:10}@media screen and (max-width:768px){.mobile-transcript-textarea{font-size:16px}}body.safari-mobile .mobile-transcript{padding:2px 4px 10px!important}@supports (-webkit-touch-callout:none){.mobile-transcript{padding:4px 4px 10px}.mobile-transcript-textarea{padding-bottom:12px;transform:translateZ(0);-webkit-transform:translateZ(0)}}.mobile-trash-folder{border-top:1px solid #e0e0e0;margin-top:16px;padding-top:16px}.mobile-trash-header{align-items:center;background:#f8f8f8;border:1px solid #ddd;border-radius:8px;cursor:pointer;display:flex;padding:12px;transition:background-color .2s}.mobile-trash-header:hover{background:#f0f0f0}.mobile-trash-icon{font-size:18px;margin-right:8px;opacity:.7}.mobile-trash-title{color:#666;flex:1 1;font-size:16px;font-weight:500}.mobile-trash-toggle{color:#888;font-size:14px}.mobile-trash-error{background:#ffebee;border-left:4px solid #e57373;border-radius:6px;color:#c62828;font-size:14px;margin:8px 0;padding:8px 12px}.mobile-trash-content{background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;margin-top:8px;overflow:hidden}.mobile-trash-loading{color:#666;font-size:14px;padding:20px;text-align:center}.mobile-trash-empty{color:#999;padding:20px;text-align:center}.mobile-trash-empty-icon{font-size:32px;margin-bottom:8px;opacity:.5}.mobile-trash-empty-text{font-size:14px}.mobile-trash-sessions{max-height:300px;overflow-y:auto}.mobile-trash-session{align-items:center;background:#fff;border-bottom:1px solid #e8e8e8;display:flex;justify-content:space-between;padding:12px;transition:background-color .2s}.mobile-trash-session:hover{background:#f9f9f9}.mobile-trash-session:last-child{border-bottom:none}.mobile-trash-session-info{flex:1 1;min-width:0}.mobile-trash-session-name{color:#333;font-size:15px;font-weight:500;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-trash-session-date{color:#666;font-size:12px;margin-bottom:1px}.mobile-trash-session-expire{color:#d32f2f;font-size:12px;font-weight:500}.mobile-trash-session-actions{display:flex;gap:8px;margin-left:12px}.mobile-trash-delete-btn,.mobile-trash-restore-btn{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;transition:all .2s;width:36px}.mobile-trash-restore-btn{background:#e8f5e8;border:1px solid #c8e6c9;color:#2e7d32}.mobile-trash-restore-btn:hover{background:#c8e6c9;transform:translateY(-1px)}.mobile-trash-delete-btn{background:#ffebee;border:1px solid #ffcdd2;color:#d32f2f}.mobile-trash-delete-btn:hover{background:#ffcdd2;transform:translateY(-1px)}.mobile-trash-delete-btn:disabled,.mobile-trash-restore-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}@media (max-width:480px){.mobile-trash-session{padding:10px}.mobile-trash-session-name{font-size:14px}.mobile-trash-session-date,.mobile-trash-session-expire{font-size:11px}.mobile-trash-delete-btn,.mobile-trash-restore-btn{font-size:14px;height:32px;width:32px}}.mobile-session-folder-modal-overlay{align-items:flex-start;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:0;position:fixed;right:0;top:0;z-index:99999}.mobile-session-folder-modal{background:#fff;display:flex;flex-direction:column;height:100vh;position:relative;width:100vw}.modal-header{align-items:center;background:#f5f5f5;border-bottom:1px solid #e0e0e0;display:flex;flex-shrink:0;justify-content:space-between;padding:16px 20px}.modal-header h2{color:#333;font-size:20px;font-weight:600;margin:0}.close-button{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:24px;padding:4px;transition:background-color .2s}.close-button:hover{background-color:#0000001a}.modal-content{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:20px}.error-message{background:#ffebee;border-left:4px solid #e57373;border-radius:8px;color:#c62828;font-size:14px;margin:16px 20px;padding:12px 16px}.action-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.action-button{background:#007bff;border:none;border-radius:8px;box-shadow:0 2px 4px #007bff4d;color:#fff;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;min-width:140px;padding:12px 20px;transition:all .2s}.action-button:hover{background:#0056b3;box-shadow:0 4px 8px #007bff66;transform:translateY(-1px)}.action-button:disabled{background:#6c757d!important;box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.action-button.create-folder{background:#4caf50}.action-button.create-folder:hover{background:#388e3c}.input-section{background:#f9f9f9;border:2px solid #e0e0e0;border-radius:8px;margin-bottom:20px;padding:16px}.input-section input,.input-section select{border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:16px;margin-bottom:12px;padding:12px;width:100%}.input-section input:focus,.input-section select:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f31a;outline:none}.input-actions{display:flex;gap:8px;justify-content:flex-end}.input-actions button{border:none;border-radius:6px;cursor:pointer;font-size:14px;min-width:70px;padding:8px 16px;transition:all .2s}.input-actions button:first-child{background:#4caf50;color:#fff}.input-actions button:first-child:hover{background:#388e3c}.input-actions button:first-child:disabled{background:#ccc;cursor:not-allowed}.input-actions button:last-child{background:#f5f5f5;border:1px solid #ddd;color:#666}.input-actions button:last-child:hover{background:#e0e0e0}.session-folder-list{flex:1 1}.folder-section{margin-bottom:16px}.folder-header{background:#f0f7ff;border:1px solid #bbdefb;border-radius:8px;padding:12px}.folder-toggle{align-items:center;background:none;border:none;cursor:pointer;display:flex;flex:1 1;font-size:16px;gap:8px;padding:0;text-align:left}.folder-toggle span{color:#1976d2;cursor:pointer;font-weight:500}.folder-sessions{margin-left:16px;margin-top:8px}.unfoldered-section{margin-bottom:16px}.section-header{border-bottom:1px solid #e0e0e0;margin-bottom:12px;padding:12px 0 8px}.section-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.session-item{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:8px;transition:all .2s}.session-item:hover{border-color:#2196f3;box-shadow:0 2px 4px #0000001a}.session-item.active{background:#e8f5e8;border-color:#4caf50}.session-button{background:none;border:none;color:#333;cursor:pointer;flex:1 1;font-size:16px;padding:16px;text-align:left;transition:background-color .2s}.session-button:hover{background:#2196f30d}.session-item.active .session-button{color:#2e7d32;font-weight:600}.item-actions{border-left:1px solid #e0e0e0;display:flex;gap:4px;padding:8px}.delete-btn,.edit-btn,.move-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:8px;transition:background-color .2s}.edit-btn:hover{background:#2196f31a}.move-btn:hover{background:#ff98001a}.delete-btn:hover{background:#f443361a}.delete-btn:disabled,.edit-btn:disabled,.move-btn:disabled{cursor:not-allowed;opacity:.5}.edit-input{background:#fff;border:2px solid #2196f3;border-radius:4px;box-sizing:border-box;font-size:16px;padding:8px;width:100%}.edit-input:focus{border-color:#1976d2;outline:none}.empty-state{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-title{color:#333;font-size:20px;font-weight:600;margin-bottom:8px}.empty-description{color:#666;font-size:16px;line-height:1.4}.loading-overlay{align-items:center;background:#fffc;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:1000}.loading-spinner{animation:spin 1s linear infinite;font-size:32px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:480px){.modal-header{padding:12px 16px}.modal-content{padding:16px}.action-buttons{flex-direction:column}.action-button{min-width:auto}.folder-header,.session-item{padding:10px}.session-button{font-size:15px;padding:14px}}.folder-picker-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:absolute;right:0;top:0;z-index:1001}.folder-picker-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-height:80vh;max-width:400px;overflow-y:auto;width:100%}.folder-picker-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;padding:16px 20px}.folder-picker-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.folder-picker-close{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:20px;padding:4px;transition:background-color .2s}.folder-picker-close:hover{background-color:#0000001a}.folder-picker-content{padding:20px}.folder-picker-content p{color:#666;font-size:14px;margin:0 0 16px}.folder-picker-options{display:flex;flex-direction:column;gap:8px}.folder-picker-option{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;font-size:16px;justify-content:space-between;padding:12px 16px;text-align:left;transition:all .2s}.folder-picker-option:hover:not(:disabled){background:#2196f30d;border-color:#2196f3}.folder-picker-option:disabled{border-style:dashed;cursor:not-allowed;opacity:.6}.folder-picker-option.current{background:#4caf501a;border-color:#4caf50}.current-label{color:#4caf50;font-size:12px;font-weight:500}@media (max-width:480px){.folder-picker-overlay{padding:16px}.folder-picker-modal{max-width:none;width:100%}.folder-picker-header{padding:14px 16px}.folder-picker-content{padding:16px}.folder-picker-option{font-size:15px;padding:14px}}.mobile-confirmation-dialog-overlay{-webkit-overflow-scrolling:touch;align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;box-sizing:border-box;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;transform:translateZ(0);width:100%;z-index:99999}.confirmation-dialog{animation:scaleIn .2s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 10px 25px #00000026;display:flex;flex-direction:column;max-width:90%;overflow:hidden;transform-origin:center center;width:400px;will-change:transform,opacity}.confirmation-dialog-content{padding:24px 24px 20px}.confirmation-dialog-title{color:#1d1d1f;font-size:17px;font-weight:600;margin:0 0 8px}.confirmation-dialog-message{color:#424245;font-size:15px;line-height:1.4;margin:0}.highlighted-name{background-color:#007aff14;border-radius:3px;color:#007aff;display:inline-block;font-weight:600;padding:0 2px}.confirmation-dialog-buttons{border-top:1px solid #d2d2d7;display:flex}.confirmation-dialog-button{background:none;border:none;cursor:pointer;flex:1 1;font-size:15px;font-weight:500;padding:12px;transition:background-color .2s}.confirmation-dialog-button:not(:last-child),.three-buttons .confirmation-dialog-button{border-right:1px solid #d2d2d7}.three-buttons .confirmation-dialog-button:last-child{border-right:none}.confirmation-dialog-cancel{color:#06c}.confirmation-dialog-cancel:hover{background-color:#f5f5f7}.confirmation-dialog-alternate{color:#007aff;font-weight:500}.confirmation-dialog-alternate:hover{background-color:#e6f2ff}.confirmation-dialog-confirm{color:#ff3b30;font-weight:600}.confirmation-dialog-confirm:hover{background-color:#fff1f0}@media (max-width:480px){.confirmation-dialog{width:320px}.confirmation-dialog-content{padding:20px 20px 16px}.confirmation-dialog-title{font-size:16px}.confirmation-dialog-message{font-size:14px}.confirmation-dialog-button{font-size:14px;padding:10px}}.sessions-page{animation:slideInFromRight .3s ease-out;background:#fff;bottom:0;display:flex;flex-direction:column;height:100vh;left:0;overflow:hidden;position:fixed;right:0;top:0;width:100vw;z-index:9999}.sessions-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1rem}.sessions-header-button{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:1.125rem;font-weight:500}.sessions-header-title{color:#111827;font-size:1.25rem;font-weight:600}.sessions-tabs{background:#f3f4f6;border-radius:.5rem;display:flex;margin:1rem;padding:.25rem}.sessions-tab{background:none;border:none;border-radius:.375rem;color:#6b7280;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.sessions-tab.active{background:#fff;box-shadow:0 1px 2px 0 #0000000d;color:#111827}.sessions-search{margin:0 1rem 1rem}.sessions-search-container{position:relative}.sessions-search-icon{color:#9ca3af;height:1.25rem;left:.75rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);width:1.25rem}.sessions-search-input{border:1px solid #d1d5db;border-radius:.5rem;box-sizing:border-box;font-size:1rem;padding:.75rem 1rem .75rem 2.5rem;width:100%}.sessions-search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.sessions-list{flex:1 1;overflow-y:auto;padding:0 1rem 5rem}.sessions-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:3rem 0}.sessions-empty-icon{color:#9ca3af;font-size:4rem;margin-bottom:1rem}.sessions-empty-title{color:#6b7280;font-size:1.125rem}.sessions-empty-subtitle{color:#9ca3af;font-size:.875rem;margin-top:.25rem}.session-item{border-radius:.5rem;margin-bottom:.5rem;overflow:hidden;position:relative;width:100%}.session-swipe-bg{align-items:center;bottom:0;display:flex;justify-content:center;position:absolute;top:0;width:5rem}.session-swipe-bg.permanent-delete,.session-swipe-bg.trash{right:0}.session-swipe-bg.folder,.session-swipe-bg.restore{left:0}.session-swipe-bg.trash{background:#ef4444}.session-swipe-bg.permanent-delete{background:#dc2626}.session-swipe-bg.restore{background:#10b981}.session-swipe-bg.folder{background:#3b82f6}.session-swipe-icon{color:#fff;height:1.5rem;width:1.5rem}.session-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-sizing:border-box;cursor:pointer;padding:.5rem;position:relative;transition:transform .2s;width:100%;z-index:1}.session-card:active{background:#f9fafb}.session-card-content{align-items:center;display:flex;justify-content:space-between}.session-info{flex:1 1}.session-name-container{align-items:center;display:flex}.session-name{color:#111827!important;font-size:1.125rem;font-weight:500;margin:0;padding:0}.session-folder-badge{border-radius:9999px;color:#fff;font-size:.75rem;font-weight:500;margin-left:.5rem;padding:.25rem .5rem}.session-dates{align-items:center;display:flex;justify-content:space-between;margin:.125rem 0 0;padding:0}.session-created-date{color:#6b7280;font-size:.875rem}.session-updated-date{color:#9ca3af;font-size:.75rem;font-style:italic}.session-menu-button{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;justify-content:center;margin-left:1rem;min-height:44px;min-width:44px;padding:.75rem;transition:color .2s}.session-menu-button:hover{color:#6b7280}.session-menu-icon{height:1.25rem;width:1.25rem}.session-context-menu{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;min-width:12rem;padding:.5rem 0;position:absolute;right:1rem;top:4rem;z-index:10}.context-menu-item{background:none;border:none;color:#374151;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;text-align:left;transition:background-color .2s;width:100%}.context-menu-item:hover{background:#f9fafb}.context-menu-item.danger{color:#dc2626}.context-menu-item.danger:hover{background:#fef2f2}.sessions-fab{align-items:center;background:#3b82f6;border:none;border-radius:1.75rem;bottom:2rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;color:#fff;cursor:pointer;display:flex;gap:.5rem;height:3.5rem;justify-content:center;left:50%;padding:0 1rem;position:fixed;transform:translateX(-50%);transition:background-color .2s;white-space:nowrap;z-index:100}.sessions-fab:hover{background:#2563eb}.sessions-fab-danger{background:#ef4444!important}.sessions-fab-danger:hover{background:#dc2626!important}.sessions-fab-danger:active{transform:translateX(-50%) scale(.95)!important}.sessions-fab-icon{flex-shrink:0;height:1.5rem;width:1.5rem}.sessions-fab-text{font-size:1rem;font-weight:600}.folder-modal-overlay{align-items:flex-end;background:#00000080;bottom:0;display:flex;left:0;position:fixed;right:0;top:0;z-index:10000}.folder-modal{background:#fff;border-radius:.5rem .5rem 0 0;max-height:24rem;overflow-y:auto;width:100%}.folder-modal-header{border-bottom:1px solid #e5e7eb;padding:1rem}.folder-modal-title{color:#111827;font-size:1.125rem;font-weight:600}.folder-modal-content{padding:1rem}.folder-option{background:none;border:1px solid #e5e7eb;border-radius:.5rem;cursor:pointer;margin-bottom:.5rem;padding:.75rem;text-align:left;transition:background-color .2s;width:100%}.folder-option:hover{background:#f9fafb}.folder-option-content{align-items:center;display:flex}.folder-color{border-radius:50%;height:1rem;margin-right:.75rem;width:1rem}.folder-description{color:#6b7280;font-size:.875rem}.folder-modal-footer{border-top:1px solid #e5e7eb;padding:1rem}.folder-cancel-button{background:none;border:none;color:#6b7280;cursor:pointer;font-weight:500;padding:.75rem;text-align:center;width:100%}.folder-section{margin-bottom:.5rem}.folder-header{align-items:center;background:#f8f9fa;border-radius:.5rem;cursor:pointer;display:flex;justify-content:space-between;padding:1rem;transition:background-color .2s;-webkit-user-select:none;user-select:none}.folder-header:hover{background:#e9ecef}.folder-header:active{background:#dee2e6}.folder-header-info{align-items:center;display:flex;gap:.75rem}.folder-icon{font-size:1.25rem;line-height:1}.folder-name{color:#374151;font-weight:600}.folder-count{color:#6b7280;font-size:.875rem;font-weight:500}.folder-chevron{color:#9ca3af;font-size:.875rem;transform:rotate(-90deg);transition:transform .2s ease}.folder-chevron.expanded{transform:rotate(0deg)}.folder-sessions{animation:slideDown .2s ease-out;border-left:2px solid #e5e7eb;margin-top:.5rem;padding-left:1rem}.context-menu-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:0}@keyframes slideInFromRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}.folder-modal{animation:slideUp .3s ease-out}.session-card:active{transform:scale(.98)}.sessions-fab:active{transform:translateX(-50%) scale(.95)}.sessions-tab:active{transform:scale(.98)}.sessions-tab-dropdown{flex:1 1;position:relative}.sessions-tab-with-dropdown{align-items:center;display:flex;justify-content:space-between;width:100%}.dropdown-chevron{color:inherit;font-size:.75rem;margin-left:.5rem;transition:transform .2s}.dropdown-chevron.expanded{transform:rotate(180deg)}.folder-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;left:0;margin-top:.25rem;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:10}.folder-dropdown-content{padding:.5rem 0}.folder-dropdown-item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-size:.875rem;justify-content:space-between;padding:.75rem 1rem;text-align:left;transition:background-color .2s;width:100%}.folder-dropdown-item:hover{background:#f9fafb}.folder-dropdown-item.active{background:#eff6ff;color:#2563eb;font-weight:500}.folder-dropdown-count{color:#9ca3af;font-size:.75rem}.folder-dropdown-item.active .folder-dropdown-count{color:#2563eb}.permanent-delete-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10001}.permanent-delete-modal{background:#fff;border-radius:.75rem;box-shadow:0 25px 50px -12px #00000040;max-height:90vh;max-width:400px;overflow-y:auto;width:100%}.permanent-delete-header{padding:1.5rem 1.5rem 0;text-align:center}.permanent-delete-header h3{color:#dc2626;font-size:1.25rem;font-weight:700;margin:0}.permanent-delete-content{padding:1rem 1.5rem}.permanent-delete-patient{background:#f3f4f6;border-radius:.5rem;font-size:.95rem;margin-bottom:1rem;padding:.75rem}.permanent-delete-warning{color:#dc2626;font-size:.95rem;margin-bottom:.75rem}.permanent-delete-list{color:#6b7280;font-size:.9rem;margin:0 0 1rem 1rem}.permanent-delete-list li{margin-bottom:.25rem}.permanent-delete-final-warning{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.95rem;font-weight:700;padding:.75rem;text-align:center}.permanent-delete-actions{display:flex;gap:.75rem;padding:1rem 1.5rem 1.5rem}.permanent-delete-cancel{background:#f3f4f6;border:1px solid #d1d5db;border-radius:.5rem;color:#374151;cursor:pointer;flex:1 1;font-weight:500;padding:.75rem 1rem;transition:all .2s}.permanent-delete-cancel:hover{background:#e5e7eb}.permanent-delete-confirm{background:#dc2626;border:none;border-radius:.5rem;color:#fff;cursor:pointer;flex:1 1;font-weight:600;padding:.75rem 1rem;transition:all .2s}.permanent-delete-confirm:hover{background:#b91c1c}.permanent-delete-confirm:active{transform:scale(.98)}.create-folder-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10001}.create-folder-modal{background:#fff;border-radius:.75rem;box-shadow:0 25px 50px -12px #00000040;max-width:400px;width:100%}.create-folder-header{border-bottom:1px solid #f3f4f6;padding:1.5rem 1.5rem 1rem}.create-folder-header h3{color:#111827;font-size:1.125rem;font-weight:600;margin:0;text-align:center}.create-folder-content{padding:1.5rem}.create-folder-input-group{display:flex;flex-direction:column;gap:.5rem}.create-folder-label{color:#374151;font-size:.875rem;font-weight:500}.create-folder-input{background:#fff;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;padding:.75rem;transition:border-color .15s ease}.create-folder-input:focus{ring:2px solid #3b82f633;border-color:#3b82f6;outline:none}.create-folder-actions{border-top:1px solid #f3f4f6;display:flex;gap:.75rem;padding:1rem 1.5rem 1.5rem}.create-folder-cancel,.create-folder-confirm{border-radius:.5rem;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:.75rem 1rem;transition:all .15s ease}.create-folder-cancel{background:#f9fafb;border:1px solid #d1d5db;color:#374151}.create-folder-cancel:hover{background:#f3f4f6}.create-folder-confirm{background:#3b82f6;border:1px solid #3b82f6;color:#fff}.create-folder-confirm:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.create-folder-confirm:disabled{cursor:not-allowed;opacity:.5}@media (max-width:480px){.sessions-header{padding:.75rem}.sessions-tabs{margin:.75rem}.sessions-search{margin:0 .75rem .75rem}.sessions-list{padding:0 .75rem 5rem}.sessions-fab{bottom:1rem;right:1rem}.permanent-delete-overlay{padding:.5rem}.permanent-delete-modal{max-width:none}.permanent-delete-actions,.permanent-delete-content,.permanent-delete-header{padding-left:1rem;padding-right:1rem}.create-folder-overlay{padding:.5rem}.create-folder-modal{max-width:none}.create-folder-actions,.create-folder-content,.create-folder-header{padding-left:1rem;padding-right:1rem}}.folder-management-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10000}.folder-management-modal{background:#fff;border-radius:12px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;max-height:80vh;max-width:400px;width:100%}.folder-management-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;justify-content:space-between;padding:1rem 1.5rem}.folder-management-header h3{color:#111827;font-size:1.125rem;font-weight:600;margin:0}.folder-management-done{background:none;border:none;border-radius:.375rem;color:#3b82f6;cursor:pointer;font-size:1rem;font-weight:500;padding:.25rem .5rem;transition:background-color .2s}.folder-management-done:hover{background:#f3f4f6}.folder-management-content{flex:1 1;overflow-y:auto;padding:1rem 1.5rem}.create-folder-button{background:#f3f4f6;border:2px dashed #d1d5db;border-radius:.5rem;color:#6b7280;cursor:pointer;font-size:.95rem;font-weight:500;margin-bottom:1.5rem;padding:.875rem;transition:all .2s;width:100%}.create-folder-button:hover{background:#e5e7eb;border-color:#9ca3af;color:#4b5563}.no-folders-message{color:#6b7280;padding:2rem 0;text-align:center}.no-folders-message p{font-size:.95rem;margin:0 0 .5rem}.no-folders-message p:last-child{margin-bottom:0}.folder-management-list{display:flex;flex-direction:column;gap:.75rem}.folder-management-item{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;justify-content:space-between;padding:1rem;transition:all .2s}.folder-management-item:hover{background:#f3f4f6;border-color:#d1d5db}.folder-info{align-items:center;display:flex;flex:1 1;gap:.75rem}.folder-color-indicator{border:2px solid #fff;border-radius:50%;box-shadow:0 0 0 1px #0000001a;flex-shrink:0;height:16px;width:16px}.folder-details{flex:1 1}.folder-name{color:#111827;font-size:1rem;font-weight:500;margin-bottom:.25rem}.folder-session-count{color:#6b7280;font-size:.875rem}.folder-actions{display:flex;gap:.5rem}.folder-delete-button{align-items:center;background:none;border:none;border-radius:.375rem;cursor:pointer;display:flex;font-size:1.25rem;justify-content:center;padding:.5rem;transition:all .2s}.folder-delete-button:hover{background:#fef2f2}@media (max-width:640px){.folder-management-modal{margin:.5rem;max-height:85vh;max-width:none}.folder-management-content,.folder-management-header{padding-left:1rem;padding-right:1rem}.folder-management-item{padding:.875rem}.folder-name{font-size:.95rem}.folder-session-count{font-size:.8rem}}.folder-delete-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10001}.folder-delete-modal{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #0006;display:flex;flex-direction:column;max-height:80vh;max-width:400px;overflow:hidden;width:100%}.folder-delete-header{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;gap:.75rem;padding:1.5rem 1.5rem 1rem}.folder-delete-icon{align-items:center;background:#fee2e2;border-radius:50%;display:flex;font-size:1.5rem;justify-content:center;padding:.5rem}.folder-delete-header h3{color:#111827;font-size:1.25rem;font-weight:600;margin:0}.folder-delete-content{flex:1 1;overflow-y:auto;padding:1rem 1.5rem}.folder-delete-folder-info{align-items:center;background:#f9fafb;border-radius:.75rem;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem}.folder-delete-color-indicator{border:2px solid #fff;border-radius:50%;box-shadow:0 0 0 1px #0000001a;flex-shrink:0;height:20px;width:20px}.folder-delete-details{flex:1 1}.folder-delete-name{color:#111827;font-size:1.125rem;font-weight:600;margin-bottom:.25rem}.folder-delete-session-count{color:#6b7280;font-size:.875rem}.folder-delete-warning{background:#fef3f2;border:1px solid #fecaca;border-radius:.75rem;padding:1rem}.folder-delete-warning-title{align-items:center;color:#dc2626;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin-bottom:.75rem}.folder-delete-warning p{color:#7c2d12;font-size:.95rem;margin:0 0 .75rem}.folder-delete-items{color:#7c2d12;margin:.75rem 0;padding-left:1.25rem}.folder-delete-items li{font-size:.95rem;margin-bottom:.5rem}.folder-delete-final-warning{border-top:1px solid #f3c6c6;color:#991b1b!important;font-weight:600!important;margin-top:1rem!important;padding-top:1rem;text-align:center}.folder-delete-actions{border-top:1px solid #f3f4f6;display:flex;gap:.75rem;padding:1rem 1.5rem 1.5rem}.folder-delete-cancel,.folder-delete-confirm{border:none;border-radius:.75rem;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.875rem 1rem;transition:all .2s}.folder-delete-cancel{background:#f3f4f6;color:#374151}.folder-delete-cancel:hover{background:#e5e7eb}.folder-delete-confirm{background:#dc2626;color:#fff}.folder-delete-confirm:hover{background:#b91c1c}.folder-delete-confirm:active{background:#991b1b;transform:scale(.98)}@media (max-width:640px){.folder-delete-modal{border-radius:12px;margin:.5rem;max-height:85vh;max-width:none}.folder-delete-header{padding:1.25rem 1rem .75rem}.folder-delete-content{padding:.75rem 1rem}.folder-delete-actions{flex-direction:column;gap:.5rem;padding:.75rem 1rem 1rem}.folder-delete-cancel,.folder-delete-confirm{width:100%}.folder-delete-folder-info{padding:.75rem}.folder-delete-name{font-size:1rem}}.mobile-change-password-dialog-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;padding:max(20px,env(safe-area-inset-top,0px) + 80px) max(20px,env(safe-area-inset-right,0px) + 20px) max(20px,env(safe-area-inset-bottom,0px) + 20px) max(20px,env(safe-area-inset-left,0px) + 20px);position:fixed;right:0;top:0;z-index:10000}.mobile-change-password-dialog{-webkit-overflow-scrolling:touch;animation:slideUp .3s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;margin:auto;max-height:calc(100vh - 160px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));max-width:500px;overflow-y:auto;position:relative;width:100%}.mobile-change-password-dialog-header{align-items:center;border-bottom:none;display:flex;justify-content:space-between;padding:24px 24px 0}.mobile-change-password-dialog-title{color:#1f2937;font-size:28px;font-weight:600;margin:0}.mobile-change-password-dialog-close{align-items:center;background:none;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;font-size:36px;height:44px;justify-content:center;line-height:1;padding:8px;transition:color .2s ease;width:44px}.mobile-change-password-dialog-close:hover{background:#f3f4f6;color:#374151}.mobile-change-password-dialog-content{padding:20px 24px 24px}.mobile-change-password-error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#dc2626;font-size:16px;font-weight:500;margin-bottom:20px;padding:16px;text-align:center}.mobile-change-password-form{display:flex;flex-direction:column}.mobile-change-password-form-group{margin-bottom:20px}.mobile-change-password-input{-webkit-appearance:none;appearance:none;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;box-sizing:border-box;font-size:18px;font-weight:500;padding:16px;transition:all .2s ease;width:100%}.mobile-change-password-input:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.mobile-change-password-input:disabled{cursor:not-allowed;opacity:.6}.mobile-change-password-input::placeholder{color:#9ca3af;font-weight:400}.mobile-change-password-requirements{color:#6b7280;font-size:14px;line-height:1.4;margin-bottom:24px;text-align:center}.mobile-change-password-buttons{display:flex;gap:12px;margin-top:8px}.mobile-change-password-button-cancel,.mobile-change-password-button-primary{border:none;border-radius:12px;cursor:pointer;flex:1 1;font-size:18px;font-weight:600;padding:16px 20px;transition:all .2s ease}.mobile-change-password-button-cancel{background:#f3f4f6;border:2px solid #e5e7eb;color:#374151}.mobile-change-password-button-cancel:hover:not(:disabled){background:#e5e7eb;transform:translateY(-1px)}.mobile-change-password-button-primary{background:linear-gradient(135deg,#4f46e5,#7c3aed);box-shadow:0 4px 12px #4f46e54d;color:#fff}.mobile-change-password-button-primary:hover:not(:disabled){box-shadow:0 6px 16px #4f46e566;transform:translateY(-1px)}.mobile-change-password-button-cancel:disabled,.mobile-change-password-button-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.mobile-change-password-button-cancel:active:not(:disabled),.mobile-change-password-button-primary:active:not(:disabled){transform:translateY(0)}.mobile-change-password-success{padding:40px 20px;text-align:center}.mobile-change-password-success-icon{color:#10b981;font-size:72px;line-height:1;margin-bottom:20px}.mobile-change-password-success-message{color:#1f2937;font-size:18px;font-weight:500;line-height:1.5}@media (max-width:480px){.mobile-change-password-dialog-overlay{align-items:flex-start;justify-content:center;padding:max(10px,env(safe-area-inset-top,0px) + 70px) 10px max(10px,env(safe-area-inset-bottom,0px) + 10px)}.mobile-change-password-dialog{border-radius:16px;margin-top:0;max-height:calc(100vh - 140px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px))}.mobile-change-password-dialog-header{padding:20px 20px 0}.mobile-change-password-dialog-title{font-size:24px}.mobile-change-password-dialog-close{font-size:32px;height:40px;width:40px}.mobile-change-password-dialog-content{padding:16px 20px 20px}.mobile-change-password-input{border-radius:10px;font-size:16px;padding:14px}.mobile-change-password-form-group{margin-bottom:16px}.mobile-change-password-error-message{border-radius:10px;font-size:14px;padding:12px}.mobile-change-password-requirements{font-size:12px;margin-bottom:20px}.mobile-change-password-buttons{flex-direction:column;gap:8px}.mobile-change-password-button-cancel,.mobile-change-password-button-primary{border-radius:10px;font-size:16px;padding:14px 18px}.mobile-change-password-success{padding:30px 15px}.mobile-change-password-success-icon{font-size:60px;margin-bottom:16px}.mobile-change-password-success-message{font-size:16px}}@media (max-width:375px) and (max-height:700px){.mobile-change-password-dialog-overlay{align-items:flex-start;justify-content:center;padding:max(8px,env(safe-area-inset-top,0px) + 60px) 8px max(8px,env(safe-area-inset-bottom,0px) + 8px)}.mobile-change-password-dialog{border-radius:12px;margin-top:0;max-height:calc(100vh - 120px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px))}.mobile-change-password-dialog-header{padding:16px 16px 0}.mobile-change-password-dialog-title{font-size:20px}.mobile-change-password-dialog-content{padding:12px 16px 16px}.mobile-change-password-input{font-size:16px;padding:12px}.mobile-change-password-form-group{margin-bottom:14px}.mobile-change-password-requirements{margin-bottom:16px}.mobile-change-password-success{padding:25px 10px}.mobile-change-password-success-icon{font-size:50px;margin-bottom:12px}.mobile-change-password-success-message{font-size:15px}}.mobile-dashboard-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #fff3;box-sizing:border-box;display:flex;gap:10px;justify-content:space-between;left:0;max-width:100vw;min-height:60px;overflow:visible;padding:20px 15px;position:fixed;right:0;top:env(safe-area-inset-top,0);width:100vw;z-index:1000}@media (max-width:480px){.mobile-dashboard-header{gap:8px;padding:15px 10px}}@media (max-width:375px){.mobile-dashboard-header{gap:6px;padding:15px 8px}}@supports (-webkit-touch-callout:none){.mobile-dashboard-header{height:50px!important;min-height:50px!important;padding:10px 15px!important}}.mobile-patient-selector-trigger{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-sizing:border-box;cursor:pointer;display:flex;flex:1 1;font-size:16px;font-weight:600;max-width:calc(100vw - 140px);min-width:160px;overflow:hidden;padding:12px 16px;transition:all .2s ease}@media (max-width:480px){.mobile-patient-selector-trigger{font-size:15px;max-width:calc(100vw - 80px);min-width:140px;padding:10px 12px}}@media (max-width:375px){.mobile-patient-selector-trigger{font-size:14px;max-width:calc(100vw - 70px);min-width:120px;padding:8px 10px}}.mobile-patient-selector-trigger:hover{background:#fafbff;border-color:#3b82f6}.mobile-patient-name{color:#374151;flex:1 1;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.mobile-patient-count{color:#6b7280;font-size:12px;font-weight:500;margin-left:8px}.mobile-patient-info-icon{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;flex-shrink:0;font-size:16px;height:32px;justify-content:center;margin-left:8px;min-width:32px;padding:6px 8px;transition:all .2s ease}.mobile-patient-info-icon:hover{background:#3b82f626;transform:scale(1.05)}.mobile-dropdown-arrow{color:#6b7280;font-size:12px;margin-left:8px;transition:transform .2s ease}.mobile-patient-selector-container{align-items:center;display:flex;flex:1 1;overflow:visible;position:relative}.mobile-patient-selector{background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 24px #00000026;left:0;max-height:80vh;min-width:250px;overflow:visible;position:absolute;top:calc(100% + 4px);width:100%;z-index:99999}.mobile-patient-list{-webkit-overflow-scrolling:touch;max-height:400px;overflow-y:auto;position:relative}.mobile-patient-list:before{background:linear-gradient(180deg,#fff 0,#fff0);top:0}.mobile-patient-list:after,.mobile-patient-list:before{content:"";height:20px;left:0;pointer-events:none;position:-webkit-sticky;position:sticky;right:0;z-index:1}.mobile-patient-list:after{background:linear-gradient(0deg,#fff 0,#fff0);bottom:0}.mobile-patient-list.scrollable-top:before{background:linear-gradient(180deg,#ffffffe6 0,#fff0);box-shadow:0 2px 4px #0000001a}.mobile-patient-list.scrollable-bottom:after{background:linear-gradient(0deg,#ffffffe6 0,#fff0);box-shadow:0 -2px 4px #0000001a}.mobile-patient-item{background:none;border:none;border-bottom:1px solid #f3f4f6;color:#374151;cursor:pointer;display:block;font-size:16px;font-weight:500;padding:16px 20px;text-align:left;transition:all .2s ease;width:100%}.mobile-patient-item:hover{background:#f8fafc;color:#1d4ed8}.mobile-patient-item.active{background:#eff6ff;color:#1d4ed8;font-weight:600}.mobile-patient-item:last-child{border-bottom:none}.mobile-new-patient-button{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-top:1px solid #e5e7eb;color:#fff;cursor:pointer;display:block;font-size:16px;font-weight:600;padding:16px 20px;transition:all .2s ease;width:100%}.mobile-new-patient-button:hover{background:linear-gradient(135deg,#2563eb,#1e40af)}.mobile-manage-patients-button{background:linear-gradient(135deg,#6b7280,#4b5563);border:none;border-radius:8px;border-top:1px solid #e5e7eb;color:#fff;cursor:pointer;display:block;flex-shrink:0;font-size:14px;font-weight:600;margin:4px 8px 8px;padding:12px;transition:all .2s ease;width:100%;width:calc(100% - 16px)}.mobile-manage-patients-button:hover{box-shadow:0 4px 12px #6b72804d;transform:translateY(-1px)}.mobile-done-editing-button{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;border-top:1px solid #e5e7eb;color:#fff;cursor:pointer;display:block;flex-shrink:0;font-size:14px;font-weight:600;margin:8px;padding:12px;transition:all .2s ease;width:100%;width:calc(100% - 16px)}.mobile-done-editing-button:hover{box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.mobile-patient-item-container{border-bottom:1px solid #f3f4f6}.mobile-patient-item-container:last-child{border-bottom:none}.mobile-patient-edit-item{align-items:center;background:none;border:none;display:flex;justify-content:space-between;padding:16px 20px;width:100%}.mobile-patient-name-edit{color:#374151;flex:1 1;font-size:16px;font-weight:500;text-align:left}.mobile-patient-actions{display:flex;gap:8px}.mobile-delete-action,.mobile-edit-action{align-items:center;background:none;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:18px;height:36px;justify-content:center;min-width:36px;padding:8px;transition:all .2s ease}.mobile-edit-action:hover{background:#3b82f61a}.mobile-delete-action:hover:not(:disabled){background:#ef44441a}.mobile-delete-action:disabled{cursor:not-allowed;opacity:.5}.mobile-hamburger-button{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;border-radius:50%;box-shadow:0 4px 12px #4f46e54d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:48px;justify-content:center;min-height:48px;min-width:48px;overflow:hidden;position:relative;transition:all .2s ease;width:48px}@media (max-width:480px){.mobile-hamburger-button{font-size:16px;height:44px;min-height:44px;min-width:44px;width:44px}}@media (max-width:375px){.mobile-hamburger-button{font-size:14px;height:40px;min-height:40px;min-width:40px;width:40px}}.mobile-profile-pic{border-radius:50%;height:100%;object-fit:cover;transition:opacity .2s ease;width:100%}.mobile-profile-pic.loading{opacity:.7}.mobile-profile-pic.loaded{opacity:1}.mobile-hamburger-icon{font-weight:700}.mobile-hamburger-button:hover{box-shadow:0 6px 16px #4f46e566;transform:scale(1.05)}.mobile-hamburger-overlay{align-items:flex-start;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;display:flex;justify-content:flex-end;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1002}.mobile-hamburger-menu{background:#fff;border-radius:16px;box-shadow:0 12px 32px #0003;margin-top:calc(50px + env(safe-area-inset-top, 0px));min-width:200px;overflow:hidden}.mobile-menu-header{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;display:flex;justify-content:space-between;padding:20px}.mobile-menu-header h3{font-size:18px;font-weight:600;margin:0}.mobile-close-menu{background:none;border:none;color:#fff;cursor:pointer;font-size:20px;line-height:1;padding:4px}.mobile-menu-items{padding:0}.mobile-menu-user-info{background:#f8fafc;border-bottom:1px solid #f3f4f6;padding:16px 20px}.mobile-menu-user-name{color:#1f2937;font-size:16px;font-weight:600;margin-bottom:4px}.mobile-menu-user-email{color:#6b7280;font-size:14px}.mobile-menu-item{background:none;border:none;border-bottom:1px solid #f3f4f6;color:#374151;cursor:pointer;display:block;font-size:16px;font-weight:500;padding:16px 20px;text-align:left;transition:all .2s ease;width:100%}.mobile-menu-item:hover{background:#f8fafc}.mobile-menu-item.change-password{color:#4f46e5}.mobile-menu-item.change-password:hover{background:#f0f9ff;color:#3730a3}.mobile-menu-item.logout{color:#dc2626}.mobile-menu-item.logout:hover{background:#fef2f2}@media (prefers-color-scheme:dark){.mobile-dashboard-header{background:#1e1e1ef2;border-bottom:1px solid #ffffff1a}.mobile-patient-selector,.mobile-patient-selector-trigger{background:#1f2937;border-color:#374151;color:#f9fafb}.mobile-patient-name{color:#f9fafb}.mobile-patient-item{border-bottom-color:#374151;color:#f9fafb}.mobile-patient-item:hover{background:#374151;color:#93c5fd}.mobile-patient-item.active{background:#1e3a8a;color:#93c5fd}.mobile-patient-name-edit{color:#f9fafb}.mobile-hamburger-menu{background:#1f2937}.mobile-menu-item{border-bottom-color:#374151;color:#f9fafb}.mobile-menu-item:hover{background:#374151}.mobile-menu-item.change-password{color:#818cf8}.mobile-menu-item.change-password:hover{background:#312e81;color:#c7d2fe}.mobile-menu-user-info{background:#374151;border-bottom-color:#4b5563}.mobile-menu-user-name{color:#f9fafb}.mobile-menu-user-email{color:#9ca3af}.mobile-patient-info-icon{color:#fff}.mobile-patient-info-icon:hover{background:#ffffff26}}.patient-edit-dialog-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;box-sizing:border-box;display:flex;height:100%;justify-content:center;left:0;padding:20px;position:fixed;top:0;width:100%;z-index:99999}.patient-edit-dialog{animation:scaleIn .2s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 10px 25px #00000026;display:flex;flex-direction:column;max-height:90vh;max-width:400px;overflow:hidden;width:100%}.patient-edit-dialog-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px 20px 15px}.patient-edit-dialog-title{color:#1d1d1f;font-size:18px;font-weight:600;margin:0}.patient-edit-dialog-close{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:18px;height:30px;justify-content:center;padding:5px;transition:background-color .2s;width:30px}.patient-edit-dialog-close:hover{background-color:#f0f0f0}.patient-edit-dialog-close:disabled{cursor:not-allowed;opacity:.5}.patient-edit-dialog-content{flex:1 1;overflow-y:auto;padding:0 20px}.patient-edit-form-group{margin-bottom:16px}.patient-edit-form-label{color:#333;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.patient-edit-form-input,.patient-edit-form-select{background-color:#fff;border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:16px;padding:12px;transition:border-color .2s;width:100%}.patient-edit-form-input:focus,.patient-edit-form-select:focus{border-color:#007aff;box-shadow:0 0 0 3px #007aff1a;outline:none}.patient-edit-form-input:disabled,.patient-edit-form-select:disabled{background-color:#f5f5f5;color:#666}.patient-edit-form-input::placeholder{color:#999}.patient-edit-dialog-buttons{border-top:1px solid #e0e0e0;display:flex;gap:12px;padding:20px}.patient-edit-button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:16px;font-weight:500;padding:12px 16px;transition:background-color .2s}.patient-edit-button-cancel{background-color:#f0f0f0;color:#333}.patient-edit-button-cancel:hover{background-color:#e0e0e0}.patient-edit-button-save{background-color:#007aff;color:#fff}.patient-edit-button-save:hover{background-color:#0056b3}.patient-edit-button:disabled{cursor:not-allowed;opacity:.5}.patient-edit-button-save:disabled{background-color:#ccc}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width:480px){.patient-edit-dialog-overlay{padding:10px}.patient-edit-dialog{max-width:none;width:100%}.patient-edit-dialog-header{padding:15px 15px 0}.patient-edit-dialog-title{font-size:16px}.patient-edit-dialog-content{padding:0 15px}.patient-edit-dialog-buttons{padding:15px}.patient-edit-form-input,.patient-edit-form-select{font-size:16px}}.patient-edit-form-readonly{background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;box-sizing:border-box;color:#666;font-size:16px;padding:12px}.patient-edit-consent-toggle{align-items:center;display:flex;gap:1rem}.patient-edit-consent-checkbox{display:none}.patient-edit-consent-slider{align-items:center;cursor:pointer;display:flex;gap:.75rem;-webkit-user-select:none;user-select:none}.patient-edit-consent-slider-track{background:#d1d5db;border-radius:.75rem;flex-shrink:0;height:1.5rem;position:relative;transition:background-color .2s;width:3rem}.patient-edit-consent-slider.active .patient-edit-consent-slider-track{background:#007aff}.patient-edit-consent-slider-thumb{background:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;height:1.25rem;left:.125rem;position:absolute;top:.125rem;transition:transform .2s;width:1.25rem}.patient-edit-consent-slider.active .patient-edit-consent-slider-thumb{transform:translateX(1.5rem)}.patient-edit-consent-label{color:#333;font-size:14px;font-weight:500;transition:color .2s}.patient-edit-consent-slider.active .patient-edit-consent-label{color:#007aff}.patient-edit-section{margin-bottom:1rem}.patient-edit-readonly-section{background-color:#fafafa;border-top:1px solid #e0e0e0;margin-left:-20px;margin-right:-20px;margin-top:1rem;padding:1rem 20px}.patient-edit-section-title{color:#666;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:.75rem;text-transform:uppercase}.patient-edit-info-list{display:flex;flex-direction:column;gap:8px}.patient-edit-info-item{align-items:flex-start;display:flex;justify-content:space-between;line-height:1.4}.patient-edit-info-label{color:#666;flex-shrink:0;font-size:14px;font-weight:500;min-width:90px}.patient-edit-info-value{color:#333;flex:1 1;font-size:14px;margin-left:8px;text-align:right}@media (max-width:480px){.patient-edit-readonly-section{margin-left:-15px;margin-right:-15px;padding-left:15px;padding-right:15px}.patient-edit-info-label{font-size:13px;min-width:80px}.patient-edit-info-value{font-size:13px;text-align:right}}.patient-edit-info-icon{cursor:pointer;display:inline-block;font-size:14px;margin-left:8px;opacity:.7;transition:opacity .2s ease;-webkit-user-select:none;user-select:none;vertical-align:middle}.patient-edit-info-icon:hover{opacity:1}.patient-edit-template-info{animation:slideDown .2s ease-out;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;font-size:13px;line-height:1.4;margin-top:12px;padding:12px}.template-info-item{color:#495057;margin-bottom:8px}.template-info-item:last-child{margin-bottom:0}.template-info-item strong{color:#212529;font-weight:600}.mobile-soap-tiptap-container{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.mobile-soap-tiptap-container .ProseMirror{-webkit-overflow-scrolling:touch!important;border:1px solid #ccc;border-radius:8px;box-sizing:border-box;font-size:16px;height:100%;line-height:1.5;overflow-y:auto!important;padding:12px;touch-action:pan-y!important}.notification{background:#10b981;border-radius:8px;box-shadow:0 4px 12px #00000026;color:#fff;font-size:14px;padding:12px 16px;position:fixed;right:20px;top:70px;z-index:1000}.mobile-soap-dialog-overlay{align-items:center;background:#0009;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.mobile-soap-dialog{animation:dialogSlideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000004d;max-height:80vh;max-width:400px;overflow:hidden;width:100%}@keyframes dialogSlideIn{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.mobile-soap-dialog-header{border-bottom:1px solid #e5e7eb;padding:24px 24px 16px}.mobile-soap-dialog-header h3{color:#dc2626;font-size:20px;font-weight:600;margin:0}.mobile-soap-dialog-body{color:#374151;line-height:1.6;padding:20px 24px}.mobile-soap-dialog-body p{margin:0 0 12px}.mobile-soap-dialog-body p:last-child{margin-bottom:0}.mobile-soap-dialog-actions{display:flex;gap:12px;justify-content:flex-end;padding:16px 24px 24px}.mobile-soap-dialog-cancel,.mobile-soap-dialog-confirm{border:none;border-radius:8px;cursor:pointer;font-weight:500;min-width:100px;padding:12px 20px;transition:all .2s ease}.mobile-soap-dialog-cancel{background:#f3f4f6;color:#374151}.mobile-soap-dialog-cancel:hover{background:#e5e7eb}.mobile-soap-dialog-confirm{background:#dc2626;color:#fff}.mobile-soap-dialog-confirm:hover{background:#b91c1c}.mobile-soap-dialog-confirm:active{transform:translateY(1px)}.mobile-soap-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;box-shadow:0 4px 12px #0000001a;box-sizing:border-box;display:flex;flex-direction:column;height:100%;margin:0 8px 16px;padding:20px 8px;touch-action:auto!important}body.safari-mobile .mobile-soap-container{margin-top:-16px!important;transform:translateY(-8px)}@media not all and (-webkit-min-device-pixel-ratio:0),not all and (min-resolution:.001dpcm){@supports (-webkit-appearance:none){.mobile-soap-container{margin-top:-12px!important;position:relative;top:-8px}}}@media screen and (-webkit-min-device-pixel-ratio:0){.mobile-soap-container{margin-top:-10px!important}}.mobile-soap-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;gap:12px;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.mobile-create-soap-button{background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;border-radius:12px;box-shadow:0 4px 12px #4f46e54d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;min-width:160px;padding:12px 20px;text-align:center;transition:all .2s ease}.mobile-create-soap-button:hover:not(.disabled){box-shadow:0 6px 16px #4f46e566;transform:translateY(-2px)}.mobile-create-soap-button:active:not(.disabled){transform:translateY(0)}.mobile-create-soap-button.loading{background:#6b7280;cursor:not-allowed;overflow:hidden;position:relative}.mobile-create-soap-button.loading:after{animation:mobile-soap-loading 2s linear infinite;background:linear-gradient(90deg,#4f46e5,#7c3aed);border-radius:0 0 12px 12px;bottom:0;content:"";height:4px;left:0;position:absolute;width:0}@keyframes mobile-soap-loading{0%{width:0}to{width:100%}}.mobile-create-soap-button.disabled{background:#9ca3af;box-shadow:0 2px 4px #9ca3af33;cursor:not-allowed;transform:none}.mobile-soap-edit-toggle{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;color:#475569;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;justify-content:center;min-width:80px;padding:8px 16px;transition:all .2s ease}.mobile-soap-edit-toggle:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px)}.mobile-soap-edit-toggle.active{background:#10b981;border-color:#059669;color:#fff}.mobile-soap-edit-toggle.active:hover{background:#059669}.mobile-soap-edit-toggle .edit-icon{font-size:16px}.mobile-soap-edit-toggle .edit-text{font-weight:600}.mobile-soap-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:16px;padding:12px}.mobile-soap-error p{color:#dc2626;flex-grow:1;font-size:14px;margin:0}.mobile-error-dismiss{align-items:center;background:none;border:none;border-radius:50%;color:#dc2626;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;margin-left:12px;padding:0;transition:background-color .2s ease;width:24px}.mobile-error-dismiss:hover{background-color:#dc26261a}.mobile-soap-content{min-height:0;touch-action:auto!important}.mobile-soap-content,.mobile-soap-display{display:flex;flex:1 1;flex-direction:column}.mobile-soap-format-note{background:#f3f4f6;border-left:3px solid #4f46e5;border-radius:6px;margin-bottom:8px;padding:8px 12px}.mobile-soap-format-note small{color:#6b7280;font-size:12px;font-style:italic}.mobile-soap-display-area{-webkit-overflow-scrolling:touch;overflow-scrolling:touch;background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;box-sizing:border-box;flex:1 1;max-height:calc(100vh - 280px);max-height:calc(100dvh - 280px);min-height:200px;overflow-y:scroll;overflow:auto;padding:16px;pointer-events:auto;position:relative;touch-action:pan-y;transform:translateZ(0);width:100%;will-change:scroll-position;z-index:1}.mobile-soap-content-text{background:none;border:none;margin:0;outline:none;white-space:pre-wrap}.mobile-soap-content-html,.mobile-soap-content-text{word-wrap:break-word;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5}.mobile-soap-content-html p{line-height:1.6;margin:0 0 12px}.mobile-soap-content-html b,.mobile-soap-content-html strong{color:#111827;font-weight:700}.mobile-soap-content-html em,.mobile-soap-content-html i{font-style:italic}.mobile-soap-content-html ol,.mobile-soap-content-html ul{margin:8px 0 16px;padding-left:20px}.mobile-soap-content-html li{line-height:1.5;margin:4px 0}.mobile-soap-content-html ul li{list-style-type:disc}.mobile-soap-content-html ol li{list-style-type:decimal}.mobile-soap-content-html h1,.mobile-soap-content-html h2,.mobile-soap-content-html h3{color:#111827;font-weight:600;margin:16px 0 8px}.mobile-soap-content-html h1{font-size:20px}.mobile-soap-content-html h2{font-size:18px}.mobile-soap-content-html h3{font-size:16px}.mobile-soap-content-html br{line-height:1.5}.mobile-soap-edit-container{display:flex;flex-direction:column;height:100%;position:relative;transform:translateZ(0);width:100%}.mobile-quill-editor{-webkit-overflow-scrolling:touch;background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100%;min-height:400px;touch-action:pan-y;width:100%}.mobile-quill-editor .ql-toolbar{-webkit-overflow-scrolling:touch;background:#f8fafc;border:none;border-bottom:2px solid #e2e8f0;border-radius:8px 8px 0 0;overflow-x:auto;padding:8px 12px;white-space:nowrap}.mobile-quill-editor .ql-toolbar button{border:1px solid #0000!important;border-radius:6px!important;height:32px!important;margin:2px!important;transition:all .2s ease!important;width:32px!important}.mobile-quill-editor .ql-toolbar button.ql-active,.mobile-quill-editor .ql-toolbar button:hover{background:#e2e8f0!important;border-color:#cbd5e1!important}.mobile-quill-editor .ql-toolbar .ql-picker{color:#374151}.mobile-quill-editor .ql-toolbar .ql-picker-label{border:1px solid #0000;border-radius:6px;font-size:14px;padding:4px 8px}.mobile-quill-editor .ql-toolbar .ql-picker-label:hover{background:#e2e8f0}.mobile-quill-editor .ql-container{-webkit-overflow-scrolling:touch;border:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px!important;height:350px;max-height:calc(100vh - 250px);overflow-y:auto;touch-action:pan-y}.mobile-quill-editor .ql-editor{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;color:#374151;font-size:16px!important;line-height:1.6;min-height:350px;overflow:visible;overscroll-behavior-y:contain;padding:16px;touch-action:pan-y;transform:scale(1);-webkit-transform:translateZ(0);transform-origin:left top;will-change:transform}.mobile-quill-editor .ql-editor:focus{outline:none}.mobile-quill-editor .ql-editor h1,.mobile-quill-editor .ql-editor h2,.mobile-quill-editor .ql-editor h3{color:#111827;font-weight:600;margin:16px 0 8px}.mobile-quill-editor .ql-editor h1{font-size:20px}.mobile-quill-editor .ql-editor h2{font-size:18px}.mobile-quill-editor .ql-editor h3{font-size:16px}.mobile-quill-editor .ql-editor p{line-height:1.6;margin:0 0 12px}.mobile-quill-editor .ql-editor strong{color:#111827;font-weight:700}.mobile-quill-editor .ql-editor em{font-style:italic}.mobile-quill-editor .ql-editor ol,.mobile-quill-editor .ql-editor ul{margin:8px 0 16px;padding-left:20px}.mobile-quill-editor .ql-editor ul li{list-style-type:disc;margin:4px 0}.mobile-quill-editor .ql-editor ol li{list-style-type:decimal;margin:4px 0}.mobile-soap-textarea{-webkit-tap-highlight-color:transparent;word-wrap:break-word;-webkit-overflow-scrolling:touch;-webkit-text-size-adjust:100%;-webkit-appearance:none;background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px!important;height:100%;line-height:1.6;min-height:400px;overflow-x:hidden;overflow-y:auto;padding:16px;resize:vertical;scroll-behavior:smooth;touch-action:pan-y;transition:border-color .2s ease;-webkit-user-select:text;user-select:text;width:100%}.mobile-soap-textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}@media (max-width:480px){.mobile-quill-editor{min-height:300px}.mobile-quill-editor .ql-container{height:250px;max-height:calc(100vh - 200px)}.mobile-quill-editor .ql-toolbar{padding:6px 8px}.mobile-quill-editor .ql-toolbar button{height:28px!important;margin:1px!important;width:28px!important}.mobile-quill-editor .ql-editor{font-size:14px!important;padding:12px}}@media (max-width:375px){.mobile-quill-editor{min-height:250px}.mobile-quill-editor .ql-container{height:200px;max-height:calc(100vh - 180px)}.mobile-quill-editor .ql-toolbar button{height:26px!important;width:26px!important}.mobile-quill-editor .ql-editor{padding:10px}}.mobile-soap-edit-status{align-items:center;display:flex;justify-content:flex-end;min-height:32px;padding:8px 0}.typing-indicator{color:#10b981}.saving-indicator,.typing-indicator{align-items:center;display:flex;font-size:14px;font-weight:500;gap:4px}.saving-indicator{color:#3b82f6}.mobile-soap-empty{align-items:center;color:#6b7280;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.mobile-soap-empty-icon{font-size:48px;margin-bottom:16px}.mobile-soap-empty h3{color:#374151;font-size:20px;font-weight:600;margin:0 0 12px}.mobile-soap-empty p{color:#6b7280;font-size:16px;line-height:1.5;margin:0;max-width:300px}@media (max-width:480px){.mobile-soap-container{margin:4px;padding:16px 6px}.mobile-soap-header{align-items:stretch;flex-direction:column;gap:12px}.mobile-soap-title{font-size:20px;text-align:center}.mobile-create-soap-button{font-size:16px;padding:16px;width:100%}.mobile-soap-textarea{font-size:14px;padding:12px}.mobile-soap-empty-icon{font-size:40px}.mobile-soap-empty h3{font-size:18px}.mobile-soap-empty p{font-size:14px}}@supports (-webkit-touch-callout:none){.mobile-soap-container{max-height:calc(100vh - 140px)!important;max-height:calc(100dvh - 140px)!important;overflow:hidden}.mobile-soap-content,.mobile-soap-display{flex:1 1;min-height:0;overflow:hidden}.mobile-soap-display-area{-webkit-overflow-scrolling:touch;max-height:calc(100vh - 250px)!important;max-height:calc(100dvh - 250px)!important;padding-bottom:24px!important}@media (max-width:480px){.mobile-soap-container{max-height:calc(100vh - 130px)!important;max-height:calc(100dvh - 130px)!important}.mobile-soap-display-area{max-height:calc(100vh - 230px)!important;max-height:calc(100dvh - 230px)!important;padding-bottom:32px!important}}@media (max-width:375px){.mobile-soap-container{max-height:calc(100vh - 120px)!important;max-height:calc(100dvh - 120px)!important}.mobile-soap-display-area{max-height:calc(100vh - 220px)!important;max-height:calc(100dvh - 220px)!important;padding-bottom:40px!important}}}@media (max-width:768px) and (-webkit-min-device-pixel-ratio:0){.mobile-soap-container{max-height:calc(100vh - 135px)!important;max-height:calc(100dvh - 135px)!important}.mobile-soap-display-area{max-height:calc(100vh - 240px)!important;max-height:calc(100dvh - 240px)!important;padding-bottom:28px!important}}@media (max-width:375px){.mobile-soap-container{margin:2px;padding:12px 4px}.mobile-soap-title{font-size:18px}.mobile-create-soap-button{font-size:15px;padding:14px}.mobile-soap-textarea{font-size:14px;padding:10px}}.mobile-soap-edit-modal-overlay{-webkit-overflow-scrolling:touch;background:#000000f2;bottom:0;display:flex;flex-direction:column;height:100vh;height:100dvh;left:0;max-width:100vw;min-height:-webkit-fill-available;overflow-x:hidden;position:fixed;right:0;top:0;touch-action:auto;width:100%;z-index:10000}.mobile-soap-edit-modal{background:#fff;box-sizing:border-box;display:flex;flex-direction:column;height:100%;max-width:100%;min-height:100vh;min-height:100dvh;min-height:-webkit-fill-available;overflow:hidden;overflow-x:hidden;width:100%}.mobile-soap-edit-modal-header{align-items:center;background:#f8fafc;border-bottom:2px solid #e2e8f0;display:flex;flex-shrink:0;justify-content:space-between;padding:16px 20px}.mobile-soap-edit-modal-header h3{color:#1f2937;font-size:20px;font-weight:600;margin:0}.mobile-soap-edit-modal-close{align-items:center;background:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:6px;justify-content:center;min-width:80px;padding:10px 16px;transition:all .2s ease}.mobile-soap-edit-modal-close .save-icon{font-size:16px}.mobile-soap-edit-modal-close .save-text{font-size:16px;font-weight:600}.mobile-soap-edit-modal-close:hover{background:#059669;transform:translateY(-1px)}.mobile-soap-edit-modal-close:active{transform:translateY(0)}.mobile-soap-edit-modal-content{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden;padding:20px}.mobile-soap-edit-modal-textarea{-webkit-tap-highlight-color:transparent;word-wrap:break-word;-webkit-overflow-scrolling:touch;-webkit-text-size-adjust:100%;-webkit-appearance:none;background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#374151;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px!important;height:100%;line-height:1.6;min-height:100%;outline:none;overflow-x:hidden;overflow-y:auto;padding:16px;resize:none;scroll-behavior:smooth;touch-action:pan-y;transform:translateZ(0);-webkit-user-select:text;user-select:text;width:100%;will-change:scroll-position}.mobile-soap-edit-modal-textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.mobile-soap-edit-modal-quill .ql-toolbar{-webkit-overflow-scrolling:touch;align-items:center;background:#f8fafc;border:none;border-bottom:1px solid #e2e8f0;border-radius:8px 8px 0 0;display:flex;flex-shrink:0;gap:2px;justify-content:center;min-height:32px;overflow-x:auto;padding:4px 8px;white-space:nowrap}.mobile-soap-edit-modal-quill .ql-toolbar button{border:1px solid #0000!important;border-radius:3px!important;flex-shrink:0;font-size:12px!important;height:22px!important;margin:1px!important;transition:all .2s ease!important;width:22px!important}.mobile-soap-edit-modal-quill .ql-toolbar button.ql-active,.mobile-soap-edit-modal-quill .ql-toolbar button:hover{background:#e2e8f0!important;border-color:#cbd5e1!important}.mobile-soap-edit-modal-quill .ql-toolbar .ql-picker{color:#374151}.mobile-soap-edit-modal-quill .ql-toolbar .ql-picker-label{border:1px solid #0000;border-radius:6px;font-size:14px;min-width:60px;padding:6px 10px}.mobile-soap-edit-modal-quill .ql-toolbar .ql-picker-label:hover{background:#e2e8f0}.mobile-soap-edit-modal-quill .ql-container{border:none;display:flex;flex:1 1;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px!important;overflow:hidden}.mobile-soap-edit-modal-quill .ql-editor{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;-webkit-overflow-scrolling:touch!important;-ms-overflow-style:none;word-wrap:break-word;color:#374151;flex:1 1;font-size:16px!important;line-height:1.6;overflow-x:hidden;overflow-y:auto!important;overscroll-behavior-y:contain;padding:16px;pointer-events:auto!important;position:relative;scroll-behavior:smooth;scrollbar-width:none;touch-action:pan-y!important;transform:translateZ(0);-webkit-user-select:text;user-select:text;will-change:scroll-position;z-index:1}.mobile-soap-edit-modal-quill .ql-editor::-webkit-scrollbar{display:none}.mobile-soap-edit-modal-quill .ql-editor:focus{outline:none}.mobile-soap-edit-modal-quill .ql-editor h1,.mobile-soap-edit-modal-quill .ql-editor h2,.mobile-soap-edit-modal-quill .ql-editor h3{color:#111827;font-weight:600;margin:16px 0 8px}.mobile-soap-edit-modal-quill .ql-editor h1{font-size:20px}.mobile-soap-edit-modal-quill .ql-editor h2{font-size:18px}.mobile-soap-edit-modal-quill .ql-editor h3{font-size:16px}.mobile-soap-edit-modal-quill .ql-editor p{line-height:1.6;margin:0 0 12px}.mobile-soap-edit-modal-quill .ql-editor strong{color:#111827;font-weight:700}.mobile-soap-edit-modal-quill .ql-editor em{font-style:italic}.mobile-soap-edit-modal-quill .ql-editor ol,.mobile-soap-edit-modal-quill .ql-editor ul{margin:8px 0 16px;padding-left:20px}.mobile-soap-edit-modal-quill .ql-editor ul li{list-style-type:disc;margin:4px 0}.mobile-soap-edit-modal-quill .ql-editor ol li{list-style-type:decimal;margin:4px 0}.mobile-soap-scroll-controls{display:flex;flex-direction:column;gap:8px;position:absolute;right:2px;top:50%;transform:translateY(-50%);z-index:10}.mobile-soap-scroll-button{align-items:center;background:#ffffffe6;border:2px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#374151;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:32px;justify-content:center;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:32px}.mobile-soap-scroll-button:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.mobile-soap-scroll-button:active{background:#f1f5f9;box-shadow:0 1px 2px #0000001a;transform:translateY(0)}.mobile-soap-scroll-down,.mobile-soap-scroll-up{color:#4f46e5}.mobile-soap-edit-modal-footer{align-items:center;background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;flex-shrink:0;justify-content:center;min-height:60px;padding:16px 20px}.mobile-soap-edit-modal-footer .saving-indicator,.mobile-soap-edit-modal-footer .typing-indicator{align-items:center;display:flex;font-size:16px;font-weight:500;gap:6px}.mobile-soap-edit-modal-footer .typing-indicator{color:#10b981}.mobile-soap-edit-modal-footer .saving-indicator{color:#3b82f6}.mobile-soap-edit-modal-overlay{animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.mobile-soap-edit-modal{animation:modalSlideUp .3s ease-out}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.mobile-soap-edit-modal-header{padding:12px 16px}.mobile-soap-edit-modal-header h3{font-size:18px}.mobile-soap-edit-modal-close{font-size:14px;min-width:70px;padding:8px 12px}.mobile-soap-edit-modal-close .save-icon,.mobile-soap-edit-modal-close .save-text{font-size:14px}.mobile-soap-edit-modal-content{padding:16px}.mobile-soap-edit-modal-textarea{font-size:16px!important;padding:12px}.mobile-soap-edit-modal-footer{min-height:50px;padding:12px 16px}}@media (max-width:375px){.mobile-soap-edit-modal-header{padding:10px 12px}.mobile-soap-edit-modal-header h3{font-size:16px}.mobile-soap-edit-modal-content{padding:12px}.mobile-soap-edit-modal-textarea{font-size:16px!important;padding:10px}.mobile-soap-edit-modal-footer{padding:10px 12px}}@supports (-webkit-touch-callout:none){.mobile-soap-edit-modal-overlay{height:100vh!important;height:100dvh!important;max-width:100vw!important;min-height:-webkit-fill-available!important;overflow-x:hidden!important;width:100%!important}.mobile-soap-edit-modal{box-sizing:border-box!important;height:100%!important;max-width:100%!important;min-height:100vh!important;min-height:100dvh!important;min-height:-webkit-fill-available!important;overflow-x:hidden!important;width:100%!important}}@media not all and (-webkit-min-device-pixel-ratio:0),not all and (min-resolution:.001dpcm){@supports (-webkit-appearance:none){.mobile-soap-edit-modal-overlay{height:100vh!important;height:100dvh!important;max-width:100vw!important;min-height:-webkit-fill-available!important;overflow-x:hidden!important;width:100%!important}.mobile-soap-edit-modal{box-sizing:border-box!important;max-width:100%!important;min-height:100vh!important;min-height:100dvh!important;min-height:-webkit-fill-available!important;overflow-x:hidden!important;width:100%!important}}}.mobile-dashboard{height:100dvh;min-height:100dvh}@supports (-webkit-appearance:none){.mobile-dashboard{height:-webkit-fill-available;min-height:-webkit-fill-available}}.mobile-no-sessions-state{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:40px 20px;text-align:center}.no-sessions-icon{font-size:64px;margin-bottom:20px;opacity:.7}.mobile-no-sessions-state h2{color:#2c3e50;font-size:24px;font-weight:600;margin:0 0 12px}.mobile-no-sessions-state p{color:#6c757d;line-height:1.5;margin:0 0 20px;max-width:300px}.mobile-dashboard{background:url(/static/media/login-background.cf69af04fc81f375d9c8.jpg) 50%/cover no-repeat,linear-gradient(135deg,#667eeacc,#764ba2cc);background-position:50%;background-repeat:no-repeat;background-size:cover;box-sizing:border-box;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh;margin:0;max-width:100vw;min-height:100vh;padding:0;position:relative;width:100vw}.mobile-dashboard *{box-sizing:border-box;touch-action:none}.mobile-dashboard .ProseMirror,.mobile-dashboard .ProseMirror *,.mobile-dashboard .mobile-editor-content,.mobile-dashboard .mobile-editor-content *,.mobile-dashboard .mobile-notes-tiptap-container,.mobile-dashboard .mobile-notes-tiptap-container *,.mobile-dashboard .mobile-soap-display-area,.mobile-dashboard .mobile-soap-display-area *,.mobile-dashboard .mobile-soap-tiptap-container,.mobile-dashboard .mobile-soap-tiptap-container *,.mobile-dashboard .mobile-tiptap-container,.mobile-dashboard .mobile-tiptap-container *,.mobile-dashboard .mobile-tiptap-editor,.mobile-dashboard .mobile-tiptap-editor *,.mobile-dashboard .mobile-tiptap-editor-wrapper,.mobile-dashboard .mobile-tiptap-editor-wrapper *,.mobile-dashboard .mobile-transcript-tiptap-container,.mobile-dashboard .mobile-transcript-tiptap-container *,.mobile-dashboard [data-scrollable=true],.mobile-dashboard [data-scrollable=true] *{-webkit-overflow-scrolling:touch!important;touch-action:pan-y!important}.mobile-dashboard{-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none;z-index:1}@supports (-webkit-appearance:none){.mobile-dashboard{background-position:50% 50%!important;background-size:cover!important}}.mobile-dashboard-content{bottom:calc(80px + env(safe-area-inset-bottom, 0px));box-sizing:border-box;display:flex;flex-direction:column;left:0;max-width:100vw;overflow:hidden;padding:10px 20px;position:fixed;right:0;top:calc(60px + env(safe-area-inset-top, 0px));touch-action:none;width:100%}body.safari-mobile .mobile-dashboard-content{padding-top:2px!important;top:calc(50px + env(safe-area-inset-top, 0px))!important}@supports (-webkit-touch-callout:none){.mobile-dashboard-content{padding-top:2px!important;top:calc(50px + env(safe-area-inset-top, 0px))!important}}@media screen and (-webkit-min-device-pixel-ratio:0){.mobile-dashboard-content{padding-top:2px!important;top:calc(50px + env(safe-area-inset-top, 0px))!important}}.mobile-dashboard-content .ProseMirror,.mobile-dashboard-content .ProseMirror *,.mobile-dashboard-content .mobile-editor-content,.mobile-dashboard-content .mobile-editor-content *,.mobile-dashboard-content .mobile-notes-tiptap-container,.mobile-dashboard-content .mobile-notes-tiptap-container *,.mobile-dashboard-content .mobile-soap-display-area,.mobile-dashboard-content .mobile-soap-display-area *,.mobile-dashboard-content .mobile-soap-tiptap-container,.mobile-dashboard-content .mobile-soap-tiptap-container *,.mobile-dashboard-content .mobile-tiptap-container,.mobile-dashboard-content .mobile-tiptap-container *,.mobile-dashboard-content .mobile-tiptap-editor,.mobile-dashboard-content .mobile-tiptap-editor *,.mobile-dashboard-content .mobile-tiptap-editor-wrapper,.mobile-dashboard-content .mobile-tiptap-editor-wrapper *,.mobile-dashboard-content .mobile-transcript-tiptap-container,.mobile-dashboard-content .mobile-transcript-tiptap-container *,.mobile-dashboard-content [data-scrollable=true],.mobile-dashboard-content [data-scrollable=true] *{-webkit-overflow-scrolling:touch!important;touch-action:pan-y!important}@media screen and (-webkit-min-device-pixel-ratio:0){:root .mobile-dashboard-content,_::-webkit-full-page-media,_:future{padding-top:0!important;top:35px!important}}@supports not (-webkit-touch-callout:none){.mobile-dashboard-content{bottom:90px;top:70px}}.mobile-patient-info{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;box-shadow:0 4px 12px #0000001a;box-sizing:border-box;margin-bottom:16px;max-width:100%;overflow-x:hidden;padding:16px;position:relative;text-align:center;width:100%;z-index:1}.mobile-patient-info h2{color:#1f2937;font-size:24px;font-weight:700;margin:0 0 8px}.mobile-appointment-type{color:#4f46e5;font-size:16px;font-weight:600;margin:0 0 4px}.mobile-session-info{color:#6b7280;font-size:14px;font-weight:500;margin:0}.mobile-action-buttons{box-sizing:border-box;contain:layout style;display:flex;flex:1 1;flex-direction:column;gap:12px;justify-content:flex-start;max-width:100vw;overflow:hidden;padding-top:10px;touch-action:none;width:100%}.mobile-action-buttons .ProseMirror,.mobile-action-buttons .ProseMirror *,.mobile-action-buttons .mobile-editor-content,.mobile-action-buttons .mobile-editor-content *,.mobile-action-buttons .mobile-notes-tiptap-container,.mobile-action-buttons .mobile-notes-tiptap-container *,.mobile-action-buttons .mobile-soap-display-area,.mobile-action-buttons .mobile-soap-display-area *,.mobile-action-buttons .mobile-soap-tiptap-container,.mobile-action-buttons .mobile-soap-tiptap-container *,.mobile-action-buttons .mobile-tiptap-container,.mobile-action-buttons .mobile-tiptap-container *,.mobile-action-buttons .mobile-tiptap-editor,.mobile-action-buttons .mobile-tiptap-editor *,.mobile-action-buttons .mobile-tiptap-editor-wrapper,.mobile-action-buttons .mobile-tiptap-editor-wrapper *,.mobile-action-buttons .mobile-transcript-tiptap-container,.mobile-action-buttons .mobile-transcript-tiptap-container *,.mobile-action-buttons [data-scrollable=true],.mobile-action-buttons [data-scrollable=true] *{-webkit-overflow-scrolling:touch!important;touch-action:pan-y!important}.mobile-consent-notice{background:#3b82f61a;border:2px solid #3b82f64d;border-radius:12px;box-sizing:border-box;margin-bottom:8px;max-width:100%;overflow-x:hidden;padding:16px;width:100%}.mobile-consent-notice p{color:#1e40af;font-size:14px;font-weight:500;line-height:1.5;margin:0;text-align:center}.mobile-medical-recording-status{background:#22c55e1a;border:2px solid #22c55e4d;border-radius:12px;box-sizing:border-box;margin-bottom:8px;max-width:100%;overflow-x:hidden;padding:12px 16px;width:100%}.medical-status-row{align-items:center;display:flex;gap:8px;margin:4px 0}.medical-status-row .status-icon{font-size:14px;min-width:16px}.medical-status-row .status-text{color:#15803d;font-size:13px;font-weight:500;line-height:1.4}.mobile-consent-button{background:#fff;border:3px solid #fbbf24;border-radius:16px;box-shadow:0 4px 12px #fbbf2433;color:#92400e;cursor:pointer;font-size:18px;font-weight:600;padding:20px;transition:all .2s ease}.mobile-consent-button.granted{background:#10b981;border-color:#10b981;box-shadow:0 4px 12px #10b9814d;color:#fff}.mobile-consent-button.not-granted{background:#fbbf24;border-color:#fbbf24;box-shadow:0 4px 12px #fbbf244d;color:#fff}.mobile-consent-button.disabled{cursor:not-allowed;opacity:.6;transform:none!important}.mobile-consent-button:hover:not(.disabled){box-shadow:0 6px 16px #fbbf2466;transform:translateY(-2px)}.mobile-consent-button.granted:hover:not(.disabled){box-shadow:0 6px 16px #10b98166}.mobile-record-container{align-items:center;box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;gap:20px;justify-content:center;max-width:100%;min-height:0;overflow:hidden;padding:10px 0;position:relative;touch-action:manipulation;width:100%}@media (max-width:480px){.mobile-record-container{gap:15px;padding:5px 0}}@media (max-width:375px){.mobile-record-container{gap:12px;padding:5px 0}}.mobile-record-button-container{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:12px}.mobile-record-button{align-items:center;background:linear-gradient(145deg,#ef4444,#dc2626 50%,#b91c1c);border:3px solid #fff3;border-radius:50%;box-shadow:0 8px 16px #ef444466,0 4px 8px #0003,inset 0 2px 4px #ffffff4d,inset 0 -2px 4px #0000004d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:28px;height:100px;justify-content:center;margin:8px;position:relative;touch-action:manipulation;transform:perspective(100px) rotateX(5deg);transition:all .2s ease;width:100px;z-index:10}@media (max-width:480px){.mobile-record-button{font-size:24px;height:85px;margin:6px;width:85px}}@media (max-width:375px){.mobile-record-button{font-size:22px;height:75px;margin:6px;width:75px}}.record-icon{color:#fff;font-size:28px}.stop-icon{color:#fff;font-size:24px}@media (max-width:480px){.record-icon{font-size:24px}.stop-icon{font-size:20px}}@media (max-width:375px){.record-icon{font-size:22px}.stop-icon{font-size:18px}}.record-button-text{color:#fff;font-size:18px;font-weight:600;line-height:1.3;text-align:center;text-shadow:0 2px 4px #0000004d}@keyframes micPulse{0%{box-shadow:0 0 0 0 #10b98166;transform:scale(1)}50%{box-shadow:0 0 0 8px #10b9811a;transform:scale(1.1)}to{box-shadow:0 0 0 0 #10b98100;transform:scale(1)}}.audio-level-display{align-items:center;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#1f2937f2;border:3px solid #6b728080;border-radius:16px;box-shadow:0 8px 32px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;flex-shrink:0;gap:8px;height:120px;max-width:calc(100vw - 40px);overflow:hidden;padding:12px;position:relative;touch-action:manipulation;transition:all .3s ease;width:240px;z-index:5}@media (max-width:480px){.audio-level-display{gap:6px;height:100px;padding:10px;width:200px}}@media (max-width:375px){.audio-level-display{gap:5px;height:85px;padding:8px;width:180px}}.audio-level-display.idle{background:#1f2937b3;border-color:#6b728080}.audio-level-display.recording{background:#1f2937f2;border-color:#3b82f6cc}.audio-level-display.active{border-color:#10b981e6;box-shadow:0 0 24px #10b98180,0 8px 32px #0000004d;transform:scale(1.05)}.segment-container{align-items:end;box-sizing:border-box;display:flex;gap:8px;height:55px;justify-content:center;max-width:100%;overflow:hidden;width:100%}@media (max-width:480px){.segment-container{gap:6px;height:40px}}@media (max-width:375px){.segment-container{gap:5px;height:35px}}.audio-segment{background:#6b728099;border:1px solid #9ca3af80;border-radius:8px;box-shadow:inset 0 1px 2px #0003;min-height:8px;transition:all .15s ease;width:16px}.audio-segment:first-child{height:12px!important}.audio-segment:nth-child(2){height:18px!important}.audio-segment:nth-child(3){height:24px!important}.audio-segment:nth-child(4){height:30px!important}.audio-segment:nth-child(5){height:36px!important}.audio-segment:nth-child(6){height:42px!important}.audio-segment:nth-child(7){height:48px!important}.audio-segment:nth-child(8){height:52px!important}@media (max-width:480px){.audio-segment:first-child{height:8px!important}.audio-segment:nth-child(2){height:12px!important}.audio-segment:nth-child(3){height:16px!important}.audio-segment:nth-child(4){height:20px!important}.audio-segment:nth-child(5){height:24px!important}.audio-segment:nth-child(6){height:28px!important}.audio-segment:nth-child(7){height:32px!important}.audio-segment:nth-child(8){height:36px!important}}@media (max-width:375px){.audio-segment:first-child{height:6px!important}.audio-segment:nth-child(2){height:9px!important}.audio-segment:nth-child(3){height:12px!important}.audio-segment:nth-child(4){height:15px!important}.audio-segment:nth-child(5){height:18px!important}.audio-segment:nth-child(6){height:21px!important}.audio-segment:nth-child(7){height:24px!important}.audio-segment:nth-child(8){height:30px!important}}.audio-segment.low.lit{background:linear-gradient(0deg,#10b981,#34d399);border-color:#10b981cc;box-shadow:0 0 8px #10b981cc,0 0 16px #10b98166;transform:scaleY(1.1)}.audio-segment.medium.lit{background:linear-gradient(0deg,#f59e0b,#fbbf24);border-color:#f59e0bcc;box-shadow:0 0 8px #f59e0bcc,0 0 16px #f59e0b66;transform:scaleY(1.1)}.audio-segment.high.lit{animation:highLevelPulse .5s infinite alternate;background:linear-gradient(0deg,#ef4444,#f87171);border-color:#ef4444cc;box-shadow:0 0 8px #ef4444cc,0 0 16px #ef444466;transform:scaleY(1.1)}.display-status{border-radius:8px;box-shadow:0 2px 8px #0000004d;font-size:16px;font-weight:900;letter-spacing:2px;margin-top:8px;padding:8px 12px;text-align:center;text-transform:uppercase;transition:all .3s ease}.audio-level-display.idle .display-status{background:#6b728066;border:2px solid #6b728099;color:#9ca3af}.audio-level-display.recording .display-status{animation:statusPulse 2s ease-in-out infinite;background:#3b82f64d;border:2px solid #3b82f6cc;box-shadow:0 0 12px #3b82f680,0 2px 8px #0000004d;color:#3b82f6}.audio-level-display.active .display-status{background:#10b9814d;border:2px solid #10b981cc;box-shadow:0 0 12px #10b98180,0 2px 8px #0000004d;color:#10b981}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes highLevelPulse{0%{box-shadow:0 0 8px #ef4444cc,0 0 16px #ef444466;transform:scaleY(1.1)}to{box-shadow:0 0 12px #ef4444,0 0 24px #ef444499;transform:scaleY(1.2)}}.mobile-record-button.recording{animation:pulse 2s infinite;background:linear-gradient(145deg,#10b981,#059669 50%,#047857);box-shadow:0 8px 16px #10b98166,0 4px 8px #0003,inset 0 2px 4px #ffffff4d,inset 0 -2px 4px #0000004d;transform:perspective(100px) rotateX(5deg)}@supports (-webkit-touch-callout:none){.mobile-record-button.recording{animation:none}.mobile-record-button{border:4px solid #ffffff4d!important;box-shadow:0 8px 20px #ef444480,0 4px 10px #0000004d,inset 0 2px 0 #fff6,inset 0 -2px 0 #0000004d!important;transform:none!important}.mobile-record-button:hover:not(.disabled){box-shadow:0 12px 25px #ef444499,0 6px 15px #0006,inset 0 3px 0 #ffffff80,inset 0 -3px 0 #0006!important;transform:translateY(-3px)!important}.mobile-record-button:active:not(.disabled){box-shadow:0 4px 10px #ef444480,0 2px 5px #0000004d,inset 0 1px 0 #ffffff4d,inset 0 -1px 0 #0000004d!important;transform:translateY(-1px)!important}.mobile-record-button.recording{box-shadow:0 8px 20px #10b98180,0 4px 10px #0000004d,inset 0 2px 0 #fff6,inset 0 -2px 0 #0000004d!important}.mobile-record-button.recording:hover:not(.disabled){box-shadow:0 12px 25px #10b98199,0 6px 15px #0006,inset 0 3px 0 #ffffff80,inset 0 -3px 0 #0006!important;transform:translateY(-3px)!important}.mobile-record-button.disabled{box-shadow:0 4px 10px #9ca3af66,0 2px 5px #0003,inset 0 1px 0 #ffffff4d,inset 0 -1px 0 #0000004d!important;transform:none!important}}@supports (-webkit-touch-callout:none) and (not (transform-style:preserve-3d)){.mobile-record-button{border:3px solid #fff6!important;box-shadow:0 6px 15px #ef444466,inset 0 2px 0 #ffffff4d,inset 0 -2px 0 #0003!important}}@supports not (-webkit-touch-callout:none){.mobile-record-button{-webkit-backface-visibility:hidden;backface-visibility:hidden}}.mobile-record-button.disabled{animation:none;background:linear-gradient(145deg,#9ca3af,#6b7280 50%,#4b5563);box-shadow:0 4px 8px #9ca3af4d,0 2px 4px #0000001a,inset 0 1px 2px #fff3,inset 0 -1px 2px #0003;cursor:not-allowed;opacity:.6;transform:perspective(100px) rotateX(5deg)!important}.mobile-record-button:hover:not(.disabled){box-shadow:0 12px 24px #ef444480,0 6px 12px #0000004d,inset 0 3px 6px #fff6,inset 0 -3px 6px #0006;transform:perspective(100px) rotateX(5deg) translateY(-3px)}.mobile-record-button:active:not(.disabled){box-shadow:0 4px 8px #ef444466,0 2px 4px #0003,inset 0 1px 2px #fff3,inset 0 -1px 2px #0003;transform:perspective(100px) rotateX(5deg) translateY(-1px)}.mobile-record-button.recording:hover:not(.disabled){box-shadow:0 12px 24px #10b98180,0 6px 12px #0000004d,inset 0 3px 6px #fff6,inset 0 -3px 6px #0006;transform:perspective(100px) rotateX(5deg) translateY(-3px)}.mobile-consent-confirmation{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}.mobile-consent-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:16px;max-width:400px;padding:24px;width:100%}.mobile-consent-modal h3{color:#1f2937;font-size:20px;font-weight:600;margin:0 0 16px;text-align:center}.mobile-consent-modal p{color:#6b7280;font-size:16px;line-height:1.5;margin:0 0 24px;text-align:center}.mobile-consent-buttons{display:flex;gap:12px}.mobile-consent-cancel,.mobile-consent-confirm{border-radius:8px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px 16px;transition:all .2s ease}.mobile-consent-cancel{background:#f3f4f6;border:1px solid #d1d5db;color:#374151}.mobile-consent-cancel:hover{background:#e5e7eb}.mobile-consent-confirm{background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;color:#fff}.mobile-consent-confirm:hover{box-shadow:0 4px 12px #4f46e54d;transform:translateY(-1px)}.mobile-consent-confirm:disabled{cursor:not-allowed;opacity:.6;transform:none}.mobile-empty-state{align-items:center;display:flex;flex:1 1;justify-content:center;padding:40px 20px;text-align:center}.mobile-empty-state p{color:#fffc;font-size:18px;margin:0}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px) scaleY(.8);transform-origin:top}to{opacity:1;transform:translateY(0) scaleY(1);transform-origin:top}}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{opacity:1;transform:perspective(100px) rotateX(5deg) scale(1)}50%{opacity:.8;transform:perspective(100px) rotateX(5deg) scale(1)}}@keyframes recordingDotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.8)}}.recording-dot{animation:recordingDotPulse 1s infinite!important}@media (max-width:480px){.mobile-dashboard-header{margin-top:env(safe-area-inset-top,0);min-height:60px;padding:16px}.mobile-patient-selector-trigger{font-size:14px;min-width:150px}.mobile-patient-selector-overlay{padding:16px}.mobile-patient-selector{max-height:75vh}.mobile-patient-list{margin-top:4px;max-height:350px;padding:12px 8px 8px}.mobile-patient-item{font-size:15px;padding:14px}.mobile-patient-item:first-child{margin-top:12px}.mobile-hamburger-button{font-size:16px;height:44px;width:44px}.mobile-dashboard-content{margin-top:calc(110px + env(safe-area-inset-top, 0px));padding:20px max(16px,env(safe-area-inset-right,0px) + 8px) max(20px,env(safe-area-inset-bottom,0px) + 16px) max(16px,env(safe-area-inset-left,0px) + 8px)}.mobile-patient-info{padding:20px}.mobile-patient-info h2{font-size:20px}.mobile-consent-button{font-size:16px;padding:16px}.mobile-record-button-container{gap:12px}.mobile-record-button{font-size:28px;height:100px;width:100px}.record-icon{font-size:28px}.stop-icon{font-size:24px}.record-button-text{font-size:16px}.mobile-record-container{gap:40px;max-width:100vw;overflow-x:hidden}.audio-level-display{gap:12px;height:160px;max-width:calc(100vw - 40px);overflow:hidden;padding:20px;width:200px}.segment-container{gap:8px;height:70px}.audio-segment{width:12px}.audio-segment:first-child{height:12px}.audio-segment:nth-child(2){height:18px}.audio-segment:nth-child(3){height:24px}.audio-segment:nth-child(4){height:30px}.audio-segment:nth-child(5){height:36px}.audio-segment:nth-child(6){height:42px}.audio-segment:nth-child(7){height:48px}.audio-segment:nth-child(8){height:54px}.display-status{font-size:14px;letter-spacing:1.5px;padding:6px 10px}}@supports (padding:max(0px)){.mobile-dashboard{min-height:100vh;min-height:calc(100vh + env(safe-area-inset-top) + env(safe-area-inset-bottom))}}@supports (-webkit-touch-callout:none){.audio-level-display{gap:8px!important;height:140px!important;margin-top:-5px!important;padding:10px!important}.segment-container{gap:6px!important;height:90px!important}.display-status{font-size:10px!important;height:auto!important;margin-top:2px!important;padding:2px 6px!important}.audio-segment:first-child{height:12px!important}.audio-segment:nth-child(2){height:20px!important}.audio-segment:nth-child(3){height:30px!important}.audio-segment:nth-child(4){height:40px!important}.audio-segment:nth-child(5){height:50px!important}.audio-segment:nth-child(6){height:60px!important}.audio-segment:nth-child(7){height:70px!important}.audio-segment:nth-child(8){height:80px!important}.mobile-record-container{gap:8px!important;padding:5px 0!important}.mobile-record-button-container{gap:6px!important}.mobile-patient-info{margin-bottom:2px!important}.mobile-action-buttons{gap:4px!important}}.audio-level-display{height:140px!important}.audio-level-display .segment-container{height:110px!important}.audio-level-display .segment-container .audio-segment:first-child{height:12px!important}.audio-level-display .segment-container .audio-segment:nth-child(2){height:20px!important}.audio-level-display .segment-container .audio-segment:nth-child(3){height:30px!important}.audio-level-display .segment-container .audio-segment:nth-child(4){height:40px!important}.audio-level-display .segment-container .audio-segment:nth-child(5){height:50px!important}.audio-level-display .segment-container .audio-segment:nth-child(6){height:60px!important}.audio-level-display .segment-container .audio-segment:nth-child(7){height:70px!important}.audio-level-display .segment-container .audio-segment:nth-child(8){height:85px!important}@media (max-width:480px){.audio-level-display{height:140px!important}.audio-level-display .segment-container{height:110px!important}.audio-level-display .segment-container .audio-segment:first-child{height:12px!important}.audio-level-display .segment-container .audio-segment:nth-child(2){height:20px!important}.audio-level-display .segment-container .audio-segment:nth-child(3){height:30px!important}.audio-level-display .segment-container .audio-segment:nth-child(4){height:40px!important}.audio-level-display .segment-container .audio-segment:nth-child(5){height:50px!important}.audio-level-display .segment-container .audio-segment:nth-child(6){height:60px!important}.audio-level-display .segment-container .audio-segment:nth-child(7){height:70px!important}.audio-level-display .segment-container .audio-segment:nth-child(8){height:85px!important}}@media (max-width:375px){.audio-level-display{height:140px!important}.audio-level-display .segment-container{height:110px!important}.audio-level-display .segment-container .audio-segment:first-child{height:12px!important}.audio-level-display .segment-container .audio-segment:nth-child(2){height:20px!important}.audio-level-display .segment-container .audio-segment:nth-child(3){height:30px!important}.audio-level-display .segment-container .audio-segment:nth-child(4){height:40px!important}.audio-level-display .segment-container .audio-segment:nth-child(5){height:50px!important}.audio-level-display .segment-container .audio-segment:nth-child(6){height:60px!important}.audio-level-display .segment-container .audio-segment:nth-child(7){height:70px!important}.audio-level-display .segment-container .audio-segment:nth-child(8){height:85px!important}}@media (max-width:768px){.mobile-dashboard-content{margin:0!important;padding:70px 20px 0!important;top:0!important}.mobile-dashboard-header{height:50px!important;min-height:50px!important;position:fixed!important;top:0!important;z-index:1002!important}}@media (max-width:768px) and (-webkit-min-device-pixel-ratio:0){.mobile-dashboard .mobile-dashboard-content.mobile-dashboard-content{margin-top:0!important;padding-top:60px!important}}@supports (-webkit-touch-callout:none){.mobile-dashboard .mobile-dashboard-content.mobile-dashboard-content.mobile-dashboard-content{margin-top:0!important;padding-top:60px!important}.mobile-transcript{margin-top:0!important;padding-top:0!important}.mobile-transcript-textarea{margin-top:0!important;padding-top:12px!important;touch-action:pan-y!important}.mobile-notes-container{margin-top:0!important;padding-top:0!important}.mobile-notes-textarea{margin-top:0!important;padding-top:12px!important;touch-action:pan-y!important}}.bottom-sheet-overlay{align-items:flex-end;animation:fadeInOverlay .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0006;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:99999}.bottom-sheet-content{animation:slideUpSheet .3s ease-out;background-color:#fff;border-top-left-radius:20px;border-top-right-radius:20px;box-shadow:0 -4px 20px #00000026;display:flex;flex-direction:column;max-height:80vh;max-width:480px;overflow:hidden;padding-bottom:env(safe-area-inset-bottom,0);width:100%}.bottom-sheet-header{border-bottom:1px solid #f0f0f0;margin-bottom:16px;padding:24px 24px 8px;position:relative;text-align:center}.bottom-sheet-header:before{background-color:#d1d5db;border-radius:2px;content:"";height:4px;left:50%;position:absolute;top:8px;transform:translateX(-50%);width:36px}.bottom-sheet-title{color:#1d1d1f;font-size:20px;font-weight:600;line-height:1.3;margin:0;outline:none}.bottom-sheet-title:focus{border-radius:4px;outline:2px solid #007aff;outline-offset:2px}.bottom-sheet-buttons{display:flex;flex:1 1;flex-direction:column;gap:12px;padding:0 24px 24px}.bottom-sheet-button{align-items:center;border:none;border-radius:12px;box-sizing:border-box;cursor:pointer;display:flex;font-size:16px;font-weight:500;justify-content:flex-start;min-height:56px;padding:16px 20px;position:relative;text-align:left;transition:all .2s ease;width:100%}.bottom-sheet-button:focus{outline:2px solid #007aff;outline-offset:2px}.bottom-sheet-button-primary{background-color:#007aff;box-shadow:0 2px 8px #007aff40;color:#fff}.bottom-sheet-button-primary:hover{background-color:#0056b3;box-shadow:0 4px 12px #007aff59;transform:translateY(-1px)}.bottom-sheet-button-primary:active{box-shadow:0 2px 6px #007aff40;transform:translateY(0)}.bottom-sheet-button-secondary{background-color:#f8f9fa;border:1px solid #e9ecef;color:#1d1d1f}.bottom-sheet-button-secondary:hover{background-color:#e9ecef;box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.bottom-sheet-button-secondary:active{background-color:#dee2e6;box-shadow:none;transform:translateY(0)}.button-content{align-items:flex-start;display:flex;flex-direction:column;width:100%}.button-main-text{font-size:16px;font-weight:500;line-height:1.3;margin-bottom:2px}.button-sub-text{font-size:14px;font-weight:400;line-height:1.2;opacity:.8}.bottom-sheet-button-primary .button-sub-text{color:#ffffffe6}.bottom-sheet-button-secondary .button-sub-text{color:#6c757d}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}@keyframes slideUpSheet{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.bottom-sheet-button,.bottom-sheet-content,.bottom-sheet-overlay{animation:none;transition:none}}@media (prefers-contrast:high){.bottom-sheet-button-primary{border:2px solid #0000}.bottom-sheet-button-secondary{border:2px solid #000}.bottom-sheet-button:focus{outline:3px solid;outline-offset:2px}}@media (max-width:480px){.bottom-sheet-header{padding:20px 20px 8px}.bottom-sheet-buttons{padding:0 20px 20px}.bottom-sheet-title{font-size:18px}.bottom-sheet-button{min-height:52px;padding:14px 16px}.button-main-text{font-size:15px}.button-sub-text{font-size:13px}}.bottom-sheet-button-primary .button-main-text,.bottom-sheet-button-primary .button-sub-text{color:#fff}.bottom-sheet-button-secondary .button-main-text{color:#1d1d1f}.button-unassigned:before{content:"⚠️";font-size:14px;margin-right:8px}.button-content .button-main-text{overflow-wrap:break-word;word-break:break-word}@media (max-width:360px){.button-main-text{font-size:14px}.button-sub-text{font-size:12px}.bottom-sheet-button{min-height:48px;padding:12px 16px}}
/*# sourceMappingURL=main.18633115.css.map*/