/* Wrapper */
.tmp-wrap { max-width: 1200px; margin: 0 auto; }
.tmp-list { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 1024px) { .tmp-list { grid-template-columns: 1fr 1fr; } }
.tmp-entry { border: 1px solid #e5e7eb; border-radius: 8px; padding: 12px; background: #fff; }
.tmp-top { margin-bottom: 10px; }
.tmp-top .tmp-name { font-weight: 600; }
.tmp-top .tmp-date { color: #6b7280; font-size: 0.9rem; font-weight: 500; margin-top: 4px; }
.tmp-top .tmp-desc { font-style: italic; margin-top: 6px; }
.tmp-row { display: flex; gap: 10px; align-items: stretch; }
.tmp-map-box, .tmp-photo-box { flex: 1; height: 220px; border: 1px solid #e5e7eb; background: #fff; position: relative; overflow: hidden; border-radius: 6px; }
.tmp-map-inner, .tmp-photo-inner { width: 100%; height: 100%; }
.tmp-photo-box img { width: 100%; height: 100%; object-fit: cover; display: block; cursor: pointer; }
.tmp-scroll-toggle { position: absolute; right: 10px; bottom: 10px; z-index: 5; background: #fff; border: 1px solid #e5e7eb; padding: 6px 8px; font-size: 12px; cursor: pointer; border-radius: 4px; box-shadow: 0 1px 2px rgba(0,0,0,.08); }
.tmp-pagination { text-align: center; padding: 10px 0 0; }
.tmp-loadmore { display: inline-block; padding: 10px 16px; border: 1px solid #e5e7eb; border-radius: 6px; background: #fff; cursor: pointer; }
.tmp-loadmore:hover { background: #f9fafb; }
.tmp-lightbox { position: fixed; inset: 0; background: rgba(0,0,0,.85); z-index: 99999; display: flex; align-items: center; justify-content: center; }
.tmp-lightbox-inner img { max-width: 90vw; max-height: 90vh; display: block; margin: 0 auto; }
.tmp-lightbox-close { position: absolute; top: 20px; right: 28px; font-size: 36px; background: none; border: none; color: #fff; cursor: pointer; }
.tmp-lightbox-nav { position: absolute; top: 50%; transform: translateY(-50%); font-size: 40px; color: #fff; background: none; border: none; cursor: pointer; padding: 10px; }
.tmp-left { left: 20px; } .tmp-right { right: 20px; }
@media (max-width: 900px) { .tmp-row { flex-direction: column; } .tmp-map-box, .tmp-photo-box { height: 240px; } }
