/* ============================================================
   Chris Myers — personal site
   Editorial executive: ink on warm ivory, literary serif +
   monospace labels, restrained oxblood accent.
   ============================================================ */

/* Fonts (Newsreader + JetBrains Mono) load via <link> in index.html for
   faster, non-render-blocking delivery. */

:root{
  --ivory:      #f4efe5;
  --ivory-deep: #ece5d7;
  --paper:      #faf7f0;
  --ink:        #211d18;
  --ink-2:      #4c453b;
  --ink-3:      #8a8170;
  --line:       rgba(33,29,24,.14);
  --line-soft:  rgba(33,29,24,.08);
  --ox:         #863521;          /* oxblood accent */
  --ox-deep:    #6c2817;

  --serif: "Newsreader", Georgia, "Times New Roman", serif;
  --mono:  "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  --maxw: 1240px;
  --gut: clamp(22px, 5vw, 64px);

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--ivory);
  color:var(--ink);
  font-family:var(--serif);
  font-size:19px;
  line-height:1.62;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"kern" 1, "liga" 1, "calt" 1;
}

::selection{ background:rgba(134,53,33,.18); }

a{ color:inherit; text-decoration:none; }

:focus-visible{ outline:2px solid var(--ox); outline-offset:3px; border-radius:2px; }

/* skip link — visible only on keyboard focus */
.skip-link{
  position:fixed; top:-60px; left:var(--gut); z-index:300;
  font-family:var(--mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase;
  background:var(--ink); color:var(--ivory); padding:10px 16px; border-radius:4px;
  transition:top .2s var(--ease);
}
.skip-link:focus{ top:12px; }

/* anchor jumps clear the fixed nav */
section[id], header[id]{ scroll-margin-top:88px; }

/* ---- subtle paper grain ---- */
body::before{
  content:"";
  position:fixed; inset:0; z-index:0; pointer-events:none;
  opacity:.5; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}

/* ---- reading progress ---- */
.progress{
  position:fixed; top:0; left:0; height:2px; width:0%;
  background:var(--ox); z-index:200; transition:width .1s linear;
}

/* ============================================================
   Layout helpers
   ============================================================ */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
.section{ position:relative; z-index:1; padding-block:clamp(72px,11vh,140px); }
.rule{ height:1px; background:var(--line); border:0; margin:0; }

.eyebrow{
  font-family:var(--mono); font-size:12px; font-weight:500;
  letter-spacing:.22em; text-transform:uppercase; color:var(--ox);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--ox); opacity:.7; }
.eyebrow.no-tick::before{ display:none; }

.kicker{
  font-family:var(--mono); font-size:11.5px; font-weight:500;
  letter-spacing:.2em; text-transform:uppercase; color:var(--ink-3);
}

h1,h2,h3{ font-weight:400; margin:0; letter-spacing:-.012em; line-height:1.04; text-wrap:balance; }
p{ text-wrap:pretty; }

/* ============================================================
   Nav
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gut);
  transition:background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
}
.nav.scrolled{
  background:rgba(244,239,229,.86);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  box-shadow:0 1px 0 var(--line-soft);
  padding-block:13px;
}
.brand{ font-size:20px; letter-spacing:-.02em; display:flex; align-items:baseline; gap:.04ch; }
.brand b{ font-weight:600; }
.brand .dot{ color:var(--ox); font-weight:600; }
.brand .amp{ color:var(--ox); font-style:italic; }
.nav-links{ display:flex; gap:30px; align-items:center; }
.nav-links a{
  font-family:var(--mono); font-size:12px; letter-spacing:.06em;
  color:var(--ink-2); text-transform:uppercase; position:relative; padding-block:4px;
  transition:color .25s var(--ease);
}
.nav-links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:0; height:1px;
  background:var(--ox); transition:right .3s var(--ease);
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after, .nav-links a.active::after{ right:0; }
.nav-links a.active{ color:var(--ink); }
.nav-cta{
  font-family:var(--mono); font-size:12px; letter-spacing:.05em; text-transform:uppercase;
  border:1px solid var(--line); border-radius:999px; padding:8px 16px !important;
  color:var(--ink) !important; transition:background .25s var(--ease), border-color .25s var(--ease);
}
.nav-cta::after{ display:none; }
.nav-cta:hover{ background:var(--ink); color:var(--ivory) !important; border-color:var(--ink); }
.nav-toggle{ display:none; }

/* ============================================================
   Hero
   ============================================================ */
.hero{ padding-top:clamp(120px,18vh,190px); padding-bottom:clamp(40px,6vh,70px); }
.hero-grid{ display:grid; grid-template-columns:minmax(0,1.55fr) minmax(0,1fr); gap:clamp(32px,5vw,72px); align-items:end; }

.hero h1{
  font-size:clamp(40px,7vw,86px);
  line-height:1.0; font-weight:400; letter-spacing:-.022em;
  margin-top:26px; max-width:14ch;
}
.hero h1 em{ font-style:italic; color:var(--ox); }
.hero-sub{
  margin-top:30px; max-width:46ch; font-size:clamp(18px,1.5vw,21px);
  color:var(--ink-2); line-height:1.6;
}
.hero-roles{
  margin-top:30px; display:flex; flex-wrap:wrap; gap:10px 12px; align-items:center;
}
.role-chip{
  font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink-2); border:1px solid var(--line); border-radius:999px; padding:7px 14px;
}

/* portrait */
.portrait{
  position:relative; aspect-ratio:4/5; border:1px solid var(--line);
  margin:0; background:var(--ivory-deep); overflow:hidden;
}
.portrait img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:50% 18%;
  filter:saturate(0) contrast(1.02);
  mix-blend-mode:multiply;
}
.portrait .corner{
  position:absolute; top:13px; right:14px; font-family:var(--mono); font-size:11px;
  letter-spacing:.16em; color:var(--ox); z-index:2;
}
.portrait .plate{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.13em; text-transform:uppercase;
  color:var(--ink-2); text-align:center; padding:14px 10px 11px;
  background:linear-gradient(to top, rgba(244,239,229,.96) 30%, rgba(244,239,229,0));
}

/* ============================================================
   Stats strip
   ============================================================ */
.stats{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:clamp(28px,4vw,46px) 0; border-left:1px solid var(--line-soft); padding-left:clamp(18px,2.5vw,34px); }
.stat:first-child{ border-left:0; padding-left:0; }
.stat .num{ font-size:clamp(38px,4.6vw,60px); line-height:1; letter-spacing:-.02em; font-weight:400; }
.stat .num .u{ color:var(--ox); }
.stat .lbl{ margin-top:12px; font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); line-height:1.5; }

/* ============================================================
   Section header
   ============================================================ */
.sec-head{ display:grid; grid-template-columns:minmax(0,.42fr) minmax(0,1fr); gap:clamp(20px,4vw,56px); align-items:start; margin-bottom:clamp(40px,6vw,72px); }
.sec-head h2{ font-size:clamp(30px,4vw,50px); line-height:1.04; max-width:18ch; }
.sec-head .lead{ font-size:clamp(19px,1.6vw,23px); color:var(--ink-2); max-width:42ch; }
.sec-num{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; color:var(--ink-3); display:inline-flex; align-items:center; gap:.7em; }
.sec-num::before{ content:""; width:22px; height:1px; background:var(--ink-3); opacity:.55; }

/* through-line prose */
.through{ max-width:60ch; margin-left:auto; }
.through p{ font-size:clamp(20px,1.8vw,25px); line-height:1.55; color:var(--ink); margin:0 0 1.1em; }
.through p .hl{ color:var(--ox); font-style:italic; }
.through .sign{ margin-top:34px; font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }

/* ============================================================
   Ventures list
   ============================================================ */
.ventures{ border-top:1px solid var(--line); }
.venture{
  display:grid; grid-template-columns:48px minmax(0,.34fr) minmax(0,1fr) auto;
  gap:clamp(14px,3vw,44px); align-items:baseline;
  padding:clamp(30px,4vw,46px) 0; border-bottom:1px solid var(--line);
  position:relative; transition:padding-left .4s var(--ease);
}
.venture::before{
  content:""; position:absolute; left:-100vw; right:100%; top:0; bottom:0;
  background:var(--ivory-deep); z-index:-1; transition:right .45s var(--ease), left .45s var(--ease);
}
.venture:hover{ padding-left:14px; }
.venture:hover::before{ left:-24px; right:-24px; }
.v-idx{ font-family:var(--mono); font-size:12px; color:var(--ink-3); letter-spacing:.05em; }
.v-meta{ display:flex; flex-direction:column; gap:7px; }
.v-role{ font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ox); }
.v-domain{ font-family:var(--mono); font-size:12px; color:var(--ink-3); letter-spacing:.02em; }
.v-main h3{ font-size:clamp(26px,3vw,40px); line-height:1.06; transition:color .25s var(--ease); }
.v-main p{ margin:12px 0 0; color:var(--ink-2); font-size:18px; max-width:52ch; line-height:1.55; }
.venture:hover .v-main h3{ color:var(--ox); }
.v-arrow{
  font-family:var(--mono); font-size:22px; color:var(--ink-3); align-self:center;
  transition:transform .4s var(--ease), color .25s var(--ease);
}
.venture:hover .v-arrow{ transform:translate(6px,-6px); color:var(--ox); }

/* ============================================================
   Books
   ============================================================ */
.books{ background:var(--paper); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.book-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(26px,3.5vw,52px); }
.book{ display:flex; flex-direction:column; }
.cover{
  aspect-ratio:2/3; position:relative; overflow:hidden; display:block;
  background:var(--ivory-deep); border:1px solid var(--line);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
  box-shadow:-6px 8px 22px rgba(33,29,24,.12);
}
.cover img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.cover::after{ content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(105deg, rgba(255,255,255,.22) 0%, rgba(255,255,255,0) 18%, rgba(255,255,255,0) 100%); }
.book:hover .cover{ transform:translateY(-8px) rotate(-.6deg); box-shadow:-16px 22px 46px rgba(33,29,24,.22); }
.book-meta{ margin-top:22px; }
.book-meta .b-k{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ox); margin-bottom:9px; }
.book-meta .b-t{ font-size:21px; line-height:1.15; }
.book-meta .b-d{ margin-top:8px; color:var(--ink-2); font-size:16px; line-height:1.5; }
.book-link{
  margin-top:14px; display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:12px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink);
}
.book-link .ar{ transition:transform .3s var(--ease); color:var(--ox); }
.book-link:hover .ar{ transform:translateX(5px); }
.book-link span.u{ background-image:linear-gradient(var(--ox),var(--ox)); background-size:0% 1px; background-repeat:no-repeat; background-position:0 100%; transition:background-size .3s var(--ease); padding-bottom:2px; }
.book-link:hover span.u{ background-size:100% 1px; }

/* ============================================================
   Writing
   ============================================================ */
.writing-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,30px); margin-bottom:clamp(36px,5vw,60px); }
.write-card{
  border:1px solid var(--line); padding:clamp(26px,3vw,38px); position:relative;
  display:flex; flex-direction:column; min-height:230px; background:transparent;
  transition:background .35s var(--ease), border-color .35s var(--ease);
}
.write-card:hover{ background:var(--paper); border-color:var(--ink-3); }
.write-card .wc-k{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ox); }
.write-card h3{ font-size:clamp(23px,2.1vw,29px); margin-top:16px; line-height:1.08; }
.write-card p{ margin:12px 0 0; color:var(--ink-2); font-size:17px; line-height:1.55; }
.write-card .wc-go{ margin-top:auto; padding-top:22px; font-family:var(--mono); font-size:12px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3); display:flex; align-items:center; gap:8px; }
.write-card:hover .wc-go{ color:var(--ox); }
.write-card .wc-go .ar{ transition:transform .3s var(--ease); }
.write-card:hover .wc-go .ar{ transform:translateX(5px); }

.previously{ border-top:1px solid var(--line); padding-top:clamp(28px,3.5vw,40px); display:grid; grid-template-columns:minmax(0,.42fr) minmax(0,1fr); gap:clamp(20px,4vw,56px); }
.previously .p-h{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }
.previously p{ margin:0; font-size:clamp(19px,1.6vw,23px); line-height:1.5; color:var(--ink); max-width:48ch; }
.previously p b{ font-weight:500; }
.previously p .ox{ color:var(--ox); }

/* ============================================================
   Long bio
   ============================================================ */
.bio{ background:var(--ink); color:var(--ivory); }
.bio .eyebrow{ color:#d98a72; }
.bio .eyebrow::before{ background:#d98a72; }
.bio-grid{ display:grid; grid-template-columns:minmax(0,.42fr) minmax(0,1fr); gap:clamp(24px,5vw,72px); }
.bio h2{ font-size:clamp(28px,3.4vw,44px); color:var(--ivory); max-width:14ch; }
.bio-body{ max-width:62ch; }
.bio-body p{ font-size:clamp(18px,1.5vw,21px); line-height:1.7; color:#e7ddca; margin:0 0 1.3em; }
.bio-body p:first-child::first-letter{
  font-size:4.2em; line-height:.78; float:left; padding:6px 12px 0 0; color:#d98a72; font-weight:500;
}
.pullquote{
  margin:clamp(34px,5vw,56px) 0; padding:0 0 0 28px; border-left:2px solid #d98a72;
  font-size:clamp(24px,2.8vw,36px); line-height:1.22; color:var(--ivory); font-style:italic; font-weight:300;
  max-width:18ch;
}

/* ============================================================
   Contact
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,.85fr); gap:clamp(30px,5vw,80px); align-items:start; }
.contact h2{ font-size:clamp(40px,6vw,86px); line-height:.98; letter-spacing:-.022em; }
.contact h2 em{ font-style:italic; color:var(--ox); }
.contact .c-sub{ margin-top:24px; font-size:clamp(19px,1.6vw,23px); color:var(--ink-2); max-width:40ch; }
.contact-actions{ display:flex; flex-direction:column; border-top:1px solid var(--line); }
.c-action{
  display:flex; flex-direction:column; gap:9px;
  padding:22px 0; border-bottom:1px solid var(--line);
  transition:padding-left .35s var(--ease);
}
.c-action:hover{ padding-left:14px; }
.c-action .ca-k{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.c-action .ca-row{ display:flex; align-items:baseline; gap:18px; }
.c-action .ca-t{ flex:1 1 auto; font-size:clamp(21px,2.2vw,27px); line-height:1.1; transition:color .25s var(--ease); }
.c-action:hover .ca-t{ color:var(--ox); }
.c-action .ar{ font-family:var(--mono); font-size:18px; color:var(--ink-3); flex:none; transition:transform .35s var(--ease), color .25s var(--ease); }
.c-action:hover .ar{ transform:translate(5px,-3px); color:var(--ox); }

/* ============================================================
   Footer
   ============================================================ */
.foot{ background:var(--ivory-deep); border-top:1px solid var(--line); }
.foot-top{ display:flex; justify-content:space-between; align-items:center; gap:22px 40px; flex-wrap:wrap; padding-top:54px; padding-bottom:30px; }
.foot .f-brand{ font-size:26px; letter-spacing:-.02em; }
.foot .f-brand .dot{ color:var(--ox); }
.foot .f-links{ display:flex; flex-wrap:wrap; gap:14px 26px; justify-content:flex-end; max-width:660px; }
.foot .f-links a{ font-family:var(--mono); font-size:12px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-2); transition:color .2s var(--ease); }
.foot .f-links a:hover{ color:var(--ox); }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:12px 30px; flex-wrap:wrap; border-top:1px solid var(--line); padding-top:24px; padding-bottom:40px; }
.foot .f-roles{ font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.foot .f-copy{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; color:var(--ink-3); }

/* ============================================================
   Reveal animation
   ============================================================ */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:960px){
  .hero-grid{ grid-template-columns:minmax(0,1.3fr) minmax(0,.9fr); gap:clamp(22px,4vw,48px); }
  .stats-grid{ grid-template-columns:repeat(2,1fr); }
  .stat:nth-child(3){ border-left:0; padding-left:0; }
  .stat{ padding-left:clamp(14px,3vw,24px); }
  .stat:nth-child(3),.stat:nth-child(4){ border-top:1px solid var(--line-soft); }
  .sec-head{ grid-template-columns:1fr; gap:16px; }
  .through{ margin-left:0; }
  .venture{ grid-template-columns:30px 1fr; grid-template-areas:"idx meta" "main main" "arrow arrow"; gap:10px 14px; }
  .v-idx{ grid-area:idx; } .v-meta{ grid-area:meta; flex-direction:row; gap:14px; align-items:baseline; }
  .v-main{ grid-area:main; } .v-arrow{ grid-area:arrow; align-self:start; }
  .book-grid{ grid-template-columns:1fr 1fr; }
  .writing-grid{ grid-template-columns:1fr; }
  .previously{ grid-template-columns:1fr; gap:14px; }
  .bio-grid{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
}
@media (max-width:620px){
  body{ font-size:18px; }
  .nav-links{ display:none; }
  .nav-toggle{ display:flex; }
  .hero-grid{ grid-template-columns:1fr; }
  .portrait{ max-width:340px; aspect-ratio:1/1; }
  .stats-grid{ grid-template-columns:1fr 1fr; }
  .book-grid{ grid-template-columns:1fr; max-width:300px; }
  .foot-top, .foot-bottom{ flex-direction:column; align-items:flex-start; }
  .foot .f-links{ justify-content:flex-start; }
}
