/* === SWISS v4 — production CSS (lifted from swiss-v4.html mockup) === */

:root {
  --bg: #fafaf7; --fg: #0f0f0f; --accent: #bd451f;
  --rule: #e8e4db; --rule-dashed: #e0d9c9;
  --mono: #6a665e; --mono-faded: #706a64;
  --bullet-dash: #b0a99a; --bio: #1a1a1a; --bullet: #333;
  --stack-bg: #f1ede3; --stack-fg: #6a6459;
  --list-border: #ebe7dd;
  --pill-bg: #0f0f0f; --pill-fg: #fafaf7;
  --contact-underline: #c8c2b4;
  --mono-sm: 10.5px;
  --mono-md: 11.5px;
}

.page[data-theme="dark"] {
  --bg: #0f0e0c; --fg: #ededeb; --accent: #e86a3e;
  --rule: #2a2822; --rule-dashed: #2a2822;
  --mono: #a8a39a; --mono-faded: #8a8680;
  --bullet-dash: #5c5954; --bio: #d8d4cc; --bullet: #c4bfb6;
  --stack-bg: #1a1815; --stack-fg: #a8a39a;
  --list-border: #2a2822;
  --pill-bg: #ededeb; --pill-fg: #0f0e0c;
  --contact-underline: #3d3a36;
}

.page {
  background: var(--bg); color: var(--fg);
  font-family: 'Inter', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  border-radius: 6px; overflow: hidden; line-height: 1.55; position: relative;
  transition: background 0.2s, color 0.2s;
}
.page .wrap { max-width: 880px; margin: 0 auto; padding: 48px 40px 56px; }

.page .theme-toggle {
  position: absolute; top: 20px; right: 20px; z-index: 10;
  display: flex; gap: 0; border: 1px solid var(--rule);
  border-radius: 2px; overflow: hidden; background: var(--bg);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: var(--mono-sm); letter-spacing: 0.08em; text-transform: uppercase;
}
.page .theme-toggle button {
  background: transparent; border: 0; padding: 10px 12px; min-height: 40px;
  color: var(--mono); cursor: pointer; font-family: inherit; font-size: inherit; letter-spacing: inherit;
  transition: background 0.15s, color 0.15s;
}
.page .theme-toggle button[aria-pressed="true"] { background: var(--fg); color: var(--bg); }
.page .theme-toggle button:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.page .theme-toggle button:hover:not([aria-pressed="true"]) { color: var(--fg); }

.meta {
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: var(--mono-sm); letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--mono-faded); padding: 0 120px 14px 0; border-bottom: 1px solid var(--rule);
}
.meta .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--accent); display:inline-block; margin-right:7px; vertical-align:1px; }

.hero { padding: 36px 0 28px; }
.hero h1 { font-size: 88px; line-height: 0.92; letter-spacing: -0.045em; font-weight: 700; margin: 0 0 24px; color: var(--fg); }
.hero h1 em { font-style: normal; color: var(--accent); font-weight: 700; }
.role-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; font-size: 14px; color: var(--bio); }
.role-row .pill {
  font-family: 'JetBrains Mono', monospace; font-size: var(--mono-sm);
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 5px 10px; background: var(--pill-bg); color: var(--pill-fg);
  display: inline-flex; align-items: center; gap: 8px;
}
.role-row .pill .open-dot { color: var(--accent); font-size: 12px; line-height: 1; }
.role-row .sep { color: var(--rule-dashed); }

.reach {
  margin-top: 14px; font-family: 'JetBrains Mono', monospace;
  font-size: var(--mono-md); letter-spacing: 0.04em; color: var(--mono-faded);
  display: flex; gap: 2px 14px; flex-wrap: wrap; align-items: baseline;
}
/* separator via ::after — wraps at END of line, never strands */
.reach > *:not(:last-child)::after {
  content: ' ·'; color: var(--rule-dashed); margin-left: 14px;
}
.reach a { color: var(--fg); text-decoration: none; border-bottom: 1px solid var(--contact-underline); padding-bottom: 1px; transition: border-color 0.15s; }
.reach a:hover { border-bottom-color: var(--accent); }
.reach a:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 1px; }

.section { padding: 26px 0; border-top: 1px solid var(--rule); }
.section-head { display: grid; grid-template-columns: 64px 1fr; gap: 24px; align-items: baseline; margin-bottom: 18px; }
.idx { font-family: 'JetBrains Mono', monospace; font-size: var(--mono-md); color: var(--mono-faded); letter-spacing: 0.08em; }
.h { font-size: 13px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--fg); margin:0; }
.row { display: grid; grid-template-columns: 64px 1fr; gap: 24px; }
.label { font-family: 'JetBrains Mono', monospace; font-size: var(--mono-sm); color: var(--mono); letter-spacing: 0.08em; padding-top: 3px; }

.bio p { font-size: 15px; line-height: 1.65; color: var(--bio); margin: 0 0 12px; max-width: 62ch; }

.job { display: grid; grid-template-columns: 180px 1fr; gap: 32px; padding: 24px 0; border-top: 1px dashed var(--rule-dashed); }
.job:first-child { border-top: 0; padding-top: 4px; }
.job .left .company { font-size: 15px; font-weight: 600; color: var(--fg); margin-bottom: 4px; letter-spacing: -0.005em; }
.job .left .dates { font-family: 'JetBrains Mono', monospace; font-size: var(--mono-sm); color: var(--mono-faded); letter-spacing: 0.04em; }
.job .left .loc { font-size: var(--mono-md); color: var(--mono); margin-top: 3px; font-family: 'JetBrains Mono', monospace; letter-spacing: 0.02em; }

.role-block { margin-bottom: 22px; }
/* thin rule between sub-roles under the same company, from v2 */
.role-block + .role-block { padding-top: 18px; border-top: 1px dashed var(--rule-dashed); }
.role-block:last-child { margin-bottom: 0; }
.role-block h4 { font-size: 14px; font-weight: 500; margin: 0 0 10px; color: var(--fg); }
.role-block ul { margin: 0; padding: 0; list-style: none; }
.role-block li { font-size: 14px; line-height: 1.55; color: var(--bullet); padding: 4px 0 4px 14px; position: relative; }
.role-block li::before { content: '–'; position: absolute; left: 0; color: var(--bullet-dash); }
.stack { font-family: 'JetBrains Mono', monospace; font-size: var(--mono-md); color: var(--stack-fg); margin-top: 10px; padding: 6px 9px; background: var(--stack-bg); border-left: 2px solid var(--accent); line-height: 1.45; }

.cols { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.list { list-style: none; padding: 0; margin: 0; }
.list li { padding: 6px 0; font-size: 14px; border-bottom: 1px solid var(--list-border); display: flex; justify-content: space-between; gap: 10px; color: var(--bio); }
.list li:last-child { border-bottom: 0; }
.list li .mono-tag { font-family: 'JetBrains Mono', monospace; font-size: var(--mono-sm); color: var(--mono); white-space: nowrap; }

.footer { margin-top: 36px; padding-top: 16px; border-top: 1px solid var(--fg); font-family: 'JetBrains Mono', monospace; font-size: var(--mono-sm); color: var(--mono-faded); letter-spacing: 0.08em; text-transform: uppercase; display: flex; gap: 14px; flex-wrap: wrap; justify-content: space-between; align-items: baseline; }
.footer .contacts-echo a { color: var(--mono-faded); text-decoration: none; border-bottom: 1px solid var(--contact-underline); padding-bottom: 1px; }
.footer .contacts-echo a:hover { color: var(--fg); border-bottom-color: var(--accent); }
.footer .version { color: var(--mono-faded); }

/* footer contacts-echo separator */
.footer .contacts-echo a:not(:last-child)::after {
  content: ' · '; color: var(--rule-dashed); margin-left: 8px;
}

/* === NEW SELECTORS — education & recommendations === */
.edu-school { font-size: 14.5px; font-weight: 600; margin-bottom: 4px; color: var(--fg); }
.edu-dates { font-size: 12.5px; color: var(--mono-faded); margin-bottom: 8px; font-family: 'JetBrains Mono', ui-monospace, monospace; letter-spacing: 0.04em; }
.edu-degree { font-size: 13.5px; color: var(--bullet); }
.refs { font-size: 14px; color: var(--bullet); }
.ref { margin-bottom: 8px; }
.ref strong { color: var(--fg); }
.refs-note { margin-top: 10px; font-size: 11.5px; color: var(--mono-faded); }

/* === MOBILE === */
@media (max-width: 640px) {
  .page .wrap { padding: 64px 20px 40px; }
  .page .theme-toggle { top: 16px; right: 16px; }
  .page .theme-toggle button { padding: 10px 11px; min-height: 40px; }
  .meta { padding-right: 0; }
  .meta > span:last-child { display: none; }
  .hero { padding: 24px 0 22px; }
  .hero h1 { font-size: 48px; line-height: 0.96; letter-spacing: -0.035em; margin-bottom: 18px; }
  .role-row { font-size: 12.5px; gap: 8px; }
  .role-row .pill { font-size: 10px; padding: 4px 8px; }
  .reach { margin-top: 12px; font-size: 11px; gap: 2px 10px; }
  .reach > *:not(:last-child)::after { margin-left: 10px; }
  .section-head { display: flex; gap: 12px; align-items: baseline; margin-bottom: 12px; grid-template-columns: none; }
  .row { grid-template-columns: 1fr; gap: 10px; }
  .idx { font-size: var(--mono-sm); }
  .label { display: none; }
  .bio p { font-size: 14.5px; }
  .job { grid-template-columns: 1fr; gap: 14px; padding: 20px 0; }
  .job .left { display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px 12px; }
  .job .left .company { margin-bottom: 0; }
  .job .left .loc { margin-top: 0; }
  .cols { grid-template-columns: 1fr; gap: 24px; }
  .role-block li { font-size: 13.5px; }
  .footer { gap: 8px 14px; }
  .footer .contacts-echo { display: flex; gap: 8px 14px; flex-wrap: wrap; }
}
@media (max-width: 380px) {
  .hero h1 { font-size: 40px; }
  .role-row .pill { font-size: 9.5px; }
}

/* === PRINT === */
@page { margin: 15mm 12mm; }
@media print {
  .page, .page[data-theme="dark"] {
    --bg: #fff; --fg: #000; --accent: #000;
    --rule: #ccc; --rule-dashed: #ddd;
    --mono: #444; --mono-faded: #555;
    --bullet-dash: #888; --bio: #111; --bullet: #111;
    --stack-bg: transparent; --stack-fg: #333;
    --list-border: #ddd;
    --pill-bg: #000; --pill-fg: #fff;
    --contact-underline: #999;
  }
  .page { background: #fff; color: #000; }
  .page .wrap { max-width: none; padding: 0; }
  .page .theme-toggle { display: none !important; }
  .hero { padding: 0 0 14px; }
  .hero h1 { font-size: 36px; margin-bottom: 10px; }
  .role-row .pill .open-part { display: none !important; }
  .role-row .sep, .role-row > span:last-child { display: none; }
  .reach { margin-top: 8px; font-size: var(--mono-sm); }
  .reach a { border-bottom: 0; }
  .reach a::after { content: ' (' attr(href) ')'; color: #666; font-size: 0.85em; }
  .section { padding: 14px 0; page-break-inside: auto; }
  .section-head { margin-bottom: 10px; }
  .job { break-inside: avoid; padding: 10px 0; }
  .stack { background: transparent; padding: 4px 0 4px 10px; border-left-color: #888; }
  .role-block { margin-bottom: 14px; break-inside: avoid; }
  .role-block + .role-block { border-top-color: #ddd; }
  .role-block h4 { font-size: 12.5px; }
  .role-block li { font-size: 11.5px; padding: 2px 0 2px 10px; }
  .meta { font-size: 9px; padding: 0 0 10px; }
  .footer .version { display: none; }
  .footer { border-top: 1px solid #ccc; margin-top: 18px; padding-top: 10px; }
  .footer a::after { content: none; }
  .footer a { border-bottom: 0; color: #555 !important; }
}
