/* ============================================================
   Justin Taylor — Portfolio
   Clean / minimal design system. Shared across all pages.
   Edit the variables below to restyle the entire site.
   ============================================================ */
:root{
  --paper:#ffffff;
  --paper-2:#f7f6f3;        /* warm near-white for alternating sections */
  --ink:#16161a;            /* near-black text */
  --ink-soft:#3a3a40;
  --muted:#76767e;          /* secondary text */
  --line:#e8e7e2;           /* hairlines */
  --accent:#234b3d;         /* quiet evergreen */
  --accent-2:#2f6b54;       /* hover */
  --maxw:1200px;
  --gutter:32px;
  --serif:"Newsreader", Georgia, serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono:"Space Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
@media(max-width:640px){:root{--gutter:22px}}

/* ---------- type helpers ---------- */
.eyebrow{
  font-family:var(--mono);font-size:12px;font-weight:400;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent);
}
.display{
  font-family:var(--serif);font-weight:300;letter-spacing:-.015em;line-height:1.04;
}
.display em{font-style:italic}
h1.display{font-size:clamp(42px,6.5vw,82px)}
h2.display{font-size:clamp(30px,4.6vw,52px)}
h3.display{font-size:clamp(24px,3vw,34px)}
.lead{font-size:clamp(18px,2.2vw,21px);color:var(--ink-soft);line-height:1.6}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:13px 24px;border-radius:2px;font-size:14px;font-weight:500;
  letter-spacing:.01em;transition:background .2s,color .2s,border-color .2s,transform .2s;
}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--accent)}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink)}
.link-underline{
  position:relative;color:var(--ink);font-weight:500;
  background-image:linear-gradient(var(--accent),var(--accent));
  background-size:0% 1px;background-repeat:no-repeat;background-position:0 100%;
  transition:background-size .3s;padding-bottom:2px;
}
.link-underline:hover{background-size:100% 1px;color:var(--accent)}

/* ---------- NAV ---------- */
header.site-nav{
  position:sticky;top:0;z-index:60;background:rgba(255,255,255,.85);
  backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.nav-brand{font-family:var(--serif);font-size:21px;font-weight:400;letter-spacing:-.01em}
.nav-brand .dot{color:var(--accent)}
.nav-menu{display:flex;align-items:center;gap:34px}
.nav-menu a{font-size:14.5px;color:var(--muted);transition:color .2s;position:relative}
.nav-menu a:hover{color:var(--ink)}
.nav-menu a.active{color:var(--ink)}
.nav-menu a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-26px;height:2px;background:var(--accent);
}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:28px;height:22px;position:relative}
.nav-toggle span{position:absolute;left:0;right:0;height:2px;background:var(--ink);transition:.3s}
.nav-toggle span:nth-child(1){top:0}
.nav-toggle span:nth-child(2){top:10px}
.nav-toggle span:nth-child(3){top:20px}
@media(max-width:760px){
  .nav-menu{
    position:fixed;inset:70px 0 auto 0;background:var(--paper);flex-direction:column;
    align-items:flex-start;gap:0;padding:8px 0;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .35s ease;height:auto;
  }
  .nav-menu.open{transform:translateY(0)}
  .nav-menu a{width:100%;padding:15px var(--gutter);font-size:17px;border-top:1px solid var(--line)}
  .nav-menu a.active::after{display:none}
  .nav-toggle{display:block}
}

/* ---------- FOOTER ---------- */
footer.site-foot{border-top:1px solid var(--line);margin-top:0;background:var(--paper-2)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:64px 0 48px}
.foot-brand{font-family:var(--serif);font-size:28px;font-weight:300;line-height:1.15;margin-bottom:16px}
.foot-brand .dot{color:var(--accent)}
.foot-col h4{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-weight:400}
.foot-col a{display:block;font-size:15px;color:var(--ink-soft);padding:5px 0;transition:color .2s}
.foot-col a:hover{color:var(--accent)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding:22px 0 40px;border-top:1px solid var(--line)}
.foot-bottom span{font-size:13px;color:var(--muted)}
@media(max-width:680px){.foot-top{grid-template-columns:1fr;gap:32px;padding:48px 0 32px}}

/* ---------- generic section ---------- */
section.block{padding:60px 0}
section.tint{background:var(--paper-2)}
.sec-head{max-width:680px;margin-bottom:40px}
.sec-head .eyebrow{display:inline-block;margin-bottom:18px}
.sec-head h2{margin-bottom:0}
.sec-head p{color:var(--muted);margin-top:18px;font-size:18px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
@media(max-width:640px){section.block{padding:64px 0}}

/* ---------- HERO ---------- */
.hero{padding:64px 0 44px;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center}
.hero h1{margin:22px 0 26px}
.hero .lead{max-width:32em;margin-bottom:36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-photo{position:relative}
.hero-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:3px;filter:grayscale(.08)}
@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-photo{order:-1;max-width:340px}
}

/* ---------- logo strip ---------- */
.logostrip{padding:26px 0;border-bottom:1px solid var(--line)}
.logostrip .wrap{display:flex;align-items:center;gap:42px;flex-wrap:wrap}
.logostrip .label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.logostrip .logos{display:flex;align-items:center;gap:44px;flex-wrap:wrap;flex:1}
.logostrip img{height:39px;width:auto;opacity:.55;filter:grayscale(1);transition:opacity .25s,filter .25s}
.logostrip img:hover{opacity:.9;filter:grayscale(0)}
.logostrip img.lg{height:60px}  /* logos with extra internal whitespace (e.g. Twitter) */
.logostrip .press-name{font-family:var(--serif);font-weight:400;font-size:23px;letter-spacing:.01em;color:var(--muted);opacity:.85;transition:color .2s}
.logostrip .press-name:hover{color:var(--ink);opacity:1}
@media(max-width:760px){
  .logostrip{padding:18px 0}
  .logostrip .wrap{flex-direction:column;align-items:flex-start;gap:12px}
  .logostrip .logos{gap:16px 22px !important;width:100%;flex:0 1 auto;justify-content:flex-start}
  .logostrip img{height:22px !important}
  .logostrip img.lg{height:30px !important}
  .logostrip .press-name{font-size:18px}
}

/* ---------- work grid ---------- */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:42px 38px}
.work-grid.three{grid-template-columns:repeat(3,1fr);gap:34px 28px}
@media(max-width:900px){.work-grid.three{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.work-grid,.work-grid.three{grid-template-columns:1fr;gap:36px}}
.work-card{display:block}
.work-card .thumb{aspect-ratio:1/1;overflow:hidden;border-radius:3px;background:var(--paper-2)}
.work-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease,filter .6s;filter:grayscale(.1)}
.work-card:hover .thumb img{transform:scale(1.04);filter:grayscale(0)}
.work-card .meta{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-top:18px}
.work-card h3{font-family:var(--serif);font-weight:400;font-size:25px;letter-spacing:-.01em}
.work-card .cat{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);white-space:nowrap}
.work-card p{color:var(--muted);font-size:15px;margin-top:8px;max-width:42em}

/* ---------- services list ---------- */
.svc-list{border-top:1px solid var(--line)}
.svc-row{
  display:grid;grid-template-columns:60px 1fr 1.2fr;gap:30px;align-items:start;
  padding:34px 4px;border-bottom:1px solid var(--line);transition:padding .25s;
}
.svc-row:hover{padding-left:14px}
.svc-row .num{font-family:var(--mono);font-size:13px;color:var(--accent)}
.svc-row h3{font-family:var(--serif);font-weight:400;font-size:clamp(22px,2.6vw,30px);letter-spacing:-.01em}
.svc-row p{color:var(--muted);font-size:16px}
@media(max-width:720px){
  .svc-row{grid-template-columns:1fr;gap:10px;padding:26px 0}
  .svc-row:hover{padding-left:0}
}

/* compact services (home) */
.svc-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:3px;overflow:hidden}
@media(max-width:820px){.svc-mini{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.svc-mini{grid-template-columns:1fr}}
.svc-mini .cell{background:var(--paper);padding:26px 24px;transition:background .25s}
.svc-mini .cell:hover{background:var(--paper-2)}
.svc-mini .num{font-family:var(--mono);font-size:12px;color:var(--accent);margin-bottom:12px}
.svc-mini h4{font-family:var(--serif);font-weight:400;font-size:21px;margin-bottom:7px}
.svc-mini p{color:var(--muted);font-size:14.5px;line-height:1.5}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:start}
@media(max-width:860px){.about-grid{grid-template-columns:1fr;gap:36px}}
.about-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:3px;filter:grayscale(.08);position:sticky;top:96px}
.about-copy p{font-size:19px;margin-bottom:22px;color:var(--ink-soft)}
.about-copy p.big{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.8vw,28px);line-height:1.35;color:var(--ink);margin-bottom:28px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px;border-top:1px solid var(--line);padding-top:36px}
.stat b{font-family:var(--serif);font-weight:300;font-size:46px;display:block;line-height:1}
.stat span{font-size:13.5px;color:var(--muted)}
@media(max-width:560px){.stats{grid-template-columns:1fr;gap:20px}}

/* ---------- case study page ---------- */
.case-head{padding:60px 0 48px;border-bottom:1px solid var(--line)}
.case-back{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block;width:fit-content;margin-bottom:34px;transition:color .2s}
.case-back:hover{color:var(--accent)}
.case-head .cat{display:inline-block;margin-bottom:16px}
.case-head h1{max-width:16em;margin-bottom:0}
.case-roles{display:flex;gap:36px;flex-wrap:wrap;margin-top:30px}
.case-roles .k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:4px}
.case-roles .v{font-size:15px;color:var(--ink)}
.case-hero{margin:0 auto;max-width:var(--maxw);padding:0 var(--gutter)}
.case-hero img{width:100%;border-radius:3px;margin-top:48px;object-fit:cover;max-height:620px}
/* full-bleed hero that shows the entire image (no crop) */
.case-hero .hero-fit{width:100%;height:auto;max-height:none;object-fit:contain;border-radius:3px;margin-top:48px;display:block}
.case-body{display:grid;grid-template-columns:1fr 2fr;gap:48px;padding:72px 0}
.case-body .side .k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.case-body .copy p{font-size:19px;color:var(--ink-soft);margin-bottom:22px;line-height:1.6}
.case-body .copy p em{font-style:italic;color:var(--ink)}
@media(max-width:760px){.case-body{grid-template-columns:1fr;gap:24px;padding:48px 0}}
.case-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding-bottom:24px}
.case-gallery img{width:100%;border-radius:3px;object-fit:cover;background:var(--paper-2)}
.case-gallery img:nth-child(3n+1){grid-column:span 2;aspect-ratio:16/9}
@media(max-width:560px){.case-gallery{grid-template-columns:1fr}.case-gallery img:nth-child(3n+1){grid-column:span 1}}
.case-nav{display:flex;justify-content:space-between;gap:16px;border-top:1px solid var(--line);padding:38px 0 0;flex-wrap:wrap}
.case-nav a{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);transition:color .2s}
.case-nav a:hover{color:var(--accent)}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:start}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:36px}}
.contact-grid h1{margin:18px 0 24px}
.contact-email{font-family:var(--serif);font-weight:300;font-size:clamp(24px,3.2vw,36px);letter-spacing:-.01em;display:inline-block;margin:8px 0 32px;border-bottom:1px solid var(--line);padding-bottom:6px;transition:border-color .2s,color .2s}
.contact-email:hover{border-color:var(--accent);color:var(--accent)}
.contact-channels{border-top:1px solid var(--line)}
.contact-channels a{display:flex;justify-content:space-between;align-items:center;padding:20px 0;border-bottom:1px solid var(--line);transition:padding .2s}
.contact-channels a:hover{padding-left:10px}
.contact-channels .name{font-size:17px}
.contact-channels .handle{font-family:var(--mono);font-size:13px;color:var(--muted)}

/* ---------- CTA band ---------- */
.cta-band{background:var(--ink);color:var(--paper)}
.cta-band .wrap{padding:84px var(--gutter);text-align:center}
.cta-band .eyebrow{color:#8fb3a3}
.cta-band h2{color:var(--paper);margin:16px auto 26px;max-width:14em}
.cta-band .btn-primary{background:var(--paper);color:var(--ink)}
.cta-band .btn-primary:hover{background:var(--accent);color:#fff}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   Case-study rich components (Island Breeze etc.)
   ============================================================ */
/* local image with graceful "drop image here" fallback */
.shot{position:relative;background:var(--paper-2);overflow:hidden;border-radius:3px}
.shot img{width:100%;height:100%;object-fit:cover;display:block}
.shot.missing img{display:none}
.shot.missing::after{
  content:attr(data-label);position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;text-align:center;padding:18px;border:1px dashed #c9c2b4;border-radius:3px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);
}
.shot.r45{aspect-ratio:4/5}
.shot.r43{aspect-ratio:4/3}
.shot.r11{aspect-ratio:1/1}
.shot.r169{aspect-ratio:16/9}

/* stats band */
.stats-band{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink);color:var(--paper)}
.stats-band .grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stats-band .grid.cols-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:640px){.stats-band .grid.cols-3{grid-template-columns:1fr}}
.stats-band .stat-cell{padding:46px 28px;border-left:1px solid rgba(255,255,255,.12)}
.stats-band .stat-cell:first-child{border-left:0}
.stats-band b{font-family:var(--serif);font-weight:300;font-size:clamp(34px,4vw,52px);line-height:1;display:block;margin-bottom:10px}
.stats-band span{font-size:13.5px;color:#a9b3ad;line-height:1.45}
@media(max-width:760px){.stats-band .grid{grid-template-columns:repeat(2,1fr)}.stats-band .stat-cell:nth-child(odd){border-left:0}.stats-band .stat-cell{padding:34px 22px}}
@media(max-width:420px){.stats-band .grid{grid-template-columns:1fr}.stats-band .stat-cell{border-left:0;border-top:1px solid rgba(255,255,255,.12)}.stats-band .stat-cell:first-child{border-top:0}}

/* "what I did" breakdown */
.did-list{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--line);border:1px solid var(--line);border-radius:3px;overflow:hidden}
@media(max-width:680px){.did-list{grid-template-columns:1fr}}
.did-item{background:var(--paper);padding:30px 28px}
.did-item .num{font-family:var(--mono);font-size:12px;color:var(--accent);margin-bottom:12px}
.did-item h4{font-family:var(--serif);font-weight:400;font-size:21px;margin-bottom:8px;letter-spacing:-.01em}
.did-item p{color:var(--muted);font-size:15px;line-height:1.55}

/* generic galleries */
.shot-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.shot-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:760px){.shot-grid-3{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.shot-grid-2{grid-template-columns:1fr}.shot-grid-3{grid-template-columns:1fr}}
.creator figcaption{margin-top:12px}
.creator .nm{font-family:var(--serif);font-size:19px}
.creator .rl{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:block;margin-top:3px}

/* lazy video embeds (TikTok / Instagram) */
.video-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.video-grid.feature{grid-template-columns:1fr;max-width:420px}
@media(max-width:620px){.video-grid{grid-template-columns:1fr}}
.video-card{position:relative;border-radius:4px;overflow:hidden;background:linear-gradient(150deg,#7fd5e6 0%,#3aa6d6 45%,#1f4f9c 100%);aspect-ratio:9/16;cursor:pointer;border:1px solid var(--line)}
.video-card .vc-meta{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;padding:18px;z-index:2;color:#fff}
.video-card .vc-top{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.video-card .vc-plat{background:rgba(255,255,255,.9);color:var(--ink);padding:3px 8px;border-radius:999px;font-weight:700}
.video-card .vc-cap{font-family:var(--serif);font-size:17px;line-height:1.25;max-width:14em;text-shadow:0 1px 12px rgba(0,0,0,.25)}
.video-card .vc-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:62px;height:62px;border-radius:999px;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;transition:transform .25s,background .25s;z-index:2}
.video-card:hover .vc-play{transform:translate(-50%,-50%) scale(1.08)}
.video-card .vc-play::after{content:"";border-left:18px solid var(--ink);border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:5px}
.video-card.loaded{cursor:default;background:#000}
.video-card.loaded .vc-meta,.video-card.loaded .vc-play{display:none}
.video-card iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-card.ig.loaded{aspect-ratio:auto;height:640px;background:var(--paper)}
.video-grid .vid{margin:0;display:flex;flex-direction:column}
.video-grid .vid figcaption{font-family:var(--mono);font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-top:12px;text-align:center}
.video-grid.three{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.video-grid.three{grid-template-columns:repeat(2,1fr)}}
/* youtube (16:9) */
.yt-embed{position:relative;aspect-ratio:16/9;border-radius:4px;overflow:hidden;border:1px solid var(--line);background:#000;margin-top:8px}
.yt-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.yt-cap{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:14px}
/* self-hosted mp4 */
.video-self{position:relative;aspect-ratio:16/9;border-radius:4px;overflow:hidden;border:1px solid var(--line);background:#000}
.video-self video{width:100%;height:100%;display:block;object-fit:contain;background:#000}
/* full designed graphic shown at natural size (no crop) */
.media-full{width:100%;height:auto;display:block;border-radius:3px;border:1px solid var(--line);background:var(--paper-2)}
.media-full + .media-full{margin-top:16px}
/* embedded tweet */
.tweet-embed{max-width:550px;margin:0 auto}
.tweet-embed .twitter-tweet{margin-left:auto !important;margin-right:auto !important}
.tweet-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;max-width:1140px;margin:0 auto}
.tweet-grid .twitter-tweet{margin-left:auto !important;margin-right:auto !important}
@media(max-width:760px){.tweet-grid{grid-template-columns:1fr}}
/* newsletter issue cards */
.issue-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:760px){.issue-grid{grid-template-columns:1fr}}
.issue{display:flex;flex-direction:column;gap:10px;border:1px solid var(--line);border-radius:10px;padding:18px 18px 24px;background:var(--paper);transition:transform .25s,box-shadow .25s,border-color .25s}
.issue-img{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:8px;margin-bottom:4px;background:var(--paper-2)}
.issue:hover{transform:translateY(-4px);box-shadow:0 22px 46px -28px rgba(19,17,15,.4);border-color:var(--accent)}
.issue .date{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.issue h3{font-family:var(--serif);font-weight:400;font-size:22px;line-height:1.2;letter-spacing:-.01em}
.issue p{color:var(--muted);font-size:14.5px;line-height:1.5}
.issue .read{margin-top:auto;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.issue:hover .read{color:var(--accent)}
/* substack subscribe embed */
.sub-embed{max-width:480px;margin:24px auto 0}
.sub-embed iframe{width:100%;height:320px;border:1px solid rgba(255,255,255,.25);border-radius:10px;background:#fff}

/* page intro header (interior pages) */
.page-head{padding:84px 0 56px;border-bottom:1px solid var(--line)}
.page-head .eyebrow{display:inline-block;margin-bottom:18px}
.page-head h1{max-width:14em}
.page-head p{color:var(--muted);font-size:19px;margin-top:20px;max-width:40em}
