@font-face { font-family: "JetBrains Mono"; font-weight: 400; font-display: swap; src: url("/assets/fonts/jetbrains-mono-400.woff2") format("woff2"); }
@font-face { font-family: "JetBrains Mono"; font-weight: 500; font-display: swap; src: url("/assets/fonts/jetbrains-mono-500.woff2") format("woff2"); }
@font-face { font-family: "JetBrains Mono"; font-weight: 700; font-display: swap; src: url("/assets/fonts/jetbrains-mono-700.woff2") format("woff2"); }

:root {
  --bg: #16130E;
  --text: #E8E2D6;
  --amber: #E8A33D;
  --comment: #8A8272;
  --hairline: #2A2620;
  --measure: 68ch;
  color-scheme: dark;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 15px;
  line-height: 1.7;
  letter-spacing: -0.01em;
  padding: clamp(1.5rem, 5vw, 4rem) clamp(1.2rem, 5vw, 2rem) 6rem;
}

main { max-width: var(--measure); margin: 0 auto; }

a { color: var(--amber); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }
:focus-visible { outline: 2px solid var(--amber); outline-offset: 3px; border-radius: 2px; }

.skip { position: absolute; left: -9999px; }
.skip:focus { left: 1rem; top: 1rem; background: var(--bg); padding: .5rem 1rem; border: 1px solid var(--amber); }

/* Hero */
.hero { padding: 2rem 0 3.5rem; border-bottom: 1px solid var(--hairline); margin-bottom: 3rem; }
.prompt { color: var(--comment); margin: 0 0 1rem; }
.prompt .tilde { color: var(--amber); }
.tagline { font-size: clamp(1.5rem, 5vw, 2.2rem); font-weight: 700; line-height: 1.3; margin: 0 0 1rem; max-width: 20ch; }
.tagline::after { content: "▋"; color: var(--amber); animation: blink 1.1s steps(1) infinite; margin-left: .1em; }
.sub { color: var(--comment); margin: 0 0 2rem; max-width: 42ch; }

.highlights { list-style: none; padding: 0; margin: 0 0 1.5rem; display: flex; flex-wrap: wrap; gap: 1.5rem 2rem; }
.highlights .metric { color: var(--amber); font-weight: 700; font-size: 1.25rem; }
.highlights .label { color: var(--comment); }
.highlights li { display: flex; flex-direction: column; }

.palette-hint { color: var(--comment); font-size: .85rem; margin: 0; }
kbd { background: var(--hairline); border-radius: 4px; padding: .1em .4em; color: var(--text); font-family: inherit; font-size: .85em; }

/* Sections */
.section { padding: 2.5rem 0; border-bottom: 1px solid var(--hairline); scroll-margin-top: 1.5rem; }
.section:last-child { border-bottom: none; }
.marker { font-size: 1rem; font-weight: 700; color: var(--text); margin: 0 0 1.5rem; }
.marker::before { content: "── "; color: var(--amber); }
.section p { max-width: 60ch; }

.job, .project { margin-bottom: 2rem; }
.job h3, .project h3 { font-size: 1rem; font-weight: 500; margin: 0 0 .25rem; }
.company { color: var(--amber); }
.meta { color: var(--comment); font-size: .85rem; margin: 0 0 .75rem; }
.job ul { margin: 0; padding-left: 1.1rem; }
.job li { margin-bottom: .5rem; max-width: 62ch; }
.job li::marker { color: var(--amber); }

.oss { list-style: none; padding: 0; margin: 0; }
.oss li { margin-bottom: 1rem; }
.oss-name { font-weight: 500; }
.oss-note { display: block; color: var(--comment); }

.skills { margin: 0; display: grid; grid-template-columns: minmax(9rem, max-content) 1fr; gap: .75rem 1.5rem; }
.skills dt { color: var(--comment); }
.skills dd { margin: 0; display: flex; flex-wrap: wrap; gap: .4rem; }
.chip { border: 1px solid var(--hairline); border-radius: 5px; padding: .1rem .55rem; font-size: .85rem; }

.certs { list-style: none; padding: 0; margin: 0; }
.certs li { margin-bottom: .75rem; }
.cert-name { display: block; }
.cert-issuer { color: var(--comment); font-size: .85rem; }

.achievements { list-style: none; padding: 0; margin: 0; }
.achievements li { margin-bottom: .5rem; }
.achievements li::before { content: "› "; color: var(--amber); }

/* Section intro line (experience / open source / projects) */
.lead { color: var(--comment); margin: -0.5rem 0 1.75rem; max-width: 60ch; }

.contact { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .5rem; }

/* Command palette */
.palette-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.55); display: none; align-items: flex-start; justify-content: center; padding-top: 15vh; z-index: 50; }
.palette-backdrop[data-open] { display: flex; }
.palette { background: var(--bg); border: 1px solid var(--hairline); border-radius: 8px; width: min(90vw, 30rem); overflow: hidden; box-shadow: 0 20px 60px rgba(0,0,0,.5); }
.palette input { width: 100%; background: transparent; border: none; border-bottom: 1px solid var(--hairline); color: var(--text); font-family: inherit; font-size: 1rem; padding: 1rem; }
.palette input:focus { outline: none; }
.palette ul { list-style: none; margin: 0; padding: .4rem; max-height: 40vh; overflow-y: auto; }
.palette li { padding: .6rem .8rem; border-radius: 5px; cursor: pointer; }
.palette li[aria-selected="true"] { background: var(--hairline); }
.palette li .cmd { color: var(--amber); }

@keyframes blink { 50% { opacity: 0; } }

/* Scroll-reveal (JS adds .reveal-in) */
.section, .hero .highlights { opacity: 1; }
.js .section { opacity: 0; transform: translateY(8px); transition: opacity .5s ease, transform .5s ease; }
.js .section.reveal-in { opacity: 1; transform: none; }

@media (max-width: 480px) {
  .skills { grid-template-columns: 1fr; gap: .25rem 0; }
  .skills dd { margin-bottom: 1rem; }
}

@media (prefers-reduced-motion: reduce) {
  .tagline::after { animation: none; }
  .js .section { opacity: 1; transform: none; transition: none; }
  * { scroll-behavior: auto !important; }
}
