/**
 * @file
 * Hero slider — mod.go.th: full-width blue band, centered content zone.
 */

.mod-hero {
  --mod-hero-aspect-w: 1000;
  --mod-hero-aspect-h: 417;
  --mod-hero-pager: 48px;
  --mod-hero-slide-bg: var(--mod-blue);
  position: relative;
  height: auto;
  box-sizing: border-box;
  background-color: var(--mod-blue);
  overflow: hidden;
}

/* ช่องว่างเมนู → สไลด์ (อยู่ที่ hero ไม่ใช่ padding ใต้ nav) */
.mod-page--front .mod-hero {
  padding-top: 8px;
}

.mod-hero__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  height: auto;
  min-height: 0;
  overflow: hidden;
}

/* โซนสไลด์ — ความกว้างตาม container, ความสูงตามสัดส่วนแบนเนอร์ 1000×417 */
.mod-hero__inner > div:not(.mod-hero__pager) {
  flex: 0 0 auto;
  width: 100%;
  aspect-ratio: var(--mod-hero-aspect-w) / var(--mod-hero-aspect-h);
  height: auto;
  min-height: 0;
  overflow: hidden;
}

.mod-hero .views-element-container,
.mod-hero .mod-block,
.mod-hero .mod-block__content,
.mod-hero .mod-block__content > div,
.mod-hero .view,
.mod-hero .view-content,
.mod-hero .view--blazy,
.mod-hero .slick,
.mod-hero .slick__slider {
  height: 100%;
  max-height: 100%;
  min-height: 0;
  margin: 0;
  overflow: hidden;
  box-sizing: border-box;
}

.mod-hero .slick {
  position: relative;
}

.mod-hero .slick__slider {
  position: relative;
}

.mod-hero .slick__slide.slide--0 {
  position: relative;
  visibility: visible;
}

.mod-hero .slick-initialized .slick__slide,
.mod-hero .slick-initialized .slick-slide {
  visibility: visible;
}

/* ทุกสไลด์ (active / inactive / cloned) — สูงเต็มโซน aspect-ratio */
.mod-hero .slick-list,
.mod-hero .slick-track,
.mod-hero .slick-slide,
.mod-hero .slick__slide,
.mod-hero .slick-slide.slick-cloned,
.mod-hero .slick__slide.slick-cloned {
  height: 100% !important;
  max-height: 100% !important;
  overflow: hidden;
}

.mod-hero .slick-slide > div,
.mod-hero .slide__content,
.mod-hero .slide__media,
.mod-hero .media,
.mod-hero .media .contextual-region {
  position: relative;
  width: 100%;
  height: 100%;
  max-height: 100%;
  min-height: 0;
  overflow: hidden;
  box-sizing: border-box;
  background-color: var(--mod-hero-slide-bg);
}

.mod-hero .slide__content {
  display: block;
  position: relative;
  height: 100%;
}

/* รูป render ผ่าน overlay (entity ref + blazy main stage ค้าง) */
.mod-hero .slide__caption {
  position: absolute !important;
  inset: 0 !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  transform: none !important;
  z-index: 2;
  pointer-events: none;
}

.mod-hero .slide__caption .contextual {
  pointer-events: auto;
}

.mod-hero .slide__overlay,
.mod-hero .slide__caption .contextual-region {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
}

/* ซ่อน metadata/thumbnail ใน overlay (ไม่ซ่อน slide__link) */
.mod-hero .slide__overlay .contextual,
.mod-hero .slide__overlay .contextual-region > div:has(> a[href*="/user/"]),
.mod-hero .slide__overlay .contextual-region > div:has(> time),
.mod-hero .slide__overlay .contextual-region > div:has(> img[src*="thumbnail"]),
/* Anonymous: no .contextual-region wrapper. */
.mod-hero .slide__overlay > div > div:has(> a[href*="/user/"]),
.mod-hero .slide__overlay > div > div:has(> span),
.mod-hero .slide__overlay > div > div:has(> time),
.mod-hero .slide__overlay > div > div:has(> img[src*="thumbnail"]) {
  display: none !important;
}

/* ลิงก์ทั้ง slide — Slick slide__link หรือ field link ใน caption */
.mod-hero .slide__link,
.mod-hero .slide__caption > .field--type-link {
  position: absolute !important;
  inset: 0 !important;
  z-index: 10;
  margin: 0 !important;
  padding: 0 !important;
  pointer-events: auto !important;
}

.mod-hero .slide__link a,
.mod-hero .slide__caption > .field--type-link a {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  color: transparent !important;
  font-size: 0 !important;
  line-height: 0 !important;
  text-indent: -9999px;
  overflow: hidden;
  cursor: pointer !important;
}

.mod-hero .slide__link a:hover,
.mod-hero .slide__link a:focus,
.mod-hero .slide__caption > .field--type-link a:hover,
.mod-hero .slide__caption > .field--type-link a:focus {
  outline: 2px solid var(--mod-orange);
  outline-offset: -2px;
}

/* ไม่ให้ Slick draggable บัง cursor ลิงก์ */
.mod-hero .slick-list.draggable {
  cursor: default;
}

.mod-hero .slick-list.draggable .slide__link a,
.mod-hero .slick-list.draggable .slide__caption > .field--type-link a {
  cursor: pointer !important;
}

.mod-hero .slick--main .slick__slide img,
.mod-hero .slick__slide img[src*="hero_banner"] {
  pointer-events: none;
}

/* เฉพาะ div ที่มี hero_banner */
.mod-hero .slide__overlay .contextual-region > div:has(> img[src*="hero_banner"]) {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-color: var(--mod-hero-slide-bg);
}

.mod-hero .slide__overlay img[src*="hero_banner"] {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center center;
}

/* ซ่อน main stage blazy ว่าง */
.mod-hero .slide__media {
  position: absolute !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.mod-hero img[src*="/styles/thumbnail/"],
.mod-hero .media--thumbnail img,
.mod-hero .field--name-thumbnail img {
  display: none !important;
}

/* div ที่ห่อ <img> — absolute เต็มกรอบ ให้ขนาดเท่ากันทุกสถานะสไลด์ */
.mod-hero .media .contextual-region > div:not(.contextual) {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-color: var(--mod-hero-slide-bg);
}

.mod-hero .field--name-field-media-image img,
.mod-hero .media__element {
  display: block;
  width: 100% !important;
  height: 100% !important;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center center;
  opacity: 1;
  visibility: visible;
}

/* ซ่อน thumbnail/metadata ถ้า view display ยังเรnder มา */
.mod-hero .field--name-thumbnail,
.mod-hero .field--name-created,
.mod-hero .field--name-uid {
  display: none !important;
}

.mod-hero img[data-lazy] {
  display: block;
}

/* Arrows */
.mod-hero .slick__arrow {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  bottom: var(--mod-hero-pager) !important;
  left: 0 !important;
  width: 100% !important;
  height: auto !important;
  margin: 0 !important;
  transform: none !important;
  z-index: 10;
  pointer-events: none;
  visibility: visible !important;
}

.mod-hero .slick-prev,
.mod-hero .slick-next {
  pointer-events: auto;
  position: absolute;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 36px;
  height: 36px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: rgba(105, 103, 103, 0.45);
  color: transparent;
  font-size: 0;
  line-height: 0;
  cursor: pointer;
  opacity: 1;
  transition: background-color 0.2s ease;
}

.mod-hero .slick-prev:hover,
.mod-hero .slick-next:hover,
.mod-hero .slick-prev:focus-visible,
.mod-hero .slick-next:focus-visible {
  background: var(--mod-orange);
}

.mod-hero .slick-prev::before,
.mod-hero .slick-next::before {
  display: none;
}

.mod-hero .slick-prev::after,
.mod-hero .slick-next::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  border-top: 2px solid var(--mod-white);
  border-right: 2px solid var(--mod-white);
}

.mod-hero .slick-prev::after {
  transform: translate(-35%, -50%) rotate(-135deg);
}

.mod-hero .slick-next::after {
  transform: translate(-65%, -50%) rotate(45deg);
}

.mod-hero .slick-prev {
  left: 0;
}

.mod-hero .slick-next {
  right: 0;
}

/* Dots pager — แถบล่างโซนกลาง */
.mod-hero__pager {
  flex: 0 0 var(--mod-hero-pager);
  position: relative;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: var(--mod-hero-pager);
  padding: 14px 0 10px;
  box-sizing: border-box;
}

.mod-hero__pager .slick-dots,
.mod-hero .slick-dots {
  position: static !important;
  display: flex !important;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 14px;
  width: auto;
  margin: 0;
  padding: 0 0 2px;
  list-style: none;
  pointer-events: auto;
  visibility: visible !important;
  opacity: 1 !important;
}

.mod-hero .slick-dots li {
  display: block;
  margin: 0;
  padding: 0;
  width: auto;
  height: auto;
  line-height: 0;
}

.mod-hero .slick-dots li button {
  display: block;
  width: 10px;
  height: 10px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: var(--mod-gray-dot);
  font-size: 0;
  line-height: 0;
  overflow: hidden;
  text-indent: -9999px;
  color: transparent;
  cursor: pointer;
}

.mod-hero .slick-dots li button::before {
  display: none !important;
  content: none !important;
}

.mod-hero .slick-dots li.slick-active button {
  background: var(--mod-gray-dot-active);
}

/* Fallback: dots ยังอยู่ใน slick__slider ก่อน JS ย้าย */
.mod-hero .slick__slider > .slick-dots {
  position: absolute !important;
  bottom: calc(-1 * var(--mod-hero-pager)) !important;
  left: 0;
  right: 0;
  z-index: 30;
  padding-top: 14px;
}
