/* Resume layout */
.cv-head {
  padding: 22vh 0 60px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: end;
}
.cv-head .lbl {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-bottom: 28px;
}
.cv-head h1 {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: clamp(56px, 11vw, 180px);
  line-height: 0.92;
  letter-spacing: -0.045em;
}
.cv-head h1 em {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--accent);
}
@media (max-width: 720px) {
  .cv-head { grid-template-columns: 1fr; }
}

.cv-quick {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  padding: 60px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.cv-quick .item .lbl {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-bottom: 12px;
}
.cv-quick .item .val {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.5;
}
.cv-quick .item .val a:hover { color: var(--accent); }
@media (max-width: 720px) {
  .cv-quick { grid-template-columns: 1fr 1fr; gap: 28px; }
}

/* Section block */
.cv-section {
  padding: 100px 0 60px;
}
.cv-section .head {
  display: grid;
  grid-template-columns: 1fr 3fr;
  gap: 40px;
  align-items: end;
  margin-bottom: 60px;
}
.cv-section .head .lbl {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-dim);
}
.cv-section .head .lbl::before {
  content: "";
  display: inline-block;
  width: 28px; height: 1px;
  background: var(--accent);
  vertical-align: middle;
  margin-right: 12px;
}
.cv-section .head h2 {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: clamp(40px, 6vw, 84px);
  line-height: 1;
  letter-spacing: -0.03em;
}
.cv-section .head h2 em { font-family: var(--font-display); font-style: italic; color: var(--accent); }
@media (max-width: 720px) {
  .cv-section .head { grid-template-columns: 1fr; gap: 14px; margin-bottom: 40px; }
}

.cv-entry {
  display: grid;
  grid-template-columns: 1fr 3fr;
  gap: 40px;
  padding: 40px 0;
  border-top: 1px solid var(--line);
  align-items: start;
}
.cv-entry:last-child { border-bottom: 1px solid var(--line); }
.cv-entry .when {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  color: var(--fg-dim);
}
.cv-entry .where {
  font-family: var(--font-sans);
  font-size: clamp(22px, 2.4vw, 30px);
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}
.cv-entry .where em { font-family: var(--font-display); font-style: italic; color: var(--accent); }
.cv-entry .role {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-bottom: 18px;
}
.cv-entry ul { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.cv-entry ul li {
  font-size: 16px;
  line-height: 1.6;
  padding-left: 24px;
  position: relative;
}
.cv-entry ul li::before {
  content: "";
  position: absolute;
  left: 0; top: 0.7em;
  width: 12px; height: 1px;
  background: var(--accent);
}
.cv-entry ul li strong { color: var(--accent); font-weight: 500; }
@media (max-width: 720px) {
  .cv-entry { grid-template-columns: 1fr; gap: 16px; padding: 30px 0; }
}

/* Skills grid */
.cv-skills {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}
.cv-skills .group .lbl {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-bottom: 18px;
}
.cv-skills .pills { display: flex; flex-wrap: wrap; gap: 8px; }
.cv-skills .pill {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  padding: 8px 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--fg);
  transition: border-color .3s, color .3s;
}
.cv-skills .pill:hover { border-color: var(--accent); color: var(--accent); }
@media (max-width: 720px) {
  .cv-skills { grid-template-columns: 1fr; gap: 28px; }
}

/* Download CTA */
.dl-card {
  margin-top: 60px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
  padding: 40px 48px;
  border: 1px solid var(--line);
  border-radius: 12px;
  position: relative;
  overflow: hidden;
}
.dl-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at top right, rgba(212,165,116,0.06), transparent 50%);
  pointer-events: none;
}
.dl-card .meta { position: relative; }
.dl-card .meta .lbl {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-bottom: 10px;
}
.dl-card .meta .file {
  font-family: var(--font-sans);
  font-size: clamp(24px, 3vw, 36px);
  letter-spacing: -0.02em;
}
.dl-card .meta .file em { font-family: var(--font-display); font-style: italic; color: var(--accent); }
.dl-card .meta .info {
  margin-top: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--fg-dim);
}
.dl-card .dl {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 22px 36px;
  background: var(--accent);
  color: var(--bg);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: background .4s, transform .4s var(--ease-out), color .4s;
}
.dl-card .dl:hover { background: var(--fg); transform: scale(1.04); }
.dl-card .dl .arrow { font-size: 16px; transition: transform .3s var(--ease); }
.dl-card .dl:hover .arrow { transform: translateY(2px); }
@media (max-width: 720px) {
  .dl-card { grid-template-columns: 1fr; padding: 32px; gap: 24px; }
}

/* ===== Light environment overrides ===== */
.section-light .cv-quick { border-color: var(--line-light); }
.section-light .cv-quick .item .lbl { color: var(--fg-light-dim); }
.section-light .cv-quick .item .val { color: var(--fg-light); }
.section-light .cv-section .head .lbl { color: var(--fg-light-dim); }
.section-light .cv-section .head h2 { color: var(--fg-light); }
.section-light .cv-entry { border-color: var(--line-light) !important; }
.section-light .cv-entry .when { color: var(--fg-light-dim); }
.section-light .cv-entry .where { color: var(--fg-light); }
.section-light .cv-entry .role { color: var(--fg-light-dim); }
.section-light .cv-entry ul li { color: var(--fg-light); }
.section-light .cv-entry ul li::before { background: var(--accent); }
.section-light .cv-skills .group .lbl { color: var(--fg-light-dim); }
.section-light .cv-skills .pill { border-color: var(--line-light); color: var(--fg-light); }
.section-light .cv-skills .pill:hover { border-color: var(--accent); color: var(--accent-deep); }

/* Download card on light bg becomes a striking dark anchor */
.section-light .dl-card {
  background: var(--bg);
  border-color: transparent;
  color: var(--fg);
}
.section-light .dl-card .meta .lbl { color: var(--fg-dim); }
.section-light .dl-card .meta .file { color: var(--fg); }
.section-light .dl-card .meta .info { color: var(--fg-dim); }
