.area-hero{background:linear-gradient(135deg,var(--bg) 0%,var(--surface-2) 100%);padding:32px var(--container-padding) 40px;border-bottom:1px solid var(--border)}.area-hero--slim{padding:20px var(--container-padding) 24px}.hero-inner{--container-max: 800px;max-width:var(--container-max);margin-left:auto;margin-right:auto;width:100%}.breadcrumb--compact{font-size:.75rem;margin-bottom:8px}.breadcrumb--compact .sep{margin:0 4px}.area-title{font-size:1.75rem;font-weight:800;letter-spacing:-.02em;color:var(--text);margin-bottom:8px}.area-hero--slim .area-title{font-size:1.5rem;margin-bottom:6px}.area-desc{font-size:.9375rem;color:var(--text-muted);line-height:1.7;max-width:600px}.area-hero--slim .area-desc{font-size:.875rem;line-height:1.6}.area-map-section{padding:20px var(--container-padding);background:var(--surface-2);border-bottom:1px solid var(--border)}.area-content{--container-max: 800px;max-width:var(--container-max);margin-left:auto;margin-right:auto;padding-left:var(--container-padding);padding-right:var(--container-padding);width:100%}.points-section{padding:28px 0 24px;border-bottom:1px solid var(--border)}.collapsible-content .points-list{margin-top:0}.points-heading{font-size:.8125rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:16px}.points-list{list-style:none;display:flex;flex-direction:column;gap:12px}.point-item{display:flex;align-items:flex-start;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px}.point-number{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--primary);color:#fff;font-size:.75rem;font-weight:700;border-radius:50%;flex-shrink:0}.point-text{font-size:.9375rem;color:var(--text);line-height:1.6}.info-section{padding:32px 0;border-bottom:1px solid var(--border)}.info-cards{display:flex;gap:12px;flex-wrap:wrap}.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 20px;min-width:140px;display:flex;flex-direction:column;gap:4px}.info-card.accent{background:var(--primary-soft);border-color:var(--primary);border-width:1.5px}.info-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em}.info-card.accent .info-label{color:var(--primary)}.info-value{font-size:1.25rem;font-weight:700;color:var(--text)}.info-value small{font-size:.875rem;font-weight:600}.info-card.accent .info-value{color:var(--primary)}.info-note{margin-top:12px;font-size:.75rem;color:var(--text-muted)}.tip-section,.walk-section,.purposes-section{padding:24px 0;border-bottom:1px solid var(--border)}.tip-heading{font-size:.8125rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}.tip-text{font-size:.9375rem;color:var(--text);line-height:1.7;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;margin:0}.collapsible-content .tip-text{font-size:.875rem}.collapsible-content .walk-list{margin-top:0}.walk-list{list-style:none;display:flex;flex-direction:column;gap:8px}.walk-list li{font-size:.875rem;color:var(--text);padding-left:20px;position:relative;line-height:1.6}.walk-list li:before{content:"→";position:absolute;left:0;color:var(--text-muted)}.purposes-grid{display:flex;flex-wrap:wrap;gap:10px}.purpose-chip{display:inline-block;font-size:.875rem;font-weight:600;color:var(--primary);background:var(--surface);border:1.5px solid var(--primary);padding:10px 18px;border-radius:24px;text-decoration:none;transition:background .15s ease,color .15s ease}.purpose-chip:hover{background:var(--primary);color:#fff;text-decoration:none}.cta-section{padding:40px 0;text-align:center}.nearby-section{padding:32px 0 48px;border-top:1px solid var(--border)}.nearby-cards{display:flex;gap:12px;flex-wrap:wrap}.nearby-card{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 18px;min-width:160px;text-decoration:none;transition:border-color .15s ease,box-shadow .15s ease}.nearby-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm);text-decoration:none}.nearby-name{font-size:.9375rem;font-weight:600;color:var(--text)}.nearby-arrow{font-size:1rem;color:var(--text-muted);transition:transform .15s ease,color .15s ease}.nearby-card:hover .nearby-arrow{transform:translate(3px);color:var(--primary)}.spots-section{padding:32px 0;border-bottom:1px solid var(--border)}.spots-heading{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:4px}.spots-sub{font-size:.8125rem;color:var(--text-muted);margin-bottom:20px}.spots-grid{display:grid;grid-template-columns:1fr;gap:14px}.spot-card{display:flex;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;transition:box-shadow .15s ease,border-color .15s ease}.spot-card:hover{box-shadow:var(--shadow-sm);border-color:var(--text-muted)}.spot-card:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.spot-thumb{flex-shrink:0;width:72px;height:72px;border-radius:var(--radius-sm);object-fit:cover;background:var(--surface-2);border:1px solid var(--border)}.spot-thumb-placeholder{display:flex;align-items:center;justify-content:center;color:var(--text-muted);opacity:.6}.spot-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.spot-header{display:flex;align-items:center;gap:8px}.spot-badge{display:inline-block;font-size:.6875rem;font-weight:700;padding:4px 10px;border-radius:14px;letter-spacing:.02em}.spot-badge.cat-toilet{background:#e0e7ff;color:#3730a3}.spot-badge.cat-rest{background:var(--primary-soft);color:var(--text)}.spot-badge.cat-convenience{background:#fef3c7;color:#92400e}.spot-badge.cat-food{background:#fde8e8;color:#9b2c2c}.spot-badge.cat-landmark{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.spot-badge.cat-worship{background:#feebc8;color:var(--accent)}.spot-name{font-size:.9375rem;font-weight:700;color:var(--text);line-height:1.3;margin:0}.spot-desc{font-size:.75rem;color:var(--text-muted);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.spot-address{font-size:.75rem;color:var(--text-muted);opacity:.8;margin-bottom:12px}.spot-map-link{display:inline-flex;align-items:center;gap:4px;font-size:.8125rem;font-weight:600;color:var(--primary);text-decoration:none;padding:6px 12px;background:var(--primary-soft);border-radius:var(--radius-sm);transition:background .15s ease}.spot-map-link:hover{background:var(--ring);text-decoration:none}.map-icon{font-size:.875rem}.status-badge{display:inline-block;font-size:.625rem;font-weight:700;padding:3px 8px;border-radius:10px;letter-spacing:.02em;margin-left:auto}.status-badge.planned{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.status-badge.far{background:#ede9fe;color:#6d28d9;border:1px solid #A78BFA}.spot-card[data-spot]{cursor:pointer}.spot-modal{position:fixed;inset:0;width:100%;max-width:100%;height:100%;max-height:100%;margin:0;padding:0;border:none;background:transparent;z-index:200;display:none}.spot-modal::backdrop{background:#00000080}.spot-modal[open]{display:flex;align-items:center;justify-content:center;padding:16px;min-height:100dvh;min-height:100vh}@supports (min-height: 100dvh){.spot-modal[open]{min-height:100dvh}}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:min(500px,calc(100vw - 32px));max-height:min(90dvh,calc(100vh - 32px));overflow-y:auto;box-shadow:0 8px 32px #0003;animation:modalFadeIn .2s ease-out;margin:auto}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.modal-title{font-size:1rem;font-weight:700;color:var(--text);margin:0}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--surface-2);border:1px solid var(--border);border-radius:50%;cursor:pointer;font-size:1.25rem;color:var(--text-muted);transition:background .15s ease,color .15s ease}.modal-close:hover{background:var(--border);color:var(--text)}.modal-close:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.modal-body{padding:20px}.modal-image{width:100%;aspect-ratio:16 / 10;object-fit:cover;border-radius:var(--radius-sm);background:var(--surface-2);margin-bottom:16px}.modal-badge{display:inline-block;font-size:.6875rem;font-weight:700;padding:4px 10px;border-radius:14px;margin-bottom:12px}.modal-name{font-size:1.125rem;font-weight:700;color:var(--text);margin-bottom:8px}.modal-desc{font-size:.9375rem;color:var(--text-muted);line-height:1.7;margin-bottom:12px}.modal-address{font-size:.8125rem;color:var(--text-muted);margin-bottom:16px}.modal-map-link{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:.9375rem;font-weight:500;color:#fff;background:var(--primary);padding:10px 18px;border-radius:var(--radius-sm);text-decoration:none;transition:background .15s ease}.modal-map-link svg{flex-shrink:0}.modal-map-link:hover{background:var(--color-primary-dark);text-decoration:none}.modal-actions{display:flex;flex-direction:column;gap:10px;margin-top:16px}.modal-detail-link{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:.9375rem;font-weight:500;color:var(--primary);background:var(--primary-soft);padding:10px 18px;border-radius:var(--radius-sm);text-decoration:none;transition:background .15s ease}.modal-detail-link:hover{background:#bfdbfe;text-decoration:none}.modal-detail-link svg{flex-shrink:0}@media (min-width: 480px){.modal-actions{flex-direction:row;justify-content:flex-end}}@media (min-width: 640px){.area-hero{padding:48px 20px 56px}.area-hero--slim{padding:28px 20px 32px}.area-title{font-size:2rem}.area-hero--slim .area-title{font-size:1.75rem}.info-card{min-width:160px}.spots-grid{grid-template-columns:repeat(2,1fr);gap:16px}.spot-thumb{width:80px;height:80px}.spot-name{font-size:1rem}.spot-desc{font-size:.8125rem}.purpose-chips,.recommended-grid{grid-template-columns:repeat(3,1fr)}}.purpose-picker{padding:24px 0;border-bottom:1px solid var(--border)}.purpose-heading{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:14px}.purpose-chips{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.purpose-chip{display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;color:var(--text);background:var(--surface);border:1.5px solid var(--border);padding:12px 16px;border-radius:24px;cursor:pointer;transition:all .15s ease;text-align:center;min-height:44px}.purpose-chip:hover{border-color:var(--primary);color:var(--primary)}.purpose-chip[aria-pressed=true]{background:var(--primary);border-color:var(--primary);color:#fff}.purpose-chip:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.recommended-section{padding:24px 0;border-bottom:1px solid var(--border)}.recommended-heading{display:flex;align-items:center;gap:10px;margin-bottom:16px}.recommended-heading .heading-text{font-size:1rem;font-weight:700;color:var(--text)}.recommended-heading .heading-badge{font-size:.6875rem;font-weight:600;color:var(--primary);background:var(--primary-soft);padding:4px 10px;border-radius:12px}.recommended-grid{display:grid;grid-template-columns:1fr;gap:12px}.recommended-card{display:flex;flex-direction:column;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;text-decoration:none;transition:border-color .15s ease,box-shadow .15s ease}.recommended-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm);text-decoration:none}.recommended-card:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.recommended-name{font-size:.9375rem;font-weight:700;color:var(--text);line-height:1.3}.recommended-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{display:inline-block;font-size:.6875rem;font-weight:600;padding:3px 8px;border-radius:10px}.tag--positive{background:#d1fae5;color:#065f46}.tag--neutral{background:var(--surface-2);color:var(--text-muted)}.tag--info{background:var(--primary-soft);color:var(--primary)}.recommended-info{display:flex;align-items:center;gap:12px;font-size:.8125rem;color:var(--text-muted)}.recommended-price{font-weight:600;color:var(--text)}.recommended-walk{color:var(--text-muted)}.recommended-more{margin-top:12px;font-size:.8125rem;color:var(--text-muted);text-align:center}.collapsible-section{border-bottom:1px solid var(--border)}.collapsible-summary{display:flex;align-items:center;gap:10px;padding:16px 0;cursor:pointer;list-style:none;user-select:none}.collapsible-summary::-webkit-details-marker{display:none}.collapsible-title{font-size:.875rem;font-weight:600;color:var(--text)}.collapsible-hint{font-size:.75rem;color:var(--text-muted);margin-left:auto;margin-right:4px}.collapsible-icon{color:var(--text-muted);transition:transform .2s ease;flex-shrink:0}.collapsible-section[open] .collapsible-icon{transform:rotate(180deg)}.collapsible-content{padding-bottom:20px}.collapsible-summary:hover,.collapsible-summary:hover .collapsible-title{color:var(--primary)}.collapsible-summary:focus-visible{outline:2px solid var(--ring);outline-offset:2px;border-radius:var(--radius-sm)}.cta-section--main{padding:28px 0;border-bottom:1px solid var(--border)}
