body {
    font-family: 'Noto Sans JP', sans-serif;
    overflow-y: scroll; /* 縦スクロールを常に確保（レイアウトのガタつき防止） */
}
/* スクロールバーのカスタマイズ */
::-webkit-scrollbar {
    width: 8px;
}
::-webkit-scrollbar-track {
    background: #f0fdf4;
}
::-webkit-scrollbar-thumb {
    background: #86efac;
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
    background: #4ade80;
}

/* indexファイルの日本地図SVG用のスタイル 　なぜかここでないと正しく表示されないため*/
.map-region {
    fill: #86efac; /* green-300 */
    stroke: #ffffff;
    stroke-width: 2;
    transition: all 0.3s ease;
    cursor: pointer;
}
.map-region:hover {
    fill: #a3e635; /* lime-400 */
    filter: drop-shadow(0 4px 6px rgba(0,0,0,0.15));
    transform: translateY(-2px);
}
.map-text {
    fill: #14532d; /* green-900 */
    font-size: 14px;
    font-weight: bold;
    pointer-events: none;
    text-anchor: middle;
    text-shadow: 0 1px 2px rgba(255,255,255,0.8);
}

/* モーダル表示用アニメーション */
@keyframes modalIn {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}
.animate-modal-in {
    animation: modalIn 0.2s ease-out forwards;
}

/* 横スクロールバーを非表示にしつつスクロール可能にする */
.no-scrollbar::-webkit-scrollbar { display: none; }
.no-scrollbar { -ms-overflow-style: none; scrollbar-width: none; -webkit-overflow-scrolling: touch; }

/* デザインラベルの装飾 */
.filter-label {
	position: relative;
	padding-left: 0.6rem;
	font-size: 10px;
	font-weight: 900;
	color: #166534;
	white-space: nowrap;
}
.filter-label::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 3px;
	height: 12px;
	background-color: #a3e635;
	border-radius: 2px;
}

/* アクティブなタグ（現在地）の強調表示 */
.tag-chip-active {
	background-color: #a3e635 !important;
	color: #166534 !important;
	border-color: #a3e635 !important;
}