/* Extracted from templates/contact.html (redesign 2026-05-31). */
.contact-shell { max-width: 880px; margin: 0 auto; padding: 4rem 1.5rem 6rem; color: var(--text-primary); }
  .contact-hero h1 { font-family: 'Playfair Display', serif; font-size: 2.6rem; margin: 0 0 0.6rem; font-weight: 600; }
  .contact-hero h1 em { font-style: italic; color: var(--accent, #4DA3FF); }
  .contact-hero p { color: var(--text-secondary); font-size: 1.05rem; margin: 0 0 2rem; }

  .contact-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 2.4rem; }
  @media (max-width: 760px) { .contact-grid { grid-template-columns: 1fr; } }

  .contact-form { padding: 2rem; border-radius: 18px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); }
  .form-row { margin-bottom: 1.2rem; }
  .form-row label { display: block; font-size: 0.85rem; font-weight: 600; margin-bottom: 0.4rem; color: var(--text-secondary); }
  .form-row input, .form-row select, .form-row textarea {
    width: 100%; padding: 0.72rem 0.9rem; border-radius: 10px;
    background: rgba(0,0,0,0.18); border: 1px solid rgba(255,255,255,0.10);
    color: var(--text-primary); font-family: inherit; font-size: 0.95rem;
    transition: border-color 0.15s;
  }
  .form-row input:focus, .form-row select:focus, .form-row textarea:focus {
    outline: 0; border-color: color-mix(in srgb, var(--c-app-accent) 50%, transparent);
  }
  .form-row textarea { resize: vertical; min-height: 110px; }
  .form-submit {
    padding: 0.9rem 1.6rem; font-size: 1rem; font-weight: 600;
    background: var(--grad);
    color: #fff; border: 0; border-radius: 12px; cursor: pointer;
    width: 100%;
    transition: transform 0.15s, box-shadow 0.15s;
  }
  .form-submit:hover { transform: translateY(-2px); box-shadow: 0 12px 28px -6px color-mix(in srgb, var(--c-app-accent) 50%, transparent); }
  .form-submit:disabled { opacity: 0.6; cursor: not-allowed; }

  .form-status { margin-top: 1rem; padding: 0.8rem 1rem; border-radius: 10px; font-size: 0.92rem; display: none; }
  .form-status.is-success { background: rgba(52, 211, 153, 0.12); border: 1px solid rgba(52, 211, 153, 0.32); color: #34D399; display: block; }
  .form-status.is-error { background: rgba(255, 80, 80, 0.10); border: 1px solid rgba(255, 80, 80, 0.32); color: #ff6b6b; display: block; }

  .contact-side { padding: 2rem; border-radius: 18px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); }
  .contact-side h3 { margin: 0 0 1rem; font-size: 1.1rem; }
  .contact-side .contact-link {
    display: flex; align-items: center; gap: 0.8rem;
    padding: 0.9rem 1rem; margin-bottom: 0.7rem;
    background: rgba(0,0,0,0.18); border-radius: 12px;
    text-decoration: none; color: var(--text-primary);
    transition: background 0.15s;
  }
  .contact-side .contact-link:hover { background: color-mix(in srgb, var(--c-app-accent) 10%, transparent); }
  .contact-side .contact-link strong { display: block; font-size: 0.95rem; }
  .contact-side .contact-link span { font-size: 0.82rem; color: var(--text-secondary); }
