/* assets/css/components/team-modal.css
 * @layer components — team member modal + card trigger styles
 * Shared between About Us and Meet Our Leaders pages.
 * ════════════════════════════════════════════════════════════════════ */

/*
 * Scroll lock — applied to <html> so the body stays in place.
 * --modal-scroll-y is set by JS before the class is added, preventing
 * any layout shift. This is the modern zero-jump technique.
 */
html.modal-open {
  overflow: hidden;
}

@layer components {

  /* ── Card trigger ── */
  .js-team-modal-trigger { cursor: pointer; }

  .js-team-modal-trigger:focus-visible {
    outline: var(--focus-ring);
    outline-offset: var(--focus-ring-offset);
    border-radius: var(--card-radius);
  }


  /* ════════════════════════════════════════════════════════════════════
     OVERLAY WRAPPER
     ════════════════════════════════════════════════════════════════════ */

  .team-modal {
    position: fixed;
    inset: 0;
    z-index: var(--z-modal, 500);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-l);
  }

  .team-modal[hidden] { display: none; }

  .team-modal__backdrop {
    position: absolute;
    inset: 0;
    background: color-mix(in oklch, var(--neutral-ultra-dark) 55%, transparent);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    animation: backdrop-in 200ms var(--ease-default) both;
  }

  @keyframes backdrop-in {
    from { opacity: 0; }
    to   { opacity: 1; }
  }


  /* ════════════════════════════════════════════════════════════════════
     PANEL
     ════════════════════════════════════════════════════════════════════ */

  .team-modal__panel {
    position: relative;
    z-index: 1;
    background: var(--white);
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-xl), 0 0 0 1px color-mix(in oklch, var(--neutral-ultra-dark) 8%, transparent);
    inline-size: min(52rem, 100%);
    max-block-size: calc(100dvh - var(--space-3xl));
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-width: thin;
    scrollbar-color: var(--border-subtle) transparent;
  }

  /* Animation — triggered by adding .is-opening class via JS */
  .team-modal__panel.is-opening {
    animation: modal-in 220ms cubic-bezier(0.22, 1, 0.36, 1) both;
  }

  @keyframes modal-in {
    from { opacity: 0; transform: translateY(1rem) scale(0.97); }
    to   { opacity: 1; transform: none; }
  }

  @keyframes modal-in-sheet {
    from { opacity: 0; transform: translateY(100%); }
    to   { opacity: 1; transform: none; }
  }


  /* ════════════════════════════════════════════════════════════════════
     CLOSE BUTTON
     ════════════════════════════════════════════════════════════════════ */

  .team-modal__close {
    position: sticky;
    inset-block-start: 0;
    float: inline-end;
    z-index: 2;
    margin: var(--space-s) var(--space-s) calc(var(--space-s) * -1) 0;
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: 2.25rem;
    block-size: 2.25rem;
    border-radius: var(--radius-full);
    border: 1px solid var(--border-subtle);
    background: var(--surface-raised);
    color: var(--text-muted);
    cursor: pointer;
    transition:
      background var(--duration-fast) var(--ease-default),
      color      var(--duration-fast) var(--ease-default);
  }

  /* Bottom close — pill style, aligned to end of content column */
  .team-modal__close-bottom {
    position: static;
    float: none;
    inline-size: auto;
    block-size: auto;
    justify-content: flex-start;
    margin: var(--content-gap) 0 0 auto;
    padding: var(--space-2xs) var(--space-m);
    gap: var(--space-2xs);
    font-size: var(--text-s);
    font-weight: var(--weight-semibold);
    border-radius: var(--radius-full);
  }

  .team-modal__close:hover {
    background: var(--surface-tinted);
    color: var(--text-main);
  }

  .team-modal__close:focus-visible {
    outline: var(--focus-ring);
    outline-offset: var(--focus-ring-offset);
  }


  /* ════════════════════════════════════════════════════════════════════
     BODY LAYOUT — photo left, content right
     ════════════════════════════════════════════════════════════════════ */

  .team-modal__body {
    display: grid;
    grid-template-columns: 13rem 1fr;
    gap: var(--container-gap);
    padding: var(--space-l);
    padding-block-start: var(--space-xs);
    align-items: start;
  }

  .team-modal__media {
    border-radius: var(--radius-xl);
    overflow: hidden;
    background: var(--surface-tinted);
    aspect-ratio: 3 / 4;
    position: sticky;
    inset-block-start: var(--space-l);
  }

  .team-modal__media img {
    display: block;
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    object-position: center top;
  }


  /* ════════════════════════════════════════════════════════════════════
     CONTENT
     ════════════════════════════════════════════════════════════════════ */

  .team-modal__content {
    display: flex;
    flex-direction: column;
    gap: var(--content-gap);
    padding-block-end: var(--space-l);
  }

  /* Name + role tightly grouped */
  .team-modal__name {
    font-size: var(--heading-s);
    font-weight: var(--weight-bold);
    line-height: var(--leading-tight);
    color: var(--text-main);
    margin: 0 0 var(--stack-gap);
  }

  .team-modal__role {
    font-size: var(--text-m);
    font-weight: var(--weight-bold);
    color: var(--primary);
    margin: 0;
  }

  .team-modal__qualifications {
    font-size: var(--text-s);
    color: var(--text-muted);
    line-height: var(--leading-relaxed);
    padding-block-start: var(--content-gap);
    border-block-start: 1px solid var(--border-subtle);
    margin: 0;
  }

  .team-modal__bio {
    font-size: var(--text-m);
    line-height: var(--leading-relaxed);
    color: var(--text-body);
  }

  .team-modal__bio p { margin: 0; }
  .team-modal__bio p + p { margin-block-start: var(--space-s); }

  .team-modal__links {
    display: flex;
    flex-wrap: wrap;
    gap: var(--cluster-gap);
  }

  .team-modal__link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2xs);
    font-size: var(--text-s);
    font-weight: var(--weight-semibold);
    color: var(--primary);
    text-decoration: none;
    padding: var(--space-2xs) var(--space-s);
    border-radius: var(--radius-full);
    border: 1px solid var(--primary-light);
    background: var(--primary-ultra-light);
    transition:
      background var(--duration-fast) var(--ease-default),
      color      var(--duration-fast) var(--ease-default);
  }

  .team-modal__link:hover {
    background: var(--primary);
    color: var(--white);
    border-color: var(--primary);
  }

  .team-modal__link svg {
    inline-size: 1em;
    block-size: 1em;
    flex-shrink: 0;
  }


  /* ════════════════════════════════════════════════════════════════════
     MOBILE — bottom sheet
     ════════════════════════════════════════════════════════════════════ */

  @media (max-width: 40em) {
    .team-modal {
      align-items: flex-end;
      padding: 0;
    }

    .team-modal__panel {
      inline-size: 100%;
      max-block-size: 88dvh;
      border-radius: var(--radius-2xl) var(--radius-2xl) 0 0;
      padding-block-start: var(--space-xs);
    }

    /* Drag-handle hint */
    .team-modal__panel::before {
      content: '';
      display: block;
      inline-size: 2.5rem;
      block-size: 4px;
      border-radius: var(--radius-full);
      background: var(--border-subtle);
      margin: 0 auto var(--space-2xs);
    }

    .team-modal__panel.is-opening {
      animation: modal-in-sheet 260ms cubic-bezier(0.22, 1, 0.36, 1) both;
    }

    .team-modal__body {
      grid-template-columns: 1fr;
      padding: var(--space-m);
      padding-block-start: var(--space-m);
    }

    .team-modal__media {
      display: none;
    }
  }

}
