/*
 * Styles for anderycks.net.
 */

@font-face {
  font-family: "Montserrat";
  font-display: swap;
  src: url(../fonts/Montserrat-VariableFont_wght.ttf) format("truetype");
}

@font-face {
  font-family: "Archivo Black";
  font-display: swap;
  src: url(../fonts/ArchivoBlack-Regular.ttf) format("truetype");
}

/* Fallback values — overridden by Ghost custom theme settings */
:root {
  --page-bg: #ffffff;
  --panel: #fffef8;
  --ink: #36323b;
  --muted: #686c6b;
  --line: #c8c4bf;
  --accent: #4d5d44;
  --accent-hover: #a2b262;
  --accent-secondary: #b6804b;
  --gh-font-heading: "Archivo Black", sans-serif;
  --gh-font-body: "Montserrat", sans-serif;
}

@media (max-width: 860px) {
  header {
    padding-top: 10px;
    gap: 0.75rem;
  }

  header img {
    height: 50px;
  }

  nav {
    gap: 0.55rem;
  }

  nav a:link,
  nav a:visited {
    padding: 0 0 0.08rem;
    font-size: 0.83rem;
  }

  .content {
    display: flex;
    flex-direction: column;
    padding: 1rem;
  }

  .content p {
    font-size: 1rem;
  }

  .post-media {
    width: 100%;
    flex: 0 1 auto;
    min-width: 0;
    max-width: 100%;
    margin: 0 auto;
  }

  .post-image {
    margin: 0 auto 1.25rem;
  }

  .connect {
    margin: 0 auto;
  }
}

/*
 * Base elements.
 */
body {
  background: var(--page-bg);
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  font-family: "Montserrat";
  font-weight: 400;
  font-style: normal;
  color: var(--ink);
}
h1 {
  font-family: "Archivo Black";
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 3.25rem);
  line-height: 1.1;
  margin: 0 0 1rem;
}
h2 {
  font-family: "Archivo Black";
  font-weight: 600;
}
h2 a:link,
h2 a:visited,
h2 a:hover {
  text-decoration: none;
  color: var(--ink);
  border-bottom: none;
}
a:link {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid;
}
a:visited {
  color: var(--accent);
}
a:hover {
  color: var(--accent-hover);
  text-decoration: none;
  border-bottom: 1px dotted;
}

/*
 * Global sections.
 */
header {
  max-width: 1220px;
  width: min(94vw, 1220px);
  margin: 0 auto;
  box-sizing: border-box;
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
  background: var(--panel);
  min-height: 82px;
  padding: 14px clamp(1rem, 2.4vw, 2rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
header img {
  display: block;
  height: 58px;
}
header a:link {
  border-bottom: none;
}
nav {
  font-family: "Archivo Black";
  font-weight: 400;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.75rem;
  padding-right: 0.24rem;
}
nav a:link,
nav a:visited {
  color: var(--ink);
  border-bottom: 1px solid;
  padding: 0 0 0.08rem;
}
nav a:hover {
  border-bottom: 1px dotted;
}
main {
  max-width: 1220px;
  width: min(94vw, 1220px);
  margin: 0 auto;
  box-sizing: border-box;
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
  background: var(--panel);
  padding: 8px 0 10px;
  flex: 1;
  overflow: hidden;
}
footer {
  max-width: 1220px;
  width: min(94vw, 1220px);
  margin: auto auto 0;
  box-sizing: border-box;
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
  background: var(--panel);
  min-height: 50px;
  padding: 20px 10px;
  text-align: center;
  color: var(--muted);
}

/*
 * Homepage elements.
 */
.content {
  max-width: 100%;
  margin: 0 auto;
  display: flex;
  flex-wrap: nowrap;
  gap: clamp(1.5rem, 3.5vw, 3rem);
  align-items: start;
  padding: clamp(1rem, 2.4vw, 2rem);
}

.post-list,
.page-body {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 70ch;
}

.content p {
  margin: 0 0 1.6em;
  font-size: 1.125rem;
  line-height: 1.6;
}

p.summary {
  font-family: "Archivo Black";
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--ink);
}

.post-media {
  flex: 0 0 clamp(250px, 30vw, 360px);
  min-width: 250px;
}

.post-image {
  display: block;
  width: 100%;
  max-width: 360px;
  margin-left: auto;
  border: 1px solid var(--line);
  background: var(--panel);
  padding: 0.24rem;
}

.connect {
  margin-top: 1rem;
  margin-left: auto;
  width: 100%;
  max-width: 360px;
}

.connect h2 {
  margin: 0 0 0.75rem;
  font-size: 1rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--ink);
}

.social-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--line);
}

.social-list li {
  border-bottom: 1px solid var(--line);
}

.social-link:link,
.social-link:visited {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  color: var(--ink);
  padding: 0.52rem 0;
}

.social-link:hover {
  color: var(--accent-hover);
  border-bottom: 1px dotted;
}

.social-link img {
  width: 1.5rem;
}

/*
 * Post list entries on the homepage.
 */
.post-entry {
  padding: 1.5rem 0;
}

.post-entry li,
.post-body li {
  margin-bottom: 0.6em;
}

blockquote {
  margin: 0 1.5em 1.6em 2.5em;
  padding: 0.25em 0 0.25em 1.25em;
  border-left: 3px solid var(--muted);
  font-style: italic;
}

blockquote p:last-child {
  margin-bottom: 0;
}

.post-entry hr {
  border: none;
  background: none;
  min-height: 30px;
  text-align: center;
}

.post-entry hr::before {
  content: "###";
}

.post-entry h2 {
  font-size: clamp(1.15rem, 2.5vw, 1.5rem);
  margin: 0;
  line-height: 1.25;
}

.post-entry h3 {
  font-family: "Archivo Black";
  font-weight: 600;
  font-size: 1rem;
  color: var(--muted);
  margin: 0 0 0.85rem;
}

.post-entry p {
  margin: 0 0 1.6em;
}

.post-entry p:last-child {
  margin-bottom: 0;
}

/*
 * Pagination.
 */
.pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--line);
  padding: 1.25rem 0 0;
  margin-top: 0.5rem;
  font-size: 0.9rem;
}

.pagination-page {
  color: var(--muted);
}

.pagination .disabled {
  color: var(--line);
  cursor: default;
}

/*
 * Single post page.
 */
.page-body:only-child {
  margin: 0 auto;
}

.post-header {
  margin-bottom: 1.5rem;
}

.post-header h1 {
  margin: 0;
}

.post-header h2 {
  font-size: 1.25rem;
  color: var(--muted);
  margin: 0;
}

.marginal-note {
  float: left;
  width: 11em;
  margin: 0.25em 1.5em 1em -14em;
  font-size: 0.8rem;
  line-height: 1.45;
  color: var(--muted);
  font-style: italic;
  border-left: 2px solid var(--line);
  padding-left: 0.75em;
}

@media (max-width: 1100px) {
  .marginal-note {
    float: none;
    width: auto;
    margin: 0 0 1.5em;
    padding: 0.75em 0 0.75em 1em;
  }
}

.post-feature-image {
  margin: 1.5rem 0 0;
  padding: 0;
}

.post-feature-image img {
  display: block;
  width: 100%;
  border: 1px solid var(--line);
  padding: 0.24rem;
}

.post-feature-image figcaption {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  color: var(--muted);
  text-align: center;
  font-style: italic;
}

.post-body p {
  margin: 0 0 1.6em;
  font-size: 1.125rem;
  line-height: 1.6;
}

/*
 * Constrain embedded content to its container.
 */
.post-list img,
.post-list video,
.post-list iframe,
.post-list embed,
.post-list object,
.page-body img,
.page-body video,
.page-body iframe,
.page-body embed,
.page-body object,
.post-body img,
.post-body video,
.post-body iframe,
.post-body embed,
.post-body object {
  max-width: 100%;
  height: auto;
}

/*
 * Ghost content width classes.
 */
.kg-width-wide {
  max-width: 85vw;
  margin-left: auto;
  margin-right: auto;
}

.kg-width-full {
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  width: 100vw;
}

.kg-width-wide img,
.kg-width-full img {
  max-width: 100%;
  height: auto;
}

/*
 * Ghost custom font support.
 */
body {
  font-family: var(--font-body, "Montserrat"), sans-serif;
}

h1, h2, h3 {
  font-family: var(--font-heading, "Archivo Black"), sans-serif;
}
