:root{--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-disabled: #93c5fd;--color-success: #16a34a;--color-error: #dc2626;--color-warning: #f59e0b;--color-text: #1f2937;--color-text-muted: #6b7280;--color-border: #d1d5db;--color-border-error: #dc2626;--color-background: #ffffff;--color-background-alt: #f9fafb;--color-background-error: #fef2f2;--color-background-success: #f0fdf4;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-sans);font-size:var(--font-size-base);line-height:1.5;color:var(--color-text);background-color:var(--color-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.home-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-lg);text-align:center}.home-screen h1{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-md)}.home-screen p{color:var(--color-text-muted);max-width:500px;margin-bottom:var(--spacing-md)}.home-hint{margin-top:var(--spacing-xl);font-size:var(--font-size-sm);color:var(--color-text-muted)}.home-hint code{background-color:var(--color-background-alt);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-family:monospace;color:var(--color-primary)}.demo-links{margin-top:var(--spacing-2xl);padding:var(--spacing-lg);background-color:var(--color-background-alt);border-radius:var(--radius-lg);max-width:500px}.demo-links-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-md);text-align:center}.demo-links-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.demo-link{padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-primary);text-decoration:none;font-size:var(--font-size-sm);text-align:center;transition:all .15s ease}.demo-link:hover{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.patient-form-page{flex:1;min-height:100vh;display:flex;align-items:stretch;justify-content:stretch;background-color:var(--color-background-alt);position:relative}.form-container{width:100%;display:grid;grid-template-columns:320px 1fr;background-color:var(--color-background);overflow:hidden;min-height:100vh}.form-left-panel{background-color:var(--color-primary);padding:var(--spacing-xl) var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.flp-branding{display:flex;flex-direction:column;gap:var(--spacing-xs)}.flp-logo{max-height:52px;max-width:180px;object-fit:contain;filter:brightness(0) invert(1)}.flp-company-name{font-size:var(--font-size-lg);font-weight:700;color:#fff;line-height:1.3}.flp-practice-name{font-size:var(--font-size-sm);color:#ffffffbf}.flp-divider{height:1px;background-color:#fff3;margin:var(--spacing-xs) 0}.flp-patient{display:flex;flex-direction:column;gap:2px}.flp-patient-label{font-size:var(--font-size-xs);font-weight:600;color:#ffffffa6;text-transform:uppercase;letter-spacing:.08em}.flp-patient-name{font-size:var(--font-size-lg);font-weight:600;color:#fff}.flp-form-meta{display:flex;flex-direction:column;gap:var(--spacing-sm)}.flp-form-title{font-size:var(--font-size-xl);font-weight:700;color:#fff;line-height:1.3}.flp-form-subtitle{font-size:var(--font-size-sm);color:#ffffffbf;line-height:1.5}.flp-spacer{flex:1}.flp-footer{font-size:var(--font-size-xs);color:#ffffff80}.form-right-panel{padding:var(--spacing-2xl);display:flex;flex-direction:column;overflow-y:auto;width:100%}.frp-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-lg);padding-bottom:var(--spacing-lg);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.frp-header-meta{display:flex;flex-direction:column;gap:var(--spacing-xs)}.frp-practice{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:500}.frp-form-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text);line-height:1.2}.frp-patient-badge{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.frp-patient-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}.frp-patient-name{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary)}.form-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md) var(--spacing-lg);margin-top:var(--spacing-md)}.field-col-span-1{grid-column:span 1}.field-col-span-2{grid-column:span 2}.form-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-field--inline{flex-direction:row;align-items:center}.form-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text);display:block;margin-bottom:var(--spacing-xs)}.required-mark{color:var(--color-error);margin-left:var(--spacing-xs)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.form-input:disabled{background-color:var(--color-background-alt);cursor:not-allowed}.form-input--error{border-color:var(--color-border-error)}.form-input--readonly{background-color:var(--color-background-alt);color:var(--color-text-muted);cursor:default}.form-input--error:focus{box-shadow:0 0 0 3px #dc26261a}.form-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:inherit;resize:vertical;min-height:100px;transition:border-color .15s ease,box-shadow .15s ease}.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.form-textarea:disabled{background-color:var(--color-background-alt);cursor:not-allowed}.form-textarea--error{border-color:var(--color-border-error)}.form-textarea--error:focus{box-shadow:0 0 0 3px #dc26261a}.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:inherit;background-color:var(--color-background);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.form-select:disabled{background-color:var(--color-background-alt);cursor:not-allowed}.form-select--error{border-color:var(--color-border-error)}.form-radio-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-radio-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.form-radio{width:1.125rem;height:1.125rem;cursor:pointer}.form-radio-text{font-size:var(--font-size-base)}.form-checkbox-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.form-checkbox{width:1.125rem;height:1.125rem;cursor:pointer}.form-checkbox-text{font-size:var(--font-size-base)}.form-error{font-size:var(--font-size-sm);color:var(--color-error);margin-top:var(--spacing-xs)}.form-help{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.insurance-sections-wrapper{margin-top:var(--spacing-lg)}.insurance-sections-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.insurance-section-block{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.insurance-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-background-alt);border-bottom:1px solid var(--color-border)}.insurance-section-title{font-size:var(--font-size-sm);font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.07em;margin:0}.insurance-section-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);color:var(--color-text-muted);cursor:pointer;transition:border-color .15s ease,color .15s ease,background-color .15s ease;padding:0}.insurance-section-delete:hover{border-color:var(--color-error);color:var(--color-error);background-color:var(--color-background-error)}.insurance-section-block .form-fields-grid{padding:var(--spacing-md)}.insurance-add-button{display:inline-flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border:1px dashed var(--color-primary);border-radius:var(--radius-md);background:transparent;color:var(--color-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background-color .15s ease}.insurance-add-button:hover{background-color:#eff6ff}.form-section-block{margin-top:var(--spacing-lg)}.form-section-block:first-child{margin-top:0}.form-section-header--first{padding-top:0!important;margin-top:0!important;border-top:none!important}.image-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-lg) var(--spacing-md);border:2px dashed var(--color-border);border-radius:var(--radius-md);background-color:var(--color-background-alt);cursor:pointer;transition:border-color .15s ease,background-color .15s ease}.image-upload-zone:hover{border-color:var(--color-primary);background-color:#eff6ff}.image-upload-zone--error{border-color:var(--color-border-error)}.image-upload-zone--disabled{opacity:.5;cursor:not-allowed}.image-upload-icon{color:var(--color-text-muted)}.image-upload-text{font-size:var(--font-size-base);font-weight:500;color:var(--color-text);margin:0}.image-upload-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.image-upload-hidden-input{display:none}.image-upload-previews{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.image-upload-thumb{position:relative;width:96px;display:flex;flex-direction:column;align-items:center;gap:4px}.image-upload-thumb-img{width:96px;height:96px;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--color-border)}.image-upload-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;border:none;background-color:#0000008c;color:#fff;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.image-upload-remove:hover{background-color:var(--color-error)}.image-upload-thumb-name{font-size:10px;color:var(--color-text-muted);max-width:96px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.form-actions{margin-top:var(--spacing-lg);display:flex;justify-content:flex-end}.form-submit-button{padding:var(--spacing-sm) var(--spacing-xl);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:background-color .15s ease}.form-submit-button:hover:not(:disabled){background-color:var(--color-primary-hover)}.form-submit-button:disabled{background-color:var(--color-primary-disabled);cursor:not-allowed}.form-submit-error{padding:var(--spacing-md);background-color:var(--color-background-error);border:1px solid var(--color-border-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.loading-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-lg);text-align:center}.loading-spinner{width:2.5rem;height:2.5rem;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{margin-top:var(--spacing-md);color:var(--color-text-muted)}.error-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-lg);text-align:center}.error-icon{font-size:4rem;margin-bottom:var(--spacing-md)}.error-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-sm)}.error-message{color:var(--color-text-muted);max-width:500px;margin-bottom:var(--spacing-md)}.error-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);max-width:500px}.success-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-lg);text-align:center}.success-icon{width:4rem;height:4rem;background-color:var(--color-success);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-3xl);margin-bottom:var(--spacing-md)}.success-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-sm)}.success-message{color:var(--color-text-muted);max-width:500px;margin-bottom:var(--spacing-md)}.success-detail{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.success-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);max-width:500px}.form-section-header{grid-column:span 2;padding-top:var(--spacing-lg);margin-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.form-section-header:first-child{padding-top:0;margin-top:0;border-top:none}.form-section-title{font-size:var(--font-size-sm);font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.07em}.form-card-hint{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius-md);font-size:var(--font-size-sm);color:#1e40af;margin-bottom:var(--spacing-sm)}.form-card-hint-icon{flex-shrink:0;font-size:1rem}.branding-practice{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs)}@media (max-width: 768px){.form-container{grid-template-columns:1fr;min-height:100vh}.form-left-panel{flex-direction:row;flex-wrap:wrap;align-items:center;padding:var(--spacing-md) var(--spacing-lg)}.flp-divider,.flp-patient,.flp-form-meta,.flp-spacer,.flp-footer{display:none}.flp-branding{flex-direction:row;align-items:center;gap:var(--spacing-sm)}.flp-company-name{font-size:var(--font-size-base)}.form-right-panel{padding:var(--spacing-lg)}.form-fields-grid{grid-template-columns:1fr}.field-col-span-1,.field-col-span-2{grid-column:span 1}}@media (max-width: 480px){.form-right-panel{padding:var(--spacing-md)}.error-title,.success-title{font-size:var(--font-size-xl)}}
