/* ============================================================
   Manpreet Singh — research site
   "The Paper": light-first, typographic, one indigo accent
   ============================================================ */

:root{
  --paper:#FBFAF7;
  --paper-2:#F4F2EC;
  --card:#FFFFFF;
  --ink:#1A1A1A;
  --ink-2:#43464D;
  --muted:#71757E;
  --faint:#9CA0A8;
  --line:#E5E2D9;
  --line-2:#EFEDE6;
  --accent:#3D3A8C;       /* deep scientific indigo */
  --accent-soft:#ECEBF6;
  --accent-ink:#2E2B73;
  --amber:#B4621E;        /* rare second accent for "current" */
  --grid:rgba(61,58,140,0.035);
  --shadow:0 1px 2px rgba(26,26,26,.04),0 8px 28px rgba(26,26,26,.06);
  --shadow-lift:0 2px 6px rgba(26,26,26,.06),0 18px 50px rgba(26,26,26,.10);

  --serif:'Newsreader',Georgia,serif;
  --sans:'Inter',-apple-system,sans-serif;
  --mono:'JetBrains Mono',monospace;
}

html[data-theme="dark"]{
  --paper:#0F0F12;
  --paper-2:#16161A;
  --card:#17171C;
  --ink:#ECEAE3;
  --ink-2:#C2C0BA;
  --muted:#8A8D96;
  --faint:#5E626C;
  --line:#272730;
  --line-2:#1F1F26;
  --accent:#A6A1F5;
  --accent-soft:#1E1C33;
  --accent-ink:#C5C1FF;
  --amber:#E0934B;
  --grid:rgba(166,161,245,0.05);
  --shadow:0 1px 2px rgba(0,0,0,.3),0 8px 28px rgba(0,0,0,.4);
  --shadow-lift:0 2px 6px rgba(0,0,0,.4),0 18px 50px rgba(0,0,0,.55);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  transition:background .4s ease,color .4s ease;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(var(--grid) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:34px 34px;
  mask-image:radial-gradient(ellipse 80% 50% at 50% 0%,#000 20%,transparent 75%);
}
.container{max-width:920px;margin:0 auto;padding:0 28px;position:relative;z-index:1}
.container-wide{max-width:1080px;margin:0 auto;padding:0 28px;position:relative;z-index:1}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent-soft);color:var(--accent-ink)}

/* ---------------- NAV ---------------- */
.site-nav{
  position:sticky;top:0;z-index:100;
  background:color-mix(in srgb,var(--paper) 82%,transparent);
  backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--line-2);
}
.nav-inner{max-width:1080px;margin:0 auto;padding:15px 28px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav-name{font-family:var(--serif);font-weight:600;font-size:18px;letter-spacing:-.01em;flex-shrink:0}
.nav-name .pt{color:var(--accent)}
.nav-links{list-style:none;display:flex;gap:26px;align-items:center}
.nav-links a{font-size:14px;color:var(--muted);font-weight:450;transition:color .2s;position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:1.5px;background:var(--accent)}
.theme-toggle{
  width:34px;height:34px;border:1px solid var(--line);border-radius:9px;
  background:var(--card);display:grid;place-items:center;cursor:pointer;
  color:var(--ink-2);transition:all .2s;flex-shrink:0;
}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}
.theme-toggle svg{width:17px;height:17px}
.theme-toggle .moon{display:none}
html[data-theme="dark"] .theme-toggle .sun{display:none}
html[data-theme="dark"] .theme-toggle .moon{display:block}
@media(max-width:680px){
  .nav-links{gap:16px}
  .nav-links li:nth-child(n+3){display:none}
}

/* ---------------- HERO ---------------- */
.hero{padding:88px 0 64px}
.hero-eyebrow{font-family:var(--mono);font-size:12.5px;color:var(--accent);letter-spacing:.05em;margin-bottom:22px;display:flex;align-items:center;gap:11px}
.hero-eyebrow::before{content:"";width:22px;height:1.5px;background:var(--accent)}
.hero h1{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(34px,5.4vw,58px);line-height:1.08;letter-spacing:-.02em;
  margin-bottom:26px;max-width:18ch;
}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero-lede{font-size:clamp(17px,2.1vw,20px);color:var(--ink-2);max-width:60ch;line-height:1.6;margin-bottom:30px}
.hero-lede strong{color:var(--ink);font-weight:600}
.hero-affil{display:flex;flex-wrap:wrap;gap:10px 22px;font-size:14px;color:var(--muted);margin-bottom:36px}
.hero-affil span{display:flex;align-items:center;gap:8px}
.hero-affil b{color:var(--ink-2);font-weight:550}
.hero-affil .key{font-family:var(--mono);font-size:11px;color:var(--accent);border:1px solid var(--line);padding:1px 7px;border-radius:5px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn{font-size:14px;font-weight:500;padding:11px 20px;border-radius:9px;transition:all .2s;display:inline-flex;align-items:center;gap:8px;border:1px solid transparent}
.btn-primary{background:var(--accent);color:#fff}
html[data-theme="dark"] .btn-primary{color:#0F0F12}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px color-mix(in srgb,var(--accent) 35%,transparent)}
.btn-ghost{border-color:var(--line);color:var(--ink-2);background:var(--card)}
.btn-ghost:hover{border-color:var(--ink-2);color:var(--ink)}

/* ---------------- METRIC RAIL (hero) ---------------- */
.metric-rail{
  margin-top:54px;display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line);border-radius:14px;background:var(--card);
  overflow:hidden;box-shadow:var(--shadow);
}
.metric{padding:22px 24px;border-right:1px solid var(--line-2)}
.metric:last-child{border-right:none}
.metric-val{font-family:var(--serif);font-weight:600;font-size:30px;line-height:1;letter-spacing:-.02em;color:var(--ink)}
.metric-val .u{font-family:var(--mono);font-size:14px;color:var(--accent);font-weight:500;margin-left:1px}
.metric-key{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:10px;letter-spacing:.01em}
.metric-sub{font-size:12px;color:var(--faint);margin-top:3px}
@media(max-width:720px){.metric-rail{grid-template-columns:repeat(2,1fr)}.metric:nth-child(2){border-right:none}.metric:nth-child(-n+2){border-bottom:1px solid var(--line-2)}}

/* ---------------- SECTIONS ---------------- */
section{padding:60px 0}
.sec-head{display:flex;align-items:baseline;gap:16px;margin-bottom:34px;border-bottom:1px solid var(--line);padding-bottom:16px}
.sec-num{font-family:var(--mono);font-size:13px;color:var(--accent);font-weight:500}
.sec-name{font-family:var(--serif);font-weight:500;font-size:clamp(24px,3.4vw,32px);letter-spacing:-.01em}
.sec-aside{font-family:var(--mono);font-size:12px;color:var(--faint);margin-left:auto}

/* ---------------- PUBLICATIONS ---------------- */
.pub-list{display:flex;flex-direction:column}
.pub{
  display:grid;grid-template-columns:1fr auto;gap:8px 24px;align-items:start;
  padding:20px 16px;border-radius:11px;transition:background .2s;
  border-bottom:1px solid var(--line-2);
}
.pub:hover{background:var(--card)}
.pub-main{min-width:0}
.pub-title{font-family:var(--serif);font-size:18px;font-weight:500;line-height:1.35;color:var(--ink);margin-bottom:7px}
.pub-venue{font-size:13.5px;color:var(--muted);display:flex;flex-wrap:wrap;gap:6px 12px;align-items:center}
.pub-venue .v{color:var(--accent);font-weight:550;font-family:var(--mono);font-size:12.5px}
.pub-venue .loc{color:var(--faint)}
.pub-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.badge{font-family:var(--mono);font-size:10.5px;padding:3px 10px;border-radius:20px;border:1px solid var(--line);color:var(--muted);white-space:nowrap}
.badge.paper{border-color:color-mix(in srgb,var(--accent) 40%,transparent);color:var(--accent);background:var(--accent-soft)}
.badge.talk{border-color:color-mix(in srgb,var(--amber) 40%,transparent);color:var(--amber)}
.badge.poster{color:var(--muted)}
a.pub{cursor:pointer;position:relative;border-left:2px solid transparent;border-radius:11px;transition:background .2s,border-color .2s}
a.pub::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:2px;height:0;background:var(--accent);border-radius:2px;transition:height .25s}
a.pub:hover::before{height:60%}
a.pub .pub-title{transition:color .2s}
a.pub:hover .pub-title{color:var(--accent)}
.pub-go{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:11px;font-weight:500;color:var(--accent);background:var(--accent-soft);padding:4px 11px;border-radius:20px;white-space:nowrap;transition:gap .2s,background .2s;border:1px solid color-mix(in srgb,var(--accent) 22%,transparent)}
a.pub:hover .pub-go{gap:9px;background:var(--accent);color:#fff}
html[data-theme="dark"] a.pub:hover .pub-go{color:#0F0F12}
@media(max-width:640px){.pub{grid-template-columns:1fr}.pub-right{flex-direction:row;align-items:center}}

/* ---------------- EXPERIENCE ---------------- */
.exp{display:grid;grid-template-columns:180px 1fr;gap:30px;padding:28px 0;border-bottom:1px solid var(--line-2)}
.exp:first-child{padding-top:6px}
.exp-meta .org{font-family:var(--serif);font-size:17px;font-weight:600;display:block;margin-bottom:4px}
.exp-meta .when{font-family:var(--mono);font-size:12px;color:var(--muted)}
.exp-meta .loc{font-size:12.5px;color:var(--faint);display:block;margin-top:2px}
.exp-role{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.exp-role .now{font-family:var(--mono);font-size:10px;font-weight:500;color:var(--amber);border:1px solid color-mix(in srgb,var(--amber) 40%,transparent);padding:2px 8px;border-radius:20px}
.exp-list{list-style:none;display:flex;flex-direction:column;gap:9px}
.exp-list li{font-size:14.5px;color:var(--ink-2);padding-left:18px;position:relative;line-height:1.55}
.exp-list li::before{content:"—";position:absolute;left:0;color:var(--accent);font-weight:600}
.exp-list li b{color:var(--ink);font-weight:600}
.exp-list li .n{font-family:var(--mono);font-size:13px;color:var(--accent-ink);font-weight:500}
@media(max-width:680px){.exp{grid-template-columns:1fr;gap:14px}}

/* ---------------- PROJECTS ---------------- */
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.proj{
  border:1px solid var(--line);border-radius:14px;background:var(--card);
  padding:24px;transition:all .25s;display:flex;flex-direction:column;box-shadow:var(--shadow);
}
.proj:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift);border-color:color-mix(in srgb,var(--accent) 30%,var(--line))}
.proj-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px}
.proj-name{font-family:var(--serif);font-size:18px;font-weight:600;line-height:1.25}
.proj-stack{font-family:var(--mono);font-size:10.5px;color:var(--faint);margin-top:7px;letter-spacing:.02em}
.proj-metric{font-family:var(--serif);font-weight:600;font-size:27px;line-height:1;color:var(--accent);white-space:nowrap}
.proj-metric .u{font-family:var(--mono);font-size:13px;color:var(--muted)}
.proj-desc{font-size:14px;color:var(--ink-2);line-height:1.6;flex:1;margin-bottom:16px}
.proj-desc b{color:var(--ink);font-weight:600}
.proj-foot{display:flex;gap:14px;font-family:var(--mono);font-size:11.5px;color:var(--muted);align-items:center}
.proj-foot a{display:flex;align-items:center;gap:5px;transition:color .2s}
.proj-foot a:hover{color:var(--accent)}
.proj-foot .sep{color:var(--line)}
@media(max-width:680px){.proj-grid{grid-template-columns:1fr}}

/* ---------------- OSS strip ---------------- */
.oss{display:flex;flex-wrap:wrap;gap:10px}
.oss-item{font-size:13px;color:var(--ink-2);border:1px solid var(--line);background:var(--card);border-radius:9px;padding:9px 14px;display:flex;align-items:center;gap:9px}
.oss-item b{color:var(--ink);font-weight:600;font-family:var(--serif)}
.oss-item .pr{font-family:var(--mono);font-size:11px;color:var(--accent)}

/* ---------------- CONTACT ---------------- */
.contact-card{
  border:1px solid var(--line);border-radius:18px;background:var(--card);
  padding:48px 40px;text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.contact-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% -10%,var(--accent-soft),transparent 55%);opacity:.7}
.contact-card h2{font-family:var(--serif);font-size:clamp(26px,4vw,38px);font-weight:500;letter-spacing:-.01em;margin-bottom:14px;position:relative}
.contact-card h2 em{font-style:italic;color:var(--accent)}
.contact-card p{color:var(--muted);max-width:46ch;margin:0 auto 26px;position:relative;font-size:15px}
.contact-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative}

/* ---------------- FOOTER ---------------- */
.site-footer{border-top:1px solid var(--line);margin-top:48px;padding:30px 0}
.footer-inner{max-width:1080px;margin:0 auto;padding:0 28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:13px;color:var(--muted)}
.footer-copy{font-family:var(--mono);font-size:12px}
.footer-links{display:flex;gap:20px}
.footer-links a{transition:color .2s}
.footer-links a:hover{color:var(--accent)}

/* ============================================================
   BLOG INDEX
   ============================================================ */
.blog-hero{padding:72px 0 36px}
.blog-hero h1{font-family:var(--serif);font-size:clamp(32px,5vw,48px);font-weight:500;letter-spacing:-.02em;margin-bottom:14px}
.blog-hero p{font-size:17px;color:var(--ink-2);max-width:56ch}
.post-grid{display:grid;gap:18px;padding-bottom:40px}
.post-card{
  display:grid;grid-template-columns:1fr;gap:0;border:1px solid var(--line);
  border-radius:14px;background:var(--card);overflow:hidden;transition:all .25s;
  box-shadow:var(--shadow);
}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift);border-color:color-mix(in srgb,var(--accent) 30%,var(--line))}
.post-card-body{padding:26px 28px}
.post-card .tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.post-card .tag{font-family:var(--mono);font-size:10.5px;color:var(--accent);background:var(--accent-soft);padding:3px 9px;border-radius:6px;letter-spacing:.02em}
.post-card h2{font-family:var(--serif);font-size:24px;font-weight:600;line-height:1.2;margin-bottom:10px;letter-spacing:-.01em}
.post-card .excerpt{font-size:14.5px;color:var(--ink-2);line-height:1.6;margin-bottom:16px;max-width:62ch}
.post-card .meta{font-family:var(--mono);font-size:11.5px;color:var(--faint);display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.post-card .meta .cta{display:inline-flex;align-items:center;gap:5px;font-weight:500;color:var(--accent);background:var(--accent-soft);padding:4px 12px;border-radius:20px;border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);margin-left:auto;transition:gap .2s,background .2s}
.post-card:hover .meta .cta{gap:9px;background:var(--accent);color:#fff}
html[data-theme="dark"] .post-card:hover .meta .cta{color:#0F0F12}

/* ============================================================
   ARTICLE / POST
   ============================================================ */
.post-header{padding:64px 0 30px;border-bottom:1px solid var(--line)}
.post-back{font-family:var(--mono);font-size:13px;color:var(--muted);display:inline-flex;align-items:center;gap:6px;margin-bottom:26px;transition:color .2s}
.post-back:hover{color:var(--accent)}
.post-title{font-family:var(--serif);font-weight:500;font-size:clamp(30px,5vw,46px);line-height:1.1;letter-spacing:-.02em;margin-bottom:20px;max-width:22ch}
.post-meta{display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center;font-size:13.5px;color:var(--muted)}
.post-meta .post-author{color:var(--ink);font-weight:600}
.post-meta .tag{font-family:var(--mono);font-size:11px;color:var(--accent);background:var(--accent-soft);padding:2px 9px;border-radius:6px}

.post-body{padding:44px 0 60px}
.post-body .container{max-width:720px}
.post-body p{margin:18px 0;font-size:17px;line-height:1.78;color:var(--ink-2)}
.post-body h2{font-family:var(--serif);font-size:28px;font-weight:600;letter-spacing:-.01em;margin:46px 0 8px;color:var(--ink);padding-top:14px}
.post-body h3{font-family:var(--serif);font-size:21px;font-weight:600;margin:32px 0 6px;color:var(--ink)}
.post-body strong{color:var(--ink);font-weight:650}
.post-body ol,.post-body ul{margin:16px 0;padding-left:26px}
.post-body li{margin:8px 0;font-size:16.5px;line-height:1.7;color:var(--ink-2)}
.post-body a{color:var(--accent);border-bottom:1px solid color-mix(in srgb,var(--accent) 35%,transparent);transition:border-color .2s}
.post-body a:hover{border-bottom-color:var(--accent)}
.post-body img{max-width:100%;border:1px solid var(--line);border-radius:12px;margin:26px 0;display:block;background:var(--card)}
.post-body hr{border:none;border-top:1px solid var(--line);margin:46px 0}
.post-body sup{font-size:.7em}
.post-body sub{font-size:.7em}
.post-body pre{
  background:var(--paper-2);border:1px solid var(--line);border-radius:12px;
  padding:18px 20px;overflow-x:auto;margin:22px 0;
  font-family:var(--mono);font-size:13.5px;line-height:1.7;color:var(--ink);
}
.post-body code{font-family:var(--mono);font-size:.86em;background:var(--accent-soft);color:var(--accent-ink);padding:2px 6px;border-radius:5px}
.post-body pre code{background:none;padding:0;color:var(--ink)}
.callout{
  background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);
  border-left:3px solid var(--accent);border-radius:10px;padding:16px 22px;margin:26px 0;
}
.callout p{margin:0;font-size:15.5px;color:var(--accent-ink)}
html[data-theme="dark"] .callout p{color:var(--ink-2)}

/* ============================================================
   RESEARCH PAPER PAGE
   ============================================================ */
.paper-tldr{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border:1px solid var(--line);border-radius:14px;background:var(--card);
  overflow:hidden;box-shadow:var(--shadow);margin:8px 0 4px;
}
.tldr-cell{padding:22px 22px;border-right:1px solid var(--line-2)}
.tldr-cell:last-child{border-right:none}
.tldr-val{font-family:var(--serif);font-weight:600;font-size:30px;line-height:1;letter-spacing:-.02em;color:var(--accent)}
.tldr-val .u{font-family:var(--mono);font-size:14px;color:var(--muted);font-weight:500}
.tldr-key{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:10px;line-height:1.4}
@media(max-width:720px){.paper-tldr{grid-template-columns:repeat(2,1fr)}.tldr-cell:nth-child(2){border-right:none}.tldr-cell:nth-child(-n+2){border-bottom:1px solid var(--line-2)}}

.figure{margin:34px 0}
.figure img{width:100%;border:1px solid var(--line);border-radius:12px;display:block;background:var(--card)}
.figure figcaption{font-size:13.5px;color:var(--muted);margin-top:12px;line-height:1.55;font-family:var(--sans)}
.figure figcaption b{color:var(--ink-2);font-family:var(--mono);font-size:12px;font-weight:500;margin-right:6px}

.finding-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:22px 0}
.finding{border:1px solid var(--line);border-radius:12px;background:var(--card);padding:22px 24px;box-shadow:var(--shadow)}
.finding .n{font-family:var(--serif);font-weight:600;font-size:25px;color:var(--accent);line-height:1;letter-spacing:-.01em}
.finding .n .u{font-family:var(--mono);font-size:13px;color:var(--muted)}
.finding h4{font-size:14px;font-weight:600;color:var(--ink);margin:12px 0 6px}
.finding p{font-size:13.5px;color:var(--ink-2);line-height:1.55;margin:0}
@media(max-width:640px){.finding-grid{grid-template-columns:1fr}}

.paper-table{width:100%;border-collapse:collapse;margin:24px 0;font-size:14px}
.paper-table th,.paper-table td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line-2)}
.paper-table th{font-family:var(--mono);font-size:11.5px;color:var(--muted);font-weight:500;letter-spacing:.02em;text-transform:uppercase;border-bottom:1px solid var(--line)}
.paper-table td{color:var(--ink-2)}
.paper-table td:first-child{color:var(--ink);font-weight:500}
.paper-table .hi{color:var(--accent);font-family:var(--mono);font-weight:500}
.paper-table tr:last-child td{border-bottom:none}

.venue-line{display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center;font-size:14px;color:var(--muted);margin-bottom:8px}
.venue-line .badge{font-family:var(--mono);font-size:11px;color:var(--accent);background:var(--accent-soft);padding:3px 10px;border-radius:6px}

.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{scroll-behavior:auto}}
