@layer components {
  /* Lodge map — illustrated paper plot with cabin pins. */
  .lodge-map {
    position: relative;
    background: var(--paper);
    border: 1px solid var(--paper-edge);
    border-radius: var(--radius-md);
    aspect-ratio: 16 / 10;
    overflow: hidden;
  }
  .lodge-map .legend-overlay {
    position: absolute;
    left: var(--space-5); top: var(--space-5);
    background: rgba(255,255,255,0.85);
    padding: var(--space-3) var(--space-4);
    font-size: var(--cap-md);
    text-transform: uppercase;
    letter-spacing: var(--tracking-cap-tight);
    font-weight: var(--weight-medium);
  }
  .lodge-map .topo {
    position: absolute; inset: 0;
    background-image:
      radial-gradient(ellipse at 30% 70%, rgba(74, 124, 78, 0.18) 0%, transparent 50%),
      radial-gradient(ellipse at 70% 30%, rgba(47, 72, 88, 0.12) 0%, transparent 60%),
      radial-gradient(circle at 20% 20%, rgba(107, 79, 51, 0.08) 0%, transparent 30%);
  }
  .lodge-map .road {
    position: absolute;
    left: 0; right: 0; top: 60%;
    height: 6px;
    background: rgba(0,0,0,0.06);
    transform: rotate(-2deg);
  }

  .cabin-pin {
    position: absolute;
    transform: translate(-50%, -50%);
    background: var(--paper);
    border: 1px solid rgba(0,0,0,0.18);
    padding: 6px 10px;
    font-size: 12px;
    font-weight: var(--weight-semibold);
    cursor: pointer;
    box-shadow: var(--shadow-card);
    text-decoration: none;
    color: var(--ink);
    white-space: nowrap;
  }
  .cabin-pin.assigned {
    background: var(--arrive);
    color: #fff;
    border-color: var(--arrive);
    box-shadow: 0 0 0 4px rgba(74, 124, 78, 0.18), var(--shadow-card);
  }
  .cabin-pin.full {
    background: rgba(0,0,0,0.05);
    color: var(--ink-faint);
  }
  .cabin-pin .occ {
    display: block;
    font-size: var(--cap-xs);
    letter-spacing: 0.04em;
    opacity: 0.8;
    margin-top: 2px;
    font-weight: var(--weight-medium);
  }

  /* Profile gallery (Profiles tab + cohort cards). */
  .profile-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--space-5);
  }
  .profile-card {
    background: var(--paper-warm);
    border: 1px solid var(--paper-edge);
    padding: var(--space-5);
    text-align: center;
    box-shadow: var(--shadow-card);
  }
  .profile-card .avatar { margin: 0 auto var(--space-3); }
  .profile-card .name {
    font-family: var(--display);
    font-style: italic;
    font-weight: var(--weight-medium);
  }
  .profile-card .meta {
    font-size: var(--cap-md);
    color: var(--ink-faint);
    margin-top: 4px;
    text-transform: uppercase;
    letter-spacing: var(--tracking-cap-tight);
    font-weight: var(--weight-medium);
  }
  .profile-card.empty {
    background: transparent;
    border-style: dashed;
    color: var(--ink-faint);
  }
  .profile-card.empty .avatar {
    background: transparent;
    color: var(--ink-faint);
    border: 1px dashed rgba(0,0,0,0.25);
  }
}
