/* ============================================
   CONTACT — Sticky notes, CTA, footer
   ============================================ */

.contact {
  padding: var(--space-3xl) 0;
  position: relative;
}

/* --- Bulletin board area --- */
.contact__board {
  max-width: 800px;
  margin: 0 auto var(--space-lg);
  padding: 0 var(--space-lg);
  display: flex;
  justify-content: center;
  gap: var(--space-lg);
  flex-wrap: wrap;
}

/* --- Sticky note --- */
.sticky-note {
  width: 200px;
  padding: var(--space-lg) var(--space-md);
  border-radius: var(--radius-sm);
  position: relative;
  box-shadow: var(--shadow-md);
  transition: transform 0.3s var(--ease-spring);
}

.sticky-note:hover {
  transform: scale(1.05);
}

/* Pin dot at top */
.sticky-note::before {
  content: '';
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 16px;
  background: #F5C842;
  border-radius: var(--radius-round);
  box-shadow: 0 2px 4px rgba(0,0,0,0.15);
}

.sticky-note--1 {
  background: #FFF8E1;
  transform: rotate(-3deg);
}

.sticky-note--2 {
  background: #FFFDF5;
  transform: rotate(2deg);
}

.sticky-note--3 {
  background: #F0F0E8;
  transform: rotate(-1.5deg);
}

.sticky-note__text {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  font-weight: 500;
  color: var(--brown);
  line-height: 1.5;
  text-align: center;
}

/* --- CTA section --- */
.contact__cta {
  text-align: center;
  margin-top: var(--space-lg);
}

.contact__cta .cta-btn {
  font-size: var(--fs-small);
  padding: 14px 28px;
}

/* ============================================
   FOOTER
   ============================================ */

.footer {
  padding: var(--space-xl) 0 var(--space-lg);
  border-top: 1px solid var(--beige);
}

.footer__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-lg);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.footer__name {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4vw, 3.5rem);
  color: var(--brown);
}

.footer__socials {
  display: flex;
  gap: var(--space-sm);
}

.footer__social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: var(--grad-gold);
  border-radius: var(--radius-sm);
  color: var(--white);
  font-size: 1.1rem;
  transition: transform 0.25s var(--ease-spring), box-shadow 0.25s;
}

.footer__social-link:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

/* Footer nav */
.footer__nav {
  display: flex;
  gap: var(--space-lg);
  margin-top: var(--space-md);
}

.footer__nav-link {
  font-size: var(--fs-small);
  color: var(--brown-light);
  transition: color 0.2s;
  /* Touch-friendly: ensure 44px minimum tap target */
  padding: 12px 8px;
  margin: -12px -8px;
}

.footer__nav-link:hover {
  color: var(--accent-orange);
}

/* Footer bottom row */
.footer__bottom {
  max-width: var(--max-width);
  margin: var(--space-md) auto 0;
  padding: var(--space-sm) var(--space-lg) var(--space-md);
  border-top: 1px solid var(--beige);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.footer__copy {
  font-size: var(--fs-xs);
  color: var(--brown-light);
}
