.site-detail { max-width: 900px; margin: 0 auto; padding: 4rem 1.5rem; }
.site-meta { display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; flex-wrap: wrap; }
.site-badge {
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 0.3rem 0.9rem; border-radius: 30px;
}
.badge-preserved { background: rgba(0,56,168,0.15); color: var(--green); border: 1px solid rgba(0,56,168,0.35); }
.badge-attention  { background: rgba(201,147,58,0.15); color: var(--brown-mid); border: 1px solid rgba(201,147,58,0.3); }
.site-region-label { font-size: 0.78rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--gold); }
.site-title { font-family: var(--font-display); font-size: clamp(2rem,5vw,3.2rem); font-weight: 900; color: var(--brown); line-height: 1.1; margin-bottom: 1.25rem; }
.site-intro { font-size: 1.05rem; color: var(--brown-mid); line-height: 1.8; margin-bottom: 2.5rem; border-left: 3px solid var(--gold); padding-left: 1.25rem; }


.feature-block { margin-bottom: 3rem; }
.feature-label {
  font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--brown-light); margin-bottom: 0.9rem; display: flex; align-items: center; gap: 0.5rem;
}
.feature-label::before { content: ''; display: block; width: 20px; height: 1px; background: var(--gold); }
.location-map-wrap {
  border-radius: var(--radius-md); overflow: hidden;
  border: 1px solid rgba(201,147,58,0.2);
  height: 320px; position: relative;
}
.location-map-wrap iframe { width: 100%; height: 100%; border: none; display: block; }
.map-caption {
  display: flex; align-items: center; gap: 0.5rem;
  margin-top: 0.6rem; font-size: 0.8rem; color: var(--brown-light);
}
.map-caption::before {
  content: '';
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: var(--red); flex-shrink: 0;
}


.comparison-slider {
  position: relative; height: 320px; border-radius: var(--radius-md); overflow: hidden;
  cursor: col-resize; user-select: none; touch-action: none;
  border: 1px solid rgba(201,147,58,0.2);
}
.sl-before, .sl-after { position: absolute; inset: 0; }
.sl-after { clip-path: inset(0 50% 0 0); }
.sl-before img, .sl-after img { width: 100%; height: 100%; object-fit: cover; pointer-events: none; }
.sl-tag {
  position: absolute; bottom: 10px;
  font-size: 0.65rem; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 4px; font-weight: 700;
}
.sl-tag-now { right: 10px; background: rgba(201,147,58,0.85); color: var(--brown); }
.sl-tag-then { left: 10px; background: rgba(14,17,32,0.75); color: var(--cream); }
.sl-handle {
  position: absolute; top: 0; bottom: 0; left: 50%;
  transform: translateX(-50%); width: 44px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  pointer-events: none; z-index: 10;
}
.sl-bar { position: absolute; top: 0; bottom: 0; width: 2px; background: var(--cream); left: 50%; transform: translateX(-50%); opacity: 0.85; }
.sl-circle {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--cream); border: 2px solid var(--gold);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; color: var(--brown); box-shadow: var(--shadow-sm); position: relative; z-index: 2;
}

.trivia-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; }
.trivia-card {
  height: 110px; cursor: pointer; perspective: 700px; position: relative;
}
.trivia-front, .trivia-back {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center; text-align: center;
  padding: 1rem; border-radius: var(--radius-sm);
  font-size: 0.88rem; line-height: 1.45;
  backface-visibility: hidden;
  transition: transform 0.55s cubic-bezier(0.4,0,0.2,1);
}
.trivia-front {
  background: var(--cream-dark); color: var(--brown); font-weight: 600;
  border: 1px solid rgba(201,147,58,0.3);
}
.trivia-front::after { content: '↻'; position: absolute; top: 7px; right: 10px; font-size: 0.68rem; color: var(--gold); }
.trivia-back { background: var(--brown); color: var(--cream); transform: rotateY(180deg); }
.trivia-card.flipped .trivia-front { transform: rotateY(-180deg); }
.trivia-card.flipped .trivia-back  { transform: rotateY(0deg); }

.site-big-quote {
  background: var(--brown);
  border-radius: var(--radius-lg);
  padding: 2.5rem;
  margin-top: 3rem;
  position: relative;
  overflow: hidden;
}
.site-big-quote::before {
  content: '"';
  font-family: var(--font-display); font-size: 10rem; line-height: 1;
  color: rgba(201,147,58,0.12);
  position: absolute; top: -1rem; left: 1rem;
  pointer-events: none;
}
.big-quote-text {
  font-family: var(--font-accent); font-style: italic;
  font-size: 1.3rem; color: var(--cream); line-height: 1.75;
  margin-bottom: 1.25rem; position: relative; z-index: 1;
}
.big-quote-meta { font-size: 0.82rem; color: var(--gold); letter-spacing: 0.08em; position: relative; z-index: 1; }

.back-link {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 0.82rem; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--brown-light); margin-bottom: 2rem;
  transition: color var(--transition);
}
.back-link:hover { color: var(--gold); }


.other-sites { background: var(--cream-dark); padding: 4rem 1.5rem; }
.other-sites-grid { max-width: 900px; margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; }
.mini-card {
  background: var(--white); border-radius: var(--radius-md); overflow: hidden;
  border: 1px solid rgba(201,147,58,0.15);
  transition: var(--transition); box-shadow: var(--shadow-sm);
}
.mini-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.mini-card img { width: 100%; height: 120px; object-fit: cover; }
.mini-card-body { padding: 0.9rem 1rem; }
.mini-card-name { font-family: var(--font-display); font-size: 0.95rem; font-weight: 700; color: var(--brown); margin-bottom: 0.3rem; line-height: 1.3; }
.mini-card-link { font-size: 0.75rem; color: var(--gold); font-weight: 600; }

@media (max-width: 600px) {
  .virtual-tour-wrap { height: 280px; }
  .comparison-slider { height: 220px; }
  .trivia-grid { grid-template-columns: 1fr 1fr; }
}