/* Contact Us Page Styles - MinecraftPL
   Keep styles modular and minimal, leveraging base.css for typography, layout, and utilities. */
:root {
  --mc-primary: #3a8f3a;
  --mc-primary-2: #2f6f2f;
  --mc-accent: #7b5e2d;
  --mc-stone: #3f3f3f;
  --mc-bg: #0e0e0e;
  --mc-card: #141414;
  --mc-border: #2a2a2a;
  --mc-text: #e8f5e9;
}

.contact-main { background: linear-gradient(180deg, #0b1a0b 0%, #0f1f0f 100%); color: var(--mc-text); }
.container { max-width: 1120px; margin-inline: auto; padding-inline: 1rem; }

.contact-hero { padding: 3rem 0 2rem; background: linear-gradient(180deg, rgba(58,143,58,0.15), rgba(58,143,58,0) 60%); }
.contact-hero h1 { font-size: clamp(1.8rem, 2.8vw, 2.4rem); margin: 0 0 .5rem; text-shadow: 0 2px 0 #0a0; }
.contact-hero .lead { margin: 0 0 1rem; opacity: .95; }
.contact-quicklinks ul { display: flex; flex-wrap: wrap; gap: .5rem .75rem; list-style: none; padding: 0; margin: .75rem 0 0; }
.contact-quicklinks a { display: inline-block; padding: .4rem .7rem; border: 2px solid var(--mc-primary); color: var(--mc-text); text-decoration: none; background: rgba(20,20,20,.6); box-shadow: 0 0 0 4px rgba(0,0,0,.2); }
.contact-quicklinks a[aria-current="page"] { background: var(--mc-primary); border-color: var(--mc-primary-2); }

.contact-grid-section { padding: 1rem 0 2rem; }
.section-intro { opacity: .95; margin: .25rem 0 1rem; }
.contact-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 1rem; }
.contact-card { grid-column: span 12; background: var(--mc-card); border: 3px solid var(--mc-border); padding: 1rem; box-shadow: 0 0 0 6px rgba(0,0,0,.25); }
.contact-card h3 { margin: 0 0 .25rem; font-size: 1.05rem; }
.contact-card p { margin: 0 0 .75rem; opacity: .95; }
.contact-cta { appearance: none; border: 3px solid var(--mc-primary-2); background: var(--mc-primary); color: #fff; padding: .55rem .9rem; cursor: pointer; font-weight: 700; text-transform: none; box-shadow: 0 0 0 4px rgba(0,0,0,.25); }
.contact-cta:hover, .contact-cta:focus { background: #44a744; outline: 3px solid #9be59b; outline-offset: 2px; }

@media (min-width: 560px) { .contact-card { grid-column: span 6; } }
@media (min-width: 900px) { .contact-card { grid-column: span 4; } }

.contact-form-section { padding: 2rem 0; background: linear-gradient(180deg, rgba(20,20,20,.35), rgba(20,20,20,0)); }
#form-title { margin-bottom: .25rem; }
.form-grid { display: grid; grid-template-columns: 1fr; gap: .9rem; margin-top: 1rem; }
.form-field { display: grid; gap: .35rem; }
.form-field-full { grid-column: 1 / -1; }
.form-field label { font-weight: 700; }
.form-field input[type="text"],
.form-field input[type="email"],
.form-field select,
.form-field textarea { width: 100%; background: #0d0d0d; color: var(--mc-text); border: 3px solid var(--mc-border); padding: .6rem .7rem; box-shadow: inset 0 0 0 2px rgba(0,0,0,.35); }
.form-field textarea { resize: vertical; }
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus { outline: 3px solid #9be59b; outline-offset: 2px; border-color: var(--mc-primary); }
.form-consent .checkbox { display: grid; grid-template-columns: auto 1fr; align-items: start; gap: .6rem; }
.form-honeypot { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

.form-actions { display: flex; align-items: center; gap: 1rem; margin-top: 1rem; }
.btn { border: 3px solid var(--mc-primary-2); background: var(--mc-primary); color: #fff; padding: .6rem 1rem; font-weight: 800; cursor: pointer; }
.btn:hover, .btn:focus { background: #44a744; outline: 3px solid #9be59b; outline-offset: 2px; }
.btn[disabled] { opacity: .6; cursor: not-allowed; }
.form-note { opacity: .9; }
.form-status { margin-top: 1rem; min-height: 1.5rem; font-weight: 700; }
.form-status.success { color: #9be59b; }
.form-status.error { color: #ffb3b3; }

.contact-extra { padding: 2rem 0 3rem; }
.extra-grid { display: grid; gap: 1rem; grid-template-columns: 1fr; }
.extra-item { background: var(--mc-card); border: 3px solid var(--mc-border); padding: 1rem; box-shadow: 0 0 0 6px rgba(0,0,0,.25); }
.contact-list, .links-list { margin: .25rem 0 0; padding-left: 1.1rem; }
.back-to-top { margin-top: 1rem; text-align: right; }

@media (min-width: 760px) {
  .form-grid { grid-template-columns: repeat(2, 1fr); }
  .form-field-full { grid-column: span 2; }
  .extra-grid { grid-template-columns: repeat(3, 1fr); }
}

.contact-hero-figure {
  margin: 1.5rem 0 1rem;
  max-width: 100%;
}

.contact-hero-figure img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 8px;
  border: 3px solid var(--mc-border);
  box-shadow: 0 0 0 6px rgba(0,0,0,.25), 0 8px 24px rgba(0,0,0,0.3);
}
