/* ============================================================
   CONTACT
   ============================================================ */
#contact {
  background: var(--light-2);
  border-top: 1px solid var(--border);
  position: relative; overflow: hidden;
}
.contact-orb {
  position: absolute;
  width: 500px; height: 500px; border-radius: 50%;
  background: radial-gradient(circle, rgba(244,114,182,.12) 0%, transparent 70%);
  filter: blur(80px);
  bottom: -150px; right: -100px;
  pointer-events: none;
}

/* Pink pixel dot grid */
#contact::before {
  content: '';
  position: absolute; inset: 0; z-index: 0;
  background-image: radial-gradient(circle, rgba(244,114,182,.18) 1.5px, transparent 1.5px);
  background-size: 24px 24px;
}

.contact-grid {
  display: grid; grid-template-columns: 1fr 1.35fr;
  gap: 5rem; align-items: start;
  position: relative; z-index: 1;
}
.contact-info h3 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 1.4rem; font-weight: 800;
  color: var(--text); margin-bottom: .875rem;
  letter-spacing: -0.02em;
}
.contact-info > p {
  color: var(--text-muted); line-height: 1.8;
  margin-bottom: 2rem; font-size: .94rem;
}
.contact-links { display: flex; flex-direction: column; gap: .6rem; }
.contact-card {
  display: flex; align-items: center; gap: .875rem;
  padding: .875rem 1rem;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 6px;
  box-shadow: 3px 3px 0 0 rgba(0,0,0,.06);
  transition: all .15s ease;
}
.contact-card:hover {
  background: var(--violet-soft);
  border-color: rgba(244,114,182,.4);
  box-shadow: 4px 4px 0 0 rgba(244,114,182,.2);
  transform: translate(-2px, -2px);
}
.contact-card-icon {
  width: 36px; height: 36px; border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.contact-card-icon svg { width: 16px; height: 16px; }
.email-icon    { background: rgba(217,119,6,.1);  color: #d97706; }
.github-icon   { background: rgba(0,0,0,.06);     color: var(--text); }
.reboot-icon   { background: rgba(194,65,12,.1);  color: #c2410c; }
.linkedin-icon { background: rgba(10,102,194,.1); color: #1d4ed8; }
.contact-card strong { display: block; font-size: .78rem; font-weight: 700; color: var(--text); }
.contact-card span { font-size: .73rem; color: var(--text-muted); }

/* Pixel-style form */
.contact-form {
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 8px; padding: 2rem;
  box-shadow: 5px 5px 0 0 rgba(244,114,182,.18);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: .875rem; }
.form-group { display: flex; flex-direction: column; gap: .35rem; margin-bottom: 1.1rem; }
.form-group label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .65rem; font-weight: 700;
  color: var(--text-muted); letter-spacing: .16em;
  text-transform: uppercase; line-height: 1.6;
}
.form-group input, .form-group textarea {
  padding: .75rem 1rem;
  background: var(--light);
  border: 1.5px solid var(--border);
  border-radius: 4px;
  font-size: .875rem; font-family: 'Plus Jakarta Sans', sans-serif;
  color: var(--text); outline: none; resize: vertical;
  transition: border-color .2s, background .2s, box-shadow .2s, transform .15s;
}
.form-group input:hover, .form-group textarea:hover {
  border-color: rgba(244,114,182,.4);
  background: var(--violet-soft);
}
.form-group input:focus, .form-group textarea:focus {
  border-color: rgba(244,114,182,.7);
  background: var(--violet-soft);
  box-shadow: 3px 3px 0 0 rgba(244,114,182,.2);
  transform: translate(-1px,-1px);
}
.form-group:focus-within label { color: var(--violet); }
.form-group input::placeholder, .form-group textarea::placeholder {
  color: var(--text-dim);
}
.form-note {
  text-align: center; font-size: .78rem; margin-top: .625rem;
  color: var(--text-dim); min-height: 1.2rem;
}
.form-note.success { color: #059669; }
.form-note.error   { color: #dc2626; }
