/* =========================================================
   THE ATLAS — per-location styles. Editorial Signal tokens
   only. Sharp edges, hairlines, coordinates, no shadow.
   ========================================================= */

/* ---------------- HOME ---------------- */
.home-stage { justify-content: center; }
.home-grid {
  flex: 1 1 auto;
  width: 100%; max-width: var(--max-content); margin: 0 auto;
  padding: clamp(24px, 6vh, 72px) var(--gutter);
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px, 6vw, 96px);
  align-items: center; position: relative; z-index: 2;
}
.home-eyebrow {
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--fg2); margin-bottom: var(--sp-6);
  display: flex; align-items: center;
}
.home-title {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(42px, 6vw, 76px); line-height: 1.05; letter-spacing: -0.015em;
  margin: 0 0 var(--sp-7); padding-bottom: 0.5em; text-wrap: balance;
}
.home-title.is-stark { font-family: var(--font-sans); font-weight: 900; letter-spacing: -0.035em; line-height: 0.92; text-transform: uppercase; }
.home-title .serif-i { font-style: italic; }
.home-sub {
  font-size: var(--fs-body-l); line-height: var(--lh-normal); color: var(--fg2);
  max-width: 46ch; margin-bottom: var(--sp-7);
}
.home-actions { display: flex; align-items: center; gap: var(--sp-5); flex-wrap: wrap; }

.home-mapwrap { position: relative; border: 1px solid var(--rule-color); background: var(--surface); padding: var(--sp-5); }
.home-map { width: 100%; aspect-ratio: 100 / 80; }
.home-map svg { width: 100%; height: 100%; display: block; }
.home-legend { margin-top: var(--sp-4); border-top: 1px solid var(--rule-color); padding-top: var(--sp-3);
  display: grid; gap: 2px; }
.home-legend__row { display: grid; grid-template-columns: 28px 1fr auto; gap: var(--sp-3); align-items: baseline;
  padding: 5px 0; border-bottom: 1px solid var(--rule-soft); }
.home-legend__row:last-child { border-bottom: 0; }
.home-legend__row .rm { font-family: var(--font-mono); font-size: 11px; color: var(--fg2); }
.home-legend__row .nm { font-size: 16px; }
.home-legend__row .ph { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg2); }
@media (max-width: 860px) {
  .home-grid { grid-template-columns: 1fr; }
  .home-mapwrap { display: none; }
}

/* ---------------- OBSERVATORY ---------------- */
.obs-prompts { display: flex; flex-wrap: wrap; gap: var(--sp-3); margin-bottom: var(--sp-7); }
.obs-prompt {
  font-family: var(--font-serif); font-style: italic; font-size: 20px;
  color: var(--fg2); padding: 6px 16px 6px 0; border-right: 1px solid var(--rule-soft);
}
.obs-prompt:last-child { border-right: 0; }
.obs-wall { align-items: stretch; }
.obs-wall .artifact { min-height: 168px; }
.obs-counter { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4);
  margin-top: var(--sp-6); flex-wrap: wrap; }

/* ---------------- CARTOGRAPHER ---------------- */
.carto-progress { margin-bottom: var(--sp-4); }
.carto-pair { display: grid; grid-template-columns: 1fr auto 1fr; gap: var(--sp-4); align-items: stretch; }
.carto-obj { border: 1px solid var(--rule-color); background: var(--surface); padding: var(--sp-5);
  display: flex; flex-direction: column; gap: var(--sp-4); min-height: 200px; }
.carto-obj__t { font-size: 26px; line-height: 1.22; }
.carto-vs { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--sp-3); padding: 0 var(--sp-2); }
.carto-vs__line { width: 1px; flex: 1; background: var(--rule-color); min-height: 28px; }
.carto-vs__q { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--fg2); text-align: center; line-height: 1.3; }
.carto-actions { display: flex; gap: var(--sp-3); margin-top: var(--sp-6); }
.carto-result { margin-top: var(--sp-6); border-top: 1px solid var(--rule-color); padding-top: var(--sp-5); }
.carto-verdict { display: flex; align-items: center; gap: var(--sp-4); margin-bottom: var(--sp-4); flex-wrap: wrap; }
.carto-badge { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 6px 12px; border: 1px solid var(--rule-color); }
.carto-badge.agree { background: var(--ink); color: var(--paper); }
.carto-badge.differ { background: transparent; color: var(--fg1); }

.prob { border: 1px solid var(--rule-color); padding: var(--sp-5); background: var(--surface); }
.prob--deep { background: var(--bone); }
.prob__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-3); }
.prob__n { font-family: var(--font-mono); font-size: 13px; color: var(--fg1); }
.prob__tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; color: var(--fg2); }
.prob__t { font-size: 24px; margin-bottom: var(--sp-3); }
.carto-challenges { display: grid; gap: var(--sp-4); }
.challenge { border-left: 3px solid var(--rule-color); padding: var(--sp-2) var(--sp-5); }
.challenge--deep { border-left-color: var(--signal); }
.challenge__lbl { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--fg2); display: block; margin-bottom: var(--sp-3); }
.challenge__t { font-size: clamp(24px, 3vw, 34px); line-height: 1.16; }

/* ---------------- HORIZON ---------------- */
.horizon-line { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 1px solid var(--rule-color); }
.future { position: relative; text-align: left; background: transparent; border: 0;
  border-right: 1px solid var(--rule-color); padding: var(--sp-6) var(--sp-5) var(--sp-7); cursor: pointer; color: var(--fg1);
  display: flex; flex-direction: column; gap: var(--sp-3); transition: background var(--dur) var(--ease); min-height: 220px; }
.future:last-child { border-right: 0; }
.future:hover { background: var(--hover-overlay); }
.future.open { background: var(--hover-overlay); }
.future__star { width: 8px; height: 8px; border: 1px solid var(--ink); background: transparent; transition: all var(--dur) var(--ease); }
.future.seen .future__star { background: var(--ink); }
.future.open .future__star { background: var(--signal); border-color: var(--signal); transform: scale(1.4); }
.future__bearing { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; color: var(--fg2); margin-top: var(--sp-3); }
.future__label { font-size: 28px; line-height: 1.05; }
.future__rec { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; color: var(--signal); }
.future__line { font-size: 15px; color: var(--fg2); margin-top: auto; }
@media (max-width: 760px) { .horizon-line { grid-template-columns: 1fr; } .future { border-right: 0; border-bottom: 1px solid var(--rule-color); } .future:last-child { border-bottom: 0; } }

.horizon-detail { margin-top: var(--sp-6); border: 1px solid var(--rule-color); padding: var(--sp-6); background: var(--surface); }
.horizon-detail__grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: var(--sp-6); }
.consq { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--sp-3); }
.consq li { padding-left: var(--sp-4); position: relative; font-size: var(--fs-body); line-height: var(--lh-normal); }
.consq li::before { content: "—"; position: absolute; left: 0; color: var(--signal); }
@media (max-width: 720px) { .horizon-detail__grid { grid-template-columns: 1fr; } }

/* ---------------- ICEBERG ---------------- */
.berg-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); align-items: start; }
@media (max-width: 760px) { .berg-grid { grid-template-columns: 1fr; } }
.berg { border: 1px solid var(--rule-color); background: var(--surface); display: flex; flex-direction: column; }
.berg__above { text-align: left; background: transparent; border: 0; cursor: pointer; color: var(--fg1);
  padding: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-3); }
.berg__weight { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; color: var(--signal); }
.berg__idea { font-size: 22px; line-height: 1.2; }
.berg__pull { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg2); }
.berg__waterline { height: 1px; background: var(--rule-color); position: relative; }
.berg__waterline::after { content: "WATERLINE"; position: absolute; right: var(--sp-3); top: -7px; background: var(--surface);
  padding: 0 6px; font-family: var(--font-mono); font-size: 8px; letter-spacing: 0.14em; color: var(--fg3); }
.berg__below { max-height: 0; overflow: hidden; background: var(--bone); transition: max-height var(--dur-slow) var(--ease); }
.berg.open .berg__below { max-height: 420px; }
.berg__below { padding: 0 var(--sp-5); }
.berg.open .berg__below { padding: var(--sp-4) var(--sp-5) var(--sp-5); }
.berg__row { display: grid; grid-template-columns: 96px 1fr; gap: var(--sp-3); padding: var(--sp-3) 0; border-bottom: 1px solid var(--rule-soft); }
.berg__row:last-child { border-bottom: 0; }
.berg__k { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg2); padding-top: 3px; }
.berg__v { font-size: 15px; line-height: 1.45; }

/* ---------------- RIVER ---------------- */
.river-note { border: 1px solid var(--signal); padding: var(--sp-4); margin-bottom: var(--sp-6); display: flex; flex-direction: column; gap: var(--sp-2); }
.river-note__tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; color: var(--signal); }
.river { display: grid; grid-template-columns: 1fr 120px 1fr; gap: 0; border: 1px solid var(--rule-color); align-items: stretch; }
.bank { padding: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-3); }
.bank--far { background: var(--bone); }
.bank__lbl { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; color: var(--fg2); margin-bottom: var(--sp-2); }
.bank__item { text-align: left; background: transparent; border: 1px solid var(--rule-color); padding: var(--sp-3) var(--sp-4);
  font-size: 15px; line-height: 1.4; color: var(--fg1); cursor: pointer; display: flex; gap: var(--sp-3); align-items: baseline;
  transition: background var(--dur) var(--ease), transform var(--dur) var(--ease); }
.bank__item:hover { background: var(--hover-overlay); }
.bank__item.crossed { background: var(--ink); color: var(--paper); }
.bank__item.crossed .bank__num { color: var(--paper); }
.bank__item--far { cursor: default; opacity: 0.4; transition: opacity var(--dur-slow) var(--ease); }
.bank__item--far.lit { opacity: 1; border-color: var(--signal); }
.bank__num { font-family: var(--font-mono); font-size: 11px; color: var(--fg2); flex: 0 0 auto; }
.river__channel { background: repeating-linear-gradient(0deg, var(--surface) 0 6px, var(--bone) 6px 12px);
  display: flex; flex-direction: column; align-items: center; justify-content: space-between; padding: var(--sp-5) 0;
  border-left: 1px solid var(--rule-color); border-right: 1px solid var(--rule-color); }
.river__label { writing-mode: vertical-rl; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em; color: var(--fg2); }
.river__bridge { writing-mode: vertical-rl; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; color: var(--signal); }
@media (max-width: 760px) { .river { grid-template-columns: 1fr; } .river__channel { flex-direction: row; padding: var(--sp-3); border: 0; border-top: 1px solid var(--rule-color); border-bottom: 1px solid var(--rule-color);} .river__label, .river__bridge { writing-mode: horizontal-tb; } }
.river-q__tabs { display: flex; gap: 0; border: 1px solid var(--rule-color); border-bottom: 0; flex-wrap: wrap; }
.river-q__tab { flex: 1; min-width: 160px; background: transparent; border: 0; border-right: 1px solid var(--rule-color); border-bottom: 1px solid var(--rule-color);
  padding: var(--sp-4); font-family: var(--font-sans); font-size: 14px; font-weight: 500; color: var(--fg2); cursor: pointer; text-align: left; transition: all var(--dur) var(--ease); }
.river-q__tab:last-child { border-right: 0; }
.river-q__tab.on { background: var(--ink); color: var(--paper); }
.river-q__a { border: 1px solid var(--rule-color); border-top: 0; padding: var(--sp-6); font-size: 26px; line-height: 1.25; }

/* ---------------- MOUNTAIN PASS ---------------- */
.pass { display: grid; grid-template-columns: 280px 1fr; gap: 0; border: 1px solid var(--rule-color); align-items: stretch; }
.pass__rail { display: flex; flex-direction: column; border-right: 1px solid var(--rule-color); }
.pass__rung { text-align: left; background: transparent; border: 0; border-bottom: 1px solid var(--rule-color);
  padding: var(--sp-3) var(--sp-4); cursor: pointer; color: var(--fg2); display: flex; align-items: center; gap: var(--sp-3);
  transition: all var(--dur) var(--ease); }
.pass__rung:last-child { border-bottom: 0; }
.pass__rung:hover { background: var(--hover-overlay); color: var(--fg1); }
.pass__rung.on { background: var(--ink); color: var(--paper); }
.pass__rung.seen:not(.on) .pass__rank { color: var(--fg1); }
.pass__rank { font-family: var(--font-mono); font-size: 13px; flex: 0 0 auto; width: 18px; }
.pass__rrailto { font-size: 14px; line-height: 1.25; }
.pass__card { padding: var(--sp-6); display: flex; flex-direction: column; }
.pass__rankbig { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--fg2); margin-bottom: var(--sp-4); }
.pass__reframe { display: flex; align-items: center; gap: var(--sp-4); flex-wrap: wrap; margin-bottom: var(--sp-5); }
.pass__from { font-size: 18px; color: var(--fg2); text-decoration: line-through; text-decoration-color: var(--fog); }
.pass__arrow { color: var(--signal); font-size: 20px; }
.pass__to { font-size: clamp(28px, 3.4vw, 40px); line-height: 1.05; }
.pass__rows { display: grid; gap: var(--sp-4); }
.pass__rows p { font-size: 15px; line-height: 1.5; margin-top: 4px; }
.pass__k { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg2); }
.pass__rec { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--signal); margin-top: var(--sp-5); }
@media (max-width: 760px) { .pass { grid-template-columns: 1fr; } .pass__rail { flex-direction: row; overflow-x: auto; border-right: 0; border-bottom: 1px solid var(--rule-color); } .pass__rung { border-bottom: 0; border-right: 1px solid var(--rule-color); min-width: 150px; } }

.crux-statement { font-size: clamp(26px, 3.6vw, 40px); line-height: 1.18; border-left: 3px solid var(--signal); padding: var(--sp-2) var(--sp-6); margin-bottom: var(--sp-4); }
.move { border: 1px solid var(--rule-color); padding: var(--sp-5); background: var(--surface); }
.move__n { font-family: var(--font-mono); font-size: 12px; color: var(--signal); }
.move__t { font-size: 20px; margin: var(--sp-3) 0; }

/* ---------------- CONSTELLATION ---------------- */
.sky { position: relative; border: 1px solid var(--rule-color); background: var(--bone); aspect-ratio: 100 / 46; margin-bottom: var(--sp-5); overflow: hidden; }
.sky__lines { position: absolute; inset: 0; width: 100%; height: 100%; }
.star { position: absolute; transform: translate(-50%, -50%); background: none; border: 0; cursor: pointer;
  display: flex; flex-direction: column; align-items: center; gap: 8px; }
.star__dot { background: var(--ash); border-radius: 50%; transition: all var(--dur) var(--ease); }
.star__dot.mag1 { width: 6px; height: 6px; }
.star__dot.mag2 { width: 9px; height: 9px; }
.star__dot.mag3 { width: 13px; height: 13px; }
.star.lit .star__dot { background: var(--ink); }
.star.active .star__dot { background: var(--signal); box-shadow: 0 0 0 4px rgba(230,90,47,0.18); }
.star__label { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg2);
  opacity: 0.5; transition: opacity var(--dur) var(--ease), color var(--dur) var(--ease); max-width: 150px; text-align: center; white-space: normal; line-height: 1.35; }
.star:hover .star__label, .star.active .star__label { opacity: 1; }
.star.lit .star__label { color: var(--fg1); opacity: 0.8; }
.star.active .star__label { color: var(--signal); opacity: 1; }
.constel-read { min-height: 96px; border-bottom: 1px solid var(--rule-color); padding-bottom: var(--sp-5); margin-bottom: var(--sp-3); display: flex; align-items: center; }
.identity { font-size: clamp(24px, 3.2vw, 36px); line-height: 1.18; max-width: 26ch; }
.constel-foot { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); margin-top: var(--sp-7); flex-wrap: wrap; }
