/* ============================================================
   Soroush Verdi — academic site
   Direction A · Editorial Index — modern minimal, black & white
   ============================================================ */
:root{
  --bg:#fcfcfb;
  --ink:#16150f;
  --ink-2:#423f37;
  --muted:#6f6c62;
  --faint:#97948a;
  --line:#e4e2dc;
  --line-2:#ece9e3;
  --accent:#16150f;
  --serif:'Newsreader',Georgia,'Times New Roman',serif;
  --sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  --mono:'Space Mono','SFMono-Regular',monospace;
  --maxw:1180px;
  --pad:64px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:350;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:#16150f;color:#fcfcfb}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}

/* ---------- nav ---------- */
.nav{
  display:flex;justify-content:space-between;align-items:baseline;
  max-width:var(--maxw);margin:0 auto;padding:34px var(--pad) 30px;
  border-bottom:1px solid var(--line);
}
.nav .mark{font-family:var(--serif);font-size:25px;font-weight:500;letter-spacing:-0.01em}
.nav .mark a{display:inline-block}
.nav .links{display:flex;gap:38px;font-size:14.5px;letter-spacing:0.01em;color:var(--muted)}
.nav .links a{position:relative;padding-bottom:3px;transition:color .18s ease}
.nav .links a:hover{color:var(--ink)}
.nav .links a.active{color:var(--ink)}
.nav .links a.active::after{
  content:'';position:absolute;left:0;right:0;bottom:-1px;height:1px;background:var(--ink);
}

/* ---------- generic page header ---------- */
.phead{padding:78px var(--pad) 0;max-width:var(--maxw);margin:0 auto}
.eyebrow{font-size:12.5px;letter-spacing:0.18em;text-transform:uppercase;color:var(--faint);margin-bottom:26px}
.phead h1{font-family:var(--serif);font-weight:400;font-size:60px;line-height:1.04;letter-spacing:-0.02em;margin-bottom:24px}
.phead .intro{font-size:18.5px;line-height:1.62;color:var(--ink-2);max-width:640px;font-weight:350}

/* ---------- home hero ---------- */
.hero{
  display:grid;grid-template-columns:1fr 380px;gap:60px;
  padding:76px var(--pad) 60px;max-width:var(--maxw);margin:0 auto;align-items:start;
}
.hero h1{font-family:var(--serif);font-weight:400;font-size:74px;line-height:1.02;letter-spacing:-0.022em;margin-bottom:30px}
.hero h1 em{font-style:italic;color:#595750}
.hero .lede{font-size:18.5px;line-height:1.62;color:var(--ink-2);max-width:560px}
.hero .actions{display:flex;gap:16px;margin-top:38px;flex-wrap:wrap}
.photo-col img{width:100%;height:466px;object-fit:cover;object-position:center 16%;filter:grayscale(1) contrast(1.02);border-radius:2px}
.photo-col .cap{font-size:12.5px;color:var(--faint);margin-top:14px;letter-spacing:0.01em;line-height:1.5}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;font-size:14.5px;letter-spacing:0.01em;
  padding:13px 22px;border:1px solid var(--ink);color:var(--ink);border-radius:999px;
  transition:background .2s ease,color .2s ease;
}
.btn:hover{background:var(--ink);color:var(--bg)}
.btn.ghost{border-color:var(--line);color:var(--muted)}
.btn.ghost:hover{border-color:var(--ink);background:transparent;color:var(--ink)}
.btn .ar{font-size:16px}

/* ---------- research index (home) ---------- */
.index{border-top:1px solid var(--line);max-width:var(--maxw);margin:46px auto 0;padding:0 var(--pad)}
.index .lab{font-family:var(--mono);font-size:12px;letter-spacing:0.08em;text-transform:uppercase;color:var(--faint);padding:36px 0 6px}
.index .row{
  display:grid;grid-template-columns:56px 1fr auto;gap:24px;
  padding:30px 0;border-bottom:1px solid var(--line-2);align-items:baseline;
  transition:padding .25s ease;
}
.index a.row:hover{padding-left:10px}
.index .num{font-family:var(--mono);font-size:13px;color:#b3afa4}
.index .ttl{font-family:var(--serif);font-size:25px;letter-spacing:-0.01em}
.index .sub{font-size:14.5px;color:var(--muted);max-width:540px;margin-top:7px;line-height:1.55}
.index .arr{font-size:18px;color:#b3afa4;transition:transform .25s ease,color .2s ease}
.index a.row:hover .arr{transform:translateX(5px);color:var(--ink)}

/* ---------- featured paper strip ---------- */
.feature{max-width:var(--maxw);margin:0 auto;padding:56px var(--pad) 0}
.feature .card{
  border:1px solid var(--line);border-radius:4px;padding:38px 40px;
  display:grid;grid-template-columns:auto 1fr;gap:34px;align-items:start;
}
.feature .tagcol{font-family:var(--mono);font-size:11.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--faint);white-space:nowrap}
.feature .status{display:inline-flex;align-items:center;gap:8px;margin-top:10px;color:var(--ink-2)}
.feature .dot{width:7px;height:7px;border-radius:50%;background:#16150f;display:inline-block}
.feature h3{font-family:var(--serif);font-size:24px;font-weight:400;line-height:1.32;letter-spacing:-0.01em;margin-bottom:12px}
.feature .auth{font-size:14.5px;color:var(--muted);line-height:1.5}
.feature .auth b{color:var(--ink);font-weight:600}

/* ---------- research detail sections ---------- */
.section{max-width:var(--maxw);margin:0 auto;padding:64px var(--pad) 0}
.section .htop{display:flex;align-items:baseline;gap:16px;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:8px}
.section .htop .k{font-family:var(--mono);font-size:12px;color:#b3afa4}
.section .htop h2{font-family:var(--serif);font-weight:400;font-size:30px;letter-spacing:-0.015em}

.area{display:grid;grid-template-columns:230px 1fr;gap:40px;padding:42px 0;border-bottom:1px solid var(--line-2)}
.area .lead{font-family:var(--serif);font-size:24px;letter-spacing:-0.01em;line-height:1.2}
.area .lead .n{font-family:var(--mono);font-size:12px;color:#b3afa4;display:block;margin-bottom:14px;letter-spacing:0.06em}
.area .body p{font-size:16.5px;line-height:1.62;color:var(--ink-2);max-width:560px;margin-bottom:18px}
.area .tags{display:flex;flex-wrap:wrap;gap:9px}
.area .tags span{font-size:13px;color:var(--muted);border:1px solid var(--line);padding:7px 14px;border-radius:999px}

/* ---------- publications list ---------- */
.pub{display:grid;grid-template-columns:120px 1fr;gap:34px;padding:34px 0;border-bottom:1px solid var(--line-2)}
.pub .yr{font-family:var(--mono);font-size:13px;color:var(--faint)}
.pub .yr .badge{display:block;margin-top:10px;font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--ink-2)}
.pub h3{font-family:var(--serif);font-size:23px;font-weight:400;line-height:1.34;letter-spacing:-0.01em;margin-bottom:12px}
.pub .auth{font-size:15px;color:var(--muted);line-height:1.55;margin-bottom:14px}
.pub .auth b{color:var(--ink);font-weight:600}
.pub .venue{font-size:14px;color:var(--ink-2)}

/* ---------- prose (about / teaching) ---------- */
.prose{max-width:680px}
.prose p{font-size:17.5px;line-height:1.68;color:var(--ink-2);margin-bottom:22px}
.prose p:first-child{font-size:20px;color:var(--ink);line-height:1.6}

/* ---------- empty / placeholder note ---------- */
.placeholder{
  border:1px dashed var(--line);border-radius:4px;padding:40px;margin-top:8px;
  color:var(--muted);font-size:15px;line-height:1.6;max-width:680px;
}
.placeholder b{color:var(--ink-2);font-weight:600}

/* ---------- CV ---------- */
.cv-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.cv-frame{
  max-width:var(--maxw);margin:48px auto 0;padding:0 var(--pad);
}
.cv-frame .frame{
  border:1px solid var(--line);border-radius:4px;background:#fff;height:840px;overflow:hidden;
}
.cv-frame iframe{width:100%;height:100%;border:0}

/* ---------- footer ---------- */
.foot{
  margin-top:96px;border-top:1px solid var(--line);
}
.foot .inner{
  max-width:var(--maxw);margin:0 auto;padding:54px var(--pad) 60px;
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;align-items:start;
}
.foot .name{font-family:var(--serif);font-size:21px;font-weight:500;margin-bottom:10px}
.foot .blurb{font-size:14px;color:var(--muted);line-height:1.6;max-width:330px}
.foot .col h4{font-family:var(--mono);font-size:11.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--faint);margin-bottom:16px;font-weight:400}
.foot .col a,.foot .col p{display:block;font-size:14.5px;color:var(--ink-2);margin-bottom:11px;transition:color .18s ease}
.foot .col a:hover{color:var(--ink)}
.foot .copy{
  max-width:var(--maxw);margin:0 auto;padding:22px var(--pad);border-top:1px solid var(--line-2);
  display:flex;justify-content:space-between;font-size:12.5px;color:var(--faint);
}

/* ---------- responsive ---------- */
@media(max-width:900px){
  :root{--pad:24px}
  .nav{flex-direction:row;flex-wrap:wrap;gap:14px;padding-top:24px;padding-bottom:20px}
  .nav .mark{font-size:22px}
  .nav .links{gap:22px;font-size:14px;width:100%}
  .hero{grid-template-columns:1fr;gap:36px;padding-top:48px}
  .hero h1{font-size:52px}
  .photo-col img{height:420px;object-position:center 12%}
  .phead h1{font-size:42px}
  .feature .card{grid-template-columns:1fr;gap:18px}
  .area{grid-template-columns:1fr;gap:14px;padding:32px 0}
  .pub{grid-template-columns:1fr;gap:10px}
  .foot .inner{grid-template-columns:1fr;gap:30px}
  .cv-frame .frame{height:600px}
}
@media(max-width:560px){
  .hero h1{font-size:42px}
  .phead h1{font-size:34px}
  .nav .links{gap:16px;font-size:13px}
}
