/* Homeschool Town — article / place detail (full reading experience) */

.article { padding-block: var(--s-6) var(--s-8); }

/* Simple prose container — still used by Share's pre-submit page. */
.article__inner { max-width: var(--container-prose); margin-inline: auto; }

/* ---- Place: full-bleed content grid ----
   A prose column for reading, flanked by a wider breakout track for
   photos and the map. Children default to the prose column; .article__full
   spans the wide track. */
.article__grid {
  --gutter: clamp(var(--s-5), 5vw, 7rem);
  display: grid;
  grid-template-columns:
    [full-start] minmax(var(--s-5), 1fr)
    [wide-start] minmax(0, var(--gutter))
    [prose-start] min(var(--container-prose), 100% - var(--s-5) * 2) [prose-end]
    minmax(0, var(--gutter))
    [wide-end] minmax(var(--s-5), 1fr) [full-end];
}
.article__grid > * { grid-column: prose; }
.article__grid > .article__full { grid-column: wide; }

/* ---- Backlink ---- */
.backlink {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-sm); font-weight: 500; text-decoration: none; color: var(--muted);
  margin-bottom: var(--s-5);
}
.backlink:hover { color: var(--primary); }
.backlink .icon { transition: transform var(--dur) var(--ease-out-quart); transform: scaleX(-1); }
.backlink:hover .icon { transform: scaleX(-1) translateX(3px); }

/* ---- Title / dek / byline ---- */
.article__cat { margin-bottom: var(--s-3); font-size: var(--t-sm); }
.article__title {
  font-size: clamp(2.1rem, 1.5rem + 2.4vw, 3.1rem);
  line-height: 1.05; letter-spacing: -0.022em; margin-bottom: var(--s-3);
}
.article__dek {
  font-size: clamp(1.15rem, 1.05rem + 0.6vw, 1.4rem);
  line-height: 1.5; color: var(--ink-soft); text-wrap: pretty;
  margin-bottom: var(--s-5);
}

.article__byline {
  display: flex; align-items: center; gap: var(--s-3); flex-wrap: wrap;
  padding-block: var(--s-4); border-block: 1px solid var(--border);
  margin-bottom: var(--s-5);
}
.article__byline .avatar { width: 2.5rem; height: 2.5rem; font-size: 0.85rem; }
.article__byline-id {
  display: inline-flex; align-items: center; gap: var(--s-3);
  margin: calc(var(--s-1) * -1) calc(var(--s-2) * -1); padding: var(--s-1) var(--s-2);
  border-radius: var(--r-md); text-decoration: none; color: inherit;
  transition: background var(--dur-fast) var(--ease-out-quart);
}
.article__byline-id:hover { background: var(--accent-tint); }
.article__byline-who { display: flex; flex-direction: column; line-height: 1.3; }
.article__byline-who strong { color: var(--ink); font-weight: 600; }
.article__byline-id:hover .article__byline-who strong { color: var(--primary); }
.article__byline-meta { font-size: var(--t-sm); color: var(--muted); }
.article__where {
  display: inline-flex; align-items: center; gap: var(--s-2);
  margin-left: auto; font-size: var(--t-sm); color: var(--muted);
}
.article__where .icon { color: var(--primary); font-size: 1.1rem; }

/* ---- Lead image ---- */
.article__lead { margin-block: var(--s-6) var(--s-7); }
.article__lead img {
  width: 100%; height: auto; aspect-ratio: 16 / 10; object-fit: cover;
  border-radius: var(--r-xl); border: 1px solid var(--border);
}
.article__lead figcaption,
.gallery__item figcaption {
  margin-top: var(--s-2); font-size: var(--t-xs); color: var(--muted); line-height: 1.45;
}

/* ---- Body prose ---- */
.article__body { font-size: var(--t-lead); line-height: 1.75; color: var(--ink); }
.article__body p { text-wrap: pretty; }
.article__body p + p { margin-top: var(--s-4); }
.article__sub {
  font-size: var(--t-h3); line-height: 1.15;
  margin-top: var(--s-6); margin-bottom: var(--s-3);
}

/* pull-quote — full top/bottom rules, display type. Never a side stripe. */
.pullquote { margin-block: var(--s-6); padding-block: var(--s-5); border-block: 1px solid var(--border-warm); }
.pullquote p {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(1.4rem, 1.1rem + 1.3vw, 1.9rem); line-height: 1.25;
  letter-spacing: -0.015em; color: var(--ink); text-wrap: balance;
}

/* "what made this unique" — the authenticity highlight */
.unique {
  display: grid; grid-template-columns: auto 1fr; gap: var(--s-4); align-items: start;
  background-image: var(--grad-surface); border: 1px solid var(--border-warm);
  border-radius: var(--r-lg); padding: var(--s-5) var(--s-6); margin-block: var(--s-7);
}
.unique__icon { color: var(--clay); font-size: 1.75rem; line-height: 1; }
.unique h2 { font-family: var(--font-body); font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; color: var(--muted); margin-bottom: var(--s-2); }
.unique p { font-family: var(--font-display); font-size: 1.3rem; line-height: 1.35; color: var(--ink); font-weight: 400; }

/* ---- Photo gallery ---- */
.gallery {
  margin-block: var(--s-7);
  display: grid; gap: var(--s-4);
  grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
}
.gallery__item { margin: 0; }
.gallery__item img {
  width: 100%; height: auto; aspect-ratio: 3 / 2; object-fit: cover;
  border-radius: var(--r-lg); border: 1px solid var(--border);
}

/* ---- Location mini-map (reuses .pin + .mapboxgl-popup from map-browse.css) ---- */
.article-map { margin-block: var(--s-7); }
.article-map__bar {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: var(--s-4); flex-wrap: wrap; margin-bottom: var(--s-3);
}
.article-map__addr {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-weight: 600; color: var(--ink);
}
.article-map__addr .icon { color: var(--primary); }
.article-map__link {
  display: inline-flex; align-items: center; gap: var(--s-1);
  font-size: var(--t-sm); font-weight: 500; text-decoration: none; white-space: nowrap;
}
.article-map__link .icon { width: 1em; height: 1em; transition: transform var(--dur) var(--ease-out-quart); }
.article-map__link:hover .icon { transform: translate(2px, -2px); }
.article-map__canvas {
  height: clamp(18rem, 45vw, 26rem);
  border-radius: var(--r-xl); overflow: hidden;
  border: 1px solid var(--border); background: var(--surface); position: relative;
}

/* ---- Facts (ages / tags) ---- */
.article__facts {
  margin-top: var(--s-7); padding-top: var(--s-5); border-top: 1px solid var(--border);
  display: flex; flex-direction: column; gap: var(--s-4);
}
.fact { display: flex; gap: var(--s-3); align-items: baseline; flex-wrap: wrap; }
.fact__label {
  flex: none; width: 5.5rem; font-size: var(--t-xs); font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase; color: var(--muted);
}
.fact__value { color: var(--ink); }
.fact__tags { display: flex; flex-wrap: wrap; gap: var(--s-2); }

/* ---- Author block (links through to the author's profile) ---- */
.author {
  margin-top: var(--s-7);
  display: grid; grid-template-columns: auto 1fr; gap: var(--s-4); align-items: start;
  background-image: var(--grad-surface); border: 1px solid var(--border-warm);
  border-radius: var(--r-lg); padding: var(--s-5) var(--s-6);
  text-decoration: none; color: inherit;
  transition: transform var(--dur) var(--ease-out-quart),
              box-shadow var(--dur) var(--ease-out-quart),
              border-color var(--dur) var(--ease-out-quart);
}
.author:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); border-color: var(--primary); color: inherit; }
.author:hover .author__name { color: var(--primary); }
.author__avatar { width: 3.25rem; height: 3.25rem; font-size: 1.05rem; }
.author__kicker { font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; color: var(--muted); }
.author__name { font-family: var(--font-display); font-size: var(--t-h3); line-height: 1.1; margin-top: var(--s-1); }
.author__bio { color: var(--ink-soft); margin-top: var(--s-2); line-height: 1.6; }
.author__base { display: inline-flex; align-items: center; gap: var(--s-2); margin-top: var(--s-3); font-size: var(--t-sm); color: var(--muted); }
.author__base .icon { color: var(--primary); }

/* ---- Report (Phase 1, ai-roadmap.md) ---- */
.article__report { margin-top: var(--s-5); text-align: center; }

/* ---- Related ---- */
.more { background-image: var(--grad-surface); border-top: 1px solid var(--border); }
.more__title { font-size: var(--t-h2); margin-bottom: var(--s-6); }

@media (prefers-reduced-motion: reduce) {
  .backlink:hover .icon { transform: scaleX(-1); }
  .article-map__link:hover .icon { transform: none; }
}

/* ---- Share: pre-submit promise ---- */
.promise-card {
  background-image: var(--grad-surface); border: 1px solid var(--border-warm);
  border-radius: var(--r-xl); padding: clamp(var(--s-5), 4vw, var(--s-7)); max-width: 60ch;
}
.promise-card h2 { font-size: var(--t-h3); margin-bottom: var(--s-3); }
.promise-card > p { color: var(--ink-soft); }
.promise-list { list-style: none; padding: 0; margin: var(--s-4) 0; display: flex; flex-direction: column; gap: var(--s-3); }
.promise-list li { display: flex; align-items: center; gap: var(--s-3); font-size: var(--t-body); color: var(--ink); }
.promise-list .icon { flex: none; font-size: 1.4rem; color: var(--accent); }
.promise-card__fine { margin-top: var(--s-4); font-size: var(--t-sm); color: var(--muted); }
.muted-note { margin-top: var(--s-5); font-size: var(--t-sm); color: var(--muted); font-style: italic; }
