/* =============================================================================
   cv.css — styles specific to the full CV page (cv.html).
   Loads on top of style.css, reusing its variables, nav, footer and buttons.
   ========================================================================== */

/* ------------------------------- CV header ------------------------------- */
.cv-hero { max-width: var(--maxw); margin: 0 auto; padding: clamp(2rem, 5vw, 3.2rem) var(--pad) 1.2rem; }
.cv-hero__eyebrow {
  text-transform: uppercase; letter-spacing: .16em; font-size: .78rem;
  font-weight: 600; color: var(--accent); margin-bottom: .5rem;
}
.cv-hero__name { font-family: var(--font-serif); font-weight: 600; letter-spacing: -.01em;
  font-size: clamp(1.9rem, 4.2vw, 2.6rem); color: var(--ink); }
.cv-hero__meta { color: var(--ink-soft); margin-top: .5rem; font-size: 1.04rem; line-height: 1.5; }
.cv-hero__meta b { color: var(--ink); font-weight: 600; }
.cv-hero__contact { display: flex; flex-wrap: wrap; gap: .45rem 1.1rem; margin-top: 1.1rem; font-size: .92rem; }
.cv-hero__contact a { display: inline-flex; align-items: center; gap: .4rem; color: var(--ink-soft); }
.cv-hero__contact a:hover { color: var(--accent); }
.cv-hero__contact svg { width: 16px; height: 16px; flex: 0 0 auto; }
.cv-hero__updated { color: var(--ink-muted); font-size: .82rem; margin-top: .8rem; }

/* ------------------------------ Table of contents ------------------------ */
.cv-toc { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad); }
.cv-toc__inner {
  display: flex; flex-wrap: wrap; gap: .35rem .55rem; align-items: center;
  padding: .9rem 1.1rem; background: var(--bg-alt); border: 1px solid var(--line);
  border-radius: var(--radius); font-size: .84rem;
}
.cv-toc__label { font-weight: 600; color: var(--ink-muted); text-transform: uppercase; letter-spacing: .08em; font-size: .72rem; margin-right: .3rem; }
.cv-toc a { color: var(--ink-soft); white-space: nowrap; }
.cv-toc a:hover { color: var(--accent); }
.cv-toc__sep { color: var(--line); }

/* -------------------------------- Sections ------------------------------- */
.cv-main { max-width: var(--maxw); margin: 0 auto; padding: 1.6rem var(--pad) 1rem; }
.cv-section { scroll-margin-top: 76px; padding-top: clamp(1.8rem, 4vw, 2.6rem); }
.cv-section__title {
  display: flex; justify-content: space-between; align-items: baseline; gap: 1rem;
  font-size: .92rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 600;
  color: var(--ink); padding-bottom: .5rem; border-bottom: 1.5px solid var(--ink);
}
.cv-section__note { font-size: .8rem; font-weight: 400; letter-spacing: 0; text-transform: none; color: var(--ink-muted); white-space: nowrap; }
.cv-section__body { margin-top: 1rem; }

/* Shared row primitives ---------------------------------------------------- */
.cv-row { display: grid; grid-template-columns: 7.5rem 1fr; gap: .2rem 1.1rem; padding: .5rem 0; border-top: 1px solid var(--line-soft); }
.cv-row:first-child { border-top: 0; }
.cv-dates { color: var(--ink-muted); font-size: .9rem; font-variant-numeric: tabular-nums; padding-top: .1rem; }
.cv-sub { font-size: .88rem; color: var(--ink-soft); margin-top: .15rem; }
.cv-sub i, .cv-sub em { font-style: italic; }

/* Positions / research experience ----------------------------------------- */
.cv-pos__line { display: flex; justify-content: space-between; gap: 1rem; align-items: baseline; flex-wrap: wrap; }
.cv-pos__title { font-weight: 600; color: var(--ink); }
.cv-pos__title--sec { font-weight: 500; color: var(--ink-soft); }
.cv-pos__affil { color: var(--ink-muted); font-size: .92rem; text-align: right; }

/* Education ---------------------------------------------------------------- */
.cv-edu { grid-template-columns: 4rem 1fr; }
.cv-edu__head { display: flex; gap: .6rem; flex-wrap: wrap; align-items: baseline; }
.cv-edu__degree { font-weight: 700; color: var(--accent); }
.cv-edu__area { color: var(--ink); }
.cv-edu__inst { color: var(--ink-soft); }

/* Grants ------------------------------------------------------------------- */
.cv-grant { grid-template-columns: 7.5rem 3.2rem 1fr; }
.cv-grant__role { color: var(--ink-muted); font-size: .9rem; }
.cv-grant__title { font-weight: 600; color: var(--ink); }

/* Teaching / service ------------------------------------------------------- */
.cv-svc { grid-template-columns: 7.5rem 9rem 1fr; }
.cv-svc__role { color: var(--ink-soft); font-size: .94rem; }
.cv-teach { grid-template-columns: 7.5rem 1fr auto; }
.cv-teach__inst { color: var(--ink-muted); font-size: .9rem; text-align: right; }

/* Mentoring ---------------------------------------------------------------- */
.cv-mentor__group + .cv-mentor__group { margin-top: 1.1rem; }
.cv-mentor__label { font-weight: 600; color: var(--ink); font-size: .9rem; text-decoration: underline; text-underline-offset: 3px; margin-bottom: .4rem; }
.cv-mentor__row { display: grid; grid-template-columns: 7.5rem 1fr auto; gap: .2rem 1.1rem; padding: .28rem 0; }
.cv-mentor__details { color: var(--ink-muted); font-size: .9rem; text-align: right; }

/* Numbered entries: publications / talks / posters ------------------------- */
.cv-num { display: grid; grid-template-columns: 2.2rem 2.7rem 1fr; gap: .3rem .7rem; padding: .55rem 0; border-top: 1px solid var(--line-soft); }
.cv-num:first-child { border-top: 0; }
.cv-num__n { text-align: right; color: var(--ink-muted); font-size: .78rem; font-weight: 600; padding-top: .22rem; font-variant-numeric: tabular-nums; }
.cv-num__year { color: var(--accent); font-weight: 600; font-size: .9rem; font-variant-numeric: tabular-nums; padding-top: .12rem; }
.cv-num__body { min-width: 0; }
.cv-authors { color: var(--ink-soft); }
.cv-authors b { color: var(--ink); font-weight: 700; }
.cv-authors sup { font-size: .7em; }
.cv-u { text-decoration: underline; text-underline-offset: 2px; }
.cv-ptitle { font-style: italic; color: var(--ink); }
.cv-venue { color: var(--ink-soft); }
.cv-doi { color: var(--accent); word-break: break-word; }
.cv-anote, .cv-note { display: block; color: var(--ink-muted); font-size: .82rem; font-style: italic; margin-top: .1rem; }

/* Datasets ----------------------------------------------------------------- */
.cv-data { padding: .5rem 0; border-top: 1px solid var(--line-soft); }
.cv-data:first-child { border-top: 0; }

/* Back-to-top / footer note ------------------------------------------------ */
.cv-foot { max-width: var(--maxw); margin: 0 auto; padding: 1.5rem var(--pad) 2.5rem; }
.cv-foot a { font-size: .9rem; font-weight: 500; }

/* ------------------------------- Responsive ------------------------------ */
@media (max-width: 680px) {
  .cv-row, .cv-edu, .cv-grant, .cv-svc, .cv-teach, .cv-mentor__row { grid-template-columns: 1fr; gap: .15rem; }
  .cv-num { grid-template-columns: 2rem 1fr; }
  .cv-num__year { grid-column: 2; padding-top: 0; }
  .cv-num__body { grid-column: 2; }
  .cv-dates { color: var(--accent); font-size: .82rem; }
  .cv-pos__affil, .cv-teach__inst, .cv-mentor__details { text-align: left; }
  .cv-teach, .cv-mentor__row { }
}
