/* ============================================================
   directory-public.css — CAICP navy/gold corporate design
   Covers: public directory page + member listing card (dpc-*)
   ============================================================ */

/* ── Variables ────────────────────────────────────────────── */
:root {
  --d-navy:       #0d1b3e;
  --d-navy-mid:   #162350;
  --d-navy-lt:    #1e2f63;
  --d-gold:       #c9a84c;
  --d-gold-lt:    #e2c47a;
  --d-gold-dk:    #a07c2e;
  --d-gold-bg:    #fdf6e7;
  --d-white:      #ffffff;
  --d-off:        #f4f5f9;
  --d-border:     #dde3f0;
  --d-muted:      #6b7794;
  --d-text:       #1a2240;

  --d-ok:         #1b7a4e;
  --d-ok-bg:      #eaf6f0;
  --d-ok-bd:      #a8d9c0;
  --d-ok-lt:      #059669;

  --d-pend:       #8a5c00;
  --d-pend-bg:    #fff8ec;
  --d-pend-bd:    #f5d78e;
  --d-pend-stripe:#d4891a;

  --d-rad:        8px;
  --d-rad-lg:     12px;
  --d-shad:       0 2px 16px rgba(13,27,62,.08);
  --d-shad-hover: 0 8px 32px rgba(13,27,62,.14);
}

/* ── Base ─────────────────────────────────────────────────── */
body.dir-public-page {
  font-family: 'Plus Jakarta Sans', 'DM Sans', system-ui, sans-serif;
  background: var(--d-off);
  color: var(--d-text);
  -webkit-font-smoothing: antialiased;
}

/* ─────────────────────────────────────────────────────────── */
/*  DIRECTORY CARD  (dpc-*)                                    */
/* ─────────────────────────────────────────────────────────── */

.dpc-card {
  background: var(--d-white);
  border-radius: var(--d-rad-lg);
  border: 1px solid var(--d-border);
  box-shadow: var(--d-shad);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
  height: 100%;
}
.dpc-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--d-shad-hover);
}

/* Status variants */
.dpc-card--pending {
  border-top: 3px solid var(--d-pend-stripe);
}
.dpc-card--certified {
  border-top: 3px solid var(--d-ok-lt);
}
.dpc-card--featured {
  box-shadow: 0 0 0 2px var(--d-gold), var(--d-shad-hover);
}
.dpc-card--featured:hover {
  box-shadow: 0 0 0 2px var(--d-gold), 0 12px 40px rgba(13,27,62,.18);
}

/* ── Ribbon (top status bar) ── */
.dpc-ribbon {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  font-size: .63rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .32rem .5rem;
  line-height: 1;
}
.dpc-ribbon--pending {
  background: linear-gradient(90deg, var(--d-pend) 0%, var(--d-pend-stripe) 100%);
  color: #fff;
}
.dpc-ribbon--certified {
  background: linear-gradient(90deg, var(--d-navy) 0%, var(--d-navy-lt) 100%);
  color: var(--d-gold-lt);
}

/* ── Photo ── */
.dpc-photo-wrap {
  display: block;
  text-decoration: none;
}
.dpc-photo {
  position: relative;
  height: 170px;
  background: linear-gradient(145deg, #e8ecf4, #f0f3f9);
  overflow: hidden;
}
.dpc-photo--pending  { box-shadow: inset 0 -3px 0 0 var(--d-pend-stripe); }
.dpc-photo--certified { box-shadow: inset 0 -3px 0 0 var(--d-ok-lt); }
.dpc-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform .35s ease;
}
.dpc-card:hover .dpc-photo img { transform: scale(1.035); }

/* Featured pill */
.dpc-featured-pill {
  position: absolute;
  top: .55rem;
  right: .55rem;
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  font-size: .63rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  background: linear-gradient(135deg, var(--d-gold) 0%, var(--d-gold-dk) 100%);
  color: var(--d-navy);
  padding: .28rem .6rem;
  border-radius: 20px;
  box-shadow: 0 2px 6px rgba(13,27,62,.2);
}

/* ── Card body ── */
.dpc-body {
  padding: .9rem 1rem .7rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .3rem;
}

/* Name row */
.dpc-name-row {
  display: flex;
  align-items: flex-start;
  gap: .45rem;
  margin-bottom: .1rem;
}
.dpc-name {
  font-size: .97rem;
  font-weight: 700;
  color: var(--d-navy);
  line-height: 1.25;
  margin: 0;
}
.dpc-name a {
  color: inherit;
  text-decoration: none;
  transition: color .15s;
}
.dpc-name a:hover { color: var(--d-gold-dk); }

/* Status icon beside name */
.dpc-status-icon {
  flex-shrink: 0;
  margin-top: .18rem;
}
.dpc-status-icon--pending {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--d-pend-bg);
  color: var(--d-pend);
  border: 1px solid var(--d-pend-bd);
  flex-shrink: 0;
}
.dpc-status-icon--cert {
  width: 20px;
  height: 20px;
  object-fit: contain;
}

/* Meta lines */
.dpc-company,
.dpc-loc,
.dpc-since {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .76rem;
  color: var(--d-muted);
  margin: 0;
}
.dpc-company svg,
.dpc-loc svg { flex-shrink: 0; color: var(--d-muted); }
.dpc-company { font-weight: 500; color: var(--d-navy-mid); }
.dpc-since   { font-size: .72rem; }

.dpc-exp {
  font-size: .72rem;
  color: var(--d-muted);
  margin: .1rem 0 .2rem;
  line-height: 1.45;
}
.dpc-exp strong { color: var(--d-navy-mid); font-weight: 600; }

/* Pills */
.dpc-pills {
  display: flex;
  flex-wrap: wrap;
  gap: .3rem;
  margin-top: auto;
  padding-top: .5rem;
}
.dpc-pill {
  display: inline-block;
  font-size: .63rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 20px;
}
.dpc-pill--brand       { background: var(--d-navy); color: var(--d-gold-lt); }
.dpc-pill--brand-pend  { background: #7a3c00; color: #ffe5b0; }
.dpc-pill--certified   { background: var(--d-ok-bg); color: var(--d-ok); border: 1px solid var(--d-ok-bd); }
.dpc-pill--pending     { background: var(--d-pend-bg); color: var(--d-pend); border: 1px solid var(--d-pend-bd); }
.dpc-pill--vetted      { background: #e6f4f4; color: #0d6e6e; border: 1px solid #a8d5d5; }

/* ── Card footer ── */
.dpc-footer {
  padding: .6rem .9rem .75rem;
  border-top: 1px solid var(--d-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  margin-top: .1rem;
}

/* CTA button */
.dpc-cta {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .03em;
  border-radius: var(--d-rad);
  padding: .38rem .85rem;
  text-decoration: none;
  transition: opacity .15s, transform .1s;
  white-space: nowrap;
}
.dpc-cta:hover { opacity: .88; transform: translateY(-1px); }
.dpc-cta--certified {
  background: linear-gradient(135deg, var(--d-gold) 0%, var(--d-gold-dk) 100%);
  color: var(--d-navy);
}
.dpc-cta--pending {
  background: var(--d-navy);
  color: var(--d-gold-lt);
}

/* Social links */
.dpc-socials {
  display: flex;
  align-items: center;
  gap: .3rem;
}
.dpc-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 1px solid var(--d-border);
  color: var(--d-muted);
  text-decoration: none;
  transition: border-color .15s, color .15s, background .15s;
}
.dpc-social-link:hover {
  border-color: var(--d-navy);
  color: var(--d-navy);
  background: var(--d-off);
}

/* ─────────────────────────────────────────────────────────── */
/*  LEGACY classes (kept for any other templates)             */
/* ─────────────────────────────────────────────────────────── */
.dir-legend-certified { color: var(--d-ok);   font-weight: 600; }
.dir-legend-pending   { color: var(--d-pend); font-weight: 600; }

.dir-legend-swatch {
  display: inline-block;
  width: .75rem;
  height: .75rem;
  border-radius: 50%;
  margin-right: .3rem;
  vertical-align: -.08em;
}
.dir-legend-swatch--pending  {
  background: var(--d-pend-stripe);
  box-shadow: 0 0 0 1px rgba(180,83,9,.35);
}
.dir-legend-swatch--certified {
  background: var(--d-ok-lt);
  box-shadow: 0 0 0 1px rgba(5,150,105,.35);
}

.dir-search {
  border-radius: var(--d-rad);
  border: 1px solid var(--d-border);
}

/* Member preview strip */
.dir-preview-banner {
  background: linear-gradient(135deg, var(--d-gold-bg) 0%, #fde68a 100%);
  border-bottom: 1px solid var(--d-pend-bd);
  color: #78350f;
  padding: .85rem 0;
}
.dir-preview-banner strong { color: #451a03; }
