/*!
 * Template Name: Hostina Template
 * Author: hostk.com
 * Version: 1.0
 * Description: Modern Responsive Bootstrap Hosting Template
 * Created: 2025
 */
 
 /* Contact Information Styles */
.contact-info {
  padding: 2rem 0;
}

.contact-info .contact-item {
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.contact-info .contact-icon {
  flex-shrink: 0;
  width: 5rem;
  height: 5rem;
  background: #00000012;
  border-radius: var(--radius-16);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
}

.contact-info .contact-details {
  flex: 1;
  width: 100%;
}

.contact-info .contact-label {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 0.5rem;
}

.contact-info .contact-text {
  font-size: 1.7rem;
  margin-bottom: 0;
  line-height: 1.5;
  font-weight: 600;
}

/* Contact Form Styles */
.contact-form-container {
  background: white;
  padding: 4rem 3rem;
  border-radius: var(--radius-24);
  box-shadow: var(--shadow-special);
  border: 1px solid #f1f3f4;
}

.contact-form-container .form-heading {
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 3rem;
  text-align: left;
}

.contact-form-container .contact-form {
  width: 100%;
}

.contact-form-container .form-input,
.contact-form-container .form-textarea {
  padding: 1.5rem 2rem !important;
  border-radius: var(--radius-16);
  font-size: 1.5rem;
  font-weight: 500;
  transition: var(--transition-base);
}

.contact-form-container .form-input::placeholder,
.contact-form-container .form-textarea::placeholder {
  color: var(--color-text);
  font-weight: 400;
}

.contact-form-container .form-textarea {
  resize: vertical;
  min-height: 120px;
  font-family: inherit;
  background-color: var(--color-light-gray);
}

/* Map Section */
.map-container {
  width: 100%;
  height: 450px;
  overflow: hidden;
}

.map-container iframe {
  width: 100%;
  height: 100%;
  border: none;
  filter: grayscale(20%);
  transition: var(--transition-base);
}

.map-container:hover iframe {
  filter: grayscale(0%);
}

/* Loading States */
.contact-form.loading {
  opacity: 0.7;
  pointer-events: none;
}

.contact-form.loading .submit-btn {
  position: relative;
  color: transparent;
}

.contact-form.loading .submit-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2rem;
  height: 2rem;
  margin: -1rem 0 0 -1rem;
  border: 2px solid transparent;
  border-top-color: white;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

/* Success/Error States */
.form-message {
  padding: 1.5rem 2rem;
  border-radius: var(--radius-16);
  margin-bottom: 2rem;
  font-size: 1.5rem;
  font-weight: 500;
}

.form-message.success {
  background: #d4edda;
  color: #155724;
  border: 1px solid #c3e6cb;
}

.form-message.error {
  background: #f8d7da;
  color: #721c24;
  border: 1px solid #f5c6cb;
}

/* Animation Enhancements */
.contact-item {
  transition: var(--transition-base);
}

.contact-item:hover {
  transform: translateX(10px);
}

.contact-item:hover .contact-icon {
  transform: scale(1.1);
  box-shadow: var(--shadow-md);
}

/* Responsive Design */
@media (max-width: 767px) {
  .contact-form-container {
    padding: 3rem 2rem;
  }

  .contact-form-container .form-heading {
    font-size: 2rem;
    margin-bottom: 2rem;
  }

  .contact-form-container .form-input,
  .contact-form-container .form-textarea {
    padding: 1.2rem 1.5rem;
    font-size: 1.4rem;
  }

  .contact-form-container .submit-btn {
    padding: 1.5rem 3rem;
    font-size: 1.4rem;
    width: 100%;
  }

  .contact-info {
    text-align: center;
  }

  .contact-info .contact-item {
    flex-direction: column;
    text-align: center;
  }

  .contact-info .contact-icon {
    align-self: center;
    margin-bottom: 1rem;
  }

  .map-container {
    height: 300px;
  }
}
