.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#00000080;justify-content:center;align-items:center;padding:1rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{box-shadow:var(--shadow-xl);background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:600px;max-height:90vh;animation:.3s cubic-bezier(.4,0,.2,1) slideUp;display:flex;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid hsl(var(--border));background:linear-gradient(135deg,var(--strata-purple)0%,var(--strata-purple-light)100%);color:#fff;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.modal-header h2{color:#fff;margin:0;font-size:1.5rem;font-weight:600}.modal-close{cursor:pointer;color:#fff;transition:background-color var(--transition-fast);background:0 0;border:none;border-radius:.5rem;justify-content:center;align-items:center;padding:.5rem;display:flex}.modal-close:hover{background:#ffffff1a}.modal-close:focus{outline-offset:2px;outline:2px solid #fff}.modal-content{flex:1;padding:2rem;overflow-y:auto}@media (max-width:640px){.modal-overlay{align-items:flex-end;padding:0}.modal-container{border-radius:12px 12px 0 0;max-height:95vh}.modal-header{padding:1rem 1.5rem}.modal-header h2{font-size:1.25rem}.modal-content{padding:1.5rem}}
.contact-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:hsl(var(--foreground));font-size:.875rem;font-weight:500}.form-group .required{color:hsl(var(--destructive))}.form-group input,.form-group textarea{border:1px solid hsl(var(--border));font-family:var(--font-family);color:hsl(var(--foreground));transition:all var(--transition-fast);background:#fff;border-radius:.5rem;padding:.75rem 1rem;font-size:1rem;line-height:1.5}.form-group input:focus,.form-group textarea:focus{border-color:var(--strata-purple);outline:none;box-shadow:0 0 0 3px #5e208e1a}.form-group input:disabled,.form-group textarea:disabled{background:hsl(var(--muted));cursor:not-allowed;opacity:.6}.form-group textarea{resize:vertical;min-height:120px}.form-message{border-radius:.5rem;align-items:center;gap:.75rem;padding:1rem;font-size:.875rem;line-height:1.5;display:flex}.form-message.success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.form-message.success svg{color:#16a34a;flex-shrink:0}.form-message.error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.form-message.error svg{color:#dc2626;flex-shrink:0}.submit-button{color:#fff;background:linear-gradient(135deg,var(--strata-purple)0%,var(--strata-purple-light)100%);cursor:pointer;width:100%;transition:all var(--transition-fast);box-shadow:var(--shadow-purple);border:none;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;padding:.875rem 2rem;font-size:1rem;font-weight:600;display:flex}.submit-button:hover:not(:disabled){box-shadow:var(--shadow-purple-lg);transform:translateY(-1px)}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.submit-button:focus{outline:2px solid var(--strata-purple);outline-offset:2px}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.file-upload-wrapper{flex-direction:column;gap:.75rem;display:flex}.file-input{display:none}.file-label{border:2px dashed hsl(var(--border));color:hsl(var(--foreground));cursor:pointer;transition:all var(--transition-fast);background:#fff;border-radius:.5rem;justify-content:center;align-items:center;gap:.75rem;padding:1rem 1.5rem;font-size:.875rem;font-weight:500;display:inline-flex}.file-label:hover{border-color:var(--strata-purple);background:hsl(var(--muted)/.3);color:var(--strata-purple)}.file-label svg{transition:transform var(--transition-fast);flex-shrink:0}.file-label:hover svg{transform:translateY(-2px)}.file-help{color:hsl(var(--muted-foreground));margin:0;font-size:.75rem}.file-selected{border:1px solid hsl(var(--border));background:hsl(var(--muted)/.3);border-radius:.5rem;justify-content:space-between;align-items:center;gap:1rem;padding:1rem;display:flex}.file-info{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.file-info svg{color:var(--strata-purple);flex-shrink:0}.file-details{flex-direction:column;flex:1;gap:.25rem;min-width:0;display:flex}.file-name{color:hsl(var(--foreground));white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;overflow:hidden}.file-size{color:hsl(var(--muted-foreground));font-size:.75rem}.file-remove{width:32px;height:32px;color:hsl(var(--destructive));cursor:pointer;transition:all var(--transition-fast);background:#fff;border:none;border-radius:.375rem;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.file-remove:hover:not(:disabled){background:hsl(var(--destructive)/.1)}.file-remove:disabled{opacity:.5;cursor:not-allowed}.file-remove svg{width:16px;height:16px}@media (max-width:640px){.contact-form{gap:1.25rem}.form-group input,.form-group textarea{font-size:16px}.file-label{padding:.875rem 1.25rem;font-size:.8125rem}.file-selected{padding:.875rem}.file-info{gap:.5rem}.file-name{font-size:.8125rem}}
