/* =======================================================
   Encounters Dating — Profile Page
   Layout and styles specific to the profile page only.
   Anything generic should live in components.css.
   ======================================================= */


/* ---------- Page container ---------- */
.profile-page {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 40px var(--container-pad) 64px;
}


/* ---------- Profile header (photo / identity / match) ---------- */
.profile-header {
  display: grid;
  grid-template-columns: 200px 1fr 380px;
  gap: 36px;
  align-items: start;
  margin-bottom: 56px;
}

.avatar-wrap { position: relative; }
.avatar {
  width: 200px;
  height: 200px;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--bg-alt);
  position: relative;
}
.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.avatar-meta {
  margin-top: 12px;
  display: flex;
  gap: var(--space-4);
  font-size: var(--fs-sm);
  color: var(--text-mid);
}
.avatar-meta span {
  display: flex;
  align-items: center;
  gap: 6px;
}

.profile-identity .eyebrow {
  margin-bottom: 10px;
}
.profile-identity h1 {
  font-size: var(--fs-3xl);
  margin-bottom: var(--space-2);
  line-height: 1.05;
  color: var(--text);
}
.profile-location {
  font-size: var(--fs-md);
  color: var(--text-mid);
  margin-bottom: 14px;
}
.profile-tagline {
  font-family: var(--serif);
  font-style: italic;
  font-size: var(--fs-lg);
  color: var(--plum-deep);
  margin-bottom: 22px;
  letter-spacing: -0.005em;
}

.profile-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}


/* ---------- Photos section (breaks out of card pattern) ---------- */
.photos-section {
  margin: var(--space-6) 0;
}
.photos-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-5);
  padding: 0 var(--space-2);
}
.photos-header h2 {
  font-size: 26px;
  letter-spacing: -0.005em;
}
.photos-header .count {
  font-size: var(--fs-sm);
  color: var(--text-mid);
}

.photos-layout {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: var(--space-3);
}
.photo-hero {
  aspect-ratio: 3 / 4;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--bg-alt);
  cursor: pointer;
  position: relative;
}
.photo-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--t-slow);
}
.photo-hero:hover img { transform: scale(1.02); }

.photo-thumbs {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr 1fr;
  gap: var(--space-3);
}
.photo-thumb {
  aspect-ratio: 3 / 2;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--bg-alt);
  cursor: pointer;
  position: relative;
}
.photo-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--t-slow);
}
.photo-thumb:hover img { transform: scale(1.04); }

.photo-thumb.more {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--plum-faint);
  color: var(--plum-deep);
  font-family: var(--serif);
  font-style: italic;
  position: relative;
}
.photo-thumb.more::after {
  content: '+1 more';
}


/* ---------- Responsive ---------- */
@media (max-width: 1000px) {
  .profile-header {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .match-panel { max-width: 480px; }
  .photos-layout {
    grid-template-columns: 1fr;
  }
  .photo-thumbs {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr;
  }
}
