/**
 * Resume layout under #rs-app — site theme tokens only (no separate theme pack).
 * Site colors/fonts: themes/default/tokens.css + content/site-theme.json (same as home/projects).
 */

.rs-page {
  min-height: 100vh;
  background: var(--color-bg);
  color: var(--color-text-primary);
  font-family: var(--font-sans);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  padding: var(--rs-page-padding-y) var(--rs-page-padding-x);
}

.rs-page-inner {
  max-width: var(--rs-max-width);
  margin: 0 auto;
}

.rs-back {
  display: inline-block;
  margin-bottom: var(--pf-space-stack-sm);
  color: var(--color-accent);
  text-decoration: none;
  font-size: 0.875rem;
}

.rs-back:hover {
  text-decoration: underline;
}

/* ── Controls (compact, views + lens grouped) ─────────── */
.rs-controls {
  margin-bottom: var(--pf-section-gap-controls);
  display: flex;
  flex-direction: column;
  gap: var(--rs-space-control-gap);
}

.rs-resume-type-row {
  display: flex;
  gap: var(--pf-control-gap);
  flex-wrap: wrap;
}

.rs-view-toolbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--pf-space-inline-md);
}

.rs-view-group {
  display: flex;
  gap: var(--pf-control-gap);
  flex-wrap: wrap;
}

/* Segment / lens / tag surfaces: shared/site-kit/styles/pf-density.css */

.rs-recruiter-label {
  font-size: inherit;
}

/* Toolbar: search + filter tags */
.rs-toolbar {
  display: flex;
  flex-direction: column;
  gap: var(--pf-section-gap-toolbar);
  margin-bottom: var(--pf-section-gap-before-card);
  padding-top: var(--pf-space-stack-sm);
  border-top: 1px solid var(--color-border);
}

.rs-search {
  width: 100%;
  max-width: min(420px, 100%);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--pf-field-radius);
  color: var(--color-text-primary);
  padding: var(--pf-field-padding-y) var(--pf-field-padding-x);
  font-size: var(--pf-field-font-size);
  font-family: var(--font-sans);
}

.rs-tag--keyword {
  color: var(--pf-translator-active-fg);
  background: var(--pf-translator-active-bg);
  border-color: var(--pf-translator-active-border);
}

.rs-toolbar-row {
  margin-top: 0;
}

.rs-tag-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: var(--pf-tag-gap);
  align-items: center;
}

.rs-recruiter-btn:disabled,
.rs-translator-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

/* ── Resume card ───────────────────────────────────────── */
.rs-resume-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--rs-radius-card);
  overflow: hidden;
}

.rs-rec-strip,
.pf-translator-banner {
  height: 0;
  overflow: hidden;
  background: var(--color-translator-highlight-muted);
  border-bottom: 1px solid var(--color-translator-highlight-border);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0 var(--pf-section-inset, 1.125rem);
  font-family: var(--font-mono);
  font-size: 0.68rem;
  color: var(--color-translator-highlight);
  transition: height var(--transition);
}

.rs-rec-strip--on,
.pf-translator-banner--on {
  height: var(--rs-rec-strip-height);
}

.rs-hdr-badge--translator {
  background: var(--color-translator-highlight-muted);
  color: var(--color-translator-highlight);
  border: 1px solid var(--color-translator-highlight-border);
}

/* Harness Edit-All — bound fields on stage */
html[data-pf-edit-mode='1'] [data-pf-editable='true'] {
  outline: 2px dashed var(--color-attention, #e8a020);
  outline-offset: 2px;
  cursor: text;
}

html[data-pf-edit-mode='1'] [data-pf-editable='true'].pf-editable--active {
  outline-color: var(--color-primary, #4a9eff);
  background: color-mix(in srgb, var(--color-surface, #fff) 92%, var(--color-primary, #4a9eff));
}

.rs-hdr-badge--rec {
  background: var(--color-translator-highlight-muted);
  color: var(--color-translator-highlight);
  border: 1px solid var(--color-translator-highlight-border);
}

.rs-resume-header {
  padding: var(--pf-section-inset, 1.125rem);
  border-bottom: 1px solid var(--color-border);
}

.rs-resume-name {
  font-family: var(--font-display);
  font-size: var(--rs-font-size-name);
  color: var(--color-text-primary);
  line-height: 1.1;
  margin-bottom: 0.25rem;
}

.rs-resume-title {
  font-family: var(--font-mono);
  font-size: var(--rs-font-size-title);
  color: var(--color-accent);
  margin-bottom: 0.75rem;
}

.rs-contact-row {
  margin-bottom: 0.6rem;
}

.rs-badge-row {
  display: flex;
  gap: var(--pf-tag-gap);
  flex-wrap: wrap;
}

.rs-hdr-badge {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  font-weight: 500;
  padding: var(--pf-tag-padding-y) var(--pf-tag-padding-x);
  border-radius: var(--rs-radius-badge);
}

.rs-hdr-badge--view {
  background: var(--color-accent-muted);
  color: var(--color-accent);
  border: 1px solid var(--color-accent-border);
}

.rs-resume-body {
  padding: var(--pf-section-inset, 1.125rem);
  display: flex;
  flex-direction: column;
  gap: var(--rs-space-section);
}

.rs-section-label {
  font-family: var(--font-mono);
  font-size: var(--rs-font-size-section-label);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: 0.6rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid var(--color-border);
}

.rs-summary-text {
  font-size: var(--rs-font-size-body);
  color: var(--color-text-secondary);
  line-height: 1.7;
}

.rs-exp-list {
  display: flex;
  flex-direction: column;
  gap: var(--pf-space-stack-lg);
}

.rs-exp-header {
  display: flex;
  justify-content: space-between;
  gap: var(--pf-space-inline-md);
  align-items: flex-start;
  margin-bottom: 0.15rem;
}

.rs-exp-role {
  font-size: 0.93rem;
  font-weight: 500;
  color: var(--color-text-primary);
}

.rs-exp-dates {
  color: var(--color-text-muted);
  white-space: nowrap;
  flex-shrink: 0;
  margin-top: 1px;
}

.rs-exp-company {
  font-family: var(--font-mono);
  font-size: 0.76rem;
  color: var(--color-accent);
  margin-bottom: 0.45rem;
}

/* pf-list provides marker; rs-exp-bullets keeps harness hook */
.rs-exp-bullets.pf-list > li,
.rs-exp-bullets > li {
  font-size: var(--rs-font-size-bullet);
  color: var(--color-text-secondary);
  line-height: 1.65;
}

.rs-skills-list {
  display: flex;
  flex-direction: column;
  gap: var(--pf-space-stack-sm);
}

.rs-skill-row {
  display: flex;
  align-items: baseline;
  gap: var(--pf-space-inline-md);
}

.rs-skill-label {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  color: var(--color-text-muted);
  min-width: 5.5rem;
  flex-shrink: 0;
}

.rs-edu-list {
  display: flex;
  flex-direction: column;
  gap: var(--pf-space-stack-sm);
}

.rs-edu-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--pf-space-inline-md);
}

.rs-edu-degree {
  font-size: var(--rs-font-size-body);
  font-weight: 500;
  color: var(--color-text-primary);
}

.rs-edu-school {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  margin-top: 0.08rem;
}

.rs-edu-year {
  color: var(--color-text-muted);
  white-space: nowrap;
}

.rs-missing-view {
  padding: calc(var(--pf-section-gap, 0.875rem) * 2) var(--pf-section-inset, 1.125rem);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.rs-missing-glyph {
  font-size: 1.75rem;
  color: var(--color-text-muted);
  margin-bottom: 0.15rem;
}

.rs-missing-title {
  font-family: var(--font-display);
  font-size: 1.15rem;
  color: var(--color-text-secondary);
}

.rs-missing-desc {
  font-size: 0.83rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  max-width: 42ch;
}

.rs-missing-code {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  padding: 0.2rem 0.55rem;
  border-radius: var(--rs-radius-badge);
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  color: var(--color-accent);
  margin-top: 0.15rem;
}

.rs-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.rs-search-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.rs-search-results {
  margin-top: var(--pf-space-stack-sm);
}

.rs-search-hit {
  border: 1px solid var(--color-border);
  border-radius: var(--pf-field-radius);
  margin-bottom: var(--pf-space-stack-xs);
  padding: 0.5rem 0.7rem;
  background: var(--color-surface);
}

.rs-search-open {
  display: block;
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  color: var(--color-accent);
  cursor: pointer;
  font: inherit;
  padding: 0;
  margin-bottom: 0.15rem;
}

.rs-search-snippet {
  display: block;
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
}

@media (max-width: 580px) {
  .rs-page {
    padding: var(--pf-space-stack-md) var(--pf-space-stack-sm);
  }

  .rs-resume-header,
  .rs-resume-body {
    padding-left: 1.15rem;
    padding-right: 1.15rem;
  }

  .rs-exp-header,
  .rs-edu-row {
    flex-direction: column;
    gap: 0.08rem;
  }

  .rs-skill-row {
    flex-direction: column;
    gap: var(--pf-tag-gap);
  }
}
