/* growordie blog — shared styles. Dark, quiet, readable. */

:root {
  --bg: #0a0d13;
  --panel: #10151f;
  --line: #1c232f;
  --text: #cdd6d0;
  --dim: #78836f;
  --faint: #4a5345;
  --green: #7CFF6B;
  --teal: #24E0A0;
  --red: #ff4050;
  --mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

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

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

body {
  background: var(--bg);
  color: var(--text);
  font: 16px/1.7 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  padding: 0 20px;
}

.wrap { max-width: 720px; margin: 0 auto; }

/* ---------- header ---------- */
.site-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 22px 0;
  border-bottom: 1px solid var(--line);
  margin-bottom: 36px;
}

.logo {
  font-weight: 700;
  font-size: 17px;
  letter-spacing: .14em;
  text-decoration: none;
  color: var(--text);
  text-transform: lowercase;
}

.logo b { color: var(--green); font-weight: 700; }
.logo i { color: var(--red); font-style: normal; }

.crumb {
  font-size: 13px;
  color: var(--dim);
  text-decoration: none;
  letter-spacing: .06em;
}

.crumb:hover { color: var(--teal); }

/* ---------- article ---------- */
article h1 {
  font-size: clamp(26px, 5.5vw, 36px);
  line-height: 1.2;
  letter-spacing: -.01em;
  color: #e8efe9;
  margin-bottom: 10px;
}

.byline {
  font-size: 13px;
  color: var(--dim);
  margin-bottom: 34px;
}

article h2 {
  font-size: 22px;
  line-height: 1.3;
  color: #e2eae3;
  margin: 42px 0 14px;
}

article h3 {
  font-size: 17px;
  color: #dbe4dc;
  margin: 30px 0 10px;
}

article p { margin: 0 0 18px; }

article a { color: var(--teal); text-decoration: none; }
article a:hover { text-decoration: underline; }

article ul, article ol { margin: 0 0 18px 22px; }
article li { margin-bottom: 8px; }

article strong { color: #e8efe9; }

article blockquote {
  border-left: 3px solid var(--green);
  padding: 4px 0 4px 18px;
  margin: 0 0 18px;
  color: var(--dim);
}

article hr {
  border: 0;
  border-top: 1px solid var(--line);
  margin: 36px 0;
}

code {
  font-family: var(--mono);
  font-size: .88em;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 1px 6px;
  color: var(--teal);
  white-space: nowrap;
}

pre {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  overflow-x: auto;
  margin: 0 0 18px;
}

pre code {
  background: none;
  border: 0;
  padding: 0;
  white-space: pre;
  color: var(--text);
}

.table-scroll { overflow-x: auto; margin: 0 0 18px; }

table {
  border-collapse: collapse;
  width: 100%;
  font-size: 14.5px;
}

th, td {
  text-align: left;
  padding: 9px 12px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}

th { color: var(--dim); font-weight: 600; letter-spacing: .04em; white-space: nowrap; }

.sig { color: var(--dim); font-style: italic; margin-top: 30px; }

/* ---------- stat callout ---------- */
.stat {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px 18px;
  margin: 0 0 18px;
  font-size: 15px;
}

.stat b { color: var(--green); }

/* ---------- blog index ---------- */
.index-title {
  font-size: clamp(24px, 5vw, 32px);
  color: #e8efe9;
  margin-bottom: 10px;
}

.index-intro { color: var(--dim); margin-bottom: 36px; font-size: 17px; }

.post-list { list-style: none; margin: 0; padding: 0; }

.post-list li {
  border-bottom: 1px solid var(--line);
  padding: 24px 0;
  margin: 0;
}

.post-list a.post-title {
  display: block;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.35;
  color: #e8efe9;
  text-decoration: none;
  margin-bottom: 6px;
}

.post-list a.post-title:hover { color: var(--green); }

.post-list p { color: var(--dim); font-size: 15px; margin: 0; }

.post-tag {
  display: inline-block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 6px;
}

/* ---------- read-next nav ---------- */
.read-next {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
}

.read-next h2 {
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--dim);
  margin: 0 0 14px;
}

.read-next ul { list-style: none; margin: 0; padding: 0; }
.read-next li { margin-bottom: 10px; }
.read-next a { color: var(--teal); text-decoration: none; font-size: 15.5px; }
.read-next a:hover { text-decoration: underline; }

/* ---------- footer ---------- */
.site-footer {
  margin: 56px 0 0;
  padding: 32px 0 44px;
  border-top: 1px solid var(--line);
  text-align: center;
}

.cta {
  display: inline-block;
  background: var(--green);
  color: #06130b;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  padding: 13px 26px;
  border-radius: 8px;
  letter-spacing: .01em;
}

.cta:hover { background: var(--teal); }

.site-footer p {
  color: var(--faint);
  font-size: 12.5px;
  margin-top: 16px;
  letter-spacing: .04em;
}

.site-footer a.plain { color: var(--dim); text-decoration: none; }
.site-footer a.plain:hover { color: var(--teal); }

@media (max-width: 480px) {
  body { font-size: 15.5px; }
  .site-header { padding: 18px 0; margin-bottom: 28px; }
}
