.cc-imagemap-container { display: flex; flex-wrap: wrap; align-items: flex-start; gap: 2%; width: 100%; margin: 0 auto; box-sizing: border-box; font-family: sans-serif; }
.cc-imagemap-container.layout-text-left { flex-direction: row; }
.cc-imagemap-container.layout-text-right { flex-direction: row-reverse; }
.cc-imagemap-text-section { flex: 0 0 38%; max-width: 38%; padding: 25px; box-sizing: border-box; background: #fdfdfd; border-radius: 12px; box-shadow: 0 4px 15px rgba(0,0,0,0.05); transition: opacity 0.3s ease-in-out; }
.cc-imagemap-map-section { flex: 0 0 60%; max-width: 60%; box-sizing: border-box; }
.cc-imagemap-welcome-title { margin-top: 0; margin-bottom: 15px; font-size: 1.5rem; font-weight: bold; color: #333; }
.cc-imagemap-welcome-desc { font-size: 1rem; line-height: 1.6; color: #555; margin-bottom: 10px; }
.cc-imagemap-display-link { display: inline-flex; align-items: center; justify-content: center; margin-top: 20px; padding: 10px 24px; background-color: #008cdb; color: #ffffff !important; border-radius: 50px; text-decoration: none; font-weight: 600; font-size: 16px; transition: background-color 0.3s ease, transform 0.2s ease; }
.cc-imagemap-display-link:hover { background-color: #0077ba; transform: translateY(-2px); text-decoration: none; }
.cc-imagemap-wrapper { position: relative; box-sizing: border-box; }
.cc-imagemap-img { max-width: 100%; height: auto; border-radius: 8px; }
.cc-imagemap-point { display: block; box-sizing: border-box; border: 2px dashed transparent; transition: all 0.25s ease; cursor: pointer; }
.cc-imagemap-point.point-type-circle { border-radius: 50%; }
.cc-imagemap-point.point-type-square { border-radius: 0; }
.cc-imagemap-point.point-type-transparent { border: none !important; }
.cc-imagemap-point.point-type-pin { border-radius: 4px; }

/* FIX: ซ่อนภาพ Custom Image ในสภาวะปกติ และแสดงเมื่อ Hover */
.cc-imagemap-point.point-type-custom_image { border: none !important; background: transparent !important; overflow: visible; }
.cc-custom-img-layer { display: block; width: 100%; height: 100%; object-fit: contain; pointer-events: none; opacity: 0 !important; transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out; }
.cc-imagemap-point.point-type-custom_image:hover .cc-custom-img-layer { opacity: 1 !important; transform: scale(1.05); }

.pointer-pin-element { position: absolute; top: 50%; left: 50%; width: 16px; height: 16px; background: #dc3545; border: 2px solid #fff; border-radius: 50% 50% 50% 0; transform: translate(-50%, -100%) rotate(-45deg); box-shadow: 0 2px 5px rgba(0,0,0,0.4); }

/* เมื่อเอาเมาส์ชี้ ให้ลอยขึ้นมาบนสุดเสมอ */
.cc-imagemap-point:hover { background-color: var(--hover-bg, rgba(0, 123, 255, 0.3)); border-color: var(--hover-color, #007bff); z-index: 999999 !important; }
.cc-imagemap-point.point-type-pin:hover .pointer-pin-element { background-color: var(--hover-color, #007bff); }
.cc-imagemap-point.point-type-transparent:hover { background-color: var(--hover-bg, rgba(0, 123, 255, 0.3)); }

.cc-imagemap-poly { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 5; background-color: transparent; transition: background-color 0.25s ease; cursor: pointer; }
.cc-imagemap-poly:hover { background-color: var(--hover-bg, rgba(0, 123, 255, 0.3)); z-index: 999999 !important; }
.cc-imagemap-poly-anchor { position: absolute; width: 0; height: 0; z-index: 6; pointer-events: none; }
.cc-imagemap-tooltip { position: absolute; bottom: 115%; left: 50%; transform: translateX(-50%) translateY(8px); width: max-content; max-width: 240px; background: #334C64; color: #fff; padding: 8px 15px; border-radius: 5px; opacity: 0; visibility: hidden; transition: all 0.3s ease; pointer-events: none; z-index: 999999 !important; text-align: center; box-shadow: 0 4px 10px rgba(0,0,0,0.2); }
.cc-imagemap-tooltip::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); border-width: 6px; border-style: solid; border-color: #334C64 transparent transparent transparent; }
.cc-imagemap-point:hover .cc-imagemap-tooltip { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.cc-imagemap-poly-anchor .cc-imagemap-tooltip { bottom: 15px; }
.cc-imagemap-poly:hover + .cc-imagemap-poly-anchor .cc-imagemap-tooltip { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.tooltip-inner-title { font-weight: bold; font-size: 14px; margin-bottom: 0; padding-bottom: 0; }
@media (max-width: 768px) { .cc-imagemap-container { flex-direction: column !important; } .cc-imagemap-text-section, .cc-imagemap-map-section { flex: 0 0 100%; max-width: 100%; width: 100%; margin-bottom: 20px; } }