.login-container{align-items:center;background:var(--ethos-canvas,#f8f9fa);display:flex;font-family:var(--ethos-font-family-base,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif);justify-content:center;min-height:100vh;padding:var(--ethos-spacing-lg,24px);transition:background-color .3s ease}.login-card{background:var(--ethos-panel-bg-white,#fff);border:var(--ethos-panel-border,1px solid rgba(0,0,0,.08));border-radius:var(--ethos-panel-radius,12px);box-shadow:var(--ethos-panel-elevation-sm,0 1px 3px rgba(0,0,0,.05));max-width:420px;padding:var(--ethos-spacing-xxl,48px) var(--ethos-spacing-xl,40px);transition:background-color .3s ease,border-color .3s ease;width:100%}.login-header{margin-bottom:var(--ethos-spacing-xl,40px);text-align:center}.app-icon{margin-bottom:var(--ethos-spacing-md,16px)}.icon-circle{align-items:center;background:linear-gradient(135deg,var(--ethos-primary,#3b82f6) 0,var(--ethos-primary-dark,#2563eb) 100%);border-radius:var(--ethos-border-radius-lg,16px);box-shadow:0 4px 12px rgba(59,130,246,.25);display:flex;font-size:28px;height:64px;justify-content:center;margin:0 auto;width:64px}.login-header h1{color:var(--ethos-text-primary,#1f2937);font-size:var(--ethos-font-size-xxl,32px);font-weight:var(--ethos-font-weight-semibold,600);letter-spacing:var(--ethos-letter-spacing-tight,-.5px);margin:0 0 var(--ethos-spacing-xs,8px) 0}.login-header svg{display:block;margin:0 auto var(--ethos-spacing-xs,8px) auto}.subtitle{color:var(--ethos-text-secondary,#6b7280);font-size:var(--ethos-font-size-base,15px);font-weight:var(--ethos-font-weight-regular,400)}.login-form{margin-bottom:var(--ethos-spacing-xl,32px)}.form-group{margin-bottom:var(--ethos-spacing-lg,24px)}.form-group label{font-size:var(--ethos-font-size-sm,14px);font-weight:var(--ethos-font-weight-medium,500);margin-bottom:var(--ethos-spacing-xs,8px);text-transform:none}.apple-input,.form-group label{color:var(--ethos-text-primary,#1f2937)}.apple-input{background:var(--ethos-panel-bg-white,#fff);border:1px solid var(--ethos-border-light,#e5e7eb);border-radius:var(--ethos-border-radius-md,8px);box-sizing:border-box;font-size:var(--ethos-font-size-base,15px);padding:var(--ethos-spacing-sm,12px) var(--ethos-spacing-md,16px);transition:var(--ethos-transition-normal,all .2s);width:100%}.apple-input:focus{border-color:var(--ethos-primary,#3b82f6);box-shadow:0 0 0 4px rgba(59,130,246,.1);outline:none}.apple-input::-moz-placeholder{color:var(--ethos-text-muted,#9ca3af);font-weight:var(--ethos-font-weight-regular,400)}.apple-input::placeholder{color:var(--ethos-text-muted,#9ca3af);font-weight:var(--ethos-font-weight-regular,400)}.apple-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);border-left:4px solid var(--ethos-error,#ef4444);border-radius:var(--ethos-border-radius-md,8px);color:var(--ethos-error,#ef4444);font-size:var(--ethos-font-size-sm,14px);margin-bottom:var(--ethos-spacing-lg,24px);padding:var(--ethos-spacing-md,16px);text-align:center}.apple-primary-btn{background:linear-gradient(135deg,var(--ethos-primary,#3b82f6) 0,var(--ethos-primary-dark,#2563eb) 100%);border:none;border-radius:var(--ethos-border-radius-md,8px);box-shadow:0 2px 4px rgba(59,130,246,.2);color:#fff;cursor:pointer;font-size:var(--ethos-font-size-base,15px);font-weight:var(--ethos-font-weight-semibold,600);min-height:56px;padding:var(--ethos-spacing-md,16px) var(--ethos-spacing-lg,24px);transition:var(--ethos-transition-normal,all .2s);width:100%}.apple-primary-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--ethos-primary-dark,#2563eb) 0,#1d4ed8 100%);box-shadow:0 4px 8px rgba(59,130,246,.3);transform:translateY(-1px)}.apple-primary-btn:active:not(:disabled){box-shadow:0 2px 4px rgba(59,130,246,.2);transform:translateY(0)}.apple-primary-btn:disabled{background:var(--ethos-neutral-400,#9ca3af);box-shadow:none;cursor:not-allowed;transform:none}.alternative-auth{margin:var(--ethos-spacing-xl,32px) 0}.divider{margin:var(--ethos-spacing-lg,24px) 0;position:relative;text-align:center}.divider:before{background:var(--ethos-border-light,#e5e7eb);content:"";height:1px;left:0;position:absolute;right:0;top:50%}.divider span{color:var(--ethos-text-secondary,#6b7280);font-size:var(--ethos-font-size-sm,14px);padding:0 var(--ethos-spacing-md,16px);position:relative}.apple-secondary-btn,.divider span{background:var(--ethos-panel-bg-white,#fff);font-weight:var(--ethos-font-weight-medium,500)}.apple-secondary-btn{align-items:center;border:1px solid var(--ethos-border-light,#e5e7eb);border-radius:var(--ethos-border-radius-md,8px);color:var(--ethos-text-primary,#1f2937);cursor:pointer;display:flex;font-size:var(--ethos-font-size-base,15px);gap:var(--ethos-spacing-sm,12px);justify-content:center;min-height:56px;padding:var(--ethos-spacing-md,16px) var(--ethos-spacing-lg,24px);transition:var(--ethos-transition-normal,all .2s);width:100%}.apple-secondary-btn:hover{background:var(--ethos-canvas-fill-01,#f9fafb);border-color:var(--ethos-primary,#3b82f6);box-shadow:0 2px 4px rgba(0,0,0,.05);transform:translateY(-1px)}.google-logo{display:block;flex-shrink:0;height:20px;width:20px}.demo-section{margin:var(--ethos-spacing-xl,32px) 0}.apple-details{background:var(--ethos-canvas-fill-01,#f9fafb);border:1px solid var(--ethos-border-light,#e5e7eb);border-radius:var(--ethos-border-radius-md,8px);overflow:hidden}.apple-details summary{background:var(--ethos-panel-bg-white,#fff);border:none;color:var(--ethos-text-primary,#1f2937);cursor:pointer;font-size:var(--ethos-font-size-sm,14px);font-weight:var(--ethos-font-weight-medium,500);list-style:none;padding:var(--ethos-spacing-md,16px) var(--ethos-spacing-lg,20px);position:relative}.apple-details summary::-webkit-details-marker{display:none}.apple-details summary:after{color:var(--ethos-text-secondary,#6b7280);content:"▼";font-size:12px;position:absolute;right:var(--ethos-spacing-lg,20px);top:50%;transform:translateY(-50%);transition:transform .2s ease}.apple-details[open] summary:after{transform:translateY(-50%) rotate(180deg)}.demo-content{background:var(--ethos-canvas-fill-01,#f9fafb);padding:var(--ethos-spacing-lg,20px)}.demo-content p{color:var(--ethos-text-primary,#1f2937);font-family:SF Mono,Monaco,Courier New,monospace;font-size:var(--ethos-font-size-sm,14px);margin:var(--ethos-spacing-xs,8px) 0}.register-section{border-top:1px solid var(--ethos-border-light,#e5e7eb);margin-top:var(--ethos-spacing-xl,32px);padding-top:var(--ethos-spacing-lg,24px);text-align:center}.register-section p{color:var(--ethos-text-secondary,#6b7280);font-size:var(--ethos-font-size-sm,14px);margin:0 0 var(--ethos-spacing-sm,12px) 0}.apple-link-btn{background:none;border:none;color:var(--ethos-primary,#3b82f6);cursor:pointer;font-size:var(--ethos-font-size-base,15px);font-weight:var(--ethos-font-weight-medium,500);padding:var(--ethos-spacing-xs,8px) 0;text-decoration:underline;transition:color .2s ease}.apple-link-btn:hover{color:var(--ethos-primary-dark,#2563eb)}.demo-credentials{background:var(--ethos-canvas-fill-01,#f9fafb);border:1px solid var(--ethos-border-light,#e5e7eb);border-radius:var(--ethos-border-radius-md,8px);margin:var(--ethos-spacing-lg,20px) 0;padding:var(--ethos-spacing-md,15px)}.demo-credentials p{color:var(--ethos-text-secondary,#6b7280);font-size:var(--ethos-font-size-sm,14px);margin:var(--ethos-spacing-xs,5px) 0}.demo-credentials code{background:rgba(59,130,246,.1);border-radius:var(--ethos-border-radius-sm,4px);color:var(--ethos-primary,#3b82f6);font-family:SF Mono,Monaco,Courier New,monospace;font-size:13px;font-weight:var(--ethos-font-weight-medium,500);padding:2px 6px}.register-link{border-top:1px solid var(--ethos-border-light,#e5e7eb);margin-top:var(--ethos-spacing-md,15px);padding-top:var(--ethos-spacing-md,15px)}.register-btn{background:none;border:none;color:var(--ethos-primary,#3b82f6);cursor:pointer;font-size:var(--ethos-font-size-sm,14px);font-weight:var(--ethos-font-weight-medium,500);margin:0;padding:0;text-decoration:none}.register-btn:hover{color:var(--ethos-primary-dark,#2563eb);text-decoration:underline}.google-auth-section{margin:var(--ethos-spacing-xl,30px) 0}.google-signin-btn,.google-signup-btn{align-items:center;background:var(--ethos-panel-bg-white,#fff);border:1px solid var(--ethos-border-light,#e5e7eb);border-radius:var(--ethos-border-radius-md,8px);color:var(--ethos-text-primary,#1f2937);cursor:pointer;display:flex;font-size:var(--ethos-font-size-base,15px);font-weight:var(--ethos-font-weight-medium,500);gap:var(--ethos-spacing-sm,10px);justify-content:center;margin-bottom:var(--ethos-spacing-sm,12px);padding:var(--ethos-spacing-sm,12px) var(--ethos-spacing-md,16px);transition:var(--ethos-transition-normal,all .2s);width:100%}.google-signin-btn:hover,.google-signup-btn:hover{background:rgba(66,133,244,.05);border-color:#4285f4;box-shadow:0 2px 4px rgba(66,133,244,.15);transform:translateY(-1px)}.google-signin-btn i,.google-signup-btn i{color:#4285f4;font-size:18px}.google-signin-btn{border-color:#4285f4;color:#4285f4}.google-signup-btn{border-color:var(--ethos-success,#10b981);color:var(--ethos-success,#10b981)}.google-signup-btn:hover{background:rgba(16,185,129,.05);border-color:var(--ethos-success,#10b981);box-shadow:0 2px 4px rgba(16,185,129,.15)}.google-signup-btn i{color:var(--ethos-success,#10b981)}.forgot-password-link{margin-top:var(--ethos-spacing-md,16px);text-align:center}.forgot-password-link button{background:none;border:none;color:var(--ethos-primary,#3b82f6);cursor:pointer;font-size:var(--ethos-font-size-sm,14px);font-weight:var(--ethos-font-weight-medium,500);padding:0;text-decoration:none}.forgot-password-link button:hover{color:var(--ethos-primary-dark,#2563eb);text-decoration:underline}@media(max-width:768px){.apple-primary-btn,.apple-secondary-btn,.google-signin-btn,.google-signup-btn{height:52px!important;min-height:52px!important;padding:0!important}}.two-factor-modal{max-height:90vh;max-width:600px;overflow-y:auto}.two-factor-modal .modal-header{margin-bottom:var(--ethos-spacing-lg);text-align:center}.two-factor-modal .modal-header h2{color:var(--text-primary,#1f2937);font-size:24px;font-weight:600;margin:0 0 8px}.two-factor-modal .modal-subtitle{color:var(--text-muted,#6b7280);font-size:14px;margin:0}.two-factor-modal .modal-body{min-height:200px;padding:0}.two-factor-modal .modal-footer{border-top:1px solid var(--border-light,#e5e7eb);display:flex;gap:var(--ethos-panel-padding-md);justify-content:center;padding-top:var(--ethos-spacing-lg)}.two-factor-content{display:flex;flex-direction:column;gap:var(--ethos-spacing-md)}.info-box{background:var(--bg-secondary,#f9fafb);border:1px solid var(--border-light,#e5e7eb)}.info-box h3,.info-box h4{color:var(--text-primary,#1f2937);font-size:16px;font-weight:600;margin:0 0 8px}.info-box p{color:var(--text-secondary,#4b5563);font-size:14px;line-height:1.6}.info-box ul{margin:8px 0 0;padding-left:var(--ethos-spacing-md)}.info-box li{color:var(--text-secondary,#4b5563);font-size:14px;line-height:1.6;margin-bottom:var(--ethos-spacing-xs)}.setup-steps{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e7eb);border-radius:var(--ethos-panel-radius);padding:var(--ethos-spacing-md)}.setup-steps h3{color:var(--text-primary,#1f2937);font-size:16px;font-weight:600;margin:0 0 12px}.setup-steps ol{margin:0;padding-left:var(--ethos-spacing-md)}.setup-steps li{color:var(--text-secondary,#4b5563);font-size:14px;line-height:1.6;margin-bottom:var(--ethos-spacing-sm)}.qr-code-section{text-align:center}.qr-code-section h3{color:var(--text-primary,#1f2937);font-size:16px;font-weight:600;margin:0 0 16px}.qr-code-container{align-items:center;background:var(--bg-primary,#fff);border:2px solid var(--border-light,#e5e7eb);border-radius:var(--ethos-panel-radius);display:flex;justify-content:center;margin-bottom:var(--ethos-spacing-md);padding:var(--ethos-spacing-md)}.qr-code-image{display:block;height:auto;max-width:256px;width:100%}.manual-entry-section{background:var(--bg-secondary,#f9fafb);border:1px solid var(--border-light,#e5e7eb);border-radius:var(--ethos-panel-radius);padding:var(--ethos-spacing-md)}.manual-entry-label{color:var(--text-muted,#6b7280);font-size:13px;margin:0 0 8px}.manual-entry-key{align-items:center;display:flex;gap:var(--ethos-spacing-sm);justify-content:center}.manual-entry-key code{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e7eb);border-radius:var(--ethos-panel-radius-sm);color:var(--text-primary,#1f2937);font-family:Courier New,monospace;font-size:14px;font-weight:600;letter-spacing:2px;padding:8px 12px}.btn-copy{background:var(--ethos-primary,#2563eb);border:none;border-radius:var(--ethos-panel-radius-sm);color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s ease}.btn-copy:hover{background:var(--ethos-primary-700,#1d4ed8)}.verification-section{border-top:1px solid var(--border-light,#e5e7eb);padding-top:var(--ethos-spacing-md);text-align:center}.verification-section h3{color:var(--text-primary,#1f2937);font-size:16px;font-weight:600;margin:0 0 8px}.verification-section p{color:var(--text-secondary,#4b5563);font-size:14px;margin:0 0 16px}.verification-input-group{display:flex;justify-content:center;margin-bottom:var(--ethos-spacing-md)}.verification-input{border:2px solid var(--border-medium,#d1d5db);border-radius:var(--ethos-panel-radius);font-family:Courier New,monospace;font-size:24px;font-weight:600;letter-spacing:8px;padding:12px 16px;text-align:center;transition:all .2s ease;width:180px}.verification-input:focus{border-color:var(--ethos-primary,#2563eb);box-shadow:0 0 0 3px rgba(37,99,235,.1);outline:none}.success-section{padding:var(--ethos-spacing-md);text-align:center}.success-icon{font-size:64px;margin-bottom:var(--ethos-spacing-md)}.success-section h2{color:var(--text-primary,#1f2937);font-size:20px;font-weight:600;margin:0 0 12px}.success-section p{color:var(--text-secondary,#4b5563);font-size:14px;line-height:1.6;margin:0 0 20px}.error-section{padding:var(--ethos-spacing-md);text-align:center}.error-icon{font-size:64px;margin-bottom:var(--ethos-spacing-md)}.error-section h2{color:var(--color-error,#dc2626);font-size:20px;font-weight:600;margin:0 0 12px}.error-section p{color:var(--text-secondary,#4b5563);font-size:14px;line-height:1.6;margin:0}.error-message{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;padding:12px 16px;text-align:center}.loading-spinner{min-height:200px}.fastprax-logo-loader{animation:fadeInOut 2s ease-in-out infinite;font-size:64px;opacity:.3}.webauthn-setup-section{text-align:center}.webauthn-setup-section h3{color:var(--text-primary,#1f2937);font-size:18px;font-weight:600;margin:0 0 12px}.webauthn-setup-section p{color:var(--text-secondary,#4b5563);font-size:14px;line-height:1.6;margin:0 0 16px}.webauthn-benefits{background:var(--bg-secondary,#f9fafb);border:1px solid var(--border-light,#e5e7eb);border-radius:var(--ethos-panel-radius);margin-bottom:var(--ethos-spacing-md);padding:var(--ethos-spacing-md)}.webauthn-benefits ul{list-style:none;margin:0;padding-left:var(--ethos-spacing-md)}.webauthn-benefits li{color:var(--text-secondary,#4b5563);font-size:14px;line-height:1.6;margin-bottom:var(--ethos-spacing-sm)}.success-message{background:#d4edda;border:1px solid #28a745;border-radius:var(--ethos-panel-radius-sm);color:#155724;font-size:14px;padding:12px 16px;text-align:center}.spinner-small{animation:spin .8s linear infinite;border:2px solid hsla(0,0%,100%,.3);border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;margin-right:var(--ethos-spacing-sm);width:14px}@keyframes spin{to{transform:rotate(1turn)}}@media(max-width:640px){.two-factor-modal{max-width:95vw}.qr-code-image{max-width:200px}.verification-input{font-size:20px;letter-spacing:6px;width:160px}.two-factor-modal .modal-footer{flex-direction:column}.two-factor-modal .modal-footer button{width:100%}}.payer-directory-page{margin:0 auto;max-width:1400px;padding:24px}.payer-header{margin-bottom:32px}.payer-header h1{color:var(--text-primary,#1a202c);font-size:32px;font-weight:600;margin:0 0 8px}.payer-header p{color:var(--text-muted,#718096);font-size:16px;margin:0}.payer-filters{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.search-container{flex:1;min-width:300px;position:relative}.search-icon{color:var(--color-disabled-text,#a0aec0);font-size:20px;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.search-input{border:1px solid var(--border-light,#e2e8f0);border-radius:8px;font-size:14px;padding:12px 12px 12px 44px;transition:border-color .2s;width:100%}.search-input:focus{border-color:var(--color-ocean-blue-500,#4299e1);outline:none}.filter-buttons{display:flex;gap:8px}.filter-buttons button{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e2e8f0);border-radius:8px;color:var(--text-secondary,#4a5568);cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.filter-buttons button:hover{background:var(--bg-secondary,#f7fafc);border-color:var(--border-medium,#cbd5e0)}.filter-buttons button.active{border-color:var(--color-ocean-blue-500,#4299e1)}.add-payer-btn,.filter-buttons button.active{background:var(--color-ocean-blue-500,#4299e1);color:var(--bg-primary,#fff)}.add-payer-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:background-color .2s}.add-payer-btn:hover{background:var(--color-ocean-blue-600,#3182ce)}.payer-list{margin-top:24px}.payer-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.payer-card{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e2e8f0);border-radius:12px;padding:20px;transition:all .2s}.payer-card:hover{border-color:var(--border-medium,#cbd5e0);box-shadow:0 4px 12px rgba(0,0,0,.1)}.payer-card-header{align-items:flex-start;border-bottom:1px solid var(--border-light,#e2e8f0);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.payer-name-section h3{color:var(--text-primary,#1a202c);font-size:18px;font-weight:600;margin:0 0 4px}.payer-id{color:var(--text-muted,#718096);font-family:monospace;font-size:12px}.payer-status .status-icon{font-size:24px}.payer-status .status-icon.active{color:var(--color-success,#48bb78)}.payer-status .status-icon.inactive{color:var(--color-error,#f56565)}.payer-details{margin-bottom:16px}.payer-detail-row{align-items:center;display:flex;font-size:14px;gap:8px;margin-bottom:12px}.payer-detail-row .detail-label{color:var(--text-secondary,#4a5568);font-weight:500;min-width:120px}.payer-detail-row .detail-value{color:var(--text-primary,#1a202c);flex:1}.payer-detail-row .detail-icon{color:var(--text-muted,#718096);font-size:18px}.method-badge{background:var(--bg-tertiary,#edf2f7);border-radius:6px;color:#2d3748;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.payer-card-actions{border-top:1px solid var(--border-light,#e2e8f0);display:flex;gap:8px;padding-top:16px}.action-btn{align-items:center;background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e2e8f0);border-radius:6px;color:var(--text-secondary,#4a5568);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.action-btn:hover{background:var(--bg-secondary,#f7fafc);border-color:var(--border-medium,#cbd5e0)}.action-btn.edit:hover{background:#ebf8ff;border-color:var(--color-ocean-blue-500,#4299e1);color:var(--color-ocean-blue-500,#4299e1)}.action-btn.delete:hover{background:#fed7d7;border-color:var(--color-error,#f56565);color:var(--color-error,#f56565)}.empty-state{padding:60px 20px}.empty-state .empty-icon{color:var(--border-medium,#cbd5e0);font-size:64px;margin-bottom:16px}.empty-state h3{color:var(--text-primary,#1a202c);font-size:20px;font-weight:600;margin:0 0 8px}.empty-state p{color:var(--text-muted,#718096);font-size:14px;margin:0 0 24px}.loading-state{flex-direction:column}.loading-spinner{margin-bottom:16px}.fastprax-icon-loader{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading-text{color:var(--text-muted,#718096);font-size:16px}@media(max-width:768px){.payer-directory-page{padding:16px}.payer-grid{grid-template-columns:1fr}.payer-filters{align-items:stretch;flex-direction:column}.search-container{min-width:100%}}.payer-edit-page{margin:0 auto;max-width:1200px;padding:24px}.payer-edit-header{gap:16px;margin-bottom:32px}.back-btn,.payer-edit-header{align-items:center;display:flex}.back-btn{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e2e8f0);border-radius:8px;color:var(--text-secondary,#4a5568);font-weight:500;gap:8px;padding:10px 16px}.back-btn:hover{background:var(--bg-secondary,#f7fafc);border-color:var(--border-medium,#cbd5e0)}.payer-edit-header h1{color:var(--text-primary,#1a202c);font-size:28px;font-weight:600;margin:0}.payer-edit-form{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e2e8f0);border-radius:12px;padding:32px}.form-section{border-bottom:1px solid var(--border-light,#e2e8f0);margin-bottom:40px;padding-bottom:32px}.form-section:last-of-type{border-bottom:none}.form-section h2{color:var(--text-primary,#1a202c);font-size:20px;font-weight:600;margin:0 0 16px}.section-description{color:var(--text-muted,#718096);font-size:14px;margin:0 0 20px}.form-grid{gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.form-group.checkbox-group{align-items:center;flex-direction:row}.form-group.checkbox-group label{align-items:center;color:var(--text-secondary,#4a5568);cursor:pointer;display:flex;font-size:14px;gap:8px}.form-group.checkbox-group input[type=checkbox]{cursor:pointer;height:18px;width:18px}.form-actions{border-top:1px solid var(--border-light,#e2e8f0);justify-content:flex-end}.btn-secondary{border:1px solid var(--border-light,#e2e8f0);border-radius:8px;color:var(--text-secondary,#4a5568);transition:all .2s}.btn-secondary:hover{background:var(--bg-secondary,#f7fafc);border-color:var(--border-medium,#cbd5e0)}.btn-primary{align-items:center;background:var(--color-ocean-blue-500,#4299e1);border-radius:8px;color:var(--bg-primary,#fff);display:flex;gap:8px;transition:background-color .2s}.btn-primary:hover:not(:disabled){background:var(--color-ocean-blue-600,#3182ce)}.btn-primary:disabled{opacity:.6}.loading-state{align-items:center;color:var(--text-muted,#718096);display:flex;padding:60px 20px}@media(max-width:768px){.payer-edit-page{padding:16px}.payer-edit-form{padding:20px}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.onboarding-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:var(--ethos-spacing-xl,40px) var(--ethos-spacing-md,20px)}.onboarding-container{background:var(--ethos-bg-primary,var(--ethos-panel-bg-white));border-radius:var(--ethos-panel-radius-lg,16px);box-shadow:var(--ethos-shadow-xl,0 20px 60px rgba(0,0,0,.3));max-width:800px;overflow:hidden;width:100%}.onboarding-header{background:linear-gradient(135deg,var(--ethos-primary-500,#667eea) 0,var(--ethos-primary-700,#764ba2) 100%);color:var(--ethos-text-inverse,#fff);padding:var(--ethos-spacing-xl,40px);text-align:left}.onboarding-header .logo{align-items:center;display:flex;gap:var(--ethos-spacing-sm,12px);justify-content:flex-start;margin-bottom:var(--ethos-spacing-lg,24px)}.onboarding-header .logo .material-icons{align-items:center;background:var(--ethos-primary,var(--ethos-primary-600));border-radius:var(--ethos-panel-radius-sm,6px);color:var(--ethos-text-inverse,#fff);display:flex;flex-shrink:0;font-size:var(--ethos-font-size-xl,32px);height:40px;justify-content:center;width:40px}.onboarding-header .logo h1{color:var(--ethos-text-inverse,#fff);font-size:var(--ethos-font-size-2xl,28px);font-weight:var(--ethos-font-weight-bold,700);margin:0}.onboarding-header h2{color:var(--ethos-text-inverse,#fff);font-size:var(--ethos-font-size-xl,24px);font-weight:var(--ethos-font-weight-semibold,600);margin:0 0 var(--ethos-spacing-md,20px) 0}.onboarding-header .invitation-info{align-items:center;color:hsla(0,0%,100%,.95);display:flex;font-size:var(--ethos-font-size-base,15px);gap:var(--ethos-spacing-sm,8px);justify-content:flex-start;margin-bottom:var(--ethos-spacing-md,16px)}.onboarding-header .invitation-info .material-icons{font-size:var(--ethos-font-size-lg,18px);opacity:.9}.onboarding-header .invitation-info strong{color:var(--ethos-text-inverse,#fff);font-weight:var(--ethos-font-weight-semibold,600)}.onboarding-header .invitation-message{backdrop-filter:blur(10px);background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.2);border-radius:var(--ethos-panel-radius-lg,12px);box-sizing:border-box;margin-top:var(--ethos-spacing-md,20px);padding:var(--ethos-spacing-md,20px) var(--ethos-spacing-lg,24px);width:100%}.onboarding-header .invitation-message p{color:hsla(0,0%,100%,.95);font-size:var(--ethos-font-size-base,15px);font-style:italic;line-height:var(--ethos-line-height-normal,1.5);margin:0}.progress-steps{background:var(--ethos-bg-secondary);border:var(--ethos-panel-border-width,1px) solid var(--ethos-border-light);display:flex;justify-content:space-between;padding:var(--ethos-spacing-xl,32px) var(--ethos-spacing-xl,40px)}.progress-steps .step{align-items:center;display:flex;flex:1;flex-direction:column;gap:var(--ethos-spacing-sm,8px);position:relative}.progress-steps .step:not(:last-child):after{background:var(--ethos-border-light);content:"";height:2px;left:calc(50% + 30px);position:absolute;right:calc(-50% + 30px);top:20px}.progress-steps .step.completed:not(:last-child):after{background:var(--ethos-success)}.progress-steps .step-number{align-items:center;background:var(--ethos-border-light);border-radius:50%;color:var(--ethos-text-muted);display:flex;font-size:var(--ethos-font-size-base,16px);font-weight:var(--ethos-font-weight-semibold,600);height:40px;justify-content:center;transition:var(--ethos-transition-normal,all .3s);width:40px;z-index:1}.progress-steps .step.active .step-number{background:var(--ethos-primary);box-shadow:0 0 0 4px rgba(59,130,246,.2);color:var(--ethos-text-inverse,#fff)}.progress-steps .step.completed .step-number{background:var(--ethos-success);color:var(--ethos-text-inverse,#fff)}.progress-steps .step-label{color:var(--ethos-text-muted);font-size:var(--ethos-font-size-sm,13px);font-weight:var(--ethos-font-weight-medium,500);text-align:center}.progress-steps .step.active .step-label{color:var(--ethos-text-primary);font-weight:var(--ethos-font-weight-semibold,600)}.onboarding-step{padding:var(--ethos-spacing-xl,40px)}.onboarding-step h3{color:var(--ethos-text-primary);font-size:var(--ethos-font-size-xl,24px);font-weight:var(--ethos-font-weight-bold,700);margin:0 0 var(--ethos-spacing-sm,8px) 0}.onboarding-step .step-description{color:var(--ethos-text-muted);margin-bottom:var(--ethos-spacing-xl,32px)}.form-field{margin-bottom:var(--ethos-spacing-lg,24px)}.form-field label{color:var(--ethos-text-secondary);display:block;font-size:var(--ethos-font-size-sm,14px);font-weight:var(--ethos-font-weight-semibold,600);margin-bottom:var(--ethos-spacing-sm,8px)}.form-field input,.form-field select,.form-field textarea{background:var(--ethos-bg-primary)!important;border:var(--ethos-panel-border-width,1px) solid var(--ethos-border-medium);border-radius:var(--ethos-panel-radius,8px);color:var(--ethos-text-primary);font-family:var(--ethos-font-family-base);font-size:var(--ethos-font-size-base,15px);padding:var(--ethos-spacing-sm,12px) var(--ethos-spacing-md,16px);transition:var(--ethos-transition-normal,all .2s)}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--ethos-primary);box-shadow:0 0 0 3px var(--ethos-primary-light)}.form-field input:disabled{background:var(--ethos-neutral-100)!important;cursor:not-allowed}.form-grid-2{grid-template-columns:repeat(2,1fr)}.form-grid-2,.form-grid-3{gap:var(--ethos-spacing-md,20px)}.form-grid-3{grid-template-columns:repeat(3,1fr)}.form-field-checkbox{margin:var(--ethos-spacing-lg,24px) 0}.form-field-checkbox label{gap:var(--ethos-spacing-sm,12px)}.form-field-checkbox input[type=checkbox]{height:20px;width:20px}.form-field-checkbox span{color:var(--ethos-text-secondary);font-size:var(--ethos-font-size-base,15px)}.consent-section{background:var(--ethos-bg-secondary);border:var(--ethos-panel-border-width,1px) solid var(--ethos-border-light);border-radius:var(--ethos-panel-radius-lg,12px);margin-bottom:var(--ethos-spacing-xl,32px);padding:var(--ethos-spacing-lg,24px)}.consent-section h4{color:var(--ethos-text-primary);font-size:var(--ethos-font-size-lg,18px);font-weight:var(--ethos-font-weight-semibold,600);margin:0 0 var(--ethos-spacing-md,16px) 0}.consent-text{background:var(--ethos-bg-primary);border:var(--ethos-panel-border-width,1px) solid var(--ethos-border-medium);border-radius:var(--ethos-panel-radius,8px);margin-bottom:var(--ethos-spacing-md,20px);max-height:200px;overflow-y:auto;padding:var(--ethos-spacing-md,20px)}.consent-text p{color:var(--ethos-text-secondary);font-size:var(--ethos-font-size-sm,14px);line-height:var(--ethos-line-height-normal,1.6);margin:0 0 var(--ethos-spacing-sm,12px) 0}.consent-text p:last-child{margin-bottom:0}.signature-section{border:var(--ethos-panel-border-width,1px) solid var(--ethos-border-light);margin-top:var(--ethos-spacing-lg,24px);padding-top:var(--ethos-spacing-lg,24px)}.signature-instructions{color:var(--ethos-text-secondary);font-size:var(--ethos-font-size-base,15px);margin-bottom:var(--ethos-spacing-md,16px)}.signature-date{color:var(--ethos-text-muted);font-size:var(--ethos-font-size-sm,14px);font-style:italic;margin-top:var(--ethos-spacing-sm,12px)}.step-actions{border:var(--ethos-panel-border-width,1px) solid var(--ethos-border-light);display:flex;gap:var(--ethos-spacing-sm,12px);justify-content:flex-end;margin-top:var(--ethos-spacing-xl,32px);padding-top:var(--ethos-spacing-lg,24px)}.btn-primary,.btn-secondary{border-radius:var(--ethos-panel-radius,8px);font-family:var(--ethos-font-family-base);font-size:var(--ethos-font-size-base,15px);font-weight:var(--ethos-font-weight-semibold,600);padding:var(--ethos-spacing-sm,12px) var(--ethos-spacing-xl,32px);transition:var(--ethos-transition-normal,all .2s)}.btn-primary{background:var(--ethos-primary);box-shadow:var(--ethos-shadow-sm,0 2px 4px rgba(59,130,246,.3));color:var(--ethos-text-inverse,#fff)}.btn-primary:hover:not(:disabled){background:var(--ethos-primary-dark);box-shadow:var(--ethos-shadow-md,0 4px 8px rgba(59,130,246,.4))}.btn-secondary{background:var(--ethos-bg-primary);border:var(--ethos-panel-border-width,1px) solid var(--ethos-border-medium);color:var(--ethos-text-secondary)}.btn-secondary:hover:not(:disabled){background:var(--ethos-neutral-100)}.error-state,.loading-state{flex-direction:column;padding:var(--ethos-spacing-2xl,80px) var(--ethos-spacing-xl,40px);text-align:center}.error-state,.loading-state,.loading-state .spinner{align-items:center;display:flex;justify-content:center}.loading-state .spinner{animation:fadeInOut 2s ease-in-out infinite;height:48px;margin-bottom:var(--ethos-spacing-md,20px);width:48px}.loading-state p{color:var(--ethos-text-muted);font-size:var(--ethos-font-size-base,16px)}.error-state .material-icons{color:var(--ethos-error);font-size:64px;margin-bottom:var(--ethos-spacing-md,16px)}.error-state h2{color:var(--ethos-text-primary);font-size:var(--ethos-font-size-xl,24px);font-weight:var(--ethos-font-weight-semibold,600);margin:0 0 var(--ethos-spacing-sm,8px) 0}.error-state p{color:var(--ethos-text-muted);font-size:var(--ethos-font-size-base,16px);margin:0 0 var(--ethos-spacing-lg,24px) 0}@media(max-width:768px){.onboarding-page{padding:var(--ethos-spacing-md,20px)}.onboarding-header{padding:var(--ethos-spacing-lg,30px) var(--ethos-spacing-md,20px)}.progress-steps{padding:var(--ethos-spacing-lg,24px) var(--ethos-spacing-md,20px)}.progress-steps .step-label{font-size:var(--ethos-font-size-xs,11px)}.onboarding-step{padding:var(--ethos-spacing-lg,30px) var(--ethos-spacing-md,20px)}.form-grid-2,.form-grid-3{gap:var(--ethos-spacing-md,16px);grid-template-columns:1fr}}@media(prefers-color-scheme:dark){.form-field input,.form-field select,.form-field textarea{background:var(--ethos-bg-primary)!important;color:var(--ethos-text-primary)!important;color-scheme:light!important}.form-field input::-moz-placeholder{color:var(--ethos-text-muted)!important}.form-field input::placeholder{color:var(--ethos-text-muted)!important}}.nppes-lookup-container{background:#f0f9ff;border:1px solid var(--border-light,#bae6fd);border-radius:var(--ethos-panel-radius-sm);margin-bottom:var(--ethos-spacing-md);padding:10px 12px}.nppes-lookup-header{align-items:center;display:flex;gap:var(--ethos-spacing-xs);margin-bottom:var(--ethos-spacing-sm)}.nppes-lookup-title{color:var(--text-primary,#0c4a6e);font-size:12px;font-weight:600}.nppes-lookup-header-inline{align-items:center;display:flex;gap:var(--ethos-panel-padding-md);margin-bottom:var(--ethos-panel-padding-md)}.nppes-lookup-title-inline{color:var(--text-primary,#0c4a6e);font-size:14px;font-weight:600}.nppes-lookup-form{align-items:start;display:grid;gap:var(--ethos-spacing-sm);grid-template-columns:1fr 1fr auto}.nppes-lookup-field{min-width:0}.nppes-lookup-label{color:var(--text-secondary,#374151);display:block;font-size:11px;font-weight:500;margin-bottom:3px}.nppes-lookup-input{background:var(--bg-primary,#fff);border:1px solid var(--border-medium,#d1d5db);border-radius:var(--ethos-panel-radius-sm);box-sizing:border-box;color:var(--text-primary,#1f2937);font-family:inherit;font-size:14px;padding:6px 10px;width:100%}.nppes-lookup-button{background:#0284c7;border:none;border-radius:var(--ethos-panel-radius-sm);box-sizing:border-box;color:var(--white,#fff);cursor:pointer;font-size:13px;font-weight:500;min-height:60px;padding:12px 16px;white-space:nowrap}.nppes-lookup-button:disabled{background:#9ca3af;cursor:not-allowed}.nppes-lookup-error{background:#fee2e2;border:1px solid var(--border-light,#ef4444);border-radius:var(--ethos-panel-radius-sm);color:var(--color-error,#dc2626);font-size:11px;font-weight:500;margin-top:var(--ethos-spacing-sm);padding:6px 8px}.nppes-lookup-results{background:var(--bg-primary,#fff);border:1px solid var(--border-medium,#d1d5db);border-radius:var(--ethos-panel-radius-sm);margin-top:var(--ethos-spacing-sm);max-height:200px;overflow-y:auto}.nppes-lookup-result-item{cursor:pointer;padding:8px 10px;transition:background .15s}.nppes-lookup-result-item:not(:last-child){border-bottom:1px solid #e5e7eb}.nppes-lookup-result-item:hover{background:var(--bg-secondary,#f9fafb)}.nppes-lookup-result-name{color:var(--text-primary,#1f2937);font-size:12px;font-weight:600;margin-bottom:2px}.nppes-lookup-result-details{color:var(--text-muted,#6b7280);font-size:11px}.nppes-lookup-result-address{color:var(--text-primary,#9ca3af);font-size:11px}@media(max-width:768px){.nppes-lookup-form{gap:var(--ethos-spacing-sm);grid-template-columns:1fr}.nppes-lookup-button{font-size:14px;height:44px;padding:10px 14px;width:100%}.nppes-lookup-input{font-size:16px;height:44px}.nppes-lookup-label{font-size:12px}.nppes-lookup-container{padding:var(--ethos-panel-padding-md)}.nppes-lookup-title{font-size:13px}}.toast{align-items:flex-start;animation:slideInRight .3s ease-out;background:#fff;border-left:4px solid;border-radius:var(--ethos-panel-radius-lg);box-shadow:0 4px 16px rgba(0,0,0,.12),0 2px 6px rgba(0,0,0,.08);display:flex;gap:var(--ethos-panel-padding-md);max-width:420px;min-width:320px;padding:var(--ethos-spacing-md);position:relative}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast-content{align-items:flex-start;display:flex;flex:1;gap:var(--ethos-panel-padding-md)}.toast-icon{flex-shrink:0;font-size:24px;margin-top:2px}.toast-text{flex:1;min-width:0}.toast-title{color:var(--ethos-neutral-800);font-size:15px;font-weight:600;margin-bottom:var(--ethos-spacing-xs)}.toast-message{color:var(--ethos-neutral-500);font-size:14px;line-height:1.5;word-wrap:break-word}.toast-close{background:none;border:none;color:#9ca3af;cursor:pointer;flex-shrink:0;padding:var(--ethos-spacing-xs);transition:color .2s}.toast-close:hover{color:#4b5563}.toast-close .material-icons{font-size:20px}.toast-success{border-left-color:var(--ethos-success)}.toast-success .toast-icon{color:var(--ethos-success)}.toast-error{border-left-color:var(--ethos-error)}.toast-error .toast-icon{color:var(--ethos-error)}.toast-warning{border-left-color:var(--ethos-warning-500)}.toast-warning .toast-icon{color:var(--ethos-warning-500)}.toast-info{border-left-color:var(--ethos-primary-500)}.toast-info .toast-icon{color:var(--ethos-primary-500)}.toast-container{display:flex;flex-direction:column;gap:var(--ethos-panel-padding-md);pointer-events:none;position:fixed;right:var(--ethos-spacing-lg);top:var(--ethos-spacing-lg);z-index:9999}.toast-container>*{pointer-events:auto}@media(max-width:768px){.toast-container{left:var(--ethos-spacing-md);max-width:calc(100vw - 32px);right:var(--ethos-spacing-md);top:var(--ethos-spacing-md)}.toast-container .toast{max-width:100%;min-width:unset}}.multi-booking-modal-content{display:flex;flex-direction:column;gap:var(--ethos-spacing-lg)}.appointments-list-section{margin-bottom:var(--ethos-spacing-lg)}.appointments-list{display:flex;flex-direction:column;gap:var(--ethos-panel-padding-md);max-height:300px;overflow-y:auto}.appointment-slot{background:#f8f9fa;border:1px solid #e5e7eb;border-radius:var(--ethos-panel-radius);gap:var(--ethos-spacing-md);padding:var(--ethos-spacing-md)}.appointment-slot,.slot-number{align-items:center;display:flex}.slot-number{background:#007aff;color:#fff;width:32px}.slot-info,.slot-patient{margin-bottom:var(--ethos-spacing-xs)}.slot-info{color:#666}.slot-service{color:#333;font-size:14px}.slot-actions{gap:var(--ethos-spacing-sm)}.edit-btn,.remove-btn{background:transparent;border:none;border-radius:var(--ethos-panel-radius-sm);padding:8px 12px;transition:background .2s}.edit-btn:hover{background:#e3f2fd}.remove-btn:hover{background:#ffebee}.add-appointment-section{border-top:1px solid #e5e7eb;padding-top:var(--ethos-spacing-lg)}.form-grid{display:grid;gap:var(--ethos-spacing-md);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:var(--ethos-spacing-md)}.form-group label{color:#333}.form-input{border:1px solid #d1d5db;border-radius:var(--ethos-panel-radius-sm);font-size:14px;transition:border-color .2s}.form-input:focus{border-color:#007aff;box-shadow:0 0 0 3px rgba(0,122,255,.1);outline:none}.typeahead-dropdown{background:#fff;border:1px solid #d1d5db;border-radius:var(--ethos-panel-radius-sm);box-shadow:0 4px 6px rgba(0,0,0,.1);margin-top:var(--ethos-spacing-xs);max-height:200px;z-index:1000}.typeahead-item{border-bottom:1px solid #f3f4f6;padding:var(--ethos-panel-padding-md)}.typeahead-item:hover{background:#f3f4f6}.typeahead-item .specialty{color:#666;font-size:12px}.btn-primary{background:#007aff;border-radius:var(--ethos-panel-radius-sm);font-size:14px;padding:12px 24px;transition:background .2s}.btn-primary:hover{background:#0056b3}.btn-primary:disabled{background:#ccc}.btn-secondary{background:#f3f4f6;border:1px solid #d1d5db;border-radius:var(--ethos-panel-radius-sm);color:#333;font-size:14px;font-weight:600;transition:background .2s}.btn-secondary:hover{background:#e5e7eb}@media(max-width:768px){.form-grid{grid-template-columns:1fr}.appointment-slot{align-items:flex-start;flex-direction:column}.slot-actions{justify-content:flex-end;width:100%}}.send-claim-email-modal{background:#fff;border-radius:var(--ethos-panel-radius-lg);box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);max-height:90vh;max-width:500px;overflow-y:auto;position:relative;width:90%}.modal-overlay{background:rgba(0,0,0,.5);bottom:0;justify-content:center;left:0;padding:var(--ethos-spacing-md);position:fixed;right:0;top:0;z-index:1000}.modal-header,.modal-overlay{align-items:center;display:flex}.modal-header{border-bottom:1px solid var(--border-light,#e5e7eb);justify-content:space-between;padding:24px 24px 20px}.modal-header h2{color:var(--text-primary,#1f2937);font-size:20px;font-weight:600;margin:0}.modal-close-button{align-items:center;background:none;border:none;border-radius:var(--ethos-panel-radius-sm);color:var(--text-secondary,#6b7280);cursor:pointer;display:flex;justify-content:center;padding:var(--ethos-spacing-xs);transition:all .2s ease}.modal-close-button:hover{background:var(--bg-secondary,#f3f4f6);color:var(--text-primary,#1f2937)}.modal-close-button:disabled{cursor:not-allowed;opacity:.5}.send-claim-email-modal form{display:flex;flex-direction:column;gap:var(--ethos-spacing-md);padding:var(--ethos-spacing-lg)}.form-field{gap:var(--ethos-spacing-sm)}.form-field input,.form-field textarea{border:1px solid var(--border-medium,#d1d5db);border-radius:var(--ethos-panel-radius-sm);font-family:inherit;font-size:14px;padding:10px 12px;transition:all .2s ease;width:100%}.form-field input:focus,.form-field textarea:focus{border-color:var(--ethos-primary,#2563eb);box-shadow:0 0 0 3px rgba(37,99,235,.1);outline:none}.form-field input:disabled,.form-field textarea:disabled{background-color:var(--bg-secondary,#f3f4f6);cursor:not-allowed;opacity:.6}.info-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--ethos-panel-radius);display:flex;gap:var(--ethos-panel-padding-md);padding:var(--ethos-spacing-md)}.info-box .material-icons{color:var(--ethos-primary-600);flex-shrink:0;font-size:20px}.info-box div{flex:1}.info-box strong{color:var(--ethos-primary-800);display:block;font-size:14px;margin-bottom:var(--ethos-spacing-xs)}.info-box p{color:var(--ethos-primary-900);font-size:13px;line-height:1.5;margin:0}.modal-actions{display:flex;gap:var(--ethos-panel-padding-md);justify-content:flex-end;margin-top:var(--ethos-spacing-sm)}.btn-primary,.btn-secondary{border-radius:var(--ethos-panel-radius-sm);font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-primary{background:var(--ethos-primary,#2563eb);color:#fff}.btn-primary:hover:not(:disabled){background:var(--ethos-primary-700)}.btn-primary:disabled{opacity:.5}.btn-secondary{background:#fff}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary,#f3f4f6)}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.error-message{background-color:#fef2f2;border-radius:var(--ethos-panel-radius-sm);color:var(--ethos-error-600);font-size:14px;padding:var(--ethos-panel-padding-md)}.patient-onboarding{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1000px;padding:var(--ethos-spacing-md)}.onboarding-header{margin-bottom:40px;text-align:center}.onboarding-header h2{color:var(--text-primary,#1f2937);font-size:32px;font-weight:700;margin:0 0 8px}.onboarding-header p{color:var(--text-muted,#6b7280);font-size:18px;margin:0 0 24px}.progress-bar{background-color:var(--bg-primary,#e5e7eb);height:8px;overflow:hidden;width:100%}.progress-bar,.progress-fill{border-radius:var(--ethos-panel-radius-sm)}.progress-fill{background:linear-gradient(90deg,var(--ethos-secondary-600) 0,#10b981 100%);height:100%;transition:width .3s ease}.onboarding-content,.setup-steps{display:flex;flex-direction:column;gap:var(--ethos-spacing-lg)}.setup-step{background:var(--bg-primary,#fff);border:2px solid #e5e7eb;border-radius:var(--ethos-panel-radius-lg);padding:var(--ethos-spacing-lg);transition:all .3s ease}.setup-step.completed{background:#f0fdf4;border-color:var(--color-success,#10b981)}.setup-step.in-progress{background:#eff6ff;border-color:var(--text-primary,#3b82f6)}.step-header{align-items:flex-start;display:flex;gap:var(--ethos-spacing-md);margin-bottom:var(--ethos-spacing-md)}.step-icon{align-items:center;background:var(--bg-primary,#fff);border:2px solid #e5e7eb;border-radius:50%;display:flex;font-size:24px;height:40px;justify-content:center;width:40px}.setup-step.completed .step-icon{background:#10b981;border-color:var(--color-success,#10b981)}.setup-step.in-progress .step-icon{background:#3b82f6;border-color:var(--text-primary,#3b82f6)}.step-info h3{color:var(--text-primary,#1f2937);font-size:20px;font-weight:600;margin:0 0 4px}.step-info p{color:var(--text-muted,#6b7280);font-size:16px;line-height:1.5;margin:0}.step-form{border:1px solid var(--border-light,#e5e7eb);margin-top:var(--ethos-spacing-lg);padding-top:var(--ethos-spacing-lg)}.form-fields{display:flex;flex-direction:column;gap:var(--ethos-spacing-md)}.form-fields h3{color:var(--text-primary,#1f2937);font-size:24px;font-weight:600;margin:0 0 8px}.form-fields h4{color:var(--text-secondary,#374151);font-size:18px;font-weight:600;margin:0 0 8px}.form-row{gap:var(--ethos-spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-group{display:flex;flex-direction:column;gap:var(--ethos-spacing-sm)}.form-group input,.form-group select,.form-group textarea{background:var(--bg-primary,#fff);border:1px solid var(--border-medium,#d1d5db);border-radius:var(--ethos-panel-radius);font-size:16px;padding:12px 16px;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--text-primary,#3b82f6);box-shadow:0 0 0 3px rgba(59,130,246,.1);outline:none}.form-group input:required:invalid{border-color:var(--color-error,#ef4444)}.form-group small{color:var(--text-muted,#6b7280);font-size:12px;margin-top:var(--ethos-spacing-xs)}.form-actions{border:1px solid var(--border-light,#e5e7eb)}.btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:var(--ethos-panel-radius);cursor:pointer;font-size:16px;font-weight:600;padding:12px 32px;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 4px 12px rgba(59,130,246,.3);transform:translateY(-1px)}.btn-primary:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.btn-secondary{border:1px solid var(--border-medium,#d1d5db);border-radius:var(--ethos-panel-radius);color:var(--text-muted,#6b7280);cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .2s ease}.btn-secondary:hover{background:var(--bg-secondary,#f9fafb);border-color:var(--text-primary,#9ca3af);color:var(--text-secondary,#374151)}.validation-error{background:#fef2f2;border:1px solid var(--border-light,#fecaca);border-radius:var(--ethos-panel-radius);color:var(--color-error,#dc2626);font-size:14px;margin-top:var(--ethos-spacing-md);padding:12px 16px}.hipaa-notice{background:#f3f4f6;border:1px solid var(--border-medium,#d1d5db);border-radius:var(--ethos-panel-radius);margin-top:var(--ethos-spacing-lg);padding:var(--ethos-spacing-md)}.hipaa-notice h4{color:var(--text-secondary,#374151);font-size:16px;font-weight:600;margin:0 0 8px}.hipaa-notice p{color:var(--text-muted,#6b7280);font-size:14px;line-height:1.5;margin:0}@media(max-width:768px){.patient-onboarding{padding:var(--ethos-spacing-md)}.onboarding-header h2{font-size:28px}.onboarding-header p{font-size:16px}.setup-step{padding:var(--ethos-spacing-md)}.step-header{flex-direction:column;gap:var(--ethos-panel-padding-md);text-align:center}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column;gap:var(--ethos-panel-padding-md)}.btn-primary,.btn-secondary{width:100%}}@media print{.patient-onboarding{max-width:none;padding:0}.form-actions{display:none}.step-form{border-top:none;padding-top:0}}.provider-modal-overlay{align-items:center;animation:fadeIn .3s ease-out;backdrop-filter:blur(4px);background:rgba(0,0,0,.5);bottom:0;display:flex;justify-content:center;left:0;padding:var(--ethos-spacing-md);position:fixed;right:0;top:0;z-index:10000}.provider-modal-overlay.closing{animation:fadeOut .3s ease-out}.provider-modal-container{animation:slideIn .3s ease-out;background:var(--bg-primary,#fff);border-radius:var(--ethos-panel-radius-lg);box-shadow:0 25px 50px -12px rgba(0,0,0,.25);display:flex;flex-direction:column;max-height:90vh;max-width:1200px;overflow:hidden;width:100%}.provider-modal-container.closing{animation:slideOut .3s ease-out}.provider-modal-header{background:#f8fafc;border:1px solid var(--border-light,#e5e7eb);flex-shrink:0;justify-content:space-between;padding:24px 32px}.provider-modal-header,.provider-modal-title{align-items:center;display:flex}.provider-modal-title h2{color:var(--text-primary,#1f2937);font-size:20px;font-weight:600;margin:0}.provider-modal-close{align-items:center;background:none;border:none;border-radius:var(--ethos-panel-radius-sm);color:var(--text-muted,#6b7280);cursor:pointer;display:flex;justify-content:center;padding:var(--ethos-spacing-sm);transition:all .2s ease}.provider-modal-close:hover{background:#f3f4f6;color:var(--text-secondary,#374151)}.provider-modal-close:active{background:#e5e7eb}.provider-modal-content{flex:1;overflow-y:auto;padding:0}.provider-modal-content .onboarding-wizard{background:transparent;padding:var(--ethos-spacing-xl)}.provider-modal-content .guided-setup{margin:0;max-width:none;padding:0}.provider-modal-content .step-header{background:#f8fafc;margin-bottom:var(--ethos-spacing-lg);padding:var(--ethos-spacing-md)}.provider-modal-content .step-form,.provider-modal-content .step-header{border:1px solid var(--border-light,#e5e7eb);border-radius:var(--ethos-panel-radius)}.provider-modal-content .step-form{background:var(--bg-primary,#fff);padding:var(--ethos-spacing-lg)}@media(max-width:768px){.provider-modal-overlay{padding:var(--ethos-spacing-sm)}.provider-modal-container{max-height:95vh;max-width:100%}.provider-modal-content .onboarding-wizard,.provider-modal-header{padding:var(--ethos-spacing-md)}.provider-modal-title h2{font-size:18px}}@media(max-width:480px){.provider-modal-content .onboarding-wizard,.provider-modal-header{padding:var(--ethos-spacing-md)}.provider-modal-title{align-items:flex-start;flex-direction:column;gap:var(--ethos-spacing-xs)}.provider-modal-title h2{font-size:16px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.95)}}.provider-modal-content::-webkit-scrollbar{width:6px}.provider-modal-content::-webkit-scrollbar-track{background:#f1f5f9}.provider-modal-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.provider-modal-content::-webkit-scrollbar-thumb:hover{background:var(--ethos-neutral-400)}.patient-edit-modal-content{max-height:calc(90vh - 120px);overflow-y:auto;padding:0}.patient-edit-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:60px 20px}.patient-edit-loading .loading-spinner{animation:fadeInOut 2s ease-in-out infinite;margin-bottom:16px;opacity:.6}.patient-edit-loading .loading-text{color:var(--text-muted,#6b7280);font-size:14px}.tab-navigation{border-bottom:2px solid var(--border-light,#e5e7eb);overflow-x:auto;padding-bottom:0}.tab-button{color:var(--text-secondary,#6b7280);font-size:14px;transition:all .2s ease;white-space:nowrap}.tab-button:hover{background:var(--bg-secondary,#f9fafb);color:var(--text-primary,#111827)}.tab-button.active{border-bottom-color:var(--ethos-primary,#2563eb);color:var(--ethos-primary,#2563eb)}.tab-button svg{font-size:18px}.form-section{margin-bottom:32px}.subscriber-section{border-top:1px solid var(--border-light,#e5e7eb);margin-top:24px;padding-top:24px}.subscriber-section h3{color:var(--text-primary,#111827);font-size:16px;font-weight:600;margin:0 0 16px}.form-actions{margin-top:32px;padding-top:24px}.btn-cancel,.btn-delete,.btn-save{border-radius:8px}@media(max-width:768px){.form-grid-2,.form-grid-3{grid-template-columns:1fr}.tab-navigation{overflow-x:auto;-webkit-overflow-scrolling:touch}.form-actions{flex-direction:column;gap:12px}.actions-left,.actions-right{width:100%}.actions-left button,.actions-right button{flex:1}}.provider-edit-modal-content{max-height:calc(90vh - 120px);overflow-y:auto;padding:0}.provider-edit-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:60px 20px}.provider-edit-loading .loading-spinner{animation:fadeInOut 2s ease-in-out infinite;margin-bottom:var(--ethos-spacing-md);opacity:.6}.provider-edit-loading .loading-text{color:var(--text-muted,#6b7280);font-size:14px}.form-container{padding:0}.form-section{margin-bottom:var(--ethos-spacing-xl)}.section-header{align-items:center;display:flex;gap:var(--ethos-spacing-sm);margin-bottom:var(--ethos-spacing-md)}.section-header h2{color:var(--text-primary,#111827);font-size:18px}.form-grid-2,.form-grid-3{display:grid;gap:var(--ethos-spacing-md)}.form-field-checkbox{margin-bottom:var(--ethos-spacing-md)}.form-field-checkbox label{gap:var(--ethos-spacing-sm)}.form-actions{align-items:center;border-top:1px solid var(--border-light,#e5e7eb);margin-top:var(--ethos-spacing-xl);padding-top:var(--ethos-spacing-lg)}.actions-left,.actions-right{gap:var(--ethos-panel-padding-md)}.btn-cancel{background:#fff;border:1px solid var(--border-medium,#d1d5db);border-radius:var(--ethos-panel-radius);color:var(--text-secondary,#6b7280);font-size:14px;font-weight:500;padding:10px 24px;transition:all .2s ease}.btn-cancel:hover{background:var(--bg-secondary,#f9fafb);border-color:var(--border-dark,#9ca3af)}.btn-save{background:var(--ethos-primary,#2563eb);border-radius:var(--ethos-panel-radius);color:#fff;font-size:14px;font-weight:500;padding:10px 24px;transition:all .2s ease}.btn-save:hover:not(:disabled){background:var(--ethos-primary-700,#1d4ed8)}.btn-save:disabled{background:var(--border-medium,#d1d5db)}.btn-delete{background:#fff;border:1px solid var(--color-error,#dc2626);border-radius:var(--ethos-panel-radius);color:var(--color-error,#dc2626);font-size:14px;font-weight:500;padding:10px 24px;transition:all .2s ease}.btn-delete:hover{background:var(--color-error,#dc2626);color:#fff}@media(max-width:768px){.form-grid-2,.form-grid-3{grid-template-columns:1fr}.form-actions{flex-direction:column;gap:var(--ethos-panel-padding-md)}.actions-left,.actions-right{width:100%}.actions-left button,.actions-right button{flex:1}}.main-workspace{background-color:var(--bg-secondary,#f9fafb);flex:1;overflow:hidden;position:relative}.workspace-content{height:100%;overflow-x:hidden;overflow-y:auto;padding:0!important;width:100%;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.main-workspace .workspace-content{animation:slideInFromRight .3s ease-out}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@media(max-width:768px){.main-workspace{padding-top:0}.workspace-content{padding:0!important}}@media(min-width:769px)and (max-width:1024px){.workspace-content{padding:0!important}}@media(min-width:1025px){.workspace-content{margin:0;max-width:100%;padding:0!important}}@media(prefers-reduced-motion:reduce){.main-workspace .workspace-content{animation:none}}.offline-indicator{align-items:center;animation:slideDown .3s ease-out;box-shadow:0 2px 8px rgba(0,0,0,.15);display:flex;justify-content:space-between;left:0;padding:12px 20px;position:fixed;right:0;top:0;z-index:10000}.offline-indicator.offline{background:#fee2e2;border-bottom:2px solid var(--ethos-error);color:var(--text-primary,#991b1b)}.offline-indicator.online{background:#d1fae5;border-bottom:2px solid var(--ethos-success);color:var(--text-primary,#065f46)}.offline-indicator.fade-out{animation:slideUp .3s ease-in forwards}.offline-content{align-items:center;display:flex;flex:1;gap:var(--ethos-panel-padding-md)}.offline-icon{font-size:20px;line-height:1}.offline-message{font-size:14px;font-weight:600;line-height:1.4}.offline-close{background:none;border:none;color:inherit;cursor:pointer;font-size:18px;margin-left:var(--ethos-panel-padding-md);opacity:.7;padding:var(--ethos-spacing-xs);transition:opacity .2s}.offline-close:hover{opacity:1}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}@media(max-width:767px){.offline-indicator{padding:10px 16px}.offline-message{font-size:13px}.offline-icon{font-size:18px}}.subscription-modal-overlay{align-items:center;backdrop-filter:blur(4px);background:rgba(0,0,0,.7);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.subscription-modal-content{animation:slideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px rgba(0,0,0,.25);max-height:90vh;max-width:600px;overflow-y:auto;width:90%}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.subscription-modal-header{border-bottom:1px solid var(--border-light,#e5e7eb);padding:40px 32px 24px;text-align:center}.subscription-modal-header h2{color:var(--text-primary,#1f2937);font-size:28px;font-weight:700;margin:16px 0 8px}.subtitle{color:var(--text-secondary,#6b7280);font-size:16px;margin:0}.subscription-modal-body{padding:var(--ethos-spacing-xl)}.main-message{color:var(--text-primary,#374151);font-size:15px;line-height:1.6;margin:0 0 24px;text-align:center}.release-info{background:#f0f9ff;border:1px solid #bae6fd;border-radius:var(--ethos-panel-radius-lg);margin-bottom:var(--ethos-spacing-lg);padding:var(--ethos-spacing-md)}.release-info h3{color:#0369a1;font-size:16px;font-weight:600;margin:0 0 16px}.features-list{list-style:none;margin:0;padding:0}.features-list li{align-items:center;color:#075985;display:flex;font-size:14px;gap:var(--ethos-panel-padding-md);padding:8px 0}.features-list li svg{color:var(--ethos-success);flex-shrink:0;font-size:20px}.pricing-card{background:linear-gradient(135deg,var(--ethos-primary-600) 0,var(--ethos-primary-700) 100%);border-radius:var(--ethos-panel-radius-lg);margin-bottom:var(--ethos-spacing-lg);padding:var(--ethos-spacing-xl);text-align:center}.price-tag{align-items:baseline;display:flex;gap:var(--ethos-spacing-xs);justify-content:center;margin-bottom:var(--ethos-panel-padding-md)}.currency{color:#fff;font-size:32px;font-weight:700}.amount{color:#fff;font-size:64px;font-weight:800;line-height:1}.period{color:hsla(0,0%,100%,.9);font-size:20px;font-weight:500}.price-description{color:hsla(0,0%,100%,.95);font-size:14px;font-weight:500}.btn-subscribe{background:var(--ethos-primary-600);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;margin-bottom:var(--ethos-spacing-md);padding:var(--ethos-spacing-md);transition:all .2s;width:100%}.btn-subscribe:hover{background:var(--ethos-primary-700);box-shadow:0 8px 16px rgba(37,99,235,.3);transform:translateY(-2px)}.help-text{color:var(--text-tertiary,#9ca3af);font-size:13px;margin:0;text-align:center}@media(max-width:768px){.subscription-modal-content{width:95%}.subscription-modal-header{padding:32px 24px 20px}.subscription-modal-header h2{font-size:24px}.pricing-card,.subscription-modal-body{padding:var(--ethos-spacing-lg)}.amount{font-size:48px}}.marketing-page{background:#fff;color:var(--text-primary,#1f2937);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.marketing-header{backdrop-filter:blur(10px);background:hsla(0,0%,100%,.98);border-bottom:1px solid var(--border-light,#e5e7eb);padding:1rem 0;position:sticky;top:0;z-index:100}.marketing-container{margin:0 auto;max-width:1200px;padding:0 2rem}.marketing-header-content{align-items:center;display:flex;justify-content:space-between}.marketing-nav{align-items:center;display:flex;gap:1.5rem}.marketing-nav-link{background:none;border:none;color:var(--text-secondary,#4b5563);cursor:pointer;font-size:1rem;font-weight:500;text-decoration:none;transition:color .2s}.marketing-nav-link:hover{color:var(--color-ocean-blue-600,#2563eb)}.marketing-btn-primary{background:linear-gradient(135deg,var(--color-ocean-blue-600,#2563eb) 0,var(--color-ocean-blue-700,#1d4ed8) 100%);border:none;border-radius:8px;color:var(--bg-primary,#fff);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.marketing-btn-primary:hover{box-shadow:0 10px 20px rgba(37,99,235,.3);transform:translateY(-2px)}.marketing-btn-secondary{align-items:center;background:var(--bg-primary,#fff);border:2px solid var(--color-ocean-blue-600,#2563eb);border-radius:8px;color:var(--color-ocean-blue-600,#2563eb);cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.marketing-btn-secondary:hover{background:#eff6ff;transform:translateY(-2px)}.marketing-btn-outline{background:transparent;border:2px solid var(--color-ocean-blue-600,#2563eb);border-radius:8px;color:var(--color-ocean-blue-600,#2563eb);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.marketing-btn-outline:hover{background:#eff6ff}.marketing-btn-large{font-size:1.125rem;padding:1rem 2rem}.marketing-btn-full{justify-content:center;width:100%}.marketing-hero{background:linear-gradient(135deg,#eff6ff,#dbeafe);padding:5rem 0;text-align:center}.marketing-hero-content{margin:0 auto;max-width:900px}.marketing-hero-title{color:var(--text-primary,#111827);font-size:3.5rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.marketing-hero-subtitle{color:var(--text-secondary,#4b5563);font-size:1.5rem;line-height:1.6;margin-bottom:2.5rem}.marketing-hero-values{display:flex;flex-direction:column;gap:1rem;margin:2.5rem auto;max-width:700px;text-align:left}.marketing-value-item{align-items:center;display:flex;font-size:1.125rem;font-weight:500;gap:.75rem}.marketing-check-icon{color:#10b981;flex-shrink:0}.marketing-hero-cta{display:flex;gap:1rem;justify-content:center;margin:2.5rem 0}.marketing-trust-text{color:#6b7280;font-style:italic;margin-top:2rem}.marketing-section{padding:5rem 0}.marketing-section-title{color:var(--text-primary,#111827);font-size:2.5rem;font-weight:800;margin-bottom:1rem;text-align:center}.marketing-section-subtitle{color:#6b7280;font-size:1.25rem;margin-bottom:3rem;text-align:center}.marketing-problem-section{background:var(--bg-secondary,#f9fafb)}.marketing-problem-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:3rem}.marketing-problem-card{background:var(--bg-primary,#fff);border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,.05);padding:2rem}.marketing-problem-icon{font-size:3rem;margin-bottom:1rem}.marketing-problem-card h3{color:var(--text-primary,#111827);font-size:1.5rem;font-weight:700;margin-bottom:1rem}.marketing-problem-list{list-style:none;padding:0}.marketing-problem-list li{color:var(--text-secondary,#4b5563);padding:.5rem 0 .5rem 1.5rem;position:relative}.marketing-problem-list li:before{color:#ef4444;content:"•";font-weight:700;left:0;position:absolute}.marketing-cost-highlight{background:var(--bg-primary,#fff);border:2px solid #fbbf24;border-radius:12px;padding:2rem;text-align:center}.marketing-cost-highlight h4{color:var(--text-primary,#111827);font-size:1.5rem;margin-bottom:1rem}.marketing-cost-items{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.marketing-cost-items span{background:#fef3c7;border-radius:8px;color:#92400e;font-weight:600;padding:.5rem 1rem}.marketing-steps{display:flex;flex-direction:column;gap:4rem}.marketing-step{background:var(--bg-primary,#fff);border:2px solid var(--border-light,#e5e7eb);border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,.05);padding:3rem}.marketing-step-badge{background:var(--color-ocean-blue-600,#2563eb);border-radius:20px;color:var(--bg-primary,#fff);display:inline-block;font-size:.875rem;font-weight:700;margin-bottom:1rem;padding:.5rem 1rem}.marketing-step-icon{font-size:3rem;margin-bottom:1rem}.marketing-step h3{color:var(--text-primary,#111827);font-size:2rem;font-weight:700;margin-bottom:1.5rem}.marketing-step-intro{color:var(--text-secondary,#4b5563);font-size:1.125rem;margin-bottom:1.5rem}.marketing-step-features{display:flex;flex-direction:column;gap:1.5rem;margin:2rem 0}.marketing-feature-group{background:var(--bg-secondary,#f9fafb);border-radius:8px;padding:1.5rem}.marketing-feature-group h4{color:var(--text-primary,#111827);font-size:1.125rem;font-weight:700;margin-bottom:1rem}.marketing-feature-item{align-items:flex-start;display:flex;gap:.75rem;padding:.5rem 0}.marketing-feature-item svg{color:#10b981;flex-shrink:0;margin-top:.25rem}.marketing-dictation-example{align-items:flex-start;background:#eff6ff;border-left:4px solid var(--color-ocean-blue-600,#2563eb);border-radius:8px;display:flex;gap:1rem;margin:1.5rem 0;padding:1.5rem}.marketing-dictation-example svg{color:var(--color-ocean-blue-600,#2563eb);flex-shrink:0}.marketing-dictation-example p{color:var(--color-ocean-blue-700,#1e40af);font-style:italic;margin:0}.marketing-before-after{background:var(--bg-secondary,#f3f4f6);border-radius:8px;margin-top:2rem;padding:1.5rem}.marketing-ba-item{border-bottom:1px solid var(--border-medium,#d1d5db);padding:.75rem 0}.marketing-ba-item:last-of-type{border-bottom:none}.marketing-ba-result{background:#dcfce7;border-radius:6px;color:#166534;font-weight:600;margin-top:1rem;padding:1rem}.marketing-features-section{background:var(--bg-secondary,#f9fafb)}.marketing-features-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.marketing-feature-card{background:var(--bg-primary,#fff);border-radius:12px;box-shadow:0 2px 4px rgba(0,0,0,.05);padding:2rem;transition:transform .2s,box-shadow .2s}.marketing-feature-card:hover{box-shadow:0 8px 16px rgba(0,0,0,.1);transform:translateY(-4px)}.marketing-feature-icon{font-size:2.5rem;margin-bottom:1rem}.marketing-feature-card h3{color:var(--text-primary,#111827);font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.marketing-feature-card p{color:#6b7280;line-height:1.6}.marketing-pricing-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:3rem 0}.marketing-pricing-card{background:var(--bg-primary,#fff);border:2px solid var(--border-light,#e5e7eb);border-radius:16px;padding:2rem;position:relative;transition:transform .2s,box-shadow .2s}.marketing-pricing-card:hover{box-shadow:0 12px 24px rgba(0,0,0,.1);transform:translateY(-4px)}.marketing-pricing-card-featured{border-color:var(--color-ocean-blue-600,#2563eb);box-shadow:0 8px 16px rgba(37,99,235,.2)}.marketing-pricing-badge{background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:20px;color:var(--bg-primary,#fff);font-size:.875rem;font-weight:700;left:50%;padding:.5rem 1rem;position:absolute;top:-12px;transform:translateX(-50%);white-space:nowrap}.marketing-pricing-header{border-bottom:1px solid var(--border-light,#e5e7eb);margin-bottom:2rem;padding-bottom:2rem;text-align:center}.marketing-pricing-header h3{color:var(--text-primary,#111827);font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.marketing-pricing-price{margin:1rem 0}.marketing-pricing-amount{color:var(--color-ocean-blue-600,#2563eb);font-size:3rem;font-weight:800}.marketing-pricing-period{color:#6b7280;font-size:1.125rem}.marketing-pricing-desc{color:#6b7280;font-size:.875rem}.marketing-pricing-features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.marketing-pricing-feature{align-items:flex-start;display:flex;font-size:.875rem;gap:.75rem}.marketing-pricing-feature svg{color:#10b981;flex-shrink:0;margin-top:.125rem}.marketing-pricing-feature-excluded svg{color:var(--border-medium,#d1d5db)}.marketing-pricing-feature-excluded{color:var(--color-disabled-text,#9ca3af)}.marketing-pricing-examples{border-top:1px solid var(--border-light,#e5e7eb);color:#6b7280;font-size:.875rem;margin-top:1.5rem;padding-top:1.5rem}.marketing-pricing-examples p{margin:.5rem 0}.marketing-guarantee{background:#dcfce7;border:2px solid #10b981;border-radius:12px;margin-top:3rem;padding:2rem;text-align:center}.marketing-guarantee h4{color:#166534;font-size:1.5rem;margin-bottom:.75rem}.marketing-guarantee p{color:#166534;font-size:1.125rem}.marketing-faq-list{margin:0 auto;max-width:800px}.marketing-faq-item{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e7eb);border-radius:8px;margin-bottom:1rem;overflow:hidden}.marketing-faq-question{align-items:center;background:none;border:none;color:var(--text-primary,#111827);cursor:pointer;display:flex;font-size:1.125rem;font-weight:600;justify-content:space-between;padding:1.5rem;text-align:left;transition:background .2s;width:100%}.marketing-faq-question:hover{background:var(--bg-secondary,#f9fafb)}.marketing-faq-answer{color:var(--text-secondary,#4b5563);line-height:1.6;padding:0 1.5rem 1.5rem}.marketing-cta-section{background:linear-gradient(135deg,var(--color-ocean-blue-700,#1e40af) 0,#1e3a8a 100%);color:var(--bg-primary,#fff);text-align:center}.marketing-cta-title{color:var(--bg-primary,#fff);font-size:3rem;font-weight:800;margin-bottom:1rem}.marketing-cta-subtitle{color:#dbeafe;font-size:1.5rem;margin-bottom:2.5rem}.marketing-cta-values{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:3rem auto;max-width:900px}.marketing-cta-value{align-items:center;display:flex;font-size:1.125rem;font-weight:500;gap:.75rem}.marketing-cta-value svg{color:#10b981;flex-shrink:0}.marketing-cta-buttons{gap:1rem}.marketing-cta-buttons,.marketing-cta-trust{display:flex;justify-content:center;margin:2.5rem 0}.marketing-cta-trust{color:#dbeafe;flex-wrap:wrap;gap:2rem}.marketing-cta-encouragement{color:#dbeafe;font-size:1.125rem;font-style:italic;margin:2rem auto 0;max-width:700px}.marketing-footer{background:var(--text-primary,#111827);color:var(--border-medium,#d1d5db);padding:3rem 0 2rem}.marketing-footer-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:3rem}.marketing-footer-column h4{color:var(--bg-primary,#fff);font-weight:700;margin-bottom:1rem}.marketing-footer-column a{color:var(--color-disabled-text,#9ca3af);display:block;padding:.5rem 0;text-decoration:none;transition:color .2s}.marketing-footer-column a:hover{color:var(--color-ocean-blue-600,#2563eb)}.marketing-footer-bottom{border-top:1px solid var(--text-secondary,#374151);color:var(--color-disabled-text,#9ca3af);font-size:.875rem;padding-top:2rem;text-align:center}.marketing-footer-bottom p{margin:.5rem 0}@media(max-width:768px){.marketing-hero-title{font-size:2.5rem}.marketing-hero-subtitle{font-size:1.125rem}.marketing-hero-cta{flex-direction:column}.marketing-cta-title,.marketing-section-title{font-size:2rem}.marketing-cta-buttons{flex-direction:column}.marketing-nav{display:none}.marketing-features-grid,.marketing-pricing-grid,.marketing-problem-grid{grid-template-columns:1fr}}.patient-edit-page{background:var(--ethos-canvas,#f8f9fa);margin:0;max-width:100%;min-height:100vh;padding:0}.patient-edit-page .page-header{align-items:center;display:flex;flex-wrap:nowrap;gap:var(--ethos-spacing-md,16px);justify-content:flex-start;margin-bottom:var(--ethos-spacing-lg,24px)}.patient-edit-page .back-btn{align-items:center;background:var(--ethos-panel-bg-white,#fff);border:1px solid var(--ethos-border-light,#e5e7eb);border-radius:var(--ethos-border-radius-md,8px);box-shadow:var(--ethos-elevation-sm,0 1px 3px rgba(0,0,0,.05));color:var(--ethos-text-secondary,#374151);cursor:pointer;display:flex;flex-shrink:0;height:auto;justify-content:center;padding:var(--ethos-spacing-xs,8px);transition:var(--ethos-transition-normal,all .2s);width:auto}.patient-edit-page .back-btn:hover{background:var(--ethos-panel-bg-light,#f9fafb);border-color:var(--ethos-primary,#3b82f6);box-shadow:var(--ethos-elevation-md,0 4px 8px rgba(0,0,0,.1));transform:translateY(-1px)}.patient-edit-page .back-btn .material-icons,.patient-edit-page .back-btn svg{color:var(--ethos-text-primary,#1f2937);font-size:24px}.patient-edit-page .page-title{color:#1a2b4d;font-size:var(--ethos-font-size-xl,24px);font-weight:var(--ethos-font-weight-bold,700);line-height:1;margin:0;white-space:nowrap}.tab-navigation{border-bottom:2px solid #e5e7eb;display:flex;gap:8px;margin-bottom:24px;padding:0 4px}.tab-button{align-items:center;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-muted,#6b7280);cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:8px;margin-bottom:-2px;padding:12px 20px;transition:all .2s}.tab-button:hover{background:#f0f9ff;color:var(--text-primary,#2563eb)}.tab-button.active{border-bottom-color:var(--text-primary,#2563eb);color:var(--text-primary,#2563eb);font-weight:600}.tab-button .material-icons{font-size:20px}.form-container{display:flex;flex-direction:column;gap:24px;margin:0;max-width:100%;width:100%}.form-section{background:var(--bg-primary,#fff);border:none;border-radius:12px;box-shadow:var(--shadow-sm,0 1px 3px rgba(0,0,0,.1));padding:24px}.section-header{border-bottom:2px solid #f3f4f6;margin-bottom:20px;padding-bottom:12px}.section-header h2{color:var(--text-primary,#1e3a8a);font-size:16px;font-weight:600;letter-spacing:.5px;margin:0;text-transform:uppercase}.form-field{display:flex;flex-direction:column;gap:8px}.form-field label{color:var(--text-secondary,#374151);font-size:14px;font-weight:500}.form-field .required{color:var(--color-error,#ef4444);margin-left:2px}.form-field input,.form-field select,.form-field textarea{background:var(--bg-primary,#fff);border:1px solid var(--border-medium,#d1d5db);border-radius:12px;box-sizing:border-box;color:var(--text-primary,#1f2937);font-family:inherit;font-size:15px;padding:14px 16px;transition:all .2s;width:100%}.form-field select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:var(--bg-primary,#fff);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='%236B7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:20px;cursor:pointer;padding-right:44px}.form-field select::-ms-expand{display:none}.form-field select::-webkit-calendar-picker-indicator,.form-field select::-webkit-inner-spin-button,.form-field select::-webkit-outer-spin-button{-webkit-appearance:none;display:none}.form-field select option{background:var(--bg-primary,#fff);color:var(--text-primary,#1f2937);font-size:15px;padding:10px}.form-field input::-moz-placeholder{color:var(--text-primary,#9ca3af)}.form-field input::placeholder{color:var(--text-primary,#9ca3af)}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--text-primary,#3b82f6);box-shadow:0 0 0 4px rgba(59,130,246,.1);outline:none}.form-field textarea{min-height:80px;resize:vertical}.form-grid-2{display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-grid-3{display:grid;gap:16px;grid-template-columns:1fr 1fr 1fr}.form-field-wide{grid-column:span 2}.form-field-checkbox{margin:12px 0}.form-field-checkbox label{align-items:center;color:var(--text-secondary,#374151);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px}.form-field-checkbox input[type=checkbox]{cursor:pointer;height:18px;margin:0;width:18px}.form-actions{align-items:flex-end;background:var(--bg-primary,#fff);border-radius:12px;bottom:0;box-shadow:var(--shadow-sm,0 1px 3px rgba(0,0,0,.1));justify-content:space-between;padding:24px;position:sticky;z-index:10}.actions-left,.actions-right{align-items:flex-end;display:flex;gap:12px}.btn-delete{background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:12px;box-shadow:0 2px 4px rgba(239,68,68,.2);color:var(--white,#fff);cursor:pointer;font-size:15px;font-weight:600;padding:14px 24px;transition:all .2s}.btn-delete:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 8px rgba(239,68,68,.3);transform:translateY(-2px)}.btn-cancel{align-items:center;background:#f3f4f6;border:none;border-radius:12px;color:var(--text-secondary,#374151);cursor:pointer;display:flex;font-size:15px;font-weight:600;height:52px;justify-content:center;padding:16px 32px;transition:all .2s}.btn-cancel:hover{background:#e5e7eb;transform:translateY(-2px)}.btn-save{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;box-shadow:0 2px 4px rgba(16,185,129,.2);color:var(--white,#fff);cursor:pointer;display:flex;font-size:15px;font-weight:600;height:52px;justify-content:center;padding:16px 32px;transition:all .2s}.btn-save:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px rgba(16,185,129,.3);transform:translateY(-2px)}.btn-save:disabled{cursor:not-allowed;opacity:.6}.btn-cancel:active,.btn-delete:active,.btn-save:active:not(:disabled){transform:translateY(0)}.loading-state{padding:64px 24px;text-align:center}.loading-spinner{align-items:center;animation:fadeInOut 2s ease-in-out infinite;display:flex;height:40px;justify-content:center;margin:0 auto 16px;width:40px}@keyframes fadeInOut{0%,to{opacity:.3}50%{opacity:1}}.loading-text{color:var(--text-muted,#64748b);font-size:14px;margin:0}@media(max-width:768px){.patient-edit-page{padding:0}.page-header{margin-bottom:16px}.page-title{font-size:22px}.form-container{gap:16px}.form-section{padding:16px}.form-grid-2,.form-grid-3{grid-template-columns:1fr}.form-field-wide{grid-column:span 1}.form-actions{flex-direction:column;gap:12px;padding:16px}.actions-left,.actions-right{flex-direction:column;width:100%}.btn-cancel,.btn-delete,.btn-save{width:100%}}@media(min-width:769px)and (max-width:1024px){.form-grid-3{grid-template-columns:1fr 1fr}.form-field-wide{grid-column:span 1}}@media(min-width:1025px){.patient-edit-page{padding:0}}.multi-booking-page{margin:0;max-width:100%;min-height:100vh;padding:20px 20px 100px;width:100%}.loading-state{color:var(--text-muted,#6b7280);font-size:16px;justify-content:center;min-height:200px}.booking-header,.loading-state{align-items:center;display:flex}.booking-header{gap:16px;margin-bottom:32px}.back-btn{background:none;border:1px solid var(--border-light,#e5e7eb);border-radius:6px;color:var(--text-secondary,#374151);cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s}.back-btn:hover{background:#f1f5f9;border-color:var(--text-primary,#2563eb);color:var(--text-primary,#2563eb)}.booking-title{color:var(--text-primary,#1e3a8a);flex:1;font-size:24px;font-weight:600;margin:0}.appointments-container{background:var(--bg-primary,#fff);border-radius:12px;box-shadow:var(--shadow-sm,0 1px 3px rgba(0,0,0,.1));padding:24px}.empty-state{padding:48px 20px;text-align:center}.empty-icon{font-size:64px;margin-bottom:16px}.empty-title{color:var(--text-secondary,#374151);font-size:20px;font-weight:600;margin:0 0 8px}.empty-subtitle{color:var(--text-muted,#64748b);font-size:14px;margin:0 0 24px}.appointments-list{margin-bottom:24px}.appointment-slot{align-items:flex-start;background:var(--bg-secondary,#f9fafb);border:1px solid var(--border-light,#e5e7eb);border-radius:8px;display:flex;gap:16px;margin-bottom:12px;padding:16px;transition:all .2s}.appointment-slot:hover{background:#f1f5f9;border-color:var(--text-primary,#2563eb)}.slot-number{align-items:center;background:#2563eb;border-radius:50%;color:var(--white,#fff);display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:32px;justify-content:center;min-width:32px}.slot-details{flex:1}.slot-patient{color:var(--text-primary,#1e3a8a);font-size:16px;font-weight:600;margin-bottom:4px}.slot-info{color:var(--text-muted,#64748b);font-size:14px;margin-bottom:4px}.slot-service{color:var(--color-success,#059669);font-size:13px;font-weight:500}.slot-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}.edit-btn,.remove-btn{align-items:center;background:none;border:1px solid var(--border-light,#e5e7eb);border-radius:6px;color:var(--text-muted,#64748b);cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:all .2s;width:32px}.edit-btn:hover{background:#eff6ff;border-color:var(--text-primary,#3b82f6);color:var(--text-primary,#3b82f6)}.remove-btn:hover{background:#fef2f2;border-color:var(--color-error,#ef4444);color:var(--color-error,#ef4444)}.add-form{background:#eff6ff;border:2px solid #2563eb;border-radius:8px;margin-top:16px;padding:20px}.form-title{color:var(--text-primary,#1e3a8a);font-size:18px;font-weight:600;margin:0 0 20px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary,#374151);display:block;font-size:14px;font-weight:500;margin-bottom:6px}.form-input{padding:10px 12px}.form-input,.form-select{border:1px solid var(--border-medium,#d1d5db);border-radius:6px;color:var(--text-secondary,#374151);font-size:14px;transition:all .2s;width:100%}.form-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;-ms-appearance:none;background-color:var(--bg-primary,#fff);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%236B7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;cursor:pointer;padding:10px 44px 10px 12px}.form-input:focus,.form-select:focus{border-color:var(--text-primary,#2563eb);box-shadow:0 0 0 3px rgba(37,99,235,.1);outline:none}.form-select:focus{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%232563EB' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.form-select::-ms-expand{display:none!important;opacity:0}.form-select::-webkit-calendar-picker-indicator,.form-select::-webkit-inner-spin-button,.form-select::-webkit-outer-spin-button{-webkit-appearance:none!important;display:none!important;opacity:0}@-moz-document url-prefix(){.form-select{text-indent:.01px;text-overflow:""}}.form-row{display:grid;gap:12px;grid-template-columns:1fr 1fr}.form-actions{display:flex;gap:12px;margin-top:20px}.btn-primary,.btn-secondary{border:none;border-radius:6px;cursor:pointer;flex:1;font-size:14px;font-weight:600;padding:12px 20px;transition:all .2s}.btn-secondary{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e7eb);color:var(--text-secondary,#374151)}.btn-secondary:hover{background:#f1f5f9;border-color:var(--text-primary,#2563eb);color:var(--text-primary,#2563eb)}.btn-primary{background:#2563eb;color:var(--white,#fff)}.btn-primary:hover{background:#1e3a8a}.add-appointment-btn{align-items:center;background:var(--bg-primary,#fff);border:2px dashed #d1d5db;border-radius:8px;color:var(--text-primary,#2563eb);cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:14px 20px;transition:all .2s;width:100%}.add-appointment-btn:hover{background:#eff6ff;border-color:var(--text-primary,#2563eb);border-style:solid}.add-icon{font-size:20px;line-height:1}.submit-container{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e7eb);bottom:0;box-shadow:0 -2px 8px rgba(0,0,0,.1);left:0;padding:16px 20px;position:fixed;right:0;z-index:100}.submit-container,.submit-container-inline{align-items:center;display:flex;justify-content:center}.submit-container-inline{margin-top:20px}.submit-all-btn{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;box-shadow:0 4px 6px rgba(16,185,129,.2);color:var(--white,#fff);cursor:pointer;display:block;font-size:16px;font-weight:600;padding:16px 24px;transition:all .2s;width:100%}.submit-all-btn:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 6px 10px rgba(16,185,129,.3);transform:translateY(-2px)}.submit-all-btn:active{transform:translateY(0)}@media(max-width:767px){.multi-booking-page{padding:12px 12px 100px}.booking-header{margin-bottom:20px}.booking-title{font-size:20px}.appointments-container{padding:16px}.appointment-slot{gap:12px;padding:12px}.slot-patient{font-size:15px}.slot-info{font-size:13px}.form-row{gap:0;grid-template-columns:1fr}.add-form{padding:16px}.form-actions{flex-direction:column}.submit-container{padding:12px 16px}.submit-all-btn{font-size:15px;padding:14px 20px}}.typeahead-container{position:relative}.typeahead-dropdown{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e7eb);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.1);left:0;margin-top:4px;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.typeahead-item{border:1px solid var(--border-light,#f3f4f6);cursor:pointer;padding:12px 16px;transition:background .2s}.typeahead-item:last-child{border-bottom:none}.typeahead-item:hover{background:var(--bg-secondary,#f9fafb)}.typeahead-name{color:var(--text-primary,#1f2937);font-size:15px;font-weight:500;margin-bottom:4px}.typeahead-dob{color:var(--text-muted,#6b7280);font-size:13px}.typeahead-empty{color:var(--text-primary,#9ca3af);font-size:14px;padding:16px;text-align:center}@media(min-width:768px)and (max-width:1023px){.multi-booking-page{padding:20px}}