/* ==========================================================================
   Phase 2 screens: Login, Dashboard, My Learning, Streams, Quests
   ========================================================================== */

.flow-page {
  min-height: 100vh;
  display: grid;
  place-items: stretch;
  padding: var(--space-8);
  /* soft brand glow in the top corners; stops are gradient positions, colors
     stay token-driven */
  background:
    radial-gradient(circle at 88% -12%, var(--accent-tint) 0%, transparent 46%),
    radial-gradient(circle at -8% 108%, var(--accent-tint) 0%, transparent 38%),
    var(--bg);
}

.lesson-list {
  display: grid;
  gap: var(--space-3);
}

.field-label {
  display: grid;
  gap: var(--space-2);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
  font-weight: 600;
}

.field-input {
  width: 100%;
  min-height: var(--touch-target);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  color: var(--text-primary);
  transition: border-color var(--motion-duration-fast) var(--motion-ease-out),
              background-color var(--motion-duration-base) var(--motion-ease-standard),
              box-shadow var(--motion-duration-fast) var(--motion-ease-out);
}

.field-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 var(--focus-ring-width) var(--accent-tint);
}

.btn--pill {
  border-radius: var(--radius-pill);
}

button:disabled,
.btn:disabled {
  cursor: not-allowed;
  opacity: 0.55;
  transform: none;
}

/* --------------------------------------------------------------------------
   Login — logo + tagline, one focused corps-member card, theme switcher.
   -------------------------------------------------------------------------- */
.login-page {
  width: min(100%, 480px);
  justify-self: center;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: var(--space-6);
  min-height: calc(100vh - (var(--space-8) * 2));
  text-align: center;
}

.login-mark {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.login-panel {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: stretch;
  gap: var(--space-5);
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.login-option {
  display: grid;
  justify-items: center;
  align-content: center;
  gap: var(--space-3);
  padding: var(--space-6);
  border-radius: var(--radius-md);
  text-align: center;
  transition: background-color var(--motion-duration-fast) var(--motion-ease-out);
}

.login-option:hover,
.login-option:focus-visible {
  background: var(--surface-alt);
}

.metric-label,
.section-heading,
.module-card__top,
.stream-card__top,
.quest-card__top,
.quest-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.metric-label span {
  color: var(--text-secondary);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
}

.screen-panel,
.module-detail {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.xp-panel {
  display: grid;
  gap: var(--space-2);
}

.progress-fill {
  width: 0;
}

.quest-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--metric-card-min), 1fr));
  gap: var(--space-4);
}

.metric-card {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-5);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.section-heading--page {
  align-items: end;
}

.lesson-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: var(--space-3);
  align-items: center;
  width: 100%;
  padding: var(--space-3) 0;
  border-top: var(--border-width) dashed var(--border);
  text-align: left;
}

.lesson-row:first-child {
  border-top: 0;
}

.status-dot {
  width: var(--space-3);
  height: var(--space-3);
  border-radius: var(--radius-pill);
  background: var(--text-muted);
}

.status-dot--complete {
  background: var(--success);
}

.status-dot--in-progress {
  background: var(--warning);
}

.status-dot--not-started {
  background: var(--text-muted);
}

.learning-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--module-detail-width);
  gap: var(--space-5);
  align-items: start;
}

.module-list {
  display: grid;
  gap: var(--space-4);
}

.module-card,
.stream-card,
.quest-card {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-5);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  text-align: left;
  transition: transform var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out),
              background-color var(--motion-duration-base) var(--motion-ease-standard);
}

.module-card:hover,
.stream-card:hover,
.quest-card:hover {
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
  border-color: var(--border-strong);
}

.module-card--active,
.stream-card--assigned {
  border-color: var(--accent);
}

.cert-box {
  display: flex;
  gap: var(--space-3);
  align-items: center;
  padding: var(--space-4);
  border-radius: var(--radius-md);
  background: var(--surface-alt);
}

/* --------------------------------------------------------------------------
   My Learning - enrolled course library
   -------------------------------------------------------------------------- */
.learning-library {
  display: grid;
  gap: var(--space-5);
}

.learning-library__hero,
.learning-filterbar {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-4);
}

.learning-library__hero > div {
  display: grid;
  gap: var(--space-2);
  max-width: calc(var(--module-detail-width) * 2);
}

.learning-library__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-2);
}

.learning-library__top-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-2);
}

.learning-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
}

.learning-summary-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.learning-summary-card strong {
  grid-column: 2 / 3;
  font-size: var(--text-h2);
  line-height: var(--lh-h2);
}

.learning-trackbar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--dash-learn-min), 1fr));
  gap: var(--space-3);
}

.learning-track-chip {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  color: var(--text-primary);
  text-align: left;
  transition: transform var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out),
              background-color var(--motion-duration-base) var(--motion-ease-standard);
}

.learning-track-chip:hover,
.learning-track-chip:focus-visible {
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
  border-color: var(--border-strong);
  background: color-mix(in srgb, var(--surface) 84%, var(--surface-alt));
}

.learning-track-chip--active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent-tint) 46%, var(--surface));
}

.learning-track-chip > span:last-child {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.learning-track-chip strong,
.learning-track-chip .text-caption {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.learning-course-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--dash-learn-min), 1fr));
  gap: var(--space-4);
}

.learning-course-card {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: var(--space-4);
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  text-align: left;
  transition: border-color var(--motion-duration-fast) var(--motion-ease-out),
              background-color var(--motion-duration-base) var(--motion-ease-standard),
              transform var(--motion-duration-fast) var(--motion-ease-out);
}

.learning-course-card:hover,
.learning-course-card:focus-visible {
  border-color: var(--border-strong);
  background: color-mix(in srgb, var(--surface) 84%, var(--surface-alt));
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
}

.learning-course-art {
  position: relative;
  min-height: calc(var(--course-media-height) + var(--space-5));
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  background: var(--badge-fill);
  color: var(--badge-icon);
}

.learning-course-art__panel {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: var(--radius-sm);
  border: var(--border-width) solid color-mix(in srgb, var(--badge-icon) 16%, var(--border));
  background: color-mix(in srgb, var(--surface) 88%, transparent);
}

.learning-course-art__panel--main {
  grid-row: 1 / 3;
}

.learning-course-art__panel--main svg {
  width: var(--space-10);
  height: var(--space-10);
}

.learning-course-art__panel--accent {
  background: color-mix(in srgb, var(--badge-icon) 14%, var(--surface));
}

.learning-course-art__status {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  width: var(--space-8);
  height: var(--space-8);
  display: grid;
  place-items: center;
  border-radius: var(--radius-pill);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  color: var(--badge-icon);
}

.learning-course-art__status svg {
  width: var(--space-4);
  height: var(--space-4);
}

.learning-course-card__body,
.learning-course-card__title {
  min-width: 0;
  display: grid;
  gap: var(--space-3);
}

.learning-course-card__title {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
}

.learning-course-card__title h3 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.learning-course-card__meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-2);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.learning-course-card__meta span {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.learning-course-card__meta svg {
  width: var(--space-4);
  height: var(--space-4);
}

.learning-course-card__meta strong {
  color: var(--text-secondary);
}

/* --------------------------------------------------------------------------
   My Learning - course player layout
   -------------------------------------------------------------------------- */
.course-shell {
  display: grid;
  grid-template-columns: var(--course-sidebar-width) minmax(0, 1fr);
  align-items: start;
  gap: var(--space-5);
}

.course-sidebar,
.course-panel {
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
}

.course-sidebar {
  position: sticky;
  top: calc(var(--topbar-height) + var(--space-5));
  max-height: calc(100vh - var(--topbar-height) - var(--space-10));
  display: grid;
  gap: var(--space-4);
  overflow-y: auto;
  padding: var(--space-4);
}

.course-sidebar__brand {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
}

.course-sidebar__brand > div,
.course-section__toggle > span,
.course-lesson-copy,
.course-insight > div,
.course-resource-row > span {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.course-sidebar__summary {
  display: grid;
  gap: var(--space-3);
  padding: 0;
  border: 0;
  background: none;
}

.course-sidebar__summary .progress-track {
  background: var(--surface-alt);
}

.course-sidebar__back {
  width: fit-content;
  min-height: auto;
  padding: 0;
  justify-content: flex-start;
}

.course-meta-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
  font-weight: 500;
}

.course-meta-line span,
.course-player__controls,
.course-lesson-actions,
.course-tabs,
.course-check-list li {
  display: flex;
  align-items: center;
}

.course-meta-line svg {
  width: var(--space-4);
  height: var(--space-4);
  margin-right: var(--space-1);
}

.course-curriculum {
  display: grid;
  gap: var(--space-2);
}

.course-section {
  overflow: hidden;
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface);
  transition: border-color var(--motion-duration-fast) var(--motion-ease-out),
              background-color var(--motion-duration-base) var(--motion-ease-standard);
}

.course-section--open {
  border-color: color-mix(in srgb, var(--accent) 48%, var(--border));
  background: color-mix(in srgb, var(--accent-tint) 34%, var(--surface));
}

.course-section--current {
  border-color: var(--accent);
}

.course-section__toggle {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  text-align: left;
}

.course-section__toggle svg {
  width: var(--space-4);
  height: var(--space-4);
  color: var(--text-muted);
  transition: transform var(--motion-duration-base) var(--motion-ease-standard);
}

.course-section--open .course-section__toggle svg {
  transform: rotate(180deg);
}

.course-section__meter {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: 0 var(--space-3) var(--space-3);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.course-section__meter span {
  height: var(--space-1);
  overflow: hidden;
  border-radius: var(--radius-pill);
  background: var(--surface-alt);
}

.course-section__meter span::before {
  content: "";
  display: block;
  width: var(--meter-value);
  height: 100%;
  border-radius: inherit;
  background: var(--accent);
}

.course-lesson-stack {
  display: grid;
  gap: var(--space-2);
  padding: 0 var(--space-2) var(--space-2);
}

.course-lesson-stack--panel {
  padding: 0;
}

.course-topic-list {
  display: grid;
  gap: var(--space-1);
  padding: 0 var(--space-2) var(--space-2);
}

.course-lesson-row {
  position: relative;
  width: 100%;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  text-align: left;
  transition: background-color var(--motion-duration-fast) var(--motion-ease-out),
              color var(--motion-duration-fast) var(--motion-ease-out),
              transform var(--motion-duration-fast) var(--motion-ease-out);
}

.course-lesson-row:hover,
.course-lesson-row--active {
  color: var(--text-primary);
  background: var(--surface);
}

.course-lesson-row:hover {
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
}

.course-lesson-row--active {
  box-shadow: var(--shadow-xs);
}

.course-topic-row--active::before {
  content: "";
  position: absolute;
  top: var(--space-2);
  bottom: var(--space-2);
  left: 0;
  width: var(--toast-accent-width);
  border-radius: var(--radius-pill);
  background: var(--accent);
}

.course-lesson-icon {
  width: var(--icon-badge-sm-size);
  height: var(--icon-badge-sm-size);
  display: grid;
  place-items: center;
  border-radius: var(--radius-sm);
  border: var(--border-width) solid color-mix(in srgb, var(--badge-icon) 48%, var(--border));
  background: var(--badge-icon);
  color: var(--danger-contrast);
  box-shadow: var(--badge-gloss), var(--shadow-sm);
}

.course-lesson-type {
  text-transform: capitalize;
}

.course-lesson-icon svg {
  width: var(--space-4);
  height: var(--space-4);
}

.course-main {
  min-width: 0;
  display: grid;
  gap: var(--space-5);
}

.course-lesson-actions {
  gap: var(--space-2);
}

.course-player {
  position: relative;
  min-height: var(--course-player-min-height);
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: var(--border-width) solid color-mix(in srgb, var(--badge-icon) 24%, var(--border));
  background: linear-gradient(135deg, color-mix(in srgb, var(--surface-sunken) 84%, var(--badge-fill)) 0%, color-mix(in srgb, var(--surface-alt) 76%, var(--badge-fill)) 100%);
}

.course-player__stage {
  position: absolute;
  inset: 0 0 calc(var(--space-10) + var(--space-6));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-sunken) 62%, transparent), color-mix(in srgb, var(--surface-sunken) 86%, transparent)),
    color-mix(in srgb, var(--badge-icon) 12%, var(--surface-sunken));
}

.course-player__controls {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto auto;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: color-mix(in srgb, var(--surface-sunken) 72%, transparent);
  -webkit-backdrop-filter: blur(var(--space-3));
  backdrop-filter: blur(var(--space-3));
  color: var(--text-primary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.course-player__timeline {
  height: var(--space-1);
  overflow: hidden;
  border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--text-muted) 28%, transparent);
}

.course-player__timeline span {
  display: block;
  width: var(--player-value);
  height: 100%;
  border-radius: inherit;
  background: var(--accent);
}

.course-player__controls button {
  display: grid;
  place-items: center;
  color: var(--text-primary);
}

.course-player__controls svg {
  width: var(--space-4);
  height: var(--space-4);
}

.course-lesson-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-4);
}

.course-lesson-head > div:first-child {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
}

.course-lesson-head .text-display {
  max-width: calc(var(--module-detail-width) * 3);
}

.course-lesson-actions {
  justify-content: flex-end;
  flex-wrap: wrap;
}

.course-next-button {
  background: var(--text-primary);
  color: var(--bg);
  box-shadow: var(--shadow-sm);
}

.course-next-button:hover {
  background: var(--text-secondary);
}

.course-tabs {
  justify-content: flex-start;
  gap: var(--space-2);
  overflow-x: auto;
  padding-bottom: var(--space-1);
}

.course-tab {
  min-height: var(--avatar-32);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
  font-weight: 600;
  white-space: nowrap;
  transition: background-color var(--motion-duration-fast) var(--motion-ease-out),
              color var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out),
              transform var(--motion-duration-fast) var(--motion-ease-out);
}

.course-tab:hover,
.course-tab--active {
  border-color: var(--accent);
  color: var(--text-primary);
  background: var(--accent-tint);
}

.course-tab:hover {
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
}

.course-panel {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-5);
}

.course-overview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}

.course-insight,
.course-focus-card,
.course-question-row,
.course-resource-row,
.course-note-row,
.course-note-form,
.course-community-form,
.course-community-post {
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface-alt);
}

.course-insight {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
}

.course-insight strong,
.course-resource-row strong,
.course-lesson-copy strong,
.course-section__toggle strong,
.course-sidebar__brand strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.course-focus-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(var(--module-detail-width), 1fr);
  gap: var(--space-5);
  padding: var(--space-5);
}

.course-focus-card > div {
  display: grid;
  align-content: start;
  gap: var(--space-2);
}

.course-check-list {
  display: grid;
  gap: var(--space-2);
}

.course-check-list li {
  gap: var(--space-2);
  color: var(--text-secondary);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
}

.course-check-list svg {
  width: var(--space-4);
  height: var(--space-4);
  color: var(--success);
}

.course-note-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: var(--space-3);
  padding: var(--space-4);
}

.course-note-input {
  min-height: calc(var(--touch-target) * 2);
  resize: vertical;
}

.course-note-list,
.course-resource-list,
.course-community-list {
  display: grid;
  gap: var(--space-2);
}

.course-community__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}

.course-community__head > div:first-child,
.course-community-post__meta > div,
.course-community-reply > div {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.course-community__stats,
.course-community-post__meta,
.course-community-post__actions,
.course-community-clap,
.course-community-reply {
  display: flex;
  align-items: center;
}

.course-community__stats {
  flex-wrap: wrap;
  gap: var(--space-3);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
  font-weight: 600;
}

.course-community__stats span,
.course-community-post__actions span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.course-community__stats svg,
.course-community-post__actions svg {
  width: var(--space-4);
  height: var(--space-4);
}

.course-community-form {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: end;
  gap: var(--space-3);
  padding: var(--space-4);
}

.course-community-input {
  min-height: calc(var(--touch-target) * 2);
  resize: vertical;
}

.course-community-post {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-4);
}

.course-community-post__meta {
  gap: var(--space-3);
}

.course-community-post__actions {
  flex-wrap: wrap;
  gap: var(--space-3);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.course-community-clap {
  gap: var(--space-1);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-pill);
  color: var(--text-secondary);
  transition: background-color var(--motion-duration-fast) var(--motion-ease-out),
              color var(--motion-duration-fast) var(--motion-ease-out);
}

.course-community-clap:hover,
.course-community-clap[aria-pressed="true"] {
  background: var(--accent-tint);
  color: var(--accent);
}

.course-community-replies {
  display: grid;
  gap: var(--space-2);
  padding-left: calc(var(--avatar-32) + var(--space-3));
}

.course-community-reply {
  align-items: flex-start;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--surface);
  color: var(--text-secondary);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
}

.course-community-reply svg {
  width: var(--space-4);
  height: var(--space-4);
  color: var(--accent);
  flex: 0 0 auto;
}

.course-note-row {
  display: grid;
  grid-template-columns: calc(var(--touch-target) * 1.25) minmax(0, 1fr);
  gap: var(--space-3);
  padding: var(--space-3);
}

.course-note-row__time {
  display: inline-grid;
  place-items: center;
  height: var(--avatar-32);
  border-radius: var(--radius-sm);
  background: var(--accent-tint);
  color: var(--accent);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
  font-weight: 600;
}

.course-question-row,
.course-resource-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  text-align: left;
}

.course-question-row {
  grid-template-columns: auto minmax(0, 1fr);
}

.course-resource-row {
  width: 100%;
  color: var(--text-primary);
  transition: border-color var(--motion-duration-fast) var(--motion-ease-out),
              transform var(--motion-duration-fast) var(--motion-ease-out);
}

.course-resource-row:hover {
  border-color: var(--border-strong);
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
}

.course-resource-row > svg {
  width: var(--space-5);
  height: var(--space-5);
  color: var(--text-muted);
}

.course-reviews {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
}

.course-rating {
  display: grid;
  justify-items: start;
  gap: var(--space-2);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  background: var(--surface-alt);
}

.course-rating strong {
  font-size: var(--text-display);
  line-height: var(--lh-display);
}

.course-rating span {
  display: flex;
  gap: var(--space-1);
  color: var(--warning);
}

.course-rating svg {
  width: var(--space-4);
  height: var(--space-4);
  fill: currentColor;
}

.course-review-copy {
  display: grid;
  gap: var(--space-2);
}

.filter-bar {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.filter-bar .field-label {
  flex: 1 1 auto;
}

.stream-grid,
.quest-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--stream-card-min), 1fr));
  gap: var(--space-4);
}

.quest-grid {
  grid-template-columns: repeat(auto-fit, minmax(var(--quest-card-min), 1fr));
}

.stream-card,
.quest-card {
  min-height: 100%;
}

.modal-stream {
  display: grid;
  gap: var(--space-3);
}

.stream-governance {
  display: grid;
  grid-template-columns: repeat(2, minmax(var(--stream-card-min), 1fr));
  gap: var(--space-4);
  align-items: start;
}

.stream-status-card,
.stream-change-form,
.stream-request-card {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.stream-status-card {
  grid-template-columns: auto minmax(0, 1fr);
  min-height: 100%;
}

.stream-status-card > div,
.stream-change-form > div,
.stream-request-card > div:first-child {
  min-width: 0;
  display: grid;
  gap: var(--space-2);
}

.stream-change-form .btn {
  justify-self: start;
}

.stream-change-form__textarea {
  min-height: calc(var(--touch-target) * 2);
  resize: vertical;
}

.stream-ack {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: var(--space-2);
  color: var(--text-secondary);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
}

.stream-ack input {
  margin-top: var(--space-1);
  accent-color: var(--accent);
}

.stream-request-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.stream-request-card__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-2);
}

.stream-archive-list {
  grid-column: 1 / -1;
  display: grid;
  gap: var(--space-3);
}

.stream-archive-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.stream-archive-card > div {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.stream-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.stream-card__meta span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.stream-card__meta svg {
  width: var(--space-4);
  height: var(--space-4);
}

.stream-page-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
}

.stream-page-actions--top {
  justify-self: end;
}

.stream-home {
  display: grid;
  gap: var(--space-5);
}

.stream-track-detail {
  display: grid;
  gap: var(--space-5);
}

.stream-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(var(--metric-card-min), calc(var(--metric-card-min) * 2.1));
  gap: var(--space-5);
  align-items: stretch;
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  border: var(--border-width) solid color-mix(in srgb, var(--badge-icon) 28%, var(--border));
  background: color-mix(in srgb, var(--badge-fill) 42%, var(--surface));
}

.stream-track-detail__hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(var(--metric-card-min), calc(var(--metric-card-min) * 2.1));
  gap: var(--space-5);
  align-items: start;
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  border: var(--border-width) solid color-mix(in srgb, var(--badge-icon) 28%, var(--border));
  background: color-mix(in srgb, var(--badge-fill) 36%, var(--surface));
}

.stream-track-detail__hero > div:first-child {
  min-width: 0;
  display: grid;
  gap: var(--space-3);
}

.stream-hero__main {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: var(--space-4);
}

.stream-hero__copy {
  min-width: 0;
  display: grid;
  gap: var(--space-3);
}

.stream-hero__copy .text-display {
  overflow-wrap: anywhere;
}

.stream-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.stream-hero__metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.stream-metric-card {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: color-mix(in srgb, var(--surface) 86%, transparent);
}

.stream-metric-card strong {
  grid-column: 2 / 3;
  font-size: var(--text-h2);
  line-height: var(--lh-h2);
}

.stream-home-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(var(--stream-card-min), 0.65fr);
  gap: var(--space-4);
  align-items: start;
}

.stream-panel {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.stream-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.stream-panel__head > div {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.stream-activity-list,
.stream-progress-list,
.stream-fact-list,
.stream-track-grid {
  display: grid;
  gap: var(--space-3);
}

.stream-activity-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.stream-activity-item,
.stream-progress-row,
.stream-fact,
.stream-rule-note,
.stream-track-card,
.stream-course-card {
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.stream-activity-item {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
}

.stream-activity-item__copy {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.stream-activity-item__copy strong,
.stream-activity-item__copy span,
.stream-activity-item__value,
.stream-progress-row strong,
.stream-fact strong,
.stream-track-card h4,
.stream-course-pill {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.stream-activity-item__value {
  color: var(--text-primary);
}

.stream-progress-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(var(--metric-card-min), 0.45fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
}

.stream-progress-row > div:first-child {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.stream-fact {
  display: grid;
  gap: var(--space-1);
  padding: var(--space-3);
}

.stream-rule-note {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: var(--space-3);
  padding: var(--space-3);
}

.stream-track-grid {
  grid-template-columns: repeat(auto-fit, minmax(var(--dash-learn-min), 1fr));
}

.stream-track-card {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: var(--space-3);
  padding: var(--space-4);
}

.stream-track-card--subscribed {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent-tint) 36%, var(--surface-alt));
}

.stream-track-card > div:first-child {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.stream-track-card__top,
.stream-course-card__top,
.stream-course-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.stream-track-card__top {
  min-width: 0;
}

.stream-role-list,
.stream-course-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.stream-course-pill {
  max-width: 100%;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  background: var(--surface);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.stream-course-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--dash-learn-min), 1fr));
  gap: var(--space-4);
}

.stream-course-card {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: var(--space-3);
  padding: var(--space-4);
}

.stream-course-card > div:nth-child(2) {
  min-width: 0;
  display: grid;
  gap: var(--space-2);
}

.stream-course-card h4,
.stream-course-card p {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

.stream-course-card h4 {
  -webkit-line-clamp: 2;
}

.stream-course-card p {
  -webkit-line-clamp: 3;
}

.stream-course-card__meta {
  justify-content: flex-start;
  flex-wrap: wrap;
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.stream-course-card__meta span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.stream-course-card__meta svg {
  width: var(--space-4);
  height: var(--space-4);
}

.stream-change-form--modal {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: none;
}

.stream-change-form--modal .btn {
  justify-self: start;
}

.stream-change-modal-intro {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  background: var(--surface-alt);
}

.stream-select-field {
  display: grid;
  gap: var(--space-2);
}

.stream-select-card {
  position: relative;
  min-height: calc(var(--touch-target) * 1.4);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
  overflow: hidden;
  transition: border-color var(--motion-duration-fast) var(--motion-ease-out),
              background-color var(--motion-duration-base) var(--motion-ease-standard);
}

.stream-select-card:focus-within,
.stream-select-card:hover {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent-tint) 32%, var(--surface-alt));
}

.stream-select-card__copy {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.stream-select-card__copy strong,
.stream-select-card__copy span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.stream-select-card__meta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
  font-weight: 700;
}

.stream-select-card__meta svg {
  width: var(--space-4);
  height: var(--space-4);
}

.stream-select-native {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

.modal-stream__tracks {
  display: grid;
  gap: var(--space-3);
}

.modal-stream__track {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.modal-stream__track .text-caption {
  display: block;
}

.quest-meta {
  justify-content: flex-start;
  flex-wrap: wrap;
  color: var(--text-secondary);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
}

.quest-meta span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.quest-meta svg {
  width: var(--space-4);
  height: var(--space-4);
}

.status-label {
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
  font-weight: 600;
  color: var(--text-secondary);
}

.status-label--complete {
  color: var(--success);
}

.status-label--in-progress {
  color: var(--warning);
}

.empty-state {
  padding: var(--space-8);
  border-radius: var(--radius-md);
  border: var(--border-width) dashed var(--border);
  color: var(--text-secondary);
  text-align: center;
}

/* --------------------------------------------------------------------------
   Challenges — community-voted innovation challenges
   -------------------------------------------------------------------------- */
.challenge-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--challenge-card-min), 1fr));
  gap: var(--space-4);
}

.challenge-card {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-5);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  text-align: left;
  min-height: 100%;
  transition: transform var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out);
}

.challenge-card:hover,
.challenge-card:focus-visible {
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
  border-color: var(--border-strong);
}

.challenge-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.challenge-card__meta {
  justify-content: flex-start;
  flex-wrap: wrap;
}

.challenge-card__lead,
.challenge-card__lead--empty {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--surface-alt);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.challenge-card__lead strong {
  color: var(--text-primary);
}

.challenge-card__lead .pill {
  margin-left: auto;
}

.challenge-card__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.challenge-card__status {
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
  font-weight: 600;
  color: var(--text-secondary);
}

.challenge-card__status--joined {
  color: var(--warning);
}

.challenge-card__status--submitted {
  color: var(--success);
}

.challenge-page {
  display: grid;
  gap: var(--space-5);
}

.challenge-page > .btn {
  justify-self: start;
}

/* --------------------------------------------------------------------------
   Leaderboard — badge tier showcase (design.md §7)
   -------------------------------------------------------------------------- */
.badge-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--badge-tile-min), 1fr));
  gap: var(--space-4);
}

.badge-tile {
  position: relative;
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  transition: transform var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out);
}

.badge-tile:hover,
.badge-tile:focus-within {
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
  border-color: var(--border-strong);
}

.badge-tile--locked {
  opacity: 0.5;
}

.badge-tile__body {
  width: 100%;
  display: grid;
  justify-items: center;
  gap: var(--space-2);
  padding: var(--space-4);
  border: none;
  background: transparent;
  text-align: center;
}

.badge-tile__share {
  position: absolute;
  top: var(--space-2);
  right: var(--space-2);
  width: var(--tile-icon-btn-size);
  height: var(--tile-icon-btn-size);
  display: grid;
  place-items: center;
  border-radius: var(--radius-pill);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
  color: var(--text-secondary);
  transition: color var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out),
              background-color var(--motion-duration-fast) var(--motion-ease-out);
}

.badge-tile__share:hover,
.badge-tile__share:focus-visible {
  color: var(--accent);
  border-color: var(--accent);
  background: var(--accent-tint);
}

.badge-tile__share svg {
  width: var(--space-4);
  height: var(--space-4);
}

.badge-tile--locked .badge-tier,
.badge-tier--locked {
  filter: grayscale(1);
}

.badge-tier {
  width: var(--badge-tier-size);
  height: var(--badge-tier-size);
  display: grid;
  place-items: center;
  border-radius: var(--radius-pill);
  color: #ffffff;
  box-shadow: var(--badge-gloss), var(--shadow-sm);
}

.badge-tier--lg {
  width: var(--badge-tier-lg-size);
  height: var(--badge-tier-lg-size);
  justify-self: center;
}

.badge-tier-1 { background: linear-gradient(160deg, var(--tier-1-from), var(--tier-1-to)); }
.badge-tier-2 { background: linear-gradient(160deg, var(--tier-2-from), var(--tier-2-to)); }
.badge-tier-3 { background: linear-gradient(160deg, var(--tier-3-from), var(--tier-3-to)); }
.badge-tier-4 { background: linear-gradient(160deg, var(--tier-4-from), var(--tier-4-to)); }
.badge-tier-5 { background: linear-gradient(160deg, var(--tier-5-from), var(--tier-5-to)); }
.badge-tier-6 { background: linear-gradient(160deg, var(--tier-6-from), var(--tier-6-to)); }
.badge-tier-7 { background: linear-gradient(160deg, var(--tier-7-from), var(--tier-7-to)); }

.badge-modal {
  display: grid;
  justify-items: center;
  gap: var(--space-3);
  text-align: center;
}

/* --------------------------------------------------------------------------
   Badge share modal — social-worthy card + platform/copy/download actions
   -------------------------------------------------------------------------- */
.share-panel {
  display: grid;
  gap: var(--space-4);
}

.share-card {
  display: grid;
  justify-items: center;
  gap: var(--space-3);
  padding: var(--space-8);
  border-radius: var(--radius-lg);
  text-align: center;
  color: #ffffff;
}

.share-card__brand {
  justify-self: start;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: 600;
}

.share-card__badge {
  width: var(--share-card-badge-size);
  height: var(--share-card-badge-size);
  box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.32), var(--shadow-md);
}

.share-card__title {
  display: grid;
  gap: var(--space-1);
}

.share-card__title strong {
  font-size: var(--text-h1);
  line-height: var(--lh-h1);
}

.share-card__title span {
  font-size: var(--text-caption);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0.85;
}

.share-card__stats {
  display: flex;
  gap: var(--space-6);
}

.share-card__stats span {
  display: grid;
  gap: var(--space-1);
}

.share-card__stats strong {
  font-size: var(--text-h2);
  line-height: var(--lh-h2);
}

.share-card__stats span span {
  font-size: var(--text-caption);
  opacity: 0.85;
}

.share-card__name {
  font-size: var(--text-body-sm);
  opacity: 0.9;
}

.share-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

/* --------------------------------------------------------------------------
   My Portfolio — hero, scores, tabbed sections
   -------------------------------------------------------------------------- */
.portfolio-hero {
  display: grid;
  gap: var(--space-5);
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.portfolio-hero__identity {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-4);
}

.portfolio-hero__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

.portfolio-hero__meta span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.portfolio-hero__actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.portfolio-hero__bio {
  color: var(--text-secondary);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
  max-width: 72ch;
}

.portfolio-scores {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
}

.portfolio-score__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-2);
}

.portfolio-score .progress-fill[class*="cat-"] {
  background: rgb(var(--cat-rgb));
}

.portfolio-stats {
  margin-top: var(--space-4);
}

.portfolio-overview {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-6);
  align-items: start;
}

.portfolio-tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.portfolio-role-list {
  display: grid;
  gap: var(--space-3);
  margin-top: var(--space-3);
}

.portfolio-role-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.portfolio-role-row > div {
  display: grid;
  gap: var(--space-1);
}

.portfolio-cert-grid,
.portfolio-project-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--challenge-card-min), 1fr));
  gap: var(--space-4);
}

.portfolio-cert-card {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.portfolio-cert-card > div {
  display: grid;
  gap: var(--space-1);
}

.portfolio-cert-card .pill {
  justify-self: start;
}

.portfolio-project-card {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-5);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.portfolio-edit-form {
  display: grid;
  gap: var(--space-3);
}

.portfolio-edit-form__textarea {
  min-height: calc(var(--touch-target) * 2);
  resize: vertical;
}

.portfolio-edit-form .btn {
  justify-self: start;
}

/* --------------------------------------------------------------------------
   Community — feed, composer, groups, projects
   -------------------------------------------------------------------------- */
.community-feed {
  gap: var(--space-4);
}

.community-composer {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.community-composer__body {
  min-width: 0;
  flex: 1 1 auto;
  display: grid;
  gap: var(--space-3);
}

.community-composer__input {
  min-height: calc(var(--touch-target) * 1.4);
  resize: vertical;
}

.community-composer__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.community-composer__context {
  flex: 1 1 auto;
  min-width: 0;
}

.community-post-list {
  display: grid;
  gap: var(--space-3);
}

.community-post {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.community-post__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.community-post__author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
  background: transparent;
  border: none;
  text-align: left;
}

.community-post__author > span:last-child {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.community-post__author strong {
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.community-post__body {
  color: var(--text-primary);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
}

.community-post__foot {
  display: flex;
  align-items: center;
}

.community-group-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--challenge-card-min), 1fr));
  gap: var(--space-4);
}

.community-group-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.community-group-card__body {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.community-group-card .btn {
  grid-column: 1 / 3;
  justify-self: start;
}

/* --------------------------------------------------------------------------
   Mentorship — directory, profile, sessions, seminars
   -------------------------------------------------------------------------- */
.mentor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--challenge-card-min), 1fr));
  gap: var(--space-4);
}

.mentor-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  text-align: left;
  transition: transform var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out);
}

.mentor-card:hover {
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
  border-color: var(--border-strong);
}

.mentor-card__body {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.mentor-card__meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.availability-dot {
  display: inline-block;
  width: var(--space-2);
  height: var(--space-2);
  border-radius: var(--radius-pill);
  background: var(--text-muted);
}

.availability-dot--available {
  background: var(--success);
}

.availability-dot--limited {
  background: var(--warning);
}

.availability-dot--unavailable {
  background: var(--text-muted);
}

.mentor-session-list,
.mentor-seminar-list {
  display: grid;
  gap: var(--space-3);
}

.mentor-session-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.mentor-session-row > div {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.mentor-seminar-card {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-5);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.mentor-seminar-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.mentor-seminar-card .btn {
  justify-self: start;
}

.mentor-slot-list {
  display: grid;
  gap: var(--space-2);
}

.mentor-slot {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
  cursor: pointer;
}

.mentor-slot input {
  accent-color: var(--accent);
}

/* --------------------------------------------------------------------------
   Messages — centralized inbox (friends and mentors)
   -------------------------------------------------------------------------- */
.messages-shell {
  display: grid;
  grid-template-columns: minmax(0, var(--messages-list-width)) minmax(0, 1fr);
  gap: var(--space-4);
  height: var(--messages-shell-height);
}

.messages-list-pane {
  display: grid;
  align-content: start;
  gap: var(--space-1);
  padding: var(--space-3);
  border-radius: var(--radius-lg);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  overflow-y: auto;
}

.messages-row {
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid transparent;
  background: transparent;
  text-align: left;
  transition: background-color var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out);
}

.messages-row:hover {
  background: var(--surface-alt);
}

.messages-row--active {
  background: var(--accent-tint);
  border-color: var(--accent);
}

.messages-row__body {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.messages-row__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.messages-row__head strong {
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.messages-row__body p {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.messages-row__dot {
  min-width: var(--space-5);
  height: var(--space-5);
  padding: 0 var(--space-1);
  display: grid;
  place-items: center;
  border-radius: var(--radius-pill);
  background: var(--accent);
  color: var(--accent-contrast);
  font-size: var(--text-caption);
  font-weight: 700;
}

.messages-thread-pane {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  border-radius: var(--radius-lg);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  overflow: hidden;
}

.messages-thread__head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  border-bottom: var(--border-width) solid var(--border);
}

.messages-thread__head > div {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.messages-thread__back {
  display: none;
}

.messages-thread__body {
  overflow-y: auto;
  padding: var(--space-4);
  display: grid;
  gap: var(--space-3);
  align-content: start;
}

.messages-bubble-row {
  display: grid;
  gap: var(--space-1);
  justify-items: start;
}

.messages-bubble-row--mine {
  justify-items: end;
}

.messages-bubble {
  max-width: 70%;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  background: var(--surface-alt);
  color: var(--text-primary);
}

.messages-bubble-row--mine .messages-bubble {
  background: var(--accent);
  color: var(--accent-contrast);
}

.messages-reply-form {
  display: flex;
  align-items: flex-end;
  gap: var(--space-3);
  padding: var(--space-4);
  border-top: var(--border-width) solid var(--border);
}

.messages-reply-input {
  flex: 1 1 auto;
  min-height: var(--touch-target);
  max-height: calc(var(--touch-target) * 2.5);
  resize: none;
}

/* --------------------------------------------------------------------------
   Opportunities - career marketplace, fit score, applications
   -------------------------------------------------------------------------- */
.opportunity-hero,
.opportunity-detail__hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(var(--metric-card-min), 0.42fr);
  gap: var(--space-5);
  align-items: stretch;
  padding: var(--space-5);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-tint) 48%, transparent), transparent 42%),
    var(--surface);
}

.opportunity-hero__copy,
.opportunity-detail__identity,
.opportunity-readiness,
.opportunity-fit-block,
.opportunity-detail,
.opportunity-detail__main,
.opportunity-detail__side,
.opportunity-fit-panel,
.opportunity-apply-panel,
.opportunity-improve-panel,
.opportunity-tracker-panel,
.opportunity-apply-modal {
  display: grid;
  gap: var(--space-4);
}

.opportunity-hero__copy {
  align-content: center;
  max-width: calc(var(--module-detail-width) * 2);
}

.opportunity-hero__actions,
.opportunity-card__meta,
.opportunity-card__facts,
.opportunity-skill-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.opportunity-readiness {
  padding: var(--space-4);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-alt) 72%, var(--surface));
}

.opportunity-readiness__score {
  display: grid;
  gap: var(--space-1);
}

.opportunity-readiness__score strong {
  font-size: var(--text-display);
  line-height: var(--lh-display);
  color: var(--accent);
}

.opportunity-readiness__row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
}

.opportunity-readiness__row > span:last-child,
.opportunity-improve-row > span,
.opportunity-cpd-item > div,
.opportunity-coach-card > div,
.opportunity-route-card > div,
.opportunity-apply-modal__intro > div {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.opportunity-board {
  gap: var(--space-5);
}

.opportunity-filters {
  display: grid;
  gap: var(--space-3);
}

.opportunity-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: end;
  gap: var(--space-3);
}

.opportunity-filter-group {
  display: grid;
  gap: var(--space-2);
}

.opportunity-filter-group .segmented {
  justify-content: flex-start;
  overflow-x: auto;
}

.opportunity-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--challenge-card-min), 1fr));
  gap: var(--space-4);
}

.opportunity-card {
  min-width: 0;
  display: grid;
  gap: var(--space-4);
  align-content: start;
  padding: var(--space-4);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  cursor: pointer;
  transition:
    transform var(--motion-duration-fast) var(--motion-ease-out),
    border-color var(--motion-duration-fast) var(--motion-ease-out),
    box-shadow var(--motion-duration-fast) var(--motion-ease-out);
}

.opportunity-card:hover {
  transform: translateY(calc(var(--motion-distance-sm) * -0.5));
  border-color: var(--accent);
  box-shadow: var(--shadow-sm);
}

.opportunity-card:focus-visible {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 var(--focus-ring-width) var(--accent-tint);
}

.opportunity-card--archived {
  opacity: 0.72;
  background: var(--surface-alt);
}

.opportunity-card__facts {
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.opportunity-card__facts span,
.opportunity-reason-list span,
.opportunity-detail-section h3,
.opportunity-route-card,
.opportunity-apply-facts div span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.opportunity-card__facts span {
  min-height: calc(var(--touch-target) - var(--space-2));
  padding: var(--space-1) var(--space-3);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-pill);
  background: var(--surface-alt);
}

.opportunity-card__facts svg,
.opportunity-reason-list svg,
.opportunity-detail-section h3 svg,
.opportunity-apply-facts svg {
  width: var(--space-4);
  height: var(--space-4);
}

.opportunity-score {
  --score-size: var(--avatar-48);
  position: relative;
  width: var(--score-size);
  height: var(--score-size);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 0;
  border-radius: var(--radius-pill);
  background:
    conic-gradient(currentColor var(--score-value), var(--surface-sunken) 0),
    var(--surface);
  color: rgb(var(--cat-rgb, var(--cat-blue-rgb)));
}

.opportunity-score::after {
  content: "";
  position: absolute;
  inset: var(--space-1);
  border-radius: inherit;
  background: var(--surface);
}

.opportunity-score strong {
  position: relative;
  z-index: 1;
}

.opportunity-score strong {
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
  color: var(--text-primary);
}

.opportunity-detail__identity {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: var(--space-4);
}

.opportunity-detail__hero {
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
}

.opportunity-detail__facts {
  margin-top: var(--space-4);
}

.opportunity-fit-block {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  padding: var(--space-4);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-alt) 72%, var(--surface));
}

.opportunity-detail__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(var(--metric-card-min), 0.34fr);
  gap: var(--space-5);
  align-items: start;
}

.opportunity-detail-section {
  display: grid;
  gap: var(--space-4);
}

.opportunity-detail-section + .opportunity-detail-section {
  padding-top: var(--space-4);
  border-top: var(--border-width) solid var(--border);
}

.opportunity-apply-facts {
  display: grid;
  gap: var(--space-2);
}

.opportunity-apply-facts div {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-1);
  padding: var(--space-3);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface-alt);
}

.opportunity-apply-facts strong {
  color: var(--text-primary);
}

.opportunity-fit-list,
.opportunity-improve-list,
.opportunity-timeline,
.opportunity-cpd-list {
  display: grid;
  gap: var(--space-3);
}

.opportunity-fit-summary {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
}

.opportunity-fit-row {
  display: grid;
  gap: var(--space-2);
}

.opportunity-fit-row > div:first-child {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.opportunity-reason-list {
  display: grid;
  gap: var(--space-2);
  color: var(--success);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
}

.opportunity-reason-list .opportunity-gap {
  color: var(--warning);
}

.opportunity-improve-row,
.opportunity-cpd-item,
.opportunity-route-card,
.opportunity-apply-modal__intro,
.opportunity-coach-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface-alt);
}

.opportunity-improve-row {
  width: 100%;
  text-align: left;
}

.opportunity-improve-row:hover {
  border-color: var(--accent);
  background: var(--accent-tint);
}

.opportunity-timeline__row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-3);
}

.opportunity-timeline__row > span {
  width: var(--space-3);
  height: var(--space-3);
  margin-top: var(--space-2);
  border-radius: var(--radius-pill);
  background: var(--border-strong);
}

.opportunity-timeline__row--complete > span {
  background: var(--success);
}

.opportunity-timeline__row--active > span {
  background: var(--warning);
}

.opportunity-career-strip {
  display: grid;
  grid-template-columns: minmax(0, 0.4fr) minmax(0, 1fr) minmax(var(--metric-card-min), 0.45fr);
  gap: var(--space-4);
  align-items: start;
  padding-top: var(--space-4);
  border-top: var(--border-width) solid var(--border);
}

.opportunity-empty {
  grid-column: 1 / -1;
}

.opportunity-apply-note {
  min-height: calc(var(--touch-target) * 2);
}

.opportunity-snapshot {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-4);
}

.opportunity-signal {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface);
  color: var(--text-primary);
  text-align: left;
  box-shadow: var(--shadow-xs);
}

button.opportunity-signal {
  cursor: pointer;
  transition:
    transform var(--motion-duration-fast) var(--motion-ease-out),
    border-color var(--motion-duration-fast) var(--motion-ease-out),
    box-shadow var(--motion-duration-fast) var(--motion-ease-out);
}

button.opportunity-signal:hover,
button.opportunity-signal:focus-visible {
  transform: translateY(calc(var(--motion-distance-sm) * -0.5));
  border-color: var(--accent);
  box-shadow: var(--shadow-sm);
}

.opportunity-signal > span:last-child {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.opportunity-toolbar {
  display: grid;
  gap: var(--space-4);
}

.opportunity-quick-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.opportunity-chip {
  min-height: var(--touch-target);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-pill);
  background: var(--surface-alt);
  color: var(--text-secondary);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
  transition:
    background-color var(--motion-duration-fast) var(--motion-ease-out),
    border-color var(--motion-duration-fast) var(--motion-ease-out),
    color var(--motion-duration-fast) var(--motion-ease-out);
}

.opportunity-chip svg {
  width: var(--space-4);
  height: var(--space-4);
}

.opportunity-chip strong {
  min-width: var(--space-6);
  display: inline-grid;
  place-items: center;
  padding: 0 var(--space-2);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--text-primary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.opportunity-chip--active {
  border-color: var(--accent);
  background: var(--accent-tint);
  color: var(--text-primary);
}

.opportunity-select-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}

.opportunity-result-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.opportunity-list {
  display: grid;
  gap: var(--space-3);
}

.opportunity-list .opportunity-card {
  align-items: start;
  padding: var(--space-5);
}

.opportunity-card__header {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: start;
  gap: var(--space-4);
}

.opportunity-card__title {
  min-width: 0;
  display: grid;
  gap: var(--space-2);
}

.opportunity-card__description {
  max-width: calc(var(--module-detail-width) * 2);
}

.opportunity-card__tools {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
}

.opportunity-card__state {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.opportunity-save-btn {
  width: var(--touch-target);
  height: var(--touch-target);
  display: grid;
  place-items: center;
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-pill);
  background: var(--surface-alt);
  color: var(--text-secondary);
  transition:
    background-color var(--motion-duration-fast) var(--motion-ease-out),
    border-color var(--motion-duration-fast) var(--motion-ease-out),
    color var(--motion-duration-fast) var(--motion-ease-out);
}

.opportunity-save-btn:hover,
.opportunity-save-btn:focus-visible {
  border-color: var(--accent);
  background: var(--accent-tint);
  color: var(--accent);
}

.opportunity-save-btn svg {
  width: var(--space-4);
  height: var(--space-4);
}

.opportunity-company-mark {
  width: var(--avatar-48);
  height: var(--avatar-48);
  display: grid;
  place-items: center;
  flex: 0 0 var(--avatar-48);
  border-radius: var(--radius-md);
  border: var(--border-width) solid rgba(var(--cat-rgb, var(--cat-blue-rgb)), var(--badge-alpha));
  background: rgba(var(--cat-rgb, var(--cat-blue-rgb)), var(--badge-alpha));
  color: rgb(var(--cat-rgb, var(--cat-blue-rgb)));
  font-weight: 800;
}

.opportunity-company-mark--lg {
  width: var(--avatar-64);
  height: var(--avatar-64);
  flex-basis: var(--avatar-64);
  font-size: var(--text-h3);
  line-height: var(--lh-h3);
}

.opportunity-detail__meta-grid,
.opportunity-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.opportunity-detail-fact,
.opportunity-setup-card {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
  padding: var(--space-3);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface-alt);
}

.opportunity-setup-card {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
}

.opportunity-detail-fact span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.opportunity-detail-fact svg {
  width: var(--space-4);
  height: var(--space-4);
}

.opportunity-detail-fact strong,
.opportunity-setup-card strong {
  color: var(--text-primary);
}

.opportunity-detail-copy {
  max-width: calc(var(--module-detail-width) * 2);
}

.opportunity-process-list {
  display: grid;
  gap: var(--space-2);
}

.opportunity-process-step {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: var(--space-3);
  padding: var(--space-3);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface-alt);
}

.opportunity-process-step > span {
  width: var(--icon-badge-sm-size);
  height: var(--icon-badge-sm-size);
  display: grid;
  place-items: center;
  border-radius: var(--radius-pill);
  background: var(--accent-tint);
  color: var(--accent);
  font-weight: 700;
}

.opportunity-company-panel {
  display: grid;
  gap: var(--space-4);
}

.opportunity-career-strip {
  padding: var(--space-5);
  border: var(--border-width) solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
}

@media (max-width: 960px) {
  .opportunity-snapshot,
  .opportunity-select-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .opportunity-signal,
  .opportunity-card__header,
  .opportunity-detail__meta-grid,
  .opportunity-mini-grid,
  .opportunity-result-row {
    grid-template-columns: 1fr;
  }

  .opportunity-card__tools {
    justify-content: flex-start;
  }

  .opportunity-result-row {
    display: grid;
    align-items: stretch;
  }

  .opportunity-chip,
  .opportunity-result-row .btn {
    width: 100%;
    justify-content: center;
  }
}

.challenge-detail {
  display: grid;
  gap: var(--space-4);
}

.challenge-detail__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  color: var(--text-secondary);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
}

.challenge-detail__meta span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.challenge-detail__deliverable {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  background: var(--surface-alt);
}

.challenge-detail__deliverable span {
  display: grid;
  gap: var(--space-1);
}

.challenge-cta,
.challenge-mine {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
}

.challenge-mine {
  justify-content: flex-start;
}

.challenge-form {
  display: grid;
  gap: var(--space-3);
}

.challenge-form__textarea {
  min-height: calc(var(--touch-target) * 2);
  resize: vertical;
}

.challenge-form .btn {
  justify-self: start;
}

.challenge-detail__submissions {
  display: grid;
  gap: var(--space-3);
}

.challenge-detail__submissions h3 {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.submission-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.submission-row--mine {
  border-color: var(--accent);
  background: var(--accent-tint);
}

.submission-row__body {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.submission-row__head {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.submission-row__body p,
.submission-row__body > span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.clap-btn {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-pill);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  color: var(--text-secondary);
  font-weight: 600;
  transition: transform var(--motion-duration-instant) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out),
              background-color var(--motion-duration-fast) var(--motion-ease-out),
              color var(--motion-duration-fast) var(--motion-ease-out);
}

.clap-btn:hover:not(:disabled) {
  border-color: var(--border-strong);
}

.clap-btn:active:not(:disabled) {
  transform: scale(var(--motion-scale-press));
}

.clap-btn--active {
  border-color: transparent;
  background: var(--badge-fill);
  color: var(--badge-icon);
}

.clap-btn svg {
  width: var(--space-4);
  height: var(--space-4);
}

/* --------------------------------------------------------------------------
   Wallet & Rewards — SkillCoins balance, catalog, transaction history
   -------------------------------------------------------------------------- */
.wallet-hero {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  border: var(--border-width) solid var(--border);
  background:
    radial-gradient(circle at top right, rgba(var(--cat-gold-rgb), 0.14), transparent 42%),
    var(--surface);
}

.wallet-hero__balance {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.wallet-hero__note {
  color: var(--text-secondary);
  max-width: 72ch;
}

.reward-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--challenge-card-min), 1fr));
  gap: var(--space-4);
}

.reward-card {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-5);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  transition: transform var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out);
}

.reward-card:hover {
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
  border-color: var(--border-strong);
}

.reward-card__body {
  display: grid;
  gap: var(--space-1);
}

.reward-card__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.wallet-tx-list {
  display: grid;
  gap: var(--space-3);
}

.wallet-tx-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.wallet-tx-row__body {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.wallet-tx-row__amount {
  white-space: nowrap;
}

.wallet-tx-row__amount--earn {
  color: var(--success);
}

.wallet-tx-row__amount--redeem {
  color: var(--danger);
}

/* --------------------------------------------------------------------------
   Settings — profile, skills & CV, security, notifications & appearance
   -------------------------------------------------------------------------- */
.settings-profile,
.settings-skills,
.settings-security,
.settings-preferences {
  display: grid;
  gap: var(--space-5);
}

.settings-locked-card {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-5);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.settings-locked-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--metric-card-min), 1fr));
  gap: var(--space-4);
}

.settings-locked-field {
  display: grid;
  gap: var(--space-1);
}

.settings-form {
  display: grid;
  gap: var(--space-3);
}

.settings-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.settings-form__textarea {
  min-height: calc(var(--touch-target) * 2);
  resize: vertical;
}

.settings-form .btn {
  justify-self: start;
}

.portfolio-overview__skills-head {
  margin-top: var(--space-4);
}

.settings-skill-form {
  display: flex;
  gap: var(--space-3);
  align-items: flex-end;
}

.settings-skill-form input {
  flex: 1 1 auto;
}

.settings-skill-tags {
  margin-top: var(--space-3);
}

.settings-skill-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.settings-skill-tag button {
  display: grid;
  place-items: center;
  background: transparent;
  border: none;
  color: inherit;
  opacity: 0.7;
}

.settings-skill-tag button:hover {
  opacity: 1;
}

.settings-skill-tag svg {
  width: var(--space-3);
  height: var(--space-3);
}

.settings-cv-upload {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  margin-top: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) dashed var(--border-strong);
  background: transparent;
  text-align: left;
  cursor: pointer;
  transition: border-color var(--motion-duration-fast) var(--motion-ease-out),
              background-color var(--motion-duration-fast) var(--motion-ease-out);
}

.settings-cv-upload:hover {
  border-color: var(--accent);
  background: var(--accent-tint);
}

.settings-cv-upload > div {
  display: grid;
  gap: var(--space-1);
}

.settings-cv-card {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  margin-top: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.settings-cv-card__body {
  min-width: 0;
  flex: 1 1 auto;
  display: grid;
  gap: var(--space-1);
}

.settings-cv-card__actions {
  display: flex;
  gap: var(--space-2);
}

.settings-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-3) 0;
}

.settings-toggle-row + .settings-toggle-row {
  border-top: var(--border-width) dashed var(--border);
}

/* Toggle switch (design.md §4.2) */
.toggle {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
}

.toggle__input {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
}

.toggle-track {
  position: relative;
  width: 38px;
  height: 22px;
  border-radius: var(--radius-pill);
  background: var(--border-strong);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.08);
  transition: background-color var(--motion-duration-fast) var(--motion-ease-out);
}

.toggle__input:checked + .toggle-track {
  background: var(--accent);
}

.toggle__input:focus-visible + .toggle-track {
  box-shadow: 0 0 0 var(--focus-ring-width) var(--accent-tint);
}

.toggle-thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 18px;
  height: 18px;
  border-radius: var(--radius-pill);
  background: #ffffff;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15), 0 1px 1px rgba(0, 0, 0, 0.06);
  transition: transform var(--motion-duration-fast) var(--motion-ease-out);
}

.toggle__input:checked + .toggle-track .toggle-thumb {
  transform: translateX(16px);
}

/* --------------------------------------------------------------------------
   XP breakdown popover — own leaderboard row and the Points stat only
   -------------------------------------------------------------------------- */
.has-xp-pop {
  position: relative;
  cursor: default;
}

.xp-pop {
  position: absolute;
  z-index: 20;
  left: 0;
  top: calc(100% + var(--space-2));
  width: var(--xp-tooltip-width);
  max-width: calc(100vw - (var(--space-8) * 2));
  display: grid;
  gap: var(--space-2);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  box-shadow: var(--shadow-md);
  opacity: 0;
  visibility: hidden;
  transform: translateY(calc(-1 * var(--motion-distance-xs)));
  transition: opacity var(--motion-duration-fast) var(--motion-ease-out),
              transform var(--motion-duration-fast) var(--motion-ease-out),
              visibility 0s linear var(--motion-duration-fast);
  pointer-events: none;
}

/* Points stat sits in the narrow right-hand column - anchor the popover to
   the right edge so it opens inward instead of overflowing past the panel. */
.dash-profile-stat.has-xp-pop .xp-pop {
  left: auto;
  right: 0;
}

.has-xp-pop:hover .xp-pop,
.has-xp-pop:focus-within .xp-pop,
.has-xp-pop.xp-pop-open .xp-pop {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity var(--motion-duration-fast) var(--motion-ease-out),
              transform var(--motion-duration-fast) var(--motion-ease-out),
              visibility 0s linear;
}

.xp-pop__row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.xp-pop__dot {
  width: var(--space-2);
  height: var(--space-2);
  border-radius: var(--radius-pill);
  background: var(--badge-icon);
}

.xp-pop__row span {
  color: var(--text-secondary);
}

.xp-pop__row strong {
  color: var(--text-primary);
  text-align: right;
}

/* Dashboard refresh: compact workspace inspired by a modern task dashboard. */
.dash-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.dash-side-metric__value,
.dash-todo-body strong,
.dash-leaderboard__name strong,
.dash-profile-stat strong,
.dash-learn-card h3,
.dash-stat-copy h3 {
  color: var(--text-primary);
}

.dash-live-icon {
  width: var(--icon-badge-size);
  height: var(--icon-badge-size);
  flex: 0 0 var(--icon-badge-size);
  display: grid;
  place-items: center;
  border-radius: var(--radius-badge);
  background: var(--badge-icon);
  color: var(--danger-contrast);
  box-shadow: var(--badge-gloss), var(--shadow-sm);
}

.dash-live-icon svg {
  width: var(--space-5);
  height: var(--space-5);
}

.dash-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(var(--dash-side-min), var(--dash-side-max));
  gap: var(--space-4);
  align-items: stretch;
}

.dash-side-grid,
.dash-main-stack,
.dash-panel {
  display: grid;
  gap: var(--space-4);
}

.dash-main-stack {
  grid-template-rows: auto 1fr;
}

.dash-pulse-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(var(--dash-side-min), 0.95fr);
  gap: var(--space-4);
  align-items: stretch;
}

.dash-pulse-column {
  display: grid;
  grid-template-rows: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--space-4);
}

.dash-side-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.dash-side-metric {
  min-width: 0;
  display: grid;
  gap: var(--space-2);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.dash-side-metric--featured {
  border-color: color-mix(in srgb, var(--accent) 72%, var(--border));
  background: linear-gradient(135deg, var(--accent), var(--accent-hover));
  color: var(--accent-contrast);
}

.dash-side-metric__icon {
  width: var(--icon-badge-sm-size);
  height: var(--icon-badge-sm-size);
  display: grid;
  place-items: center;
  border-radius: var(--radius-sm);
  border: var(--border-width) solid color-mix(in srgb, var(--badge-icon) 48%, var(--border));
  background: var(--badge-icon);
  color: var(--danger-contrast);
  box-shadow: var(--badge-gloss), var(--shadow-sm);
}

.dash-side-metric--featured .dash-side-metric__icon {
  border-color: color-mix(in srgb, var(--accent-contrast) 42%, transparent);
  background: color-mix(in srgb, var(--accent-contrast) 16%, transparent);
  color: var(--accent-contrast);
}

.dash-side-metric__icon svg {
  width: var(--space-4);
  height: var(--space-4);
}

.dash-side-metric__label {
  color: var(--text-secondary);
}

.dash-side-metric--featured .dash-side-metric__label,
.dash-side-metric--featured .dash-side-metric__value {
  color: var(--accent-contrast);
}

.dash-side-metric__value {
  font-size: var(--text-h1);
  line-height: var(--lh-h1);
  font-weight: 700;
}

.dash-panel {
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.dash-panel--pulse {
  align-content: start;
}

.dash-panel__head h2 {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.dash-panel__head svg {
  width: var(--space-4);
  height: var(--space-4);
  color: var(--text-secondary);
}

.dash-pulse-list {
  display: grid;
  gap: var(--space-2);
}

.dash-pulse-list--compact {
  gap: var(--space-1);
}

.dash-pulse-item {
  min-width: 0;
  width: 100%;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
  text-align: left;
  transition:
    border-color var(--motion-duration-fast) var(--motion-ease-out),
    background-color var(--motion-duration-fast) var(--motion-ease-out),
    transform var(--motion-duration-fast) var(--motion-ease-out);
}

.dash-pulse-item:hover {
  border-color: var(--accent);
  background: var(--accent-tint);
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
}

.dash-pulse-item__copy {
  min-width: 0;
  display: grid;
  gap: var(--space-1);
}

.dash-pulse-item__copy strong,
.dash-pulse-item__copy span,
.dash-pulse-item__signal {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-pulse-item__copy strong {
  color: var(--text-primary);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
}

.dash-pulse-item__signal {
  max-width: calc(var(--touch-target) * 2.6);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
  font-weight: 700;
}

.dash-todo-body,
.dash-learn-card {
  display: grid;
  gap: var(--space-1);
  min-width: 0;
}

.dash-todo-body strong,
.dash-learn-card h3,
.dash-todo-body span,
.dash-leaderboard__name strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-stat-widget {
  display: grid;
  justify-items: center;
  gap: var(--space-4);
  text-align: center;
}

.dash-stat-orbit {
  position: relative;
  width: calc(var(--avatar-48) * 2 + var(--space-4));
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  padding: var(--space-2);
  border-radius: var(--radius-pill);
  background: conic-gradient(var(--accent) var(--stat-progress), var(--surface-alt) 0);
}

.dash-stat-orbit::before {
  content: "";
  position: absolute;
  inset: var(--space-2);
  border-radius: inherit;
  background: var(--surface);
  border: var(--border-width) solid var(--border);
}

.dash-stat-orbit .avatar {
  position: relative;
  z-index: 1;
}

.dash-stat-copy {
  display: grid;
  gap: var(--space-1);
  max-width: var(--module-detail-width);
}

.dash-profile-stats {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.dash-profile-stat {
  display: grid;
  gap: var(--space-1);
  min-width: 0;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
  text-align: left;
}

.dash-profile-stat strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
}

.dash-week-chart {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: end;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.dash-week-bar {
  min-width: 0;
  min-height: calc(var(--touch-target) * 2 + var(--space-5));
  display: grid;
  grid-template-rows: 1fr auto;
  justify-items: center;
  gap: var(--space-2);
  color: var(--text-secondary);
}

.dash-week-bar__track {
  width: 100%;
  height: calc(var(--touch-target) * 2);
  display: flex;
  align-items: flex-end;
}

.dash-week-bar__fill {
  width: 100%;
  height: var(--bar-value);
  min-height: var(--space-5);
  border-radius: var(--radius-md);
  background:
    repeating-linear-gradient(
      135deg,
      color-mix(in srgb, var(--accent) 22%, transparent) 0,
      color-mix(in srgb, var(--accent) 22%, transparent) var(--border-width),
      var(--surface-alt) var(--border-width),
      var(--surface-alt) var(--space-2)
    );
  transition: height var(--motion-duration-slower) var(--motion-ease-out);
}

.dash-week-bar__fill--active {
  background: linear-gradient(180deg, var(--accent-hover), var(--accent));
}

.dash-todo-list,
.dash-leaderboard {
  display: grid;
  gap: var(--space-2);
}

.dash-todo-list {
  max-height: var(--dash-todo-max-height);
  overflow-y: hidden;
}

.dash-todo-list--scrollable {
  overflow-y: auto;
  padding-right: var(--space-1);
}

.dash-todo-add {
  width: var(--touch-target);
  height: var(--touch-target);
  display: grid;
  place-items: center;
  border-radius: var(--radius-pill);
  border: var(--border-width) solid color-mix(in srgb, var(--accent) 42%, var(--border));
  background: var(--accent-tint);
  color: var(--accent);
  transition: background-color var(--motion-duration-fast) var(--motion-ease-out),
              color var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out),
              transform var(--motion-duration-fast) var(--motion-ease-out),
              box-shadow var(--motion-duration-fast) var(--motion-ease-out);
}

.dash-todo-add:hover,
.dash-todo-add:focus-visible {
  border-color: var(--accent);
  background: var(--accent);
  color: var(--accent-contrast);
  box-shadow: var(--badge-gloss), var(--shadow-sm);
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
}

.dash-todo-add svg {
  width: var(--space-5);
  height: var(--space-5);
}

.dash-todo-item {
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
  min-height: var(--dash-todo-row-height);
  min-width: 0;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
  cursor: pointer;
  transition: transform var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out),
              background-color var(--motion-duration-fast) var(--motion-ease-out);
}

.dash-todo-item:hover {
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
  border-color: var(--border-strong);
  background: var(--surface);
}

.dash-todo-check {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.dash-todo-box {
  width: var(--space-6);
  height: var(--space-6);
  display: grid;
  place-items: center;
  border-radius: var(--radius-sm);
  border: var(--border-width) solid var(--border-strong);
  background: var(--surface);
  color: transparent;
  transition: background-color var(--motion-duration-fast) var(--motion-ease-out),
              border-color var(--motion-duration-fast) var(--motion-ease-out),
              color var(--motion-duration-fast) var(--motion-ease-out),
              transform var(--motion-duration-fast) var(--motion-ease-out),
              box-shadow var(--motion-duration-fast) var(--motion-ease-out);
}

.dash-todo-box svg {
  width: var(--space-4);
  height: var(--space-4);
}

.dash-todo-check:focus-visible + .dash-todo-box {
  border-color: var(--accent);
  box-shadow: 0 0 0 var(--focus-ring-width) var(--accent-tint);
}

.dash-todo-check:checked + .dash-todo-box {
  border-color: var(--accent);
  background: var(--accent);
  color: var(--accent-contrast);
  box-shadow: var(--badge-gloss);
  transform: scale(var(--motion-scale-press));
}

.dash-todo-item--done {
  color: var(--text-muted);
}

.dash-todo-item--done strong {
  color: var(--text-muted);
  text-decoration: line-through;
}

.todo-manager {
  display: grid;
  gap: var(--space-4);
}

.todo-manager__intro {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.todo-manager__intro > div,
.todo-manager__row > span {
  display: grid;
  gap: var(--space-1);
  min-width: 0;
}

.todo-manager__intro strong {
  color: var(--text-primary);
}

.todo-manager__form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) max-content;
  align-items: end;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.todo-manager__subhead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-inline: var(--space-1);
}

.todo-manager__list {
  display: grid;
  gap: var(--space-2);
  max-height: calc((var(--dash-todo-row-height) * 4) + (var(--space-2) * 3));
  overflow-y: auto;
  padding-right: var(--space-1);
}

.todo-manager__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.todo-manager__row strong,
.todo-manager__row span span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-leaderboard__row {
  display: grid;
  grid-template-columns: var(--dash-rank-size) auto minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface-alt);
}

.dash-panel--leaderboard {
  align-content: start;
}

.dash-leaderboard__row--self {
  border-color: var(--accent);
  background: var(--accent-tint);
}

.dash-leaderboard__rank {
  width: var(--dash-rank-size);
  height: var(--dash-rank-size);
  display: grid;
  place-items: center;
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
  font-weight: 700;
}

.dash-leaderboard__name {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
}

.dash-leaderboard__name strong {
  min-width: 0;
}

.corps-mini-badge {
  flex: 0 0 auto;
  width: var(--corps-mini-badge-size);
  height: var(--corps-mini-badge-size);
  display: grid;
  place-items: center;
  border-radius: var(--radius-pill);
  background: var(--badge-fill);
  color: var(--badge-icon);
}

.corps-mini-badge svg {
  width: calc(var(--corps-mini-badge-size) * 0.6);
  height: calc(var(--corps-mini-badge-size) * 0.6);
}

.dash-leaderboard__xp {
  color: var(--text-primary);
  white-space: nowrap;
}

.dash-learn-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--dash-learn-min), 1fr));
  gap: var(--space-4);
}

.dash-learn-card {
  display: grid;
  align-content: start;
  gap: var(--space-3);
  min-width: 0;
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
  text-align: left;
  transition: border-color var(--motion-duration-fast) var(--motion-ease-out),
              transform var(--motion-duration-fast) var(--motion-ease-out);
}

.dash-learn-card:hover {
  border-color: var(--border-strong);
  transform: translateY(calc(-1 * var(--motion-distance-2xs)));
}

.dash-learn-card .progress-track {
  height: var(--dash-meter-height);
}

.dash-course-art {
  position: relative;
  height: var(--course-media-height);
  min-height: 0;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
  grid-template-rows: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--space-2);
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  background: var(--badge-fill);
  color: var(--badge-icon);
}

.dash-course-art__block {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: var(--radius-sm);
  border: var(--border-width) solid var(--border);
  background: var(--surface);
}

.dash-course-art__block--main {
  grid-row: 1 / 3;
}

.dash-course-art__block--main svg {
  width: var(--space-8);
  height: var(--space-8);
}

.dash-course-art__block--top {
  background: var(--surface-alt);
}

.dash-course-art__block--bottom {
  background: var(--badge-fill);
}

.dash-course-art__heart {
  position: absolute;
  top: var(--space-2);
  right: var(--space-2);
  width: var(--space-8);
  height: var(--space-8);
  display: grid;
  place-items: center;
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--text-secondary);
  border: var(--border-width) solid var(--border);
}

.dash-course-art__heart svg {
  width: var(--space-4);
  height: var(--space-4);
}

.dash-learn-card__title-row,
.dash-course-meta,
.dash-course-mentor,
.dash-rating {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.dash-learn-card__title-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-3);
  justify-content: stretch;
  align-items: flex-start;
}

.dash-learn-card__title-row h3 {
  min-width: 0;
  min-height: calc(var(--lh-body-sm) * 2);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
  font-weight: 700;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  white-space: normal;
}

.dash-rating {
  flex: 0 0 auto;
  gap: var(--space-1);
  color: var(--text-primary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
  font-weight: 700;
}

.dash-rating svg {
  width: var(--space-3);
  height: var(--space-3);
  color: var(--warning);
  fill: currentColor;
}

.dash-course-mentor {
  color: var(--text-secondary);
  min-width: 0;
}

.dash-course-mentor .avatar {
  width: var(--space-6);
  height: var(--space-6);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.dash-course-mentor .text-caption {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-course-meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  justify-content: stretch;
  color: var(--text-secondary);
  font-size: var(--text-caption);
  line-height: var(--lh-caption);
}

.dash-course-meta span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dash-course-meta svg {
  width: var(--space-4);
  height: var(--space-4);
}

.dash-course-meta strong {
  justify-self: end;
  color: var(--text-secondary);
  font-weight: 600;
  white-space: nowrap;
}

@media (max-width: 1024px) {
  .learning-layout,
  .dash-workspace,
  .dash-pulse-grid {
    grid-template-columns: 1fr;
  }

  .dash-pulse-column {
    grid-template-rows: auto;
  }

  .learning-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .stream-governance {
    grid-template-columns: 1fr;
  }

  .stream-hero,
  .stream-track-detail__hero,
  .stream-home-grid,
  .opportunity-hero,
  .opportunity-detail__hero,
  .opportunity-detail__grid,
  .opportunity-career-strip {
    grid-template-columns: 1fr;
  }

  .course-shell {
    grid-template-columns: 1fr;
  }

  .course-sidebar {
    position: static;
    max-height: none;
  }

  .course-overview-grid,
  .course-focus-card {
    grid-template-columns: 1fr;
  }

  .module-detail {
    position: static;
  }
}

@media (max-width: 640px) {
  .flow-page {
    padding: var(--space-4);
  }

  .settings-form__grid {
    grid-template-columns: 1fr;
  }

  .settings-skill-form {
    flex-direction: column;
    align-items: stretch;
  }

  .settings-cv-card,
  .settings-toggle-row {
    flex-wrap: wrap;
  }

  .dash-pulse-item {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .dash-pulse-item__signal {
    grid-column: 2 / 3;
    max-width: none;
  }

  .opportunity-search,
  .opportunity-card__header,
  .opportunity-detail__identity,
  .opportunity-fit-block,
  .opportunity-improve-row,
  .opportunity-cpd-item,
  .opportunity-route-card,
  .opportunity-apply-modal__intro,
  .opportunity-coach-card {
    grid-template-columns: 1fr;
  }

  .opportunity-hero,
  .opportunity-detail__hero {
    padding: var(--space-4);
  }

  .opportunity-score {
    justify-self: start;
  }

  .opportunity-hero__actions .btn,
  .opportunity-search .btn,
  .opportunity-apply-panel .btn,
  .opportunity-route-card .btn,
  .opportunity-route-card a {
    width: 100%;
  }

  .opportunity-filter-group .segmented {
    width: 100%;
  }

  .portfolio-hero__identity {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .portfolio-hero__actions {
    grid-column: 1 / 3;
    flex-direction: row;
    flex-wrap: wrap;
  }

  .portfolio-hero__actions .btn {
    flex: 1 1 auto;
  }

  .community-composer {
    flex-direction: column;
  }

  .community-composer__foot {
    flex-direction: column;
    align-items: stretch;
  }

  .mentor-card {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .mentor-card > .pill {
    grid-column: 1 / 3;
    justify-self: start;
  }

  .mentor-session-row {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .mentor-session-row > .status-label {
    grid-column: 1 / 3;
  }

  .messages-shell {
    grid-template-columns: 1fr;
    height: auto;
  }

  .messages-list-pane {
    display: grid;
  }

  .messages-thread-pane {
    display: none;
  }

  .messages-shell--thread-open .messages-list-pane {
    display: none;
  }

  .messages-shell--thread-open .messages-thread-pane {
    display: grid;
    min-height: 70vh;
  }

  .messages-thread__back {
    display: inline-flex;
  }

  .portfolio-scores,
  .portfolio-overview {
    grid-template-columns: 1fr;
  }

  .login-panel {
    grid-template-columns: 1fr;
  }

  .section-heading,
  .learning-library__hero,
  .learning-filterbar,
  .filter-bar,
  .quest-card__top {
    align-items: flex-start;
    flex-direction: column;
  }

  .learning-summary,
  .learning-trackbar,
  .learning-course-grid {
    grid-template-columns: 1fr;
  }

  .learning-library__hero .btn,
  .learning-library__actions,
  .learning-library__actions .btn,
  .learning-library__top-actions,
  .learning-library__top-actions .btn,
  .learning-filterbar .segmented {
    width: 100%;
  }

  .filter-bar .segmented {
    width: 100%;
    overflow-x: auto;
  }

  .stream-status-card,
  .stream-request-card,
  .stream-archive-card,
  .stream-hero__main,
  .stream-progress-row,
  .stream-rule-note {
    grid-template-columns: 1fr;
  }

  .stream-page-actions,
  .stream-page-actions .btn,
  .stream-hero__actions,
  .stream-hero__actions .btn,
  .stream-panel__head,
  .stream-panel__head .btn {
    width: 100%;
  }

  .stream-page-actions,
  .stream-panel__head {
    align-items: flex-start;
    flex-direction: column;
  }

  .stream-hero__metrics,
  .stream-activity-list,
  .stream-track-grid,
  .stream-course-grid {
    grid-template-columns: 1fr;
  }

  .stream-select-card {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .stream-select-card__meta {
    grid-column: 2 / 3;
    justify-content: flex-start;
  }

  .stream-change-form .btn,
  .stream-change-form--modal .btn,
  .stream-request-card__actions,
  .stream-request-card__actions .btn,
  .stream-archive-card .btn {
    width: 100%;
  }

  .stream-request-card__actions {
    justify-content: flex-start;
  }

  .screen-panel,
  .module-detail {
    padding: var(--space-5);
  }

  .dash-panel__head {
    align-items: flex-start;
    flex-direction: column;
  }

  .dash-profile-stats {
    grid-template-columns: 1fr;
  }

  .todo-manager__form {
    grid-template-columns: 1fr;
  }

  .dash-leaderboard__row {
    grid-template-columns: var(--dash-rank-size) auto minmax(0, 1fr);
  }

  .dash-leaderboard__xp {
    grid-column: 3 / 4;
  }

  .challenge-card__foot,
  .challenge-cta,
  .challenge-mine {
    align-items: flex-start;
    flex-direction: column;
  }

  .submission-row {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .clap-btn {
    grid-column: 1 / 3;
    justify-content: center;
  }

  .course-shell,
  .course-main,
  .course-sidebar {
    gap: var(--space-4);
  }

  .course-sidebar,
  .course-panel {
    border-radius: var(--radius-md);
  }

  .course-lesson-head {
    align-items: flex-start;
    grid-template-columns: 1fr;
  }

  .course-lesson-actions {
    justify-content: flex-start;
  }

  .course-player {
    min-height: calc(var(--touch-target) * 8);
  }

  .course-player__controls {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .course-player__controls button:nth-of-type(2),
  .course-player__controls button:nth-of-type(3) {
    display: none;
  }

  .course-note-form,
  .course-community-form,
  .course-reviews,
  .course-note-row,
  .course-question-row,
  .course-resource-row {
    grid-template-columns: 1fr;
  }

  .course-community__head {
    align-items: flex-start;
    flex-direction: column;
  }

  .course-note-form,
  .course-community-form {
    align-items: stretch;
  }

  .course-community-replies {
    padding-left: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .module-card,
  .stream-card,
  .quest-card,
  .challenge-card,
  .learning-course-card,
  .learning-track-chip,
  .dash-todo-item,
  .dash-learn-card,
  .dash-pulse-item,
  .course-tab,
  .course-lesson-row,
  .course-resource-row,
  .clap-btn,
  .badge-tile,
  .opportunity-card {
    transform: none;
  }

  .xp-pop {
    transform: none;
    transition: opacity var(--motion-duration-fast) linear,
                visibility 0s linear var(--motion-duration-fast);
  }

  .has-xp-pop:hover .xp-pop,
  .has-xp-pop:focus-within .xp-pop,
  .has-xp-pop.xp-pop-open .xp-pop {
    transform: none;
    transition: opacity var(--motion-duration-fast) linear, visibility 0s linear;
  }
}
