/* ═══════════════════════════════════════════════════════
   PELOTERO — Global Stylesheet
   ═══════════════════════════════════════════════════════
   Brand Colors (from brand guidelines):
     Dark:         #313638
     Light:        #faf9f5
     Mid Gray:     #b0aea5
     Light Gray:   #e8e6dc
     Yellow-Green: #d6ef67 (primary accent)
     Blue:         #274c77 (secondary accent)
     Orange:       #f19a39 (tertiary accent)

   Typography:
     Headings: Sol Pro (via Adobe Typekit)
     Body:     Avenir Next Condensed (fallback: Arial)
   ═══════════════════════════════════════════════════════ */

/* ── CSS Custom Properties ── */
:root {
  /* Brand core */
  --pel-dark: #313638;
  --pel-light: #faf9f5;
  --pel-mid-gray: #b0aea5;
  --pel-light-gray: #e8e6dc;

  /* Accents */
  --pel-accent: #d6ef67;
  --pel-accent-dim: #b8ce45;
  --pel-blue: #274c77;
  --pel-orange: #f19a39;

  /* Navy palette (for dark header areas) */
  --pel-navy: #152238;
  --pel-navy-mid: #1E3050;
  --pel-navy-light: #28406A;

  /* Surfaces & cards */
  --pel-card: #ffffff;
  --pel-surface: #F5F6F0;
  --pel-surface-alt: #ECEEE4;
  --pel-border: #E0E2D8;

  /* Text */
  --pel-text: #1A1A1A;
  --pel-text-secondary: #5A5D52;
  --pel-text-muted: #8E9184;

  /* Radius */
  --pel-radius: 12px;
  --pel-radius-sm: 6px;

  /* Accent utilities (rgba variants) */
  --pel-accent-bg: rgba(214, 239, 103, 0.10);
  --pel-accent-bg-med: rgba(214, 239, 103, 0.20);
  --pel-accent-bg-strong: rgba(214, 239, 103, 0.30);

  /* Rating palette */
  
  --pel-performance-great: #D4E26C;
  --pel-performance-above: #9FBC70;
  --pel-performance-good: #6A9776;
  --pel-performance-average: #2B6A7C;
  --pel-performance-below: var(--pel-blue);
  
  --pel-rating-great: #9FBC70;
  --pel-rating-above: rgb(214 239 103);
  --pel-rating-good: rgb(214 239 103);
  --pel-rating-average: rgb(214 239 103 / 50%);
  --pel-rating-below: rgb(214 239 103 / 25%);
  --pel-rating-poor: rgba(204, 0, 0, 0.15);

}

/* ── Reset & Base ── */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  background: #e0e6ea;
  font-family: 'avenir next condensed', 'Avenir Next Condensed', Arial, sans-serif;
  color: var(--pel-text);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}


/* ── Typography ── */
h1, h2, h3, h4, h5, h6,
.heading {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-weight: 700;
  line-height: 1.2;
}

a {
  color: var(--pel-blue);
  text-decoration: none;
}

.sol-pro-italic {
  font-family: sol-pro, sans-serif;
  font-weight: 400;
  font-style: italic;
}

.sol-pro-bold {
  font-family: sol-pro, sans-serif;
  font-weight: 700;
  font-style: normal;
}

.sol-pro-bold-italic {
  font-family: sol-pro, sans-serif;
  font-weight: 700;
  font-style: italic;
}

.no-wrap {
  white-space: nowrap;
}

/* ── Page Wrapper ── */
.pel-page {
  width: 1100px;
  max-width: 100%;
  margin: 0 auto;
  padding: 32px 16px;
}


/* ═══════════════════════════════════════════════════════
   TOPBAR — Main site header (reusable across all pages)
   ═══════════════════════════════════════════════════════ */
.pel-topbar {
  background: var(--pel-navy);
  padding: 0 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 54px;
  /*border-radius: var(--pel-radius) var(--pel-radius) 0 0;*/
}

.pel-topbar__logo {
  display: flex;
  align-items: center;
  text-decoration: none;
}

.pel-topbar__logo-img {
  height: 28px;
  filter: brightness(5.5);
  display: block;
}

.pel-topbar__logo:hover {
  text-decoration: none;
}

.pel-topbar__nav {
  display: flex;
  gap: 24px;
  font-size: 14px;
  font-weight: 500;
  list-style: none;
}

.pel-topbar__nav a {
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  letter-spacing: 0.3px;
  transition: color 0.15s;
}

.pel-topbar__nav a:hover,
.pel-topbar__nav a.active {
  color: #fff;
}

/* Dropdown support in topbar */
.pel-topbar__dropdown {
  position: relative;
}

.pel-topbar__dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;
  right: 0;
  background: var(--pel-card);
  border: 1px solid var(--pel-border);
  border-radius: var(--pel-radius-sm);
  min-width: 200px;
  padding: 8px 0;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  z-index: 1000;
}

.pel-topbar__dropdown:hover .pel-topbar__dropdown-menu,
.pel-topbar__dropdown.open .pel-topbar__dropdown-menu {
  display: block;
}

.pel-topbar__dropdown-menu a {
  display: block;
  padding: 8px 16px;
  color: var(--pel-text) !important;
  font-size: 14px;
  text-decoration: none;
}

.pel-topbar__dropdown-menu a:hover {
  background: var(--pel-accent-bg);
  color: var(--pel-text) !important;
}


/* ═══════════════════════════════════════════════════════
   ATHLETE HERO — Athlete profile header
   (reusable across all athlete tabs)
   ═══════════════════════════════════════════════════════ */
.pel-hero {
  background: var(--pel-navy);
  padding: 28px 36px 8px;
  position: relative;
  overflow: hidden;
  border-top-left-radius: var(--pel-radius);
  border-top-right-radius: var(--pel-radius);
}

/* Decorative background circles */
.pel-hero::before {
  content: '';
  position: absolute;
  top: -60px;
  right: -30px;
  width: 360px;
  height: 360px;
  border-radius: 50%;
  border: 50px solid rgba(214, 239, 103, 0.05);
}

.pel-hero::after {
  content: '';
  position: absolute;
  bottom: 20px;
  right: 100px;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  border: 30px solid rgba(214, 239, 103, 0.03);
}

.pel-hero__inner {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 24px;
  align-items: flex-start;
}

/* Avatar */
.pel-hero__avatar {
  width: 76px;
  height: 76px;
  border-radius: 50%;
  background: var(--pel-navy-mid);
  border: 2.5px solid var(--pel-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}

.pel-hero__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.pel-hero__avatar svg {
  width: 36px;
  height: 36px;
}

/* Athlete info */
.pel-hero__info {
  flex: 1;
}

.pel-hero__name {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin: 0;
}

.pel-hero__email {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.35);
  margin-top: 2px;
}

.pel-hero__email a {
  color: rgba(255, 255, 255, 0.35);
  text-decoration: none;
}

.pel-hero__email a:hover {
  color: rgba(255, 255, 255, 0.6);
}

/* Stat pills (age, height, weight, etc.) */
.pel-hero__stats {
  display: flex;
  gap: 10px;
  margin-top: 12px;
  flex-wrap: wrap;
}

.pel-hero__stat {
  font-size: 14px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.08);
  padding: 5px 14px;
  border-radius: 4px;
  letter-spacing: 0.3px;
}

/* Tags (motor preferences, etc.) */
.pel-hero__tags {
  display: flex;
  gap: 7px;
  margin-top: 12px;
  flex-wrap: wrap;
}

.pel-hero__tag {
  font-size: 10px;
  font-weight: 600;
  color: var(--pel-accent);
  background: rgba(214, 239, 103, 0.12);
  padding: 4px 12px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

/* Motor preferences edit/view icon within tags row */
.pel-hero__tag-edit {
  display: inline-flex;
  align-items: center;
  color: rgba(255, 255, 255, 0.4);
  font-size: 14px;
  background: none;
  border: none;
  padding: 0 2px;
  cursor: pointer;
  line-height: 1;
  text-decoration: none;
}

.pel-hero__tag-edit:hover {
  color: var(--pel-accent);
}

/* "Enter Motor Preferences" prompt link */
.pel-hero__tag-link {
  display: inline-block;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.4);
  margin-top: 10px;
  text-decoration: none;
  letter-spacing: 0.3px;
}

.pel-hero__tag-link:hover {
  color: var(--pel-accent);
  text-decoration: none;
}

/* Data status widget (right side) */
.pel-hero__status {
  margin-left: auto;
  flex-shrink: 0;
}

.pel-hero__status-box {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--pel-radius-sm);
  padding: 12px 16px;
  min-width: 180px;
  text-align: center;
}

.pel-hero__status-title {
  font-size: 12px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.pel-hero__status-icons {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-bottom: 8px;
}

.pel-hero__status-icon {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}

.pel-hero__status-icon--available {
  background: var(--pel-accent);
  color: var(--pel-dark);
}

.pel-hero__status-icon--old {
  background: var(--pel-orange);
  color: #fff;
}

.pel-hero__status-icon--missing {
  background: #D6D6D6;
  color: #888;
}

.pel-hero__status-icon--pending {
  background: transparent;
  border: 1.5px solid var(--pel-accent);
  color: var(--pel-accent);
}


/* ═══════════════════════════════════════════════════════
   TABS — Athlete tab navigation
   (reusable across all athlete pages)
   ═══════════════════════════════════════════════════════ */
.pel-tabs {
  display: flex;
  gap: 0;
  background: var(--pel-navy);
  padding: 0 32px;
  position: relative;
  z-index: 1;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.pel-tabs__item {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.4);
  padding: 16px 16px 8px;
  cursor: pointer;
  position: relative;
  letter-spacing: 0.06rem;
  text-transform: uppercase;
  transition: color 0.15s;
  user-select: none;
  text-decoration: none;
  white-space: nowrap;
  display: block;
}

.pel-tabs__item:hover {
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
}

.pel-tabs__item.active {
  color: #fff;
}

.pel-tabs__item.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 8px;
  right: 8px;
  height: 3px;
  background: var(--pel-accent);
  border-radius: 2px 2px 0 0;
}

/* Hitting tab: small chevron hint */
.pel-tabs__item--has-sub::after {
  display: none; /* overridden when active */
}
.pel-tabs__item--has-sub.active::after {
  display: block;
}


/* ═══════════════════════════════════════════════════════
   SUB-TABS — Hitting section secondary navigation
   ═══════════════════════════════════════════════════════ */
.pel-subtabs {
  display: flex;
  background: var(--pel-navy-mid);
  padding: 0 32px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.pel-subtabs::-webkit-scrollbar {
  display: none;
}

.pel-subtabs__item {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.45);
  padding: 10px 14px 12px;
  cursor: pointer;
  position: relative;
  transition: color 0.15s;
  text-decoration: none;
  white-space: nowrap;
  display: block;
}

.pel-subtabs__item:hover {
  color: rgba(255, 255, 255, 0.75);
  text-decoration: none;
}

.pel-subtabs__item.active {
  color: var(--pel-accent);
  font-weight: bold;
}

/*
.pel-subtabs__item.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 6px;
  right: 6px;
  height: 2px;
  background: var(--pel-accent);
  border-radius: 2px 2px 0 0;
}
*/

/* Container for the toggle within the subnav */
.pel-subtabs__actions {
  margin-left: auto; /* Pushes toggle to the right on desktop */
  display: flex;
  align-items: center;
  padding-right: 16px;
}

/* The actual "Pill" toggle */
.pel-switch-hit-toggle {
  position: relative;
  display: flex;
  background: rgba(255, 255, 255, 0.06);
  border: none;
  border-radius: 20px;
  height: 28px;
  width: 72px;
  padding: 2px;
  overflow: hidden;
  align-self: center;
  margin-left: auto;
}

.pel-switch-hit-toggle input {
  display: none;
}

.pel-switch-hit-toggle label {
  flex: 1;
  z-index: 2;
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 24px;
  text-align: center;
  margin: 0;
  padding-left: 4px;
  padding-right: 4px;
  color: var(--pel-text-muted, #6b7a8d);
  transition: color 0.2s ease;
  border-radius: 20px;
}

/* Text color when selected */
.pel-switch-hit-toggle input:checked + label {
  color: #1a2332;
}

/* The sliding background indicator */
.toggle-selection-slider {
  position: absolute;
  top: 2px;
  left: 2px;
  width: calc(50% - 2px);
  height: calc(100% - 4px);
  background: var(--pel-accent, #d6ef67);
  border-radius: 20px;
  transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 1;
}

/* Move slider to the right when 'R' is checked */
#side_r:checked ~ .toggle-selection-slider {
  transform: translateX(100%);
}

/* Mobile Responsiveness */
@media (max-width: 767px) {
  .pel-subtabs {
    flex-wrap: wrap;
    justify-content: center;
  }
  .pel-subtabs__actions {
    margin: 10px 0;
    width: 100%;
    justify-content: center;
    padding-right: 0;
  }
}

/* ═══════════════════════════════════════════════════════
   BODY / CONTENT AREA
   ═══════════════════════════════════════════════════════ */
.pel-body {
  background: var(--pel-surface);
  border-left: 0.5px solid var(--pel-border);
  border-right: 0.5px solid var(--pel-border);
  border-bottom: 0.5px solid var(--pel-border);
  border-radius: 0 0 var(--pel-radius) var(--pel-radius);
  padding: 28px 32px;
}


/* ═══════════════════════════════════════════════════════
   CARDS — Reusable card components
   ═══════════════════════════════════════════════════════ */
.pel-card {
  background: var(--pel-card);
  border-radius: 10px;
  border: 0.5px solid var(--pel-border);
  padding: 20px 22px;
  position: relative;
  overflow: hidden;
  transition: border-color 0.15s;
  margin-bottom: 16px;
}

.pel-card:hover {
  border-color: #CCC;
}

/* Opt-out of the card's overflow clipping so CSS-only .pel-tip tooltips inside
   the card (e.g. rating-component category names) aren't cut off at the card
   edge. Only apply to cards with no full-bleed content relying on the clip. */
.pel-card--overflow-visible {
  overflow: visible;
}

.pel-card__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 16px;
}

.pel-card__title {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--pel-text-secondary);
  margin-bottom: 24px;
}

.pel-card__subtitle {
  font-size: 14px;
  color: var(--pel-text-muted);
}

/* Kebab (three-dot) menu for card-level secondary actions. */
.pel-kebab {
  position: relative;
  display: inline-block;
}
.pel-kebab__btn {
  background: transparent;
  border: 0;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  cursor: pointer;
  color: var(--pel-text-secondary);
  font-size: 16px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.pel-kebab__btn:hover {
  background: var(--pel-accent-bg);
  color: var(--pel-text);
}
.pel-kebab__menu {
  display: none;
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 4px;
  background: var(--pel-card);
  border: 1px solid var(--pel-border);
  border-radius: var(--pel-radius-sm);
  min-width: 200px;
  padding: 6px 0;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  z-index: 200;
}
.pel-kebab.open .pel-kebab__menu {
  display: block;
}
.pel-kebab__item {
  display: block;
  width: 100%;
  text-align: left;
  background: transparent;
  border: 0;
  padding: 8px 16px;
  font-size: 13px;
  color: var(--pel-text);
  cursor: pointer;
  text-decoration: none;
  font-family: inherit;
}
.pel-kebab__item:hover {
  background: var(--pel-accent-bg);
  color: var(--pel-text);
}
.pel-kebab__item[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Stacked fact rows inside a card body. */
.pel-card__row {
  font-size: 14px;
  line-height: 1.4;
}
.pel-card__row + .pel-card__row {
  margin-top: 10px;
}
.pel-card__row--status {
  margin-bottom: 14px;
}

/* Inline action button group inside a card. */
.pel-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.pel-card__actions form {
  margin: 0;
}

/* Muted secondary text — small utility used inside card rows. */
.pel-muted {
  color: var(--pel-text-muted);
  font-size: 13px;
}


/* ═══════════════════════════════════════════════════════
   SCORE CARDS — Section cards with left accent bar
   ═══════════════════════════════════════════════════════ */
.pel-score-card {
  background: var(--pel-card);
  border-radius: 10px;
  border: 0.5px solid var(--pel-border);
  padding: 22px 28px;
  margin-bottom: 16px;
  position: relative;
  transition: border-color 0.15s;
}

.pel-score-card:hover {
  border-color: var(--pel-accent-dim);
}

.pel-score-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: var(--pel-accent);
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}

.pel-score-card__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 4px;
}

.pel-score-card__title {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 22px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.pel-score-card__subtitle {
  font-size: 13px;
  color: var(--pel-text-muted);
  margin-bottom: 20px;
}

/* Zero-state: no AthleteReport for this template yet. The card chrome is shown
   faded with a centered overlay message (mirrors the Rating tab components).
   .pel-score-card is already position: relative, so the overlay anchors to it. */
.pel-score-card--empty::before {
  background: var(--pel-border);
}

.pel-score-card__overlay-msg {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 14px;
  font-weight: 600;
  color: var(--pel-text-muted);
  border-radius: 10px;
  text-align: center;
  padding: 16px;
}

.pel-score-card__faded {
  opacity: 0.25;
}

/* Page-level zero-state: a stacked CTA card above a faded teaser of the real
   content (e.g. the Hitting Overview before any reports/workouts exist). Use
   when an entire tab is empty; the single-card overlay above is for one card. */
.pel-zero-state {
  background: var(--pel-surface);
  border: 1px solid var(--pel-border);
  border-radius: 8px;
  padding: 24px;
  margin-bottom: 24px;
  font-size: 14px;
}

.pel-faded {
  opacity: 0.3;
  pointer-events: none;
}


/* ═══════════════════════════════════════════════════════
   METRICS LAYOUT — Score + bar breakdown
   ═══════════════════════════════════════════════════════ */
.pel-metrics {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 16px 28px;
  align-items: start;
}

.pel-metrics__overall {
  text-align: center;
  padding-right: 24px;
  border-right: 0.5px solid var(--pel-border);
  min-width: 90px;
}

.pel-metrics__overall-number {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 56px;
  font-weight: 700;
  line-height: 1;
  color: var(--pel-navy);
}

.pel-metrics__overall-label {
  font-size: 10px;
  color: var(--pel-text-muted);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  font-weight: 600;
  margin-top: 3px;
}

/* Bar rows */
.pel-metrics__bars {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.pel-metrics__row {
  display: grid;
  grid-template-columns: 120px 1fr 32px 64px;
  gap: 12px;
  align-items: center;
}

.pel-metrics__label {
  color: var(--pel-text-secondary);
  text-align: right;
  font-size: 14px;
  font-weight: 500;
}

.pel-metrics__track {
  height: 10px;
  background: var(--pel-surface-alt);
  border-radius: 2px;
  overflow: hidden;
}

.pel-metrics__fill {
  height: 100%;
  border-radius: 2px;
  background: var(--pel-accent);
}

.pel-metrics__value {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-weight: 700;
  font-size: 15px;
}

/* Badges */
.pel-badge {
  font-size: 10px;
  padding: 3px 10px;
  border-radius: 3px;
  font-weight: 600;
  text-align: center;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  display: inline-block;
}

/*
.bg-dark-green { background: var(--pel-accent-bg-strong); }
.bg-light-green { background: var(--pel-accent-bg-med); }
.bg-light-orange { background: rgba(241, 154, 57, 0.15); }
.bg-dark-orange { background: rgba(241, 154, 57, 0.25); }
.bg-light-red { background: rgba(204, 0, 0, 0.08); }
.bg-dark-red { background: rgba(204, 0, 0, 0.15); }
*/

.pel-badge--great {
  background: var(--pel-rating-great);
}

.pel-badge--good {
  background: var(--pel-rating-above);
}

.pel-badge--avg {
  /*background: var(--pel-accent-bg);*/
  background: var(--pel-rating-average);
}

.pel-badge--below {
  /*background: rgba(241, 154, 57, 0.15);*/
  background: var(--pel-rating-below);
  color: var(--pel-light-gray);
}

.pel-badge--poor {
  /*background: rgba(204, 0, 0, 0.1);*/
  background: var(--pel-rating-poor);
  color: #9A2020;
}


/* ═══════════════════════════════════════════════════════
   GRID UTILITIES
   ═══════════════════════════════════════════════════════ */
.pel-grid-2 {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 20px;
}

.pel-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  text-align: center;
}

.pel-grid-5-7 {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 16px;
}

.pel-grid-7-5 {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: 20px;
}

.pel-flex-center {
  display: flex;
  justify-content: center;
  align-items: center;
}


/* ═══════════════════════════════════════════════════════
   CIRCULAR PROGRESS — Workout rings
   ═══════════════════════════════════════════════════════ */
.pel-ring {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

.pel-ring__value {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 24px;
  font-weight: 700;
}

.pel-ring__label {
  font-size: 12px;
  color: var(--pel-text-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}


/* ═══════════════════════════════════════════════════════
   SERVICE DASHBOARD — shared data-viz building blocks
   ═══════════════════════════════════════════════════════ */

/* Three-number score row (e.g. Mechanics / Power / Performance) */
.pel-score-trio {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  text-align: center;
  padding: 18px 0 6px;
}

.pel-score-trio__value {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 1;
  color: var(--pel-navy);
}

.pel-score-trio__label {
  font-size: 11px;
  color: var(--pel-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  font-weight: 600;
  margin-top: 6px;
}

/* Colored-swatch legend (donut-chart companion) */
.pel-legend {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.pel-legend__item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--pel-text-secondary);
}

.pel-legend__swatch {
  width: 12px;
  height: 12px;
  border-radius: 2px;
  flex-shrink: 0;
}

/* Checklist-style list with icon-circle + progress bar + caption */
.pel-checklist {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.pel-checklist__item {
  display: grid;
  grid-template-columns: 32px 1fr 32px 32px;
  gap: 14px;
  align-items: center;
  padding: 8px;
}

.pel-checklist__icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--pel-surface);
  border: 2px solid var(--pel-border);
  font-size: 18px;
  color: var(--pel-navy);
  position: relative;
  flex-shrink: 0;
}

.pel-checklist__icon--ok {
  background: var(--pel-accent);
  border-color: var(--pel-accent);
}

.pel-checklist__icon--warn {
  background: var(--pel-surface);
  border-color: var(--pel-orange);
}

.pel-checklist__warn-dot {
  display: none;
  color: var(--pel-orange);
  font-size: 14px;
  line-height: 1;
  background: #fff;
  border-radius: 50%;
  padding: 1px;
}

.pel-checklist__icon--warn .pel-checklist__warn-dot {
  display: block;
}

.pel-checklist__body {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.pel-checklist__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.pel-checklist__title {
  font-weight: 700;
  font-size: 14px;
  color: var(--pel-text);
}

.pel-checklist__meta {
  display: flex;
  align-items: center;
  text-align: right;
  justify-content: space-between;
  font-size: 12px;
  color: var(--pel-text-muted);
}

.pel-checklist__chevron {
  font-size: 14px;
  color: var(--pel-text-muted);
  text-align: right;
}

/* Thin progress track + fill (reusable) */
.pel-progress {
  height: 10px;
  background: var(--pel-surface-alt);
  border-radius: 3px;
  overflow: hidden;
}

.pel-progress__fill {
  height: 100%;
  border-radius: 3px;
  background: var(--pel-accent);
  transition: width 0.3s ease;
}

.pel-progress__fill--warn {
  background: var(--pel-orange);
}

/* Inline-chart layout (chart + legend side-by-side) */
.pel-chart-inline {
  display: flex;
  align-items: center;
  gap: 16px;
}

.pel-chart-inline__chart {
  flex: 1 1 50%;
  min-width: 0;
}

.pel-chart-inline__side {
  flex: 0 0 auto;
}

/* Small muted caption beneath a chart */
.pel-card__caption {
  text-align: center;
  font-size: 13px;
  color: var(--pel-text-muted);
  margin-top: 10px;
}

/* Tip strip below content (e.g. "Add missing data to unlock …") */
.pel-tip-strip {
  background: var(--pel-surface);
  color: var(--pel-text-secondary);
  font-size: 11px;
  font-weight: 600;
  padding: 8px 14px;
  border-radius: 10px;
  text-align: center;
  margin-top: 16px;
}

/* CSS-only hover tooltip — wrap content in <span class="pel-tip" data-tip="..."> */
.pel-tip {
  position: relative;
  border-bottom: 2px dashed #d6d5d5;
  cursor: help;
}

.pel-tip::after {
  content: attr(data-tip);
  position: absolute;
  left: 50%;
  bottom: calc(100% + 8px);
  transform: translateX(-50%);
  background: var(--pel-navy, #152238);
  color: #fff;
  font-family: 'avenir next condensed', sans-serif;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.35;
  padding: 6px 10px;
  border-radius: 6px;
  white-space: normal;
  width: max-content;
  max-width: 240px;
  text-align: center;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.15s ease, visibility 0.15s ease;
  z-index: 1000;
}

.pel-tip::before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: calc(100% + 2px);
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: var(--pel-navy, #152238);
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.15s ease, visibility 0.15s ease;
  z-index: 1000;
}

.pel-tip:hover::after,
.pel-tip:focus::after,
.pel-tip:hover::before,
.pel-tip:focus::before {
  opacity: 1;
  visibility: visible;
}


/* ═══════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════ */
.pel-btn {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 12px;
  font-weight: 600;
  border-radius: 4px;
  padding: 6px 18px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  transition: all 0.15s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  line-height: 1.4;
  background: var(--pel-light);
  color: var(--pel-navy);
}

.pel-btn--no-outline {
  color: var(--pel-navy);
  background: transparent;
  border: none;
}

.pel-btn--outline {
  color: var(--pel-navy);
  border: 1.5px solid var(--pel-navy);
  background: transparent;
}

.pel-btn--outline:hover {
  background: var(--pel-navy);
  color: #fff;
}

.pel-btn--accent {
  color: var(--pel-navy);
  border: 1.5px solid var(--pel-accent);
  background: transparent;
  font-size: 14px;
  padding: 8px 24px;
}

.pel-btn--accent:hover {
  background: var(--pel-accent);
  color: var(--pel-navy);
}

.pel-btn--filled {
  color: var(--pel-dark);
  background: var(--pel-accent);
  border: 1.5px solid var(--pel-accent);
}

.pel-btn--filled:hover {
  background: var(--pel-accent-dim);
  border-color: var(--pel-accent-dim);
}

.pel-btn--sm {
  font-size: 10px;
  padding: 5px 14px;
  white-space: nowrap;
}

.pel-btn--dark {
  color: #fff;
  background: var(--pel-dark);
  border: 1.5px solid var(--pel-dark);
}

.pel-btn--dark:hover {
  background: #1a1c1d;
  border-color: #1a1c1d;
}

.pel-btn--warning {
  color: #9A2020;
}


/* ═══════════════════════════════════════════════════════
   VIDEO PLAYER (Mechanics page)
   ═══════════════════════════════════════════════════════ */
.pel-video-wrap {
  border-radius: 10px;
  overflow: hidden;
  background: #0A0A0A;
  position: relative;
  aspect-ratio: 16/9;
}

.pel-video-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
}

.pel-video-top {
  background: rgba(0, 0, 0, 0.7);
  padding: 12px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  backdrop-filter: blur(4px);
}

.pel-video-controls {
  background: rgba(0, 0, 0, 0.75);
  padding: 12px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  backdrop-filter: blur(4px);
}

.pel-video-body {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}


/* ═══════════════════════════════════════════════════════
   UTILITY CLASSES
   ═══════════════════════════════════════════════════════ */
.pel-text-muted { color: var(--pel-text-muted); }
.pel-text-secondary { color: var(--pel-text-secondary); }
.pel-text-accent { color: var(--pel-accent); }
.pel-text-navy { color: var(--pel-navy); }
.pel-text-white { color: #fff; }

.pel-mb-0 { margin-bottom: 0; }
.pel-mb-1 { margin-bottom: 8px; }
.pel-mb-2 { margin-bottom: 16px; }
.pel-mb-3 { margin-bottom: 24px; }
.pel-mt-1 { margin-top: 8px; }
.pel-mt-2 { margin-top: 16px; }
.pel-mt-3 { margin-top: 24px; }

.pel-text-center { text-align: center; }
.pel-text-right { text-align: right; }
.pel-text-uppercase { text-transform: uppercase; }

.pel-hidden { display: none; }

/* Screen reader only (accessible hidden text) */
.pel-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}


/* ═══════════════════════════════════════════════════════
   ORG HERO — Organization profile header
   (reusable across all organization tabs)
   ═══════════════════════════════════════════════════════ */
.pel-org-hero__inner {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 24px;
  align-items: center;
}

.pel-org-hero__icon {
  width: 76px;
  height: 76px;
  border-radius: 14px;
  background: var(--pel-light);
  border: 2.5px solid var(--pel-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}

.pel-org-hero__icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pel-org-hero__icon svg {
  width: 36px;
  height: 36px;
}

.pel-org-hero__info {
  flex: 1;
}

.pel-org-hero__name {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin: 0;
}

.pel-org-hero__sub {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.4);
  margin-top: 4px;
}

/* Stat cards in hero */
.pel-org-hero__stats {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
  flex-shrink: 0;
}

.pel-org-stat {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--pel-radius-sm);
  padding: 10px 20px;
  text-align: center;
  min-width: 110px;
  transition: background 0.15s;
}

.pel-org-stat:hover {
  background: rgba(255, 255, 255, 0.09);
}

.pel-org-stat__value {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 28px;
  font-weight: 700;
  color: #fff;
  line-height: 1;
}

.pel-org-stat__label {
  font-size: 10px;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  font-weight: 600;
  margin-top: 4px;
}

/* Hero action button (ghost on dark hero bg) */
.pel-hero-action {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 6px;
  padding: 7px 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.pel-hero-action:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.3);
  color: #fff;
}

.pel-hero-action i {
  font-size: 11px;
}

/* Inline pill next to hero name (e.g. Demo, status) */
.pel-hero-name-pill {
  display: inline-block;
  font-family: avenir next condensed, 'Avenir Next Condensed', Arial, sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 999px;
  vertical-align: middle;
  margin-left: 10px;
  position: relative;
  top: -4px;
}

.pel-hero-name-pill--accent {
  background: var(--pel-accent);
  color: var(--pel-navy);
}

.pel-hero-name-pill--muted {
  background: rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(255, 255, 255, 0.18);
}


/* ═══════════════════════════════════════════════════════
   CONTROLS — Filter bar (reusable)
   ═══════════════════════════════════════════════════════ */
.pel-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.pel-controls__label {
  font-size: 13px;
  color: var(--pel-text-secondary);
  white-space: nowrap;
  font-weight: 500;
}

.pel-controls__input {
  font-family: 'avenir next condensed', 'Avenir Next Condensed', Arial, sans-serif;
  font-size: 13px;
  padding: 0 12px;
  border: 1px solid var(--pel-border);
  border-radius: 4px;
  height: 32px;
  background: #fff;
  color: var(--pel-text);
  transition: border-color 0.15s;
}

.pel-controls__input:focus {
  outline: none;
  border-color: var(--pel-blue);
}

.pel-controls__select {
  font-family: 'avenir next condensed', 'Avenir Next Condensed', Arial, sans-serif;
  font-size: 13px;
  padding: 0 10px;
  border: 1px solid var(--pel-border);
  border-radius: 4px;
  height: 32px;
  background: #fff;
  color: var(--pel-text);
}

.pel-controls__spacer {
  margin-left: auto;
}


/* ═══════════════════════════════════════════════════════
   TABLES — Reusable data tables
   ═══════════════════════════════════════════════════════ */
.pel-table-wrap {
  background: var(--pel-card);
  border: 0.5px solid var(--pel-border);
  border-radius: 10px;
  overflow: hidden;
}

.pel-table {
  border-collapse: collapse;
  width: 100%;
  background: var(--pel-card)
}

.pel-table th {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: var(--pel-text-muted);
  text-align: left;
  padding: 12px 16px;
  border-bottom: 1px solid var(--pel-border);
  background: var(--pel-surface-alt);
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.pel-table__no-border th {
  border-bottom: none;
}

.pel-table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--pel-surface);
  vertical-align: middle;
  font-size: 14px;
}

.pel-table__no-border td {
  border-bottom: none;
}

.pel-table tbody tr:last-child td {
  border-bottom: none;
}

.pel-table tbody tr {
  transition: background 0.1s;
}

.pel-table tbody tr:hover td {
  background: var(--pel-surface);
}

/* Opt-in row affordance: pairs the inherited hover highlight above with a
   pointer cursor for tables whose rows navigate on click. The click handler
   itself is wired per-page (it must skip interactive cells). */
.pel-table--clickable tbody tr {
  cursor: pointer;
}

.pel-table__name {
  font-weight: 600;
  color: var(--pel-blue);
  font-size: 14px;
}


.pel-table__sub {
  font-size: 12px;
  color: var(--pel-text-muted);
  margin-top: 2px;
}


/* ═══════════════════════════════════════════════════════
   PILLS — Status & category indicators
   ═══════════════════════════════════════════════════════ */
.pel-pill {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
  letter-spacing: 0.3px;
}

.pel-pill--blue  { background: #e6f1fb; color: #0c447c; }
.pel-pill--green { background: var(--pel-accent-bg-med); color: #27500a; }
.pel-pill--amber { background: #faeeda; color: #633806; }
.pel-pill--red   { background: rgba(204, 0, 0, 0.08); color: #8c0000; }
.pel-pill--gray  { background: var(--pel-light-gray); color: var(--pel-text-secondary); }
.pel-pill--muted { background: var(--pel-surface); color: var(--pel-mid-gray); }

/* Inline send/resend status indicators (e.g. "Sent ✓" after a Resend
 * button click, or the bulk-send summary toast). Compact, no border. */
.pel-resend-status { font-size: 12px; margin-left: 4px; }
.pel-resend-status--ok  { color: #0a8b32; }
.pel-resend-status--err { color: #b00020; }

/* Borderless icon button — wraps an <i class="mdi mdi-…"> glyph.
 * Use for low-prominence row-level actions that should sit beside a
 * pel-pill without competing for visual weight (e.g. send/resend
 * invitation, inline edit). Always pair with aria-label + title for
 * accessibility, since the icon carries no text label. */
.pel-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  margin-left: 4px;
  padding: 0;
  border: 0;
  border-radius: 4px;
  background: transparent;
  color: var(--pel-text-secondary);
  cursor: pointer;
  vertical-align: middle;
  transition: background-color 0.12s, color 0.12s;
}
.pel-icon-btn .mdi { font-size: 16px; line-height: 1; }
.pel-icon-btn:hover { background: var(--pel-light-gray); color: var(--pel-dark); }
.pel-icon-btn:focus-visible {
  outline: 2px solid var(--pel-accent);
  outline-offset: 1px;
}
.pel-icon-btn:disabled { opacity: 0.4; cursor: not-allowed; }

.pel-pills-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.pel-no-val {
  font-size: 12px;
  color: var(--pel-mid-gray);
  font-style: italic;
}


/* ═══════════════════════════════════════════════════════
   AVATAR (small, for table rows)
   ═══════════════════════════════════════════════════════ */
.pel-avatar-sm {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(39, 76, 119, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}


/* ═══════════════════════════════════════════════════════
   SECTION TOGGLE (for tabbed content)
   ═══════════════════════════════════════════════════════ */
.pel-section {
  display: none;
}

.pel-section.active {
  display: block;
}


/* ═══════════════════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════════════════ */
.pel-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(21, 34, 56, 0.55);
  z-index: 200;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(4px);
}

.pel-overlay.open {
  display: flex;
}

.pel-modal {
  background: var(--pel-card);
  border-radius: var(--pel-radius);
  border: 0.5px solid var(--pel-border);
  width: 100%;
  max-width: 460px;
  overflow: hidden;
  margin: 1rem;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.2);
}

.pel-modal--wide {
  max-width: 580px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
}

.pel-modal--chart {
  max-width: 860px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
}

.pel-modal__header {
  background: var(--pel-navy);
  padding: 14px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}

.pel-modal__logo {
  font-family: sol-pro, sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: #fff;
  letter-spacing: 2.5px;
  font-style: italic;
  text-transform: uppercase;
}

.pel-modal__close {
  color: rgba(255, 255, 255, 0.5);
  font-size: 18px;
  cursor: pointer;
  background: none;
  border: none;
  line-height: 1;
  transition: color 0.15s;
}

.pel-modal__close:hover {
  color: #fff;
}

.pel-modal__body {
  padding: 20px 24px 24px;
  overflow-y: auto;
  min-height: 0;
}

.pel-modal__title {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 17px;
  font-weight: 700;
  color: var(--pel-text);
  margin-bottom: 8px;
}

.pel-modal__subtitle {
  font-size: 13px;
  color: var(--pel-text-muted);
  margin-bottom: 24px;
}

.pel-modal__action-row {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.pel-modal__action-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  border: 1px solid var(--pel-border);
  border-radius: 8px;
  transition: background 0.1s;
}

.pel-modal__action-item:hover {
  background: var(--pel-surface);
}

.pel-modal__action-left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.pel-modal__action-icon {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.pel-modal__action-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--pel-text);
}

.pel-modal__action-desc {
  font-size: 12px;
  color: var(--pel-text-muted);
  margin-top: 1px;
}

.pel-modal__btn-copy {
  background: var(--pel-dark);
  color: var(--pel-accent);
  border: none;
  border-radius: 6px;
  padding: 6px 14px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: background 0.15s;
}

.pel-modal__btn-copy:hover {
  background: #1a1c1d;
}

.pel-modal__btn-dl {
  background: var(--pel-blue);
  color: #e6f1fb;
  border: none;
  border-radius: 6px;
  padding: 6px 14px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: background 0.15s;
}

.pel-modal__btn-dl:hover {
  background: #1d3d60;
}

.pel-modal__footer {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--pel-border);
}


/* ═══════════════════════════════════════════════════════
   PERMISSIONS — Toggle switches and rows
   ═══════════════════════════════════════════════════════ */
.pel-perm-label {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 10px;
  font-weight: 700;
  color: var(--pel-text-muted);
  letter-spacing: 0.8px;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.pel-perm-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid var(--pel-surface);
}

.pel-perm-row:last-of-type {
  border-bottom: none;
}

.pel-perm-text {
  font-size: 14px;
  color: var(--pel-text);
}

.pel-toggle {
  width: 36px;
  height: 20px;
  border-radius: 10px;
  background: var(--pel-border);
  position: relative;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.15s;
}

/* Reflect the real checkbox state — the hidden <input> is the source of truth,
   toggled natively by its wrapping <label>. (.on kept for any non-checkbox uses.) */
.pel-toggle.on,
.pel-perm-row input:checked + .pel-toggle {
  background: var(--pel-dark);
}

.pel-toggle::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: white;
  top: 2px;
  left: 2px;
  transition: left 0.15s;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
}

.pel-toggle.on::after,
.pel-perm-row input:checked + .pel-toggle::after {
  left: 18px;
}


/* ═══════════════════════════════════════════════════════
   SERVICE FORM — shared by New Service + Edit Service modals
   ═══════════════════════════════════════════════════════ */
.ns-field { margin-bottom: 24px; }
.ns-label {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--pel-text-secondary);
  margin-bottom: 8px;
}
.ns-input {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--pel-border);
  border-radius: var(--pel-radius-sm);
  font-family: 'avenir next condensed', Arial, sans-serif;
  font-size: 14px;
  color: var(--pel-text);
  background: #fff;
  transition: border-color 0.15s;
}
.ns-input:focus { outline: none; border-color: var(--pel-blue); }
.ns-payer-card {
  flex: 1;
  border: 1px solid var(--pel-border);
  border-radius: 8px;
  padding: 14px 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: border-color 0.15s;
}
.ns-payer-card.selected { border-color: var(--pel-dark); }
.ns-radio {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid var(--pel-mid-gray);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ns-data-pill {
  padding: 7px 16px;
  border: 1px solid var(--pel-border);
  border-radius: 20px;
  background: #fff;
  color: var(--pel-text);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.15s;
  font-family: 'avenir next condensed', Arial, sans-serif;
}
.ns-data-pill.on {
  background: var(--pel-dark);
  color: var(--pel-accent);
  border-color: var(--pel-dark);
}
.ns-divider {
  border: none;
  border-top: 1px solid var(--pel-border);
  margin: 0 0 24px;
}

/* ═══════════════════════════════════════════════════════
   PEL-COMBO — Reusable textbox-style multi-select with chips.
   See app_web/static/app_web/js/pel-combo.js for behavior.
   ═══════════════════════════════════════════════════════ */
.pel-combo { position: relative; }

.pel-combo__control {
  width: 100%;
  min-height: 44px;
  padding: 6px 34px 6px 8px;
  border: 1px solid var(--pel-border);
  border-radius: var(--pel-radius-sm);
  background: #fff;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  cursor: text;
  transition: border-color 0.15s;
}
.pel-combo__control:focus-within,
.pel-combo.is-open > .pel-combo__control { border-color: var(--pel-blue); outline: none; }

.pel-combo__placeholder {
  font-family: 'avenir next condensed', Arial, sans-serif;
  font-size: 13px;
  color: var(--pel-text-muted);
  padding: 4px 2px;
}

.pel-combo__pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 6px 2px 10px;
  background: var(--pel-blue);
  color: var(--pel-light);
  border-radius: 14px;
  font-family: 'avenir next condensed', Arial, sans-serif;
  font-size: 13px;
  line-height: 1;
}
.pel-combo__pill-x {
  background: none;
  border: none;
  color: var(--pel-accent);
  opacity: 0.7;
  font-size: 14px;
  line-height: 1;
  padding: 2px 4px;
  cursor: pointer;
  border-radius: 50%;
}
.pel-combo__pill-x:hover { opacity: 1; background: rgba(255, 255, 255, 0.12); }

.pel-combo__caret {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--pel-text-muted);
  pointer-events: none;
  font-size: 10px;
}

.pel-combo__menu {
  display: none;
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 4px);
  background: #fff;
  border: 1px solid var(--pel-border);
  border-radius: var(--pel-radius-sm);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  max-height: 220px;
  overflow-y: auto;
  z-index: 20;
}
.pel-combo.is-open > .pel-combo__menu { display: block; }

.pel-combo__option {
  padding: 9px 12px;
  font-family: 'avenir next condensed', Arial, sans-serif;
  font-size: 14px;
  color: var(--pel-text);
  cursor: pointer;
}
.pel-combo__option:hover,
.pel-combo__option.is-focused { background: var(--pel-surface); }

.pel-combo__empty {
  padding: 12px;
  font-size: 13px;
  color: var(--pel-text-muted);
  text-align: center;
}


/* ═══════════════════════════════════════════════════════
   TOAST NOTIFICATION
   ═══════════════════════════════════════════════════════ */
.pel-toast {
  display: none;
  font-size: 13px;
  padding: 8px 16px;
  border-radius: 6px;
  margin-top: 12px;
  text-align: center;
  background: var(--pel-dark);
  color: var(--pel-accent);
  font-weight: 600;
}


/* ═══════════════════════════════════════════════════════
   HEADER SLOTS & CONTEXT SWITCHER
   ═══════════════════════════════════════════════════════ */

/* ── Shared slot wrapper — positions dropdowns relative to their button ── */
.pel-header-slot {
  position: relative;
  display: flex;
  align-items: center;
}

/* ── Topbar layout updates ── */
.pel-topbar__sep {
  width: 1px;
  height: 24px;
  background: rgba(255, 255, 255, 0.15);
  margin: 0 16px;
  flex-shrink: 0;
}

.pel-topbar__breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.5);
}

.pel-topbar__breadcrumb a {
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
}

.pel-topbar__breadcrumb a:hover {
  color: #fff;
}

.pel-topbar__tabs {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: 8px;
}

.pel-topbar__spacer {
  flex: 1;
}

/* ── Context switcher button ── */
.pel-ctx {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  height: 36px;
  padding: 0 10px;
  border-radius: var(--pel-radius-sm);
  transition: background 0.15s;
}

.pel-ctx:hover {
  background: rgba(255, 255, 255, 0.08);
}

.pel-ctx--link {
  text-decoration: none;
}

.pel-ctx__name {
  color: rgba(255, 255, 255, 0.85);
  font-size: 14px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 200px;
}

.pel-ctx__badge {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 2px 8px;
  border-radius: 999px;
  white-space: nowrap;
  text-transform: capitalize;
}

.pel-ctx__badge--coach {
  color: var(--pel-accent);
  background: rgba(214, 239, 103, 0.15);
}

.pel-ctx__badge--parent {
  color: var(--pel-orange);
  background: rgba(241, 154, 57, 0.15);
}

.pel-ctx__badge--athlete {
  color: #6ba3d6;
  background: rgba(39, 76, 119, 0.25);
}

.pel-ctx__chev {
  color: rgba(255, 255, 255, 0.4);
  font-size: 13px;
  transition: transform 0.15s;
}

.pel-ctx__chev--flip {
  transform: rotate(180deg);
}

/* ── Context dropdown ── */
.pel-ctx-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 9px);
  left: 0;
  min-width: 280px;
  background: var(--pel-card);
  border: 1px solid var(--pel-light-gray);
  border-radius: var(--pel-radius);
  padding: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  z-index: 1001;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 0.15s, transform 0.15s;
}

.pel-ctx-dropdown--open {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

.pel-ctx-dropdown__section {
  padding: 4px 0;
}

.pel-ctx-dropdown__label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--pel-mid-gray);
  padding: 4px 8px 6px;
}

.pel-ctx-dropdown__divider {
  border: none;
  border-top: 1px solid var(--pel-light-gray);
  margin: 4px 0;
}

.pel-ctx-dropdown__item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 44px;
  padding: 6px 8px;
  border: none;
  background: none;
  border-radius: 8px;
  cursor: pointer;
  font-family: inherit;
  font-size: 14px;
  text-align: left;
  color: var(--pel-text);
  transition: background 0.12s;
}

.pel-ctx-dropdown__item:hover {
  background: var(--pel-light-gray);
}

.pel-ctx-dropdown__item--active {
  background: var(--pel-accent-bg);
}

.pel-ctx-dropdown__icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  flex-shrink: 0;
}

.pel-ctx-dropdown__icon--coach {
  color: var(--pel-accent-dim);
  background: rgba(214, 239, 103, 0.18);
}

.pel-ctx-dropdown__icon--parent {
  color: var(--pel-orange);
  background: rgba(241, 154, 57, 0.15);
}

.pel-ctx-dropdown__icon--athlete {
  color: var(--pel-blue);
  background: rgba(39, 76, 119, 0.12);
}

.pel-ctx-dropdown__info {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
}

.pel-ctx-dropdown__name {
  font-weight: 600;
  font-size: 14px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pel-ctx-dropdown__sub {
  font-size: 12px;
  color: var(--pel-text-muted);
}

.pel-ctx-dropdown__check {
  color: var(--pel-accent-dim);
  font-size: 14px;
  flex-shrink: 0;
}

/* ── User menu ── */
.pel-user {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  height: 36px;
  padding: 0 8px;
  border-radius: var(--pel-radius-sm);
  transition: background 0.15s;
}

.pel-user:hover {
  background: rgba(255, 255, 255, 0.08);
}

.pel-user__avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--pel-blue);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}

.pel-user__avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pel-user__initials {
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.pel-user__name {
  color: rgba(255, 255, 255, 0.7);
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
}

.pel-user__chev {
  color: rgba(255, 255, 255, 0.4);
  font-size: 10px;
  transition: transform 0.15s;
}

.pel-user__chev--flip {
  transform: rotate(180deg);
}

.pel-user-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 9px);
  right: 0;
  width: 200px;
  background: var(--pel-card);
  border: 1px solid var(--pel-light-gray);
  border-radius: var(--pel-radius);
  padding: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  z-index: 1001;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 0.15s, transform 0.15s;
}

.pel-user-dropdown--open {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

.pel-user-dropdown__item {
  display: block;
  width: 100%;
  min-height: 36px;
  padding: 8px 12px;
  border: none;
  background: none;
  border-radius: 8px;
  cursor: pointer;
  font-family: inherit;
  font-size: 14px;
  text-align: left;
  color: var(--pel-text);
  text-decoration: none;
  transition: background 0.12s;
}

.pel-user-dropdown__item:hover {
  background: var(--pel-light-gray);
  text-decoration: none;
  color: var(--pel-text);
}

.pel-user-dropdown__item--danger {
  color: #c0392b;
}

.pel-user-dropdown__item--danger:hover {
  color: #c0392b;
  background: rgba(192, 57, 43, 0.08);
}

.pel-user-dropdown__divider {
  border: none;
  border-top: 1px solid var(--pel-light-gray);
  margin: 4px 0;
}

/* ── Admin menu ── */
.pel-admin {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  height: 36px;
  padding: 0 8px;
  border-radius: var(--pel-radius-sm);
  transition: background 0.15s;
}

.pel-admin:hover {
  background: rgba(255, 255, 255, 0.08);
}

.pel-admin__label {
  color: rgba(255, 255, 255, 0.5);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.3px;
}

.pel-admin__chev {
  color: rgba(255, 255, 255, 0.4);
  font-size: 10px;
  transition: transform 0.15s;
}

.pel-admin__chev--flip {
  transform: rotate(180deg);
}

.pel-admin-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 9px);
  right: 0;
  width: 220px;
  background: var(--pel-card);
  border: 1px solid var(--pel-light-gray);
  border-radius: var(--pel-radius);
  padding: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  z-index: 1001;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 0.15s, transform 0.15s;
  max-height: 70vh;
  overflow-y: auto;
}

.pel-admin-dropdown--open {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

.pel-admin-dropdown__item {
  display: block;
  width: 100%;
  min-height: 36px;
  padding: 8px 12px;
  border-radius: 8px;
  font-family: inherit;
  font-size: 14px;
  text-align: left;
  color: var(--pel-text);
  text-decoration: none;
  transition: background 0.12s;
}

.pel-admin-dropdown__item:hover {
  background: var(--pel-light-gray);
  text-decoration: none;
  color: var(--pel-text);
}

.pel-admin-dropdown__divider {
  border: none;
  border-top: 1px solid var(--pel-light-gray);
  margin: 4px 0;
}

/* ── Global header search (superuser) ── */
.pel-search {
  position: relative;
  display: flex;
  align-items: center;
  margin-right: 16px;
}

.pel-search__icon {
  position: absolute;
  left: 11px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.4);
  pointer-events: none;
}

.pel-search__input {
  font-family: 'avenir next condensed', 'Avenir Next Condensed', Arial, sans-serif;
  font-size: 13px;
  height: 32px;
  width: 210px;
  padding: 0 12px 0 30px;
  border-radius: var(--pel-radius-sm);
  border: 1px solid rgba(255, 255, 255, 0.15);
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  transition: width 0.15s, background 0.15s, border-color 0.15s;
}

.pel-search__input::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

/* Stay widened while focused OR while the results panel is open, so moving
   the mouse off the input to click a result doesn't snap the box shut. */
.pel-search__input:focus,
.pel-search--open .pel-search__input {
  outline: none;
  width: 300px;
  background: rgba(255, 255, 255, 0.14);
  border-color: var(--pel-accent);
}

.pel-search__panel {
  display: none;
  position: absolute;
  top: calc(100% + 9px);
  left: 0;
  width: 340px;
  max-height: 70vh;
  overflow-y: auto;
  background: var(--pel-card);
  border: 1px solid var(--pel-light-gray);
  border-radius: var(--pel-radius);
  padding: 6px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  z-index: 1001;
}

.pel-search--open .pel-search__panel {
  display: block;
}

.pel-search__group {
  padding: 4px 0;
}

.pel-search__group + .pel-search__group {
  border-top: 1px solid var(--pel-light-gray);
  margin-top: 4px;
}

.pel-search__group-label {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--pel-mid-gray);
  padding: 4px 10px 6px;
}

.pel-search__item {
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding: 6px 10px;
  border-radius: 8px;
  text-decoration: none;
  color: var(--pel-text);
  transition: background 0.12s;
}

.pel-search__item:hover {
  background: var(--pel-light-gray);
  text-decoration: none;
  color: var(--pel-text);
}

.pel-search__item-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--pel-blue);
}

.pel-search__item-meta {
  font-size: 12px;
  color: var(--pel-text-muted);
}

.pel-search__hint {
  padding: 12px 10px;
  font-size: 13px;
  text-align: center;
  color: var(--pel-text-muted);
}

/* ── Breadcrumb separator ── */
.pel-topbar__breadcrumb-sep {
  color: #666;
  margin: 0 6px;
}


/* ═══════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .pel-page {
    padding: 16px 8px;
  }

  .pel-topbar {
    padding: 0 16px;
    border-radius: 0;
  }

  .pel-topbar__nav {
    display: none; /* Use mobile menu instead */
  }

  .pel-topbar__breadcrumb,
  .pel-topbar__tabs,
  .pel-search {
    display: none;
  }

  .pel-topbar__sep {
    margin: 0 8px;
  }

  .pel-ctx__name {
    max-width: 120px;
  }

  .pel-user__name {
    display: none;
  }

  .pel-ctx-dropdown {
    left: 16px;
    width: calc(100vw - 32px);
    min-width: unset;
  }

  .pel-user-dropdown {
    right: 16px;
  }

  .pel-ctx-dropdown__item,
  .pel-user-dropdown__item {
    min-height: 44px;
  }

  .pel-hero {
    padding: 20px 16px 0;
  }

  .pel-hero__inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .pel-hero__name {
    font-size: 24px;
  }

  .pel-hero__stats {
    justify-content: center;
  }

  .pel-hero__tags {
    justify-content: center;
  }

  .pel-hero__status {
    margin-left: 0;
    margin-top: 16px;
  }

  .pel-tabs {
    padding: 0 16px;
  }

  .pel-tabs__item {
    font-size: 13px;
    padding: 12px 10px;
  }

  .pel-subtabs {
    padding: 0 16px;
  }

  .pel-subtabs__item {
    font-size: 12px;
    padding: 9px 10px 8px;
  }

  .pel-body {
    padding: 20px 16px;
    border-radius: 0 0 var(--pel-radius) var(--pel-radius);
  }

  .pel-grid-2 {
    grid-template-columns: 1fr;
  }

  .pel-grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }

  .pel-grid-5-7,
  .pel-grid-7-5 {
    grid-template-columns: 1fr;
  }

  .pel-metrics {
    grid-template-columns: 1fr;
  }

  .pel-metrics__overall {
    border-right: none;
    border-bottom: 0.5px solid var(--pel-border);
    padding-right: 0;
    padding-bottom: 16px;
  }

  .pel-metrics__row {
    grid-template-columns: 80px 1fr 28px 48px;
    gap: 8px;
  }

  .pel-org-hero {
    padding: 20px 16px 0;
  }

  .pel-org-hero__inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .pel-org-hero__name {
    font-size: 24px;
  }

  .pel-org-hero__stats {
    margin-left: 0;
    margin-top: 16px;
    flex-wrap: wrap;
    justify-content: center;
  }

  .pel-controls {
    flex-direction: column;
    align-items: stretch;
  }

  .pel-controls__spacer {
    margin-left: 0;
  }
}

.pel-modal__footer--left {
  justify-content: flex-start;
}

.pel-card__header--stack {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}

.ns-input--readonly {
  background-color: #f4f4f4;
  color: #777;
  cursor: not-allowed;
  border: 1px solid var(--pel-border);
}
label:hover .avatar-overlay {
  opacity: 1;
}
@media (min-width: 769px) and (max-width: 1023px) {
  .pel-ctx__name {
    max-width: 160px;
  }
}


/* ═══════════════════════════════════════════════════════
   PEL-INLINE-TABS — In-section toggle (e.g. Below | Exceeds)
   Distinct from .pel-subtabs (dark navy hitting nav used by
   athlete_base) — this is a lightweight inline-link variant.
   ═══════════════════════════════════════════════════════ */
.pel-inline-tabs {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  font-family: 'avenir next condensed', Arial, sans-serif;
}
.pel-inline-tabs__item {
  font-family: inherit;
  font-size: 14px;
  color: var(--pel-text-muted);
  cursor: pointer;
  padding: 2px 0;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  transition: color 0.15s, border-color 0.15s;
}
.pel-inline-tabs__item:hover { color: var(--pel-text); }
.pel-inline-tabs__item:focus-visible {
  outline: 2px solid var(--pel-accent);
  outline-offset: 2px;
}
.pel-inline-tabs__item.active {
  color: var(--pel-text);
  font-weight: 700;
  border-bottom-color: var(--pel-accent);
}
.pel-inline-tabs__sep {
  color: var(--pel-border);
  user-select: none;
}


/* ═══════════════════════════════════════════════════════
   PEL-DROP — File drag/drop area (video upload modal)
   ═══════════════════════════════════════════════════════ */
.pel-drop {
  border: 1px dashed var(--pel-border);
  border-radius: 10px;
  padding: 22px 16px;
  text-align: center;
  background: var(--pel-surface);
  color: var(--pel-text-muted);
  font-size: 13px;
  transition: border-color 0.15s, background 0.15s;
}
.pel-drop.is-over {
  border-color: var(--pel-accent);
  background: var(--pel-accent-bg);
  color: var(--pel-text);
}
.pel-drop__file {
  margin-top: 8px;
  color: var(--pel-text);
  font-weight: 600;
  font-size: 13px;
}


/* ═══════════════════════════════════════════════════════
   PEL-FIELD — Reusable form field (label + input/select)
   ═══════════════════════════════════════════════════════ */
.pel-field { margin-bottom: 14px; }
.pel-field__label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--pel-text-secondary);
  margin-bottom: 6px;
}
.pel-field__input,
.pel-field__select {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--pel-border);
  border-radius: var(--pel-radius-sm);
  font-family: 'avenir next condensed', Arial, sans-serif;
  font-size: 14px;
  color: var(--pel-text);
  background: #fff;
}
.pel-field__input:focus,
.pel-field__select:focus { outline: none; border-color: var(--pel-blue); }
.pel-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 14px;
}
.pel-field__textarea {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--pel-border);
  border-radius: var(--pel-radius-sm);
  font-family: 'avenir next condensed', Arial, sans-serif;
  font-size: 14px;
  color: var(--pel-text);
  background: #fff;
  min-height: 90px;
  resize: vertical;
}
.pel-field__textarea:focus { outline: none; border-color: var(--pel-blue); }
.pel-field__error {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  color: #9A2020;
}
.pel-field__input:disabled,
.pel-field__select:disabled,
.pel-field__textarea:disabled {
  background: var(--pel-surface, #f7f7f5);
  color: var(--pel-text-secondary);
  cursor: not-allowed;
}
.pel-form-errors {
  background: #fdf0f0;
  color: #8a1f1f;
  border: 1px solid #f5c2c2;
  border-radius: 6px;
  padding: 10px 12px;
  font-size: 13px;
  margin-bottom: 12px;
}
.pel-form-errors ul { margin: 0; padding-left: 18px; }
.pel-form-footer {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 16px;
}


/* ═══════════════════════════════════════════════════════
   ACTION ITEMS PAGE — service action items tab
   ═══════════════════════════════════════════════════════ */
.pel-ai-section { margin-bottom: 32px; }
.pel-ai-section:last-child { margin-bottom: 0; }
.pel-ai-section-title {
  font-family: sol-pro, 'Sol Pro', Arial, sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--pel-text);
  margin: 0;
}
.pel-ai-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.pel-ai-section-head__left {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pel-ai-warning { color: var(--pel-orange, #b46e00); }
.pel-ai-progress-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 200px;
}
.pel-ai-progress-row .pel-progress { flex: 1; }
.pel-ai-progress-row__count {
  font-size: 13px;
  color: var(--pel-text-muted);
  white-space: nowrap;
  min-width: 56px;
  text-align: right;
}
.pel-modal__body p.pel-ai-modal-note {
  font-size: 13px;
  color: var(--pel-text-muted);
  margin: 0 0 14px;
}
.pel-ai-video-reqs {
  font-size: 12px;
  color: var(--pel-text-muted);
  margin-top: 14px;
}
.pel-ai-video-reqs ul { padding-left: 18px; margin: 6px 0; }
.pel-ai-video-warning {
  margin-top: 8px;
  font-size: 12px;
  color: #b4232c;
}

/* Action items inline tabs render as plain links rather than the
   default muted-text pattern. Active tab keeps the accent underline. */
.pel-ai-section .pel-inline-tabs__item { color: var(--pel-blue); }
.pel-ai-section .pel-inline-tabs__item:hover { text-decoration: underline; }
.pel-ai-section .pel-inline-tabs__item.active {
  color: var(--pel-text);
  font-weight: 700;
}
.pel-ai-section .pel-inline-tabs__item.active:hover { text-decoration: none; }


.pel-switch {
  position: relative;
  display: inline-block;
  width: 38px;
  height: 22px;
}

.pel-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.pel-switch__slider {
  position: absolute;
  cursor: pointer;
  inset: 0;
  background-color: #d6d3cd;
  transition: .2s;
  border-radius: 999px;
}

.pel-switch__slider:before {
  position: absolute;
  content: "";
  height: 16px;
  width: 16px;
  left: 3px;
  top: 3px;
  background-color: white;
  transition: .2s;
  border-radius: 50%;
}

.pel-switch input:checked + .pel-switch__slider {
  background-color: #31363b;
}

.pel-switch input:checked + .pel-switch__slider:before {
  transform: translateX(16px);
}

.pel-score-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px 16px;
}

.pel-score-grid > div {
  width: calc(33.333% - 16px);
  text-align: center;
}