/* The Soi 31 line, embedded as a section on the directory home.
   Everything is scoped under .railblock and uses local variables, so the
   cobalt transit look never leaks into the warm directory around it. */
.railblock {
  --line: #2546c7;
  --line-soft: #cdd5f1;
  --eat: #e0552f;
  --drink: #b03a6a;
  --coffee: #a06a2c;
  --shop: #c39a1f;
  --spa: #1f8f74;
  --stay: #4a5e93;
  --rb-ink: #1b1b17;
  --rb-soft: #6c6a5c;
  --rb-rule: #cdc8b4;
  --rb-card: #fbfaf4;
  font-family: "Archivo", system-ui, sans-serif;
  color: var(--rb-ink);
}
.railblock .rail-sign { display: flex; justify-content: center; margin-bottom: 18px; }
.railblock .rail-sign svg { width: 188px; height: auto; filter: drop-shadow(0 2px 5px rgba(20, 16, 6, 0.22)); }
.railblock .rail-picks { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin-bottom: 6px; }
.railblock .chip-pick { font-family: "Space Mono", monospace; font-size: 11px; letter-spacing: 0.03em; border: 1px solid var(--rb-rule); background: #fff; border-radius: 30px; padding: 7px 13px; cursor: pointer; display: flex; align-items: center; gap: 7px; color: var(--rb-ink); }
.railblock .chip-pick:hover { border-color: var(--line); color: var(--line); }
.railblock .chip-pick b { font-weight: 700; }
.railblock .chip-pick .sq { width: 9px; height: 9px; border-radius: 2px; }

.railblock .diagram-wrap { margin: 16px auto 0; max-width: 720px; }
.railblock svg.diagram { display: block; width: 100%; height: auto; }
.railblock svg.diagram text { pointer-events: none; }
.railblock .st-name { font-family: "Archivo", sans-serif; font-weight: 700; fill: var(--rb-ink); }
.railblock .st-time { font-family: "Space Mono", monospace; fill: var(--rb-soft); font-weight: 400; }
.railblock .st-num { font-family: "Space Mono", monospace; font-weight: 700; fill: var(--line); }
.railblock .st-num.on { fill: #fff; }
.railblock .st-tag { font-family: "Space Mono", monospace; fill: var(--rb-soft); letter-spacing: 0.14em; }
.railblock .station { cursor: pointer; }
.railblock .row-bg { fill: var(--rb-ink); opacity: 0; transition: opacity 0.15s; }
.railblock .station:hover .row-bg { opacity: 0.05; }
.railblock .station:hover .st-name { fill: var(--line); }
.railblock .station.active .row-bg { opacity: 0.06; }
@media (prefers-reduced-motion: no-preference) { .railblock .station.pulse .dot-halo { animation: rbpulse 1.3s ease-out 2; } }
@keyframes rbpulse { from { r: 11; opacity: 0.5; } to { r: 30; opacity: 0; } }

.railblock .legend { margin: 26px auto 0; max-width: 720px; border-top: 1px solid var(--rb-rule); padding-top: 18px; display: flex; flex-wrap: wrap; gap: 12px 24px; align-items: center; }
.railblock .legtitle { font-family: "Space Mono", monospace; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--rb-soft); width: 100%; }
.railblock .leg-item { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--rb-ink); }
.railblock .leg-sq { width: 12px; height: 12px; border-radius: 2px; flex: none; }

/* place card (scoped so it does not collide with the warm venue cards) */
.railblock .scrim { position: fixed; inset: 0; background: rgba(28, 26, 16, 0.42); opacity: 0; visibility: hidden; transition: opacity 0.25s; z-index: 200; }
.railblock .scrim.open { opacity: 1; visibility: visible; }
.railblock .card { position: fixed; z-index: 210; background: var(--rb-card); color: var(--rb-ink); display: flex; flex-direction: column; overflow: hidden; box-shadow: 0 18px 60px rgba(20, 16, 6, 0.4); font-family: "Archivo", sans-serif; }
@media (min-width: 760px) { .railblock .card { top: 0; right: 0; height: 100vh; width: 430px; transform: translateX(108%); transition: transform 0.42s cubic-bezier(0.16, 0.84, 0.3, 1); border-left: 4px solid var(--line); } .railblock .card.open { transform: translateX(0); } }
@media (max-width: 759px) { .railblock .card { left: 0; right: 0; bottom: 0; max-height: 88vh; transform: translateY(108%); transition: transform 0.42s cubic-bezier(0.16, 0.84, 0.3, 1); border-top: 4px solid var(--line); border-top-left-radius: 14px; border-top-right-radius: 14px; } .railblock .card.open { transform: translateY(0); } }
.railblock .card-scroll { overflow-y: auto; padding: 30px 32px 36px; }
.railblock .grab { display: none; }
@media (max-width: 759px) { .railblock .grab { display: block; width: 42px; height: 4px; border-radius: 3px; background: var(--rb-rule); margin: 10px auto 0; } }
.railblock .card-close { position: absolute; top: 16px; right: 16px; z-index: 5; width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--rb-rule); background: var(--rb-card); cursor: pointer; font-size: 15px; color: var(--rb-soft); display: flex; align-items: center; justify-content: center; transition: 0.15s; }
.railblock .card-close:hover { background: var(--rb-ink); color: #fff; border-color: var(--rb-ink); }
.railblock .card-cat { display: flex; align-items: center; gap: 9px; font-family: "Space Mono", monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--rb-soft); position: static; background: none; padding: 0; }
.railblock .card-cat .cdot { width: 11px; height: 11px; border-radius: 2px; }
.railblock .card-cat .tier { margin-left: auto; color: var(--rb-ink); }
.railblock .card-name { font-family: "Archivo", sans-serif; font-weight: 800; font-size: 32px; line-height: 1.04; margin: 12px 0 4px; letter-spacing: -0.02em; color: var(--rb-ink); }
.railblock .card-no { color: var(--line); }
.railblock .card-meta { display: flex; flex-wrap: wrap; gap: 6px 18px; font-family: "Space Mono", monospace; font-size: 11.5px; color: var(--rb-soft); margin: 8px 0 18px; }
.railblock .card-meta b { color: var(--rb-ink); font-weight: 700; }
.railblock .photo { position: relative; width: 100%; aspect-ratio: 4 / 3; border: 1px solid var(--rb-rule); border-radius: 4px; overflow: hidden; background: #e7e2d0; }
.railblock .photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.railblock .photo .cap { position: absolute; left: 10px; bottom: 9px; font-family: "Space Mono", monospace; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: #fff; background: rgba(20, 16, 6, 0.45); padding: 3px 7px; border-radius: 3px; }
.railblock .card-take { font-size: 16px; line-height: 1.55; color: #33322a; margin: 18px 0 16px; font-family: "Archivo", sans-serif; }
.railblock .chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
.railblock .chip { font-family: "Space Mono", monospace; font-size: 10.5px; letter-spacing: 0.04em; color: var(--rb-soft); border: 1px solid var(--rb-rule); border-radius: 20px; padding: 5px 11px; background: transparent; }
.railblock .card-actions { display: flex; gap: 10px; }
.railblock .card-btn { flex: 1; text-align: center; font-family: "Space Mono", monospace; font-size: 12px; letter-spacing: 0.05em; padding: 12px; border-radius: 3px; cursor: pointer; border: 1px solid var(--rb-ink); transition: 0.15s; text-decoration: none; color: var(--rb-ink); }
.railblock .card-btn.primary { background: var(--rb-ink); color: var(--rb-card); }
.railblock .card-btn.primary:hover { background: var(--line); border-color: var(--line); }
.railblock .card-btn.ghost { background: transparent; }
.railblock .card-btn.ghost:hover { background: #efe9da; }
.railblock .card-foot { font-family: "Space Mono", monospace; font-size: 10px; color: var(--rb-soft); margin-top: 18px; border: 0; padding: 0; display: block; }
