/* Varun Kotte — portfolio shared styles */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#ffffff; --bg-subtle:#f5f7f8; --card:#ffffff; --border:#e4e8ea;
  --text:#0f1417; --muted:#4f5860; --faint:#6f7880;
  --accent:#0f766e; --accent-hover:#115e56; --wash:#e4f3f0; --good:#0f766e;
  --radius:8px;
  --mono:ui-monospace,"SF Mono","JetBrains Mono",Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --maxw:740px; --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px;--s7:48px;--s8:72px;
}
@media (prefers-color-scheme:dark){:root:not([data-theme="light"]){
  --bg:#0c1116; --bg-subtle:#141b21; --card:#141b21; --border:#232c34;
  --text:#e9edf1; --muted:#a2acb5; --faint:#7a848d;
  --accent:#2dd4bf; --accent-hover:#5eead4; --wash:#0f2b28; --good:#2dd4bf;
}}
:root[data-theme="dark"]{
  --bg:#0c1116; --bg-subtle:#141b21; --card:#141b21; --border:#232c34;
  --text:#e9edf1; --muted:#a2acb5; --faint:#7a848d;
  --accent:#2dd4bf; --accent-hover:#5eead4; --wash:#0f2b28; --good:#2dd4bf;
}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important;animation:none!important}}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--s5)}
a{color:var(--accent);text-decoration:none;transition:color .12s ease}
a:hover{color:var(--accent-hover);text-decoration:underline;text-underline-offset:2px}
a:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:3px}
.skip{position:absolute;left:-9999px;top:0;background:#0f766e;color:#fff;padding:8px 14px;z-index:10;border-radius:var(--radius)}
.skip:focus{left:8px;top:8px}
/* nav */
header.top{position:sticky;top:0;background:var(--bg);background:color-mix(in srgb,var(--bg) 90%,transparent);
  -webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px);
  border-bottom:1px solid var(--border);z-index:5}
.topbar{display:flex;align-items:center;justify-content:space-between;height:54px;gap:var(--s4)}
.brand{font-family:var(--mono);font-size:14px;font-weight:600;color:var(--text)}
.brand:hover{text-decoration:none;color:var(--accent)}
.mainnav{display:flex;align-items:center;gap:var(--s5);font-size:14px}
.mainnav a{color:var(--muted)}
.mainnav a:hover{color:var(--text);text-decoration:none}
.mainnav a[aria-current="page"]{color:var(--text);font-weight:600}
.toggle{font-family:var(--mono);font-size:13px;color:var(--muted);background:none;border:1px solid var(--border);
  border-radius:var(--radius);padding:4px 8px;cursor:pointer;line-height:1}
.toggle:hover{border-color:var(--faint);color:var(--text)}
main{padding-bottom:var(--s8)}
section{padding-block:var(--s7) 0}
h1{font-size:32px;font-weight:700;line-height:1.1;letter-spacing:-.02em}
h2.kicker{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);margin-bottom:var(--s5);display:flex;align-items:center;gap:10px}
h2.kicker::before{content:"";width:18px;height:2px;background:var(--accent)}
h3{font-size:18px;font-weight:700;line-height:1.3;letter-spacing:-.01em}
/* hero (claim-first) */
#hero{padding-block:var(--s8) var(--s6)}
.eyebrow{font-family:var(--mono);font-size:13px;letter-spacing:.05em;color:var(--muted);text-transform:uppercase;margin-bottom:var(--s4)}
h1.claim{font-size:clamp(32px,6vw,52px);line-height:1.06;letter-spacing:-.03em;max-width:18ch;font-weight:750}
h1.claim em{font-style:normal;color:var(--accent)}
.role{font-size:18px;color:var(--muted);line-height:1.5;max-width:52ch;margin-top:var(--s4)}
.links{display:flex;flex-wrap:wrap;gap:var(--s4);margin-top:var(--s5);font-family:var(--mono);font-size:14px}
/* stat row */
.stats{display:flex;flex-wrap:wrap;gap:var(--s6);margin-top:var(--s6);padding-top:var(--s5);border-top:1px solid var(--border)}
.stat{font-family:var(--mono);font-size:13px;color:var(--muted);font-variant-numeric:tabular-nums;line-height:1.4}
.stat b{display:block;font-size:26px;font-weight:700;color:var(--accent);letter-spacing:-.02em}
.muted{color:var(--muted)} .faint{color:var(--faint)} .mono{font-family:var(--mono)}
.bio{color:var(--muted);max-width:64ch}
.pagehead{padding-block:var(--s8) var(--s2)}
.pagehead h1{font-size:30px}
/* highlights */
.news{list-style:none;margin-top:var(--s2)}
.news li{padding:var(--s3) 0;border-bottom:1px solid var(--border);font-size:15.5px}
.news li:last-child{border-bottom:none}
.news b{font-weight:600;color:var(--text)}
/* teaser cards */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4);margin-top:var(--s2)}
.card2{border:1px solid var(--border);border-radius:var(--radius);padding:var(--s5);background:var(--card);
  transition:transform .15s ease,border-color .15s ease}
.card2:hover{transform:translateY(-2px);border-color:var(--accent)}
.card2.feature{grid-column:1 / -1;background:var(--bg-subtle)}
.card2 h3{margin-bottom:6px}
.card2 p{font-size:14.5px;color:var(--muted)}
.card2 a.more{font-family:var(--mono);font-size:12.5px;display:inline-block;margin-top:10px}
.seeall{font-family:var(--mono);font-size:13px;margin-top:var(--s4);display:inline-block}
/* list items */
.item{padding:var(--s4) 0;border-bottom:1px solid var(--border)}
.item:last-child{border-bottom:none}
.item .meta{color:var(--muted);font-size:15px;margin-top:4px}
.item .meta b{color:var(--text);font-weight:600}
.row{display:flex;justify-content:space-between;align-items:baseline;gap:var(--s4);flex-wrap:wrap}
.out{font-family:var(--mono);font-size:13px;color:var(--muted);font-variant-numeric:tabular-nums;margin-top:8px}
.out b{color:var(--accent);font-weight:700}
.tag{font-family:var(--mono);font-size:11px;padding:2px 8px;border-radius:5px;white-space:nowrap}
.tag.v{color:#fff;background:var(--accent)}
:root[data-theme="dark"] .tag.v{color:#0c1116}
@media (prefers-color-scheme:dark){:root:not([data-theme="light"]) .tag.v{color:#0c1116}}
.tag.w{color:var(--accent);background:var(--wash)}
.tag.p{color:var(--faint);border:1px solid var(--border)}
/* research details */
details.paper{border-bottom:1px solid var(--border);padding:var(--s4) 0}
details.paper:last-of-type{border-bottom:none}
details.paper summary{list-style:none;cursor:pointer}
details.paper summary::-webkit-details-marker{display:none}
.caret{font-family:var(--mono);font-size:12px;color:var(--faint);display:inline-block;transition:transform .15s ease}
details.paper[open] .caret{transform:rotate(180deg)}
details.paper[open] summary h3{color:var(--accent)}
details.paper .body{margin-top:var(--s3);color:var(--muted);font-size:15px}
details.paper .body p{margin-bottom:var(--s3);max-width:64ch}
.plinks{font-family:var(--mono);font-size:13px;display:flex;gap:14px;flex-wrap:wrap;margin-top:var(--s2)}
.disc{font-family:var(--mono);font-size:12px;color:var(--faint);margin-top:2px}
/* case study */
.case{border:1px solid var(--border);border-radius:var(--radius);background:var(--card);padding:var(--s5);margin-top:var(--s4)}
.case:first-of-type{margin-top:var(--s2)}
.case h3{margin-bottom:var(--s3)}
.case dl{display:grid;grid-template-columns:auto 1fr;gap:8px var(--s4);font-size:15px}
.case dt{font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);padding-top:3px}
.case dd{color:var(--text)}
.case dd b{color:var(--accent);font-weight:700}
.grp{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin:var(--s6) 0 var(--s2)}
.grp:first-of-type{margin-top:var(--s2)}
.sub{font-family:var(--mono);font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);margin-bottom:var(--s3)}
ul.tight{list-style:none} ul.tight li{padding:6px 0;border-bottom:1px solid var(--border);font-size:15px}
ul.tight li:last-child{border-bottom:none}
.about p{max-width:64ch} .about p+p{margin-top:var(--s3)}
footer{border-top:1px solid var(--border);margin-top:var(--s8);padding-block:var(--s5) var(--s7);font-size:13px;color:var(--muted)}
footer .faint{font-family:var(--mono);font-size:12px;margin-top:6px}
@media (max-width:620px){
  h1.claim{font-size:30px}.role{font-size:17px}.cards{grid-template-columns:1fr}
  .card2.feature{grid-column:auto}.case dl{grid-template-columns:1fr}.case dt{padding-top:0}
  .mainnav{gap:var(--s4)}.stats{gap:var(--s5)}
}
@media print{header.top,.toggle{display:none}a{color:#000;text-decoration:underline}body{font-size:11pt}}
