/* ============================================================
   Youth n Rise — contact page (builds on styles.css)
   ============================================================ */

/* shorter hero variant */
.cx-hero { height: 78svh; min-height: 54rem; }

/* ---------- contact main: form + aside ---------- */
.cx-main { background: var(--bg); padding: 12rem 0; }
.cx-main__grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 7rem; align-items: start; }

.cx-form-wrap .eyebrow { color: var(--coral); margin-bottom: 1.4rem; }
.cx-form-wrap h2 { font-size: clamp(3.4rem, 5vw, 6rem); line-height: 0.95; margin-bottom: 1.4rem; }
.cx-lead { font-size: 1.8rem; opacity: 0.65; max-width: 46rem; margin-bottom: 4rem; }

.cx-form { display: grid; gap: 2.8rem; }
.cx-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 2.8rem; }
.cx-field label { display: block; font-size: 1.4rem; font-weight: 600; margin-bottom: 0.9rem; }
.cx-field input, .cx-field textarea, .cx-field select {
  font-size: 1.8rem; padding: 0.9rem 0; border-bottom: 1.5px solid rgba(0,0,0,0.18);
  transition: border-color 0.3s; border-radius: 0; background: transparent; font-family: inherit; resize: vertical;
}
.cx-field select { cursor: pointer; }
.cx-field input::placeholder, .cx-field textarea::placeholder { color: rgba(0,0,0,0.3); }
.cx-field input:focus, .cx-field textarea:focus, .cx-field select:focus { border-color: var(--coral); outline: none; }
.cx-field .hint { display: none; font-size: 1.3rem; color: #cc3a2b; margin-top: 0.7rem; }
.cx-field.error input, .cx-field.error textarea { border-color: #cc3a2b; }
.cx-field.error .hint { display: block; }
.cx-submit { margin-top: 1rem; justify-self: start; }

.cx-success h2 { font-size: clamp(3.4rem, 5vw, 6rem); margin: 1.4rem 0; }
.cx-success .eyebrow { color: var(--coral); }

/* aside */
.cx-aside { position: sticky; top: 13rem; display: grid; gap: 3rem; }
.cx-aside__media { border-radius: 2rem; overflow: hidden; aspect-ratio: 4/3; background: var(--bg-soft); }
.cx-aside__media img { width: 100%; height: 100%; object-fit: cover; }
.cx-aside__details { display: grid; gap: 2.4rem; }
.cx-detail { display: grid; gap: 0.4rem; }
.cx-detail__label { font-size: 1.3rem; text-transform: uppercase; letter-spacing: 0.14em; opacity: 0.5; font-weight: 600; }
.cx-detail a, .cx-detail p { font-size: 1.9rem; font-weight: 500; }
.cx-detail a { transition: color 0.3s; }
.cx-detail a:hover { color: var(--coral); }
.cx-socials { display: flex; gap: 2rem; padding-top: 1rem; }
.cx-socials a { font-size: 1.5rem; font-weight: 600; position: relative; }
.cx-socials a::after { content: ""; position: absolute; left: 0; bottom: -2px; width: 100%; height: 1.5px; background: currentColor; transform: scaleX(0); transform-origin: left; transition: transform 0.35s var(--ease-expo); }
.cx-socials a:hover::after { transform: scaleX(1); }

/* ---------- departments ---------- */
.cx-depts { background: var(--bg-soft); padding: 11rem 0; }
.cx-depts__title { font-size: clamp(2.8rem, 4vw, 4.6rem); margin-bottom: 5rem; max-width: 30ch; }
.cx-depts__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.cx-dept { background: var(--paper); border-radius: 1.8rem; padding: 3.4rem; border: 1.5px solid rgba(0,0,0,0.06); transition: transform 0.4s var(--ease-expo), box-shadow 0.4s; }
.cx-dept:hover { transform: translateY(-4px); box-shadow: 0 2rem 4rem rgba(0,0,0,0.08); }
.cx-dept h3 { font-size: 2.4rem; margin-bottom: 1rem; }
.cx-dept p { font-size: 1.6rem; opacity: 0.7; margin-bottom: 2rem; }
.cx-dept a { font-size: 1.7rem; font-weight: 600; color: var(--coral); }
.cx-dept a:hover { text-decoration: underline; }

/* ---------- responsive ---------- */
@media (max-width: 1023px) {
  .cx-main { padding: 8rem 0; }
  .cx-main__grid { grid-template-columns: 1fr; gap: 5rem; }
  .cx-aside { position: static; }
  .cx-depts { padding: 7rem 0; }
  .cx-depts__grid { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .cx-row2 { grid-template-columns: 1fr; }
}
