/*
Theme Name: Farahani Academic Editable
Theme URI: https://hfarahani.com
Author: Hossein Farahani
Author URI: https://hfarahani.com
Description: A clean, al-folio-inspired multi-page academic theme for researchers. Builds editable WordPress pages automatically on activation; homepage, research, publications, teaching, and CV content are stored as normal page content rather than rendered from PHP shortcodes.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: farahani-academic
*/

/* =========================================================================
   DESIGN TOKENS
   To recolor the whole site, change --accent (and --accent-dark / --accent-tint).
   Sober alternatives if pine-teal isn't your taste:
     navy      #243B6B  /  dark #182a4d  /  tint rgba(36,59,107,.08)
     oxblood   #7B2230  /  dark #5E1A25  /  tint rgba(123,34,48,.08)
     ink-slate #2C3A47  /  dark #1d2731  /  tint rgba(44,58,71,.08)
   ========================================================================= */
:root{
  --paper:      #FCFCFB;
  --paper-2:    #F4F5F3;
  --ink:        #17181C;
  --ink-soft:   #3A3D44;
  --muted:      #6E727A;
  --rule:       #E4E6E2;
  --accent:     #15564A;
  --accent-dark:#0F3F36;
  --accent-tint:rgba(21,86,74,.09);

  --ui:    "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;
  --serif: "Spectral", Georgia, "Times New Roman", serif;

  --maxw: 820px;
  --pad:  clamp(1.25rem, 5vw, 2.5rem);
}

/* =========================================================================
   RESET / BASE
   ========================================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serif);
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--accent); text-decoration:none; }
a:hover{ color:var(--accent-dark); }
::selection{ background:var(--accent-tint); }

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

/* Accessibility: skip link + focus ring */
.skip-link{ position:absolute; left:-9999px; top:0; background:var(--ink); color:var(--paper);
  padding:.6rem 1rem; border-radius:0 0 6px 0; font-family:var(--ui); z-index:200; }
.skip-link:focus{ left:0; }
a:focus-visible, button:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; border-radius:3px; }

/* =========================================================================
   SITE HEADER / NAV
   ========================================================================= */
.site-header{
  position:sticky; top:0; z-index:100;
  background:color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter:saturate(140%) blur(8px);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--rule);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  height:64px;
}
.brand{
  font-family:var(--ui); font-weight:700; font-size:1.05rem; letter-spacing:-.01em;
  color:var(--ink); white-space:nowrap;
}
.brand:hover{ color:var(--ink); }
.nav-links{
  display:flex; align-items:center; gap:1.55rem; list-style:none; margin:0; padding:0;
}
.nav-links a{
  font-family:var(--ui); font-weight:600; font-size:.97rem; color:var(--ink);
  letter-spacing:.005em; padding:.35rem 0; position:relative;
}
.nav-links a::after{
  content:""; position:absolute; left:0; right:0; bottom:.05rem; height:2px;
  background:var(--accent); transform:scaleX(0); transform-origin:left;
  transition:transform .22s ease;
}
.nav-links a:hover, .nav-links a.active{ color:var(--accent); }
.nav-links a:hover::after, .nav-links a.active::after{ transform:scaleX(1); }
.nav-links a.cv-link{ color:var(--accent); }

.nav-toggle{
  display:none; background:none; border:0; cursor:pointer; padding:.4rem;
  color:var(--ink);
}
.nav-toggle svg{ width:24px; height:24px; display:block; }

/* =========================================================================
   SECTIONS
   ========================================================================= */
.section{ padding-top:3.4rem; padding-bottom:3.4rem; border-bottom:1px solid var(--rule); }
.section:last-of-type{ border-bottom:0; }
.eyebrow{
  font-family:var(--ui); font-weight:600; font-size:.72rem; letter-spacing:.13em;
  text-transform:uppercase; color:var(--accent); margin:0 0 .55rem;
}
.section-title{
  font-family:var(--ui); font-weight:700; font-size:1.55rem; letter-spacing:-.015em;
  color:var(--ink); margin:0 0 1.6rem; line-height:1.15;
}
.lead{ color:var(--ink-soft); }

/* =========================================================================
   HERO / ABOUT
   ========================================================================= */
.hero{ padding-top:3.6rem; padding-bottom:3.2rem; border-bottom:1px solid var(--rule); }
.hero-grid{
  display:grid; grid-template-columns:1fr 220px; gap:2.6rem; align-items:start;
}
.hero-eyebrow{
  font-family:var(--ui); font-weight:600; font-size:.74rem; letter-spacing:.13em;
  text-transform:uppercase; color:var(--accent); margin:0 0 .5rem;
}
.hero-name{
  font-family:var(--ui); font-weight:700; letter-spacing:-.025em; line-height:1.02;
  font-size:clamp(2.4rem, 6vw, 3.25rem); color:var(--ink); margin:0;
}
.hero-rule{ width:88px; height:4px; background:var(--accent); margin:1rem 0 1rem; border-radius:2px; }
.hero-role{
  font-family:var(--ui); font-weight:500; font-size:1.05rem; color:var(--ink-soft); margin:0 0 1.1rem;
}
.hero-bio{ font-size:1.06rem; color:var(--ink-soft); margin:0 0 1.3rem; max-width:46ch; }
.hero-bio strong{ color:var(--ink); font-weight:600; }

.tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin:0 0 1.5rem; padding:0; list-style:none; }
.tag{
  font-family:var(--ui); font-size:.78rem; font-weight:500; color:var(--ink-soft);
  background:var(--paper-2); border:1px solid var(--rule);
  padding:.28rem .65rem; border-radius:999px; line-height:1;
}

.hero-actions{ display:flex; flex-wrap:wrap; gap:.7rem; align-items:center; }
.btn{
  font-family:var(--ui); font-weight:600; font-size:.9rem; line-height:1;
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.62rem 1.05rem; border-radius:7px; border:1px solid transparent; cursor:pointer;
}
.btn svg{ width:16px; height:16px; }
.btn-primary{ background:var(--accent); color:#fff; }
.btn-primary:hover{ background:var(--accent-dark); color:#fff; }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--rule); }
.btn-ghost:hover{ border-color:var(--accent); color:var(--accent); }

/* social icon row */
.social{ display:flex; gap:.85rem; margin-top:1.1rem; }
.social a{ color:var(--muted); display:inline-flex; }
.social a:hover{ color:var(--accent); }
.social svg{ width:20px; height:20px; }

/* portrait */
.portrait{ width:220px; }
.portrait img{
  width:220px; height:220px; object-fit:cover; border-radius:12px;
  box-shadow:0 1px 0 var(--rule), 0 16px 32px -22px rgba(20,30,28,.45);
}
.portrait-cap{
  font-family:var(--ui); font-size:.76rem; color:var(--muted); text-align:center;
  margin-top:.7rem; line-height:1.45;
}

/* =========================================================================
   NEWS
   ========================================================================= */
.news{ list-style:none; margin:0; padding:0; }
.news li{
  display:grid; grid-template-columns:84px 1fr; gap:1rem; padding:.6rem 0;
  border-bottom:1px dashed var(--rule);
}
.news li:last-child{ border-bottom:0; }
.news .date{ font-family:var(--ui); font-weight:600; font-size:.82rem; color:var(--accent); padding-top:.12rem; }
.news .item{ font-size:1rem; color:var(--ink-soft); }
.news .item strong{ color:var(--ink); font-weight:600; }

/* =========================================================================
   PUBLICATIONS — the year rail
   ========================================================================= */
.pub-list{ position:relative; }
.pub-list::before{
  content:""; position:absolute; left:64px; top:.4rem; bottom:.4rem; width:2px;
  background:var(--rule);
}
.year-group{
  display:grid; grid-template-columns:86px 1fr; gap:0; margin-bottom:2.1rem;
}
.year-group:last-child{ margin-bottom:0; }
.year-label{
  position:relative; font-family:var(--ui); font-weight:600; font-size:.98rem;
  color:var(--accent); padding-top:.1rem;
}
.year-label::before{
  content:""; position:absolute; left:58px; top:.42rem; width:10px; height:10px;
  border-radius:50%; background:var(--accent); border:2px solid var(--paper); box-sizing:content-box;
}
.year-entries{ display:flex; flex-direction:column; gap:1.35rem; }

.pub{ padding-left:1.05rem; border-left:2px solid transparent; }
.pub.featured{ border-left:2px solid var(--accent); }
.pub-title{ font-family:var(--serif); font-weight:600; font-size:1.04rem; line-height:1.42; color:var(--ink); margin:0; }
.pub-authors{ font-family:var(--ui); font-weight:400; font-size:.88rem; line-height:1.55; color:var(--muted); margin:.32rem 0 0; }
.pub-authors .me{ color:var(--ink); font-weight:600; }
.pub-venue{ font-family:var(--ui); font-size:.86rem; line-height:1.5; color:var(--ink-soft); margin:.22rem 0 0; font-style:italic; }
.badge{
  display:inline-block; font-family:var(--ui); font-weight:600; font-size:.66rem; letter-spacing:.04em;
  text-transform:uppercase; color:var(--accent); background:var(--accent-tint);
  border-radius:4px; padding:.18rem .42rem; margin-left:.4rem; vertical-align:.08em; font-style:normal;
}
.pub-legend{ font-family:var(--ui); font-size:.78rem; color:var(--muted); margin-top:1.8rem; }

/* =========================================================================
   TEACHING / GENERIC CONTENT CARDS
   ========================================================================= */
.cards{ display:flex; flex-direction:column; gap:1.4rem; }
.card{ }
.card-head{ display:flex; align-items:baseline; gap:.6rem; flex-wrap:wrap; }
.card-title{ font-family:var(--ui); font-weight:600; font-size:1.06rem; color:var(--ink); margin:0; }
.card-code{ font-family:var(--ui); font-weight:500; font-size:.8rem; color:var(--accent); background:var(--accent-tint); padding:.16rem .45rem; border-radius:4px; }
.card-meta{ font-family:var(--ui); font-size:.84rem; color:var(--muted); margin:.2rem 0 .5rem; }
.card-body{ font-size:1rem; color:var(--ink-soft); margin:0; }

.callout{
  background:var(--paper-2); border:1px solid var(--rule); border-radius:10px;
  padding:1.1rem 1.25rem; margin-top:1.5rem;
}
.callout p{ margin:0; font-size:.98rem; color:var(--ink-soft); }
.callout strong{ color:var(--ink); }

/* simple definition rows (grants, awards, service) */
.rows{ list-style:none; margin:0; padding:0; }
.rows > li{ padding:1rem 0; border-bottom:1px solid var(--rule); }
.rows > li:last-child{ border-bottom:0; }
.row-title{ font-family:var(--ui); font-weight:600; font-size:1.02rem; color:var(--ink); margin:0; }
.row-sub{ font-family:var(--ui); font-size:.85rem; color:var(--accent); margin:.15rem 0 .35rem; }
.row-body{ font-size:.98rem; color:var(--ink-soft); margin:0; }
.row-tag{ font-family:var(--ui); font-size:.78rem; font-weight:600; color:var(--muted); float:right; }

.two-col{ display:grid; grid-template-columns:1fr 1fr; gap:.4rem 2.5rem; }
.mini{ list-style:none; margin:0; padding:0; }
.mini li{ padding:.5rem 0; border-bottom:1px dashed var(--rule); font-size:.97rem; color:var(--ink-soft); font-family:var(--serif); }
.mini li:last-child{ border-bottom:0; }
.mini b{ font-family:var(--ui); font-weight:600; color:var(--ink); }

/* =========================================================================
   CONTACT / FOOTER
   ========================================================================= */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.6rem; }
.contact-block h3{ font-family:var(--ui); font-weight:600; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin:0 0 .5rem; }
.contact-block p, .contact-block a{ font-size:1rem; color:var(--ink-soft); margin:.15rem 0; }
.contact-block a:hover{ color:var(--accent); }

.site-footer{ padding:2.2rem 0 2.8rem; }
.foot-inner{ display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap;
  font-family:var(--ui); font-size:.83rem; color:var(--muted); }
.foot-inner a{ color:var(--muted); }
.foot-inner a:hover{ color:var(--accent); }
.to-top{ font-family:var(--ui); font-size:.83rem; }

/* =========================================================================
   GENERIC PAGE / POST (page.php, single.php, index.php)
   ========================================================================= */
.entry{ padding-top:3rem; padding-bottom:3rem; }
.entry-title{ font-family:var(--ui); font-weight:700; font-size:2rem; letter-spacing:-.02em; color:var(--ink); margin:0 0 .4rem; line-height:1.1; }
.entry-date{ font-family:var(--ui); font-size:.85rem; color:var(--muted); margin:0 0 1.6rem; }
.entry-content{ font-size:1.08rem; color:var(--ink-soft); }
.entry-content h2{ font-family:var(--ui); font-weight:600; color:var(--ink); margin-top:2rem; }
.entry-content h3{ font-family:var(--ui); font-weight:600; color:var(--ink); }
.entry-content a{ text-decoration:underline; text-underline-offset:2px; }
.entry-content blockquote{ border-left:3px solid var(--accent); margin:1.5rem 0; padding:.2rem 0 .2rem 1.2rem; color:var(--ink); font-style:italic; }
.entry-content img{ border-radius:8px; margin:1.5rem 0; }
.entry-content code{ font-family:ui-monospace,SFMono-Regular,Menlo,monospace; background:var(--paper-2); padding:.12rem .35rem; border-radius:4px; font-size:.9em; }
.post-list{ list-style:none; margin:0; padding:0; }
.post-list li{ padding:1.3rem 0; border-bottom:1px solid var(--rule); }
.post-list h2{ font-family:var(--ui); font-size:1.25rem; margin:0 0 .2rem; }
.post-list .entry-date{ margin:0; }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 760px){
  body{ font-size:17px; }
  .hero-grid{ grid-template-columns:1fr; gap:1.8rem; }
  .portrait{ order:-1; width:150px; }
  .portrait img{ width:150px; height:150px; }
  .portrait-cap{ display:none; }

  .nav-links{
    position:absolute; top:64px; left:0; right:0;
    flex-direction:column; align-items:flex-start; gap:0;
    background:var(--paper); border-bottom:1px solid var(--rule);
    padding:.4rem var(--pad) 1rem; display:none;
  }
  .nav-links.open{ display:flex; }
  .nav-links li{ width:100%; }
  .nav-links a{ display:block; width:100%; padding:.7rem 0; font-size:1rem; border-bottom:1px solid var(--rule); }
  .nav-links a::after{ display:none; }
  .nav-toggle{ display:inline-flex; }

  .pub-list::before{ display:none; }
  .year-group{ grid-template-columns:1fr; }
  .year-label{ margin-bottom:.7rem; font-size:1.1rem; }
  .year-label::before{ display:none; }

  .news li{ grid-template-columns:1fr; gap:.15rem; }
  .news .date{ font-size:.8rem; }

  .two-col, .contact-grid{ grid-template-columns:1fr; gap:1.2rem; }
}

/* ── Fallback-template helpers (blog index, archives, single, pages) ─────── */
.page-head{ padding-top:3rem; margin-bottom:1.4rem; }
.page-head .entry-title{ margin-bottom:.4rem; }

.post-nav{
  display:flex; justify-content:space-between; gap:1.5rem;
  margin-top:3rem; padding-top:1.4rem; border-top:1px solid var(--rule);
  font-family:var(--ui); font-size:.95rem;
}
.post-nav a{ color:var(--accent); }
.post-nav a:hover{ color:var(--accent-dark); }

.navigation.pagination{ margin-top:2.6rem; padding-top:1.6rem; border-top:1px solid var(--rule); }
.navigation.pagination .nav-links{
  display:flex; flex-wrap:wrap; gap:.5rem; align-items:center;
  position:static; background:none; box-shadow:none; padding:0;
}
.navigation.pagination .page-numbers{
  font-family:var(--ui); font-size:.95rem; line-height:1;
  padding:.5rem .75rem; border:1px solid var(--rule); border-radius:6px;
  color:var(--ink-soft); text-decoration:none;
}
.navigation.pagination .page-numbers:hover{ border-color:var(--accent); color:var(--accent); }
.navigation.pagination .page-numbers.current{
  background:var(--accent); border-color:var(--accent); color:#fff;
}
.navigation.pagination .page-numbers.dots{ border:none; padding:.5rem .25rem; }
.navigation.pagination .page-numbers::after{ display:none; }

/* ── Current-page highlight for the WordPress nav menu ──────────────────── */
.nav-links .current-menu-item > a,
.nav-links .current_page_item > a,
.nav-links .current-menu-parent > a{ color:var(--ink); }
.nav-links .current-menu-item > a::after,
.nav-links .current_page_item > a::after,
.nav-links .current-menu-parent > a::after{ transform:scaleX(1); }
/* CV menu item picks up the accent (class added to the menu item) */
.nav-links .cv-menu-item > a{ color:var(--accent); font-weight:600; }

/* ── Teaching: course curriculum maps ──────────────────────────────────── */
.course{ margin-bottom:2.8rem; }
.course:last-of-type{ margin-bottom:0; }
.course-top{ display:flex; align-items:baseline; justify-content:space-between; gap:.4rem 1.2rem; flex-wrap:wrap; }
.course-meta{ font-family:var(--ui); font-size:.84rem; color:var(--muted); margin:.3rem 0 0; }
.course-desc{ font-size:1rem; color:var(--ink-soft); margin:.6rem 0 0; max-width:62ch; }
.syllabus-link{ font-family:var(--ui); font-weight:600; font-size:.85rem; color:var(--accent); white-space:nowrap; display:inline-flex; align-items:center; gap:.35rem; }
.syllabus-link:hover{ color:var(--accent-dark); }
.syllabus-link svg{ width:14px; height:14px; }

.modules{ position:relative; margin-top:1.2rem; }
.modules::before{ content:""; position:absolute; left:12px; top:.7rem; bottom:.7rem; width:2px; background:var(--rule); }
.module{ position:relative; display:grid; grid-template-columns:42px 1fr; gap:0; padding:.5rem 0; }
.module-num{
  position:relative; z-index:1; width:26px; height:26px; box-sizing:border-box;
  border-radius:50%; background:var(--accent); color:#fff; border:2px solid var(--paper);
  font-family:var(--ui); font-weight:600; font-size:.8rem; line-height:1;
  display:flex; align-items:center; justify-content:center;
}
.module-num.cap{ background:var(--paper); color:var(--accent); border:2px solid var(--accent); }
.module-name{ font-family:var(--ui); font-weight:600; font-size:1.03rem; color:var(--ink); margin:.1rem 0 0; }
.module-name .kicker{ color:var(--accent); }
.module-topics{ display:flex; flex-wrap:wrap; gap:.4rem; margin-top:.55rem; }
.course-note{ font-family:var(--ui); font-size:.86rem; color:var(--muted); margin:.9rem 0 0; padding-left:42px; }
.course-note b{ color:var(--ink-soft); font-weight:600; }

/* ── Research: illustrated program blocks ──────────────────────────────── */
.programs{ display:flex; flex-direction:column; gap:1.9rem; }
.program{ display:grid; grid-template-columns:56px 1fr; gap:1.2rem; align-items:start; }
.program-icon{ color:var(--accent); display:flex; align-items:flex-start; justify-content:center; padding-top:.15rem; }
.program-icon svg{ width:46px; height:46px; }
.program-title{ font-family:var(--ui); font-weight:600; font-size:1.06rem; color:var(--ink); margin:0 0 .5rem; }
.program-body{ color:var(--ink-soft); font-size:1rem; line-height:1.62; margin:0; }

/* Flagship callout with globe glyph */
.flagship{ display:grid; grid-template-columns:46px 1fr; gap:1.1rem; align-items:start; }
.flagship-icon{ color:var(--accent); padding-top:.15rem; }
.flagship-icon svg{ width:40px; height:40px; }

/* Course header: glyph + title on the left, syllabus link on the right */
.course-id{ display:flex; align-items:center; gap:.75rem; min-width:0; }
.course-icon{ color:var(--accent); flex:none; line-height:0; }
.course-icon svg{ width:38px; height:38px; }
.syllabus-link svg{ width:15px; height:15px; }

@media (max-width:560px){
  .program{ grid-template-columns:1fr; gap:.55rem; }
  .program-icon{ justify-content:flex-start; }
  .flagship{ grid-template-columns:1fr; gap:.55rem; }
}

/* ── Block-editor content: keep shortcode components clean ──────────────────
   Shortcodes render inside .entry-content, so the prose-link underline and the
   image margin must not bleed onto component buttons, icons, or the portrait. */
.entry-content .btn,
.entry-content .social a,
.entry-content .syllabus-link{ text-decoration:none; }
.entry-content .hero img{ margin:0; border-radius:12px; }
.inline-glyph{ display:inline-flex; vertical-align:middle; color:var(--accent); }
.inline-glyph svg{ width:34px; height:34px; }

/* Emergency robustness patch: keep Teaching module maps horizontal even after
   Gutenberg/WordPress normalization or class-name conflicts. */
body .modules{
  display:block !important;
  width:100% !important;
  max-width:920px !important;
}
body .modules::before{
  left:12px !important;
}
body .modules .module{
  position:relative !important;
  display:grid !important;
  grid-template-columns:42px minmax(0, 1fr) !important;
  width:100% !important;
  max-width:920px !important;
  align-items:start !important;
  gap:0 !important;
  padding:.55rem 0 !important;
  box-sizing:border-box !important;
}
body .modules .module > .module-num{
  grid-column:1 !important;
  grid-row:1 !important;
}
body .modules .module > div{
  grid-column:2 !important;
  grid-row:1 !important;
  width:100% !important;
  min-width:0 !important;
  max-width:none !important;
  display:block !important;
}
body .modules .module-name{
  display:block !important;
  width:auto !important;
  max-width:none !important;
  min-width:0 !important;
  white-space:normal !important;
  overflow-wrap:normal !important;
  word-break:normal !important;
}
body .modules .module-topics{
  display:flex !important;
  flex-wrap:wrap !important;
  width:100% !important;
  max-width:none !important;
  gap:.4rem !important;
}
body .modules .module-topics .tag{
  display:inline-flex !important;
  width:auto !important;
  min-width:0 !important;
  max-width:none !important;
  white-space:normal !important;
  line-height:1.15 !important;
}

/* =========================================================================
   PERSISTENT PROFILE SIDEBAR
   A restrained desktop identity column. Hidden on smaller screens so pages stay
   clean and readable on mobile/tablet.
   ========================================================================= */
.site-header .wrap{
  max-width:1180px;
}
.site-layout{
  width:100%;
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:230px minmax(0, 1fr);
  column-gap:clamp(2rem, 5vw, 4.25rem);
  padding-left:var(--pad);
  padding-right:var(--pad);
}
.site-layout .site-main{
  min-width:0;
}
.site-layout .site-main > .section > .wrap,
.site-layout .site-main > .hero > .wrap{
  padding-left:0;
  padding-right:0;
  margin-left:0;
  margin-right:auto;
}
.profile-sidebar{
  display:block;
  padding-top:3.4rem;
}
.profile-card{
  position:sticky;
  top:88px;
  font-family:var(--ui);
  color:var(--ink);
  line-height:1.35;
}
.profile-photo-link{
  display:block;
  width:118px;
  height:118px;
  margin-bottom:1rem;
}
.profile-photo{
  width:118px;
  height:118px;
  object-fit:cover;
  object-position:center 34%;
  border-radius:999px;
  border:1px solid var(--rule);
  box-shadow:0 1px 0 rgba(0,0,0,.04), 0 14px 28px -22px rgba(20,30,28,.65);
  filter:saturate(.92) contrast(1.03);
}
.profile-name{
  font-weight:800;
  letter-spacing:-.02em;
  font-size:1.02rem;
  margin-bottom:.2rem;
}
.profile-title{
  font-weight:650;
  font-size:.86rem;
  color:var(--ink-soft);
  margin-bottom:.35rem;
}
.profile-affil{
  font-family:var(--serif);
  font-size:.82rem;
  color:var(--muted);
  line-height:1.45;
  margin-bottom:1rem;
}
.profile-links{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:.42rem;
  border-top:1px solid var(--rule);
  padding-top:.9rem;
}
.profile-links a{
  font-size:.84rem;
  font-weight:650;
  color:var(--accent);
  text-decoration:none;
}
.profile-links a:hover{
  color:var(--accent-dark);
  text-decoration:underline;
  text-underline-offset:3px;
}

/* Once the sidebar exists, avoid repeating a large portrait on the home page. */
.site-layout .hero-grid{
  grid-template-columns:1fr;
}
.site-layout .hero .portrait{
  display:none;
}

@media (max-width: 980px){
  .site-header .wrap{ max-width:var(--maxw); }
  .site-layout{
    display:block;
    max-width:var(--maxw);
  }
  .profile-sidebar{ display:none; }
  .site-layout .site-main > .section > .wrap,
  .site-layout .site-main > .hero > .wrap{
    padding-left:0;
    padding-right:0;
    margin-left:auto;
    margin-right:auto;
  }
  .site-layout .hero-grid{
    grid-template-columns:1fr 160px;
  }
  .site-layout .hero .portrait{
    display:block;
    width:160px;
  }
  .site-layout .hero .portrait img{
    width:160px;
    height:160px;
  }
}

@media (max-width: 720px){
  .site-layout .hero-grid{ grid-template-columns:1fr; }
  .site-layout .hero .portrait{ display:none; }
}
