.spots-page{padding:var(--page-content-py) var(--container-padding) 60px;min-height:100vh}.spots-inner{max-width:var(--container-max);margin-left:auto;margin-right:auto;width:100%}.spots-toolbar{position:sticky;top:var(--header-height-sm);z-index:90;background:var(--bg);padding:16px 0;margin-bottom:24px;border-bottom:1px solid var(--border)}@media (min-width: 640px){.spots-toolbar{top:var(--header-height-md)}}@media (min-width: 768px){.spots-toolbar{top:var(--header-height-lg)}}.spots-toolbar-inner{display:flex;flex-direction:column;gap:12px}.spots-search{position:relative}.spots-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.spots-search-input{width:100%;padding:12px 14px 12px 42px;font-size:.9375rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);transition:border-color .15s ease,box-shadow .15s ease}.spots-search-input::placeholder{color:var(--text-muted)}.spots-search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}.spots-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.spots-filter-group{display:flex;align-items:center;gap:6px}.spots-filter-label{font-size:.75rem;font-weight:600;color:var(--text-muted);flex-shrink:0}.spots-filter-select{padding:8px 32px 8px 12px;font-size:.8125rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center;background-size:12px;color:var(--text);cursor:pointer;appearance:none;-webkit-appearance:none}.spots-filter-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}.spots-filter-checks{display:flex;flex-wrap:wrap;gap:4px}.spots-filter-check{display:flex;align-items:center;cursor:pointer}.spots-filter-check input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.spots-filter-check-label{display:inline-block;padding:6px 12px;font-size:.75rem;font-weight:600;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:16px;transition:all .15s ease;user-select:none}.spots-filter-check input:checked+.spots-filter-check-label{color:var(--primary);background:var(--primary-soft);border-color:var(--primary)}.spots-filter-check:hover .spots-filter-check-label{border-color:var(--text-muted)}.spots-filter-check input:focus-visible+.spots-filter-check-label{outline:2px solid var(--ring);outline-offset:1px}.spots-count{margin-left:auto;font-size:.8125rem;color:var(--text-muted);background:var(--surface-2);padding:6px 12px;border-radius:20px;font-weight:600}.spots-count strong{color:var(--text)}.spots-grid{display:grid;grid-template-columns:1fr;gap:16px}@media (min-width: 600px){.spots-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 900px){.spots-grid{grid-template-columns:repeat(3,1fr)}}.spots-empty{grid-column:1 / -1;text-align:center;padding:60px 20px;color:var(--text-muted)}.spots-empty-icon{margin-bottom:12px;opacity:.5;color:var(--text-muted)}.spots-empty p{font-size:.9375rem}.spot-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:box-shadow .15s ease,border-color .15s ease,transform .15s ease;display:flex;flex-direction:column}.spot-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary);transform:translateY(-2px)}.spot-card:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.spot-card-thumb{width:100%;height:120px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;overflow:hidden}.spot-card-thumb img{width:100%;height:100%;object-fit:cover}.spot-card-thumb-placeholder{opacity:.4;color:var(--text-muted)}.spot-card-body{padding:14px 16px;flex:1;display:flex;flex-direction:column;gap:8px}.spot-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.spot-card-name{font-size:.9375rem;font-weight:700;color:var(--text);line-height:1.4}.spot-card-badge{font-size:.625rem;font-weight:700;padding:3px 8px;border-radius:12px;flex-shrink:0;white-space:nowrap}.spot-card-badge.cat-toilet{background:#dbeafe;color:#1d4ed8}.spot-card-badge.cat-rest{background:#d1fae5;color:#065f46}.spot-card-badge.cat-convenience{background:#fef3c7;color:#92400e}.spot-card-badge.cat-food{background:#fce7f3;color:#9d174d}.spot-card-badge.cat-landmark{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.spot-card-badge.cat-worship{background:#fee2e2;color:#991b1b}.spot-card-area{font-size:.75rem;color:var(--text-muted)}.spot-card-desc{font-size:.8125rem;color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.spot-card-footer{display:flex;gap:8px;margin-top:auto;padding-top:8px}.spot-card-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:8px 12px;font-size:.75rem;font-weight:600;border-radius:var(--radius-sm);text-decoration:none;transition:background .15s ease}.spot-card-btn-detail{background:var(--primary);color:#fff}.spot-card-btn-detail:hover{background:var(--color-primary-dark);text-decoration:none}.spot-card-btn-map{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.spot-card-btn-map:hover{background:var(--border);text-decoration:none}.spot-card.is-featured{border-color:var(--accent)}.spot-card.is-featured:before{content:"";display:block;height:3px;background:var(--accent)}.spot-card-featured{position:absolute;top:8px;right:8px;font-size:.625rem;font-weight:700;padding:3px 8px;border-radius:10px;background:var(--accent);color:#fff}.spot-card-status{font-size:.625rem;font-weight:700;padding:3px 8px;border-radius:10px;background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.spot-card-far{font-size:.625rem;font-weight:700;padding:3px 8px;border-radius:10px;background:#ede9fe;color:#6d28d9;border:1px solid #A78BFA}.spot-modal-overlay{position:fixed;inset:0;z-index:1000;background:#00000080;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;display:flex;align-items:center;justify-content:center;padding:16px}.spot-modal-overlay.is-open{opacity:1;visibility:visible}.spot-modal{background:var(--surface);width:100%;max-width:500px;max-height:min(90vh,600px);border-radius:var(--radius-lg);transform:translateY(20px) scale(.95);opacity:0;transition:transform .3s ease,opacity .3s ease;overflow:hidden;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom,0)}.spot-modal-overlay.is-open .spot-modal{transform:translateY(0) scale(1);opacity:1}@media (max-width: 599px){.spot-modal-overlay{padding:12px}.spot-modal{max-height:min(85vh,560px)}}.spot-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.spot-modal-title{font-size:1rem;font-weight:700;color:var(--text)}.spot-modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:var(--surface-2);border-radius:50%;cursor:pointer;color:var(--text-muted);transition:background .15s ease,color .15s ease}.spot-modal-close:hover{background:var(--border);color:var(--text)}.spot-modal-body{padding:20px;overflow-y:auto;flex:1}.spot-modal-image{width:100%;height:180px;background:var(--surface-2);border-radius:var(--radius-sm);margin-bottom:20px;display:flex;align-items:center;justify-content:center;overflow:hidden}.spot-modal-image img{width:100%;height:100%;object-fit:cover}.spot-modal-image-placeholder{opacity:.3;color:var(--text-muted)}.spot-modal-slider{margin-bottom:16px}.spot-modal-slider-main{position:relative;width:100%;aspect-ratio:16 / 10;background:var(--surface-2);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:8px}.spot-modal-slider-img{width:100%;height:100%;object-fit:cover;display:block}.spot-modal-slider-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;opacity:.7;transition:opacity .15s ease,background .15s ease}.spot-modal-slider-nav:hover{opacity:1;background:#000000b3}.spot-modal-slider-prev{left:8px}.spot-modal-slider-next{right:8px}.spot-modal-slider-thumbs{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px}.spot-modal-slider-thumb{flex-shrink:0;width:48px;height:48px;padding:0;border:2px solid transparent;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface-2);cursor:pointer;opacity:.6;transition:opacity .15s ease,border-color .15s ease}.spot-modal-slider-thumb:hover{opacity:.9}.spot-modal-slider-thumb.is-active{opacity:1;border-color:var(--primary)}.spot-modal-slider-thumb img{width:100%;height:100%;object-fit:cover;display:block}.spot-modal-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.spot-modal-badge{font-size:.6875rem;font-weight:700;padding:4px 10px;border-radius:14px}.spot-modal-badge.cat-toilet{background:#dbeafe;color:#1d4ed8}.spot-modal-badge.cat-rest{background:#d1fae5;color:#065f46}.spot-modal-badge.cat-convenience{background:#fef3c7;color:#92400e}.spot-modal-badge.cat-food{background:#fce7f3;color:#9d174d}.spot-modal-badge.cat-landmark{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.spot-modal-badge.cat-worship{background:#fee2e2;color:#991b1b}.spot-modal-area{font-size:.75rem;color:var(--text-muted);background:var(--surface-2);padding:4px 10px;border-radius:14px}.spot-modal-desc{font-size:.9375rem;color:var(--text);line-height:1.7;margin-bottom:20px}.spot-modal-info{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.spot-modal-info-row{display:flex;align-items:flex-start;gap:12px}.spot-modal-info-icon{flex-shrink:0;width:20px;color:var(--text-muted)}.spot-modal-info-text{font-size:.875rem;color:var(--text)}.spot-modal-footer{padding:16px 20px;border-top:1px solid var(--border);flex-shrink:0;display:flex;gap:10px}.spot-modal-detail-btn,.spot-modal-map-btn{display:flex;align-items:center;justify-content:center;gap:6px;flex:1;padding:12px 16px;font-size:.875rem;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;text-decoration:none;transition:background .15s ease,opacity .15s ease}.spot-modal-detail-btn{background:var(--primary);color:#fff}.spot-modal-detail-btn:hover{background:var(--color-primary-dark);text-decoration:none}.spot-modal-map-btn{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.spot-modal-map-btn:hover{background:var(--border);text-decoration:none}.spot-modal-status{font-size:.6875rem;font-weight:700;padding:4px 10px;border-radius:14px;background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.spot-modal-status.planned{background:#fef3c7;color:#92400e;border-color:#f59e0b}.spot-modal-far{font-size:.6875rem;font-weight:700;padding:4px 10px;border-radius:14px;background:#ede9fe;color:#6d28d9;border:1px solid #A78BFA}.spot-modal-planned-notice{display:flex;align-items:flex-start;gap:10px;background:#fef3c7;border:1px solid #F59E0B;border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:16px;font-size:.8125rem;color:#92400e}.spot-modal-planned-notice-icon{flex-shrink:0}.spot-modal-detail-btn.is-disabled{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border);pointer-events:none;opacity:.7;cursor:not-allowed}.spot-modal-handle{display:flex;justify-content:center;padding:8px 0 4px}.spot-modal-handle-bar{width:40px;height:4px;background:var(--border);border-radius:2px}@media (min-width: 600px){.spot-modal-handle{display:none}}.spots-note{margin-top:40px;padding-top:20px;border-top:1px solid var(--border)}.spots-note p{font-size:.8125rem;color:var(--text-muted)}.spots-mobile-controls{display:none}@media (max-width: 599px){.spots-mobile-controls{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.spots-mobile-search{width:100%;position:relative}.spots-toolbar{display:none}.spots-filter-rows{display:flex;flex-direction:column;gap:8px}.spots-filter-row{display:flex;align-items:center;gap:10px;width:100%;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease,border-color .15s ease;text-align:left}.spots-filter-row:hover,.spots-filter-row:focus{background:var(--surface-2);border-color:var(--text-muted);outline:none}.spots-filter-row:active{transform:scale(.99)}.spots-filter-row-icon{flex-shrink:0;color:var(--text-muted)}.spots-filter-row-label{flex-shrink:0;font-size:.875rem;font-weight:600;color:var(--text)}.spots-filter-row-value{flex:1;font-size:.8125rem;color:var(--text-muted);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.spots-filter-row-value.has-selection{color:var(--primary);font-weight:600}.spots-filter-row-arrow{flex-shrink:0;color:var(--text-muted);opacity:.6}.spots-subbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0}.spots-count-mobile{font-size:.8125rem;color:var(--text-muted)}.spots-count-mobile strong{color:var(--text);font-weight:700}.spots-subbar-sort{display:flex;align-items:center}.spots-sort-select-mobile{padding:6px 28px 6px 10px;font-size:.75rem;font-weight:600;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 8px center;background-size:12px;color:var(--text);cursor:pointer;appearance:none;-webkit-appearance:none}.spots-sort-select-mobile:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--ring)}}@media (min-width: 600px){.spots-count-mobile,.spots-subbar,.spots-filter-rows{display:none}}.spots-active-filters{display:none}@media (max-width: 599px){.spots-active-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.spots-active-filters:empty{display:none;margin-bottom:0}.spots-active-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;font-size:.75rem;font-weight:600;background:var(--primary-soft);color:var(--primary);border:1px solid var(--primary);border-radius:16px}.spots-active-chip-remove{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;background:transparent;border:none;color:var(--primary);cursor:pointer;border-radius:50%;transition:background .15s ease}.spots-active-chip-remove:hover{background:#0000001a}}.filter-sheet-overlay{position:fixed;inset:0;z-index:1000;background:#00000080;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.filter-sheet-overlay.is-open{opacity:1;visibility:visible}.filter-sheet{position:fixed;bottom:0;left:0;right:0;z-index:1001;background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:85vh;transform:translateY(100%);transition:transform .3s ease;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom,0)}.filter-sheet-overlay.is-open .filter-sheet{transform:translateY(0)}.filter-sheet-handle{display:flex;justify-content:center;padding:8px 0 4px}.filter-sheet-handle-bar{width:40px;height:4px;background:var(--border);border-radius:2px}.filter-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px 16px;border-bottom:1px solid var(--border)}.filter-sheet-title{font-size:1rem;font-weight:700;color:var(--text)}.filter-sheet-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:var(--surface-2);border-radius:50%;cursor:pointer;color:var(--text-muted);transition:background .15s ease,color .15s ease}.filter-sheet-close:hover{background:var(--border);color:var(--text)}.filter-sheet-body{padding:20px;overflow-y:auto;flex:1}.filter-sheet-section{margin-bottom:24px}.filter-sheet-section:last-child{margin-bottom:0}.filter-sheet-section-title{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}.filter-sheet-checks{display:flex;flex-wrap:wrap;gap:8px}.filter-sheet-footer{padding:16px 20px;border-top:1px solid var(--border);display:flex;gap:12px}.filter-sheet-apply-btn{flex:1;padding:14px 24px;font-size:.9375rem;font-weight:600;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease}.filter-sheet-apply-btn:hover{background:var(--color-primary-dark)}.filter-sheet-reset-btn{padding:14px 20px;font-size:.875rem;font-weight:600;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease}.filter-sheet-reset-btn:hover{background:var(--surface-2)}.filter-sheet-list{display:flex;flex-direction:column;gap:0}.filter-sheet-list-item{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s ease}.filter-sheet-list-item:last-child{border-bottom:none}.filter-sheet-list-item:hover{background:var(--surface-2)}.filter-sheet-list-item:active{background:var(--border)}.filter-sheet-list-item input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.filter-sheet-list-checkbox{flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border);border-radius:4px;background:var(--surface);color:transparent;transition:all .15s ease}.filter-sheet-list-item input:checked+.filter-sheet-list-checkbox{background:var(--primary);border-color:var(--primary);color:#fff}.filter-sheet-list-label{flex:1;font-size:.9375rem;color:var(--text)}.filter-sheet-list-item input:checked~.filter-sheet-list-label{font-weight:600}.filter-sheet-hint{margin-top:8px;font-size:.75rem;color:var(--text-muted);line-height:1.4}@media (min-width: 600px){.filter-sheet-overlay{display:none!important}}.spots-open-now-toggle{display:flex;align-items:center;gap:10px;cursor:pointer}.spots-open-now-label{font-size:.875rem;font-weight:600;color:var(--text)}.spots-toggle-switch{position:relative;width:44px;height:24px;background:var(--border);border-radius:12px;transition:background .2s ease;flex-shrink:0}.spots-toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;transition:transform .2s ease}.spots-open-now-toggle input{position:absolute;opacity:0;width:0;height:0}.spots-open-now-toggle input:checked+.spots-toggle-switch{background:var(--primary)}.spots-open-now-toggle input:checked+.spots-toggle-switch:after{transform:translate(20px)}.spots-open-now-toggle input:focus-visible+.spots-toggle-switch{outline:2px solid var(--ring);outline-offset:2px}.spots-filter-group-open-now{display:none}@media (min-width: 600px){.spots-filter-group-open-now{display:flex;align-items:center;gap:8px;margin-left:8px;padding-left:12px;border-left:1px solid var(--border)}.spots-open-now-toggle-desktop{display:flex;align-items:center;gap:8px;cursor:pointer}.spots-open-now-toggle-desktop .spots-open-now-label{font-size:.75rem}.spots-open-now-toggle-desktop .spots-toggle-switch{width:36px;height:20px;border-radius:10px}.spots-open-now-toggle-desktop .spots-toggle-switch:after{width:16px;height:16px}.spots-open-now-toggle-desktop input:checked+.spots-toggle-switch:after{transform:translate(16px)}}@media (max-width: 599px){.spots-filters{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;-webkit-overflow-scrolling:touch}.spots-filter-group{flex-shrink:0}.spots-count{display:none}}.spot-detail-page{padding:var(--page-content-py) var(--container-padding) 60px;min-height:100vh}.spot-detail-inner{max-width:700px;margin-left:auto;margin-right:auto;width:100%}.spot-detail-hero{width:100%;height:220px;background:var(--surface-2);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:24px}.spot-detail-hero-img{width:100%;height:100%;object-fit:cover}.spot-detail-hero-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.spot-detail-hero-icon,.spot-detail-hero-placeholder .icon{opacity:.3;color:var(--text-muted)}@media (min-width: 640px){.spot-detail-hero{height:280px}}.spot-detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:24px}.spot-detail-badge{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:700;padding:6px 14px;border-radius:16px}.spot-detail-badge.cat-toilet{background:#dbeafe;color:#1d4ed8}.spot-detail-badge.cat-rest{background:#d1fae5;color:#065f46}.spot-detail-badge.cat-convenience{background:#fef3c7;color:#92400e}.spot-detail-badge.cat-food{background:#fce7f3;color:#9d174d}.spot-detail-badge.cat-landmark{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.spot-detail-badge.cat-worship{background:#fee2e2;color:#991b1b}.spot-detail-area-link{font-size:.8125rem;color:var(--primary);text-decoration:none}.spot-detail-area-link:hover{text-decoration:underline}.spot-detail-status{font-size:.6875rem;font-weight:700;padding:4px 10px;border-radius:10px;background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.spot-detail-section{margin-bottom:28px}.spot-detail-section-title{font-size:.875rem;font-weight:700;color:var(--text-muted);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.spot-detail-desc{font-size:.9375rem;color:var(--text);line-height:1.8}.spot-detail-desc p{margin-bottom:12px}.spot-detail-desc p:last-child{margin-bottom:0}.spot-detail-address{font-size:.9375rem;color:var(--text);line-height:1.6}.spot-detail-gallery{margin-bottom:28px}.spot-gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:12px}@media (min-width: 500px){.spot-gallery-grid{grid-template-columns:repeat(3,1fr)}}.spot-gallery-btn{display:block;width:100%;padding:0;border:none;background:none;cursor:pointer;border-radius:var(--radius-sm);overflow:hidden;transition:transform .15s ease,box-shadow .15s ease}.spot-gallery-btn:hover{transform:scale(1.02);box-shadow:var(--shadow-md)}.spot-gallery-btn:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.spot-gallery-img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius-sm);background:var(--surface-2)}body.lightbox-open{overflow:hidden;position:fixed;width:100%;top:calc(-1 * var(--scroll-y, 0px))}.lightbox-overlay{position:fixed;inset:0;z-index:1000;background:#000000eb;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.lightbox-overlay.is-open{opacity:1;visibility:visible}.lightbox-content{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.lightbox-close{position:absolute;top:16px;right:16px;z-index:10;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:background .15s ease}.lightbox-close:hover{background:#fff3}.lightbox-close:focus-visible{outline:2px solid #fff;outline-offset:2px}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:background .15s ease}.lightbox-nav:hover{background:#ffffff40}.lightbox-nav:focus-visible{outline:2px solid #fff;outline-offset:2px}.lightbox-prev{left:16px}.lightbox-next{right:16px}.lightbox-image-wrap{max-width:calc(100% - 120px);max-height:calc(100% - 100px);display:flex;align-items:center;justify-content:center}.lightbox-img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:var(--radius-sm);box-shadow:0 4px 32px #0006}.lightbox-counter{position:absolute;bottom:20px;left:50%;transform:translate(-50%);font-size:.875rem;color:#ffffffb3;background:#00000080;padding:6px 16px;border-radius:20px}@media (max-width: 600px){.lightbox-nav{width:40px;height:40px}.lightbox-prev{left:8px}.lightbox-next{right:8px}.lightbox-image-wrap{max-width:calc(100% - 80px)}}.spot-gallery-attribution{font-size:.625rem;color:var(--text-muted);margin-top:4px;line-height:1.3}.spot-gallery-attribution a{color:var(--text-muted);text-decoration:underline}.spot-gallery-attribution a:hover{color:var(--primary)}.spot-gallery-note{font-size:.75rem;color:var(--text-muted);margin:0}.spot-detail-map-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;font-size:.9375rem;font-weight:600;background:var(--primary);color:#fff;border-radius:var(--radius-sm);text-decoration:none;transition:background .15s ease}.spot-detail-map-btn:hover{background:var(--color-primary-dark);text-decoration:none}.spot-detail-map-note{font-size:.8125rem;color:#92400e;margin-top:12px}.spot-detail-note{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 18px;margin-top:32px}.spot-detail-note p{font-size:.8125rem;color:var(--text-muted);margin:0}.spot-detail-nav{display:flex;flex-wrap:wrap;gap:12px;margin-top:40px;padding-top:24px;border-top:1px solid var(--border)}.spot-detail-back{display:inline-flex;align-items:center;gap:6px;font-size:.875rem;color:var(--primary);text-decoration:none}.spot-detail-back:hover{text-decoration:underline}.spot-detail-planned-banner{display:flex;align-items:flex-start;gap:12px;background:#fef3c7;border:1px solid #F59E0B;border-radius:var(--radius-md);padding:16px 20px;margin-bottom:24px}.spot-detail-planned-icon,.spot-detail-planned-banner .icon{flex-shrink:0;color:#92400e}.spot-detail-planned-text{display:flex;flex-direction:column;gap:4px}.spot-detail-planned-text strong{font-size:.9375rem;font-weight:700;color:#92400e}.spot-detail-planned-text span{font-size:.8125rem;color:#b45309}.spot-detail-status.planned{font-size:.6875rem;font-weight:700;padding:4px 10px;border-radius:10px;background:#fef3c7;color:#92400e;border:1px solid #F59E0B}.spot-detail-status.far{font-size:.6875rem;font-weight:700;padding:4px 10px;border-radius:10px;background:#ede9fe;color:#6d28d9;border:1px solid #A78BFA}.spot-detail-updated{font-size:.75rem;color:var(--text-muted)}.spot-detail-article{margin-bottom:32px;line-height:1.8;color:var(--text)}.spot-detail-article h2{font-size:1.25rem;font-weight:700;color:var(--text);margin:32px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--primary)}.spot-detail-article h2:first-child{margin-top:0}.spot-detail-article h3{font-size:1.0625rem;font-weight:700;color:var(--text);margin:24px 0 12px}.spot-detail-article p{font-size:.9375rem;margin-bottom:16px}.spot-detail-article ul,.spot-detail-article ol{font-size:.9375rem;margin:16px 0;padding-left:24px}.spot-detail-article li{margin-bottom:8px}.spot-detail-article strong{font-weight:700;color:var(--text)}.spot-detail-article a{color:var(--primary);text-decoration:underline}.spot-detail-article a:hover{text-decoration:none}.spot-detail-article blockquote{margin:20px 0;padding:16px 20px;background:var(--surface-2);border-left:4px solid var(--primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:.9375rem;color:var(--text)}.spot-detail-article blockquote p:last-child{margin-bottom:0}.spot-detail-article table{width:100%;margin:20px 0;border-collapse:collapse;font-size:.875rem}.spot-detail-article th,.spot-detail-article td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}.spot-detail-article th{font-weight:700;background:var(--surface-2)}.spot-detail-article tr:hover td{background:var(--surface-2)}.spot-detail-article code{font-family:monospace;font-size:.875em;background:var(--surface-2);padding:2px 6px;border-radius:4px}.spot-detail-article hr{margin:32px 0;border:none;border-top:1px solid var(--border)}.spot-detail-no-article{display:flex;align-items:flex-start;gap:14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px 24px;margin-bottom:24px}.spot-detail-no-article-icon,.spot-detail-no-article .icon{flex-shrink:0;color:var(--text-muted)}.spot-detail-no-article-text{display:flex;flex-direction:column;gap:4px}.spot-detail-no-article-text strong{font-size:.9375rem;font-weight:700;color:var(--text)}.spot-detail-no-article-text span{font-size:.8125rem;color:var(--text-muted)}.spot-detail-fallback{margin-top:16px}.spot-related{margin-top:40px}.spot-related-grid{display:grid;grid-template-columns:1fr;gap:12px}@media (min-width: 480px){.spot-related-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 640px){.spot-related-grid{grid-template-columns:repeat(3,1fr)}}.spot-related-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;text-decoration:none;transition:box-shadow .15s ease,border-color .15s ease,transform .15s ease}.spot-related-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary);transform:translateY(-2px);text-decoration:none}.spot-related-thumb{width:100%;height:80px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;overflow:hidden}.spot-related-thumb img{width:100%;height:100%;object-fit:cover}.spot-related-thumb-placeholder{opacity:.4;color:var(--text-muted)}.spot-related-body{padding:10px 12px;display:flex;flex-direction:column;gap:6px}.spot-related-name{font-size:.8125rem;font-weight:700;color:var(--text);line-height:1.3}.spot-related-badge{font-size:.5625rem;font-weight:700;padding:2px 6px;border-radius:8px;width:fit-content}.spot-related-badge.cat-toilet{background:#dbeafe;color:#1d4ed8}.spot-related-badge.cat-rest{background:#d1fae5;color:#065f46}.spot-related-badge.cat-convenience{background:#fef3c7;color:#92400e}.spot-related-badge.cat-food{background:#fce7f3;color:#9d174d}.spot-related-badge.cat-landmark{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.spot-related-badge.cat-worship{background:#fee2e2;color:#991b1b}.spot-related-desc{font-size:.6875rem;color:var(--text-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.spot-card-dev-info{margin-top:4px}.spot-card-dev-badge{display:inline-block;font-size:.625rem;font-weight:600;padding:3px 8px;border-radius:8px;background:#d1fae5;color:#065f46}.spot-card-dev-btn{display:inline-flex;align-items:center;gap:4px;font-size:.625rem;font-weight:600;padding:4px 10px;border-radius:8px;background:#fef3c7;color:#92400e;border:1px solid #F59E0B;cursor:pointer;transition:background .15s ease}.spot-card-dev-btn:hover{background:#fde68a}.spot-template-overlay{position:fixed;inset:0;z-index:1100;background:#0009;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;display:flex;align-items:center;justify-content:center;padding:16px}.spot-template-overlay.is-open{opacity:1;visibility:visible}.spot-template-modal{background:var(--surface);width:100%;max-width:640px;max-height:85vh;border-radius:var(--radius-lg);transform:translateY(20px) scale(.95);opacity:0;transition:transform .3s ease,opacity .3s ease;overflow:hidden;display:flex;flex-direction:column;border:2px solid #F59E0B}.spot-template-overlay.is-open .spot-template-modal{transform:translateY(0) scale(1);opacity:1}.spot-template-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fef3c7;border-bottom:1px solid #F59E0B;flex-shrink:0}.spot-template-title{font-size:.9375rem;font-weight:700;color:#92400e}.spot-template-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:#0000001a;border-radius:50%;cursor:pointer;color:#92400e;transition:background .15s ease}.spot-template-close:hover{background:#0003}.spot-template-body{padding:16px 20px;overflow-y:auto;flex:1}.spot-template-path{font-size:.75rem;font-family:monospace;color:var(--text-muted);background:var(--surface-2);padding:8px 12px;border-radius:var(--radius-sm);margin-bottom:12px}.spot-template-code{font-size:.75rem;font-family:monospace;line-height:1.6;background:#1e293b;color:#e2e8f0;padding:16px;border-radius:var(--radius-sm);overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;max-height:400px;overflow-y:auto}.spot-template-footer{padding:16px 20px;border-top:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;gap:12px}.spot-template-copy-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;font-size:.875rem;font-weight:600;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease}.spot-template-copy-btn:hover{background:var(--color-primary-dark)}.spot-template-copied{font-size:.8125rem;color:#065f46;font-weight:600;display:none}.intent-modal-overlay{position:fixed;inset:0;z-index:1000;background:#00000080;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.intent-modal-overlay.is-open{opacity:1;visibility:visible}.intent-modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:400px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003;transform:translateY(20px);transition:transform .2s ease}.intent-modal-overlay.is-open .intent-modal{transform:translateY(0)}.intent-modal-header{padding:24px 24px 16px;text-align:center}.intent-modal-title{font-size:1.25rem;font-weight:800;color:var(--text);margin:0 0 8px}.intent-modal-desc{font-size:.875rem;color:var(--text-muted);margin:0;line-height:1.5}.intent-modal-body{padding:0 16px 16px;display:flex;flex-direction:column;gap:10px}.intent-option{display:flex;align-items:center;gap:14px;padding:16px;background:var(--surface-2);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:border-color .15s ease,background .15s ease,transform .1s ease}.intent-option:hover{background:var(--bg);border-color:var(--primary)}.intent-option:active{transform:scale(.98)}.intent-option:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.intent-option-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--surface);border-radius:var(--radius-sm);color:var(--primary);flex-shrink:0}.intent-option-label{font-size:1rem;font-weight:700;color:var(--text);display:block}.intent-option-desc{font-size:.8125rem;color:var(--text-muted);display:block;margin-top:2px}.intent-option-any{padding-left:20px;flex-direction:column;align-items:flex-start;gap:4px}.intent-option-any .intent-option-label{font-size:.9375rem}.intent-option-any .intent-option-desc{font-size:.75rem}.intent-modal-footer{padding:0 24px 20px;text-align:center}.intent-modal-note{font-size:.75rem;color:var(--text-muted);margin:0}.spots-intent-chip{background:var(--primary-soft)!important;color:var(--primary)!important;border:1.5px solid var(--primary)!important;cursor:pointer;display:inline-flex!important;align-items:center;gap:6px;padding:6px 12px;font-size:.8125rem;font-weight:600;border-radius:20px;transition:background .15s ease}.spots-intent-chip:hover{background:var(--primary)!important;color:#fff!important}.spots-intent-chip-arrow{margin-left:2px;opacity:.7}@media (max-width: 639px){.intent-modal-overlay{padding:16px;align-items:flex-end}.intent-modal{max-width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:80vh}.intent-modal-header{padding:20px 20px 12px}.intent-modal-title{font-size:1.125rem}.intent-modal-body{padding:0 12px 12px;gap:8px}.intent-option{padding:14px;gap:12px}.intent-option-icon{width:44px;height:44px}}
