.jcm-visualization { margin: 2rem 0; }
.jcm-viz-legend {
	display: flex; gap: 20px; flex-wrap: wrap; margin-bottom: 12px;
}
.jcm-legend-item { display: flex; align-items: center; gap: 8px; font-size: .9rem; }
.jcm-legend-item i { display: inline-block; width: 14px; height: 14px; border-radius: 3px; }

.jcm-viz-breadcrumb {
	display: flex; flex-wrap: wrap; align-items: center; gap: 4px;
	margin-bottom: 12px; font-size: .9rem;
}
.jcm-viz-crumb {
	background: none; border: none; padding: 4px 8px; cursor: pointer;
	color: #1e3a5f; text-decoration: underline; font-size: inherit;
}
.jcm-viz-crumb.is-current { font-weight: 700; text-decoration: none; cursor: default; color: #1e293b; }
.jcm-viz-crumb-sep { color: #94a3b8; }

.jcm-viz-stage-wrap { position: relative; }
.jcm-viz-back {
	margin-bottom: 12px;
	padding: 8px 16px;
	background: #f1f5f9;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	cursor: pointer;
	font-size: .9rem;
}
.jcm-viz-back:hover { background: #e2e8f0; }

.jcm-viz-stage { min-height: 200px; }
.jcm-viz-level-title { margin: 0 0 12px; font-size: 1.25rem; color: #1e3a5f; }
.jcm-viz-stage-inner {
	position: relative;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 8px 30px rgba(0,0,0,.12);
}
.jcm-viz-bg { display: block; width: 100%; height: auto; }
.jcm-viz-overlay { position: absolute; inset: 0; width: 100%; height: 100%; }
.jcm-hotspot { cursor: pointer; transition: fill-opacity .2s; }
.jcm-hotspot:hover, .jcm-hotspot:focus { fill-opacity: .7 !important; outline: none; }
.jcm-viz-empty, .jcm-viz-loading { padding: 2rem; text-align: center; color: #64748b; }

.jcm-viz-card {
	position: fixed; bottom: 24px; right: 24px; z-index: 9999;
	background: #fff; border-radius: 12px; padding: 20px 24px;
	box-shadow: 0 12px 40px rgba(0,0,0,.18); max-width: 380px; width: calc(100% - 48px);
	border: 1px solid #e2e8f0;
}
.jcm-viz-card[hidden] { display: none !important; }
.jcm-viz-card-close {
	position: absolute; top: 8px; right: 12px;
	background: none; border: none; font-size: 1.4rem; cursor: pointer; line-height: 1;
}
.jcm-viz-card h4 { margin: 0 0 8px; font-size: 1.1rem; }
.jcm-viz-card-price { font-size: 1.25rem; font-weight: 700; color: #1e3a5f; margin: 8px 0; }

.jcm-status-badge {
	display: inline-block; padding: 4px 10px; border-radius: 999px;
	font-size: 12px; font-weight: 600;
}
.jcm-status-available { background: #dcfce7; color: #166534; }
.jcm-status-reserved { background: #fef3c7; color: #92400e; }
.jcm-status-sold { background: #fee2e2; color: #991b1b; }

@media (max-width: 600px) {
	.jcm-viz-card { left: 16px; right: 16px; bottom: 16px; width: auto; }
}
