body,html{margin:0;padding:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-50:#f0f4f8;--primary-100:#d9e2ec;--primary-200:#bcccdc;--primary-300:#9fb3c8;--primary-400:#829ab1;--primary-500:#627d98;--primary-600:#486581;--primary-700:#334e68;--primary-800:#243b53;--primary-900:#102a43;--accent-500:#2d8a5d;--accent-600:#247a50;--gray-50:#f8f9fa;--gray-100:#f1f3f5;--gray-200:#e9ecef;--gray-300:#dee2e6;--gray-400:#ced4da;--gray-500:#adb5bd;--gray-600:#868e96;--gray-700:#495057;--gray-800:#343a40;--gray-900:#212529;--success:#2d8a5d;--success-light:#d4edda;--warning:#c9a227;--warning-light:#fff3cd;--danger:#c9302c;--danger-light:#f8d7da;--info:#2d6a8a;--info-light:#d1ecf1;--font-serif:"Source Serif 4",Georgia,serif;--font-sans:"Source Sans 3",-apple-system,BlinkMacSystemFont,sans-serif;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #00000012;--shadow-lg:0 10px 15px #0000001a;--shadow-xl:0 20px 25px #00000026;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--sidebar-width:260px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:#f1f3f5;background:var(--gray-100);color:#343a40;color:var(--gray-800);font-family:Source Sans\ 3,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-sans);line-height:1.6;min-height:100vh}a{color:#486581;color:var(--primary-600);text-decoration:none}a:hover{text-decoration:underline}.loading-screen{align-items:center;display:flex;flex-direction:column;gap:1rem;gap:var(--space-md);justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e9ecef;border-top-color:#486581;border:3px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary-600);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.loading-inline{color:#adb5bd;color:var(--gray-500);padding:2rem;padding:var(--space-xl);text-align:center}.auth-page{align-items:center;background:linear-gradient(135deg,#243b53,#102a43);background:linear-gradient(135deg,var(--primary-800) 0,var(--primary-900) 100%);display:flex;justify-content:center;min-height:100vh;padding:1.5rem;padding:var(--space-lg)}.auth-container{background:#fff;border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 20px 25px #00000026;box-shadow:var(--shadow-xl);max-width:400px;overflow:hidden;width:100%}.auth-header{background:#102a43;background:var(--primary-900);color:#fff;padding:2rem;padding:var(--space-xl);text-align:center}.auth-header h1{font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.75rem;font-weight:600;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.auth-header p{font-size:.9rem;opacity:.8}.auth-form{padding:2rem;padding:var(--space-xl)}.auth-form h2{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.25rem}.auth-error,.auth-form h2{margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.auth-error{background:#f8d7da;background:var(--danger-light);border-radius:8px;border-radius:var(--radius-md);color:#c9302c;color:var(--danger);font-size:.9rem;padding:1rem;padding:var(--space-md)}.form-group{margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.form-group label{color:#495057;color:var(--gray-700);display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.form-group input{border:1px solid #dee2e6;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);font-family:Source Sans\ 3,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-sans);font-size:1rem;padding:1rem;padding:var(--space-md);transition:border-color .2s,box-shadow .2s;width:100%}.form-group input:focus{border-color:#627d98;border-color:var(--primary-500);box-shadow:0 0 0 3px #4865811a;outline:none}.auth-btn{border:none;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 1.5rem;padding:var(--space-md) var(--space-lg);transition:all .2s;width:100%}.auth-btn.primary{background:#243b53;background:var(--primary-800);color:#fff}.auth-btn.primary:hover:not(:disabled){background:#102a43;background:var(--primary-900)}.auth-btn:disabled{cursor:not-allowed;opacity:.6}.auth-footer{background:#f8f9fa;background:var(--gray-50);color:#868e96;color:var(--gray-600);font-size:.9rem;padding:1.5rem 2rem;padding:var(--space-lg) var(--space-xl);text-align:center}.landing-page{display:flex;flex-direction:column;min-height:100vh}.landing-header{background:#102a43;background:var(--primary-900);color:#fff;padding:3rem;padding:var(--space-2xl);text-align:center}.landing-header h1{font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:2.5rem;font-weight:600;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.landing-header p{font-size:1.1rem;opacity:.8}.landing-main{flex:1 1;margin:0 auto;max-width:900px;padding:3rem;padding:var(--space-2xl);width:100%}.landing-hero{margin-bottom:3rem;margin-bottom:var(--space-2xl);text-align:center}.landing-hero h2{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.75rem;margin-bottom:1rem;margin-bottom:var(--space-md)}.landing-hero p{color:#868e96;color:var(--gray-600);font-size:1.1rem;margin:0 auto;max-width:600px}.landing-cards{grid-gap:1.5rem;grid-gap:var(--space-lg);display:grid;gap:1.5rem;gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.landing-card{align-items:center;background:#fff;border:2px solid #e9ecef;border:2px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);display:flex;flex-direction:column;padding:2rem;padding:var(--space-xl);text-align:center;text-decoration:none;transition:all .2s}.landing-card:hover{border-color:#627d98;border-color:var(--primary-500);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);text-decoration:none;transform:translateY(-2px)}.landing-card.highlight{background:linear-gradient(135deg,#fff,#d4edda);background:linear-gradient(135deg,#fff 0,var(--success-light) 100%);border-color:#2d8a5d;border-color:var(--accent-500)}.landing-card svg{color:#486581;color:var(--primary-600);margin-bottom:1rem;margin-bottom:var(--space-md)}.landing-card h3{color:#212529;color:var(--gray-900);font-size:1.1rem;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.landing-card p{color:#868e96;color:var(--gray-600);font-size:.9rem}.landing-footer{background:#f8f9fa;background:var(--gray-50);border-top:1px solid #e9ecef;border-top:1px solid var(--gray-200);padding:2rem;padding:var(--space-xl);text-align:center}.landing-footer p{color:#adb5bd;color:var(--gray-500);font-size:.85rem;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.dashboard{display:flex;min-height:100vh}.sidebar{background:#102a43;background:var(--primary-900);bottom:0;color:#fff;display:flex;flex-direction:column;left:0;position:fixed;top:0;transition:transform .3s;width:260px;width:var(--sidebar-width);z-index:100}.sidebar-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:1.5rem;padding:var(--space-lg)}.sidebar-header h1{font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.25rem;font-weight:600}.mobile-close{background:none;border:none;color:#fff;cursor:pointer;display:none}.sidebar-user{border-bottom:1px solid #ffffff1a;gap:1rem;gap:var(--space-md);padding:1.5rem;padding:var(--space-lg)}.sidebar-user,.user-avatar{align-items:center;display:flex}.user-avatar{background:#486581;background:var(--primary-600);border-radius:50%;font-weight:600;height:40px;justify-content:center;width:40px}.user-info{display:flex;flex-direction:column}.user-name{font-size:.95rem;font-weight:500}.user-role{font-size:.8rem;opacity:.7}.sidebar-nav{flex:1 1}.nav-item,.sidebar-nav{padding:1rem;padding:var(--space-md)}.nav-item{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--radius-md);color:#fffc;cursor:pointer;display:flex;font-size:.95rem;gap:1rem;gap:var(--space-md);text-align:left;transition:all .2s;width:100%}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#ffffff26;color:#fff}.nav-badge{background:#fff3;border-radius:100px;font-size:.8rem;margin-left:auto;padding:2px 8px}.sidebar-footer{border-top:1px solid #ffffff1a;padding:1rem;padding:var(--space-md)}.nav-item.logout{color:#fff9}.nav-item.logout:hover{background:#c9302c4d;color:#fff}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:260px;margin-left:var(--sidebar-width)}.main-header{align-items:center;background:#fff;border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--gray-200);display:flex;gap:1rem;gap:var(--space-md);padding:1.5rem 2rem;padding:var(--space-lg) var(--space-xl);position:-webkit-sticky;position:sticky;top:0;z-index:50}.mobile-menu-btn{background:none;border:none;color:#495057;color:var(--gray-700);cursor:pointer;display:none}.main-header h2{color:#212529;color:var(--gray-900);flex:1 1;font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.25rem;font-weight:600}.header-btn{align-items:center;background:#fff;border:1px solid #dee2e6;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);color:#495057;color:var(--gray-700);cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;gap:.5rem;gap:var(--space-sm);padding:.5rem 1rem;padding:var(--space-sm) var(--space-md);transition:all .2s}.header-btn:hover{background:#f8f9fa;background:var(--gray-50)}.header-btn.primary{background:#243b53;background:var(--primary-800);border-color:#243b53;border-color:var(--primary-800);color:#fff}.header-btn.primary:hover{background:#102a43;background:var(--primary-900)}.main-body{flex:1 1;overflow-y:auto;padding:2rem;padding:var(--space-xl)}.patient-list{max-width:900px}.list-header{margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.search-box{align-items:center;background:#fff;border:1px solid #dee2e6;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);display:flex;gap:.5rem;gap:var(--space-sm);max-width:400px;padding:1rem;padding:var(--space-md)}.search-box svg{color:#ced4da;color:var(--gray-400)}.search-box input{border:none;flex:1 1;font-size:.95rem;outline:none}.empty-state{color:#adb5bd;color:var(--gray-500);padding:3rem;padding:var(--space-2xl);text-align:center}.empty-state svg{color:#dee2e6;color:var(--gray-300);margin-bottom:1rem;margin-bottom:var(--space-md)}.empty-state h3{color:#495057;color:var(--gray-700);font-size:1.1rem;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.empty-state.small{padding:2rem;padding:var(--space-xl)}.empty-state.small svg{height:24px;width:24px}.patient-cards{display:flex;flex-direction:column;gap:.5rem;gap:var(--space-sm)}.patient-card{align-items:center;background:#fff;border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:1rem;gap:var(--space-md);padding:1.5rem;padding:var(--space-lg);transition:all .2s}.patient-card:hover{border-color:#9fb3c8;border-color:var(--primary-300);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md)}.patient-avatar{align-items:center;background:#d9e2ec;background:var(--primary-100);border-radius:50%;color:#334e68;color:var(--primary-700);display:flex;flex-shrink:0;font-size:1.1rem;font-weight:600;height:48px;justify-content:center;width:48px}.patient-avatar.large{font-size:1.5rem;height:64px;width:64px}.patient-info{flex:1 1;min-width:0}.patient-info h4{color:#212529;color:var(--gray-900);font-size:1rem;font-weight:600;margin-bottom:2px}.patient-info p{color:#adb5bd;color:var(--gray-500);font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.patient-phase{border-radius:100px;font-size:.8rem;font-weight:500;padding:4px 12px}.patient-status{color:#ced4da;color:var(--gray-400)}.patient-status.active{color:#2d8a5d;color:var(--success)}.patient-status.pending{color:#c9a227;color:var(--warning)}.patient-card .chevron{color:#ced4da;color:var(--gray-400)}.patient-detail{max-width:900px}.detail-header{align-items:center;background:#fff;border-radius:12px;border-radius:var(--radius-lg);display:flex;gap:1.5rem;gap:var(--space-lg);margin-bottom:2rem;margin-bottom:var(--space-xl);padding:2rem;padding:var(--space-xl)}.patient-header-info h2{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.5rem;margin-bottom:2px}.patient-header-info p{color:#adb5bd;color:var(--gray-500)}.phase-badge.large{border-radius:8px;border-radius:var(--radius-md);color:#fff;font-weight:600;margin-left:auto;padding:.5rem 1.5rem;padding:var(--space-sm) var(--space-lg)}.detail-section{margin-bottom:2rem;margin-bottom:var(--space-xl)}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem;margin-bottom:var(--space-md)}.section-header h3{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.1rem}.section-btn{align-items:center;background:#fff;border:1px solid #dee2e6;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);color:#868e96;color:var(--gray-600);cursor:pointer;display:inline-flex;font-size:.85rem;gap:.25rem;gap:var(--space-xs);padding:.5rem 1rem;padding:var(--space-sm) var(--space-md);transition:all .2s}.section-btn:hover{background:#f8f9fa;background:var(--gray-50);color:#343a40;color:var(--gray-800)}.phase-card{background:#fff;border-left:4px solid;border-radius:12px;border-radius:var(--radius-lg);padding:1.5rem;padding:var(--space-lg)}.phase-info h4{color:#212529;color:var(--gray-900);font-size:1.1rem;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.phase-info p{color:#868e96;color:var(--gray-600);margin-bottom:1rem;margin-bottom:var(--space-md)}.phase-meta{align-items:center;color:#adb5bd;color:var(--gray-500);display:flex;font-size:.85rem;gap:.25rem;gap:var(--space-xs)}.tools-grid{grid-gap:1rem;grid-gap:var(--space-md);display:grid;gap:1rem;gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.tool-card{align-items:center;background:#fff;border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;display:flex;flex-direction:column;gap:.5rem;gap:var(--space-sm);padding:1.5rem;padding:var(--space-lg);position:relative;text-align:center;transition:all .2s}.tool-card:hover{border-color:#829ab1;border-color:var(--primary-400);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md)}.tool-card svg{color:#486581;color:var(--primary-600)}.tool-name{color:#212529;color:var(--gray-900);font-size:.95rem;font-weight:600}.tool-desc{color:#adb5bd;color:var(--gray-500);font-size:.8rem}.tool-external{color:#ced4da;color:var(--gray-400);position:absolute;right:.5rem;right:var(--space-sm);top:.5rem;top:var(--space-sm)}.tool-card.large{padding:2rem;padding:var(--space-xl)}.tool-card.large svg:first-child{height:32px;width:32px}.activity-list{background:#fff;border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);overflow:hidden}.activity-item{align-items:center;border-bottom:1px solid #f1f3f5;border-bottom:1px solid var(--gray-100);display:flex;gap:1rem;gap:var(--space-md);padding:1rem 1.5rem;padding:var(--space-md) var(--space-lg)}.activity-item:last-child{border-bottom:none}.activity-icon{align-items:center;background:#f1f3f5;background:var(--gray-100);border-radius:50%;color:#adb5bd;color:var(--gray-500);display:flex;height:32px;justify-content:center;width:32px}.activity-info{flex:1 1}.activity-event{color:#343a40;color:var(--gray-800);display:block;font-size:.9rem;font-weight:500}.activity-time,.activity-tool{color:#adb5bd;color:var(--gray-500);font-size:.8rem}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1.5rem;padding:var(--space-lg);position:fixed;right:0;top:0;z-index:200}.modal{background:#fff;border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 20px 25px #00000026;box-shadow:var(--shadow-xl);max-height:90vh;max-width:480px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:1.5rem;padding:var(--space-lg)}.modal-header h3{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.1rem}.modal-header button{background:none;border:none;color:#adb5bd;color:var(--gray-500);cursor:pointer}.modal-body,.modal-footer{padding:1.5rem;padding:var(--space-lg)}.modal-footer{border-top:1px solid #e9ecef;border-top:1px solid var(--gray-200);display:flex;gap:1rem;gap:var(--space-md);justify-content:flex-end}.modal-btn{background:#fff;border:1px solid #dee2e6;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);color:#495057;color:var(--gray-700);cursor:pointer;font-size:.95rem;font-weight:500;padding:.5rem 1.5rem;padding:var(--space-sm) var(--space-lg);transition:all .2s}.modal-btn:hover{background:#f8f9fa;background:var(--gray-50)}.modal-btn.primary{background:#243b53;background:var(--primary-800);border-color:#243b53;border-color:var(--primary-800);color:#fff}.modal-btn.primary:hover:not(:disabled){background:#102a43;background:var(--primary-900)}.modal-btn:disabled{cursor:not-allowed;opacity:.6}.form-note{align-items:flex-start;background:#d1ecf1;background:var(--info-light);border-radius:8px;border-radius:var(--radius-md);color:#495057;color:var(--gray-700);display:flex;font-size:.85rem;gap:.5rem;gap:var(--space-sm);padding:1rem;padding:var(--space-md)}.form-note svg{color:#2d6a8a;color:var(--info);flex-shrink:0;margin-top:2px}.success-message{padding:2rem;padding:var(--space-xl);text-align:center}.success-message svg{color:#2d8a5d;color:var(--success);margin-bottom:1rem;margin-bottom:var(--space-md)}.success-message h4{color:#212529;color:var(--gray-900);font-size:1.25rem;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.success-note{color:#adb5bd;color:var(--gray-500);font-size:.9rem;margin-top:1rem;margin-top:var(--space-md)}.phase-options{display:flex;flex-direction:column;gap:.5rem;gap:var(--space-sm);margin-top:1.5rem;margin-top:var(--space-lg)}.phase-option{align-items:center;background:#fff;border:2px solid #e9ecef;border:2px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:flex;gap:1rem;gap:var(--space-md);padding:1rem;padding:var(--space-md);text-align:left;transition:all .2s}.phase-option:hover:not(:disabled){background:#f8f9fa;background:var(--gray-50)}.phase-option:disabled{cursor:not-allowed;opacity:.7}.phase-option.current{background:#f8f9fa;background:var(--gray-50)}.phase-dot{border-radius:50%;flex-shrink:0;height:12px;width:12px}.phase-option div{flex:1 1}.phase-option strong{color:#212529;color:var(--gray-900);display:block;font-size:.95rem}.phase-option span{color:#adb5bd;color:var(--gray-500);font-size:.85rem}.current-badge{background:#e9ecef;background:var(--gray-200);border-radius:100px;color:#868e96;color:var(--gray-600);font-size:.75rem;padding:2px 8px}.clinical-tools{max-width:900px}.tools-section{margin-bottom:3rem;margin-bottom:var(--space-2xl)}.tools-section h3{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.1rem;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.tools-section>p{color:#adb5bd;color:var(--gray-500);font-size:.9rem;margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.settings-page{max-width:600px}.settings-section{margin-bottom:2rem;margin-bottom:var(--space-xl)}.settings-section h3{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.1rem;margin-bottom:1rem;margin-bottom:var(--space-md)}.settings-card{background:#fff;border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);padding:1.5rem;padding:var(--space-lg)}.setting-row{border-bottom:1px solid #f1f3f5;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;padding:1rem 0;padding:var(--space-md) 0}.setting-row:last-child{border-bottom:none}.setting-row label{color:#495057;color:var(--gray-700);font-weight:500}.setting-row span{color:#868e96;color:var(--gray-600)}.version{color:#adb5bd;color:var(--gray-500);font-size:.85rem;margin-top:1rem;margin-top:var(--space-md)}.patient-dashboard{display:flex;flex-direction:column;min-height:100vh}.patient-header{align-items:center;background:#102a43;background:var(--primary-900);color:#fff;display:flex;gap:1rem;gap:var(--space-md);padding:1rem 1.5rem;padding:var(--space-md) var(--space-lg)}.header-brand h1{font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.25rem}.header-user{align-items:center;display:flex;gap:1rem;gap:var(--space-md);margin-left:auto}.header-user span{font-size:.9rem}.logout-btn{background:#ffffff1a;border:none;border-radius:4px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;padding:.5rem;padding:var(--space-sm)}.logout-btn:hover{background:#fff3}.patient-main{flex:1 1;margin:0 auto;max-width:800px;width:100%}.patient-main,.phase-banner{padding:2rem;padding:var(--space-xl)}.phase-banner{align-items:flex-end;border-radius:12px;border-radius:var(--radius-lg);color:#fff;display:flex;justify-content:space-between;margin-bottom:2rem;margin-bottom:var(--space-xl)}.phase-banner-content .phase-label{font-size:.8rem;letter-spacing:.1em;opacity:.8;text-transform:uppercase}.phase-banner-content h2{font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.75rem;margin:.5rem 0;margin:var(--space-sm) 0}.phase-banner-content p{opacity:.9}.phase-banner-meta{font-size:.85rem;opacity:.8}.patient-section{margin-bottom:3rem;margin-bottom:var(--space-2xl)}.patient-section h3{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.1rem;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.patient-section>p{color:#adb5bd;color:var(--gray-500);font-size:.9rem;margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.patient-tools-grid{grid-gap:1rem;grid-gap:var(--space-md);display:grid;gap:1rem;gap:var(--space-md)}.patient-tool-card{align-items:center;background:#fff;border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:1rem;gap:var(--space-md);padding:1.5rem;padding:var(--space-lg);text-align:left;transition:all .2s}.patient-tool-card:hover{border-color:#829ab1;border-color:var(--primary-400);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md)}.patient-tool-card .tool-icon{align-items:center;background:#d9e2ec;background:var(--primary-100);border-radius:8px;border-radius:var(--radius-md);color:#334e68;color:var(--primary-700);display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.patient-tool-card .tool-content{flex:1 1}.patient-tool-card .tool-content h4{color:#212529;color:var(--gray-900);font-size:1.05rem;margin-bottom:2px}.patient-tool-card .tool-content p{color:#adb5bd;color:var(--gray-500);font-size:.85rem}.patient-tool-card .tool-arrow{color:#ced4da;color:var(--gray-400)}.patient-footer{background:#f8f9fa;background:var(--gray-50);border-top:1px solid #e9ecef;border-top:1px solid var(--gray-200);padding:1.5rem;padding:var(--space-lg);text-align:center}.patient-footer p{color:#adb5bd;color:var(--gray-500);font-size:.85rem;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.patient-footer a{color:#486581;color:var(--primary-600);font-size:.85rem}.consent-page{align-items:center;background:#f1f3f5;background:var(--gray-100);display:flex;justify-content:center;min-height:100vh;padding:1.5rem;padding:var(--space-lg)}.consent-container{background:#fff;border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 10px 15px #0000001a;box-shadow:var(--shadow-lg);max-width:600px;overflow:hidden;width:100%}.consent-header{background:#102a43;background:var(--primary-900);color:#fff;padding:2rem;padding:var(--space-xl);text-align:center}.consent-header h1{font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.5rem;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.consent-body{padding:2rem;padding:var(--space-xl)}.consent-body h2{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.25rem}.consent-body h2,.consent-text{margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.consent-text{background:#f8f9fa;background:var(--gray-50);border-radius:8px;border-radius:var(--radius-md);font-size:.9rem;line-height:1.7;max-height:300px;overflow-y:auto;padding:1.5rem;padding:var(--space-lg)}.consent-text h4{color:#343a40;color:var(--gray-800);font-size:.95rem;margin-bottom:.5rem;margin-bottom:var(--space-sm);margin-top:1.5rem;margin-top:var(--space-lg)}.consent-text h4:first-child{margin-top:0}.consent-text ul{margin-bottom:1rem;margin-bottom:var(--space-md);margin-left:1.5rem;margin-left:var(--space-lg)}.consent-checkbox{align-items:center;background:#f8f9fa;background:var(--gray-50);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:flex;gap:1rem;gap:var(--space-md);margin-bottom:1.5rem;margin-bottom:var(--space-lg);padding:1rem;padding:var(--space-md)}.consent-checkbox input{height:20px;width:20px}.consent-checkbox span{color:#495057;color:var(--gray-700);font-size:.95rem}.consent-btn{background:#243b53;background:var(--primary-800);border:none;border-radius:8px;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 1.5rem;padding:var(--space-md) var(--space-lg);transition:all .2s;width:100%}.consent-btn:hover:not(:disabled){background:#102a43;background:var(--primary-900)}.consent-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.mobile-close{display:block}.main-content{margin-left:0}.mobile-menu-btn{display:block}.main-header{padding:1rem 1.5rem;padding:var(--space-md) var(--space-lg)}.main-body{padding:1.5rem;padding:var(--space-lg)}.header-btn span{display:none}.detail-header{flex-direction:column;text-align:center}.phase-badge.large{margin-left:0;margin-top:1rem;margin-top:var(--space-md)}.phase-banner{align-items:flex-start;flex-direction:column;gap:1rem;gap:var(--space-md)}.tools-grid{grid-template-columns:1fr 1fr}}@media (max-width:480px){.landing-cards,.tools-grid{grid-template-columns:1fr}.patient-card{flex-wrap:wrap}.patient-phase{margin-top:.5rem;margin-top:var(--space-sm);order:5;text-align:center;width:100%}}
/*# sourceMappingURL=main.f6a7ef2a.css.map*/