*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;color:#333;line-height:1.7;background:#fff}
a{color:#8B0000;text-decoration:none}
a:hover{text-decoration:underline}

/* Page shell: sidebar left, main right */
.shell{display:flex;min-height:100vh}

/* ── SIDEBAR ── */
.sidebar{width:260px;min-width:260px;background:#8B0000;display:flex;flex-direction:column}

.sidebar-header{padding:28px 24px 20px}
.sidebar-home-link{text-decoration:none;color:inherit}
.sidebar-title{color:#fff;font-size:15px;font-weight:700;line-height:1.35;letter-spacing:.01em}
.sidebar-role{color:#e8b4b4;font-size:12px;margin-top:4px}

.sidebar-divider{border:none;border-top:1px solid rgba(255,255,255,.15);margin:0 20px}

.sidebar nav{padding:8px 0;flex:1}
.nav-link{color:#e0c0c0;font-size:13.5px;padding:9px 24px;display:block;border-left:3px solid transparent;transition:background .15s,color .15s,border-color .15s}
.nav-link:hover{background:rgba(255,255,255,.1);color:#fff;text-decoration:none;border-left-color:rgba(255,255,255,.6)}
.nav-link.active{background:rgba(255,255,255,.15);color:#fff;border-left-color:#fff;font-weight:600}

/* Collapsible section headers */
.nav-section{color:#d49a9a;font-size:11px;text-transform:uppercase;letter-spacing:1.2px;padding:14px 24px 4px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:space-between;user-select:none}
.nav-section:hover{color:#fff}
.nav-section .arrow{font-size:9px;transition:transform .2s}
.nav-section.open .arrow{transform:rotate(90deg)}
.nav-children{overflow:hidden;max-height:0;transition:max-height .25s ease}
.nav-children.open{max-height:500px}
.nav-children .nav-link{padding-left:36px;font-size:13px;color:#d4a5a5}

.sidebar-social{margin-top:auto;border-top:1px solid rgba(255,255,255,.15);padding:16px 24px}
.sidebar-social a{color:#d49a9a;font-size:13px;display:block;padding:3px 0}
.sidebar-social a:hover{color:#fff;text-decoration:none}
.sidebar-email{color:#c09090;font-size:12px;margin-top:10px;word-break:break-all}

/* ── MAIN AREA (top nav + content) ── */
.main-area{flex:1;display:flex;flex-direction:column;min-width:0}

/* Top nav bar */
.topnav{background:#f8f8f8;border-bottom:1px solid #e0e0e0;padding:0 32px;display:flex;align-items:center;height:48px;position:sticky;top:0;z-index:10}
.topnav nav a{font-size:13.5px;color:#444;padding:14px 11px;display:inline-block;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}
.topnav nav a:hover{color:#8B0000;text-decoration:none;border-bottom-color:#8B0000}
.topnav nav a.active{color:#8B0000;font-weight:600;border-bottom-color:#8B0000}

/* Content */
.content{flex:1;padding:36px 44px;background:#fff}
.content h2{font-size:21px;font-weight:700;color:#8B0000;margin:0 0 14px;padding-bottom:8px;border-bottom:2px solid #8B0000}
.content h3{font-size:16px;font-weight:600;color:#333;margin:22px 0 8px}
.content p{margin-bottom:12px;font-size:15px}
.content ul{margin:0 0 16px 20px;font-size:15px}
.content li{margin-bottom:6px}

.highlight{background:#fef2f2;border-left:4px solid #8B0000;padding:16px 20px;margin:16px 0;border-radius:0 6px 6px 0}
.highlight strong{color:#8B0000}

/* Standard Markdown tables */
.content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0;
  font-size: 14px;
}
.content th {
  background: #8B0000;
  color: #fff;
  padding: 8px 12px;
  text-align: left;
  font-weight: 600;
}
.content td {
  padding: 8px 12px;
  border-bottom: 1px solid #e8e8e8;
}
.content tr:nth-child(even) td {
  background: #fafafa;
}

/* Research metrics table */
.metrics-table{width:100%;border-collapse:collapse;margin:20px 0;font-size:14px}
.metrics-table th{background:#8B0000;color:#fff;padding:10px 16px;text-align:left;font-weight:600;letter-spacing:.03em}
.metrics-table td{padding:9px 16px;border-bottom:1px solid #f0e0e0}
.metrics-table tr:nth-child(even) td{background:#fef8f8}
.metrics-table .val{font-weight:700;color:#8B0000;font-size:16px}

.industry-tags{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}
.industry-tags span{background:#8B0000;color:#fff;padding:5px 13px;border-radius:4px;font-size:13px;font-weight:500}

.awards-list{list-style:none;margin-left:0;padding:0}
.awards-list li{padding:8px 0;border-bottom:1px solid #f5eaea;font-size:14px}
.awards-list li:last-child{border-bottom:none}
.awards-list li::before{content:"–";color:#8B0000;margin-right:8px;font-weight:700}

footer.foot{background:#8B0000;color:#e0c0c0;padding:14px 32px;font-size:12.5px;text-align:center}

/* Publication link badges */
.pub-link{display:inline-block;padding:4px 12px;background:#8B0000;color:#fff;border-radius:3px;font-size:13px;margin-right:6px;text-decoration:none}
.pub-year-count{display:inline-block;padding:2px 8px;background:#8B0000;color:#fff;border-radius:3px;font-size:12px;font-weight:600;margin-left:8px}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .shell{flex-direction:column}
  .sidebar{width:100%;min-width:0}
  .sidebar-header{padding:16px 16px 12px}
  .sidebar nav{display:flex;flex-wrap:wrap;padding:4px 8px}
  .nav-section{padding:10px 12px 2px;font-size:10px}
  .nav-children{max-height:0}
  .nav-children .nav-link{padding:5px 12px;font-size:12px}
  .nav-link{padding:7px 10px;font-size:13px;border-left:none}
  .sidebar-social{display:none}
  .topnav{padding:0 12px;overflow-x:auto}
  .topnav nav a{padding:12px 8px;font-size:13px;white-space:nowrap}
  .content{padding:20px 16px}
}

/* ── COMPACT CV PAGE ── */
.cv-compact h2 {
  font-size: 17px !important;
  margin-top: 1.2rem !important;
  margin-bottom: 0.3rem !important;
  padding-bottom: 0.2rem !important;
}
.cv-compact h3 {
  font-size: 14px !important;
  margin-top: 0.8rem !important;
  margin-bottom: 0.2rem !important;
}
.cv-compact p {
  margin-bottom: 0.3rem !important;
  font-size: 13.5px !important;
  line-height: 1.5 !important;
}
.cv-compact ul, .cv-compact ol {
  margin-bottom: 0.4rem !important;
  font-size: 13.5px !important;
  line-height: 1.45 !important;
}
.cv-compact li {
  margin-bottom: 2px !important;
}
.cv-compact hr {
  margin: 0.6rem 0 !important;
}
.cv-compact strong {
  font-size: inherit;
}

/* Page hero image */
.page-hero {
  margin: 0 0 1.5rem 0;
  border-radius: 6px;
  overflow: hidden;
}
.page-hero img {
  width: 100%;
  height: auto;
  max-height: 400px;
  object-fit: cover;
  display: block;
}

/* Content images */
.content-img {
  max-width: 100%;
  height: auto;
  border-radius: 4px;
  margin: 1rem 0;
}

/* Image gallery (for pages with multiple images like media/teaching) */
.img-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  margin: 1rem 0;
}
.img-gallery img {
  width: 100%;
  height: 150px;
  object-fit: cover;
  border-radius: 4px;
}

/* ── PRINT ── */
@media print{
  .sidebar,.topnav{display:none}
  .content{padding:20px}
  .shell{display:block}
}
