/* =====================================================================
   styles.css — สไตล์ทั้งหมดของ DARK TRIP
   ธีม: แดงไวน์นีออน + ทองอบอุ่น + ดำ
   ปรับสีหลักได้ที่ :root ด้านล่าง
   ===================================================================== */

/* ===================== THEME TOKENS ===================== */
:root{
  --black:        #0a0506;   /* พื้นหลังดำอมแดง */
  --black-2:      #140a0d;   /* การ์ด/แผง */
  --black-3:      #1d0f14;   /* hover */
  --wine:         #6e0c22;   /* แดงไวน์ลึก (ผนังเลานจ์) */
  --wine-2:       #a8132f;   /* แดงไวน์สด */
  --neon:         #ff2433;   /* แดงนีออนจริงตามป้าย (โทนแดงสด) */
  --neon-soft:    #ff6360;
  --gold:         #e7b24e;   /* ทองอบอุ่น */
  --gold-2:       #f8d78a;   /* ทองสว่าง */
  --gold-deep:    #a9802f;
  --amber:        #ff8a3a;   /* แสงอำพันอบอุ่น (ambient เลานจ์) */
  --cream:        #f4e7d4;   /* ตัวอักษรอุ่น */
  --muted:        #b89a8f;
  --line:         rgba(231,178,78,.20);
  --glow-neon:    0 0 6px rgba(255,36,51,.9), 0 0 22px rgba(255,36,51,.55), 0 0 48px rgba(168,19,47,.45);
  --glow-gold:    0 0 18px rgba(231,178,78,.4);
  --glow-amber:   0 0 26px rgba(255,138,58,.4);
  --radius:       16px;
  --maxw:         1200px;
  --font-disp:    'Cinzel', 'Noto Sans Thai', serif;
  --font-body:    'Noto Sans Thai', system-ui, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--font-body);
  background:var(--black);
  color:var(--cream);
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
/* พื้นหลังเลานจ์: แสงแดงไวน์ + แอ่งแสงอำพันอบอุ่น + ขอบมืด (vignette) */
body::before{
  content:""; position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(820px 560px at 82% -8%, rgba(168,19,47,.28), transparent 60%),
    radial-gradient(680px 520px at 4% 16%, rgba(110,12,34,.34), transparent 55%),
    radial-gradient(520px 360px at 50% 4%,  rgba(255,138,58,.12), transparent 62%),  /* amber บน */
    radial-gradient(560px 460px at 50% 116%, rgba(231,178,78,.10), transparent 60%), /* ทองล่าง */
    radial-gradient(135% 120% at 50% 45%, transparent 52%, rgba(0,0,0,.6) 100%);      /* vignette */
}
body::after{ /* ฟิล์มเกรน/เส้นสแกนเบา ๆ ให้ฟีลฟิล์มกลางคืน */
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.045;
  background-image:repeating-linear-gradient(0deg,#fff 0 1px,transparent 1px 3px);
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 22px; }
section{ padding:clamp(56px,9vw,120px) 0; position:relative; }

/* ===================== HELPERS ===================== */
.eyebrow{
  font-family:var(--font-disp);
  letter-spacing:.42em; text-transform:uppercase;
  font-size:.72rem; color:var(--gold);
  display:inline-flex; align-items:center; gap:12px; margin-bottom:18px;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:linear-gradient(90deg,transparent,var(--gold)); }
h1,h2,h3{ font-family:var(--font-disp); line-height:1.15; font-weight:700; }
.neon-text{ color:var(--neon-soft); text-shadow:var(--glow-neon); }
.gold-text{ color:var(--gold-2); }
.section-title{ font-size:clamp(1.7rem,4vw,2.9rem); margin-bottom:14px; letter-spacing:.04em; }
.section-sub{ color:var(--muted); max-width:620px; margin:0 auto; }
.center{ text-align:center; }

.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-disp); font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  font-size:.8rem; padding:15px 30px; border-radius:999px; cursor:pointer;
  border:1px solid transparent; transition:.28s ease; position:relative;
}
.btn svg{ width:16px; height:16px; }
.btn-neon{
  background:linear-gradient(180deg,var(--wine-2),var(--wine));
  border-color:rgba(255,92,122,.6);
  box-shadow:var(--glow-neon);
  color:#fff;
}
.btn-neon:hover{ transform:translateY(-3px); box-shadow:0 0 10px rgba(255,31,79,1),0 0 34px rgba(255,31,79,.7),0 0 70px rgba(179,23,59,.5); }
.btn-gold{ background:transparent; border-color:var(--gold); color:var(--gold-2); }
.btn-gold:hover{ background:var(--gold); color:#1a0c05; box-shadow:var(--glow-gold); transform:translateY(-3px); }

/* ===================== BRAND / LOGO Anona (component: dt-logo) ===================== */
.brand{ display:inline-flex; align-items:center; gap:13px; text-decoration:none; }
.brand .mark{ display:inline-flex; flex:0 0 auto; }
.brand .mark svg{
  width:38px; height:38px;
  filter:drop-shadow(0 0 10px rgba(231,178,78,.5)) drop-shadow(0 0 7px rgba(255,36,51,.28));
}
.brand-words{ display:inline-flex; align-items:baseline; gap:9px; line-height:1; white-space:nowrap; }
.brand-name{
  font-family:'Playfair Display','Cormorant Garamond',Georgia,serif; font-weight:700; font-size:1.6rem; letter-spacing:.01em;
  background:linear-gradient(180deg,#fbe6ad,#e7b24e 58%,#bf9338);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
  filter:drop-shadow(0 0 9px rgba(231,178,78,.35));
}
.brand-sub{ font-family:var(--font-disp); font-size:.66rem; letter-spacing:.05em; color:var(--gold-2); opacity:.92; }
.brand-cn{ font-size:.92rem; letter-spacing:.04em; color:var(--gold-2); text-shadow:0 0 10px rgba(231,178,78,.3); }

/* footer: ใหญ่ขึ้นเล็กน้อย */
.brand--footer{ margin-bottom:18px; }
.brand--footer .mark svg{ width:44px; height:44px; }
.brand--footer .brand-name{ font-size:1.8rem; }

/* มือถือ: เหลือ A + Anona ให้กระชับ */
@media (max-width:560px){
  .brand-sub, .brand-cn{ display:none; }
  .brand-name{ font-size:1.4rem; }
  .brand .mark svg{ width:34px; height:34px; }
}

/* ===================== NAVBAR (component: dt-header) ===================== */
header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(14px);
  background:linear-gradient(180deg,rgba(10,5,6,.92),rgba(10,5,6,.55));
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.nav-links{ display:flex; align-items:center; gap:30px; list-style:none; }
.nav-links a{ font-size:.86rem; letter-spacing:.06em; color:var(--cream); position:relative; padding:6px 0; transition:.2s; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:0; width:0; height:2px; background:var(--neon); box-shadow:var(--glow-neon); transition:.28s; }
.nav-links a:hover{ color:var(--neon-soft); }
.nav-links a:hover::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }

/* --- ปุ่มเปลี่ยนภาษา (dropdown) --- */
.lang-switch{ position:relative; }
.lang-btn{
  display:inline-flex; align-items:center; gap:7px; cursor:pointer;
  font-family:var(--font-disp); font-size:.8rem; letter-spacing:.03em;
  color:var(--gold-2); background:rgba(255,255,255,.03);
  border:1px solid var(--line); padding:9px 13px; border-radius:999px; transition:.2s;
}
.lang-btn:hover{ border-color:var(--gold); box-shadow:var(--glow-gold); }
.lang-btn .caret{ font-size:.62rem; transition:transform .25s; }
.lang-switch.open .lang-btn .caret{ transform:rotate(180deg); }
.lang-menu{
  position:absolute; top:calc(100% + 8px); right:0; min-width:172px; z-index:80; margin:0;
  list-style:none; padding:6px; border-radius:14px;
  background:rgba(16,8,11,.98); backdrop-filter:blur(14px);
  border:1px solid var(--line); box-shadow:0 18px 44px rgba(0,0,0,.6), var(--glow-gold);
  opacity:0; transform:translateY(-8px) scale(.98); pointer-events:none; transition:.22s ease;
}
.lang-switch.open .lang-menu{ opacity:1; transform:none; pointer-events:auto; }
.lang-menu li{
  display:flex; align-items:center; gap:10px; padding:11px 12px; border-radius:10px; cursor:pointer;
  font-size:.88rem; color:var(--cream); transition:.16s;
}
.lang-menu li:hover{ background:rgba(231,178,78,.12); color:var(--gold-2); }
.lang-menu li.active{ color:var(--gold-2); }
.lang-menu li.active::after{ content:"✓"; margin-left:auto; color:var(--neon-soft); }
.burger span{ width:26px; height:2px; background:var(--gold-2); transition:.3s; }

/* mobile menu */
.mobile-menu{
  display:none; position:fixed; inset:74px 0 auto 0; z-index:49;
  flex-direction:column; background:rgba(10,5,6,.97); backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line); padding:18px 22px 26px;
  transform:translateY(-120%); transition:transform .35s ease; gap:4px;
}
.mobile-menu.open{ transform:translateY(0); }
.mobile-menu a{ padding:14px 6px; border-bottom:1px solid var(--line); letter-spacing:.06em; }
.mobile-menu .mm-lang{ display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; padding-top:16px; border-top:1px solid var(--line); }
.mm-lang button{
  flex:1 1 calc(50% - 8px); padding:13px 10px; border-radius:12px; cursor:pointer;
  background:rgba(255,255,255,.03); border:1px solid var(--line); color:var(--cream);
  font-family:var(--font-body); font-size:.92rem; transition:.18s;
}
.mm-lang button.active{ border-color:var(--gold); color:var(--gold-2); box-shadow:var(--glow-gold); }
.mm-lang button:active{ transform:scale(.97); }
@media (min-width:681px){ .mobile-menu{ display:none !important; } }

/* ===================== HERO (component: dt-hero) ===================== */
.hero{ min-height:92vh; display:flex; align-items:center; padding-top:40px; overflow:hidden; position:relative; }

/* --- วิดีโอพื้นหลัง Hero --- */
.hero-bg{ position:absolute; inset:0; z-index:0; overflow:hidden; background:var(--black); }
.hero-video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center;
  /* เพิ่มความเข้มขึ้นเล็กน้อยให้เข้าธีมมืด */
  filter:saturate(1.05) contrast(1.05) brightness(.85);
}
/* เลเยอร์คลุมวิดีโอ: ทำให้ตัวอักษรอ่านง่าย + ไล่โทนแดงไวน์/ทองให้เข้าธีม */
.hero-overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(10,5,6,.94) 0%, rgba(10,5,6,.78) 38%, rgba(10,5,6,.40) 100%),
    linear-gradient(180deg, rgba(10,5,6,.55) 0%, transparent 30%, rgba(10,5,6,.88) 100%),
    radial-gradient(700px 420px at 78% 30%, rgba(179,23,59,.28), transparent 65%);
}
/* ขอบล่างจางลงพื้นดำ ต่อกับ section ถัดไปอย่างเนียน */
.hero--video::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:120px; z-index:0;
  background:linear-gradient(180deg, transparent, var(--black));
}
/* เนื้อหา hero ต้องอยู่เหนือวิดีโอ */
.hero-grid{ position:relative; z-index:1; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.hero h1{ font-size:clamp(2.6rem,7vw,5.4rem); letter-spacing:.04em; }
.hero h1 .line2{ display:block; }
.hero p.lead{ color:var(--muted); font-size:clamp(1rem,1.6vw,1.18rem); margin:22px 0 30px; max-width:520px; }
.hero-actions{ display:flex; gap:16px; flex-wrap:wrap; }
.hero-stats{ display:flex; gap:34px; margin-top:46px; flex-wrap:wrap; }
.hero-stats .num{ font-family:var(--font-disp); font-size:1.9rem; color:var(--gold-2); }
.hero-stats .lbl{ font-size:.78rem; color:var(--muted); letter-spacing:.08em; }

.hero-visual{ position:relative; }
.hero-card{
  aspect-ratio:4/5; border-radius:24px; position:relative; overflow:hidden;
  background:
    linear-gradient(160deg,rgba(122,13,40,.5),rgba(10,5,6,.2)),
    repeating-linear-gradient(135deg,#1a0a10 0 22px,#220c14 22px 44px);
  border:1px solid rgba(255,92,122,.45);
  box-shadow:var(--glow-neon),inset 0 0 60px rgba(0,0,0,.6);
}
.hero-card .tag{
  position:absolute; top:18px; left:18px; font-family:var(--font-disp);
  font-size:.7rem; letter-spacing:.3em; color:var(--gold-2);
  border:1px solid var(--gold); padding:6px 12px; border-radius:999px; background:rgba(0,0,0,.4);
}
.hero-card .placeholder-txt{
  position:absolute; inset:0; display:grid; place-content:center; text-align:center;
  color:rgba(244,233,216,.35); font-family:var(--font-disp); letter-spacing:.3em; font-size:.8rem;
}
.hero-card .moon{
  position:absolute; bottom:-40px; right:-40px; width:200px; height:200px; border-radius:50%;
  background:radial-gradient(circle at 40% 40%,var(--neon),var(--wine) 55%,transparent 72%);
  filter:blur(6px); opacity:.6;
}
.float-badge{
  position:absolute; bottom:24px; left:-18px; background:var(--black-2);
  border:1px solid var(--gold); border-radius:14px; padding:14px 18px;
  box-shadow:var(--glow-gold); display:flex; align-items:center; gap:12px;
}
.float-badge .dot{ width:10px; height:10px; border-radius:50%; background:var(--neon); box-shadow:var(--glow-neon); }
.float-badge small{ display:block; color:var(--muted); font-size:.7rem; }
.float-badge b{ color:var(--gold-2); font-family:var(--font-disp); }

/* ===================== MARQUEE (component: dt-marquee) ===================== */
.marquee{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:16px 0; overflow:hidden; background:rgba(122,13,40,.12); }
.marquee-track{ display:flex; gap:48px; white-space:nowrap; animation:scroll 22s linear infinite; }
.marquee span{ font-family:var(--font-disp); letter-spacing:.3em; color:var(--gold); font-size:.9rem; }
.marquee span i{ color:var(--neon-soft); font-style:normal; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ===================== ABOUT (component: dt-about) ===================== */
.about-grid{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.about-visual{
  aspect-ratio:1/1; border-radius:20px; position:relative; overflow:hidden;
  border:1px solid var(--line);
  background:
    radial-gradient(circle at 70% 20%,rgba(255,31,79,.3),transparent 50%),
    repeating-linear-gradient(45deg,#150a0f 0 30px,#1d0e14 30px 60px);
  box-shadow:inset 0 0 70px rgba(0,0,0,.7);
}
.about-visual .frame-label{ position:absolute; inset:auto 0 0 0; padding:20px; font-family:var(--font-disp); letter-spacing:.2em; color:var(--muted); font-size:.75rem; }
.about h2{ font-size:clamp(1.8rem,4vw,3rem); margin-bottom:18px; }
.about p{ color:var(--muted); margin-bottom:18px; }
.check-list{ list-style:none; display:grid; gap:14px; margin-top:24px; }
.check-list li{ display:flex; gap:14px; align-items:flex-start; }
.check-list .ic{ color:var(--gold-2); flex:0 0 auto; box-shadow:var(--glow-gold); width:26px; height:26px; border-radius:50%; border:1px solid var(--gold); display:grid; place-items:center; font-size:.8rem; }

/* ===================== TRIPS / CARDS (component: dt-trips) ===================== */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:50px; }
.card{
  background:linear-gradient(180deg,var(--black-2),var(--black));
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  transition:.32s ease; position:relative;
}
.card:hover{ transform:translateY(-8px); border-color:rgba(255,92,122,.5); box-shadow:var(--glow-neon); }
.card-thumb{
  aspect-ratio:16/10; position:relative; overflow:hidden;
  background:repeating-linear-gradient(135deg,#1a0a10 0 24px,#23101a 24px 48px);
  display:grid; place-items:center;
}
.card-thumb .glow{ position:absolute; width:140px; height:140px; border-radius:50%; background:radial-gradient(circle,var(--neon),transparent 70%); opacity:.45; filter:blur(8px); top:-30px; right:-30px; }
.card-thumb .num{ font-family:var(--font-disp); font-size:3.4rem; color:rgba(232,181,88,.18); font-weight:900; }
.card-price{ position:absolute; bottom:12px; left:12px; background:rgba(0,0,0,.55); border:1px solid var(--gold); color:var(--gold-2); font-family:var(--font-disp); font-size:.8rem; padding:6px 12px; border-radius:999px; }
.card-body{ padding:24px; }
.card-body h3{ font-size:1.2rem; margin-bottom:10px; color:var(--cream); }
.card-body p{ color:var(--muted); font-size:.92rem; margin-bottom:18px; }
.card-body .meta{ display:flex; gap:16px; font-size:.78rem; color:var(--gold); border-top:1px solid var(--line); padding-top:14px; flex-wrap:wrap; }
/* ปุ่ม CTA LINE / WeChat ในการ์ดแพ็กเกจ */
.card-cta{ display:flex; gap:10px; margin-top:16px; }
.card-cta a{
  flex:1; display:inline-flex; align-items:center; justify-content:center; gap:7px;
  padding:11px 8px; border-radius:11px; color:#fff; text-decoration:none;
  font-family:var(--font-disp); font-weight:700; font-size:.78rem; letter-spacing:.03em;
  transition:.2s ease; white-space:nowrap;
}
.card-cta a svg{ width:17px; height:17px; flex:0 0 auto; }
.cta-line{ background:linear-gradient(180deg,#0ad96a,#06C755); box-shadow:0 4px 14px rgba(6,199,85,.35); }
.cta-line:hover{ transform:translateY(-2px); box-shadow:0 8px 22px rgba(6,199,85,.55); }
.cta-wechat{ background:linear-gradient(180deg,#19d873,#07C160); box-shadow:0 4px 14px rgba(7,193,96,.35); }
.cta-wechat:hover{ transform:translateY(-2px); box-shadow:0 8px 22px rgba(7,193,96,.55); }
.card-cta a:active{ transform:scale(.97); }
.card-tag{ position:absolute; top:12px; left:12px; z-index:2; background:var(--neon); color:#fff; font-size:.66rem; letter-spacing:.15em; padding:5px 11px; border-radius:999px; box-shadow:var(--glow-neon); font-family:var(--font-disp); }

/* ===================== FEATURES (component: dt-features) ===================== */
.features{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:50px; }
.feature{
  text-align:center; padding:34px 22px; border:1px solid var(--line); border-radius:var(--radius);
  background:rgba(20,10,13,.5); transition:.3s;
}
.feature:hover{ border-color:var(--gold); box-shadow:var(--glow-gold); transform:translateY(-6px); }
.feature .ic{
  width:60px; height:60px; margin:0 auto 18px; border-radius:50%; display:grid; place-items:center;
  font-size:1.5rem; color:var(--gold-2);
  background:radial-gradient(circle at 35% 30%,rgba(255,31,79,.3),transparent 60%);
  border:1px solid var(--gold); box-shadow:var(--glow-gold);
}
.feature .ic svg{ width:26px; height:26px; }
.feature h3{ font-size:1.05rem; margin-bottom:8px; color:var(--cream); }
.feature p{ color:var(--muted); font-size:.86rem; }

/* ===================== REVIEWS (component: dt-reviews) ===================== */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:50px; }
.review{
  background:linear-gradient(180deg,var(--black-2),var(--black)); border:1px solid var(--line);
  border-radius:var(--radius); padding:28px; position:relative;
}
.review .stars{ color:var(--gold-2); display:flex; gap:3px; margin-bottom:14px; filter:drop-shadow(var(--glow-gold)); }
.review .stars svg{ width:18px; height:18px; }
.review p{ color:var(--cream); font-size:.95rem; margin-bottom:20px; }
.review .who{ display:flex; align-items:center; gap:12px; }
.review .ava{ width:42px; height:42px; border-radius:50%; background:radial-gradient(circle at 35% 30%,var(--wine-2),var(--wine)); border:1px solid var(--gold); display:grid; place-items:center; font-family:var(--font-disp); color:var(--gold-2); }
.review .who b{ font-size:.9rem; }
.review .who small{ color:var(--muted); font-size:.74rem; }
.quote-mark{ position:absolute; top:16px; right:22px; font-family:var(--font-disp); font-size:3rem; color:rgba(255,31,79,.18); }

/* ===================== CTA BAND (component: dt-cta) ===================== */
.cta-band{ text-align:center; }
.cta-inner{
  border:1px solid rgba(255,92,122,.4); border-radius:26px; padding:clamp(40px,6vw,72px) 26px;
  background:
    radial-gradient(600px 300px at 50% 0%,rgba(255,31,79,.18),transparent 60%),
    linear-gradient(180deg,var(--black-2),var(--black));
  box-shadow:var(--glow-neon);
}
.cta-inner h2{ font-size:clamp(1.8rem,5vw,3.2rem); margin-bottom:16px; }
.cta-inner p{ color:var(--muted); margin-bottom:30px; }

/* =====================================================================
   SOCIAL BAR (component: dt-social) — ดีไซน์ใหม่: แคปซูลนีออนกระจก
   - ปกติ = วงกลมไอคอนสีแบรนด์ (glass)
   - hover = แคปซูลกางออกโชว์ชื่อ + พื้นสีแบรนด์ + แสงวิ่งผ่าน (sheen) + ไอคอนเด้ง
   - LINE/WeChat (.soc--primary) = กางชื่อค้างไว้ + วงแหวนเรืองแสงเต้นตลอด
   ===================================================================== */
.socials{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-top:14px; }

.soc{
  /* ตัวแปรสีต่อแพลตฟอร์ม (กำหนดด้านล่าง) */
  --c:   var(--gold-2);
  --glow: rgba(232,181,88,.55);
  --ring: rgba(232,181,88,.35);

  position:relative; display:inline-flex; align-items:center;
  height:50px; border-radius:999px; overflow:hidden; isolation:isolate;
  color:var(--c);
  background:linear-gradient(160deg,rgba(255,255,255,.07),rgba(255,255,255,.01));
  border:1px solid var(--ring);
  backdrop-filter:blur(8px);
  transition:background .3s ease, color .3s ease, box-shadow .35s ease,
             transform .3s cubic-bezier(.22,1,.36,1);
}
/* ช่องไอคอน (คงที่ทรงกลม) */
.soc-ic{ flex:0 0 50px; height:50px; display:grid; place-items:center; z-index:2; }
.soc-ic svg{ width:21px; height:21px; transition:transform .4s cubic-bezier(.34,1.56,.64,1); }
/* ป้ายชื่อ (ซ่อนไว้ ม้วนออกตอน hover) */
.soc-label{
  display:inline-flex; align-items:center; gap:7px; white-space:nowrap; z-index:2;
  max-width:0; overflow:hidden; opacity:0;
  font-family:var(--font-disp); font-weight:700; font-size:.78rem; letter-spacing:.1em; color:#fff;
  transition:max-width .42s cubic-bezier(.22,1,.36,1), opacity .3s ease, padding .35s ease;
}
/* แสงวิ่งผ่าน (sheen) */
.soc::before{
  content:""; position:absolute; top:0; left:-70%; width:55%; height:100%; z-index:1;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);
  transform:skewX(-18deg); opacity:0; pointer-events:none;
}
@keyframes soc-sheen{ 0%{left:-70%;opacity:0} 25%{opacity:1} 100%{left:130%;opacity:0} }

/* hover: กางออก + เปลี่ยนเป็นพื้นสีแบรนด์ */
.soc:hover{
  background:var(--c); color:#fff; border-color:transparent;
  box-shadow:0 8px 22px var(--glow), 0 0 22px var(--glow);
  transform:translateY(-4px);
}
.soc:hover .soc-label{ max-width:170px; opacity:1; padding-right:22px; }
.soc:hover .soc-ic svg{ transform:rotate(-10deg) scale(1.18); }
.soc:hover::before{ animation:soc-sheen .75s ease; }

/* --- สีแบรนด์จริงของแต่ละแพลตฟอร์ม --- */
.soc--line{      --c:#06C755; --glow:rgba(6,199,85,.5);   --ring:rgba(6,199,85,.4); }
.soc--wechat{    --c:#07C160; --glow:rgba(7,193,96,.5);   --ring:rgba(7,193,96,.4); }
.soc--facebook{  --c:#1877F2; --glow:rgba(24,119,242,.5); --ring:rgba(24,119,242,.4); }
.soc--instagram{ --c:#E4405F; --glow:rgba(228,64,95,.5);  --ring:rgba(228,64,95,.4); }
.soc--youtube{   --c:#FF0000; --glow:rgba(255,0,0,.5);    --ring:rgba(255,0,0,.4); }
.soc--tiktok{    --c:#22d3e0; --glow:rgba(34,211,224,.5); --ring:rgba(34,211,224,.4); }
.soc--whatsapp{  --c:#25D366; --glow:rgba(37,211,102,.5); --ring:rgba(37,211,102,.4); }
.soc--x{         --c:#e9e9e9; --glow:rgba(255,255,255,.4);--ring:rgba(255,255,255,.3); }
.soc--telegram{  --c:#26A5E4; --glow:rgba(38,165,228,.5); --ring:rgba(38,165,228,.4); }
/* Instagram hover ใช้ไล่เฉดของจริง */
.soc--instagram:hover{ background:linear-gradient(45deg,#F58529,#DD2A7B 55%,#8134AF); }
/* TikTok hover พื้นดำ */
.soc--tiktok:hover{ background:#000; box-shadow:0 8px 22px rgba(34,211,224,.5), 0 0 18px rgba(238,29,82,.5); }

/* ★ LINE + WeChat = ช่องทางหลัก: กางชื่อค้าง + พื้นสีเต็ม + วงแหวนเต้น */
.soc--primary{
  background:var(--c); color:#fff; border-color:transparent;
  box-shadow:0 0 16px var(--glow); animation:soc-pulse 2.6s ease-in-out infinite;
}
.soc--primary .soc-ic svg{ width:24px; height:24px; }
.soc--primary .soc-label{ max-width:170px; opacity:1; padding-right:22px; }
.soc--primary:hover{ transform:translateY(-4px) scale(1.04); }
@keyframes soc-pulse{
  0%,100%{ box-shadow:0 0 14px var(--glow); }
  50%{ box-shadow:0 0 28px var(--glow), 0 0 8px var(--glow); }
}
/* จุดไฟกะพริบหน้า LINE/WeChat */
.soc-dot{
  width:8px; height:8px; border-radius:50%; background:#fff; flex:0 0 auto;
  box-shadow:0 0 8px #fff; animation:soc-blink 1.4s ease-in-out infinite;
}
@keyframes soc-blink{ 0%,100%{opacity:1; transform:scale(1)} 50%{opacity:.4; transform:scale(.7)} }

/* ลดการเคลื่อนไหวถ้าผู้ใช้ตั้งค่า reduce motion */
@media (prefers-reduced-motion:reduce){
  .soc, .soc *{ animation:none !important; transition:none !important; }
}

/* ===================== FOOTER (component: dt-footer) ===================== */
footer{ border-top:1px solid var(--line); background:linear-gradient(180deg,var(--black),#070304); padding:60px 0 28px; }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1fr 1.4fr; gap:40px; }
.foot-grid h4{ font-family:var(--font-disp); color:var(--gold-2); letter-spacing:.12em; margin-bottom:18px; font-size:.92rem; }
.foot-grid a, .foot-grid p{ color:var(--muted); font-size:.88rem; display:block; margin-bottom:10px; transition:.2s; }
.foot-col-links a:hover{ color:var(--neon-soft); }
.foot-about p{ display:block; }
.contact-list{ list-style:none; }
.contact-list li{ display:flex; align-items:center; gap:10px; color:var(--muted); font-size:.88rem; margin-bottom:12px; }
.contact-list .ic{ width:18px; height:18px; color:var(--gold-2); flex:0 0 auto; }
.contact-list .ic svg{ width:18px; height:18px; }
.copyright{ border-top:1px solid var(--line); margin-top:40px; padding-top:24px; text-align:center; color:var(--muted); font-size:.8rem; }
.copyright .age{ color:var(--neon-soft); border:1px solid rgba(255,92,122,.4); padding:3px 10px; border-radius:999px; font-size:.72rem; margin-right:8px; }

/* คอลัมน์ติดต่อ: ข้อมูล + การ์ด QR */
.foot-contact{ display:flex; flex-direction:column; gap:20px; }

/* --- การ์ด QR LINE --- */
.qr-card{ display:flex; align-items:center; gap:14px; }
.qr-frame{
  position:relative; flex:0 0 auto; width:104px; height:104px; padding:7px;
  background:#fff; border-radius:12px; box-shadow:0 0 0 1px rgba(6,199,85,.5), 0 0 20px rgba(6,199,85,.35);
}
.qr-frame img, .qr-frame .qr-svg, .qr-frame .qr-svg svg{ width:100%; height:100%; display:block; border-radius:4px; object-fit:cover; }
.qr-badge{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:26px; height:26px; border-radius:7px; background:#06C755; display:grid; place-items:center;
  color:#fff; box-shadow:0 0 0 3px #fff;
}
.qr-badge svg{ width:16px; height:16px; }
.qr-meta b{ display:block; color:var(--cream); font-family:var(--font-disp); letter-spacing:.06em; }
.qr-meta small{ display:block; color:var(--muted); font-size:.8rem; margin:4px 0 8px; line-height:1.4; }
.qr-id{ display:inline-block; font-size:.74rem; color:var(--gold-2); border:1px solid var(--line); padding:3px 9px; border-radius:999px; }

/* ===================== REVEAL ANIMATION ===================== */
.reveal{ opacity:0; transform:translateY(28px); transition:.7s ease; }
.reveal.show{ opacity:1; transform:none; }

/* =====================================================================
   CAST / ทีมงาน — การ์ดรูปแนวตั้ง + ชื่อ/ตำแหน่งใต้การ์ด (responsive)
   ===================================================================== */
#cast .cast-grid{
  display:grid; gap:20px; margin-top:48px;
  grid-template-columns:repeat(auto-fit, minmax(190px, 1fr));   /* PC: รูปใหญ่ เด่น */
}
.cast-card{ transition:.2s; }
/* การ์ด = รูปเต็มใบ (ชื่อซ้อนบนรูป) */
.cast-photo{
  position:relative; aspect-ratio:3/4; border-radius:18px; overflow:hidden;
  border:1px solid rgba(231,178,78,.32);
  box-shadow:0 10px 30px rgba(0,0,0,.5);
  transition:transform .4s ease, box-shadow .4s ease, border-color .4s ease;
}
/* เลเยอร์รูป (ซูมได้โดยไม่ดันกรอบ) */
.cast-media{
  position:absolute; inset:0; background:#160b10 center/cover no-repeat;
  transition:transform .65s cubic-bezier(.2,.8,.2,1);
}
.cast-media.is-empty{ background:linear-gradient(160deg,#241019,#120a0e); }
/* ไล่เงาล่างให้ชื่ออ่านง่าย + รูปดูพรีเมียม */
.cast-photo::after{
  content:""; position:absolute; inset:0; z-index:1; transition:.35s;
  background:linear-gradient(180deg, transparent 42%, rgba(10,5,6,.2) 58%, rgba(10,5,6,.86));
}
/* กรอบทองเรือง (โผล่ตอน hover) */
.cast-photo::before{
  content:""; position:absolute; inset:0; z-index:3; border-radius:18px; pointer-events:none;
  border:1px solid rgba(248,215,138,0); transition:.4s;
}
.cast-ph{ position:absolute; inset:0; z-index:1; display:grid; place-items:center;
  font-family:var(--font-disp); font-weight:800; font-size:3rem; color:rgba(248,215,138,.32); }
/* ชื่อซ้อนบนรูป */
.cast-name{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:14px 12px 16px; text-align:center; }
.cast-name b{ font-family:var(--font-disp); color:var(--cream); font-size:1.06rem; letter-spacing:.06em;
  text-shadow:0 2px 12px rgba(0,0,0,.7); transition:.3s; }
/* ป้ายเพชร Ace นีออนมุมบน */
.cast-ace{ position:absolute; top:10px; right:10px; z-index:3; width:17px; height:17px; color:var(--neon);
  filter:drop-shadow(var(--glow-neon)); opacity:.92; }
.cast-ace svg{ width:100%; height:100%; }
/* แสงกวาดผ่าน */
.cast-shine{ position:absolute; top:0; left:-60%; width:55%; height:100%; z-index:2; pointer-events:none;
  transform:skewX(-18deg); opacity:0; background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent); }
@keyframes castShine{ 0%{left:-60%;opacity:0} 25%{opacity:1} 100%{left:120%;opacity:0} }

/* hover (PC): ยกลอย + รูปซูม + กรอบทอง + นีออน + แสงกวาด */
.cast-card:hover .cast-photo{ transform:translateY(-7px); border-color:rgba(255,92,122,.55);
  box-shadow:0 18px 44px rgba(0,0,0,.6), var(--glow-neon); }
.cast-card:hover .cast-media{ transform:scale(1.09); }
.cast-card:hover .cast-photo::after{ background:linear-gradient(180deg, transparent 38%, rgba(122,13,40,.35) 60%, rgba(10,5,6,.9)); }
.cast-card:hover .cast-photo::before{ border-color:rgba(248,215,138,.55); box-shadow:inset 0 0 20px rgba(231,178,78,.28); }
.cast-card:hover .cast-name b{ color:var(--gold-2); }
.cast-card:hover .cast-shine{ animation:castShine .8s ease; }

/* มือถือ/จอสัมผัส: ไม่มี hover → ให้รูปขยับช้า ๆ (ken-burns) เป็นลูกเล่น */
@media (hover:none){
  .cast-media{ animation:castKen 16s ease-in-out infinite alternate; }
}
@keyframes castKen{ from{ transform:scale(1) } to{ transform:scale(1.1) } }

@media (max-width:1024px){ #cast .cast-grid{ grid-template-columns:repeat(auto-fit, minmax(150px, 1fr)); gap:14px; } }
@media (max-width:680px){
  #cast .cast-grid{ grid-template-columns:1fr 1fr; gap:12px; }   /* มือถือ: 2 คอลัมน์ */
  .cast-ph{ font-size:2.2rem; }
  .cast-name b{ font-size:.96rem; }
  .cast-card:active .cast-photo{ transform:scale(.98); }
}
@media (prefers-reduced-motion:reduce){
  .cast-media, .cast-shine{ animation:none !important; transition:none !important; }
}

/* =====================================================================
   GALLERY — โซนรูปภาพ (สร้างอัตโนมัติเมื่อมีรูป slot 'gallery' จากแอดมิน)
   ===================================================================== */
#gallery .gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:44px; }
.gallery-item{
  display:block; aspect-ratio:1/1; border-radius:14px; border:1px solid var(--line);
  background:#120a0e center/cover no-repeat; position:relative; overflow:hidden;
  box-shadow:inset 0 0 50px rgba(0,0,0,.5); transition:.32s ease;
}
.gallery-item::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(122,13,40,.45));
  opacity:0; transition:.3s;
}
.gallery-item:hover{ transform:translateY(-5px); border-color:rgba(255,92,122,.5); box-shadow:var(--glow-neon); }
.gallery-item:hover::after{ opacity:1; }
@media (max-width:1024px){ #gallery .gallery-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:680px){ #gallery .gallery-grid{ grid-template-columns:1fr 1fr; gap:10px; } }

/* =====================================================================
   LOUNGE FX — ลูกเล่นพรีเมียมสไตล์บาร์/เลานจ์ (Anona vibe)
   ทองชิมเมอร์ · ประกายดาว · หลอดนีออน · ริบบิ้นทอง · มงกุฎ · ออร่าอำพัน
   ===================================================================== */

/* --- ทองชิมเมอร์: ตัวอักษรทองมีแสงกวาดผ่าน --- */
.gold-text{
  background:linear-gradient(100deg,
    var(--gold) 0%, var(--gold-2) 22%, #fff6da 38%, var(--gold-2) 54%, var(--gold) 74%);
  background-size:220% auto;
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
  filter:drop-shadow(0 0 10px rgba(231,178,78,.35));
  animation:goldShine 7s linear infinite;
}
@keyframes goldShine{ to{ background-position:-220% center; } }

/* --- ออร่าแสงอำพันลอย (ทั้งหน้า) --- */
.fx-orbs{ position:fixed; inset:0; z-index:-1; pointer-events:none; overflow:hidden; }
.fx-orbs i{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.16; }
.fx-orbs i:nth-child(1){ width:360px; height:360px; left:-70px; top:14%; background:var(--amber); animation:orbA 20s ease-in-out infinite; }
.fx-orbs i:nth-child(2){ width:320px; height:320px; right:-60px; top:52%; background:var(--neon);  animation:orbB 26s ease-in-out infinite; }
.fx-orbs i:nth-child(3){ width:260px; height:260px; left:38%;  top:78%; background:var(--gold);  animation:orbA 30s ease-in-out infinite; }
@keyframes orbA{ 0%,100%{ transform:translate(0,0) } 50%{ transform:translate(20px,42px) } }
@keyframes orbB{ 0%,100%{ transform:translate(0,0) } 50%{ transform:translate(-26px,-34px) } }

/* --- เลเยอร์เอฟเฟกต์ใน Hero --- */
.hero-grid{ z-index:2; }
.hero-fx{ position:absolute; inset:0; z-index:1; overflow:hidden; pointer-events:none; }

/* ประกายดาวทอง (สร้างด้วย JS) */
.spark{
  position:absolute; color:var(--gold-2); line-height:1; font-size:var(--s,12px);
  text-shadow:0 0 8px rgba(248,215,138,.95); opacity:0; z-index:1; pointer-events:none;
  animation:twinkle var(--d,3s) ease-in-out infinite var(--delay,0s);
}
@keyframes twinkle{
  0%,100%{ opacity:0; transform:scale(.4) rotate(0deg); }
  50%{ opacity:1; transform:scale(1) rotate(45deg); }
}

/* หลอดนีออนแดงแนวตั้ง (กรอบ Hero แบบป้าย) */
.neon-tube{
  position:absolute; top:7%; bottom:7%; width:4px; border-radius:6px;
  background:linear-gradient(180deg, transparent, var(--neon) 12%, var(--neon-soft) 50%, var(--neon) 88%, transparent);
  box-shadow:0 0 10px var(--neon), 0 0 26px rgba(255,36,51,.7);
  animation:tubeFlicker 5s linear infinite;
}
.neon-tube.left{ left:10px; }
.neon-tube.right{ right:10px; animation-delay:.6s; }
@keyframes tubeFlicker{
  0%,100%{ opacity:.95 } 46%{ opacity:.95 } 47%{ opacity:.55 } 48%{ opacity:.95 }
  70%{ opacity:.85 } 71%{ opacity:1 } 92%{ opacity:.9 } 93%{ opacity:1 }
}

/* ริบบิ้นทองไหล (signature swoosh ของป้าย) */
.gold-ribbon{ position:absolute; left:0; right:0; bottom:5%; width:100%; height:130px; opacity:.8; }
.gold-ribbon .rb-base{ fill:none; stroke:rgba(231,178,78,.30); stroke-width:2; }
.gold-ribbon .rb-glow{
  fill:none; stroke:url(#rbGrad); stroke-width:3; stroke-linecap:round;
  stroke-dasharray:70 660; filter:drop-shadow(0 0 6px rgba(248,215,138,.9));
  animation:ribbonRun 6s linear infinite;
}
@keyframes ribbonRun{ to{ stroke-dashoffset:-730; } }

/* มงกุฎ crest เหนือหัวข้อ Hero */
.hero-crest{ display:inline-flex; align-items:center; gap:10px; margin-bottom:14px; }
.hero-crest .crown{ width:30px; height:30px; color:var(--gold-2); filter:drop-shadow(var(--glow-gold)); animation:crestGlow 3.5s ease-in-out infinite; }
.hero-crest .line{ width:42px; height:1px; background:linear-gradient(90deg,transparent,var(--gold)); }
@keyframes crestGlow{ 0%,100%{ filter:drop-shadow(0 0 6px rgba(248,215,138,.4)); } 50%{ filter:drop-shadow(0 0 14px rgba(248,215,138,.85)); } }

/* --- การ์ดพรีเมียม: แสงทองกวาดด้านบนตอน hover --- */
.card::after{
  content:""; position:absolute; inset:0; z-index:3; pointer-events:none; opacity:0;
  background:linear-gradient(120deg, transparent 40%, rgba(248,215,138,.16) 50%, transparent 60%);
  background-size:240% 100%; background-position:140% 0; transition:opacity .3s;
}
.card:hover::after{ opacity:1; animation:cardSheen 1s ease forwards; }
@keyframes cardSheen{ to{ background-position:-40% 0; } }

/* เส้นขอบไพ่ Ace สีแดงในมุมการ์ดเด่น (HOT/NEW) */
.card-tag{ background:linear-gradient(180deg,var(--neon),#c40f24); }

/* ปุ่มนีออน: แสงเต้นเบา ๆ ให้รู้สึก “เปิดไฟ” */
.btn-neon{ animation:btnBreath 3.2s ease-in-out infinite; }
@keyframes btnBreath{
  0%,100%{ box-shadow:0 0 6px rgba(255,36,51,.8),0 0 20px rgba(255,36,51,.5),0 0 42px rgba(168,19,47,.35); }
  50%{ box-shadow:0 0 9px rgba(255,36,51,1),0 0 30px rgba(255,36,51,.7),0 0 60px rgba(168,19,47,.5); }
}

/* เคารพการตั้งค่าลดการเคลื่อนไหว */
@media (prefers-reduced-motion:reduce){
  .gold-text, .fx-orbs i, .spark, .neon-tube, .gold-ribbon .rb-glow, .hero-crest .crown,
  .btn-neon, .card:hover::after{ animation:none !important; }
  .gold-text{ -webkit-text-fill-color:initial; color:var(--gold-2); background:none; }
}

/* =====================================================================
   RESPONSIVE — แนวทาง Mobile-First (ปรับละเอียดสำหรับมือถือ/แท็บเล็ต)
   ===================================================================== */

/* --- globals: สัมผัส + ขอบจอปลอดภัย (notch/home indicator) --- */
.wrap{
  padding-left:max(22px, env(safe-area-inset-left));
  padding-right:max(22px, env(safe-area-inset-right));
}
a, button, .btn, .soc, .mbar-btn{ -webkit-tap-highlight-color:transparent; }
.btn{ min-height:48px; }                 /* ปุ่มแตะง่าย ≥48px */
.btn:active{ transform:scale(.97); }

/* เบอร์เกอร์ → กากบาท (X) */
.burger span{ transform-origin:center; }
.burger.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.is-open span:nth-child(2){ opacity:0; }
.burger.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ค่าเริ่มต้น: ซ่อนองค์ประกอบเฉพาะมือถือ */
.mobile-bar{ display:none; }
.swipe-hint{ display:none; }

/* ===== แท็บเล็ตแนวนอน / จอกลาง ===== */
@media (max-width:1024px){
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
  .hero-visual{ max-width:440px; margin:0 auto; width:100%; }
  .about-grid{ grid-template-columns:1fr; gap:36px; }
  .cards{ grid-template-columns:repeat(2,1fr); }
  .features{ grid-template-columns:repeat(2,1fr); }
  .reviews{ grid-template-columns:1fr 1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:32px; }
}

/* ===== แท็บเล็ตแนวตั้ง: กันเมนูบนแน่นเกินไป (ยังเปลี่ยนภาษาได้) ===== */
@media (max-width:900px){
  .nav-links{ gap:18px; }
  .nav-links a{ font-size:.78rem; }
  .lang-btn{ padding:8px 11px; font-size:.76rem; }
}

/* ===== มือถือ (≤680px) ===== */
@media (max-width:680px){
  /* --- Header --- */
  .nav{ height:64px; }
  .nav-links{ display:none; }
  .nav-cta{ gap:6px; }
  .nav-cta .btn{ display:none; }            /* ใช้แถบติดต่อด่วนล่างจอแทน */
  /* ปุ่มเปลี่ยนภาษาโชว์บนมือถือ (เหลือธง) */
  .lang-switch{ display:block; }
  .lang-btn{ padding:8px 9px; gap:4px; font-size:.78rem; }
  .lang-btn .ll{ display:none; }
  .lang-btn .lf{ font-size:1.1rem; line-height:1; }
  .lang-menu{ min-width:184px; padding:7px; }
  .lang-menu li{ padding:14px 14px; font-size:.96rem; }
  .lg-flag{ font-size:1.15rem; }
  .burger{ display:flex; padding:9px; }
  .mobile-menu{ inset:64px 0 auto 0; padding:12px 20px calc(20px + env(safe-area-inset-bottom)); }
  .mobile-menu a{ font-size:1.02rem; padding:16px 6px; }

  /* --- จังหวะ/ตัวอักษรรวม --- */
  section{ padding:44px 0; }
  .section-title{ font-size:clamp(1.5rem,7.5vw,2rem); }
  .eyebrow{ font-size:.64rem; letter-spacing:.26em; margin-bottom:14px; }
  .section-sub{ font-size:.92rem; }

  /* --- Hero: เนื้อหาวางล่าง ให้เด่นบนวิดีโอ --- */
  .hero{ min-height:86vh; padding:24px 0 20px; align-items:flex-end; }
  .hero--video{ min-height:88vh; }
  .hero-visual{ display:none; }              /* ตัดการ์ด placeholder ออก ให้หน้าสะอาด */
  /* FX: หลอดนีออนบางลง + ริบบิ้น/มงกุฎ/ประกายย่อส่วน */
  .neon-tube{ width:3px; top:10%; bottom:10%; }
  .neon-tube.left{ left:6px; } .neon-tube.right{ right:6px; }
  .gold-ribbon{ height:90px; bottom:3%; }
  .hero-crest .crown{ width:26px; height:26px; }
  .hero-crest .line{ width:30px; }
  .fx-orbs i{ filter:blur(54px); opacity:.13; }
  .hero h1{ font-size:clamp(2.3rem,11vw,3rem); }
  .hero p.lead{ font-size:1rem; margin:16px 0 24px; }
  .hero-actions{ flex-direction:column; gap:12px; }
  .hero-actions .btn{ width:100%; justify-content:center; }
  .hero-stats{ margin-top:30px; gap:10px; width:100%; }
  .hero-stats > div{ flex:1 1 0; min-width:0; text-align:center; }
  .hero-stats .num{ font-size:1.35rem; }
  .hero-stats .lbl{ font-size:.66rem; letter-spacing:.04em; }

  /* --- About --- */
  .about-visual{ aspect-ratio:4/3; }

  /* --- Trips: การ์ดปัดแนวนอน (swipe carousel) + snap --- */
  .cards{
    display:grid; grid-auto-flow:column; grid-template-columns:none;
    grid-auto-columns:84%; gap:14px;
    overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
    padding:4px 4px 16px; margin-inline:-4px; scroll-padding-inline:4px;
    scrollbar-width:none;
  }
  .cards::-webkit-scrollbar{ display:none; }
  .card{ scroll-snap-align:center; }
  .card:hover{ transform:none; box-shadow:none; border-color:var(--line); }  /* ไม่มี hover บนสัมผัส */
  .card:active{ transform:scale(.985); }
  .swipe-hint{ display:block; text-align:center; margin-top:4px; color:var(--muted); font-size:.76rem; letter-spacing:.05em; }

  /* --- Features: 2 คอลัมน์กระชับ --- */
  .features{ grid-template-columns:1fr 1fr; gap:12px; }
  .feature{ padding:22px 14px; }
  .feature .ic{ width:50px; height:50px; margin-bottom:12px; }
  .feature h3{ font-size:.98rem; }
  .feature p{ font-size:.8rem; }

  /* --- Reviews: ปัดแนวนอนเช่นกัน --- */
  .reviews{
    display:grid; grid-auto-flow:column; grid-template-columns:none;
    grid-auto-columns:88%; gap:14px;
    overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
    padding-bottom:8px; scrollbar-width:none;
  }
  .reviews::-webkit-scrollbar{ display:none; }
  .review{ scroll-snap-align:center; }

  /* --- CTA --- */
  .cta-inner .hero-actions{ flex-direction:column; }

  /* --- Footer: จัดให้กระชับ ไม่เรียงยาว --- */
  .foot-grid{ grid-template-columns:1fr 1fr; text-align:left; gap:26px 16px; }
  .foot-about{ grid-column:1 / -1; text-align:center; }       /* แบรนด์+โซเชียล เต็มแถว กึ่งกลาง */
  .foot-about .brand{ justify-content:center; }
  .foot-about .socials{ justify-content:center; }
  .foot-col-links{ text-align:left; }                          /* เมนู | แพ็กเกจ วางคู่กัน */
  .foot-contact{ grid-column:1 / -1; flex-direction:row; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px; padding-top:6px; border-top:1px solid var(--line); }
  .foot-contact-info{ flex:1 1 160px; }
  .contact-list li{ justify-content:flex-start; }
  .qr-card{ flex:0 0 auto; }
  footer{ padding:46px 0 24px; }

  /* --- โซเชียล: ทุกตัวขนาดเท่ากัน แตะง่าย --- */
  .socials{ gap:10px; justify-content:center; }
  .soc{ height:52px; }
  .soc-ic{ flex-basis:52px; height:52px; }

  /* --- แถบติดต่อด่วน ติดล่างจอ (mobile bottom action bar) --- */
  body{ padding-bottom:calc(78px + env(safe-area-inset-bottom)); }
  .mobile-bar{
    display:grid; grid-template-columns:repeat(3,1fr); gap:8px;
    position:fixed; left:0; right:0; bottom:0; z-index:60;
    padding:9px 12px calc(9px + env(safe-area-inset-bottom));
    background:rgba(10,5,6,.97); backdrop-filter:blur(16px);
    border-top:1px solid var(--line);
  }
  .mbar-btn{
    display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px;
    min-height:54px; border-radius:14px; color:var(--cream);
    font-family:var(--font-disp); font-size:.7rem; letter-spacing:.04em;
    border:1px solid var(--line); transition:transform .15s ease;
  }
  .mbar-btn svg{ width:20px; height:20px; }
  .mbar-btn:active{ transform:scale(.93); }
  .mbar-line{ background:#06C755; color:#fff; border-color:transparent; }
  .mbar-call{ color:var(--gold-2); border-color:var(--gold); }
  .mbar-book{ background:linear-gradient(180deg,var(--wine-2),var(--wine)); color:#fff; border-color:rgba(255,92,122,.6); box-shadow:0 0 14px rgba(255,31,79,.5); }
}

/* ===== จอเล็กพิเศษ (≤380px) ===== */
@media (max-width:380px){
  .wrap{ padding-left:max(16px, env(safe-area-inset-left)); padding-right:max(16px, env(safe-area-inset-right)); }
  .hero h1{ font-size:2.05rem; }
  .hero-stats .num{ font-size:1.18rem; }
  .brand b{ font-size:1.02rem; letter-spacing:.12em; }
  .cards{ grid-auto-columns:90%; }
  .mbar-btn{ font-size:.64rem; }
  /* QR: จัดกึ่งกลางเต็มแถวบนจอเล็ก */
  .foot-contact{ justify-content:center; }
  .qr-card{ flex-direction:column; text-align:center; gap:10px; }
  .qr-meta small{ margin:4px auto 8px; }
}
