/* ── Design tokens ─────────────────────────────────────────── */
:root {
  --font-display: 'Cabinet Grotesk', 'Helvetica Neue', sans-serif;
  --font-body:    'Satoshi', 'Helvetica Neue', sans-serif;
  --font-mono:    'JetBrains Mono', 'Fira Code', 'Courier New', monospace;

  --text-xs:   clamp(0.75rem,  0.7rem  + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem  + 0.35vw, 1rem);
  --text-base: clamp(1rem,     0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem    + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem,   1.2rem  + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem,     1.2rem  + 2.5vw,  3.5rem);

  --space-1:0.25rem; --space-2:0.5rem;  --space-3:0.75rem;
  --space-4:1rem;    --space-5:1.25rem; --space-6:1.5rem;
  --space-8:2rem;    --space-10:2.5rem; --space-12:3rem;
  --space-16:4rem;   --space-20:5rem;   --space-24:6rem;

  --radius-sm:0.375rem; --radius-md:0.625rem;
  --radius-lg:1rem;     --radius-full:9999px;
  --transition: 180ms cubic-bezier(0.16,1,0.3,1);

  /* Narrower content column */
  --content-default: 720px;
  --content-wide: 1120px;
  --header-h: 60px;
}

/* ── Light theme ───────────────────────────────────────────── */
:root[data-theme='light'] {
  --color-bg:         #f4f3ef;
  --color-surface:    #ffffff;
  --color-surface-2:  #f0efe9;
  --color-border:     #d8d6cf;
  --color-divider:    #e4e2db;
  --color-text:       #1a1814;
  --color-text-muted: #6b6a65;
  --color-text-faint: #a8a7a2;
  --color-accent:     #1a5c9e;
  --color-accent-2:   #0d7a5f;
  --color-accent-glow:rgba(26,92,158,0.12);
  --shadow-sm:0 1px 3px rgba(0,0,0,0.06);
  --shadow-md:0 4px 16px rgba(0,0,0,0.08);
  --shadow-lg:0 12px 40px rgba(0,0,0,0.10);
}

/* ── Dark theme ────────────────────────────────────────────── */
:root[data-theme='dark'] {
  --color-bg:         #0d1117;
  --color-surface:    #161b22;
  --color-surface-2:  #1c232e;
  --color-border:     rgba(255,255,255,0.07);
  --color-divider:    rgba(255,255,255,0.05);
  --color-text:       #e6edf3;
  --color-text-muted: #8b949e;
  --color-text-faint: #484f58;
  --color-accent:     #79b8f5;
  --color-accent-2:   #56d364;
  --color-accent-glow:rgba(121,184,245,0.10);
  --shadow-sm:0 1px 3px rgba(0,0,0,0.3);
  --shadow-md:0 4px 16px rgba(0,0,0,0.4);
  --shadow-lg:0 12px 40px rgba(0,0,0,0.5);
}

/* ── Base ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 16px);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.7;color:var(--color-text);background-color:var(--color-bg);transition:background-color .25s var(--transition),color .25s var(--transition);}
img,svg{display:block;max-width:100%;}
ul[role='list'],ol[role='list']{list-style:none;}
h1,h2,h3,h4{text-wrap:balance;font-family:var(--font-display);line-height:1.2;}
p,li{text-wrap:pretty;}
a{color:var(--color-accent);text-decoration:none;transition:color var(--transition);}
a:hover{color:var(--color-text);text-decoration:underline;text-underline-offset:3px;}
button{cursor:pointer;background:none;border:none;font:inherit;color:inherit;}
code,.mono{font-family:var(--font-mono);font-size:.88em;color:var(--color-accent-2);}
::selection{background:var(--color-accent-glow);}
:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;border-radius:var(--radius-sm);}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important;}}

/* ── Layout ────────────────────────────────────────────────── */
.container{width:min(100% - var(--space-8),var(--content-default));margin-inline:auto;}
.container-wide{width:min(100% - var(--space-8),var(--content-wide));margin-inline:auto;}

/* ── Header ────────────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:50;border-bottom:1px solid var(--color-border);background:color-mix(in oklab,var(--color-bg) 85%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);}
.nav{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding-block:var(--space-3);min-height:var(--header-h);}
.logo-link{display:flex;align-items:center;gap:var(--space-2);color:var(--color-text);font-family:var(--font-display);font-weight:700;font-size:var(--text-sm);letter-spacing:-.01em;text-decoration:none;}
.logo-link:hover{color:var(--color-accent);text-decoration:none;}
.logo-mark{width:28px;height:28px;flex-shrink:0;}
.nav-right{display:flex;align-items:center;gap:var(--space-5);}
.nav-links{display:flex;gap:var(--space-4);list-style:none;}
.nav-links a{color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500;letter-spacing:.01em;}
.nav-links a:hover,.nav-links a.active{color:var(--color-text);text-decoration:none;}
.theme-toggle{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-full);color:var(--color-text-muted);border:1px solid var(--color-border);transition:color var(--transition),border-color var(--transition);}
.theme-toggle:hover{color:var(--color-text);border-color:var(--color-text-muted);}
.lang-toggle{display:flex;align-items:center;justify-content:center;height:30px;padding-inline:.6em;border-radius:var(--radius-full);color:var(--color-text-muted);border:1px solid var(--color-border);font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;transition:color var(--transition),border-color var(--transition);cursor:pointer;background:transparent;}
.lang-toggle:hover{color:var(--color-text);border-color:var(--color-text-muted);}

/* ── Language toggle ───────────────────────────────────────── */
html[data-lang="en"] [lang="ru"]{display:none !important;}
html[data-lang="ru"] [lang="en"]{display:none !important;}

/* ── Hero ──────────────────────── */
.hero{padding-block:clamp(var(--space-10),6vw,var(--space-16));border-bottom:1px solid var(--color-border);}
.hero-inner{display:grid;grid-template-columns:88px 1fr;gap:var(--space-6);align-items:start;}
.hero-photo-col{padding-top:4px;}
.hero-photo{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid var(--color-border);}
.hero-text-col{}
.hero-name{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;color:var(--color-text);margin-bottom:var(--space-1);}
.hero-role{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-4);font-style:italic;}
.hero-bio{font-size:var(--text-base);color:var(--color-text-muted);line-height:1.75;margin-bottom:var(--space-4);}
.hero-bio p+p{margin-top:var(--space-3);}
.hero-ctas{display:flex;gap:var(--space-5);flex-wrap:wrap;font-size:var(--text-sm);}
.hero-ctas a{color:var(--color-accent);}
.arrow-link::before{content:'→ ';}

/* ── Section shared ────────────────────────────────────────── */
.section{padding-block:clamp(var(--space-10),6vw,var(--space-16));border-bottom:1px solid var(--color-border);}
.section:last-of-type{border-bottom:none;}
.section-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;letter-spacing:-.025em;color:var(--color-text);margin-bottom:var(--space-6);}
.section-intro{font-size:var(--text-base);color:var(--color-text-muted);line-height:1.75;margin-bottom:var(--space-6);}

/* ── About ─────────────────────────────────────────────────── */
.about-prose{font-size:var(--text-base);color:var(--color-text-muted);line-height:1.8;}
.about-prose p{margin-bottom:var(--space-4);}
.about-prose p:last-child{margin-bottom:0;}
.about-prose a{color:var(--color-accent);}

/* collapsible past life */
details.past-life{margin-top:var(--space-4);border-top:1px solid var(--color-border);padding-top:var(--space-4);}
details.past-life summary{font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;user-select:none;list-style:none;display:flex;align-items:center;gap:var(--space-2);}
details.past-life summary::-webkit-details-marker{display:none;}
details.past-life summary::before{content:'▸';font-size:.7em;transition:transform .2s;}
details.past-life[open] summary::before{transform:rotate(90deg);}
details.past-life summary:hover{color:var(--color-text);}
.past-life-body{margin-top:var(--space-4);font-size:var(--text-base);color:var(--color-text-muted);line-height:1.8;}
.past-life-body p{margin-bottom:var(--space-3);}

/* Speaking section */
.speaking-subhead{font-family:var(--font-display);font-size:var(--text-base);font-weight:700;color:var(--color-text);margin-top:var(--space-8);margin-bottom:var(--space-4);}
.speaking-topics{list-style:none;display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4);}
.speaking-topics li{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6;padding-left:var(--space-4);position:relative;}
.speaking-topics li::before{content:'▸';position:absolute;left:0;color:var(--color-accent-2);font-size:.65em;top:.25em;}
.keynote-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:var(--space-5);}
.keynote-card{display:flex;flex-direction:column;border-radius:var(--radius-lg);overflow:hidden;text-decoration:none;transition:transform var(--transition),box-shadow var(--transition);border:1px solid var(--color-border);}
.keynote-card:hover{transform:translateY(-2px);box-shadow:0 4px 24px rgba(0,0,0,.15);}
.keynote-card img{width:100%;aspect-ratio:16/9;object-fit:cover;}
.keynote-info{padding:var(--space-3) var(--space-4) var(--space-4);}
.keynote-title{font-size:var(--text-sm);font-weight:600;color:var(--color-text);line-height:1.4;margin-bottom:var(--space-1);}
.keynote-meta{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-faint);letter-spacing:.03em;}
.speaking-booking{margin-top:var(--space-8);}
.speaking-booking p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.65;}
.speaking-booking a{color:var(--color-accent);}

/* Third-person bio */
.bio-details{margin-top:var(--space-8);border-top:1px solid var(--color-border);padding-top:var(--space-4);}
.bio-details summary{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-faint);cursor:pointer;user-select:none;list-style:none;display:flex;align-items:center;gap:var(--space-2);}
.bio-details summary::-webkit-details-marker{display:none;}
.bio-details summary::before{content:'\25B8';font-size:.7em;transition:transform .2s;}
.bio-details[open] summary::before{transform:rotate(90deg);}
.bio-details summary:hover{color:var(--color-text);}
.bio-block-body{margin-top:var(--space-4);}
.bio-block-text{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.75;border-left:2px solid var(--color-border);padding-left:var(--space-4);}

/* credentials note */
.creds-note{margin-top:var(--space-6);font-size:var(--text-sm);color:var(--color-text-faint);border-top:1px solid var(--color-border);padding-top:var(--space-4);}
.creds-note a{color:var(--color-accent);}

/* ── Card ──────────────────────────────────────────────────── */
.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);box-shadow:var(--shadow-sm);transition:border-color var(--transition),box-shadow var(--transition);}
.card:hover{border-color:var(--color-text-faint);box-shadow:var(--shadow-md);}

/* ── Work grid ─────────────────────────────────────────────── */
.work-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,320px),1fr));gap:var(--space-4);}
.work-card h3{font-size:var(--text-base);font-weight:700;color:var(--color-text);margin-bottom:var(--space-1);}
.work-meta{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-accent);letter-spacing:.03em;margin-bottom:var(--space-3);}
.work-card p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.65;}
.work-card ul{margin-top:var(--space-3);padding-left:var(--space-4);list-style:disc;}
.work-card li{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6;margin-bottom:var(--space-1);}
.work-link{display:inline-block;margin-top:var(--space-3);font-size:var(--text-sm);}
.work-link::before{content:'→ ';}

/* ── Career Timeline ───────────────────────────────────────── */
.timeline-controls{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);}
.timeline-arrow{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-full);border:1px solid var(--color-border);color:var(--color-accent);background:var(--color-surface);transition:border-color var(--transition),background var(--transition),opacity var(--transition);flex-shrink:0;}
.timeline-arrow:disabled{opacity:.25;cursor:default;}
.timeline-arrow:not(:disabled):hover{border-color:var(--color-accent);background:var(--color-surface-2);}
.timeline-viewport{flex:1;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;scrollbar-width:none;-webkit-overflow-scrolling:touch;}
.timeline-viewport::-webkit-scrollbar{display:none;}
.timeline-rail{position:relative;display:inline-block;min-width:100%;padding:.5rem 0 .25rem;}
.timeline-line{position:absolute;left:0;right:0;top:17px;height:2px;background:linear-gradient(90deg,transparent 0,var(--color-accent) 8%,var(--color-accent) 92%,transparent 100%);opacity:.4;z-index:0;}
.timeline-track{position:relative;z-index:1;display:flex;gap:var(--space-3);min-width:max-content;align-items:flex-start;padding:0 var(--space-2);}
.timeline-item{flex:0 0 100px;max-width:100px;text-align:center;cursor:pointer;user-select:none;transition:transform var(--transition);}
.timeline-item.active{transform:translateY(-2px);}
.timeline-marker{width:22px;height:22px;margin:0 auto var(--space-3);display:flex;align-items:center;justify-content:center;color:var(--color-accent);transition:transform .2s ease,color .2s ease,filter .2s ease;}
.timeline-marker::before{content:'';width:12px;height:12px;border-radius:50%;border:2px solid currentColor;background:var(--color-bg);display:block;}
.timeline-item:hover .timeline-marker{transform:scale(1.15);}
.timeline-item.active .timeline-marker{color:var(--color-accent-2);filter:drop-shadow(0 0 6px rgba(86,211,100,.35));}
.timeline-item.active .timeline-marker::before{background:currentColor;border-color:currentColor;box-shadow:0 0 0 3px rgba(86,211,100,.18);}
.timeline-name{font-size:var(--text-xs);font-weight:600;color:var(--color-text-muted);line-height:1.2;white-space:normal;overflow-wrap:anywhere;}
.timeline-item.active .timeline-name,.timeline-item:hover .timeline-name{color:var(--color-text);}
.timeline-detail{margin-top:var(--space-4);border-top:1px solid var(--color-border);padding-top:var(--space-5);}
.timeline-detail-header{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-2);}
.timeline-company{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;color:var(--color-text);}
.timeline-years{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-accent);letter-spacing:.04em;}
.timeline-role{font-size:var(--text-sm);font-weight:600;color:var(--color-text-muted);margin-bottom:var(--space-4);}
.timeline-facts{list-style:none;display:grid;gap:var(--space-2);}
.timeline-facts li{position:relative;padding-left:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6;}
.timeline-facts li::before{content:'›';position:absolute;left:0;color:var(--color-accent);font-weight:700;}

/* ── Talks ─────────────────────────────────────────────────── */
.talks-year-group{margin-bottom:var(--space-6);}
.talks-year-group:last-child{margin-bottom:0;}
.year-label{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border);}
.talk-list{list-style:none;display:flex;flex-direction:column;gap:0;}
.talk-item{display:grid;grid-template-columns:160px 1fr;gap:var(--space-4);padding-block:var(--space-3);border-bottom:1px solid var(--color-divider);align-items:baseline;}
.talk-item:last-child{border-bottom:none;}
.talk-venue{font-size:var(--text-sm);font-weight:600;color:var(--color-accent);line-height:1.4;}
.talk-title{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.5;}
.talk-co{font-size:var(--text-xs);color:var(--color-text-faint);}
.talks-archive{display:none;}
.talks-archive.expanded{display:block;}
.show-more-btn{display:inline-flex;align-items:center;gap:var(--space-2);margin-top:var(--space-5);font-size:var(--text-sm);color:var(--color-accent);background:none;border:none;padding:0;cursor:pointer;}
.show-more-btn:hover{color:var(--color-text);}
.show-more-btn::before{content:'→ ';}

/* ── Talks & Writing grid ──────────────────────────────────── */
.talks-writing-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);}
.talks-writing-col h3{font-size:var(--text-sm);font-weight:700;color:var(--color-text);margin-bottom:var(--space-4);}
.talks-archive-details,.writing-archive-details{margin-top:var(--space-5);}
.talks-archive-details summary,.writing-archive-details summary{font-size:var(--text-sm);color:var(--color-accent);cursor:pointer;user-select:none;list-style:none;display:inline-flex;align-items:center;gap:var(--space-2);}
.talks-archive-details summary::-webkit-details-marker,.writing-archive-details summary::-webkit-details-marker{display:none;}
.talks-archive-details summary::before,.writing-archive-details summary::before{content:'→ ';}
.talks-archive-details summary:hover,.writing-archive-details summary:hover{color:var(--color-text);}
.talks-archive-details[open],.writing-archive-details[open]{margin-top:var(--space-4);}
.talks-archive-details h4,.writing-archive-details h4{font-size:var(--text-sm);font-weight:600;color:var(--color-text-muted);margin-top:var(--space-5);margin-bottom:var(--space-3);}

/* ── Writing / Links grid ──────────────────────────────────── */
.links-two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);}
.links-card h3{font-size:var(--text-sm);font-weight:700;color:var(--color-text);margin-bottom:var(--space-4);}
.links-card h3+h3{margin-top:var(--space-6);}
.link-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-2);}
.link-list+h3{margin-top:var(--space-6)!important;}
.link-list li{font-size:var(--text-sm);line-height:1.45;color:var(--color-text-muted);}
.link-list li a{color:var(--color-text-muted);}
.link-list li a:hover{color:var(--color-accent);text-decoration:underline;text-underline-offset:3px;}
.link-note{font-size:var(--text-xs);color:var(--color-text-faint);display:block;}
.links-full{margin-top:var(--space-4);}

/* Video feed */
.video-feed{list-style:none;display:flex;flex-direction:column;gap:0;}
.video-item{display:grid;grid-template-columns:40px 1fr;gap:var(--space-3);padding-block:var(--space-3);border-bottom:1px solid var(--color-divider);align-items:baseline;}
.video-item:last-child{border-bottom:none;}
.video-icon{font-size:1rem;text-align:center;}
.video-meta{font-size:var(--text-xs);color:var(--color-text-faint);margin-top:2px;}

/* ── Contact ───────────────────────────────────────────────── */
.contact-list{list-style:none;display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--space-6);}
.contact-item{display:flex;flex-direction:column;gap:var(--space-1);}
.contact-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-faint);letter-spacing:.06em;text-transform:uppercase;}
.contact-value{font-size:var(--text-base);font-weight:500;color:var(--color-text);}
.contact-value a{color:var(--color-text);}
.contact-value a:hover{color:var(--color-accent);}

/* ── Footer ────────────────────────────────────────────────── */
.site-footer{padding-block:var(--space-8);border-top:1px solid var(--color-border);}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap;}
.footer-copy{font-size:var(--text-xs);color:var(--color-text-faint);}
.footer-links{display:flex;gap:var(--space-5);}
.footer-links a{font-size:var(--text-xs);color:var(--color-text-faint);}
.footer-links a:hover{color:var(--color-text);text-decoration:none;}

/* ── Responsive ────────────────────────────────────────────── */
@media(max-width:640px){
  .nav-links{display:none;}
  .hero-inner{grid-template-columns:72px 1fr;gap:var(--space-4);}
  .hero-photo{width:64px;height:64px;}
  .links-two-col,.talks-writing-grid{grid-template-columns:1fr;}
  .talk-item{grid-template-columns:1fr;gap:var(--space-1);}
  .video-item{grid-template-columns:32px 1fr;}
}
