/* ── Situ – Architecture Photo Map ───────────────────────────────────
 * Design tokens from style.css are in scope. Accent = gold (--accent
 * = #cda12c). All former blue (#60a5fa) has been replaced with gold.
 * Naming convention: .situ-* with BEM-ish sub-parts (situ-card__cover).
 * ─────────────────────────────────────────────────────────────────── */

/* ── Full-screen map page layout ──────────────────────────────────── */
body.situ-map-page {
  display: flex; flex-direction: column;
  height: 100vh; overflow: hidden;
}
body.situ-map-page > nav { flex-shrink: 0; }
body.situ-map-page .pb-5 {
  flex: 1; min-height: 0;
  padding-bottom: 0 !important;
  display: flex; flex-direction: column;
  overflow: hidden;
}
body.situ-map-page .situ-shell {
  flex: 1; min-height: 0;
  overflow: hidden;
}
body.situ-map-page .footer {
  flex-shrink: 0;
  margin-top: 0 !important;
}
/* Short viewport: footer would eat into usable map area; hide it.
   Scrolling is not an option — it conflicts with map pan/zoom. */
@media(max-height:580px){
  body.situ-map-page .footer { display: none; }
}

/* ── Map full-screen shell ────────────────────────────────────────── */
.situ-shell {
  display: flex; flex-direction: column;
  position: relative;
}

/* ── Map control bar ──────────────────────────────────────────────── */
.situ-bar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 10px 16px;
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  z-index: 1000; flex-shrink: 0;
}
.situ-bar-left  { display: flex; align-items: center; gap: 10px; }
.situ-bar-right { display: flex; align-items: center; gap: 8px; margin-left: auto; }

.situ-bar-brand {
  font-size: 15px; font-weight: 800;
  color: var(--text-primary); letter-spacing: -.01em;
  display: flex; align-items: center; gap: 7px;
}
.situ-bar-brand i { color: var(--accent); }

.situ-bar-count {
  font-size: 12px; color: var(--text-muted);
  background: var(--bg-surface); border: 1px solid var(--border);
  padding: 2px 9px; border-radius: var(--radius-pill);
}

.situ-bar-filters { display: flex; gap: 8px; flex: 1; justify-content: center; }

.situ-bar-filter-select {
  background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 6px 10px;
  font-size: 12.5px; color: var(--text-secondary);
  font-family: inherit; cursor: pointer;
  transition: border-color .15s, box-shadow .15s;
}
.situ-bar-filter-select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(205,161,44,.18);
}

/* Creator search bar beside the type select */
.situ-bar-creator-search {
  position: relative; display: flex; align-items: center; gap: 4px;
}
.situ-bar-creator-inp {
  background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 6px 10px;
  font-size: 12.5px; color: var(--text-secondary); font-family: inherit;
  width: 180px; outline: none; transition: border-color .15s, box-shadow .15s;
}
.situ-bar-creator-inp:focus {
  border-color: var(--accent); box-shadow: 0 0 0 3px rgba(205,161,44,.18);
}
.situ-bar-creator-clear {
  background: none; border: none; cursor: pointer; color: var(--text-muted);
  font-size: 16px; line-height: 1; padding: 2px 5px; border-radius: 50%;
  transition: color .12s;
}
.situ-bar-creator-clear:hover { color: var(--text-primary); }
.situ-bar-creator-drop {
  position: absolute; top: calc(100% + 5px); left: 0;
  min-width: 220px; max-height: 240px; overflow-y: auto;
  background: var(--bg-card); border: 1px solid var(--border);
  /* UI-46 — keep this inside Situ's own band (1000, with the rest of the bar)
     rather than tying it to the navbar's exact 1100; a 1100-vs-1100 tie would
     resolve by DOM order and could let the navbar paint over the open dropdown. */
  border-radius: var(--radius-md); z-index: 1000;
  box-shadow: 0 8px 24px rgba(0,0,0,.22);
}
.situ-bar-creator-opt {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; cursor: pointer; font-size: 13px;
  color: var(--text-primary); transition: background .12s;
}
.situ-bar-creator-opt:hover,
.situ-bar-creator-opt.is-active { background: var(--bg-surface); }
.situ-bar-creator-opt-logo {
  width: 22px; height: 22px; border-radius: 50%; object-fit: cover;
  flex-shrink: 0;
}

/* Map bar buttons use .arch-btn-ghost / .arch-cta site classes directly */
.situ-bar .arch-btn-ghost,
.situ-bar .arch-cta {
  height: 34px; font-size: 12.5px; padding: 0 13px;
}

#situMap { flex: 1; z-index: 1; }

/* Dark tile tint */
.leaflet-tile { filter: brightness(.85) saturate(.9); }
[data-theme="light"] .leaflet-tile { filter: none; }

/* ── Top-viewed strip ─────────────────────────────────────────────── */
.situ-top-strip {
  position: absolute; top: 12px; left: 12px; right: 12px;
  z-index: 800;
  display: flex; gap: 8px;
  overflow-x: auto; scrollbar-width: none;
  pointer-events: none;
}
.situ-top-strip::-webkit-scrollbar { display: none; }

.situ-top-card {
  pointer-events: all;
  flex-shrink: 0;
  display: flex; align-items: center; gap: 8px;
  padding: 4px 12px 4px 4px;
  background: rgba(10,10,10,.60);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 999px;
  cursor: pointer;
  transition: background .18s, border-color .18s, transform .18s;
  text-align: left;
}
.situ-top-card:hover {
  background: rgba(205,161,44,.22);
  border-color: rgba(205,161,44,.55);
  transform: translateY(-2px);
}

.situ-top-card__thumb {
  width: 26px; height: 26px; border-radius: 50%;
  background-size: cover; background-position: center;
  background-color: var(--bg-surface);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: var(--text-muted);
  flex-shrink: 0;
}

.situ-top-card__title {
  font-size: 12px; font-weight: 600; color: #e8e8e8;
  white-space: nowrap; max-width: 110px;
  overflow: hidden; text-overflow: ellipsis;
}

/* ── Map highlight ring (on hover of top card) ────────────────────── */
.situ-highlight-ring {
  width: 44px; height: 44px; border-radius: 50%;
  border: 2px solid var(--accent);
  animation: situ-ring-pulse 1.2s ease-in-out infinite;
  pointer-events: none;
}
@keyframes situ-ring-pulse {
  0%, 100% { opacity: .9; transform: scale(1); }
  50%       { opacity: .3; transform: scale(1.4); }
}

/* ── Map popup overlay ────────────────────────────────────────────── */
.situ-overlay {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, .55);
  z-index: 1999;
}

/* ── Map popup panel ──────────────────────────────────────────────── */
.situ-popup {
  position: fixed; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 60%;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: 2000; overflow: hidden;
}
.situ-popup-close {
  position: absolute; top: 10px; right: 10px;
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(0,0,0,.45); border: none;
  color: #fff; font-size: 12px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; z-index: 1;
  transition: background .15s;
}
.situ-popup-close:hover { background: rgba(0,0,0,.7); }
.situ-popup-img {
  width: 100%; aspect-ratio: 5/3;
  background: var(--bg-surface);
  background-size: cover; background-position: center;
}
.situ-popup-img.no-photo {
  display: flex; align-items: center; justify-content: center;
  font-size: 48px; color: var(--text-muted);
}
.situ-popup-body { padding: 18px 20px; }
.situ-popup-type {
  font-size: 11px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--accent);
  display: block; margin-bottom: 6px;
}
.situ-popup-title {
  font-size: 18px; font-weight: 800; color: var(--text-primary);
  margin: 0 0 6px; line-height: 1.3;
}
.situ-popup-location {
  font-size: 13px; color: var(--text-muted);
  margin: 0 0 16px; display: flex; align-items: center; gap: 5px;
}
.situ-popup-foot { display: flex; align-items: center; justify-content: space-between; }
.situ-popup-author { font-size: 13px; color: var(--text-muted); }
.situ-popup-cta {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 16px; border-radius: var(--radius-sm);
  background: rgba(205,161,44,.12); border: 1px solid rgba(205,161,44,.28);
  color: var(--accent); font-size: 13px; font-weight: 700;
  text-decoration: none; transition: background .14s;
}
.situ-popup-cta:hover { background: rgba(205,161,44,.22); color: var(--accent-hover); }

/* ── Custom Leaflet markers ───────────────────────────────────────── */
.situ-marker {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2px solid rgba(205,161,44,.6);
  background: var(--bg-card);
  background-size: cover; background-position: center;
  box-shadow: 0 2px 8px rgba(0,0,0,.5);
  cursor: pointer; transition: transform .15s;
}
.situ-marker:hover { transform: scale(1.15); }
.situ-marker.no-photo {
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; color: var(--accent);
  background: rgba(10,13,20,.92);
  border-color: rgba(205,161,44,.5);
}

/* Cluster overrides */
.marker-cluster-small,
.marker-cluster-medium,
.marker-cluster-large { background: rgba(205,161,44,.18); }
.marker-cluster-small div,
.marker-cluster-medium div,
.marker-cluster-large div { background: rgba(205,161,44,.55); color: #fff; font-weight: 700; }

/* ── Explore hero ─────────────────────────────────────────────────── */
.situ-hero {
  background: rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding: 48px 0 36px;
}
.situ-hero__inner.container { min-height: auto; }
.situ-hero__inner {
  display: grid;
  gap: 24px;
  grid-template-columns: minmax(0,1fr) auto;
  align-items: end;
}
.situ-hero__eyebrow {
  display: block;
  font-size: 0.75rem; letter-spacing: .22em;
  text-transform: uppercase; color: var(--accent);
  font-weight: 800; margin-bottom: 6px;
}
.situ-hero__title h1 {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 900; letter-spacing: -0.8px; line-height: 1.1;
  background: linear-gradient(120deg, #cda12c 0%, #ffd35e 50%, #e0c97a 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 8px;
}
.situ-hero__tag {
  color: var(--text-muted); font-size: 1.05rem; max-width: 60ch; line-height: 1.6;
}
.situ-hero__actions {
  display: flex; flex-direction: row; align-items: center; gap: 10px;
}

/* ── Explore filter bar ───────────────────────────────────────────── */
.situ-filters {
  position: sticky; top: 0; z-index: 10;
  background: rgba(14,16,20,.95);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--border);
  padding: 12px 0;
}
[data-theme="light"] .situ-filters {
  background: rgba(245,246,248,.95);
}
.situ-filters .container { min-height: auto; }
.situ-filters__inner {
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
}
.situ-filter-lbl {
  font-size: 0.7rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--text-muted); white-space: nowrap;
}
.situ-filter-pill {
  display: inline-flex; padding: 5px 13px;
  border-radius: var(--radius-pill);
  background: var(--bg-surface); border: 1px solid var(--border);
  color: var(--text-secondary); font-size: 12px; font-weight: 600;
  text-decoration: none;
  transition: background .13s, border-color .13s, color .13s;
  white-space: nowrap;
}
.situ-filter-pill:hover {
  background: rgba(205,161,44,.10); border-color: rgba(205,161,44,.28); color: var(--accent);
}
.situ-filter-pill.is-active {
  background: rgba(205,161,44,.14); border-color: rgba(205,161,44,.35); color: var(--accent);
}

/* ── Explore grid & cards ─────────────────────────────────────────── */
.situ-grid-section {
  padding: 28px 0 60px;
  background: var(--bg-base);
}
.situ-grid-section .container { min-height: auto; }

.situ-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(4, minmax(0,1fr));
}
@media (max-width: 1024px) { .situ-grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 600px)  { .situ-grid { grid-template-columns: 1fr; } }

.situ-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 14px; overflow: hidden;
  display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
  transition: transform .15s var(--ease), border-color .15s, box-shadow .25s var(--ease);
}
.situ-card:hover {
  transform: translateY(-2px);
  border-color: rgba(205,161,44,.4);
  box-shadow: 0 8px 24px rgba(0,0,0,.32);
}

.situ-card__cover {
  display: block; position: relative;
  height: 180px; overflow: hidden;
  background: var(--bg-surface); flex-shrink: 0;
}
.situ-card__cover img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .2s var(--ease);
}
.situ-card:hover .situ-card__cover img { transform: scale(1.04); }
.situ-card__cover-empty {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 2.5rem; color: rgba(205,161,44,.32);
}
.situ-card__badge {
  position: absolute; top: 8px; left: 8px;
  background: rgba(0,0,0,.55); backdrop-filter: blur(4px);
  color: #ffd35e;
  font-size: 0.65rem; font-weight: 800;
  letter-spacing: .06em; text-transform: uppercase;
  padding: 3px 8px; border-radius: var(--radius-pill);
  border: 1px solid rgba(205,161,44,.35);
}
.situ-card__body {
  padding: 14px 16px 16px;
  display: flex; flex-direction: column; gap: 4px;
  flex: 1; min-width: 0;
}
.situ-card__name {
  font-size: 0.95rem; font-weight: 700;
  color: var(--text-primary); margin: 0;
  line-height: 1.3;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.situ-card:hover .situ-card__name { color: var(--accent-hover); }
.situ-card__meta {
  font-size: 0.78rem; color: var(--text-muted); margin: 0;
  display: flex; align-items: center; gap: 4px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.situ-card__meta i { color: var(--accent); flex-shrink: 0; font-size: 0.7rem; }
.situ-card__foot {
  margin-top: auto; padding-top: 10px;
  border-top: 1px solid var(--border);
  display: flex; justify-content: space-between; align-items: center;
}
.situ-card__author { font-size: 11px; color: var(--text-muted); }
.situ-card__votes {
  display: flex; align-items: center; gap: 4px;
  font-size: 11.5px; color: var(--text-muted);
}
.situ-card__votes i { color: var(--accent); font-size: 10px; }


/* Tag-filter note */
.situ-tag-note {
  font-size: 13px; color: var(--text-muted); margin: 0 0 18px;
}
.text-accent  { color: var(--accent); }
.link-accent  { color: var(--accent); text-decoration: none; font-weight: 600; }
.link-accent:hover { text-decoration: underline; }

/* Empty state */
.situ-empty { text-align: center; padding: 60px 24px; }
.situ-empty i { font-size: 3rem; color: var(--text-muted); margin-bottom: 16px; display: block; }
.situ-empty h2 { font-size: 1.1rem; font-weight: 700; color: var(--text-primary); margin: 0 0 6px; }
.situ-empty p  { font-size: 0.88rem; color: var(--text-muted); margin: 0 0 20px; }

/* ── Pin detail — photo gallery ───────────────────────────────────── */
.situ-gallery-cover img {
  width: 100%; max-height: 460px; object-fit: cover;
  border-radius: var(--radius-lg); display: block;
}
.situ-gallery-strip { display: flex; gap: 8px; margin-top: 8px; flex-wrap: wrap; }
.situ-gallery-thumb { display: block; flex-shrink: 0; }
.situ-gallery-thumb img {
  width: 90px; height: 68px; object-fit: cover;
  border-radius: var(--radius-sm); border: 1px solid var(--border); cursor: zoom-in;
  transition: border-color .14s;
}
.situ-gallery-thumb img:hover { border-color: rgba(205,161,44,.5); }

/* Pin head */
.situ-pin-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 10px; margin-bottom: 14px;
}
.situ-type-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: var(--radius-pill);
  background: rgba(205,161,44,.10); border: 1px solid rgba(205,161,44,.25);
  font-size: 11px; font-weight: 700; color: var(--accent);
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: 8px;
}
.situ-pin-title {
  font-size: 22px; font-weight: 800; color: var(--text-primary);
  margin: 0 0 6px; letter-spacing: -.01em; line-height: 1.3;
}
.situ-pin-location {
  font-size: 13px; color: var(--text-muted);
  display: flex; align-items: center; gap: 5px; margin: 0;
}
.situ-pin-location i { color: var(--accent); }
.situ-pin-body {
  font-size: 14.5px; color: var(--text-secondary);
  line-height: 1.8; margin-bottom: 14px;
}
.situ-pin-body p { margin-bottom: 10px; }

/* Tags */
.situ-pin-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.situ-tag-pill {
  display: inline-flex; padding: 2px 9px;
  background: rgba(205,161,44,.08); border: 1px solid rgba(205,161,44,.20);
  border-radius: var(--radius-pill); font-size: 11.5px; font-weight: 600;
  color: var(--accent); text-decoration: none; transition: background .13s;
}
.situ-tag-pill:hover { background: rgba(205,161,44,.18); }

/* Action buttons */
.situ-pin-actions {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding-top: 14px; border-top: 1px solid var(--border);
}
.situ-action-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px; border-radius: var(--radius-pill);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-muted); font-size: 12.5px; font-weight: 600;
  cursor: pointer; transition: background .14s, color .14s, border-color .14s;
}
.situ-action-btn i { font-size: 11px; }
.situ-action-btn:hover {
  background: rgba(205,161,44,.10); color: var(--accent); border-color: rgba(205,161,44,.28);
}
.situ-action-btn.is-active {
  background: rgba(205,161,44,.12); color: var(--accent); border-color: rgba(205,161,44,.35);
}
.situ-action-btn.is-saved.is-active {
  background: rgba(250,204,21,.10); color: #fbbf24; border-color: rgba(250,204,21,.30);
}
.situ-action-stat {
  font-size: 12.5px; color: var(--text-muted);
  display: inline-flex; align-items: center; gap: 5px;
}
.situ-action-edit {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 12.5px; font-weight: 600; color: var(--text-muted);
  text-decoration: none; margin-left: auto;
  transition: color .13s;
}
.situ-action-edit i { font-size: 11px; }
.situ-action-edit:hover { color: var(--accent); }

.situ-flag-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 11px; border-radius: 99px;
  background: transparent; border: 1px solid var(--border);
  color: var(--text-muted); font-size: 12px; font-weight: 600; cursor: pointer;
  margin-left: auto;
  transition: background .14s, color .14s, border-color .14s;
}
.situ-flag-btn i { font-size: 11px; }
.situ-flag-btn:hover { background: rgba(251,146,60,.10); color: #fb923c; border-color: rgba(251,146,60,.30); }
.situ-flag-btn.is-flagged { background: rgba(251,146,60,.12); color: #fb923c; border-color: rgba(251,146,60,.35); }

/* Shared modal (used by edit_pin.html delete confirm + pin_detail.html flag) */
.situ-modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.55);
  display: flex; align-items: center; justify-content: center; padding: 16px;
}
.situ-modal-overlay[hidden] { display: none; }
.situ-modal {
  background: var(--bg-surface); border: 1px solid var(--border); border-radius: 18px;
  width: 100%; max-width: 440px; padding: 26px 28px;
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
}
.situ-modal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.situ-modal-title { font-size: 15px; font-weight: 800; color: var(--text-primary); margin: 0; display: flex; align-items: center; gap: 8px; }
.situ-modal-close { background: transparent; border: none; color: var(--text-muted); font-size: 16px; cursor: pointer; padding: 2px 6px; border-radius: 6px; }
.situ-modal-close:hover { color: var(--text-primary); }
.situ-modal-sub { font-size: 13.5px; color: var(--text-secondary); margin: 0 0 22px; line-height: 1.6; }
.situ-modal-foot { display: flex; gap: 10px; flex-wrap: wrap; }

/* Flag modal (reuses situ-modal) */
.situ-flag-reasons { display: flex; flex-direction: column; gap: 8px; margin-bottom: 22px; }
.situ-flag-option {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-radius: 10px; border: 1px solid var(--border);
  cursor: pointer; font-size: 13.5px; color: var(--text-secondary);
  transition: background .13s, border-color .13s;
}
.situ-flag-option:hover { background: rgba(251,146,60,.06); border-color: rgba(251,146,60,.25); }
.situ-flag-option input[type=radio] { accent-color: #fb923c; width: 15px; height: 15px; flex-shrink: 0; }

/* Mini map */
.situ-detail-map {
  height: 200px; border-radius: var(--radius-sm);
  overflow: hidden; border: 1px solid var(--border);
}
.situ-map-link {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 12.5px; color: var(--accent); text-decoration: none; font-weight: 600;
}
.situ-map-link:hover { text-decoration: underline; }

/* Author card */
.situ-author-link {
  display: flex; align-items: center; gap: 12px;
  text-decoration: none; margin-top: 10px;
}
.situ-author-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  object-fit: cover; border: 1px solid var(--border); flex-shrink: 0;
}
.situ-author-initial {
  background: rgba(205,161,44,.12); border-color: rgba(205,161,44,.25);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 700; color: var(--accent);
}
.situ-author-name { font-size: 13.5px; font-weight: 700; color: var(--text-primary); margin: 0; }
.situ-author-link:hover .situ-author-name { color: var(--accent); }
.situ-author-when { font-size: 11.5px; color: var(--text-muted); margin: 2px 0 0; }

/* Stats */
.situ-stat-row {
  display: flex; justify-content: space-between;
  padding: 7px 0; border-bottom: 1px solid var(--border);
  font-size: 13px; color: var(--text-secondary);
}
.situ-stat-row:last-child { border-bottom: none; }
.situ-stat-row strong { color: var(--text-primary); font-weight: 700; }

/* Nearby */
.situ-nearby-row {
  display: flex; align-items: center; gap: 10px; padding: 7px 0;
  text-decoration: none; border-bottom: 1px solid var(--border);
}
.situ-nearby-row:last-of-type { border-bottom: none; }
.situ-nearby-thumb {
  width: 44px; height: 44px; border-radius: var(--radius-sm);
  object-fit: cover; border: 1px solid var(--border); flex-shrink: 0;
}
.situ-nearby-icon {
  background: var(--bg-surface); color: var(--text-muted);
  display: inline-flex; align-items: center; justify-content: center; font-size: 14px;
}
.situ-nearby-body { min-width: 0; flex: 1; }
.situ-nearby-title {
  font-size: 13px; font-weight: 600; color: var(--text-primary);
  margin: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.situ-nearby-row:hover .situ-nearby-title { color: var(--accent); }
.situ-nearby-loc { font-size: 11px; color: var(--text-muted); margin: 2px 0 0; }

/* ── Add pin form ─────────────────────────────────────────────────── */
.situ-picker-map {
  display: block;
  height: 280px; border-radius: var(--radius-md);
  overflow: hidden; border: 1px solid var(--border);
  margin-top: 8px;
}
.situ-coords-display {
  display: flex; align-items: center; gap: 6px;
  font-size: 12.5px; color: var(--success); margin-top: 6px; font-weight: 600;
}

/* Tag chips preview */
.situ-tag-preview { display: flex; flex-wrap: wrap; gap: 6px; }
.situ-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 9px; border-radius: var(--radius-pill);
  background: rgba(205,161,44,.10); border: 1px solid rgba(205,161,44,.22);
  font-size: 12px; font-weight: 600; color: var(--accent);
}

/* Photo preview thumbnails */
.situ-photo-preview { display: flex; flex-wrap: wrap; gap: 8px; }
.situ-photo-preview img {
  width: 72px; height: 72px; object-fit: cover;
  border-radius: var(--radius-sm); border: 1px solid var(--border);
}

/* Tips list */
.situ-tips {
  font-size: 13px; color: var(--text-secondary);
  line-height: 1.75; padding-left: 18px; margin: 10px 0 0;
}
.situ-tips li { margin-bottom: 4px; }

/* ── Comments ─────────────────────────────────────────────────────── */
.situ-comments { display: flex; flex-direction: column; gap: 14px; margin-bottom: 4px; }
.situ-comment { display: flex; gap: 10px; align-items: flex-start; }
.situ-comment-avatar {
  width: 30px; height: 30px; border-radius: 50%; object-fit: cover;
  border: 1px solid var(--border); flex-shrink: 0;
}
.situ-comment-initial {
  background: rgba(96,165,250,.12); border-color: rgba(96,165,250,.25);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; color: #60a5fa;
}
.situ-comment-body-wrap { flex: 1; min-width: 0; }
.situ-comment-meta { display: flex; align-items: center; gap: 7px; margin-bottom: 3px; }
.situ-comment-author {
  font-size: 12.5px; font-weight: 700; color: var(--text-primary);
  text-decoration: none;
}
.situ-comment-author:hover { color: var(--accent); }
.situ-comment-time { font-size: 11.5px; color: var(--text-muted); }
.situ-comment-text { font-size: 13.5px; color: var(--text-secondary); margin: 0; line-height: 1.55; }
.situ-comment-actions { display: inline-flex; gap: 10px; margin-inline-start: auto; }
.situ-comment-act {
  background: none; border: none; padding: 0; cursor: pointer; font: inherit;
  font-size: 11px; font-weight: 600; color: var(--text-muted); transition: color .14s;
}
.situ-comment-act:hover { color: var(--text-primary); }
.situ-comment-act.is-del:hover { color: #e57373; }
.situ-comment-edit-box { display: flex; gap: 8px; align-items: center; margin-top: 4px; }
.situ-comment-edit-input {
  flex: 1; min-width: 0; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 6px 10px; font-size: 13px; color: var(--text-primary); font-family: inherit;
}
.situ-comment-edit-input:focus { outline: none; border-color: rgba(96,165,250,.45); }
.situ-comment-edit-save, .situ-comment-edit-cancel {
  background: none; border: none; cursor: pointer; font: inherit;
  font-size: 11.5px; font-weight: 600; padding: 4px; white-space: nowrap;
}
.situ-comment-edit-save { color: var(--accent); }
.situ-comment-edit-cancel { color: var(--text-muted); }

.situ-comment-form {}
.situ-comment-row { display: flex; align-items: center; gap: 8px; }
.situ-comment-input {
  flex: 1; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 10px; padding: 8px 12px; font-size: 13px;
  color: var(--text-primary); outline: none; transition: border-color .14s;
}
.situ-comment-input::placeholder { color: var(--text-muted); }
.situ-comment-input:focus { border-color: rgba(96,165,250,.45); }
.situ-comment-login { font-size: 13px; color: var(--text-muted); margin: 10px 0 0; }
.situ-comment-login a { color: var(--accent); text-decoration: none; }
.situ-comment-login a:hover { text-decoration: underline; }

/* ── Responsive ───────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .situ-hero__inner { grid-template-columns: 1fr; }
  .situ-hero__actions { flex-direction: row; align-items: flex-start; }
}
@media (max-width: 600px) {
  .situ-bar-filters { display: none; }
  .situ-popup { width: 92%; }
}
