/* ===========================================================
   Christopher Adams — site styles
   One stylesheet shared by every page. Edit colours, fonts
   and spacing here and the change applies site-wide.
   =========================================================== */

:root{
  --ink:#1a1a1a;
  --paper:#fbfaf7;
  --muted:#6b6862;
  --line:#e3e0d8;
  --accent:#9c2c2c;        /* deep theatre red — used sparingly */
  --display:"Georgia","Times New Roman",serif;
  --body:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit}
.wrap{max-width:880px;margin:0 auto;padding:0 28px}

/* ---- nav ---- */
nav{
  display:flex;justify-content:space-between;align-items:center;
  padding:26px 0;border-bottom:1px solid var(--line);
}
nav .name{
  font-family:var(--display);font-size:17px;letter-spacing:.2px;
  text-decoration:none;color:var(--ink);
}
nav ul{display:flex;gap:26px;list-style:none}
nav a{
  text-decoration:none;color:var(--muted);font-size:14px;
  letter-spacing:.4px;transition:color .2s;
}
nav a:hover,nav a.active{color:var(--accent)}

/* ---- hero ---- */
.hero{padding:96px 0 72px;border-bottom:1px solid var(--line)}
.hero h1{
  font-family:var(--display);font-weight:400;
  font-size:clamp(38px,7vw,68px);line-height:1.05;
  letter-spacing:-.5px;margin-bottom:24px;
}
.hero .role{
  font-size:15px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--muted);margin-bottom:30px;
}
.hero .lede{font-size:20px;max-width:560px;color:#3a3a3a;line-height:1.55}
.hero .lede em{color:var(--accent);font-style:italic}

/* ---- hero image ---- */
.hero-img{
  width:100%;height:clamp(220px,38vw,380px);object-fit:cover;
  display:block;border-radius:4px;margin-bottom:44px;
  background:#ece9e1;  /* shows while loading / if missing */
}
/* placeholder box used until a real image is dropped in */
.img-placeholder{
  display:flex;align-items:center;justify-content:center;text-align:center;
  background:#ece9e1;color:#9a968c;border:1px dashed #c9c5ba;border-radius:4px;
  font-size:13px;letter-spacing:.5px;line-height:1.5;padding:16px;
}
.hero-ph{width:100%;height:clamp(220px,38vw,380px);margin-bottom:44px}

/* ---- section heads ---- */
.eyebrow{
  font-size:12px;letter-spacing:3px;text-transform:uppercase;
  color:var(--muted);margin-bottom:34px;
  display:flex;align-items:center;gap:14px;
}
.eyebrow::after{content:"";flex:1;height:1px;background:var(--line)}
section{padding:72px 0}
section + section{border-top:1px solid var(--line)}

/* ---- awards ---- */
.award{
  display:grid;grid-template-columns:1fr auto;gap:8px 30px;
  padding:22px 0;border-bottom:1px solid var(--line);align-items:baseline;
}
.award:first-of-type{border-top:1px solid var(--line)}
.award .title{font-family:var(--display);font-size:20px}
.award .play{color:var(--accent);font-style:italic;font-family:var(--display)}
.award .body{color:var(--muted);font-size:14.5px;margin-top:3px}
.award .year{font-size:13px;letter-spacing:1px;color:var(--muted);text-align:right;white-space:nowrap}
.award .tag{
  display:inline-block;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--accent);border:1px solid var(--accent);border-radius:2px;
  padding:2px 8px;margin-right:10px;vertical-align:middle;
}

/* ---- work list ---- */
.work-grid{display:grid;gap:0}
.piece{
  display:grid;grid-template-columns:120px 1fr;gap:30px;
  padding:30px 0;border-bottom:1px solid var(--line);
}
.piece:first-child{border-top:1px solid var(--line)}
.piece .meta{font-size:13px;letter-spacing:.5px;color:var(--muted);line-height:1.5}
.piece h3{font-family:var(--display);font-weight:400;font-size:24px;margin-bottom:8px}
.piece p{color:#48453f;font-size:15.5px;max-width:48ch}
.piece a{text-decoration:none}
.piece a:hover h3{color:var(--accent)}
.piece .arrow{color:var(--accent);font-size:13px;letter-spacing:.5px;margin-top:10px;display:inline-block}

/* work list with thumbnails: thumb | meta | text */
.piece.has-thumb{grid-template-columns:140px 110px 1fr;gap:26px}
.piece .thumb{width:140px;height:100px;object-fit:cover;border-radius:4px;background:#ece9e1;display:block}
.piece .thumb-ph{width:140px;height:100px;font-size:11px}

/* ---- publications ---- */
.pub{border-top:1px solid var(--line);padding:24px 0}
.pub:last-of-type{border-bottom:1px solid var(--line)}
.pub h3{font-family:var(--display);font-weight:400;font-size:22px;margin-bottom:5px}
.pub .by{font-size:14px;color:#48453f;margin-bottom:8px}
.pub .desc{font-size:15px;color:#48453f;line-height:1.55;max-width:62ch}
.pub .links{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px 20px}
.pub .links a{color:var(--accent);font-size:13.5px;text-decoration:none}
.pub .links a:hover{text-decoration:underline}

/* ---- image gallery + lightbox ---- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:8px 0 0}
.gallery button{padding:0;border:none;background:#ece9e1;border-radius:4px;overflow:hidden;cursor:pointer;aspect-ratio:1/1;display:block}
.gallery img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s,opacity .2s}
.gallery button:hover img{transform:scale(1.04);opacity:.92}
.lightbox{position:fixed;inset:0;background:rgba(20,18,15,.92);display:none;align-items:center;justify-content:center;z-index:1000;padding:24px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:4px;box-shadow:0 8px 40px rgba(0,0,0,.5)}
.lightbox .lb-close{position:absolute;top:18px;right:24px;font-size:34px;line-height:1;color:#fff;background:none;border:none;cursor:pointer;opacity:.8}
.lightbox .lb-close:hover{opacity:1}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:40px;color:#fff;background:none;border:none;cursor:pointer;opacity:.7;padding:0 18px;user-select:none}
.lightbox .lb-nav:hover{opacity:1}
.lightbox .lb-prev{left:8px}
.lightbox .lb-next{right:8px}
@media(max-width:620px){.gallery{grid-template-columns:repeat(2,1fr)}}

/* ---- play page: credits + press ---- */
.credits{display:grid;grid-template-columns:auto 1fr;gap:8px 20px;font-size:14.5px;margin:8px 0 4px;max-width:560px}
.credits dt{color:var(--muted);letter-spacing:.3px}
.credits dd{margin:0;color:#3a3a3a}
.creatives{font-size:13.5px;color:var(--muted);line-height:1.7;margin:18px 0 0;max-width:600px}
.support{font-size:13.5px;color:var(--muted);font-style:italic;margin-top:14px}
.press{margin:8px 0 0}
.quote{border-left:2px solid var(--accent);padding:2px 0 2px 22px;margin:24px 0}
.quote p{font-family:var(--display);font-size:18px;line-height:1.5;color:var(--ink);font-style:italic;margin:0}
.quote .stars{color:var(--accent);font-style:normal;letter-spacing:1px;margin-right:6px;font-family:var(--body)}
.quote cite{display:block;font-style:normal;font-family:var(--body);font-size:13px;color:var(--muted);letter-spacing:.5px;margin-top:8px}
.venues{font-size:13px;color:var(--muted);line-height:1.7;margin-top:8px}

/* ---- generic prose (about / play pages) ---- */
.play-img{width:100%;height:clamp(240px,42vw,420px);object-fit:cover;display:block;border-radius:4px;background:#ece9e1}
.play-img-ph{width:100%;height:clamp(240px,42vw,420px)}
.page-head{padding:80px 0 48px;border-bottom:1px solid var(--line)}
.page-head .role{font-size:13px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
.page-head h1{font-family:var(--display);font-weight:400;font-size:clamp(34px,6vw,56px);line-height:1.08;letter-spacing:-.5px}
.page-head .sub{margin-top:18px;color:var(--muted);font-size:16px;letter-spacing:.3px}
.prose{padding:56px 0;max-width:640px}
.prose p{font-size:17px;color:#3a3a3a;margin-bottom:22px}
.prose p:last-child{margin-bottom:0}
.prose .pull{font-family:var(--display);font-size:21px;font-style:italic;color:var(--ink);line-height:1.5;margin:36px 0;padding-left:22px;border-left:2px solid var(--accent)}
.prose .pull cite{display:block;font-style:normal;font-family:var(--body);font-size:14px;color:var(--muted);letter-spacing:.5px;margin-top:12px}
.back{display:inline-block;margin:8px 0 0;font-size:14px;letter-spacing:.5px;color:var(--muted);text-decoration:none}
.back:hover{color:var(--accent)}

/* ---- contact form ---- */
.form{max-width:520px;padding:8px 0 0}
.form label{display:block;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin:24px 0 8px}
.form input,.form textarea{
  width:100%;font-family:var(--body);font-size:16px;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:3px;
  padding:13px 14px;transition:border-color .2s;
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--accent)}
.form textarea{min-height:150px;resize:vertical}
.form button{
  margin-top:28px;font-family:var(--body);font-size:14px;letter-spacing:1px;
  text-transform:uppercase;color:#fff;background:var(--accent);
  border:none;border-radius:3px;padding:14px 30px;cursor:pointer;transition:opacity .2s;
}
.form button:hover{opacity:.88}
.social{margin-top:48px;padding-top:32px;border-top:1px solid var(--line);font-size:15px}
.social a{color:var(--accent);text-decoration:none}
.social a:hover{text-decoration:underline}

/* ---- footer ---- */
footer{
  border-top:1px solid var(--line);padding:48px 0 64px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;
  color:var(--muted);font-size:14px;
}
footer a{color:var(--muted);text-decoration:none}
footer a:hover{color:var(--accent)}

/* ---- responsive ---- */
@media(max-width:620px){
  .piece{grid-template-columns:1fr;gap:8px}
  .piece.has-thumb{grid-template-columns:1fr;gap:12px}
  .piece .thumb,.piece .thumb-ph{width:100%;height:180px}
  .award{grid-template-columns:1fr}
  .award .year{text-align:left}
  nav ul{gap:18px}
  .hero{padding:64px 0 52px}
}

/* ---- accessibility ---- */
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important}}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
