/* Marc Schonbrun — site design system (v2)
   Quiet editorial. Warm monochrome. Built to read like a well-made book. */

:root{
  /* Ink Blue — crisp monochrome + one deep book-cloth accent */
  --paper:#f3f3ef;
  --paper-2:#ecebe3;
  --panel:#e8e7e0;
  --ink:#141410;
  --ink-soft:#2c2e2a;
  --muted:#67655e;
  --faint:#9a968c;
  --line:#dbd9cf;
  --line-2:#cecabd;
  --accent:#2b3c66;
  --accent-soft:#41527d;

  /* measure */
  --read:660px;
  --wide:1080px;

  --serif:'Newsreader',Georgia,'Times New Roman',serif;
  --sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);
  font-size:17px;line-height:1.68;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
::selection{background:#2b3c66;color:#f3f3ef;}

h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.1;margin:0;letter-spacing:-0.012em;}
em{font-style:italic;}
p{margin:0 0 1.15em;}
p:last-child{margin-bottom:0;}

.u-serif{font-family:var(--serif);}
.u-sans{font-family:var(--sans);}

/* ---------- shared layout ---------- */
.wrap{max-width:var(--wide);margin:0 auto;padding:0 40px;}
.measure{max-width:var(--read);}

/* eyebrow / small label */
.kicker{
  font-family:var(--sans);font-size:12px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
}

/* ---------- nav ---------- */
.site-nav{
  position:sticky;top:0;z-index:20;background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid color-mix(in srgb,var(--accent) 22%,var(--line));
}
.site-nav .inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--wide);margin:0 auto;padding:18px 40px;
}
.brand{font-family:var(--serif);font-size:20px;letter-spacing:-0.01em;}
.brand b{font-weight:500;color:var(--accent);}
.nav-links{display:flex;gap:30px;align-items:baseline;}
.nav-links a{
  font-family:var(--sans);font-size:14px;font-weight:500;color:var(--muted);
  position:relative;padding:4px 0;transition:color .2s ease;
}
.nav-links a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;
  background:var(--ink);transition:right .28s cubic-bezier(.2,.7,.2,1);
}
.nav-links a:hover{color:var(--ink);}
.nav-links a:hover::after{right:0;background:var(--accent);}
.nav-links a.here{color:var(--accent);}
.nav-links a.here::after{right:0;background:var(--accent);}

/* ---------- footer ---------- */
.site-foot{border-top:1px solid color-mix(in srgb,var(--accent) 30%,var(--line));margin-top:120px;background:color-mix(in srgb,var(--accent) 5%,var(--paper));}
.site-foot .inner{
  display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;
  max-width:var(--wide);margin:0 auto;padding:34px 40px 48px;
  font-family:var(--sans);font-size:13.5px;color:var(--muted);
}
.site-foot .foot-links{display:flex;gap:22px;flex-wrap:wrap;}
.site-foot .foot-links a{transition:color .2s;}
.site-foot .foot-links a:hover{color:var(--accent);}
.site-foot .foot-credit{display:block;margin-top:6px;font-size:12px;color:var(--faint);}

/* ---------- image placeholder ---------- */
.ph{
  position:relative;overflow:hidden;background:var(--paper-2);
  border:1px solid color-mix(in srgb,var(--accent) 18%,var(--line));
  background-image:repeating-linear-gradient(135deg,
     transparent 0 11px, color-mix(in srgb,var(--accent) 8%,transparent) 11px 12px);
  display:flex;align-items:flex-end;
}
.ph > span{
  font-family:'Newsreader',monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--accent);font-weight:600;
  padding:12px 14px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
}
/* a .ph holding a real photo */
.ph.filled{background:var(--panel);background-image:none;border-color:color-mix(in srgb,var(--accent) 16%,var(--line));}
.ph.filled > span{display:none;}
.ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}

/* ---------- interior pages ---------- */
.page-main{padding:9vh 0 0;}
.page-head{max-width:760px;margin-bottom:52px;}
.page-head .kicker{display:block;margin-bottom:22px;}
.page-title{
  font-size:clamp(42px,6.2vw,76px);line-height:.98;letter-spacing:-0.022em;color:var(--ink);
}
.page-lead{
  font-family:var(--serif);font-size:clamp(20px,2.3vw,25px);line-height:1.46;
  color:var(--accent);font-style:italic;margin:26px 0 0;max-width:620px;
}

/* a thin accent rule under the header */
.page-head .rule{height:2px;width:64px;background:var(--accent);margin-top:34px;}

/* prose */
.prose{max-width:var(--read);}
.prose p{
  font-family:var(--serif);font-size:19px;line-height:1.72;color:var(--ink-soft);
  margin:0 0 1.35em;
}
.prose p:first-of-type{font-size:21px;line-height:1.62;color:var(--ink);}
.prose em{font-style:italic;}
.prose a{color:var(--accent);font-weight:500;
  border-bottom:1px solid color-mix(in srgb,var(--accent) 35%,transparent);transition:border-color .2s;}
.prose a:hover{border-color:var(--accent);}

/* a wide figure (portrait/banner) */
.figure{margin:0 0 54px;}
.figure .ph{width:100%;border-radius:4px;}
.figure figcaption{font-family:var(--sans);font-size:13px;color:var(--muted);margin-top:12px;}

/* story: portrait sits beside the opening */
.lead-split{display:grid;grid-template-columns:300px 1fr;gap:54px;align-items:start;margin-bottom:8px;}
.lead-split .ph{width:100%;height:380px;border-radius:4px;position:sticky;top:96px;}
@media (max-width:840px){
  .lead-split{grid-template-columns:1fr;gap:30px;}
  .lead-split .ph{position:static;height:320px;max-width:300px;}
}

/* small link list (music videos etc.) */
.linklist{list-style:none;margin:44px 0 0;padding:0;max-width:var(--read);}
.linklist li{border-top:1px solid var(--line);}
.linklist a{
  display:flex;align-items:baseline;gap:14px;padding:18px 2px;
  font-family:var(--sans);font-size:16px;color:var(--ink);transition:padding .25s,color .2s;
}
.linklist a:hover{padding-left:8px;color:var(--accent);}
.linklist .ll-label{font-weight:600;}
.linklist .ll-meta{font-size:14px;color:var(--muted);}
.linklist .ll-arr{margin-left:auto;color:var(--faint);transition:transform .25s,color .2s;}
.linklist a:hover .ll-arr{transform:translateX(4px);color:var(--accent);}

/* a quiet "next page" pager */
.pager{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  margin-top:80px;padding-top:30px;border-top:1px solid var(--line);max-width:var(--read);}
.pager a{font-family:var(--sans);font-size:14.5px;font-weight:600;color:var(--accent);
  border-bottom:1.5px solid color-mix(in srgb,var(--accent) 32%,transparent);padding-bottom:3px;transition:border-color .2s;}
.pager a:hover{border-color:var(--accent);}
.pager .muted{color:var(--muted);border:none;font-weight:400;}

@media (max-width:720px){
  .page-main{padding:5vh 0 0;}
  .page-head{margin-bottom:38px;}
}

/* ---------- reveal motion ---------- */
/* Hidden state is gated behind .js-reveal (added by site.js) so the page
   is fully visible if JS is disabled, slow, or fails to run. */
.js-reveal [data-reveal]{opacity:0;transform:translateY(14px);
  transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1);}
.js-reveal [data-reveal].in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  .js-reveal [data-reveal]{opacity:1;transform:none;transition:none;}
}

/* ---------- responsive base ---------- */
@media (max-width:720px){
  .wrap{padding:0 22px;}
  .site-nav .inner{padding:15px 22px;}
  .site-foot .inner{padding:28px 22px 38px;}
  .nav-links{gap:18px;}
  .nav-links a{font-size:13px;}
  .brand{font-size:18px;}
}
