:root {
  --primary: #722f01;
  --secondary: #652806;
  --light: #fdf8e0;
  --white: #ffffff;
  --text: #fdf8e0;
  --shadow: rgba(0, 0, 0, 0.4);
  --accent: #f1c27d;
}
.contact-hero {
  padding: 70px 0 50px;
  background:
    radial-gradient(circle at top left, #fdf8e015 0, transparent 50%),
    radial-gradient(circle at bottom right, #f1c27d20 0, transparent 55%),
    linear-gradient(135deg, #2b1300, #000000);
  text-align: center;
  color: #fdf8e0;
}

.contact-hero h1 {
  font-size: 40px;
  font-family: "Playfair Display", serif;
}

.contact-hero h1 span {
  color: var(--accent);
}

.contact-hero p {
  max-inline-size: 700px;
  margin: 12px auto 0;
  font-size: 17px;
  color: #fbeed2;
}

/* CONTACT INFO */

.contact-info {
  padding: 60px 0;
  background: #1a0b02;
}

.contact-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 25px;
}

.info-card {
  background: #2a1404;
  padding: 22px 20px;
  border-radius: 14px;
  text-align: center;
  box-shadow: 0 4px 16px var(--shadow);
  color: var(--light);
  border: 1px solid rgba(241, 194, 125, 0.18);
}

.info-card i {
  font-size: 26px;
  color: var(--accent);
  margin-block-end: 8px;
}

.info-card h3 {
  font-size: 18px;
  margin-block-end: 6px;
}

.info-card p a {
  color: var(--accent);
  font-weight: 500;
}

/* MAP SECTION */

.map-section {
  padding: 60px 0;
  background: #130702;
  text-align: center;
  color: var(--light);
}

.map-section h2 {
  font-size: 30px;
  font-family: "Playfair Display", serif;
  margin-block-end: 10px;
}

.map-section p {
  max-inline-size: 650px;
  margin: 0 auto 20px;
  color: #fbeed2;
}

.map-placeholder {
  block-size: 280px;
  border-radius: 14px;
  background: repeating-linear-gradient(
    45deg,
    #3a1b06,
    #3a1b06 10px,
    #4b2007 10px,
    #4b2007 20px
  );
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px var(--shadow);
}

.map-placeholder p {
  font-weight: 600;
  color: var(--accent);
}

/* FORM SECTION */

.contact-form-section {
  padding: 70px 0;
  background: #1a0b02;
  color: var(--light);
}

.form-container {
  max-inline-size: 820px;
  margin: 0 auto;
  background: #2a1404;
  padding: 28px 24px 32px;
  border-radius: 18px;
  box-shadow: 0 6px 22px var(--shadow);
  border: 1px solid rgba(241, 194, 125, 0.26);
}

.form-container h2 {
  font-size: 30px;
  font-family: "Playfair Display", serif;
  color: var(--accent);
}

.form-container p {
  margin: 10px 0 20px;
  color: #fbeed2;
}

.contact-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 22px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.form-group label {
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
}

.form-group input,
.form-group select,
.form-group textarea {
  border-radius: 8px;
  border: 1px solid #5f4127;
  padding: 9px 11px;
  font-size: 14px;
  outline: none;
  background: #1a0b02;
  color: var(--light);
}

.form-group textarea {
  resize: vertical;
}

/* message field */
.form-group:nth-child(7) {
  grid-column: 1 / -1;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(241, 194, 125, 0.3);
}

.contact-form .btn {
  grid-column: 1 / -1;
  justify-self: flex-start;
  padding: 12px 26px;
  border-radius: 999px;
  border: none;
  cursor: pointer;
  font-weight: 600;
}

.primary-btn {
  background: linear-gradient(135deg, var(--accent), #fdd9a2);
  color: #411a00;
}

.primary-btn:hover {
  background: linear-gradient(135deg, #fdd9a2, var(--accent));
}

.form-note {
  margin-block-start: 14px;
  font-size: 13px;
  color: #fbeed2;
}

/* RESPONSIVE */

@media (max-width: 768px) {
  .contact-form {
    grid-template-columns: 1fr;
  }

  .contact-form .btn {
    justify-self: center;
  }
}
.map-placeholder {
  background: none !important;
  padding: 0;
}
