*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding-bottom:2rem}.app-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;box-shadow:0 4px 6px #0000001a;padding:1.5rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{justify-content:space-between;margin:0 auto;max-width:1200px}.app-header h1,.header-content{align-items:center;display:flex}.app-header h1{color:#1a202c;font-size:1.75rem;gap:.75rem}.app-header h1 svg{color:#667eea}.add-contact-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 6px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:transform .2s,box-shadow .2s}.add-contact-btn:hover{box-shadow:0 6px 12px #667eea66;transform:translateY(-2px)}.add-contact-btn:active{transform:translateY(0)}.app-main{margin:2rem auto;max-width:1200px;padding:0 2rem}.search-section{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem;padding:1.5rem}.search-bar{align-items:center;display:flex;margin-bottom:1rem;position:relative}.search-icon{color:#718096;left:1rem;pointer-events:none;position:absolute}.search-input{border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:.875rem 1rem .875rem 3rem;transition:border-color .2s,box-shadow .2s;width:100%}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.clear-search{align-items:center;background:#e2e8f0;border:none;border-radius:50%;color:#4a5568;cursor:pointer;display:flex;font-size:1.25rem;height:24px;justify-content:center;position:absolute;right:1rem;transition:background .2s;width:24px}.clear-search:hover{background:#cbd5e0}.results-count{color:#718096;font-size:.875rem}.contact-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.contact-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;gap:1rem;padding:1.5rem;position:relative;transition:transform .2s,box-shadow .2s}.contact-card:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-4px)}.contact-avatar{border-radius:50%;flex-shrink:0;height:60px;object-fit:cover;width:60px}.contact-info{flex:1 1;min-width:0}.contact-name{color:#1a202c;font-size:1.125rem;font-weight:600;margin-bottom:.75rem}.contact-details{display:flex;flex-direction:column;gap:.5rem}.contact-detail{align-items:center;color:#4a5568;display:flex;font-size:.875rem;gap:.5rem}.contact-detail svg{color:#667eea;flex-shrink:0}.contact-detail span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-actions{display:flex;flex-direction:column;gap:.5rem}.action-btn{align-items:center;background:#0000;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.edit-btn:hover{background:#667eea;border-color:#667eea;color:#fff}.edit-btn:hover svg{stroke:#fff}.delete-btn:hover{background:#f56565;border-color:#f56565;color:#fff}.delete-btn:hover svg{stroke:#fff}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-height:90vh;max-width:500px;overflow-y:auto;padding:2rem;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.modal-header h2{color:#1a202c;font-size:1.5rem}.close-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#718096;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;line-height:1;padding:0;transition:background .2s;width:32px}.close-btn:hover{background:#e2e8f0}.form-group{margin-bottom:1.25rem}.form-group label{color:#2d3748;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.form-group input{border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:.75rem;transition:border-color .2s,box-shadow .2s;width:100%}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input.error{border-color:#f56565}.error-message{color:#f56565;display:block;font-size:.875rem;margin-top:.25rem}.modal-actions{display:flex;gap:1rem;margin-top:2rem}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 6px #667eea4d;color:#fff}.btn-primary:hover{box-shadow:0 6px 12px #667eea66;transform:translateY(-2px)}.btn-secondary{background:#e2e8f0;color:#2d3748}.btn-secondary:hover{background:#cbd5e0}.loading-container{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem}.spinner{animation:spin .8s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:1rem;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.loading-container p{font-size:1.125rem;font-weight:500}.error-container{align-items:center;background:#fff;border-radius:12px;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.error-container svg{color:#f56565;margin-bottom:1rem}.error-container h3{color:#1a202c;font-size:1.5rem;margin-bottom:.5rem}.error-container p{color:#718096;font-size:1rem}.empty-state{align-items:center;background:#fff;border-radius:12px;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.empty-state svg{color:#cbd5e0;margin-bottom:1rem}.empty-state h3{color:#1a202c;font-size:1.5rem;margin-bottom:.5rem}.empty-state p{color:#718096;font-size:1rem}@media (max-width:768px){.app-header{padding:1rem}.header-content{align-items:stretch;flex-direction:column;gap:1rem}.app-header h1{font-size:1.5rem}.add-contact-btn,.app-header h1{justify-content:center}.app-main{padding:0 1rem}.contact-list{grid-template-columns:1fr}.contact-card{align-items:center;flex-direction:column;text-align:center}.contact-actions{flex-direction:row;justify-content:center;width:100%}.modal-content{padding:1.5rem}.modal-actions{flex-direction:column}}
/*# sourceMappingURL=main.98c7b73a.css.map*/