/* Contact page layout */
.p-wrap{
  width: 100%;
  margin: 0 auto;
  padding: 0 20px;
}

/* Page rhythm */
#contact.p-wrap{ padding-top: calc(var(--header-h) + 24px); padding-bottom: 80px; }
section{ margin-block: 56px; }
@media (max-width: 768px){ section{ margin-block: 44px; } }

/* Hero */
.contact-hero{
  position: relative; background:#0a0a0a; min-height: 36vh;
  display:flex; align-items:center; justify-content:center; text-align:center;
  border-radius: 18px; overflow:hidden;
}
.contact-hero .hero-inner{ max-width: 780px; padding: 48px 20px; display:grid; gap:16px; }
.contact-hero h1{ font-family: Cinzel, serif; margin: 0 0 8px; font-size: clamp(34px,5vw,52px); letter-spacing:.05em; text-transform:uppercase; }
.contact-hero .sub{ color:#bdbdbd; margin: 0 0 16px; font-size:1.05rem; }
.hero-ctas{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* Cards */
.contact-cards{ display:grid; grid-template-columns: repeat(3, 1fr); gap:20px; }
@media (max-width: 900px){ .contact-cards{ grid-template-columns:1fr; } }
.ccard{ background:#0e0e0e; border:1px solid #1f1f1f; border-radius:12px; padding:18px; display:flex; flex-direction:column; gap:10px; }
.ccard h3{ font-family: Cinzel, serif; margin:.2rem 0 .5rem; letter-spacing:.04em; text-transform:uppercase; }
.ccard .tiny.link{ display:inline-block; margin-top:6px; color:#d7c07a; text-decoration:none; }
.ccard .tiny.link:hover{ text-decoration:underline; }

/* Form */
.contact-form h2, .contact-faq h2, .contact-cta h2{ font-family: Cinzel, serif; letter-spacing:.05em; text-transform:uppercase; }
.contact-form form{ background:#0b0b0b; border:1px solid #1f1f1f; border-radius:14px; padding:28px; box-shadow:0 18px 40px rgba(0,0,0,0.35); }
@media (max-width: 600px){ .contact-form form{ padding:22px; } }
.contact-form .row{ display:grid; gap:14px; }
.contact-form .row.halves{ grid-template-columns:1fr 1fr; }
@media (max-width: 720px){ .contact-form .row.halves{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
label{ color:#d7c07a; font-size:.95rem; letter-spacing:.06em; text-transform:uppercase; }
input, select, textarea{
  background:#111; border:1px solid #2a2a2a; border-radius:10px; color:#f3f3f3; padding:.8rem .9rem;
  font-family:inherit; font-size:1rem;
}
textarea{ resize:vertical; min-height:160px; }
input:focus, select:focus, textarea:focus{
  outline:none; border-color:#d7c07a; box-shadow:0 0 0 2px rgba(215,192,122,.15);
}
input.bad, select.bad, textarea.bad{ border-color:#ff7a7a; box-shadow:0 0 0 2px rgba(255,122,122,.15); }
.conditional[hidden]{ display:none !important; }
.err{ color:#ffb3b3; font-size:.9rem; min-height:1em; margin:0; }
.muted{ color:#a7a7a7; }
.tiny{ font-size:.9rem; }
.contact-form .tiny{ letter-spacing:.04em; }
.contact-form .btn-gold{ min-height:48px; padding-inline:28px; }
#form-state{ margin-top:16px; color:#d7c07a; font-size:.95rem; min-height:1.25em; }

/* FAQ */
.contact-faq details{ background:#0e0e0e; border:1px solid #1f1f1f; border-radius:10px; padding:12px 14px; margin-bottom:10px; }
.contact-faq summary{ color:#d7c07a; cursor:pointer; font-weight:600; letter-spacing:.05em; text-transform:uppercase; }
.contact-faq p{ margin:10px 0 0; color:#d0d0d0; line-height:1.6; }

/* CTA */
.contact-cta{ text-align:center; background:#0d0d0d; border:1px solid #1f1f1f; border-radius:14px; padding:40px 20px; box-shadow:0 18px 40px rgba(0,0,0,0.32); }
.contact-cta .row{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:18px; }
.contact-cta .btn{ min-width:180px; }

/* Utilities */
.btn-outline.btn-quiet{ border-color:rgba(215,192,122,.4); color:#d7c07a; }
.contact-cards .btn-outline{ min-height:44px; }
.contact-hero::after{
  content:""; position:absolute; inset:0; background:radial-gradient(circle at 50% 20%, rgba(215,192,122,0.08), transparent 60%);
  pointer-events:none; mix-blend-mode:screen;
}
