*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}#root{width:100%;max-width:800px}.container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px}h1{color:#333;margin-bottom:10px;font-size:2rem}.subtitle{color:#666;margin-bottom:30px;font-size:1rem}.step-indicator{display:flex;justify-content:space-between;margin-bottom:40px;position:relative}.step-indicator:before{content:"";position:absolute;top:15px;left:0;right:0;height:2px;background:#e0e0e0;z-index:0}.step{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;z-index:1;flex:1}.step-number{width:32px;height:32px;border-radius:50%;background:#e0e0e0;color:#999;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.step.active .step-number{background:#667eea;color:#fff}.step.completed .step-number{background:#4caf50;color:#fff}.step-label{font-size:12px;color:#999;text-align:center}.step.active .step-label{color:#667eea;font-weight:600}.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px;margin-top:20px;max-height:400px;overflow-y:auto;padding:10px;border:1px solid #e0e0e0;border-radius:8px}.emoji-button{aspect-ratio:1;border:2px solid transparent;border-radius:8px;background:#f5f5f5;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:3rem}.emoji-button:hover{background:#e8e8e8;transform:scale(1.05)}.emoji-button.selected{border-color:#667eea;background:#f0f4ff}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500}.form-group textarea,.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:16px;font-family:inherit;transition:border-color .2s}.form-group textarea:focus,.form-group input:focus{outline:none;border-color:#667eea}.form-group textarea{resize:vertical;min-height:120px}.char-count{text-align:right;font-size:12px;color:#999;margin-top:4px}.char-count.warning{color:#ff9800}.char-count.error{color:#f44336}.address-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px}.address-validation{margin-top:12px;padding:12px;border-radius:8px;font-size:14px}.address-validation.success{background:#e8f5e9;color:#2e7d32}.address-validation.error{background:#ffebee;color:#c62828}.address-validation.validating{background:#fff3e0;color:#e65100}.button-group{display:flex;gap:12px;margin-top:30px}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;flex:1}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:#e0e0e0;color:#333}.btn-secondary:hover:not(:disabled){background:#d0d0d0}.summary-card{background:#f5f5f5;padding:24px;border-radius:8px;margin-bottom:24px}.summary-item{margin-bottom:16px}.summary-item:last-child{margin-bottom:0}.summary-label{font-weight:600;color:#666;font-size:14px;margin-bottom:4px}.summary-value{color:#333;font-size:16px}.summary-emoji{font-size:4rem;text-align:center;margin:20px 0}.price-display{text-align:center;margin:24px 0}.price-amount{font-size:3rem;font-weight:700;color:#667eea}.price-label{color:#666;margin-top:8px}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-left:8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success-message{text-align:center;padding:40px}.success-icon{font-size:4rem;margin-bottom:20px}.success-message h2{color:#4caf50;margin-bottom:12px}.success-message p{color:#666;line-height:1.6}.error-message{background:#ffebee;border-left:4px solid #f44336;padding:16px;margin:16px 0;border-radius:4px}.error-message strong{color:#c62828;display:block;margin-bottom:4px}@media(max-width:640px){.container{padding:24px}.emoji-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}.emoji-button{font-size:2rem}.address-grid{grid-template-columns:1fr}.step-label{font-size:10px}}
