/* ============================================================
   ui_kits/portfolio/portfolio.css
   All screen styles in one place so the JSX stays readable.
   Mobile-first reset + desktop breakpoints.
   ============================================================ */

/* ---- Reset / base ---- */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; background: var(--bg); overflow-x: hidden; }
body { cursor: none; }
@media (hover: none) { body { cursor: auto; } }
#app { min-height: 100vh; }
img { display: block; max-width: 100%; }
button { font-family: inherit; }

/* ---- Keyframes used across files ---- */
@keyframes shimmer { 0% { transform: translateX(-100%); } 100% { transform: translateX(100%); } }
@keyframes portraitDrift { 0%,100% { transform: translate(0,0); } 50% { transform: translate(-2px,-1px); } }

/* ---- Portal intro animation ---- */
@keyframes portalSpinCW  { from { transform: rotate(0deg);   } to { transform: rotate(360deg);  } }
@keyframes portalSpinCCW { from { transform: rotate(0deg);   } to { transform: rotate(-360deg); } }
@keyframes portalPulse   {
  0%, 100% { opacity: 0.35; transform: scale(1);    }
  50%      { opacity: 0.65; transform: scale(1.06); }
}
@keyframes splitUp {
  from { transform: translateY(110%); }
  to   { transform: translateY(0);    }
}

/* ============================================================
   HOVER affordances (cannot live in inline styles)
   ============================================================ */
.featured-tile:hover .feat-title { color: var(--accent); }
.featured-tile:hover img { transform: scale(1.03); }
.featured-tile:hover .arrow { transform: translateX(6px); color: var(--accent); }

.archive-row:hover { background: linear-gradient(90deg, rgba(58,107,255,0.06), transparent 50%); }
.archive-row:hover .feat-title { color: var(--accent); }
.archive-row:hover .arrow { transform: translateX(6px); color: var(--accent); }
.archive-row:hover .archive-row__num { color: var(--accent); }

.links-row:hover .links-row__v { color: var(--accent); }
.see-all:hover .arrow { transform: translateX(8px); color: var(--accent); }

article a, .post__body a { color: var(--accent); }

/* ============================================================
   HERO STATUS BAR
   ============================================================ */
.hero-status {
  display: flex; justify-content: space-between; gap: 16px;
  padding: 16px 48px; border-bottom: 1px solid var(--rule);
  font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase;
  flex-wrap: wrap;
}
.hero-status__item { display: flex; gap: 10px; min-width: 0; }
.hero-status__k { color: var(--fg-3); }
.hero-status__v { color: var(--fg-1); display: flex; align-items: center; gap: 6px; }
.hero-status__dot { width: 6px; height: 6px; background: var(--ok); border-radius: 50%; box-shadow: 0 0 0 3px rgba(125,224,166,0.18); }

/* ============================================================
   HERO
   ============================================================ */
.hero { padding: var(--s-8) 48px var(--s-7); position: relative; }
.hero__year {
  position: absolute; top: 32px; right: 48px;
  font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-3);
}
.hero__h1 {
  font-family: var(--ff-display); font-weight: 700;
  font-size: clamp(48px, 9vw, 156px);
  line-height: 0.92; letter-spacing: -0.05em;
  margin: 0; color: var(--fg-1);
  text-wrap: balance;
}
.hero__h1 .hero__line,
.hero__h1 .hero__accent {
  display: inline-block;
}
.hero__accent { color: var(--accent-hi); font-style: normal; }

.hero__meta {
  display: grid; grid-template-columns: repeat(3, max-content);
  gap: 64px; margin-top: 56px;
}
.hero__meta-col { display: flex; flex-direction: column; gap: 8px; }
.hero__meta-lbl { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-3); }
.hero__meta-val { font-family: var(--ff-mono); font-size: 14px; line-height: 1.5; color: var(--fg-1); }

/* ============================================================
   SECTIONS + FEATURED GRID
   ============================================================ */
.section { padding: var(--s-8) 48px 0; }
.section__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 48px; gap: 16px; flex-wrap: wrap; }
.section__lbl { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-2); }
.section__title { font-family: var(--ff-display); font-weight: 700; font-size: clamp(28px, 4vw, 56px); letter-spacing: -0.03em; line-height: 1; margin: 0; color: var(--fg-1); }

.featured-grid { display: grid; grid-template-columns: 1.2fr 1fr 0.9fr; gap: 32px; }

.featured-tile { display: flex; flex-direction: column; gap: 12px; text-decoration: none; color: inherit; padding-top: 20px; border-top: 1px solid var(--rule); }
.featured-tile__cover { aspect-ratio: 16/10; overflow: hidden; border: 1px solid var(--rule); margin-bottom: 6px; }
.featured-tile__cover img { width: 100%; height: 100%; object-fit: cover; transition: transform 500ms var(--ease-out); }
.featured-tile__meta { display: flex; gap: 14px; font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-2); flex-wrap: wrap; }
.featured-tile__cat { color: var(--fg-3); margin-left: auto; }
.feat-title { font-family: var(--ff-display); font-weight: 700; font-size: 28px; line-height: 1.05; letter-spacing: -0.02em; margin: 0; color: var(--fg-1); transition: color 220ms; }
.featured-tile__excerpt { font-family: var(--ff-mono); font-size: 13px; line-height: 1.55; color: var(--fg-2); margin: 0; max-width: 44ch; }
.featured-tile__cta { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-2); margin-top: 4px; }
.arrow { display: inline-block; transition: transform 220ms var(--ease-out), color 220ms; }

.all-row { display: flex; justify-content: space-between; align-items: center; padding-top: 32px; border-top: 1px solid var(--rule); gap: 16px; flex-wrap: wrap; }
.see-all { font-family: var(--ff-display); font-weight: 700; font-size: clamp(28px, 4vw, 48px); letter-spacing: -0.03em; color: var(--fg-1); text-decoration: none; line-height: 1; }

/* ============================================================
   PAGES — common
   ============================================================ */
.page { padding: var(--s-7) 48px var(--s-7); }
.page__h1 { font-family: var(--ff-display); font-weight: 700; font-size: clamp(56px, 8vw, 128px); line-height: 0.92; letter-spacing: -0.05em; margin: 0 0 28px; color: var(--fg-1); }
.page__h2 { font-family: var(--ff-display); font-weight: 700; font-size: clamp(28px, 4vw, 56px); letter-spacing: -0.03em; line-height: 1; margin: 0; color: var(--fg-1); }
.page__sub { font-family: var(--ff-mono); font-size: 14px; line-height: 1.55; color: var(--fg-2); margin: 0; }
.kicker, .sub-kicker { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-3); margin-bottom: 18px; }

/* ============================================================
   ARCHIVE
   ============================================================ */
.page-archive .page__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 48px; margin-bottom: 56px; flex-wrap: wrap; }
.page-archive .page__head-left { max-width: 60ch; }
.page-archive .page__head-right { display: flex; flex-direction: column; gap: 14px; align-items: flex-end; min-width: 240px; }
.search-wrap { display: flex; align-items: center; border-bottom: 1px solid var(--rule); padding: 8px 0; min-width: 240px; }
.search-slash { font-family: var(--ff-mono); color: var(--fg-3); margin-right: 10px; }
.search-input { flex: 1; padding: 0; border-bottom: 0; }
.archive-count { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-2); }

.archive-controls { display: flex; justify-content: space-between; gap: 48px; padding-bottom: 28px; margin-bottom: 16px; border-bottom: 1px solid var(--rule); flex-wrap: wrap; }
.archive-controls__block { display: flex; flex-direction: column; gap: 14px; flex: 1; min-width: 240px; }
.archive-controls__block--right { align-items: flex-end; flex: 0; min-width: 220px; }
.control-lbl { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-3); }
.tags-row { display: flex; flex-wrap: wrap; gap: 8px; }
.sort-select { min-width: 220px; padding: 6px 0; }

.archive-list { list-style: none; padding: 0; margin: 0; }
.archive-row {
  display: grid; grid-template-columns: 56px 110px 1fr 280px 32px;
  align-items: center; gap: 24px;
  padding: 20px 12px 20px 0; border-bottom: 1px solid var(--rule);
  text-decoration: none; color: inherit; font-family: var(--ff-mono);
  transition: background 220ms var(--ease-out);
}
.archive-row__num { font-size: 11px; color: var(--fg-3); letter-spacing: 0.08em; transition: color 220ms; }
.archive-row__date { font-size: 11px; color: var(--fg-2); letter-spacing: 0.06em; text-transform: uppercase; }
.archive-row__title { font-family: var(--ff-display); font-weight: 700; font-size: 24px; letter-spacing: -0.02em; line-height: 1.05; color: var(--fg-1); transition: color 220ms; }
.archive-row__tags { display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; }
.archive-row__tag { font-size: 10px; letter-spacing: 0.06em; color: var(--fg-2); text-transform: lowercase; }
.archive-row__arrow { font-family: var(--ff-display); font-size: 22px; color: var(--fg-3); text-align: right; }
.archive-empty { padding: 80px; text-align: center; font-family: var(--ff-mono); font-size: 14px; color: var(--fg-2); border: 1px solid var(--rule); }

/* Archived work vault */
.archive-vault { margin-top: 64px; border-top: 1px solid var(--rule); }
.archive-vault__toggle {
  display: flex; align-items: center; gap: 20px; width: 100%;
  padding: 24px 0; background: none; border: none; cursor: pointer;
  text-align: left; transition: opacity 160ms;
}
.archive-vault__toggle:hover { opacity: 0.7; }
.archive-vault__count { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--fg-2); text-transform: uppercase; }
.archive-vault__chevron { font-family: var(--ff-mono); font-size: 14px; color: var(--fg-3); margin-left: auto; }
.archive-list--vault { opacity: 0.75; }
.archive-row--vault .feat-title { font-size: 20px; }

/* ============================================================
   POST
   ============================================================ */
.page-post { max-width: 1100px; margin: 0 auto; }
.post__head { margin-bottom: 48px; }
.post__kicker { display: flex; gap: 18px; flex-wrap: wrap; font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-2); margin-bottom: 28px; }
.post__title { font-family: var(--ff-display); font-weight: 700; font-size: clamp(40px, 7vw, 96px); line-height: 0.95; letter-spacing: -0.04em; margin: 0; color: var(--fg-1); max-width: 20ch; }
.post__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 28px; }
.post__cover { aspect-ratio: 16/9; overflow: hidden; border: 1px solid var(--rule); margin-bottom: 56px; }
.post__cover img { width: 100%; height: 100%; object-fit: cover; }
.post__body { font-family: var(--ff-mono); font-size: 16px; line-height: 1.7; color: var(--fg-1); max-width: 62ch; }
.post__lead { font-size: 19px; line-height: 1.55; color: var(--fg-1); margin-bottom: 28px; font-weight: 400; }
.post__h2 { font-family: var(--ff-display); font-weight: 700; font-size: 32px; letter-spacing: -0.02em; margin: 40px 0 16px; color: var(--fg-1); }
.post__ul { list-style: none; padding: 0; margin: 0; font-family: var(--ff-mono); font-size: 14px; line-height: 1.8; color: var(--fg-1); }
.post__k { display: inline-block; width: 120px; color: var(--fg-3); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; margin-right: 12px; }
/* Markdown-rendered body */
.post__md { margin-top: 8px; }
.post__md p { margin: 0 0 20px; }
.post__md h2 { font-family: var(--ff-display); font-weight: 700; font-size: 28px; letter-spacing: -0.02em; line-height: 1.1; color: var(--fg-1); margin: 40px 0 16px; }
.post__md h3 { font-family: var(--ff-display); font-weight: 700; font-size: 20px; letter-spacing: -0.01em; line-height: 1.1; color: var(--fg-1); margin: 28px 0 12px; }
.post__md ul, .post__md ol { padding-left: 22px; margin: 0 0 20px; }
.post__md li { margin-bottom: 6px; line-height: 1.65; }
.post__md hr { border: none; border-top: 1px solid var(--rule); margin: 36px 0; }
.post__md img { max-width: 100%; border: 1px solid var(--rule); margin: 20px 0; }
.post__md iframe { max-width: 100%; display: block; margin: 24px 0; border: 1px solid var(--rule); }
.post__md blockquote { border-left: 3px solid var(--accent); padding-left: 16px; margin: 0 0 20px; color: var(--fg-2); }
.post__md code { background: rgba(58,107,255,0.1); padding: 2px 5px; border-radius: 3px; font-size: 0.9em; }
.post__md pre { background: rgba(255,255,255,0.04); border: 1px solid var(--rule); padding: 16px; overflow-x: auto; margin: 0 0 20px; border-radius: 2px; }
.post__md pre code { background: none; padding: 0; }

.post__nav { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; margin-top: 80px; padding-top: 32px; border-top: 1px solid var(--rule); }
.post__nav-link { display: flex; flex-direction: column; gap: 10px; text-decoration: none; color: inherit; transition: transform 220ms var(--ease-out); }
.post__nav-link:hover { transform: translateY(-4px); }
.post__nav-link--right { text-align: right; }
.post__nav-lbl { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-2); }
.post__nav-title { font-family: var(--ff-display); font-weight: 700; font-size: 22px; letter-spacing: -0.02em; line-height: 1.1; color: var(--fg-1); transition: color 220ms; }
.post__nav-link:hover .post__nav-title { color: var(--accent); }

/* ============================================================
   ABOUT
   ============================================================ */
.page-about { padding: var(--s-7) 48px var(--s-7); }
.about__head { margin-bottom: 72px; max-width: 70ch; }
.about__lead { font-family: var(--ff-display); font-weight: 500; font-size: clamp(22px, 2.4vw, 30px); line-height: 1.25; letter-spacing: -0.015em; color: var(--fg-1); margin: 0; max-width: 30ch; }
.about__grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 64px; margin-bottom: 96px; padding-top: 48px; border-top: 1px solid var(--rule); }
.about__photo-wrap { display: flex; flex-direction: column; gap: 12px; }
.about__photo-cap { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-3); }
.about__bio { display: flex; flex-direction: column; gap: 22px; }
.about__para { font-family: var(--ff-mono); font-size: 16px; line-height: 1.65; color: var(--fg-1); margin: 0; max-width: 62ch; }

.about__stack, .about__links, .about__contact { margin-bottom: 96px; }
.about__sub-head { margin-bottom: 32px; padding-top: 32px; border-top: 1px solid var(--rule); }
.stack-list, .links-list { list-style: none; padding: 0; margin: 0; }
.stack-row, .links-row { display: grid; grid-template-columns: 260px 1fr; gap: 24px; padding: 18px 0; border-top: 1px solid var(--rule); }
.stack-row__k, .links-row__k { font-family: var(--ff-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-2); }
.stack-row__v, .links-row__v { font-family: var(--ff-mono); font-size: 15px; color: var(--fg-1); text-decoration: none; transition: color 220ms; }

.about__contact { padding-top: 48px; border-top: 1px solid var(--rule); }
.about__email { display: inline-block; font-family: var(--ff-display); font-weight: 700; font-size: clamp(28px, 5vw, 72px); letter-spacing: -0.03em; color: var(--fg-1); text-decoration: none; transition: color 220ms; word-break: break-all; }
.about__email:hover { color: var(--accent); }

/* ============================================================
   PORTRAIT FRAME — interactive cell behind the photo
   ============================================================ */
.portrait {
  position: relative; aspect-ratio: 3/4;
  border: 1px solid var(--rule); overflow: hidden;
  background: #060608;
  isolation: isolate;
}
.portrait__img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  z-index: 2;
}
.portrait__grid {
  position: absolute; inset: 0; z-index: 1;
  display: grid;
  grid-template-columns: repeat(14, 1fr);
  grid-template-rows: repeat(18, 1fr);
  --mx: 0.5; --my: 0.5;
}
.portrait__cell {
  display: block; width: 100%; height: 100%;
  background: rgba(58,107,255,0.0);
  transition: background 360ms var(--ease-out);
}
.portrait__cell.is-on {
  background: rgba(58,107,255,0.18);
}
/* cells near the cursor get a flash of accent-hi */
.portrait__cell {
  --dx: calc(var(--cx) - var(--mx));
  --dy: calc(var(--cy) - var(--my));
}
.portrait__blob {
  position: absolute; inset: -10%; z-index: 3;
  pointer-events: none;
  mix-blend-mode: screen;
  filter: blur(20px);
  transition: background 240ms var(--ease-out);
}
.portrait__scan {
  position: absolute; inset: 0; z-index: 4;
  pointer-events: none;
  background:
    repeating-linear-gradient(0deg, rgba(0,0,0,0.18) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(90deg, rgba(58,107,255,0.06) 0 1px, transparent 1px 4px);
  mix-blend-mode: multiply;
  opacity: 0.55;
}
.portrait__corner {
  position: absolute; z-index: 5;
  font-family: var(--ff-mono); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--fg-1); background: rgba(10,10,11,0.7); backdrop-filter: blur(6px);
  padding: 4px 6px; border: 1px solid var(--rule);
}
.portrait__corner--tl { top: 8px; left: 8px; }
.portrait__corner--tr { top: 8px; right: 8px; color: var(--accent-hi); }
.portrait__corner--bl { bottom: 8px; left: 8px; color: var(--accent); }
.portrait__corner--br { bottom: 8px; right: 8px; }

/* ============================================================
   404
   ============================================================ */
.page-404 {
  padding: var(--s-9) 48px var(--s-8);
  display: flex; flex-direction: column; align-items: flex-start; gap: 32px;
  min-height: 70vh;
}
.nf__code {
  font-family: var(--ff-display); font-weight: 700;
  font-size: clamp(140px, 28vw, 380px);
  letter-spacing: -0.06em; line-height: 0.8;
  color: var(--accent-hi); margin: 0;
}
.nf__lines { display: flex; flex-direction: column; gap: 8px; }
.nf__line1 { font-family: var(--ff-display); font-weight: 700; font-size: clamp(24px, 3.4vw, 40px); letter-spacing: -0.02em; color: var(--fg-1); line-height: 1.1; }
.nf__line2 { font-family: var(--ff-mono); font-size: clamp(13px, 1.4vw, 15px); color: var(--fg-2); max-width: 56ch; line-height: 1.55; }
.nf__back { margin-top: 16px; }

/* ============================================================
   FOOTER
   ============================================================ */
footer { padding: 28px 48px; border-top: 1px solid var(--rule); font-family: var(--ff-mono); margin-top: var(--s-8); }

/* ============================================================
   RESPONSIVE — mobile (<= 760px)
   ============================================================ */
@media (max-width: 760px) {
  body { cursor: auto; }

  /* Nav — collapse role + status, keep links scrollable */
  nav[class] { padding: 12px 18px !important; height: auto !important; flex-wrap: wrap; gap: 12px; }
  /* Hide the role caption + status; keep monogram + lang + links */

  .hero-status {
    padding: 12px 18px; gap: 8px 14px; font-size: 10px;
  }
  .hero-status__item { gap: 6px; flex-shrink: 0; }

  .hero { padding: var(--s-6) 18px var(--s-5); }
  .hero__year { top: 14px; right: 18px; font-size: 10px; }
  .hero__meta { grid-template-columns: 1fr 1fr; gap: 24px 28px; margin-top: 36px; }

  .section { padding: var(--s-6) 18px 0; }
  .section__head { margin-bottom: 28px; }
  .featured-grid { grid-template-columns: 1fr; gap: 28px; }

  .all-row { padding-top: 24px; }

  .page { padding: var(--s-6) 18px var(--s-6); }
  .page-archive .page__head { gap: 24px; margin-bottom: 32px; flex-direction: column; align-items: flex-start; }
  .page-archive .page__head-right { width: 100%; flex-direction: row; justify-content: space-between; align-items: flex-end; }
  .page-archive .page__head-right .search-wrap { min-width: 0; flex: 1; }

  .archive-controls { flex-direction: column; gap: 20px; padding-bottom: 18px; }
  .archive-controls__block--right { align-items: flex-start; }
  .sort-select { min-width: 0; width: 100%; }

  .archive-row {
    grid-template-columns: 44px 1fr 22px;
    grid-template-rows: auto auto auto;
    gap: 6px 12px;
    padding: 16px 0;
  }
  .archive-row__num { grid-column: 1; grid-row: 1; }
  .archive-row__date { grid-column: 2; grid-row: 1; text-align: left; }
  .archive-row__title { grid-column: 1 / span 3; grid-row: 2; font-size: 20px; }
  .archive-row__tags { grid-column: 1 / span 3; grid-row: 3; justify-content: flex-start; }
  .archive-row__arrow { grid-column: 3; grid-row: 1; }

  /* Post */
  .page-post .post__kicker { font-size: 10px; gap: 10px; }
  .post__body { font-size: 15px; }
  .post__nav { grid-template-columns: 1fr; gap: 32px; margin-top: 56px; padding-top: 24px; }
  .post__nav-link--right { text-align: left; }

  /* About */
  .about__head { margin-bottom: 40px; }
  .about__grid { grid-template-columns: 1fr; gap: 32px; margin-bottom: 56px; padding-top: 32px; }
  .stack-row, .links-row { grid-template-columns: 1fr; gap: 6px; padding: 14px 0; }
  .about__stack, .about__links, .about__contact { margin-bottom: 56px; }
  .about__sub-head { margin-bottom: 20px; padding-top: 24px; }

  /* 404 */
  .page-404 { padding: var(--s-7) 18px var(--s-6); gap: 24px; min-height: 60vh; align-items: center; text-align: center; }
  .nf__code { width: 100%; text-align: center; line-height: 0.85; }
  .nf__lines { align-items: center; }
  .nf__line2 { padding: 0 8px; }
  .nf__back { align-self: center; }

  /* Footer */
  footer { padding: 20px 18px; }
  footer > div { font-size: 10px !important; flex-direction: column; gap: 6px; align-items: flex-start; }

  /* Marquee — faster + smaller */
  .marquee__track { animation-duration: 24s; }
  .marquee__track span:not([style*='var(--fg-3)']) { font-size: 22px !important; }
}

/* ---- Tablet (760 – 1100) ---- */
@media (min-width: 761px) and (max-width: 1100px) {
  .hero { padding: var(--s-7) 28px var(--s-6); }
  .hero__year { right: 28px; }
  .section { padding: var(--s-7) 28px 0; }
  .page { padding: var(--s-7) 28px var(--s-7); }
  .page-about { padding: var(--s-7) 28px var(--s-7); }
  .page-404 { padding: var(--s-8) 28px var(--s-7); }
  .featured-grid { grid-template-columns: 1fr 1fr; }
  .featured-grid > *:nth-child(3) { grid-column: 1 / span 2; }
  .archive-row { grid-template-columns: 48px 90px 1fr 200px 24px; gap: 16px; }
  .about__grid { grid-template-columns: 1fr; gap: 32px; }
  .about__photo-wrap { max-width: 380px; }
}

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion: reduce) {
  .portrait__img { animation: none; }
}
