/* ============================================================
   cv.gomanov.pro — резюме
   Часть 1: общая дизайн-система (site)
   Часть 2: страничные стили «письма»
   Newsreader (serif) · Hanken Grotesk (sans) · Space Mono (mono) · Caveat (подпись)
   ============================================================ */

/* ===================== ДИЗАЙН-СИСТЕМА ===================== */

:root {
  /* warm light palette */
  --paper:      #f3ecdd;
  --paper-2:    #ece3d0;
  --paper-3:    #e4d8bf;
  --card:       #f8f3e8;
  --ink:        #2b2620;
  --ink-2:      #4a4338;
  --ink-soft:   #756b5b;
  --line:       rgba(43, 38, 32, 0.16);
  --line-2:     rgba(43, 38, 32, 0.28);
  --accent:     #b65a3c;
  --accent-2:   #9a4528;
  --accent-tint:#efd9cb;
  --on-accent:  #fbf6ee;

  --serif: "Newsreader", Georgia, "Times New Roman", serif;
  --sans:  "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --mono:  "Space Mono", ui-monospace, "SFMono-Regular", monospace;

  --maxw: 1140px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 14px;
  --shadow: 0 1px 2px rgba(43,38,32,.05), 0 12px 30px -18px rgba(43,38,32,.30);
  --shadow-lg: 0 30px 60px -32px rgba(43,38,32,.45);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --paper:      #1f1b16;
    --paper-2:    #272219;
    --paper-3:    #2f2920;
    --card:       #292319;
    --ink:        #efe6d6;
    --ink-2:      #d2c7b3;
    --ink-soft:   #a4977f;
    --line:       rgba(239, 230, 214, 0.14);
    --line-2:     rgba(239, 230, 214, 0.26);
    --accent:     #e0825a;
    --accent-2:   #eca079;
    --accent-tint:#3a2a20;
    --on-accent:  #20160f;
    --shadow:     0 1px 2px rgba(0,0,0,.4), 0 12px 30px -18px rgba(0,0,0,.6);
    --shadow-lg:  0 30px 60px -32px rgba(0,0,0,.7);
  }
}
[data-theme="dark"] {
  --paper:      #1f1b16;
  --paper-2:    #272219;
  --paper-3:    #2f2920;
  --card:       #292319;
  --ink:        #efe6d6;
  --ink-2:      #d2c7b3;
  --ink-soft:   #a4977f;
  --line:       rgba(239, 230, 214, 0.14);
  --line-2:     rgba(239, 230, 214, 0.26);
  --accent:     #e0825a;
  --accent-2:   #eca079;
  --accent-tint:#3a2a20;
  --on-accent:  #20160f;
  --shadow:     0 1px 2px rgba(0,0,0,.4), 0 12px 30px -18px rgba(0,0,0,.6);
  --shadow-lg:  0 30px 60px -32px rgba(0,0,0,.7);
}

/* ---------- reset ---------- */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  margin: 0; background: var(--paper); color: var(--ink);
  font-family: var(--sans); font-size: 17px; line-height: 1.6;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
h1,h2,h3,h4,p,ul,ol,figure,blockquote { margin: 0; }
ul,ol { padding: 0; list-style: none; }
a { color: inherit; text-decoration: none; }
img,svg { display: block; max-width: 100%; }
::selection { background: var(--accent); color: var(--on-accent); }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 3px; }

/* ---------- type ---------- */
.serif { font-family: var(--serif); }
.mono  { font-family: var(--mono); }
.muted { color: var(--ink-soft); }
.measure { max-width: 56ch; }

.kicker {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-soft);
}

/* ---------- links & tags ---------- */
.link {
  display: inline-flex; align-items: center; gap: 8px; font-weight: 600;
  border-bottom: 1.5px solid var(--accent); padding-bottom: 2px;
  transition: gap .18s, color .18s;
}
.link:hover { gap: 12px; color: var(--accent); }
.link .arr { transition: transform .18s; }
.link:hover .arr { transform: translateX(2px); }

.tags { display: flex; flex-wrap: wrap; gap: 8px; }
.tag {
  font-family: var(--mono); font-size: 12px; color: var(--ink-2);
  border: 1px solid var(--line-2); border-radius: 999px; padding: 6px 12px;
  background: transparent;
}

/* theme toggle */
.theme-btn {
  width: 38px; height: 38px; border-radius: 999px; border: 1px solid var(--line-2);
  background: transparent; color: var(--ink-2); cursor: pointer;
  display: grid; place-items: center; transition: border-color .15s, color .15s;
  flex-shrink: 0;
}
.theme-btn:hover { border-color: var(--accent); color: var(--accent); }
.theme-btn svg { width: 18px; height: 18px; }
.theme-btn .ico-dark { display: none; }
[data-theme="dark"] .theme-btn .ico-dark { display: block; }
[data-theme="dark"] .theme-btn .ico-light { display: none; }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .theme-btn .ico-dark { display: block; }
  :root:not([data-theme="light"]) .theme-btn .ico-light { display: none; }
}

/* ---------- footer (shared) ---------- */
.foot { background: var(--paper-2); border-top: 1px solid var(--line); padding-block: 48px; }
.foot-inner { display: flex; justify-content: space-between; align-items: flex-start; gap: 28px; flex-wrap: wrap; }
.foot b { font-family: var(--serif); font-size: 20px; font-weight: 600; }
.foot .kicker { display: block; margin-top: 6px; }
.foot-links { display: flex; gap: 24px; flex-wrap: wrap; }
.foot-links a { font-size: 14.5px; color: var(--ink-2); transition: color .15s; }
.foot-links a:hover { color: var(--accent); }

/* ===================== СТРАНИЦА CV · «Письмо» ===================== */

.page-cv { background: var(--paper); }

/* slim top */
.cv-top { position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter: saturate(150%) blur(12px); border-bottom: 1px solid var(--line); }
.cv-top-inner { width: min(760px, 100%); margin: 0 auto; padding: 14px var(--gutter); display: flex; align-items: center; gap: 16px; }
.cv-top .name { font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-soft); }
.cv-top .spacer { margin-left: auto; }
.cv-top a.mini { font-size: 14px; color: var(--ink-2); border-bottom: 1.5px solid var(--accent); padding-bottom: 2px; }

/* the letter column */
.letter { width: min(660px, 100%); margin: 0 auto; padding-inline: var(--gutter); }
.letter-wide { width: min(760px, 100%); margin: 0 auto; padding-inline: var(--gutter); }

.cv-intro { padding-top: clamp(40px, 7vw, 84px); text-align: center; display: flex; flex-direction: column; align-items: center; gap: 20px; }
.cv-portrait { width: 116px; height: 116px; border-radius: 50%; object-fit: cover; box-shadow: var(--shadow); background: var(--paper-3); }
.cv-meta { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-soft); }
.cv-intro h1 { font-family: var(--serif); font-weight: 500; line-height: 1.05; letter-spacing: -0.02em; font-size: clamp(30px, 5vw, 46px); }
.cv-intro h1 em { font-style: italic; color: var(--accent); }

/* prose */
.prose { padding-top: clamp(36px, 5vw, 56px); }
.prose p { font-family: var(--serif); font-size: clamp(19px, 2.3vw, 22px); line-height: 1.62; color: var(--ink); margin-bottom: 22px; }
.prose p.first { position: relative; }
.prose .dropcap { font-family: var(--serif); font-size: 3.4em; line-height: 0.72; float: left; padding: 10px 12px 0 0; color: var(--accent); font-weight: 500; }
.prose strong { font-weight: 600; }
.prose .ink-soft { color: var(--ink-soft); }

/* section label inside letter */
.cv-label { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); margin-bottom: 18px; }
.cv-h { font-family: var(--serif); font-weight: 500; line-height: 1.08; letter-spacing: -0.01em; font-size: clamp(26px, 3.4vw, 36px); margin-bottom: 22px; }
.cv-sec { padding-block: clamp(44px, 6vw, 72px); }
.cv-divider { width: 56px; height: 2px; background: var(--accent); margin: 0 auto; border: 0; }

/* availability */
.avail-list { display: grid; gap: 0; border-top: 1px solid var(--line-2); margin-top: 8px; }
.avail-list li { padding: 18px 0; border-bottom: 1px solid var(--line); display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: baseline; }
.avail-list .badge { font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--on-accent); background: var(--accent); padding: 4px 10px; border-radius: 999px; white-space: nowrap; }
.avail-list .badge.soft { color: var(--accent); background: var(--accent-tint); }
.avail-list p { color: var(--ink-2); font-size: 16px; }
.avail-list p b { color: var(--ink); }

/* strengths */
.strengths { display: grid; gap: 0; border-top: 1px solid var(--line-2); }
.strength { padding: 26px 0; border-bottom: 1px solid var(--line); display: grid; grid-template-columns: 1fr; gap: 8px; }
.strength h3 { font-family: var(--serif); font-weight: 500; font-size: clamp(20px, 2.6vw, 25px); letter-spacing: -0.01em; }
.strength .en { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); }
.strength p { color: var(--ink-2); font-size: 16px; }

/* experience narrative */
.exp { display: grid; gap: 0; border-top: 1px solid var(--line-2); }
.exp-item { padding: 24px 0; border-bottom: 1px solid var(--line); }
.exp-item h3 { font-family: var(--serif); font-weight: 500; font-size: clamp(19px, 2.4vw, 23px); margin-bottom: 6px; }
.exp-item p { color: var(--ink-2); font-size: 16px; }

/* tech */
.cv-tags { display: flex; flex-wrap: wrap; gap: 8px; }

/* quote */
.cv-quote { text-align: center; padding-block: clamp(48px, 7vw, 88px); }
.cv-quote blockquote { font-family: var(--serif); font-style: italic; font-weight: 400; line-height: 1.3; letter-spacing: -0.01em; font-size: clamp(24px, 3.6vw, 38px); color: var(--ink); }
.cv-quote blockquote span { color: var(--accent); }

/* signature + contact */
.cv-sign { padding-block: clamp(40px, 6vw, 64px); }
.sig { font-family: "Caveat", cursive; font-size: clamp(34px, 5vw, 46px); color: var(--ink); line-height: 1; }
.cv-contact { display: grid; gap: 0; border-top: 1px solid var(--line-2); margin-top: 28px; }
.cv-contact li { display: grid; grid-template-columns: 130px 1fr; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--line); align-items: baseline; }
.cv-contact .k { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-soft); }
.cv-contact a { border-bottom: 1.5px solid var(--accent); padding-bottom: 1px; font-weight: 600; }

.cv-ps { background: var(--paper-2); border-top: 1px solid var(--line); padding-block: clamp(36px, 5vw, 56px); }
.cv-ps p { font-size: 17px; color: var(--ink-2); }
.cv-ps p b { color: var(--ink); }

/* footer narrower on CV */
.page-cv .foot-inner { width: min(760px, 100%); }

@media (max-width: 520px) {
  .avail-list li, .cv-contact li { grid-template-columns: 1fr; gap: 6px; }
  .prose .dropcap { font-size: 2.9em; }
}
