/* Контент зоны менти. Токены и база — /css/site-tokens.css; шапка — site-header.css + site-header.js */
.mentee-main {
  flex: 1 0 auto;
  padding-block: clamp(2rem, 5vw, 3rem) var(--sp8);
}
.mentee-page-title {
  font-family: var(--fh);
  font-size: var(--text-2xl);
  font-weight: 600;
  font-style: italic;
  line-height: 1.12;
  letter-spacing: -0.03em;
  margin-bottom: var(--sp4);
}
.mentee-lead {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  max-width: 54ch;
  line-height: 1.7;
  font-style: italic;
  margin-bottom: var(--sp8);
}
.mentee-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--sp5) var(--sp6);
  margin-bottom: var(--sp5);
  box-shadow: var(--shadow-sm);
}
.mentee-card h2 {
  font-family: var(--fb);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--sp3);
}
.mentee-card ul {
  margin: 0.5rem 0 0 1.1rem;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.mentee-card li + li {
  margin-top: 0.35rem;
}
.mentee-card p {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.55;
}
.mentee-card a.mentee-inline-link {
  color: var(--color-primary);
  font-weight: 500;
  text-decoration: underline;
}
.mentee-card a.mentee-inline-link:hover {
  color: var(--color-primary-hover);
}
.mentee-account-admin-view {
  margin: 0 0 var(--sp4);
  padding: 0.7rem 1rem;
  border: 1px solid color-mix(in srgb, var(--color-primary) 28%, var(--color-border));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-primary) 8%, var(--color-surface));
  color: var(--color-text);
  font-size: var(--text-sm);
  font-weight: 700;
  text-align: center;
}
.mentee-account-peer-view {
  margin: 0 0 var(--sp4);
  padding: 0.7rem 1rem;
  border: 1px solid color-mix(in srgb, var(--color-border) 80%, var(--color-primary));
  border-radius: var(--radius-md);
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: 600;
  text-align: center;
}
/* Pill-кнопка как плашки в шапке (mail-link-header) */
a.mentee-pill-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp2);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-primary);
  background: var(--color-primary-hl);
  padding: var(--sp2) var(--sp4);
  border-radius: 100px;
  text-decoration: none;
  transition: opacity var(--tr);
  flex-shrink: 0;
}
a.mentee-pill-btn:hover {
  opacity: 0.85;
}
a.mentee-pill-btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  opacity: 1;
}
.mentee-card .mentee-card-cta {
  margin-top: var(--sp4);
  margin-bottom: 0;
}
.mentee-card .mentee-card-meta {
  margin-top: var(--sp3);
  margin-bottom: 0;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.55;
}

/* Хаб /docs/: секции «Подготовка» / «Практика» и плитки внутри */
.mentee-card.mentee-docs-hub-section > h2.mentee-docs-hub-section-title {
  font-family: var(--fh);
  font-size: var(--text-lg);
  font-weight: 600;
  font-style: italic;
  letter-spacing: -0.02em;
  color: var(--color-text);
  margin-bottom: var(--sp5);
  line-height: 1.2;
}
.mentee-docs-hub-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 15.5rem), 1fr));
  gap: var(--sp4);
  align-items: stretch;
}
a.mentee-docs-hub-tile {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  margin: 0;
  padding: var(--sp4) var(--sp5);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: none;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition:
    border-color var(--tr),
    background-color var(--tr),
    box-shadow var(--tr);
}
a.mentee-docs-hub-tile:visited {
  color: inherit;
}
a.mentee-docs-hub-tile:hover {
  border-color: rgba(1, 105, 111, 0.45);
  background: var(--color-primary-hl);
  box-shadow: var(--shadow-sm);
}
a.mentee-docs-hub-tile:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.mentee-docs-hub-tile-title {
  font-family: var(--fb);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  margin: 0 0 var(--sp3);
  line-height: 1.35;
  text-decoration: none;
}
a.mentee-docs-hub-tile:has(p) .mentee-docs-hub-tile-title {
  margin-bottom: var(--sp3);
}
a.mentee-docs-hub-tile:not(:has(p)) .mentee-docs-hub-tile-title {
  margin-bottom: 0;
}
a.mentee-docs-hub-tile p {
  margin: 0;
  flex: 1 1 auto;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.55;
}

/* Общий прогресс на /docs/ */
.mentee-docs-hub-total {
  margin-bottom: var(--sp6);
  padding: var(--sp4) var(--sp5);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.mentee-docs-hub-total-head {
  display: flex;
  flex-direction: column;
  gap: var(--sp2);
  margin-bottom: var(--sp3);
}
.mentee-docs-hub-total-head-row {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp3);
}
.mentee-docs-hub-total-title {
  font-family: var(--fb);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  margin: 0;
}
.mentee-docs-hub-total-pct {
  font-family: var(--fb);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-primary);
  margin: 0;
  font-variant-numeric: tabular-nums;
}
.mentee-docs-hub-total-pct span {
  font-variant-numeric: tabular-nums;
}
.mentee-docs-hub-optin {
  display: inline-flex;
  align-items: center;
  gap: var(--sp2);
  width: fit-content;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.35;
  cursor: pointer;
  user-select: none;
}
.mentee-docs-hub-optin input {
  appearance: none;
  position: relative;
  width: 2.85rem;
  height: 1.55rem;
  margin: 0;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface-offset);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.03);
  transition:
    background-color var(--tr),
    border-color var(--tr),
    box-shadow var(--tr);
  cursor: pointer;
}
.mentee-docs-hub-optin input::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.16rem;
  width: 1.22rem;
  height: 1.22rem;
  border-radius: 50%;
  background: var(--color-bg);
  box-shadow: var(--shadow-sm);
  transform: translateY(-50%);
  transition: transform 0.2s ease, background-color var(--tr);
}
.mentee-docs-hub-optin input:checked {
  background: linear-gradient(90deg, var(--color-primary), rgba(1, 105, 111, 0.8));
  border-color: rgba(1, 105, 111, 0.5);
}
.mentee-docs-hub-optin input:checked::before {
  transform: translate(1.28rem, -50%);
  background: #fff;
}
.mentee-docs-hub-optin input:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--color-primary) 55%, transparent);
  outline-offset: 2px;
}
.mentee-docs-hub-optin:focus-within {
  color: var(--color-text);
}
.mentee-docs-hub-total-bar-wrap,
.mentee-progress-with-streak {
  display: flex;
  align-items: center;
  gap: var(--sp3);
}
.mentee-docs-hub-total-bar-wrap {
  margin-bottom: var(--sp2);
}
.mentee-docs-hub-total-bar,
.mentee-progress-with-streak > .mentee-docs-hub-total-bar,
.mentee-progress-summary > .mentee-progress-summary-bar {
  flex: 1 1 auto;
  min-width: 0;
}
.mentee-docs-hub-total-bar {
  height: 0.5rem;
  border-radius: 100px;
  background: var(--color-border);
  overflow: hidden;
}
.mentee-streak-chip {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-width: 3.1rem;
  line-height: 1.1;
  color: var(--color-text);
}
.mentee-streak-chip[hidden] {
  display: none !important;
}
.mentee-streak-chip-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  line-height: 1;
}
.mentee-streak-chip-gif {
  display: block;
  width: 2rem;
  height: 2rem;
  object-fit: contain;
  flex-shrink: 0;
}
.mentee-streak-chip-gif[hidden] {
  display: none !important;
}
.mentee-streak-chip-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0;
  min-width: 1.55rem;
  line-height: 1;
  text-align: center;
}
.mentee-streak-chip-value {
  display: block;
  width: 100%;
  font-family: var(--fb);
  font-size: 1rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  line-height: 1.05;
  text-align: center;
}
.mentee-streak-chip-label {
  display: block;
  width: 100%;
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--color-text-muted);
  text-transform: lowercase;
  line-height: 1.05;
  text-align: center;
}
.mentee-streak-chip--compact .mentee-streak-chip-icon,
.mentee-streak-chip--compact .mentee-streak-chip-gif {
  width: 1.65rem;
  height: 1.65rem;
}
.mentee-streak-chip--compact .mentee-streak-chip-value {
  font-size: 0.82rem;
}
.mentee-streak-chip--compact .mentee-streak-chip-label {
  font-size: 0.62rem;
}
.mentee-streak-chip--active .mentee-streak-chip-gif {
  opacity: 1;
  filter: none;
}
.mentee-streak-chip--inactive .mentee-streak-chip-gif,
.mentee-streak-chip--zero .mentee-streak-chip-gif {
  opacity: 0.36;
  filter: grayscale(0.8) saturate(0.3) brightness(0.9);
}
.mentee-streak-chip--inactive .mentee-streak-chip-value,
.mentee-streak-chip--zero .mentee-streak-chip-value {
  color: var(--color-text-muted);
}
.mentee-docs-hub-total-fill {
  display: block;
  height: 100%;
  width: 0%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-primary), rgba(1, 105, 111, 0.75));
  transition: width 0.35s ease;
}
.mentee-docs-hub-total-note {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.45;
}
.mentee-progress-breakdown {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.2rem 0;
}
.mentee-progress-breakdown-item {
  white-space: nowrap;
}
.mentee-progress-breakdown-item + .mentee-progress-breakdown-item::before {
  content: "·";
  margin: 0 0.45rem;
  color: var(--color-text-muted);
  font-weight: 400;
}
.mentee-progress-breakdown-item strong {
  font-weight: 700;
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
}
.mentee-docs-hub-program-days {
  margin: var(--sp2) 0 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.45;
}
.mentee-docs-hub-total[data-state="loading"] .mentee-docs-hub-total-fill {
  opacity: 0.45;
}
html[data-theme="dark"] .mentee-docs-hub-total-fill {
  background: linear-gradient(90deg, var(--color-primary), rgba(79, 152, 163, 0.85));
}

.mentee-docs-hub-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--sp2);
  margin: 0 0 var(--sp4);
  padding: var(--sp2);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface-offset);
}
.mentee-docs-hub-tab {
  appearance: none;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: var(--sp2) var(--sp4);
  background: transparent;
  color: var(--color-text-muted);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}
.mentee-docs-hub-tab.is-active {
  background: var(--color-primary);
  color: #fff;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--color-primary) 35%, transparent);
}
.mentee-docs-hub-tab:hover:not(.is-active) {
  color: var(--color-text);
  border-color: var(--color-border);
  background: color-mix(in srgb, var(--color-surface) 88%, var(--color-primary) 12%);
}
.mentee-docs-hub-tab:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.mentee-docs-hub-leaderboard-note {
  margin: 0 0 var(--sp3);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.45;
}
.mentee-docs-hub-leaderboard-state {
  display: grid;
  gap: var(--sp3);
}
.mentee-docs-hub-leaderboard-empty {
  margin: 0;
  padding: var(--sp4);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-primary) 4%, var(--color-surface));
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.55;
}
.mentee-docs-hub-leaderboard-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--sp3);
}
.mentee-docs-hub-leaderboard-item {
  padding: var(--sp4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.mentee-docs-hub-leaderboard-item.is-self {
  border-color: color-mix(in srgb, var(--color-primary) 32%, var(--color-border));
  background: color-mix(in srgb, var(--color-primary) 4%, var(--color-bg));
}
.mentee-docs-hub-leaderboard-item.is-clickable {
  cursor: pointer;
  transition: border-color var(--tr), box-shadow var(--tr), transform var(--tr);
}
.mentee-docs-hub-leaderboard-item.is-clickable:hover,
.mentee-docs-hub-leaderboard-item.is-clickable:focus-visible {
  border-color: color-mix(in srgb, var(--color-primary) 42%, var(--color-border));
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
  outline: none;
}
.mentee-docs-hub-leaderboard-item:nth-child(1) {
  border-color: color-mix(in srgb, #c9a227 48%, var(--color-border));
  background:
    radial-gradient(circle at 0% 0%, color-mix(in srgb, #d7b847 14%, transparent), transparent 38%),
    var(--color-bg);
}
.mentee-docs-hub-leaderboard-item:nth-child(2) {
  border-color: color-mix(in srgb, #9ca3af 40%, var(--color-border));
}
.mentee-docs-hub-leaderboard-item:nth-child(3) {
  border-color: color-mix(in srgb, #b7791f 34%, var(--color-border));
}
.mentee-docs-hub-leaderboard-row {
  display: grid;
  grid-template-columns: auto auto minmax(0, 1fr) auto;
  gap: var(--sp3);
  align-items: center;
}
.mentee-docs-hub-leaderboard-avatar {
  position: relative;
  display: inline-flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary), rgba(1, 105, 111, 0.72));
  color: #fff;
  font-family: var(--fb);
  font-size: var(--text-sm);
  font-weight: 800;
  letter-spacing: -0.04em;
  box-shadow: var(--shadow-sm);
}
.mentee-docs-hub-leaderboard-avatar.has-image {
  background: var(--color-surface-offset);
}
.mentee-docs-hub-leaderboard-avatar img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.mentee-account-avatar-privacy {
  display: inline-flex;
  align-items: flex-start;
  gap: var(--sp2);
  margin: var(--sp3) 0 0;
  max-width: 14rem;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: 1.45;
  cursor: pointer;
  text-align: left;
}
.mentee-account-avatar-privacy input {
  margin-top: 0.15rem;
  flex-shrink: 0;
}
.mentee-account-avatar-privacy-text {
  display: block;
}
.mentee-docs-hub-leaderboard-rank {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  width: 2.45rem;
  height: 2.45rem;
  padding: 0;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));
  color: var(--color-primary);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.mentee-docs-hub-leaderboard-medal {
  font-size: 1.45rem;
  line-height: 1;
}
.mentee-docs-hub-leaderboard-item:nth-child(1) .mentee-docs-hub-leaderboard-rank {
  background: linear-gradient(135deg, #f2d675, #c9a227);
  color: #3b2a00;
}
.mentee-docs-hub-leaderboard-item:nth-child(2) .mentee-docs-hub-leaderboard-rank {
  background: linear-gradient(135deg, #edf1f4, #b9c2ca);
  color: #2f3b44;
}
.mentee-docs-hub-leaderboard-item:nth-child(3) .mentee-docs-hub-leaderboard-rank {
  background: linear-gradient(135deg, #f0c99b, #bd7f45);
  color: #3f240a;
}
.mentee-docs-hub-leaderboard-main {
  min-width: 0;
  display: grid;
  gap: var(--sp2);
}
.mentee-docs-hub-leaderboard-name-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp2);
}
.mentee-docs-hub-leaderboard-name {
  margin: 0;
  font-family: var(--fb);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.35;
}
.mentee-docs-hub-leaderboard-self {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.5rem;
  padding: 0 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-primary) 12%, var(--color-surface));
  color: var(--color-primary);
  font-size: var(--text-xs);
  font-weight: 700;
}
.mentee-docs-hub-leaderboard-badges,
.mentee-account-meta-badges {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
}
.mentee-account-meta-badges {
  width: 100%;
}
.mentee-docs-hub-leaderboard-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  min-height: 1.5rem;
  padding: 0 0.55rem;
  border-radius: 999px;
  font-size: var(--text-xs);
  font-weight: 700;
  line-height: 1.2;
  color: color-mix(in srgb, var(--color-text) 88%, var(--color-primary));
  background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));
  border: 1px solid color-mix(in srgb, var(--color-primary) 18%, var(--color-border));
  white-space: nowrap;
}
.mentee-docs-hub-leaderboard-badge--got_offer {
  color: color-mix(in srgb, #0b7285 82%, var(--color-text));
  background: color-mix(in srgb, #0b7285 10%, var(--color-surface));
  border-color: color-mix(in srgb, #0b7285 24%, var(--color-border));
}
.mentee-docs-hub-leaderboard-badge--started_work {
  color: color-mix(in srgb, #2b8a3e 82%, var(--color-text));
  background: color-mix(in srgb, #2b8a3e 10%, var(--color-surface));
  border-color: color-mix(in srgb, #2b8a3e 24%, var(--color-border));
}
.mentee-account-admin-badges {
  margin-bottom: var(--sp4);
}
.mentee-docs-hub-leaderboard-days {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.5rem;
  padding: 0 0.55rem;
  border-radius: 999px;
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-weight: 600;
  white-space: nowrap;
}
.mentee-docs-hub-leaderboard-streak {
  flex: 0 0 auto;
  padding: 0.1rem 0.45rem 0.1rem 0.35rem;
  border-radius: 999px;
  background: color-mix(in srgb, #f76707 8%, var(--color-surface));
  border: 1px solid color-mix(in srgb, #f76707 18%, var(--color-border));
}
.mentee-docs-hub-leaderboard-pct {
  margin: 0;
  font-family: var(--fb);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-primary);
  font-variant-numeric: tabular-nums;
}
.mentee-docs-hub-leaderboard-breakdown {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.45;
}
.mentee-docs-hub-leaderboard-bar {
  height: 0.45rem;
  border-radius: 999px;
  background: var(--color-border);
  overflow: hidden;
}
.mentee-docs-hub-leaderboard-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-primary), rgba(1, 105, 111, 0.75));
}
html[data-theme="dark"] .mentee-docs-hub-leaderboard-fill {
  background: linear-gradient(90deg, var(--color-primary), rgba(79, 152, 163, 0.85));
}

.mentee-account-page {
  display: grid;
  gap: var(--sp6);
}
.mentee-account-page:has(.mentee-account-admin-wrap:not([hidden])) {
  overflow: visible;
}
.mentee-account-layout {
  position: relative;
  width: 100%;
  min-width: 0;
}
.mentee-account-main {
  display: grid;
  gap: var(--sp6);
  min-width: 0;
  width: 100%;
}
.mentee-account-admin-wrap {
  position: absolute;
  right: calc(100% + clamp(var(--sp4), 2vw, var(--sp8)));
  top: 0;
  width: min(12.5rem, calc(100vw - 100% - 2 * var(--sp6)));
  min-width: 9rem;
  z-index: 1;
}
.mentee-account-admin-wrap[hidden],
.mentee-account-admin-mode-panel[hidden],
.mentee-account-history[hidden],
.mentee-account-grid[hidden],
.mentee-account-privacy-panel[hidden],
a.mentee-pill-btn[data-admin-only][hidden] {
  display: none !important;
}
/* Ссылка «Подпись договора» — скрыта до проверки /auth/me (класс ставит account-page.js). */
a.mentee-pill-btn[data-admin-only] {
  display: none !important;
}
html.account-admin-links-ready a.mentee-pill-btn[data-admin-only]:not([hidden]) {
  display: inline-flex !important;
}
.mentee-account-admin-sticky {
  position: sticky;
  top: 5.5rem;
  display: flex;
  flex-direction: column;
  gap: var(--sp3);
}
.mentee-account-admin-panel.mentee-account-privacy-panel {
  grid-template-columns: 1fr;
  gap: var(--sp3);
  padding: var(--sp3) var(--sp4);
}
.mentee-account-admin-panel .mentee-account-privacy-title {
  margin-bottom: 0;
}
.mentee-account-admin-mode-panel {
  display: block;
}
.mentee-account-admin-mode-panel[hidden] {
  display: none !important;
}
.mentee-account-hero {
  display: grid;
  gap: var(--sp5);
  align-items: stretch;
  overflow: hidden;
  padding: clamp(var(--sp5), 3vw, var(--sp8));
  background:
    radial-gradient(circle at 18% 18%, color-mix(in srgb, var(--color-primary) 18%, transparent), transparent 30%),
    radial-gradient(circle at 84% 10%, color-mix(in srgb, #d8b870 12%, transparent), transparent 28%),
    linear-gradient(135deg, var(--color-surface), color-mix(in srgb, var(--color-primary) 3%, var(--color-surface)));
}
.mentee-account-hero-layout,
.mentee-account-hero-stat {
  min-width: 0;
}
.mentee-account-hero-layout {
  display: grid;
  grid-template-columns: minmax(15rem, 17rem) minmax(0, 1fr);
  gap: clamp(var(--sp5), 4vw, var(--sp8));
  align-items: stretch;
}
.mentee-account-hero-id {
  display: grid;
  align-content: start;
  justify-items: center;
  align-items: center;
  gap: var(--sp4);
  text-align: center;
  min-width: 0;
  padding: var(--sp4);
  border-radius: calc(var(--radius-lg) + 0.35rem);
  background:
    linear-gradient(180deg, color-mix(in srgb, #fff 64%, transparent), transparent 70%),
    color-mix(in srgb, var(--color-primary) 4%, var(--color-surface));
  border: 1px solid color-mix(in srgb, var(--color-primary) 13%, var(--color-border));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 55%, transparent);
}
.mentee-account-hero-id-text {
  min-width: 0;
  max-width: 14rem;
}
.mentee-account-hero-side {
  display: grid;
  gap: var(--sp5);
  align-content: center;
  min-width: 0;
  padding: var(--sp5);
  border-radius: calc(var(--radius-lg) + 0.35rem);
  background: color-mix(in srgb, var(--color-surface) 82%, transparent);
  border: 1px solid color-mix(in srgb, var(--color-border) 75%, transparent);
}
.mentee-account-avatar {
  position: relative;
  display: inline-flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 14rem;
  height: 14rem;
  border-radius: 2.5rem;
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary), rgba(1, 105, 111, 0.72));
  color: #fff;
  font-family: var(--fb);
  font-size: 3rem;
  font-weight: 800;
  letter-spacing: -0.05em;
  box-shadow:
    0 1.25rem 2.75rem color-mix(in srgb, var(--color-primary) 18%, transparent),
    0 0 0 0.35rem color-mix(in srgb, var(--color-surface) 78%, transparent),
    0 0 0 0.5rem color-mix(in srgb, var(--color-primary) 16%, transparent);
}
.mentee-account-avatar.has-image {
  border-radius: 50%;
}
.mentee-account-avatar img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.mentee-account-kicker {
  margin: 0 0 var(--sp2);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.mentee-account-hero .mentee-account-name {
  margin: 0 0 var(--sp2);
  font-family: var(--fh);
  font-size: clamp(1.8rem, 2.8vw, 2.6rem);
  font-weight: 700;
  font-style: italic;
  line-height: 1.05;
  color: var(--color-text);
}
.mentee-account-sub {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.5;
  overflow-wrap: anywhere;
}
.mentee-account-name-controls {
  display: grid;
  justify-items: center;
  gap: var(--sp2);
  margin-top: var(--sp3);
}
.mentee-account-edit-name-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: 0.35rem 0.8rem;
  border: 1px solid color-mix(in srgb, var(--color-primary) 18%, var(--color-border));
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-primary) 6%, var(--color-surface));
  color: var(--color-primary);
  font: inherit;
  font-size: var(--text-xs);
  font-weight: 800;
  cursor: pointer;
}
.mentee-account-edit-name-btn:hover {
  background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));
}
.mentee-account-edit-name-btn:focus-visible,
.mentee-account-name-input:focus-visible,
.mentee-account-name-icon-btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.mentee-account-name-input {
  width: min(100%, 13.5rem);
  min-height: 2.6rem;
  padding: 0.2rem 0.7rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-surface) 92%, white);
  color: var(--color-text);
  font-family: var(--fh);
  font-size: clamp(1.45rem, 2.5vw, 2.2rem);
  font-style: italic;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  box-shadow: 0 10px 24px rgba(15, 77, 87, 0.08);
}
.mentee-account-name-form-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp2);
}
.mentee-account-name-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.15rem;
  height: 2.15rem;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface);
  color: var(--color-text);
  font: inherit;
  font-size: 1.15rem;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(15, 77, 87, 0.08);
}
.mentee-account-name-icon-btn--save {
  border-color: color-mix(in srgb, #148a55 34%, var(--color-border));
  background: color-mix(in srgb, #148a55 12%, var(--color-surface));
  color: #137248;
}
.mentee-account-name-icon-btn--cancel {
  border-color: color-mix(in srgb, #b64a4a 26%, var(--color-border));
  background: color-mix(in srgb, #b64a4a 8%, var(--color-surface));
  color: #9a3a3a;
}
.mentee-account-name-icon-btn:hover {
  transform: translateY(-1px);
}
.mentee-account-meta {
  display: flex;
  flex-direction: column;
  gap: var(--sp2);
  margin: 0;
}
.mentee-account-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp2);
  align-items: center;
}
.mentee-account-meta-pill {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0 0.75rem;
  border-radius: 999px;
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-weight: 600;
  white-space: nowrap;
}
.mentee-account-meta-pill[hidden] {
  display: none !important;
}
.mentee-account-meta-pill[data-role="account-rank-leaderboard"] {
  gap: 0.45rem;
  min-height: 2.5rem;
  padding: 0.2rem 1rem 0.2rem 0.45rem;
  background: linear-gradient(135deg, #fff7d6, color-mix(in srgb, var(--color-primary) 8%, var(--color-surface)));
  border: 1px solid color-mix(in srgb, #c9a227 42%, var(--color-border));
  color: var(--color-text);
  font-size: var(--text-sm);
  font-weight: 800;
  box-shadow: var(--shadow-sm);
}
.mentee-account-meta-pill--streak,
.mentee-account-meta-pill[data-role="account-streak"] {
  gap: 0;
  padding: 0.12rem 0.6rem 0.12rem 0.3rem;
  background: color-mix(in srgb, #f76707 8%, var(--color-surface));
  border: 1px solid color-mix(in srgb, #f76707 18%, var(--color-border));
  color: var(--color-text);
}
.mentee-account-meta-pill--streak .mentee-streak-chip,
.mentee-account-meta-pill[data-role="account-streak"] .mentee-streak-chip {
  min-width: 0;
  color: inherit;
}
.mentee-account-meta-pill--freezes,
.mentee-account-meta-pill[data-role="account-streak-freezes"] {
  background: color-mix(in srgb, #7ec8e8 16%, var(--color-surface));
  border: 1px solid color-mix(in srgb, #7ec8e8 30%, var(--color-border));
}
.mentee-account-meta-pill--program-rank,
.mentee-account-meta-pill[data-role="account-rank-program"] {
  gap: 0.35rem;
  min-height: 2rem;
  padding: 0.2rem 0.85rem;
  background: color-mix(in srgb, var(--color-primary) 8%, var(--color-surface));
  border: 1px solid color-mix(in srgb, var(--color-primary) 22%, var(--color-border));
  color: var(--color-text);
  font-size: var(--text-xs);
  font-weight: 700;
}
.mentee-account-rank-medal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: linear-gradient(135deg, #f2d675, #c9a227);
  font-size: 1.25rem;
  line-height: 1;
}
.mentee-account-rank-text {
  display: inline-block;
}
.mentee-account-nav {
  display: grid;
  gap: var(--sp5);
}
.mentee-account-nav-group {
  display: grid;
  gap: var(--sp3);
  padding: var(--sp4);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--color-surface-offset) 58%, transparent);
  border: 1px solid color-mix(in srgb, var(--color-border) 76%, transparent);
}
.mentee-account-nav-title {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.mentee-account-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp2);
  align-items: center;
}
.mentee-pill-btn--secondary {
  background: var(--color-surface-offset);
  color: var(--color-text);
}
.mentee-account-hero-stat {
  display: grid;
  gap: var(--sp3);
  align-content: start;
  padding: var(--sp4);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--color-primary) 4%, var(--color-surface));
  border: 1px solid color-mix(in srgb, var(--color-primary) 12%, var(--color-border));
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 45%, transparent);
}
.mentee-account-hero-stat-label {
  margin: 0;
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.mentee-account-hero-stat-value {
  margin: 0;
  font-family: var(--fb);
  font-size: clamp(2.25rem, 5vw, 3.5rem);
  font-weight: 800;
  line-height: 1;
  color: var(--color-primary);
  font-variant-numeric: tabular-nums;
}
.mentee-account-hero-bar {
  height: 0.7rem;
  border-radius: 999px;
  background: var(--color-border);
  overflow: hidden;
}
.mentee-account-hero-bar span {
  display: block;
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-primary), rgba(1, 105, 111, 0.75));
}
html[data-theme="dark"] .mentee-account-hero-bar span {
  background: linear-gradient(90deg, var(--color-primary), rgba(79, 152, 163, 0.85));
}
html[data-theme="dark"] .mentee-account-hero {
  background:
    radial-gradient(circle at 18% 18%, color-mix(in srgb, var(--color-primary) 6%, transparent), transparent 32%),
    radial-gradient(circle at 84% 10%, color-mix(in srgb, #c9a227 4%, transparent), transparent 28%),
    linear-gradient(135deg, var(--color-surface), color-mix(in srgb, var(--color-primary) 2%, var(--color-surface)));
}
html[data-theme="dark"] .mentee-account-hero-id {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--color-primary) 7%, transparent), transparent 72%),
    color-mix(in srgb, var(--color-primary) 3%, var(--color-surface));
  border-color: color-mix(in srgb, var(--color-primary) 10%, var(--color-border));
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-primary) 8%, transparent);
}
html[data-theme="dark"] .mentee-account-avatar {
  box-shadow:
    0 0.75rem 1.5rem color-mix(in srgb, var(--color-primary) 10%, transparent),
    0 0 0 0.35rem color-mix(in srgb, var(--color-surface) 92%, transparent),
    0 0 0 0.5rem color-mix(in srgb, var(--color-primary) 7%, transparent);
}
html[data-theme="dark"] .mentee-account-kicker {
  color: color-mix(in srgb, var(--color-primary) 82%, var(--color-text));
}
html[data-theme="dark"] .mentee-account-meta-pill[data-role="account-rank-leaderboard"] {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, #c9a227 12%, var(--color-surface-offset)),
    color-mix(in srgb, var(--color-primary) 5%, var(--color-surface))
  );
  border-color: color-mix(in srgb, #c9a227 20%, var(--color-border));
  color: var(--color-text);
  box-shadow: none;
}
html[data-theme="dark"] .mentee-account-rank-medal {
  background: linear-gradient(135deg, #b8952f, #8a6d1f);
  box-shadow: none;
}
.mentee-account-hero-note {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.45;
}
.mentee-account-progress {
  display: grid;
  gap: var(--sp4);
}
.mentee-account-progress-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(10.5rem, 1fr));
  gap: var(--sp3);
  align-items: stretch;
}
.mentee-account-progress-card {
  display: grid;
  grid-template-rows: auto auto auto;
  gap: var(--sp2);
  padding: var(--sp4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.mentee-account-progress-card--overall {
  grid-column: 1 / -1;
  border-color: color-mix(in srgb, var(--color-primary) 14%, var(--color-border));
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--color-primary) 4%, var(--color-surface));
}
.mentee-account-progress-card-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--sp2);
  min-height: 1.25rem;
}
.mentee-account-progress-card-pct {
  margin: 0;
  color: var(--color-primary);
  font-family: var(--fb);
  font-size: var(--text-lg);
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.mentee-account-progress-bar {
  height: 0.5rem;
  border-radius: 999px;
  background: var(--color-border);
  overflow: hidden;
}
.mentee-account-progress-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-primary), rgba(1, 105, 111, 0.72));
}
.mentee-account-progress-card-count {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: 1.45;
}
.mentee-account-progress-card-label {
  margin: 0;
  color: var(--color-text);
  font-size: var(--text-sm);
  font-weight: 700;
  line-height: 1.35;
  min-height: 2.7rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.mentee-account-progress-card-note {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: 1.45;
}
.mentee-account-history {
  display: grid;
  gap: var(--sp4);
}
.mentee-account-history-summary {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp2);
}
.mentee-account-history-stat {
  display: grid;
  gap: 0.15rem;
  min-width: 7.5rem;
  padding: var(--sp3) var(--sp4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.mentee-account-history-stat strong {
  font-family: var(--fb);
  font-size: var(--text-sm);
  font-weight: 800;
  color: var(--color-primary);
  font-variant-numeric: tabular-nums;
}
.mentee-account-history-stat span {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.35;
}
.mentee-account-history-chart-wrap {
  position: relative;
  overflow-x: auto;
  padding-bottom: var(--sp1);
}
.mentee-account-history-chart {
  display: block;
  width: 100%;
  min-width: 36rem;
  height: auto;
}
.mentee-account-history-chart-bg {
  fill: color-mix(in srgb, var(--color-primary) 3%, var(--color-surface));
  stroke: color-mix(in srgb, var(--color-primary) 10%, var(--color-border));
  stroke-width: 1;
}
.mentee-account-history-grid {
  stroke: color-mix(in srgb, var(--color-border) 85%, transparent);
  stroke-width: 1;
}
.mentee-account-history-axis {
  fill: var(--color-text-muted);
  font-size: 10px;
}
.mentee-account-history-axis--x {
  font-size: 11px;
}
.mentee-account-history-line {
  fill: none;
  stroke: var(--color-primary);
  stroke-width: 2.5;
  stroke-linejoin: round;
  stroke-linecap: round;
}
.mentee-account-history-dot {
  fill: var(--color-primary);
  stroke: var(--color-bg);
  stroke-width: 1.5;
}
.mentee-account-history-point {
  cursor: default;
  outline: none;
}
.mentee-account-history-point.is-active .mentee-account-history-dot,
.mentee-account-history-point:focus .mentee-account-history-dot,
.mentee-account-history-point:hover .mentee-account-history-dot {
  fill: color-mix(in srgb, var(--color-primary) 82%, #fff 18%);
  stroke: var(--color-surface);
  stroke-width: 2.5;
}
.mentee-account-history-dot-hit {
  fill: transparent;
  pointer-events: all;
}
.mentee-account-history-bar {
  fill: color-mix(in srgb, var(--color-text-muted) 35%, var(--color-border));
}
.mentee-account-history-bar.is-up {
  fill: color-mix(in srgb, var(--color-primary) 72%, #fff 28%);
}
.mentee-account-history-bar.is-down {
  fill: color-mix(in srgb, #c0392b 55%, var(--color-border) 45%);
}
.mentee-account-history-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp3);
  margin: var(--sp2) 0 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.mentee-account-history-legend-line {
  color: var(--color-primary);
  font-weight: 600;
}
.mentee-account-history-legend-bar {
  font-weight: 600;
}
.mentee-account-history-tooltip {
  position: absolute;
  z-index: 3;
  display: grid;
  gap: 0.1rem;
  min-width: 8.5rem;
  padding: 0.55rem 0.7rem;
  border: 1px solid color-mix(in srgb, var(--color-primary) 28%, var(--color-border));
  border-radius: var(--radius-md);
  background: var(--color-surface);
  box-shadow: var(--shadow-md);
  color: var(--color-text);
  font-size: var(--text-xs);
  line-height: 1.3;
  pointer-events: none;
  transform: translateZ(0);
}
.mentee-account-history-tooltip[hidden] {
  display: none;
}
.mentee-account-history-tooltip-date,
.mentee-account-history-tooltip-delta {
  color: var(--color-text-muted);
}
.mentee-account-history-tooltip-pct {
  font-family: var(--fb);
  font-size: var(--text-md);
  color: var(--color-primary);
  font-variant-numeric: tabular-nums;
}
.mentee-account-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--sp4);
}
.mentee-account-card {
  display: grid;
  gap: var(--sp3);
}
.mentee-account-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--sp4);
}
.mentee-account-card-title {
  margin: 0;
  font-family: var(--fb);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text);
}
.mentee-account-settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
  gap: var(--sp4);
}
.mentee-account-settings-group {
  display: grid;
  gap: var(--sp3);
  align-content: start;
  padding: var(--sp4);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in srgb, var(--color-border) 80%, transparent);
  background: color-mix(in srgb, var(--color-surface-offset) 55%, var(--color-surface));
}
.mentee-account-settings-group-title {
  margin: 0;
  font-family: var(--fb);
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
.mentee-account-settings-group .mentee-account-privacy-options {
  display: grid;
  gap: var(--sp3);
}
.mentee-account-switch {
  display: flex;
  align-items: center;
  gap: var(--sp3);
  width: 100%;
  max-width: 100%;
  color: var(--color-text);
  cursor: pointer;
  user-select: none;
}
.mentee-account-switch input {
  flex-shrink: 0;
  appearance: none;
  position: relative;
  width: 2.85rem;
  height: 1.55rem;
  margin: 0;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface-offset);
  cursor: pointer;
  transition:
    background-color var(--tr),
    border-color var(--tr),
    box-shadow var(--tr);
}
.mentee-account-switch input::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.16rem;
  width: 1.22rem;
  height: 1.22rem;
  border-radius: 50%;
  background: var(--color-bg);
  box-shadow: var(--shadow-sm);
  transform: translateY(-50%);
  transition: transform 0.2s ease, background-color var(--tr);
}
.mentee-account-switch input:checked {
  background: linear-gradient(90deg, var(--color-primary), rgba(1, 105, 111, 0.8));
  border-color: rgba(1, 105, 111, 0.5);
}
.mentee-account-switch input:checked::before {
  transform: translate(1.28rem, -50%);
  background: #fff;
}
.mentee-account-switch input:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--color-primary) 55%, transparent);
  outline-offset: 2px;
}
.mentee-account-switch input:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
.mentee-account-switch-ui {
  display: none;
}
.mentee-account-switch-text {
  flex: 1;
  min-width: 0;
  font-size: var(--text-sm);
  line-height: 1.45;
}
.mentee-account-card-note {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.45;
}
.mentee-account-bot-line {
  grid-column: 1 / -1;
}
.mentee-account-notify-test {
  margin-top: var(--sp2);
  padding: 0;
  border: 0;
  background: none;
  color: var(--color-primary);
  font-size: var(--text-xs);
  font-weight: 600;
  text-decoration: underline;
  cursor: pointer;
}
.mentee-account-notify-test:hover {
  color: var(--color-primary-hover);
}
.mentee-account-notify-test:disabled {
  opacity: 0.6;
  cursor: default;
}
.mentee-account-primary-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 2.5rem;
  padding: 0.7rem 1.1rem;
  border-radius: 999px;
  background: var(--color-primary);
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  box-shadow: var(--shadow-sm);
}
.mentee-account-primary-link:hover {
  background: var(--color-primary-hover);
}
.mentee-account-primary-link:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.mentee-account-links {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--sp2);
}
.mentee-account-link {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.2rem;
  min-height: 4.25rem;
  padding: var(--sp3) var(--sp4);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface-offset);
  color: var(--color-text);
  font-weight: 600;
  text-decoration: none;
  text-align: center;
  transition:
    border-color var(--tr),
    background-color var(--tr),
    color var(--tr),
    box-shadow var(--tr);
}
.mentee-account-link strong,
.mentee-account-link span {
  display: block;
}
.mentee-account-link span {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-weight: 500;
  line-height: 1.35;
}
.mentee-account-link:hover {
  border-color: rgba(1, 105, 111, 0.35);
  background: color-mix(in srgb, var(--color-primary) 6%, var(--color-surface));
  box-shadow: var(--shadow-sm);
}
.mentee-account-link:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.mentee-account-leaderboard {
  display: grid;
  gap: var(--sp4);
}
.mentee-account-leaderboard .mentee-account-section-head {
  display: grid;
  grid-template-columns: 1fr;
}
.mentee-account-privacy-panel {
  display: grid;
  grid-template-columns: minmax(12rem, 0.75fr) minmax(0, 1.25fr);
  gap: var(--sp4);
  align-items: start;
  padding: var(--sp4);
  border: 1px solid color-mix(in srgb, var(--color-primary) 12%, var(--color-border));
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 8% 12%, color-mix(in srgb, var(--color-primary) 7%, transparent), transparent 34%),
    var(--color-surface-offset);
}
.mentee-account-privacy-title {
  margin: 0 0 var(--sp2);
  color: var(--color-text);
  font-family: var(--fb);
  font-size: var(--text-base);
  font-weight: 700;
}
.mentee-account-privacy-options {
  display: grid;
  gap: var(--sp3);
  align-items: start;
}
.mentee-account-section-head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--sp3);
}
.mentee-account-section-lead {
  margin: var(--sp1) 0 0;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.5;
}
.mentee-account-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--sp2);
  padding: var(--sp2);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface-offset);
}
.mentee-account-tab {
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  padding: var(--sp2) var(--sp4);
  border-radius: 999px;
  color: var(--color-text-muted);
  text-decoration: none;
  font-weight: 700;
  border: 1px solid transparent;
}
.mentee-account-tab.is-active,
.mentee-account-tab:hover {
  color: var(--color-text);
}
.mentee-account-empty {
  margin: 0;
  padding: var(--sp4);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-primary) 4%, var(--color-surface));
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.55;
}
.mentee-account-leaderboard-state {
  display: grid;
  gap: var(--sp3);
}

.mentee-bottom-bar {
  flex-shrink: 0;
  border-top: 1px solid var(--color-divider);
  padding-block: var(--sp6) var(--sp10);
  background: var(--color-bg);
}
.mentee-bottom-inner {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 0;
}
code {
  font-size: 0.85em;
  background: var(--color-bg);
  padding: 0.1rem 0.35rem;
  border-radius: 0.25rem;
  border: 1px solid var(--color-border);
}

/* Длинные тексты гайда */
.mentee-doc-back {
  margin-bottom: var(--sp3);
}
.mentee-doc {
  max-width: 72ch;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.65;
}
.mentee-doc h2 {
  font-family: var(--fh);
  font-size: var(--text-xl);
  font-weight: 600;
  font-style: italic;
  color: var(--color-text);
  margin: var(--sp8) 0 var(--sp3);
  scroll-margin-top: 5rem;
}
.mentee-doc h2:first-child {
  margin-top: 0;
}
.mentee-doc h3 {
  font-family: var(--fb);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
  margin: var(--sp6) 0 var(--sp2);
  scroll-margin-top: 5rem;
}
.mentee-doc h4 {
  font-family: var(--fb);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  margin: var(--sp5) 0 var(--sp2);
  scroll-margin-top: 4rem;
}
.mentee-doc h5 {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  margin: var(--sp4) 0 var(--sp2);
}
.mentee-doc p {
  margin: 0 0 var(--sp3);
}
.mentee-doc ul,
.mentee-doc ol {
  margin: 0 0 var(--sp4);
  padding-left: 1.25rem;
}
.mentee-doc li + li {
  margin-top: 0.35rem;
}
.mentee-doc-links {
  margin: 0 0 var(--sp3);
}
.mentee-doc-links a {
  color: var(--color-primary);
  font-weight: 500;
  text-decoration: underline;
}
.mentee-doc-links a:hover {
  color: var(--color-primary-hover);
}
.mentee-doc-table-wrap {
  margin: 0 0 var(--sp5);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}
.mentee-doc-table-wrap .mentee-doc-table {
  margin: 0;
}
.mentee-doc-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 var(--sp5);
  font-size: 0.8125rem;
}
.mentee-doc-table th,
.mentee-doc-table td {
  border: 1px solid var(--color-border);
  padding: var(--sp3) var(--sp4);
  text-align: left;
  vertical-align: top;
}
.mentee-doc-table th {
  background: var(--color-surface-offset);
  font-weight: 600;
  color: var(--color-text);
  border-bottom: 2px solid var(--color-divider);
}
.mentee-doc-table tbody tr:nth-child(even) {
  background: var(--color-bg);
}

/* Страница гайда: сетка + оглавление + главы-карточки + код */
:root {
  --mentee-code-bg: #252b36;
  --mentee-code-border: rgba(1, 105, 111, 0.35);
  --mentee-code-text: #e8eaef;
  --mentee-code-kw: #c792ea;
  --mentee-code-string: #c3e88d;
  --mentee-code-comment: #7d8a96;
  --mentee-code-num: #f78c6c;
}
[data-theme="dark"] {
  --mentee-code-bg: #0d1218;
  --mentee-code-border: rgba(79, 152, 163, 0.35);
  --mentee-code-text: #dce1e8;
  --mentee-code-kw: #dabafa;
  --mentee-code-string: #b8e986;
  --mentee-code-comment: #6b7785;
  --mentee-code-num: #fab387;
}

.mentee-guide-main .mentee-page-title {
  margin-bottom: var(--sp5);
}

.mentee-guide-main .mentee-guide-blurb {
  margin-top: calc(-1 * var(--sp2));
  margin-bottom: var(--sp6);
  max-width: 72ch;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.65;
}
.mentee-guide-main .mentee-guide-blurb a.mentee-inline-link {
  color: var(--color-primary);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.mentee-guide-main .mentee-guide-blurb a.mentee-inline-link:hover {
  text-decoration-thickness: 2px;
}

/* Гайд шире обычного `.container` (960px), чтобы колонка текста и TOC смотрелись на десктопе */
main.mentee-guide-main.container {
  max-width: min(100% - 2 * var(--sp6), 1360px);
}

.mentee-doc-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(11.5rem, 17rem);
  gap: clamp(var(--sp6), 2.5vw, var(--sp10));
  align-items: stretch;
  width: 100%;
}

.mentee-doc-toc-wrap {
  position: relative;
  min-width: 0;
}

/* Родитель на всю высоту колонки контента — sticky держит оглавление в зоне видимости при прокрутке длинной статьи */
.mentee-doc-toc-sticky {
  position: sticky;
  top: 5.5rem;
  display: flex;
  flex-direction: column;
  max-height: min(calc(100vh - 6rem), 78vh);
  padding: var(--sp3) var(--sp4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.mentee-doc-toc-title {
  font-family: var(--fb);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  margin-bottom: var(--sp3);
}

.mentee-doc-toc-root {
  list-style: none;
  margin: 0;
  padding: 0;
}

#mentee-doc-toc {
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  padding-right: 0.25rem;
  margin-right: -0.25rem;
}

.mentee-doc-toc-sub {
  list-style: none;
  margin: 0.35rem 0 var(--sp2);
  padding: 0 0 0 var(--sp2);
  border-left: 2px solid var(--color-divider);
}

.mentee-doc-toc-item {
  margin: 0;
}

.mentee-doc-toc-item--h2 {
  margin-bottom: 0.35rem;
}

.mentee-doc-toc-item--h2 > .mentee-doc-toc-row > .mentee-doc-toc-link {
  font-weight: 600;
  color: var(--color-text);
}

.mentee-doc-toc-item--h3 {
  margin-bottom: 0.15rem;
}

/* Базовый вид ссылок TOC; страницы с menti-guide.css переопределяют (плашки, active). */
.mentee-doc-toc-link {
  display: block;
  padding: 0.12rem 0;
  font-size: 0.6875rem;
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
  line-height: 1.3;
}

.mentee-doc-toc-link:hover {
  color: var(--color-primary-hover);
}

.mentee-doc-column {
  min-width: 0;
}

/* Чуть крупнее основной текст гайда на широких экранах */
@media (min-width: 1100px) {
  .mentee-guide-main .mentee-doc {
    font-size: var(--text-base);
    line-height: 1.7;
  }
}

.mentee-doc {
  max-width: none;
}

/* Глава — только заголовок шага; контент в карточках .mentee-doc-topic (как /roadmap/) */
.mentee-doc-chapter {
  margin-bottom: var(--sp10);
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

.mentee-doc-chapter > h2 {
  font-family: var(--fh);
  font-size: var(--text-xl);
  font-weight: 600;
  font-style: italic;
  color: var(--color-text);
  margin: var(--sp8) 0 var(--sp5);
  padding-bottom: var(--sp3);
  border-bottom: 2px solid var(--color-divider);
  scroll-margin-top: 5rem;
}

.mentee-doc-chapter:first-of-type > h2 {
  margin-top: 0;
}

.mentee-doc-topic.mentee-card {
  margin-bottom: var(--sp5);
}

.mentee-doc-topic.mentee-card > h3 {
  margin-top: 0;
  margin-bottom: var(--sp3);
  padding: 0 0 var(--sp3);
  border-bottom: 1px solid var(--color-divider);
  font-family: var(--fb);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  background: transparent;
  border-left: none;
  scroll-margin-top: 5rem;
}

.mentee-doc-topic h4 {
  margin-top: var(--sp4);
  margin-bottom: var(--sp2);
  padding: var(--sp2) var(--sp3);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  background: var(--color-bg);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
}

.mentee-doc-topic h5 {
  margin-top: var(--sp3);
  color: var(--color-text);
  font-size: var(--text-sm);
}

/* Блок «Курсы» — карточки под заголовком (одна или несколько ссылок) */
.mentee-doc-chapter > h2 + .mentee-doc-links {
  margin-top: 0;
  padding: var(--sp4) var(--sp5);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.mentee-doc-chapter > h2 + .mentee-doc-links ~ .mentee-doc-links {
  margin-top: var(--sp4);
  padding: var(--sp4) var(--sp5);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

/* Все ссылки в тексте гайда — явно (карточки «Полезные материалы», «Задания для закрепления», скачивание .cf — отдельный стиль) */
.mentee-doc a[href]:not(.mentee-resource-card):not(.mentee-practice-link):not(.practice-download-card):not(.mentee-recording-action):not(.mentee-pill-btn) {
  color: var(--color-primary);
  font-weight: 500;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.mentee-doc a[href]:not(.mentee-resource-card):not(.mentee-practice-link):not(.practice-download-card):not(.mentee-recording-action):not(.mentee-pill-btn):hover {
  color: var(--color-primary-hover);
}

.mentee-doc-external-link::after {
  content: " ↗";
  font-size: 0.85em;
  opacity: 0.75;
}

.mentee-doc-pre {
  margin: 0 0 var(--sp5);
  padding: var(--sp4) var(--sp5);
  overflow-x: auto;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.8125rem;
  line-height: 1.55;
  background: var(--mentee-code-bg);
  color: var(--mentee-code-text);
  border: 1px solid var(--mentee-code-border);
  border-radius: var(--radius-md);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.mentee-doc-pre code,
.mentee-doc-pre code * {
  font-family: inherit;
}

.mentee-doc-pre code {
  display: block;
  padding: 0;
  border: none;
  background: transparent !important;
  color: inherit;
  white-space: pre;
}

.mentee-doc-pre code span {
  font-weight: inherit;
}

.mentee-code-kw {
  color: var(--mentee-code-kw);
  font-weight: 600;
}

.mentee-code-string {
  color: var(--mentee-code-string);
}

.mentee-code-comment {
  color: var(--mentee-code-comment);
  font-style: italic;
}

.mentee-code-num {
  color: var(--mentee-code-num);
}

@media (max-width: 1100px) {
  .mentee-account-admin-wrap:not([hidden]) {
    position: static;
    width: 100%;
    min-width: 0;
    margin-bottom: var(--sp4);
  }

  .mentee-account-admin-sticky {
    position: static;
  }
}

@media (max-width: 960px) {
  .mentee-account-hero,
  .mentee-account-grid {
    grid-template-columns: 1fr;
  }

  .mentee-account-progress-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mentee-account-links {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  main.mentee-guide-main.container {
    max-width: 100%;
    padding-inline: var(--sp5);
  }

  .mentee-doc-layout {
    grid-template-columns: 1fr;
    gap: var(--sp6);
  }

  /* Контент в DOM первым; на узком экране оглавление сверху для быстрых переходов */
  .mentee-doc-toc-wrap {
    order: -1;
  }

  .mentee-doc-toc-sticky {
    position: static;
    padding: var(--sp4);
    margin-bottom: var(--sp2);
  }

  .mentee-doc-toc-link {
    font-size: var(--text-xs);
    padding: 0.18rem 0;
  }
}

@media (max-width: 720px) {
  .mentee-account-hero-layout {
    grid-template-columns: 1fr;
    gap: var(--sp5);
  }

  .mentee-account-hero-side {
    padding-top: 0;
  }

  .mentee-account-privacy-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .mentee-docs-hub-leaderboard-row,
  .mentee-account-card-head {
    grid-template-columns: 1fr;
  }

  .mentee-account-avatar {
    width: 10rem;
    height: 10rem;
    font-size: 2.25rem;
  }

  .mentee-account-hero-id-text {
    max-width: none;
  }

  .mentee-account-card-head {
    display: grid;
  }

  .mentee-account-progress-grid,
  .mentee-account-links {
    grid-template-columns: 1fr;
  }

  .mentee-account-leaderboard-toggle {
    justify-items: start;
  }

  .mentee-docs-hub-leaderboard-row {
    display: grid;
  }

  .mentee-docs-hub-leaderboard-pct {
    justify-self: start;
  }

  main.mentee-guide-main.container {
    padding-inline: var(--sp4);
  }

  .mentee-doc-pre {
    font-size: 0.75rem;
    padding: var(--sp3) var(--sp4);
  }
}
