.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)}}@media (max-width:640px){.contact-form{gap:1.25rem}.form-group input,.form-group textarea{font-size:16px}}
