/* Self-hosted fonts — no data sent to Google */
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('/fonts/space-grotesk-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('/fonts/space-grotesk-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url('/fonts/jetbrains-mono-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url('/fonts/jetbrains-mono-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ============================================================
   Terminal — shared stylesheet for the AWS SA blog.
   Dark builder's-tool brutalism. Space Grotesk + JetBrains Mono.
   Amber accent (an AWS nod, not the literal orange).
   ============================================================ */

:root {
  --bg:      #0C0C0E;
  --panel:   #121215;
  --panel2:  #161619;
  --ink:     #E7E5DE;
  --dim:     #8A8982;
  --dim2:    #6E6D67;
  --faint:   #3A3A3D;
  --line:    rgba(231,229,222,0.10);
  --line2:   rgba(231,229,222,0.05);
  --accent:  oklch(0.80 0.13 80);
  --accent-dim: oklch(0.80 0.13 80 / 0.16);
  --maxw:    1080px;
  --prose:   720px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: "Space Grotesk", sans-serif;
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  line-height: 1.5;
  font-size: 17px;
}

.mono { font-family: "JetBrains Mono", monospace; }

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

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 40px; }

/* number highlight — the calc-integrity signal */
.num {
  font-family: "JetBrains Mono", monospace;
  color: var(--accent);
  background: var(--accent-dim);
  padding: 0 5px;
  font-size: 0.9em;
  white-space: nowrap;
  border-radius: 1px;
}

/* ---------- shell title bar ---------- */
.shellbar {
  border-bottom: 1px solid var(--line);
  background: var(--bg);
  position: sticky; top: 0; z-index: 50;
}
.shellbar .wrap {
  display: flex; align-items: center; gap: 8px;
  font-family: "JetBrains Mono", monospace;
  font-size: 12.5px; color: var(--dim);
  height: 44px;
}
.shellbar .dot {
  width: 10px; height: 10px; border-radius: 5px;
  background: var(--accent); flex: 0 0 auto;
}
.shellbar .path { color: var(--ink); }
.shellbar .sep { color: var(--faint); }
.shellbar .right { margin-left: auto; color: var(--faint); }

/* ---------- masthead (name + nav), all pages ---------- */
.masthead { border-bottom: 1px solid var(--line); }
.masthead .wrap {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 22px; padding-bottom: 22px; gap: 24px;
}
.brand { display: flex; flex-direction: column; gap: 5px; }
.brand .name {
  font-size: 22px; font-weight: 700; letter-spacing: -0.02em; line-height: 1;
}
.brand .name:hover { color: var(--accent); }
.brand .sub {
  font-family: "JetBrains Mono", monospace;
  font-size: 11.5px; color: var(--dim2); letter-spacing: 0.01em;
}
.brand .sub .a { color: var(--accent); }
nav.main { display: flex; gap: 22px; font-family: "JetBrains Mono", monospace; font-size: 13.5px; }
nav.main a { color: var(--dim); transition: color .12s; }
nav.main a .s { color: var(--accent); }
nav.main a:hover, nav.main a.active { color: var(--ink); }

/* ---------- homepage hero ---------- */
.hero { padding: 64px 0 36px; }
.hero .whoami {
  font-family: "JetBrains Mono", monospace;
  font-size: 13px; color: var(--accent); margin-bottom: 18px;
}
.hero .whoami .p { color: var(--dim); }
.hero h1 {
  font-size: 54px; font-weight: 700; letter-spacing: -0.03em; line-height: 0.98;
}
.hero .role {
  font-family: "JetBrains Mono", monospace;
  font-size: 13px; color: var(--dim); margin-top: 16px;
}
.hero .role .a { color: var(--accent); }
.manifesto {
  border-top: 1px solid var(--line);
  padding: 36px 0 44px;
  max-width: 940px;
}
.manifesto p {
  font-size: 28px; font-weight: 400; letter-spacing: -0.01em; line-height: 1.34;
  text-wrap: pretty;
}
.caret {
  display: inline-block; width: 9px; height: 22px;
  background: var(--accent); margin-left: 5px; transform: translateY(4px);
  animation: blink 1.1s steps(1) infinite;
}
@keyframes blink { 0%,49%{opacity:1} 50%,100%{opacity:0} }

/* ---------- tag filter ---------- */
.filterbar {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding-bottom: 18px;
  font-family: "JetBrains Mono", monospace;
}
.filterbar .grep { color: var(--dim); font-size: 12.5px; margin-right: 4px; }
.tag {
  font-family: "JetBrains Mono", monospace; font-size: 11.5px; color: var(--dim);
  border: 1px solid var(--line); padding: 4px 10px; transition: .12s;
  cursor: pointer; background: transparent;
}
.tag:hover { border-color: var(--accent); color: var(--accent); }
.tag.on { color: var(--bg); background: var(--accent); border-color: var(--accent); }

/* ---------- feed ---------- */
.feed { border-top: 1px solid var(--line); }
.entry {
  display: grid; grid-template-columns: 64px 1fr 168px; gap: 24px;
  align-items: start; padding: 26px 16px 26px 0;
  border-bottom: 1px solid var(--line); margin-right: -16px;
  position: relative; transition: background .14s;
}
.entry:hover { background: var(--panel); }
.entry .bar {
  position: absolute; left: -16px; top: 0; bottom: 0; width: 3px;
  background: transparent; transition: background .14s;
}
.entry.flag .bar { background: var(--accent); }
.entry:hover .bar { background: var(--accent); }
.entry .idx {
  font-family: "JetBrains Mono", monospace; font-size: 14px; color: var(--dim2);
  padding-top: 7px; padding-left: 6px; font-variant-numeric: tabular-nums;
}
.entry .head { color: var(--accent); font-family: "JetBrains Mono", monospace;
  font-size: 10.5px; letter-spacing: 0.14em; margin-bottom: 9px; }
.entry h2 {
  font-size: 24px; font-weight: 600; letter-spacing: -0.02em; line-height: 1.13;
  transition: color .14s; max-width: 640px;
}
.entry.flag h2 { font-size: 29px; }
.entry:hover h2 { color: var(--accent); }
.entry .dek {
  font-size: 16px; color: var(--dim); margin-top: 11px; max-width: 600px;
  text-wrap: pretty;
}
.entry .hashtags { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.entry .hashtags span { font-family: "JetBrains Mono", monospace; font-size: 10.5px; color: var(--faint); }
.entry .meta { font-family: "JetBrains Mono", monospace; text-align: right; padding-top: 5px; }
.entry .meta .date { font-size: 12.5px; color: var(--ink); }
.entry .meta .read { font-size: 12px; color: var(--dim2); margin-top: 7px; }
.entry .meta .go { font-size: 13px; color: var(--dim2); margin-top: 14px; transition: .16s; }
.entry:hover .meta .go { color: var(--accent); transform: translateX(3px); }
.entry.hide { display: none; }

/* ---------- NOW panel ---------- */
.nowpanel { margin: 48px 0 0; background: var(--panel); border: 1px solid var(--line); }
.nowpanel .h {
  font-family: "JetBrains Mono", monospace; font-size: 13px; color: var(--accent);
  padding: 16px 22px; border-bottom: 1px solid var(--line);
}
.nowpanel .h .p { color: var(--dim); }
.nowpanel .row {
  display: grid; grid-template-columns: 26px 140px 1fr; gap: 14px;
  padding: 16px 22px; border-bottom: 1px solid var(--line); align-items: baseline;
}
.nowpanel .row:last-child { border-bottom: none; }
.nowpanel .row .mk { color: var(--accent); font-family: "JetBrains Mono", monospace; }
.nowpanel .row .verb {
  font-family: "JetBrains Mono", monospace; font-size: 13px; color: var(--ink);
  text-transform: uppercase; letter-spacing: 0.04em;
}
.nowpanel .row .what { font-size: 15.5px; color: var(--dim); line-height: 1.45; }

/* ---------- footer ---------- */
footer.site {
  border-top: 1px solid var(--line); margin-top: 64px;
  font-family: "JetBrains Mono", monospace; font-size: 12.5px; color: var(--dim2);
}
footer.site .wrap {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 26px; padding-bottom: 48px; gap: 20px; flex-wrap: wrap;
}
footer.site .links { display: flex; gap: 16px; }
footer.site a:hover { color: var(--accent); }
footer.site .legal { display: flex; gap: 16px; }

/* ---------- article ---------- */
.article { padding: 56px 0 0; }
.article .crumb {
  font-family: "JetBrains Mono", monospace; font-size: 12.5px; color: var(--dim2);
  margin-bottom: 28px;
}
.article .crumb a { color: var(--dim); }
.article .crumb a:hover { color: var(--accent); }
.article .crumb .s { color: var(--faint); }
.article .ahead { max-width: var(--prose); }
.article .ameta {
  font-family: "JetBrains Mono", monospace; font-size: 12.5px; color: var(--dim2);
  display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 22px;
}
.article .ameta .t { color: var(--accent); }
.article h1.title {
  font-size: 44px; font-weight: 700; letter-spacing: -0.03em; line-height: 1.06;
  text-wrap: balance;
}
.article .standfirst {
  font-size: 21px; color: var(--dim); line-height: 1.45; margin-top: 22px;
  max-width: var(--prose); text-wrap: pretty;
}
.article .body { max-width: var(--prose); padding: 40px 0 0; }
.article .body > * { margin-bottom: 24px; }
.article .body p { font-size: 18px; line-height: 1.62; color: #D8D6CF; text-wrap: pretty; }
.article .body p.lead::first-letter { } /* reserved */
.article .body h2 {
  font-size: 15px; font-family: "JetBrains Mono", monospace; font-weight: 600;
  color: var(--accent); letter-spacing: 0.04em; text-transform: uppercase;
  margin-top: 48px; margin-bottom: 4px;
  padding-top: 24px; border-top: 1px solid var(--line);
}
.article .body h3 { font-size: 22px; font-weight: 600; letter-spacing: -0.01em; margin-top: 36px; }
.article .body strong { color: var(--ink); font-weight: 600; }
.article .body em { color: var(--ink); font-style: italic; }
.article .body a.inline { color: var(--accent); border-bottom: 1px solid var(--accent-dim); }
.article .body a.inline:hover { background: var(--accent-dim); }
.article .body ul, .article .body ol { padding-left: 22px; }
.article .body li { font-size: 18px; line-height: 1.6; color: #D8D6CF; margin-bottom: 10px; }
.article .body li::marker { color: var(--accent); }
.article .body blockquote {
  border-left: 3px solid var(--accent); padding: 4px 0 4px 22px; margin: 32px 0;
  font-size: 22px; line-height: 1.4; color: var(--ink); font-weight: 500; letter-spacing: -0.01em;
}

/* the signature: a worked cost build-up table */
.calc {
  border: 1px solid var(--line); background: var(--panel);
  font-family: "JetBrains Mono", monospace; margin: 36px 0; overflow-x: auto;
}
.calc .cap {
  font-size: 12px; color: var(--dim); padding: 14px 18px;
  border-bottom: 1px solid var(--line); letter-spacing: 0.02em;
}
.calc .cap .a { color: var(--accent); }
.calc table { width: 100%; border-collapse: collapse; font-size: 14px; }
.calc th, .calc td { text-align: left; padding: 11px 18px; border-bottom: 1px solid var(--line2); }
.calc th { color: var(--dim2); font-weight: 500; font-size: 11.5px; letter-spacing: 0.06em; text-transform: uppercase; }
.calc td { color: var(--ink); }
.calc td.n { text-align: right; font-variant-numeric: tabular-nums; }
.calc tr:last-child td { border-bottom: none; }
.calc tr.total td { border-top: 1px solid var(--line); color: var(--accent); font-weight: 600; border-bottom: none; }
.calc tr.total td:first-child { color: var(--ink); }
.calc .pos { color: oklch(0.78 0.13 150); }
.calc .neg { color: oklch(0.70 0.16 30); }

/* prev/next + back */
.article .endnote {
  max-width: var(--prose); margin-top: 48px; padding-top: 24px;
  border-top: 1px solid var(--line);
  font-family: "JetBrains Mono", monospace; font-size: 13px; color: var(--dim);
}
.article .endnote .sig { color: var(--accent); }
.morefrom { max-width: var(--prose); margin: 44px auto 0; }
.morefrom .h { font-family: "JetBrains Mono", monospace; font-size: 12px; color: var(--dim2);
  letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 4px; }

/* ---------- generic page (about/now/legal) ---------- */
.page { padding: 56px 0 0; max-width: var(--prose); }
.page .kicker {
  font-family: "JetBrains Mono", monospace; font-size: 13px; color: var(--accent);
  margin-bottom: 16px;
}
.page .kicker .p { color: var(--dim); }
.page h1 { font-size: 44px; font-weight: 700; letter-spacing: -0.03em; line-height: 1.05; }
.page .intro { font-size: 21px; color: var(--dim); line-height: 1.5; margin-top: 22px; text-wrap: pretty; }
.page .content { padding-top: 36px; }
.page .content > * { margin-bottom: 22px; }
.page .content p { font-size: 18px; line-height: 1.62; color: #D8D6CF; text-wrap: pretty; }
.page .content h2 {
  font-size: 14px; font-family: "JetBrains Mono", monospace; font-weight: 600;
  color: var(--accent); letter-spacing: 0.05em; text-transform: uppercase;
  margin-top: 44px; margin-bottom: 6px; padding-top: 22px; border-top: 1px solid var(--line);
}
.page .content h3 { font-size: 19px; font-weight: 600; margin-top: 28px; }
.page .content strong { color: var(--ink); }
.page .content a.inline { color: var(--accent); border-bottom: 1px solid var(--accent-dim); }
.page .content a.inline:hover { background: var(--accent-dim); }
.page .content ul { padding-left: 22px; }
.page .content li { font-size: 18px; line-height: 1.6; color: #D8D6CF; margin-bottom: 9px; }
.page .content li::marker { color: var(--accent); }
.page .content dl { display: grid; grid-template-columns: 200px 1fr; gap: 6px 20px; }
.page .content dt { font-family: "JetBrains Mono", monospace; font-size: 13px; color: var(--dim2); text-transform: uppercase; letter-spacing: 0.04em; }
.page .content dd { font-size: 17px; color: var(--ink); }
.page .ph { color: var(--accent); background: var(--accent-dim); padding: 0 5px; border-radius: 1px;
  font-family: "JetBrains Mono", monospace; font-size: 0.92em; }
.page .note {
  border: 1px solid var(--line); background: var(--panel); padding: 16px 20px;
  font-size: 14.5px; color: var(--dim); line-height: 1.55; margin-top: 32px;
}
.page .note strong { color: var(--accent); }

/* ---------- responsive ---------- */
@media (max-width: 880px) {
  body { font-size: 16px; }
  .wrap { padding: 0 22px; }
  .hero h1 { font-size: 38px; }
  .manifesto p { font-size: 22px; }
  .article h1.title, .page h1 { font-size: 32px; }
  .article .standfirst, .page .intro { font-size: 18px; }
  .entry { grid-template-columns: 1fr; gap: 8px; padding-left: 14px; margin-right: 0; }
  .entry .idx { display: none; }
  .entry .meta { text-align: left; display: flex; gap: 16px; align-items: center; padding-top: 4px; }
  .entry .meta .read, .entry .meta .go { margin-top: 0; }
  .entry .bar { left: 0; }
  .entry { padding-left: 16px; }
  .nowpanel .row { grid-template-columns: 20px 1fr; }
  .nowpanel .row .verb { grid-column: 2; }
  .page .content dl { grid-template-columns: 1fr; gap: 2px 0; }
  .page .content dd { margin-bottom: 14px; }
  footer.site .wrap { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 560px) {
  .masthead .wrap { flex-direction: column; align-items: flex-start; gap: 16px; }
  nav.main { flex-wrap: wrap; }
  .shellbar .right { display: none; }
}
