@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@500;700&family=Lora:ital,wght@0,400;0,600;1,400&display=swap');

:root {
  --bg:       #f5f0e8;
  --hdr-from: #2c1a0e;
  --hdr-to:   #5c3320;
  --accent:   #b8760a;
  --accent-lt:#d4952a;
  --text:     #1e130a;
  --muted:    #7a5c40;
  --card-bg:  #fdf8f0;
  --border:   #d4c4a8;
  --radius:   8px;
  --danger:   #c0392b;
  --success:  #2e7d32;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Lora', Georgia, serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ── Header ── */
header {
  background: linear-gradient(135deg, var(--hdr-from), var(--hdr-to));
  color: #f5ead8;
  padding: 0.9rem 1.5rem;
}

.header-inner { max-width: 900px; margin: 0 auto; }

.logo-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.logo-icon { font-size: 2rem; }

.logo-text h1 {
  font-family: 'Caveat', cursive;
  font-size: 1.7rem;
  color: #f0d090;
  line-height: 1.1;
}

.dl {
  color: #ffc84a;
  text-shadow: 0 1px 8px rgba(255,180,30,0.55);
}

.tagline {
  font-size: 0.8rem;
  color: rgba(240,220,170,0.75);
  font-style: italic;
  margin-top: 0.1rem;
}

/* ── Main ── */
main { flex: 1; display: flex; align-items: flex-start; justify-content: center; padding: 2.5rem 1rem; }

.contact-wrap { width: 100%; max-width: 580px; }

.contact-box {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 2rem 2rem 2.5rem;
  box-shadow: 0 6px 28px rgba(30,10,0,0.1);
}

.back-link {
  display: inline-block;
  color: var(--muted);
  font-size: 0.82rem;
  text-decoration: none;
  margin-bottom: 1.2rem;
}
.back-link:hover { color: var(--accent); }

.contact-box h2 {
  font-family: 'Caveat', cursive;
  font-size: 2rem;
  color: var(--hdr-from);
  margin-bottom: 0.3rem;
}

.contact-intro {
  font-size: 0.9rem;
  color: var(--muted);
  font-style: italic;
  margin-bottom: 1.5rem;
}

/* ── Form ── */
.field-group {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  margin-bottom: 1.1rem;
}

.field-group label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.req { color: var(--accent); }

.field-group input,
.field-group textarea {
  padding: 0.55rem 0.75rem;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  font-family: 'Lora', serif;
  font-size: 0.92rem;
  background: #fff;
  color: var(--text);
  resize: vertical;
  transition: border-color 0.15s;
}

.field-group input:focus,
.field-group textarea:focus {
  outline: none;
  border-color: var(--accent);
}

.form-error {
  color: var(--danger);
  font-size: 0.82rem;
  min-height: 1.2em;
  margin-bottom: 0.6rem;
  font-style: italic;
}

.submit-btn {
  width: 100%;
  padding: 0.7rem 1.2rem;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 7px;
  font-family: 'Lora', serif;
  font-size: 1rem;
  cursor: pointer;
  transition: filter 0.15s;
}
.submit-btn:hover  { filter: brightness(1.1); }
.submit-btn:disabled { opacity: 0.6; cursor: not-allowed; filter: none; }

/* ── Success state ── */
.success-state {
  text-align: center;
  padding: 2rem 1rem;
}

.success-icon {
  width: 64px;
  height: 64px;
  background: var(--success);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1rem;
}

.success-state h3 {
  font-family: 'Caveat', cursive;
  font-size: 1.8rem;
  color: var(--hdr-from);
  margin-bottom: 0.4rem;
}

.success-state p {
  color: var(--muted);
  font-style: italic;
  margin-bottom: 1.4rem;
}

.back-btn {
  display: inline-block;
  padding: 0.55rem 1.3rem;
  background: var(--accent);
  color: #fff;
  border-radius: 6px;
  text-decoration: none;
  font-size: 0.9rem;
  transition: filter 0.15s;
}
.back-btn:hover { filter: brightness(1.1); }

/* ── Footer ── */
footer {
  background: var(--hdr-from);
  color: rgba(240,220,170,0.65);
  text-align: center;
  padding: 0.9rem 1rem;
  font-size: 0.78rem;
  font-style: italic;
}

.hidden { display: none !important; }
