/* cv.diogo.site — restrained, senior-role oriented interactive CV. */

:root {
  --paper: #f6f7f5;
  --paper-soft: #edf2ef;
  --sheet: #ffffff;
  --ink: #172029;
  --muted: #66737b;
  --blueprint: #355f63;
  --blue-soft: #e5eeee;
  --brass: #5f7f73;
  --brass-soft: #edf4f1;
  --rule: #d9e0dc;
  --rule-strong: #bdcbc4;
  --shadow: 0 24px 80px -55px rgba(23, 32, 41, .55);
  --serif: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI Variable", "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --sans: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI Variable", "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --mono: "SFMono-Regular", ui-monospace, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { overflow-x: hidden; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition: none !important; }
}

body {
  margin: 0;
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.57;
  background:
    radial-gradient(circle at 12% -10%, rgba(53,95,99,.10), transparent 30rem),
    radial-gradient(circle at 100% 0%, rgba(95,127,115,.08), transparent 28rem),
    linear-gradient(180deg, #f9faf8 0, var(--paper) 24rem, var(--paper) 100%);
}

a { color: var(--blueprint); text-decoration-thickness: 1px; text-underline-offset: 2px; }
a:hover { color: #2f5559; }
:focus-visible { outline: 3px solid rgba(53,95,99,.32); outline-offset: 3px; border-radius: 6px; }
.muted { color: var(--muted); }

.skip { position: absolute; left: -200vw; top: 0; background: var(--ink); color: white; padding: .55rem .9rem; }
.skip:focus-visible { left: .75rem; top: .75rem; z-index: 30; }

/* ------------------------------------------------------------ layout */
.wrap {
  display: grid;
  grid-template-columns: minmax(17rem, 20.5rem) minmax(0, 54rem);
  gap: 2.2rem;
  max-width: 80rem;
  margin: 0 auto;
  padding: 2.3rem 1.25rem 3rem;
}

/* ------------------------------------------------------------ rail */
.rail {
  position: sticky;
  top: 1.2rem;
  align-self: start;
  max-height: calc(100vh - 2.4rem);
  overflow-y: auto;
  padding: 1.2rem;
  border: 1px solid rgba(53,95,99,.12);
  border-radius: 24px;
  background: rgba(255,255,255,.76);
  box-shadow: 0 18px 60px -48px rgba(24,32,51,.85);
  backdrop-filter: blur(10px);
  scrollbar-width: thin;
}
.rail-kicker {
  margin: 0 0 .25rem;
  color: var(--brass);
  font-family: var(--mono);
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.rail-name {
  margin: 0;
  font-family: var(--serif);
  font-size: 1.62rem;
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -.01em;
}
.rail-tagline { margin: .45rem 0 0; font-size: .9rem; color: var(--muted); }
.rail-open {
  margin: .85rem 0 1.1rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  font-size: .84rem;
  color: var(--muted);
}
.rail-block { border-top: 1px solid rgba(201,189,173,.75); padding: 1rem 0 1.05rem; margin: 0; }
.rail-block h2 {
  margin: 0 0 .65rem;
  color: var(--muted);
  font-family: var(--mono);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.rail-hint { margin: 0 0 .8rem; color: var(--muted); font-size: .8rem; }
.rail-profiles { list-style: none; margin: 0; padding: 0; display: grid; gap: .28rem; }
.rail-profiles li { display: flex; align-items: center; justify-content: space-between; gap: .55rem; }
.rail-profiles a:not(.rail-pdf) {
  flex: 1;
  padding: .28rem .35rem;
  border-radius: 9px;
  text-decoration: none;
  font-size: .91rem;
}
.rail-profiles a:not(.rail-pdf):hover { background: var(--blue-soft); }
.rail-profiles a.is-active { color: var(--ink); font-weight: 750; background: var(--brass-soft); }
.rail-pdf {
  font-family: var(--mono); font-size: .68rem; font-weight: 800;
  padding: .18rem .48rem; border-radius: 999px;
  border: 1px solid rgba(36,74,120,.25);
  background: #fff; text-decoration: none;
}
.rail-pdf:hover { border-color: var(--brass); }

.budget, .rail-sections { border: 0; margin: 0 0 .9rem; padding: 0; }
.budget legend, .rail-sections legend { font-size: .78rem; font-weight: 800; padding: 0; margin-bottom: .4rem; }
.budget-opt, .rail-sections label {
  display: flex; align-items: center; gap: .55rem;
  padding: .28rem .35rem; border-radius: 10px; cursor: pointer;
  font-size: .84rem;
}
.budget-opt:hover, .rail-sections label:hover { background: rgba(53,95,99,.07); }
.budget-opt input, .rail-sections input { accent-color: var(--brass); }
.budget-pages { display: inline-flex; gap: 2px; }
.pg { width: 9px; height: 12px; background: #fff; border: 1px solid var(--rule-strong); border-radius: 2px; box-shadow: inset 0 2px 0 var(--rule); }
.budget-opt input:checked ~ .budget-pages .pg { border-color: var(--brass); box-shadow: inset 0 2px 0 var(--brass); }
.pg-more { border-style: dashed; }
.btn-make {
  width: 100%; cursor: pointer;
  border: 0; border-radius: 999px;
  padding: .74rem .95rem;
  color: #fff;
  font: 800 .9rem var(--sans);
  background: linear-gradient(135deg, var(--blueprint), #25484b);
  box-shadow: 0 14px 30px -20px rgba(24,32,51,.7);
}
.btn-make:hover { filter: brightness(1.06); }
.btn-make:active { transform: translateY(1px); }
.rail-contact ul { list-style: none; margin: .35rem 0 0; padding: 0; display: flex; flex-wrap: wrap; gap: .35rem; }
.rail-contact li a {
  display: inline-block; padding: .16rem .45rem;
  border: 1px solid rgba(53,95,99,.18); border-radius: 999px;
  background: #fff; text-decoration: none; font-size: .8rem;
}
.rail-contact p { margin: 0; font-size: .88rem; }

/* ------------------------------------------------------- document */
.doc {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #fff 0, var(--sheet) 100%);
  border: 1px solid rgba(53,95,99,.12);
  border-radius: 30px;
  box-shadow: var(--shadow);
  padding: 3rem 3.25rem 3.25rem;
}
.doc::before {
  content: "";
  position: absolute; inset: 0 0 auto 0; height: 10px;
  background: linear-gradient(90deg, var(--blueprint), #6f8c83);
}
.doc::after {
  content: "";
  position: absolute; top: 10px; right: -9rem; width: 22rem; height: 22rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(53,95,99,.10), transparent 70%);
  pointer-events: none;
}
.doc-head {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 118px 1fr;
  gap: 1.45rem;
  align-items: start;
  margin-bottom: 1.35rem;
}
.doc-photo {
  width: 118px; height: 118px; object-fit: cover;
  border-radius: 26px;
  border: 4px solid #fff;
  box-shadow: 0 18px 42px -28px rgba(24,32,51,.75);
  filter: saturate(.97) contrast(1.02);
}
.doc-head h1 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(2rem, 3vw, 3.1rem);
  line-height: 1.03;
  font-weight: 780;
  letter-spacing: -.035em;
}
.doc-tagline { margin: .45rem 0 .55rem; color: var(--muted); font-size: 1.03rem; }
.role-chips { list-style: none; margin: .35rem 0 .75rem; padding: 0; display: flex; flex-wrap: wrap; gap: .38rem; }
.role-chips li {
  padding: .24rem .58rem;
  border-radius: 999px;
  border: 1px solid rgba(53,95,99,.10);
  background: var(--blue-soft);
  color: #233d5b;
  font-size: .78rem;
  font-weight: 750;
}
.doc-open {
  margin: .9rem 0 0;
  padding: .75rem 0 0;
  border-left: 0;
  border-top: 1px solid var(--rule);
  color: var(--muted);
  background: transparent;
}
.doc-contact { margin: .45rem 0 0; font-size: .92rem; color: var(--muted); }
.doc-viewing {
  position: relative; z-index: 1;
  display: flex; flex-wrap: wrap; gap: .35rem .5rem;
  align-items: center;
  margin: 0 0 1.8rem;
  padding: .65rem .85rem;
  border: 1px solid rgba(53,95,99,.13);
  border-radius: 16px;
  background: rgba(234,241,248,.64);
  color: var(--muted);
  font-size: .84rem;
}
.doc-viewing strong { color: var(--ink); }

.cv-section { position: relative; z-index: 1; margin: 0 0 1.85rem; }
.cv-section h2 {
  display: flex; align-items: center; gap: .65rem;
  margin: 0 0 .95rem;
  color: var(--blueprint);
  font-family: var(--mono);
  font-size: .82rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.tick { width: 2rem; height: 3px; border-radius: 999px; background: linear-gradient(90deg, var(--brass), rgba(95,127,115,.18)); flex: none; }
.entry {
  margin: 0 0 .86rem;
  padding: .84rem .95rem;
  border: 1px solid rgba(201,189,173,.65);
  border-radius: 18px;
  background: rgba(255,255,255,.62);
}
.entry header { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; }
.entry-title { margin: 0; font-size: 1.01rem; line-height: 1.25; font-weight: 820; }
.entry-title a { text-decoration: none; border-bottom: 1px solid var(--rule-strong); }
.entry-title a:hover { border-color: var(--brass); }
.entry-dates { font-family: var(--mono); font-size: .72rem; color: var(--muted); white-space: nowrap; }
.entry-sub { margin: .12rem 0 .34rem; color: var(--muted); font-size: .9rem; font-weight: 600; }
.entry-body { font-size: .93rem; }
.md p { margin: .36rem 0 .64rem; }
.md ul { margin: .32rem 0 .72rem; padding-left: 1.25rem; }
.md li { margin: .16rem 0; }
.md li::marker { color: var(--brass); }
.md code { font-family: var(--mono); font-size: .84em; background: var(--paper-soft); border: 1px solid var(--rule); border-radius: 5px; padding: .05em .33em; }
.md pre { background: var(--paper-soft); border: 1px solid var(--rule); border-radius: 12px; padding: .8rem 1rem; overflow-x: auto; }
.md pre code { background: none; border: 0; padding: 0; }
.md img { max-width: 100%; height: auto; border-radius: 12px; }
.skills { margin: 0; display: grid; grid-template-columns: minmax(8.5rem, 12rem) 1fr; gap: .5rem 1rem; }
.skills dt { font-weight: 850; font-size: .9rem; color: var(--blueprint); }
.skills dd { margin: 0; font-size: .92rem; }
.quote { margin: 0 0 1rem; padding: .9rem 1rem; border-left: 4px solid var(--brass); border-radius: 16px; background: rgba(237,244,241,.52); }
.quote blockquote { margin: 0; font-family: var(--serif); font-size: 1.03rem; font-style: italic; }
.quote figcaption { margin-top: .35rem; font-size: .85rem; color: var(--muted); }
.site-foot { max-width: 80rem; margin: 0 auto; padding: 0 1.4rem 2.2rem; font-size: .78rem; color: var(--muted); }

@media (max-width: 68rem) {
  .wrap { grid-template-columns: 1fr; gap: 1.4rem; }
  .rail { position: static; max-height: none; }
}
@media (max-width: 42rem) {
  body { font-size: 15px; }
  .wrap { padding: 1rem .7rem 2rem; }
  .doc { border-radius: 22px; padding: 1.6rem 1rem 1.8rem; }
  .doc-head { grid-template-columns: 1fr; }
  .doc-photo { width: 96px; height: 96px; }
  .entry header { flex-wrap: wrap; gap: .2rem .7rem; }
  .skills { grid-template-columns: 1fr; gap: .1rem; }
}
@media print {
  body { background: #fff; }
  .rail, .site-foot, .doc-viewing, .doc-open, .role-chips { display: none; }
  .wrap { display: block; padding: 0; max-width: none; }
  .doc { border: 0; border-radius: 0; box-shadow: none; padding: 0; }
  .doc::before, .doc::after { display: none; }
  .entry { border: 0; padding: 0; background: transparent; }
}


/* Final responsive hardening. */
.cv-shell, .cv-document, .cv-rail { min-width: 0; }
.cv-document, .cv-section, .entry, .md { overflow-wrap: break-word; }
@media (max-width: 760px) {
  .cv-shell { display: block; width: min(100%, 100vw); }
  .cv-rail { position: static; width: auto; margin-bottom: 1rem; }
  .doc-top { display: block; }
  .doc-actions { margin-top: .8rem; }
  .entry header { display: block; }
  .entry-dates { display: inline-block; margin-top: .1rem; }
}


/* --- saved-view descriptions (extension, same sage language) --------- */
.rail-profiles li {
  padding: .4rem .6rem .45rem;
  margin: 0 0 .3rem -.6rem;
  border-left: 3px solid transparent;
  border-radius: 0 10px 10px 0;
}
.rail-profiles li:hover { background: var(--paper-soft); }
.rail-profiles li.is-active {
  background: var(--sheet);
  border-left-color: var(--brass);
  box-shadow: 0 10px 30px -26px rgba(23, 32, 41, .6);
}
.rail-prof-row { display: flex; align-items: baseline; justify-content: space-between; gap: .6rem; }
.rail-prof-name { text-decoration: none; font-weight: 700; }
.rail-profiles li.is-active .rail-prof-name { color: var(--ink); }
.rail-prof-desc {
  display: block; margin-top: .16rem;
  font-size: .76rem; line-height: 1.4; color: var(--muted);
}

/* PT Sans here too, matching the main site */
@font-face {
  font-family: "PT Sans";
  src: url("/assets/fonts/PT-Sans/PT-Sans_Regular.woff2") format("woff2");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "PT Sans";
  src: url("/assets/fonts/PT-Sans/PT-Sans_Bold.woff2") format("woff2");
  font-weight: 600 800; font-style: normal; font-display: swap;
}
body, button, input, select, textarea {
  font-family: "PT Sans", ui-sans-serif, system-ui, -apple-system,
    "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* Unified top navigation, matching the main site. */
.site-head {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .82rem clamp(1rem, 4vw, 2.2rem);
  border-bottom: 1px solid rgba(23,32,41,.10);
  background: rgba(249,250,248,.82);
  backdrop-filter: blur(16px) saturate(1.05);
}
.brand {
  color: var(--ink);
  text-decoration: none;
  font-size: clamp(1.02rem, 1vw + .65rem, 1.28rem);
  font-weight: 760;
  letter-spacing: -.025em;
  white-space: nowrap;
}
.brand:hover { color: var(--blueprint); }
.site-head nav { display: flex; align-items: center; justify-content: flex-end; gap: .22rem; min-width: 0; }
.site-head nav a {
  padding: .38rem .64rem;
  border-radius: 999px;
  color: #263840;
  text-decoration: none;
  font-size: .9rem;
  font-weight: 720;
  white-space: nowrap;
}
.site-head nav a:hover { background: rgba(53,95,99,.08); color: var(--blueprint); }
.site-head nav a.is-active { background: var(--blue-soft); color: #233d3f; }
@media (max-width: 42rem) {
  .site-head { position: static; display: block; padding: .78rem .85rem .58rem; }
  .brand { display: inline-block; margin-bottom: .45rem; }
  .site-head nav { justify-content: flex-start; gap: .18rem; overflow-x: auto; padding-bottom: .18rem; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .site-head nav::-webkit-scrollbar { display: none; }
  .site-head nav a { padding: .3rem .48rem; font-size: .82rem; }
}
@media print { .site-head { display: none; } }
