/*
 * ln-myconnectcard/assets/css/public.css
 * MyConnectCard™ Visionary Profile + Directory Styles
 * Uses Latina Network design system CSS variables.
 */

:root {
  --mcc-tierra:    #C4622D;
  --mcc-oro:       #D4A853;
  --mcc-plum:      #5C2D4E;
  --mcc-plum-dark: #3D1D34;
  --mcc-crema:     #F5EDD8;
  --mcc-teal:      #1CA9A0;
  --mcc-serif:     'Cormorant Garamond', Georgia, serif;
  --mcc-sans:      'Outfit', sans-serif;
}


/* ── HERO ─────────────────────────────────────────────────────────────────── */

.mcc-profile-wrap { background: var(--mcc-crema); }

.mcc-hero {
  position: relative;
  min-height: 420px;
  background-color: var(--mcc-plum-dark);
  background-size: cover;
  background-position: center top;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.mcc-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(61,29,52,0.92) 0%,
    rgba(61,29,52,0.72) 50%,
    rgba(61,29,52,0.55) 100%
  );
  z-index: 1;
}

.mcc-hero-inner {
  position: relative;
  z-index: 2;
  max-width: 1160px;
  margin: 0 auto;
  padding: 64px 56px;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 48px;
  align-items: flex-end;
}

/* Badges */
.mcc-badges { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; align-items: center; }

.mcc-tier-badge {
  font-family: var(--mcc-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 4px 12px;
  background: var(--mcc-tierra);
  color: var(--mcc-crema);
  border-radius: 2px;
}

.mcc-tier-badge--sm { font-size: 9px; padding: 2px 8px; }

.mcc-status-badge {
  font-family: var(--mcc-sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 2px;
}

.mcc-status--elevated { background: var(--mcc-oro); color: #3a2800; }

.mcc-founding-badge {
  font-family: var(--mcc-sans);
  font-size: 11px;
  font-weight: 600;
  color: var(--mcc-oro);
  letter-spacing: 0.05em;
}

.mcc-founding-badge--sm { font-size: 9px; }

/* Name */
.mcc-name {
  font-family: var(--mcc-serif);
  font-size: clamp(36px, 5vw, 64px);
  font-weight: 300;
  color: var(--mcc-crema);
  line-height: 1.05;
  margin: 0 0 12px;
}

.mcc-role-line {
  font-family: var(--mcc-sans);
  font-size: 17px;
  font-weight: 300;
  color: rgba(245, 237, 216, 0.7);
  margin: 0 0 20px;
}

/* City / role chips in hero */
.mcc-chips { display: flex; gap: 8px; flex-wrap: wrap; }

.mcc-chip {
  font-family: var(--mcc-sans);
  font-size: 11px;
  font-weight: 500;
  padding: 3px 10px;
  border-radius: 2px;
  white-space: nowrap;
}

.mcc-chip--city     { background: rgba(245,237,216,0.1); color: rgba(245,237,216,0.7); border: 1px solid rgba(245,237,216,0.2); }
.mcc-chip--role     { background: rgba(28,169,160,0.2); color: var(--mcc-teal); }
.mcc-chip--specialty{ background: rgba(245,237,216,0.08); color: rgba(245,237,216,0.5); border: 1px solid rgba(245,237,216,0.12); }
.mcc-chip--sm       { font-size: 10px; padding: 2px 8px; }

/* Non-hero chip variants (in sidebar / body) */
.mcc-body-wrap .mcc-chip--city     { background: rgba(92,45,78,0.07); color: var(--mcc-plum); border: 1px solid rgba(92,45,78,0.12); }
.mcc-body-wrap .mcc-chip--role     { background: rgba(28,169,160,0.1); color: #157f79; }
.mcc-body-wrap .mcc-chip--specialty{ background: rgba(92,45,78,0.06); color: rgba(92,45,78,0.6); border: 1px solid rgba(92,45,78,0.1); }

/* Headshot */
.mcc-hero-headshot { flex-shrink: 0; }

.mcc-headshot-img {
  width: 180px;
  height: 180px;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid rgba(245,237,216,0.15);
  display: block;
}

.mcc-headshot-placeholder {
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--mcc-plum), var(--mcc-tierra));
  display: flex;
  align-items: center;
  justify-content: center;
}

.mcc-headshot-placeholder span {
  font-family: var(--mcc-serif);
  font-size: 72px;
  font-weight: 300;
  color: var(--mcc-crema);
}


/* ── ACTION BAR ───────────────────────────────────────────────────────────── */

.mcc-action-bar {
  background: #fff;
  border-bottom: 1px solid rgba(92,45,78,0.08);
  position: sticky;
  top: 0;
  z-index: 40;
  box-shadow: 0 2px 12px rgba(61,29,52,0.06);
}

.mcc-action-bar-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 14px 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.mcc-ctas { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }

.mcc-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--mcc-sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 10px 20px;
  transition: all 0.2s;
  white-space: nowrap;
  cursor: pointer;
  border: none;
}

.mcc-btn--primary  { background: var(--mcc-tierra); color: var(--mcc-crema); }
.mcc-btn--primary:hover { background: #b5561f; color: var(--mcc-crema); }
.mcc-btn--secondary{ background: transparent; color: var(--mcc-plum); border: 1px solid rgba(92,45,78,0.2); }
.mcc-btn--secondary:hover { border-color: var(--mcc-plum); }
.mcc-btn--ghost    { background: transparent; color: rgba(92,45,78,0.6); border: 1px solid rgba(92,45,78,0.12); }
.mcc-btn--ghost:hover { color: var(--mcc-plum); border-color: rgba(92,45,78,0.3); }
.mcc-btn--ghost svg { stroke: currentColor; }

/* Social icons */
.mcc-social-row { display: flex; gap: 12px; align-items: center; }

.mcc-social-icon {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(92,45,78,0.4);
  transition: color 0.2s, transform 0.2s;
}

.mcc-social-icon:hover { color: var(--mcc-tierra); transform: translateY(-1px); }
.mcc-social-icon svg { width: 18px; height: 18px; }


/* ── BODY LAYOUT ──────────────────────────────────────────────────────────── */

.mcc-body-wrap { max-width: 1160px; margin: 0 auto; padding: 56px 56px 80px; }

.mcc-body-inner {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 56px;
  align-items: flex-start;
}

/* Sections */
.mcc-section { margin-bottom: 56px; }

.mcc-section-heading {
  font-family: var(--mcc-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--mcc-tierra);
  margin: 0 0 24px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(92,45,78,0.1);
}

/* Bio */
.mcc-short-bio {
  font-family: var(--mcc-serif);
  font-size: clamp(20px, 2.5vw, 26px);
  font-weight: 300;
  line-height: 1.5;
  color: var(--mcc-plum);
  margin: 0 0 24px;
}

.mcc-long-bio-content { font-family: var(--mcc-sans); font-size: 17px; font-weight: 300; line-height: 1.85; color: rgba(26,13,24,.78); }
.mcc-long-bio-content p { margin-bottom: 18px; }

.mcc-long-bio-wrap { overflow: hidden; }
.mcc-long-bio-wrap.collapsed .mcc-long-bio-content { max-height: 0; overflow: hidden; }

.mcc-bio-toggle {
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--mcc-sans);
  font-size: 13px;
  font-weight: 600;
  color: var(--mcc-tierra);
  padding: 12px 0;
  display: flex;
  align-items: center;
  gap: 6px;
  letter-spacing: 0.05em;
}

.mcc-bio-toggle-arrow { transition: transform 0.3s; display: inline-block; }
.mcc-bio-toggle[aria-expanded="true"] .mcc-bio-toggle-arrow { transform: rotate(180deg); }


/* Recognition badges */
.mcc-recognition-badges { display: flex; flex-direction: column; gap: 12px; }

.mcc-rec-badge {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 14px 16px;
  background: rgba(212, 168, 83, 0.06);
  border: 1px solid rgba(212, 168, 83, 0.2);
}

.mcc-rec-icon { font-size: 22px; flex-shrink: 0; }
.mcc-rec-info { display: flex; flex-direction: column; gap: 2px; }
.mcc-rec-name { font-family: var(--mcc-sans); font-size: 14px; font-weight: 600; color: var(--mcc-plum); }
.mcc-rec-program { font-size: 13px; color: rgba(92,45,78,0.55); }
.mcc-rec-year { font-size: 12px; font-weight: 600; color: var(--mcc-oro); }


/* Articles */
.mcc-content-list { display: flex; flex-direction: column; gap: 24px; }

.mcc-content-item {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 16px;
  align-items: flex-start;
}

.mcc-content-thumb-link { display: block; aspect-ratio: 1; overflow: hidden; }
.mcc-content-thumb { width: 80px; height: 80px; object-fit: cover; }

.mcc-content-info { display: flex; flex-direction: column; gap: 4px; }

.mcc-content-cat {
  font-family: var(--mcc-sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 2px 8px;
  display: inline-block;
  width: fit-content;
}

.mcc-cat--business { background: rgba(196,98,45,.1); color: var(--mcc-tierra); }
.mcc-cat--money    { background: rgba(212,168,83,.12); color: #7a5e1a; }
.mcc-cat--wellness { background: rgba(28,169,160,.1); color: #157f79; }
.mcc-cat--culture  { background: rgba(92,45,78,.1); color: var(--mcc-plum); }
.mcc-cat--power    { background: rgba(61,29,52,.1); color: var(--mcc-plum-dark); }
.mcc-cat--voices   { background: rgba(196,98,45,.08); color: var(--mcc-tierra); }

.mcc-content-title { font-family: var(--mcc-serif); font-size: 18px; font-weight: 400; color: var(--mcc-plum); margin: 0; line-height: 1.2; }
.mcc-content-title a { color: inherit; text-decoration: none; transition: color .2s; }
.mcc-content-title a:hover { color: var(--mcc-tierra); }
.mcc-content-excerpt { font-family: var(--mcc-sans); font-size: 14px; font-weight: 300; color: rgba(92,45,78,.55); margin: 0; line-height: 1.5; }
.mcc-content-date { font-family: var(--mcc-sans); font-size: 12px; color: rgba(92,45,78,.35); }


/* Voice grid */
.mcc-voice-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }

.mcc-voice-item { display: flex; flex-direction: column; gap: 10px; background: #fff; border: 1px solid rgba(92,45,78,.07); }

.mcc-voice-item a { display: block; aspect-ratio: 16/9; overflow: hidden; }
.mcc-voice-thumb { width: 100%; height: 100%; object-fit: cover; }

.mcc-voice-thumb-placeholder {
  aspect-ratio: 16/9;
  background: var(--mcc-plum-dark);
  display: flex;
  align-items: center;
  justify-content: center;
}

.mcc-voice-thumb-placeholder span { font-size: 32px; color: rgba(245,237,216,.4); }

.mcc-voice-info { padding: 12px; display: flex; flex-direction: column; gap: 4px; }
.mcc-voice-type { font-family: var(--mcc-sans); font-size: 10px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--mcc-tierra); }
.mcc-voice-title { font-family: var(--mcc-serif); font-size: 16px; font-weight: 400; color: var(--mcc-plum); margin: 0; line-height: 1.2; }
.mcc-voice-title a { color: inherit; text-decoration: none; }
.mcc-voice-title a:hover { color: var(--mcc-tierra); }
.mcc-voice-date { font-family: var(--mcc-sans); font-size: 12px; color: rgba(92,45,78,.35); }


/* Events */
.mcc-events-list { display: flex; flex-direction: column; gap: 16px; }

.mcc-event-item { display: flex; gap: 16px; align-items: flex-start; padding: 14px 0; border-bottom: 1px solid rgba(92,45,78,.06); }
.mcc-event-date { font-family: var(--mcc-sans); font-size: 12px; font-weight: 600; color: var(--mcc-oro); flex-shrink: 0; min-width: 90px; }
.mcc-event-title { font-family: var(--mcc-serif); font-size: 17px; font-weight: 400; color: var(--mcc-plum); margin: 0 0 4px; }
.mcc-event-title a { color: inherit; text-decoration: none; }
.mcc-event-location { font-size: 13px; color: rgba(92,45,78,.5); font-style: italic; margin: 0; }


/* ── SIDEBAR ──────────────────────────────────────────────────────────────── */

.mcc-sidebar-col { position: sticky; top: 80px; }

.mcc-sidebar-block { padding: 20px; background: #fff; border: 1px solid rgba(92,45,78,.07); margin-bottom: 16px; }

.mcc-sidebar-heading { font-family: var(--mcc-sans); font-size: 10px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: rgba(92,45,78,.4); margin: 0 0 12px; }

.mcc-specialty-chips { display: flex; flex-wrap: wrap; gap: 6px; }

.mcc-back-link { font-family: var(--mcc-sans); font-size: 13px; font-weight: 600; color: var(--mcc-tierra); text-decoration: none; }
.mcc-city-link { font-family: var(--mcc-sans); font-size: 14px; color: var(--mcc-plum); text-decoration: none; display: block; }
.mcc-city-link:hover { color: var(--mcc-tierra); }


/* ── DIRECTORY ────────────────────────────────────────────────────────────── */

.mcc-directory-wrap { max-width: 1160px; margin: 0 auto; padding: 0 0 80px; }

/* Filter bar */
.mcc-dir-filters {
  position: sticky;
  top: 0;
  z-index: 40;
  background: var(--mcc-plum-dark);
  padding: 16px 0;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 40px;
}

.mcc-dir-filter-form { display: flex; gap: 10px; flex-wrap: wrap; flex: 1; align-items: center; }

.mcc-dir-search-field { position: relative; flex: 1; min-width: 200px; }

.mcc-dir-input {
  width: 100%;
  padding: 9px 36px 9px 12px;
  background: rgba(245,237,216,.08);
  border: 1px solid rgba(245,237,216,.15);
  color: var(--mcc-crema);
  font-family: var(--mcc-sans);
  font-size: 14px;
  outline: none;
  border-radius: 0;
}

.mcc-dir-input::placeholder { color: rgba(245,237,216,.35); }
.mcc-dir-input:focus { border-color: rgba(245,237,216,.35); }

.mcc-dir-search-btn {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: rgba(245,237,216,.4);
  cursor: pointer;
}

.mcc-dir-dropdowns { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

.mcc-dir-select {
  padding: 8px 12px;
  background: rgba(245,237,216,.07);
  border: 1px solid rgba(245,237,216,.15);
  color: var(--mcc-crema);
  font-family: var(--mcc-sans);
  font-size: 13px;
  cursor: pointer;
  border-radius: 0;
  outline: none;
  min-width: 130px;
}

.mcc-dir-clear { font-family: var(--mcc-sans); font-size: 12px; color: rgba(245,237,216,.35); text-decoration: none; padding: 6px; }
.mcc-dir-clear:hover { color: var(--mcc-tierra); }

.mcc-dir-count { font-family: var(--mcc-sans); font-size: 13px; font-weight: 600; color: rgba(245,237,216,.45); white-space: nowrap; }

/* Grid */
.mcc-dir-grid { display: grid; gap: 24px; }
.mcc-dir-col-2 { grid-template-columns: repeat(2, 1fr); }
.mcc-dir-col-3 { grid-template-columns: repeat(3, 1fr); }
.mcc-dir-col-4 { grid-template-columns: repeat(4, 1fr); }

.mcc-dir-empty { font-family: var(--mcc-sans); font-size: 16px; font-weight: 300; color: rgba(92,45,78,.4); text-align: center; padding: 48px 0; grid-column: 1/-1; }
.mcc-dir-empty a { color: var(--mcc-tierra); }

/* Load more */
.mcc-dir-load-more-wrap { text-align: center; margin-top: 40px; }

.mcc-dir-load-more {
  font-family: var(--mcc-sans);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: 14px 40px;
  background: transparent;
  border: 1px solid rgba(92,45,78,.2);
  color: var(--mcc-plum);
  cursor: pointer;
  transition: all .2s;
}

.mcc-dir-load-more:hover { background: var(--mcc-plum); color: var(--mcc-crema); }


/* ── CARDS ────────────────────────────────────────────────────────────────── */

.mcc-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid rgba(92,45,78,.07);
  transition: transform .2s, box-shadow .2s;
}

.mcc-card:hover { transform: translateY(-3px); box-shadow: 0 8px 32px rgba(61,29,52,.1); }

.mcc-card-img-link { display: block; aspect-ratio: 1; overflow: hidden; background: var(--mcc-plum-dark); }
.mcc-card-img { width: 100%; height: 100%; object-fit: cover; transition: filter .3s; filter: saturate(.85); }
.mcc-card:hover .mcc-card-img { filter: saturate(1); }

.mcc-card-placeholder {
  aspect-ratio: 1;
  background: linear-gradient(135deg, var(--mcc-plum-dark), var(--mcc-plum));
  display: flex;
  align-items: center;
  justify-content: center;
}

.mcc-card-placeholder span { font-family: var(--mcc-serif); font-size: clamp(40px,8vw,64px); font-weight: 300; color: rgba(245,237,216,.5); }

.mcc-card-body { padding: 18px 18px 16px; display: flex; flex-direction: column; gap: 6px; flex: 1; }

.mcc-card-badges { display: flex; gap: 6px; flex-wrap: wrap; }

.mcc-card-name { font-family: var(--mcc-serif); font-size: 20px; font-weight: 400; color: var(--mcc-plum); margin: 0; line-height: 1.15; }
.mcc-card-name a { color: inherit; text-decoration: none; transition: color .2s; }
.mcc-card-name a:hover { color: var(--mcc-tierra); }

.mcc-card-role { font-family: var(--mcc-sans); font-size: 13px; font-weight: 400; color: rgba(92,45,78,.6); margin: 0; line-height: 1.4; }

.mcc-card-city { font-family: var(--mcc-sans); font-size: 12px; color: rgba(92,45,78,.4); margin: 0; display: flex; align-items: center; gap: 4px; }
.mcc-card-city svg { flex-shrink: 0; }

.mcc-card-bio { font-family: var(--mcc-sans); font-size: 13px; font-weight: 300; line-height: 1.55; color: rgba(92,45,78,.55); margin: 0; }

.mcc-card-specialties { display: flex; flex-wrap: wrap; gap: 4px; }

.mcc-card-cta { font-family: var(--mcc-sans); font-size: 12px; font-weight: 700; letter-spacing: .1em; color: var(--mcc-tierra); text-decoration: none; margin-top: auto; padding-top: 10px; }
.mcc-card-cta:hover { color: #b5561f; }


/* ── RESPONSIVE ──────────────────────────────────────────────────────────── */

@media (max-width: 1024px) {
  .mcc-hero-inner { padding: 48px 32px; }
  .mcc-body-wrap { padding: 40px 32px 60px; }
  .mcc-body-inner { grid-template-columns: 1fr; }
  .mcc-sidebar-col { position: static; }
  .mcc-action-bar-inner { padding: 12px 32px; }
  .mcc-headshot-img, .mcc-headshot-placeholder { width: 140px; height: 140px; }
  .mcc-dir-grid.mcc-dir-col-3 { grid-template-columns: repeat(2, 1fr); }
  .mcc-dir-grid.mcc-dir-col-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .mcc-hero-inner { grid-template-columns: 1fr; padding: 40px 20px; }
  .mcc-hero-headshot { order: -1; }
  .mcc-headshot-img, .mcc-headshot-placeholder { width: 100px; height: 100px; }
  .mcc-headshot-placeholder span { font-size: 40px; }
  .mcc-body-wrap { padding: 32px 20px 48px; }
  .mcc-action-bar-inner { flex-direction: column; gap: 12px; padding: 12px 20px; align-items: flex-start; }
  .mcc-voice-grid { grid-template-columns: 1fr; }
  .mcc-content-item { grid-template-columns: 1fr; }
  .mcc-content-thumb-link { display: none; }
  .mcc-dir-grid { grid-template-columns: 1fr; }
  .mcc-dir-filters { padding: 12px 20px; }
}
