:root {
  --bg: #f7f3ec;
  --paper: #fffaf2;
  --ink: #1f1b17;
  --muted: #6f665c;
  --line: #ded4c7;
  --accent: #6f4933;
  --accent-dark: #473022;
  --soft: #ece3d6;
  --shadow: 0 24px 60px rgba(49, 38, 25, 0.08);
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: Georgia, 'Times New Roman', serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.6;
}
a { color: inherit; }
.site-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 24px clamp(20px, 5vw, 72px);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  background: rgba(247, 243, 236, 0.92);
  backdrop-filter: blur(10px);
  z-index: 5;
}
.brand {
  font-size: 1.15rem;
  text-decoration: none;
  letter-spacing: .04em;
  text-transform: uppercase;
}
nav { display: flex; gap: 22px; align-items: center; font-size: .94rem; }
nav a { text-decoration: none; color: var(--muted); }
nav a:hover { color: var(--ink); }
.lang { border: 1px solid var(--line); padding: 4px 9px; border-radius: 999px; }
.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(280px, .55fr);
  gap: clamp(32px, 6vw, 80px);
  padding: clamp(56px, 9vw, 120px) clamp(20px, 5vw, 72px);
  max-width: 1240px;
  margin: 0 auto;
}
.eyebrow {
  margin: 0 0 14px;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: .75rem;
  font-family: Arial, sans-serif;
  font-weight: 700;
}
h1, h2, h3 { line-height: 1.08; margin: 0; font-weight: 500; }
h1 { font-size: clamp(2.7rem, 7vw, 5.8rem); letter-spacing: -.045em; max-width: 900px; }
h2 { font-size: clamp(2rem, 4vw, 3.6rem); letter-spacing: -.035em; }
h3 { font-size: 1.45rem; margin-bottom: 12px; }
.lead { font-size: clamp(1.15rem, 2vw, 1.45rem); color: var(--muted); max-width: 760px; margin: 28px 0 0; }
.actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 34px; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 12px 20px;
  border-radius: 999px;
  text-decoration: none;
  font-family: Arial, sans-serif;
  font-size: .92rem;
}
.primary { background: var(--ink); color: var(--paper); }
.secondary { border: 1px solid var(--line); color: var(--ink); }
.author-card {
  background: var(--paper);
  border: 1px solid var(--line);
  padding: 18px;
  box-shadow: var(--shadow);
  align-self: start;
}
.portrait-frame {
  aspect-ratio: 4 / 5;
  background: linear-gradient(135deg, #d8cabb, #f4eadc);
  display: grid;
  place-items: center;
  color: var(--muted);
  overflow: hidden;
}
.portrait-frame img { width: 100%; height: 100%; object-fit: cover; display: block; }
.portrait-frame span { display: none; font-family: Arial, sans-serif; text-transform: uppercase; letter-spacing: .1em; font-size: .72rem; }
.portrait-frame.empty span { display: block; }
.author-card p { color: var(--muted); font-size: .96rem; margin: 16px 0 0; }
.section {
  max-width: 1240px;
  margin: 0 auto;
  padding: clamp(48px, 7vw, 92px) clamp(20px, 5vw, 72px);
  border-top: 1px solid var(--line);
}
.section-heading { max-width: 760px; margin-bottom: 34px; }
.section-heading p, .split p, .about p, .contact p, .article p { color: var(--muted); }
.book-grid { display: grid; gap: 22px; }
.book-card {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 24px;
  padding: 24px;
  background: var(--paper);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.book-card.muted { background: var(--soft); }
.cover {
  aspect-ratio: 2 / 3;
  border: 1px solid var(--line);
  display: grid;
  place-items: center;
  text-align: center;
  color: var(--muted);
  font-family: Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .7rem;
  background: #eee5d9;
}
.status {
  margin: 0 0 10px;
  color: var(--accent);
  font-family: Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: .09em;
  font-size: .74rem;
  font-weight: 700;
}
.text-link { color: var(--accent-dark); text-underline-offset: 4px; }
.split { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(28px, 6vw, 80px); align-items: start; }
.essay-list { display: grid; gap: 12px; }
.essay-list a {
  background: var(--paper);
  border: 1px solid var(--line);
  padding: 18px 20px;
  text-decoration: none;
  box-shadow: 0 12px 32px rgba(49, 38, 25, 0.05);
}
.about { max-width: 920px; }
.contact {
  display: flex;
  justify-content: space-between;
  gap: 28px;
  align-items: center;
}
footer {
  padding: 28px clamp(20px, 5vw, 72px);
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  color: var(--muted);
  font-size: .9rem;
}
.article-page { max-width: 900px; margin: 0 auto; padding: clamp(50px, 8vw, 100px) 20px; }
.article { background: var(--paper); border: 1px solid var(--line); padding: clamp(28px, 5vw, 60px); box-shadow: var(--shadow); }
.article h1 { font-size: clamp(2.3rem, 5vw, 4.6rem); }
/* SOCIAL MEDIA */
.author-links a{display:inline-flex;align-items:center;justify-content:center;margin:0 14px;}
.linkedin{color:#0A66C2;}
.fetlife{color:#7a1f2a;}
.author-links svg{width:30px;height:30px;display:block;}
.author-links a:hover{opacity:.8;}

/* CONTACT */

.contact-section{
max-width:700px;
margin:5rem auto;
padding:0 1.5rem;
}

.contact-form{
display:flex;
flex-direction:column;
gap:1rem;
margin-top:2rem;
}

.contact-form label{
font-weight:600;
}

.contact-form input,
.contact-form textarea{
padding:14px;
font-size:1rem;
border:1px solid #c9c2b8;
background:#faf8f2;
font-family:inherit;
}

.contact-form button{
padding:14px 24px;
border:none;
cursor:pointer;
font-size:1rem;
background:#2d2a26;
color:#fff;
width:fit-content;
}


/* RESPONSIVE */

@media (max-width: 820px) {
  .site-header { 
    align-items: flex-start; 
    gap: 16px; 
    flex-direction: column; 
    position: static; 
  }

  nav { 
    flex-wrap: wrap; 
    gap: 12px 18px; 
  }

  .hero, .split { 
    grid-template-columns: 1fr; 
  }

  .book-card { 
    grid-template-columns: 110px 1fr; 
    padding: 18px; 
  }

  .contact { 
    flex-direction: column; 
    align-items: flex-start; 
  }
}

@media (max-width: 820px) {
  .site-header { align-items: flex-start; gap: 16px; flex-direction: column; position: static; }
  nav { flex-wrap: wrap; gap: 12px 18px; }
  .hero, .split { grid-template-columns: 1fr; }
  .book-card { grid-template-columns: 110px 1fr; padding: 18px; }
  .contact { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 520px) {
  .book-card { grid-template-columns: 1fr; }
  .cover { max-width: 160px; }
}
