/* About */
.about-grid {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 64px;
  align-items: start;
}
@media (max-width: 880px) { .about-grid { grid-template-columns: 1fr; gap: 40px; } }

.about-portrait { position: sticky; top: 100px; display: flex; flex-direction: column; gap: 18px; }
@media (max-width: 880px) { .about-portrait { position: relative; top: 0; } }
.portrait-frame { position: relative; aspect-ratio: 4/5; overflow: hidden; border: 1px solid var(--ink); }
.portrait-frame img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.05); transition: filter 0.5s var(--bezier), transform 0.6s var(--bezier); }
.portrait-frame:hover img { filter: grayscale(0) contrast(1); transform: scale(1.02); }
.portrait-tag {
  position: absolute; left: 10px; top: 10px;
  background: var(--cream); padding: 4px 8px;
  font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase;
}
.portrait-corners i { position: absolute; width: 14px; height: 14px; border: 1px solid var(--cream); }
.portrait-corners i:nth-child(1) { top: 8px; left: 8px; border-right: 0; border-bottom: 0; }
.portrait-corners i:nth-child(2) { top: 8px; right: 8px; border-left: 0; border-bottom: 0; }
.portrait-corners i:nth-child(3) { bottom: 8px; left: 8px; border-right: 0; border-top: 0; }
.portrait-corners i:nth-child(4) { bottom: 8px; right: 8px; border-left: 0; border-top: 0; }

.portrait-meta { font-size: 11px; display: flex; flex-direction: column; gap: 4px; }
.kv-row {
  display: grid; grid-template-columns: auto 1fr auto; gap: 8px;
  align-items: baseline; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--ink-soft);
}
.kv-row > :first-child { color: var(--ink-mute); }
.kv-row > :last-child { color: var(--ink); }
.kv-dots { border-bottom: 1px dotted var(--hairline); height: 1px; transform: translateY(-3px); }

.about-copy { display: flex; flex-direction: column; gap: 36px; }
.about-lead {
  font-size: clamp(20px, 2.2vw, 28px);
  line-height: 1.4; letter-spacing: -0.015em; max-width: 28ch; font-weight: 400;
  margin: 0;
}
.about-lead strong { font-weight: 600; }
.about-pillars { display: grid; grid-template-columns: 1fr; gap: 0; }
.pillar { display: grid; grid-template-columns: 60px 1fr; gap: 18px; padding: 22px 0; border-top: 1px solid var(--hairline); }
.pillar:last-child { border-bottom: 1px solid var(--hairline); }
.pillar-num { font-size: 11px; letter-spacing: 0.06em; color: var(--ink-mute); }
.pillar h4 { margin: 0; font-size: 18px; font-weight: 600; letter-spacing: -0.01em; }
.pillar p { margin: 4px 0 0; color: var(--ink-soft); font-size: 15px; line-height: 1.5; max-width: 50ch; }

.about-quote {
  position: relative; padding: 24px 0 0 60px;
  border-top: 1px solid var(--ink);
}
.quote-mark { position: absolute; left: 0; top: 4px; font-size: 90px; line-height: 0.7; }
.about-quote blockquote {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(22px, 2.6vw, 32px);
  line-height: 1.3; letter-spacing: -0.01em;
}

/* Skills */
.skills-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
}
@media (max-width: 960px) { .skills-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .skills-grid { grid-template-columns: 1fr; } }

.skill-col-head {
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 10px; align-items: baseline;
  font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase;
  padding-bottom: 10px; border-bottom: 1px solid var(--ink); margin-bottom: 8px;
}
.skill-col-head .skill-count { color: var(--ink-mute); }

.skill-list { display: flex; flex-direction: column; }
.skill-row { padding: 10px 0; border-bottom: 1px solid var(--hairline); transition: padding 0.2s var(--bezier); }
.skill-row:hover { padding-left: 6px; }
.skill-line { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.skill-name { font-size: 14px; font-weight: 500; }
.skill-y { font-size: 10px; color: var(--ink-mute); letter-spacing: 0.06em; }
.skill-bar { position: relative; height: 6px; background: var(--cream-3); }
.skill-fill {
  height: 100%; background: var(--ink);
  transform-origin: left; transform: scaleX(0);
  animation: fillIn 1.1s var(--bezier) forwards;
}
.reveal.in .skill-fill { animation-play-state: running; }
@keyframes fillIn { to { transform: scaleX(1); } from { transform: scaleX(0); } }
.skill-fill { transform: scaleX(1); transition: width 0.6s var(--bezier); }
.skill-ticks { position: absolute; inset: 0; display: flex; }
.skill-ticks i { flex: 1; border-right: 1px solid rgba(237,230,210,0.5); }
.skill-ticks i:last-child { border-right: 0; }

.skills-foot {
  display: flex; flex-wrap: wrap; gap: 14px;
  margin-top: 32px; padding-top: 18px; border-top: 1px solid var(--hairline);
  font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-soft);
}
