/**
 * DIFGC hotel & travel (accommodation.html) — scoped under #difgc-accommodation
 * (from difgc-2026 accommodation.html, for WordPress/Elementor embed)
 */

/* 避免 Elementor 外层容器铺色挡住 #difgc-accommodation 背景图 */
.pageContent.page-accommodation-landing,
.pageContent.page-accommodation-landing > .elementor.elementor-9 {
  background: transparent !important;
}

#difgc-accommodation,
#difgc-accommodation *::before,
#difgc-accommodation *::after {
  box-sizing: border-box;
}

/* 栏目间距：首屏与第一节之间若有 div 等，`section + section` 选不中；除首个 section 外去掉上边距 */
#difgc-accommodation > section:not(:first-of-type) {
  padding-top: 0 !important;
}

#difgc-accommodation {
  --primary: #0d9488;
  --primary-dark: #0f766e;
  --accent: #f59e0b;
  --dark-bg: #0f172a;
  /* 浅色内容区：原 #1e293b 卡片改为白底 + 阴影 */
  --card-bg: #ffffff;
  --card-border: #e2e8f0;
  --text-light: #0e1428;
  --text-muted: #64748b;
  --teal-light: #ccfbf1;
  --card-shadow: 0 4px 24px rgba(15, 23, 42, 0.08), 0 1px 3px rgba(15, 23, 42, 0.06);
  /* 与泰国站 page-common.css 一致：正文 Lato + Noto Sans SC（本地 fonts/thailand-fonts.css） */
  font-family: Lato, 'Noto Sans SC', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  /* 与 #difgc-award-selection 一致：仅 page-bg.jpg，无叠色、无额外 background-color */
  background-image: url('../img/page-bg.jpg');
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  background-attachment: fixed;
  color: var(--text-light);
  position: relative;
  z-index: 1;
  overflow-x: hidden;
}

/* Hero：覆盖 Tailwind min-h-screen(100vh)，为顶栏等预留 206px */
#difgc-accommodation .min-h-screen {
  min-height: calc(100vh - 206px) !important;
}

/* 浅底可读：白字改为深色（与 award-selection 思路一致；保留实心按钮上的白字） */
#difgc-accommodation .text-white {
  color: #0e1428 !important;
}
#difgc-accommodation a.btn-glow.bg-teal-600.text-white,
#difgc-accommodation a.btn-glow.bg-teal-500.text-white,
#difgc-accommodation a.btn-glow.bg-slate-700.text-white,
#difgc-accommodation a.btn-glow.bg-slate-600.text-white {
  color: #ffffff !important;
}
#difgc-accommodation #airport-tabs .tab-btn.active.text-white {
  color: #ffffff !important;
}
#difgc-accommodation .text-slate-300 {
  color: #475569 !important;
}
#difgc-accommodation .text-slate-400 {
  color: #64748b !important;
}
#difgc-accommodation .text-slate-500 {
  color: #64748b !important;
}
#difgc-accommodation .text-teal-300 {
  color: #0f766e !important;
}
#difgc-accommodation .text-teal-200\/80 {
  color: #0d9488 !important;
}
#difgc-accommodation a.text-amber-400 {
  color: #d97706 !important;
}
#difgc-accommodation a.text-amber-400:hover {
  color: #b45309 !important;
}

/* 原 slate-800 提示条：浅灰底 + 深色字，不加整页蒙层 */
#difgc-accommodation .bg-slate-800 {
  background-color: #f1f5f9 !important;
  color: #334155 !important;
}
#difgc-accommodation .bg-slate-800.text-amber-400 {
  color: #b45309 !important;
}
#difgc-accommodation .bg-slate-800.text-teal-400 {
  color: #0f766e !important;
}

/* 原 bg-slate-800/50 大区块 → 白底 + 阴影 */
#difgc-accommodation .bg-slate-800\/50 {
  background-color: #ffffff !important;
  border-color: var(--card-border) !important;
  box-shadow: var(--card-shadow);
}

#difgc-accommodation .border-slate-700 {
  border-color: #e2e8f0 !important;
}
/* 酒店卡片内竖线分隔，勿覆盖 .bg-slate-700 按钮 */
#difgc-accommodation .w-px.bg-slate-700 {
  background-color: #e2e8f0 !important;
}

/* 标题层级：与 page-common / Award 一致 — Montserrat + Noto Sans SC */
#difgc-accommodation h1,
#difgc-accommodation h2,
#difgc-accommodation h3,
#difgc-accommodation h4 {
  font-family: Montserrat, 'Noto Sans SC', 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

@keyframes difgcAccFadeUp {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes difgcAccTitleExpand {
  from {
    transform: scaleX(0);
    opacity: 0;
  }
  to {
    transform: scaleX(1);
    opacity: 1;
  }
}

@keyframes difgcAccMarquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

#difgc-accommodation .hero-badge {
  animation: difgcAccFadeUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
}
#difgc-accommodation .hero-title {
  animation: difgcAccFadeUp 0.6s 0.1s cubic-bezier(0.16, 1, 0.3, 1) both;
}
#difgc-accommodation .hero-sub {
  animation: difgcAccFadeUp 0.6s 0.2s cubic-bezier(0.16, 1, 0.3, 1) both;
}
#difgc-accommodation .hero-cta {
  animation: difgcAccFadeUp 0.6s 0.3s cubic-bezier(0.16, 1, 0.3, 1) both;
}

#difgc-accommodation .section-title::after {
  content: '';
  display: block;
  width: min(280px, 75vw);
  height: 3px;
  background: linear-gradient(90deg, var(--primary), var(--accent), transparent);
  margin-top: 12px;
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
#difgc-accommodation .section-title.inview::after {
  transform: scaleX(1);
}

#difgc-accommodation [data-reveal] {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}
#difgc-accommodation [data-reveal].inview {
  opacity: 1;
  transform: translateY(0);
}

#difgc-accommodation .card-hover {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
#difgc-accommodation .card-hover:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.12), 0 8px 16px rgba(15, 23, 42, 0.08);
}

#difgc-accommodation .btn-glow {
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}
#difgc-accommodation .btn-glow::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
  transition: left 0.5s ease;
}
#difgc-accommodation .btn-glow:hover::before {
  left: 100%;
}
#difgc-accommodation .btn-glow:hover {
  box-shadow: 0 0 24px rgba(13, 148, 136, 0.6);
  transform: translateY(-2px);
}

/* 机场 Tab 容器：移动端两枚按钮纵向排列，避免窄屏挤压；sm 起与桌面一致横向 */
#difgc-accommodation #airport-tabs {
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 0.5rem !important;
}
@media (min-width: 640px) {
  #difgc-accommodation #airport-tabs {
    flex-direction: row !important;
    align-items: center !important;
    gap: 1.5rem !important;
  }
}

/* 机场 Tab：覆盖主题里 #cc3366 等，统一用主题色 teal */
#difgc-accommodation #airport-tabs .tab-btn {
  position: relative;
  border: none;
  cursor: pointer;
  border-radius: 8px;
  padding: 0.5rem 1rem 0.65rem;
  margin: 0;
  width: 100%;
  text-align: left;
  box-sizing: border-box;
  background-color: transparent !important;
  transition: background-color 0.2s ease, color 0.2s ease;
}
@media (min-width: 640px) {
  #difgc-accommodation #airport-tabs .tab-btn {
    width: auto;
    text-align: center;
  }
}
#difgc-accommodation #airport-tabs .tab-btn:hover:not(.active) {
  background-color: rgba(13, 148, 136, 0.14) !important;
  color: var(--primary) !important;
}
#difgc-accommodation #airport-tabs .tab-btn:active:not(.active) {
  background-color: rgba(13, 148, 136, 0.22) !important;
}
#difgc-accommodation #airport-tabs .tab-btn:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
#difgc-accommodation #airport-tabs .tab-btn.active {
  background-color: var(--primary) !important;
  color: #ffffff !important;
}
#difgc-accommodation #airport-tabs .tab-btn.active:hover {
  background-color: var(--primary-dark) !important;
  color: #ffffff !important;
}
#difgc-accommodation #airport-tabs .tab-btn.active:active {
  background-color: #0d6d64 !important;
  color: #ffffff !important;
}

#difgc-accommodation .transport-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 16px;
  box-shadow: var(--card-shadow);
  transition: all 0.3s ease;
}
#difgc-accommodation .transport-card:hover {
  border-color: var(--primary);
}

#difgc-accommodation .place-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 16px;
  box-shadow: var(--card-shadow);
  overflow: hidden;
}
#difgc-accommodation .place-card img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  transition: transform 0.4s ease;
}
#difgc-accommodation .place-card:hover img {
  transform: scale(1.05);
}

#difgc-accommodation .marquee-wrap {
  overflow: hidden;
  white-space: nowrap;
}
#difgc-accommodation .marquee-track {
  display: inline-flex;
  animation: difgcAccMarquee 30s linear infinite;
}
#difgc-accommodation .marquee-track:hover {
  animation-play-state: paused;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  #difgc-accommodation .hero-badge,
  #difgc-accommodation .hero-title,
  #difgc-accommodation .hero-sub,
  #difgc-accommodation .hero-cta {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
  #difgc-accommodation .section-title::after {
    transform: scaleX(1);
    transition: none;
  }
  #difgc-accommodation [data-reveal] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  #difgc-accommodation .marquee-track {
    animation: none !important;
  }
}

/* Hero 主标题：与 Award / 泰国站标题一致 — Montserrat（字号由 Tailwind text-5xl/md:text-7xl + clamp 兜底） */
#difgc-accommodation h1.hero-title {
  font-family: Montserrat, 'Noto Sans SC', 'Helvetica Neue', Helvetica, Arial, sans-serif !important;
  font-size: clamp(2rem, 5vw, 3.5rem) !important;
  line-height: 1.1 !important;
}
#difgc-accommodation .transport-card h3,
#difgc-accommodation .place-card h3 {
  font-size: clamp(1rem, 1.85vw, 1.125rem) !important;
  line-height: 1.35 !important;
}
#difgc-accommodation .bg-slate-800\/50 h3.text-xl {
  font-size: clamp(1.05rem, 2vw, 1.2rem) !important;
  line-height: 1.35 !important;
}
