/*
Theme Name: The Lagoona Korat Zoo
Theme URI: https://thelagoonakoratzoo.com
Author: The Lagoona Korat Zoo
Description: Custom homepage theme with full SEO (JSON-LD AmusementPark + FAQ), Open Graph, sitemap, robots.txt, Google Search Console verification, and AI-search crawler support.
Version: 1.4
*/

/* =========================================================
   The Lagoona Korat Zoo — Site styles
   Inspired by Apple-style scroll storytelling, in vibrant
   water-park colors. Pure CSS, no framework.
   ========================================================= */

:root{
  /* Brand */
  --navy:        #1e2a78;
  --navy-deep:   #0f1a55;
  --wave:        #2bb6f0;
  --aqua:        #0fcfd4;
  --sky:         #c6ecff;

  /* Water-park accents */
  --sun:         #ffd028;
  --tangerine:   #ff8a2a;
  --coral:       #ff5b8a;
  --grape:       #8a5cff;
  --leaf:        #2bbf6a;

  /* Neutrals */
  --cream:       #fff8eb;
  --paper:       #ffffff;
  --ink:         #15224a;
  --ink-soft:    #3b487a;
  --line:        rgba(20,30,80,.10);

  /* Type */
  --display: "Mali", "Prompt", system-ui, sans-serif;
  --body:    "Prompt", system-ui, -apple-system, sans-serif;

  /* Sizes */
  --max:      1200px;
  --pad-x:    clamp(20px, 5vw, 64px);
  --radius:   28px;
  --radius-s: 16px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  font-size:17px;
  line-height:1.55;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

h1,h2,h3,h4,h5{
  font-family:var(--display);
  font-weight:800;
  letter-spacing:-.01em;
  line-height:1.05;
  margin:0;
}

.kicker{
  font-family:var(--body);
  font-weight:600;
  font-size:14px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--wave);
  margin:0 0 14px;
}
.kicker--white{color:rgba(255,255,255,.85)}

em{font-style:normal;color:var(--wave)}

/* =========================================================
   NAV
========================================================= */
.nav{
  position:fixed;
  top:14px; left:50%; transform:translateX(-50%);
  width:min(var(--max), calc(100% - 28px));
  display:flex; align-items:center; gap:18px;
  padding:10px 14px 10px 18px;
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border:1px solid rgba(255,255,255,.6);
  border-radius:999px;
  box-shadow:0 10px 30px rgba(15,26,85,.08);
  z-index:50;
  transition:padding .25s, box-shadow .25s;
}
.nav.is-scrolled{box-shadow:0 16px 40px rgba(15,26,85,.14)}
.nav__brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:700;line-height:1;color:var(--navy);font-size:14px;flex-shrink:0}
.nav__brand img{width:38px;height:38px;border-radius:10px;background:#fff;padding:3px;object-fit:contain}
.nav__brand b{font-weight:800;font-size:15px}
.nav__links{display:flex;gap:6px;margin-left:auto}
.nav__links a{
  padding:9px 14px;border-radius:999px;font-weight:500;font-size:15px;
  color:var(--ink-soft); transition:.2s;
}
.nav__links a:hover{background:rgba(43,182,240,.12); color:var(--navy)}
.nav__cta{
  padding:10px 18px; border-radius:999px;
  background:var(--navy); color:#fff; font-weight:600; font-size:14px;
  transition:.2s; flex-shrink:0;
}
.nav__cta:hover{background:var(--wave); transform:translateY(-1px)}

/* Language toggle */
.nav__lang{
  display:inline-flex; align-items:center; gap:4px;
  padding:8px 14px; border-radius:999px;
  border:2px solid var(--navy);
  font-family:var(--display); font-weight:700;
  font-size:13px;
  color:var(--navy);
  background:transparent;
  transition:.2s;
  flex-shrink:0;
}
.nav__lang:hover{background:var(--navy); color:#fff}
.nav__lang:hover .nav__lang-sep{color:rgba(255,255,255,.5)}
.nav__lang-th, .nav__lang-en{transition:.2s; opacity:.4}
.nav__lang-sep{opacity:.5; color:var(--navy)}
.nav__lang .nav__lang-th{opacity:1}
.nav__lang.is-en .nav__lang-th{opacity:.4}
.nav__lang.is-en .nav__lang-en{opacity:1}

.nav__burger{display:none;width:40px;height:40px;flex-direction:column;justify-content:center;align-items:center;gap:5px;border-radius:50%;background:var(--navy);flex-shrink:0}
.nav__burger span{display:block;width:18px;height:2px;background:#fff;border-radius:2px;transition:.25s}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =========================================================
   HERO
========================================================= */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  padding:120px var(--pad-x) 0;
  display:flex; flex-direction:column;
  isolation:isolate;
  overflow:hidden;
  background:linear-gradient(180deg, #b9e6ff 0%, #d8efff 40%, #fff8eb 100%);
}
.hero__sky{position:absolute; inset:0; z-index:-1; pointer-events:none}
.sun{
  position:absolute; top:8%; right:14%;
  width:140px; height:140px; border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #fff4a8, #ffd028 55%, #ff8a2a);
  box-shadow:0 0 60px 12px rgba(255,208,40,.55);
  animation:sunFloat 8s ease-in-out infinite;
}
@keyframes sunFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-14px)}
}
.cloud{position:absolute;background:#fff;border-radius:999px;box-shadow:30px 0 0 -5px #fff, -30px 0 0 -8px #fff, 50px -10px 0 -14px #fff}
.cloud--1{top:18%; left:8%; width:80px; height:24px; animation:cloudDrift 28s linear infinite}
.cloud--2{top:30%; left:40%; width:60px; height:18px; opacity:.85; animation:cloudDrift 36s linear infinite}
.cloud--3{top:12%; left:65%; width:100px; height:30px; animation:cloudDrift 44s linear infinite}
@keyframes cloudDrift{
  0%{transform:translateX(0)}
  100%{transform:translateX(120vw)}
}

.hero__waves{position:absolute;left:0;right:0;bottom:-1px;z-index:-1;line-height:0;height:240px;overflow:hidden}
.hero__waves .wave{position:absolute;left:0;width:200%;height:220px}
.wave--4{bottom:80px; opacity:.5; animation:waveSlide 14s linear infinite}
.wave--1{bottom:55px; opacity:.75; animation:waveSlide 11s linear -2s infinite}
.wave--2{bottom:25px; opacity:.92; animation:waveSlide 9s linear -4s infinite reverse}
.wave--3{bottom:0; animation:waveSlide 13s linear -6s infinite}

@keyframes waveSlide{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

.splash{
  position:absolute; left:50%; bottom:160px;
  width:60px; height:60px;
  animation:splashFloat 3s ease-in-out infinite;
}
@keyframes splashFloat{
  0%,100%{transform:translateY(0); opacity:.7}
  50%{transform:translateY(-12px); opacity:1}
}

/* Bubbles rising */
.hero__bubbles{position:absolute; inset:0; pointer-events:none; z-index:0; overflow:hidden}
.bubble{
  position:absolute;
  left:var(--x);
  bottom:-30px;
  width:var(--s);
  height:var(--s);
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.95), rgba(174,228,255,.4) 60%, rgba(43,182,240,.3));
  box-shadow:inset -2px -2px 6px rgba(43,182,240,.3), 0 2px 6px rgba(43,182,240,.2);
  animation:bubbleUp var(--d) linear var(--delay) infinite;
  opacity:0;
}
@keyframes bubbleUp{
  0%{transform:translateY(0) translateX(0) scale(.6); opacity:0}
  10%{opacity:.85}
  50%{transform:translateY(-50vh) translateX(20px) scale(1)}
  90%{opacity:.7}
  100%{transform:translateY(-100vh) translateX(-15px) scale(.8); opacity:0}
}

.hero__content{position:relative; z-index:2; max-width:760px; margin-top:auto; margin-bottom:auto; padding-bottom:140px}
.hero__eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.65);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.9);
  padding:8px 16px; border-radius:999px;
  font-size:14px; color:var(--navy); font-weight:500;
  margin-bottom:24px;
}
.hero__eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 4px rgba(255,91,138,.25)}

.hero__title{
  font-size:clamp(56px, 12vw, 168px);
  color:var(--navy-deep);
  line-height:.92;
  letter-spacing:-.03em;
}
.hero__title em{
  background:linear-gradient(180deg, var(--wave), var(--aqua));
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
  font-style:normal;
}
.hero__title .word{display:block}

.hero__title--brand{
  font-size:clamp(48px, 9vw, 132px);
  letter-spacing:-.02em;
}
.hero__brand-sub{
  font-family:var(--display);
  font-weight:700;
  color:var(--navy-deep);
  font-size:clamp(18px, 2.2vw, 30px);
  margin:8px 0 0;
  opacity:.9;
}

.hero__sub{
  font-size:clamp(17px, 2vw, 22px);
  color:var(--ink-soft);
  max-width:540px;
  margin:24px 0 32px;
}
.hero__ctas{display:flex;gap:12px;flex-wrap:wrap}

.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 28px; border-radius:999px;
  font-family:var(--body); font-weight:600; font-size:17px;
  transition:transform .15s, box-shadow .25s, background .25s;
  white-space:nowrap;
}
.btn--primary{background:var(--coral); color:#fff; box-shadow:0 10px 24px rgba(255,91,138,.4)}
.btn--primary:hover{transform:translateY(-2px); box-shadow:0 16px 30px rgba(255,91,138,.5); background:#ff437a}
.btn--ghost{background:rgba(255,255,255,.7); color:var(--navy); border:2px solid var(--navy)}
.btn--ghost:hover{background:var(--navy); color:#fff}

.hero__mascot{
  position:absolute;
  right:max(-40px, calc(50% - 720px));
  bottom:90px;
  width:clamp(260px, 35vw, 520px);
  z-index:1;
  filter:drop-shadow(0 30px 40px rgba(15,26,85,.25));
  animation:mascotBob 5s ease-in-out infinite;
  pointer-events:none;
}

/* Polaroid slideshow — stacked photos that fade in rotation
   Sits BEHIND the title text and mascot (low z-index) */
.hero__polaroids{
  position:absolute;
  top:14%;
  right:clamp(40px, 8vw, 140px);
  width:clamp(264px, 28.8vw, 408px);
  aspect-ratio:1.15/1;
  z-index:0;
  pointer-events:none;
}
.poly{
  position:absolute;
  inset:0;
  margin:0;
  background:#fff;
  padding:10px 10px 32px;
  border-radius:6px;
  box-shadow:0 18px 40px rgba(15,26,85,.28), 0 6px 14px rgba(15,26,85,.18);
  opacity:0;
  transform:scale(.92) rotate(var(--r));
  transition:opacity 1.2s ease, transform 1.4s cubic-bezier(.22,.9,.3,1);
}
.poly img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:3px;
  display:block;
}
.poly--1{--r:-6deg}
.poly--2{--r:5deg}
.poly--3{--r:-3deg}
.poly--4{--r:7deg}
.poly--5{--r:-5deg}

.poly.is-active{
  opacity:1;
  transform:scale(1) rotate(var(--r));
  z-index:3;
}
.poly.is-prev{
  opacity:0;
  transform:scale(1.04) rotate(var(--r)) translateY(-8px);
  z-index:2;
}

@keyframes mascotBob{
  0%,100%{transform:translateY(0) rotate(-2deg)}
  50%{transform:translateY(-18px) rotate(2deg)}
}

.hero__scroll{
  position:absolute; left:50%; bottom:24px; transform:translateX(-50%);
  text-align:center;
  font-size:12px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--navy);
  z-index:3;
}
.hero__scroll span{
  display:block; margin-top:6px; font-size:22px;
  animation:bounce 2s infinite;
}
@keyframes bounce{
  0%,20%,50%,80%,100%{transform:translateY(0)}
  40%{transform:translateY(-10px)}
  60%{transform:translateY(-5px)}
}

/* =========================================================
   ABOUT
========================================================= */
.about{
  position:relative;
  padding:120px var(--pad-x) 140px;
  background:var(--cream);
  overflow:hidden;
}
.about__inner{max-width:var(--max);margin:0 auto;position:relative}
.about__headline{
  font-size:clamp(40px, 7vw, 96px);
  color:var(--navy-deep);
  max-width:14ch;
  margin-bottom:24px;
}
.about__lead{
  font-size:clamp(17px, 1.6vw, 21px);
  color:var(--ink-soft);
  max-width:60ch;
  margin:0 0 60px;
}
.about__family{
  position:absolute;
  right:-20px; top:-20px;
  width:clamp(140px, 22vw, 320px);
  animation:mascotBob 6s ease-in-out -1s infinite;
}

.stats{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
  margin-top:40px;
}
.stat{
  padding:32px 26px;
  border-radius:var(--radius);
  color:#fff;
  position:relative; overflow:hidden;
  box-shadow:0 20px 40px rgba(15,26,85,.12);
  transition:transform .3s;
}
.stat:hover{transform:translateY(-6px)}
.stat::before{
  content:""; position:absolute; right:-20px; bottom:-20px;
  width:80px; height:80px; border-radius:50%;
  background:rgba(255,255,255,.18);
}
.stat--blue{background:linear-gradient(135deg, var(--wave), #1a90db)}
.stat--yellow{background:linear-gradient(135deg, var(--sun), var(--tangerine)); color:var(--navy-deep)}
.stat--pink{background:linear-gradient(135deg, var(--coral), #e6306b)}
.stat--teal{background:linear-gradient(135deg, var(--aqua), #0aa7ad)}
.stat__num{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(48px, 6vw, 80px);
  line-height:1;
}
.stat__label{
  margin-top:8px;
  font-weight:600;
  font-size:18px;
}
.stat__label small{display:block; font-weight:400; font-size:14px; opacity:.85; margin-top:4px}

/* =========================================================
   MARQUEE BANNER
========================================================= */
.banner{
  background:var(--navy-deep);
  color:#fff;
  overflow:hidden;
  padding:22px 0;
  border-top:6px solid var(--sun);
  border-bottom:6px solid var(--sun);
}
.marquee{display:flex; overflow:hidden; mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent)}
.marquee__track{
  display:flex; gap:60px;
  white-space:nowrap;
  animation:marquee 30s linear infinite;
  font-family:var(--display); font-weight:700;
  font-size:clamp(22px, 3vw, 36px);
}
.marquee__track span{display:inline-flex; align-items:center}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* =========================================================
   ZONES
========================================================= */
.zones{
  position:relative;
  background:linear-gradient(180deg, var(--navy-deep), #0a1442);
  color:#fff;
  padding:120px 0 80px;
}
.zones__intro{
  text-align:center;
  padding:0 var(--pad-x) 60px;
  max-width:900px; margin:0 auto;
}
.zones__intro h2{
  font-size:clamp(40px, 7vw, 88px);
  color:#fff;
}
.zones__intro-sub{
  margin-top:18px;
  color:rgba(255,255,255,.6);
  font-size:clamp(15px, 1.4vw, 18px);
}

.zone{
  position:relative;
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:60px;
  align-items:center;
  max-width:var(--max);
  margin:0 auto;
  padding:100px var(--pad-x);
}
.zone--reverse{grid-template-columns:1fr 1.1fr}
.zone--reverse .zone__media{order:2}

.zone__media{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  aspect-ratio:4/3;
  box-shadow:0 30px 60px rgba(0,0,0,.4);
  transform:translateY(40px);
  opacity:0;
  transition:transform .9s cubic-bezier(.22,.9,.3,1), opacity .9s;
}
.zone.in-view .zone__media{transform:none; opacity:1}
.zone__media img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1.4s ease;
}
.zone:hover .zone__media img{transform:scale(1.05)}
.zone__tag{
  position:absolute; top:18px; left:18px;
  background:rgba(255,255,255,.95);
  color:var(--navy-deep);
  padding:8px 16px; border-radius:999px;
  font-size:13px; font-weight:700; letter-spacing:.04em;
}

.zone__text{
  transform:translateY(40px);
  opacity:0;
  transition:transform .9s .15s cubic-bezier(.22,.9,.3,1), opacity .9s .15s;
}
.zone.in-view .zone__text{transform:none; opacity:1}

.zone__index{
  font-family:var(--display);
  font-weight:700;
  letter-spacing:.2em;
  font-size:14px;
  text-transform:uppercase;
  color:rgba(255,255,255,.5);
  margin:0 0 14px;
}
.zone__text h3{
  font-size:clamp(48px, 6vw, 88px);
  color:#fff;
  margin-bottom:24px;
}
.zone__text h3 em{
  background:linear-gradient(180deg, currentColor, currentColor);
  -webkit-background-clip:text; background-clip:text;
  font-style:normal;
}
.zone__text > p{
  font-size:clamp(16px, 1.5vw, 19px);
  color:rgba(255,255,255,.78);
  max-width:50ch;
  margin:0 0 24px;
}
.zone__bullets{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:10px;
}
.zone__bullets li{
  padding-left:28px; position:relative;
  color:rgba(255,255,255,.9); font-weight:500;
}
.zone__bullets li::before{
  content:""; position:absolute; left:0; top:.6em;
  width:14px; height:14px; border-radius:50%;
  background:currentColor;
  box-shadow:0 0 0 3px rgba(255,255,255,.18);
}

.zone__mascot{
  position:absolute;
  width:clamp(120px, 16vw, 200px);
  z-index:3;
  pointer-events:none;
  filter:drop-shadow(0 20px 30px rgba(0,0,0,.4));
}
.zone--yellow .zone__mascot{right:-20px; bottom:40px; animation:mascotBob 5s ease-in-out infinite}
.zone--pink .zone__mascot{right:-30px; top:40px; animation:mascotBob 6s ease-in-out -1s infinite}
.zone--blue .zone__mascot{left:-30px; bottom:30px; animation:mascotBob 7s ease-in-out -2s infinite}
.zone--sun .zone__mascot{right:-20px; top:40px; animation:mascotBob 5.5s ease-in-out -1.5s infinite}

/* zone accent colors */
.zone--orange .zone__index{color:var(--tangerine)}
.zone--orange .zone__text h3 em{color:var(--tangerine)}
.zone--orange .zone__bullets li{color:var(--tangerine)}

.zone--yellow .zone__index{color:var(--sun)}
.zone--yellow .zone__text h3 em{color:var(--sun)}
.zone--yellow .zone__bullets li{color:var(--sun)}

.zone--pink .zone__index{color:var(--coral)}
.zone--pink .zone__text h3 em{color:var(--coral)}
.zone--pink .zone__bullets li{color:var(--coral)}

.zone--teal .zone__index{color:var(--aqua)}
.zone--teal .zone__text h3 em{color:var(--aqua)}
.zone--teal .zone__bullets li{color:var(--aqua)}

.zone--blue .zone__index{color:var(--wave)}
.zone--blue .zone__text h3 em{color:var(--wave)}
.zone--blue .zone__bullets li{color:var(--wave)}

.zone--sun .zone__index{color:#fff2a0}
.zone--sun .zone__text h3 em{color:#fff2a0}
.zone--sun .zone__bullets li{color:#fff2a0}

.zone--green .zone__index{color:var(--leaf)}
.zone--green .zone__text h3 em{color:var(--leaf)}
.zone--green .zone__bullets li{color:var(--leaf)}

/* =========================================================
   SAFETY STRIP
========================================================= */
.safety{
  background:var(--sun);
  color:var(--navy-deep);
  padding:60px var(--pad-x);
  border-top:6px solid var(--navy-deep);
  border-bottom:6px solid var(--navy-deep);
}
.safety__inner{
  max-width:var(--max); margin:0 auto;
  display:flex; align-items:center; gap:40px;
  flex-wrap:wrap;
}
.safety__inner img{width:120px; flex-shrink:0; animation:mascotBob 5s ease-in-out infinite}
.safety h3{font-size:clamp(22px, 3vw, 32px); margin-bottom:8px}
.safety p{margin:0; font-size:clamp(15px, 1.4vw, 17px)}

/* =========================================================
   FOOD
========================================================= */
.food{
  padding:120px var(--pad-x);
  background:var(--cream);
}
.section-head{
  text-align:center;
  max-width:800px;
  margin:0 auto 60px;
}
.section-head h2{
  font-size:clamp(40px, 7vw, 88px);
  color:var(--navy-deep);
}
.section-head--light h2{color:#fff}

.food__grid{
  max-width:var(--max); margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
}
.food__card{
  background:#fff;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 20px 40px rgba(15,26,85,.08);
  transition:transform .3s, box-shadow .3s;
  display:flex; flex-direction:column;
}
.food__card:hover{transform:translateY(-6px); box-shadow:0 30px 60px rgba(15,26,85,.16)}
.food__card--lg{grid-column:span 3}
.food__card--lg{display:grid; grid-template-columns:1.4fr 1fr; align-items:stretch}
.food__card--lg img{width:100%; height:100%; object-fit:cover; min-height:340px}
.food__card img{aspect-ratio:4/3; width:100%; object-fit:cover}
.food__card--lg .food__body{padding:50px}
.food__body{padding:24px}
.food__chip{
  display:inline-block;
  background:var(--coral); color:#fff;
  padding:4px 12px; border-radius:999px;
  font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  margin-bottom:14px;
}
.food__body h3{
  font-size:clamp(22px, 2.5vw, 32px);
  color:var(--navy-deep);
  margin-bottom:8px;
}
.food__body p{
  margin:0; color:var(--ink-soft); font-size:15px;
}
.food__card--lg .food__body h3{font-size:clamp(28px, 3.5vw, 44px)}
.food__card--lg .food__body p{font-size:17px}

/* =========================================================
   PRICE
========================================================= */
.price{
  position:relative;
  background:linear-gradient(180deg, var(--wave), var(--navy));
  color:#fff;
  padding:120px var(--pad-x);
  overflow:hidden;
}
.price::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image:
    radial-gradient(circle 80px at 10% 20%, rgba(255,255,255,.12), transparent),
    radial-gradient(circle 120px at 85% 30%, rgba(255,208,40,.18), transparent),
    radial-gradient(circle 100px at 70% 80%, rgba(255,91,138,.18), transparent);
}
.price__grid{
  max-width:1000px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
  position:relative;
}
.ticket{
  background:#fff;
  color:var(--ink);
  border-radius:var(--radius);
  padding:40px;
  position:relative;
  box-shadow:0 30px 60px rgba(0,0,0,.2);
}
.ticket--water{border-top:8px solid var(--coral)}
.ticket--zoo{border-top:8px solid var(--sun)}
.ticket__tag{
  display:inline-block;
  font-family:var(--display); font-weight:700;
  background:var(--cream); color:var(--navy-deep);
  padding:6px 14px; border-radius:999px;
  font-size:13px; letter-spacing:.06em;
}
.ticket__top h3{
  font-size:28px; color:var(--navy-deep);
  margin:14px 0 24px;
}
.ticket__rows{
  display:flex; flex-direction:column;
  border-top:1px dashed var(--line);
}
.ticket__row{
  display:flex; justify-content:space-between; align-items:baseline;
  padding:18px 0;
  border-bottom:1px dashed var(--line);
}
.ticket__row span{color:var(--ink-soft); font-size:17px}
.ticket__row b{
  font-family:var(--display);
  font-size:36px;
  color:var(--navy-deep);
  font-weight:800;
}
.ticket__notes{
  list-style:none; padding:0; margin:24px 0 0;
  font-size:14px; color:var(--ink-soft);
  display:flex; flex-direction:column; gap:8px;
}
.ticket__notes li{padding-left:20px; position:relative}
.ticket__notes li::before{content:"•"; position:absolute; left:6px; color:var(--coral); font-weight:700}
.price__foot{
  text-align:center; margin:40px auto 0;
  font-size:14px; color:rgba(255,255,255,.7);
  max-width:600px;
}

/* =========================================================
   FAQ — น้องคองช่วยตอบ
========================================================= */
.faq{
  position:relative;
  padding:120px var(--pad-x);
  background:
    radial-gradient(circle 240px at 12% 18%, rgba(43,182,240,.12), transparent 60%),
    radial-gradient(circle 280px at 88% 78%, rgba(255,208,40,.18), transparent 60%),
    linear-gradient(180deg, #eaf6ff 0%, #fff8eb 100%);
  overflow:hidden;
}
.faq .section-head{margin-bottom:40px}
.faq__kong-inline{
  display:inline-block;
  vertical-align:middle;
  width:clamp(48px, 7vw, 88px);
  margin-right:8px;
  transform:translateY(-6px);
}
.faq__kong-inline img{
  width:100%;
  filter:drop-shadow(0 8px 14px rgba(15,26,85,.2));
  animation:mascotBob 5s ease-in-out infinite;
}
.faq__lead{
  color:var(--ink-soft);
  font-size:clamp(15px, 1.4vw, 17px);
  margin-top:14px;
}

.faq__list{
  max-width:900px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:14px;
}

.qa{
  background:#fff;
  border-radius:24px;
  box-shadow:0 12px 30px rgba(15,26,85,.07);
  border:2px solid transparent;
  overflow:hidden;
  transition:border-color .25s, box-shadow .25s, transform .25s;
}
.qa:hover{box-shadow:0 18px 40px rgba(15,26,85,.12)}
.qa[open]{
  border-color:var(--wave);
  box-shadow:0 24px 50px rgba(43,182,240,.18);
}
.qa summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:18px;
  padding:18px 22px;
  user-select:none;
}
.qa summary::-webkit-details-marker{display:none}
.qa__avatar{
  width:54px; height:54px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--sky), #fff);
  border:3px solid #fff;
  box-shadow:0 6px 14px rgba(15,26,85,.12);
  flex-shrink:0;
  display:grid; place-items:center;
  overflow:hidden;
}
.qa__avatar img{
  width:120%;
  margin-top:6px;
  pointer-events:none;
}
.qa__q{
  flex:1;
  font-family:var(--display);
  font-size:clamp(16px, 1.8vw, 20px);
  color:var(--navy-deep);
  font-weight:700;
  line-height:1.4;
}
.qa__q b{font-weight:700}
.qa__plus{
  font-family:var(--display);
  font-size:32px;
  font-weight:800;
  color:var(--wave);
  width:36px; height:36px;
  display:grid; place-items:center;
  border-radius:50%;
  background:rgba(43,182,240,.12);
  flex-shrink:0;
  transition:transform .35s cubic-bezier(.22,.9,.3,1), background .25s;
  line-height:1;
}
.qa[open] .qa__plus{
  transform:rotate(45deg);
  background:var(--coral);
  color:#fff;
}

.qa__a{
  padding:6px 22px 26px 94px;
  color:var(--ink);
  font-size:clamp(15px, 1.4vw, 17px);
  line-height:1.7;
  animation:qaSlide .35s ease;
}
.qa__a > p{margin:0 0 10px}
.qa__a > p:last-child{margin-bottom:0}
.qa__hl{color:var(--coral)}

@keyframes qaSlide{
  from{opacity:0; transform:translateY(-8px)}
  to{opacity:1; transform:none}
}

/* price grid inside FAQ */
.qa__price-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin:6px 0 14px;
}
.qa__price{
  background:var(--cream);
  border-radius:16px;
  padding:16px;
  border:2px solid var(--line);
}
.qa__price--zoo{border-color:var(--sun)}
.qa__price--water{border-color:var(--wave)}
.qa__price-tag{
  display:inline-block;
  font-family:var(--display);
  font-weight:700;
  background:var(--navy-deep); color:#fff;
  padding:4px 12px; border-radius:999px;
  font-size:12px; letter-spacing:.04em;
  margin-bottom:10px;
}
.qa__price--zoo .qa__price-tag{background:var(--sun); color:var(--navy-deep)}
.qa__price--water .qa__price-tag{background:var(--wave)}
.qa__price-row{
  display:flex; justify-content:space-between; align-items:baseline;
  padding:6px 0;
  border-bottom:1px dashed var(--line);
}
.qa__price-row:last-child{border-bottom:0}
.qa__price-row span{color:var(--ink-soft); font-size:14px}
.qa__price-row b{
  font-family:var(--display);
  font-size:22px;
  color:var(--navy-deep);
}

.qa__notes{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:6px;
  font-size:14px; color:var(--ink-soft);
}
.qa__notes li{padding-left:18px; position:relative}
.qa__notes li::before{content:"•"; position:absolute; left:4px; color:var(--coral); font-weight:700}

.qa__big{
  font-family:var(--display);
  font-size:clamp(20px, 2.4vw, 28px);
  color:var(--navy-deep);
  margin:4px 0 8px !important;
}

/* CTA box at bottom */
.faq__cta{
  max-width:900px;
  margin:60px auto 0;
  background:var(--navy-deep);
  color:#fff;
  border-radius:var(--radius);
  padding:36px;
  display:flex; align-items:center; gap:30px;
  position:relative;
  overflow:hidden;
}
.faq__cta::before{
  content:""; position:absolute; right:-30px; bottom:-30px;
  width:200px; height:200px; border-radius:50%;
  background:rgba(255,208,40,.12);
}
.faq__cta img{
  width:120px; flex-shrink:0;
  animation:mascotBob 5s ease-in-out infinite;
  position:relative; z-index:1;
}
.faq__cta h3{
  font-size:clamp(22px, 2.6vw, 28px);
  margin-bottom:8px;
  color:#fff;
}
.faq__cta p{
  margin:0 0 18px;
  color:rgba(255,255,255,.75);
  font-size:15px;
}
.faq__cta-btns{display:flex; gap:10px; flex-wrap:wrap}

@media (max-width: 700px){
  .qa summary{padding:14px 16px; gap:12px}
  .qa__avatar{width:44px; height:44px}
  .qa__a{padding:6px 18px 22px 72px}
  .qa__price-grid{grid-template-columns:1fr}
  .faq__cta{flex-direction:column; text-align:center; padding:28px}
  .faq__cta-btns{justify-content:center}
}

/* =========================================================
   CONTACT
========================================================= */
.contact{
  padding:120px var(--pad-x);
  background:var(--cream);
  position:relative;
  overflow:hidden;
}
.contact__inner{max-width:var(--max); margin:0 auto; position:relative}
.contact__grid{
  display:grid; grid-template-columns:repeat(2, 1fr); gap:18px;
  max-width:900px; margin:0 auto;
}
.contact__grid > .ccard:nth-child(5):nth-last-child(1){
  grid-column:1 / -1;
}
.ccard{
  background:#fff;
  border-radius:var(--radius);
  padding:36px;
  display:block;
  transition:transform .25s, box-shadow .25s;
  border:2px solid transparent;
  box-shadow:0 14px 30px rgba(15,26,85,.08);
}
.ccard:hover{transform:translateY(-4px); box-shadow:0 24px 50px rgba(15,26,85,.18)}
.ccard__icon{font-size:36px; margin-bottom:14px}
.ccard__icon--fb{
  width:44px; height:44px;
  color:#1877f2;
  display:flex; align-items:center;
}
.ccard__icon--fb svg{width:44px; height:44px; display:block}
.ccard h4{font-size:24px; color:var(--navy-deep); margin-bottom:6px}
.ccard p{margin:0 0 16px; color:var(--ink-soft); font-size:15px}
.ccard__cta{
  display:inline-block;
  font-weight:700; color:var(--coral);
  font-size:15px;
}
.ccard--map:hover{border-color:var(--coral)}
.ccard--phone:hover{border-color:var(--leaf)}
.ccard--phone .ccard__cta{color:var(--leaf); font-size:20px; font-family:var(--display)}
.ccard--fb:hover{border-color:var(--wave)}
.ccard--fb .ccard__cta{color:var(--wave)}
.ccard--fb-page:hover{border-color:#1877f2}
.ccard--fb-page .ccard__cta{color:#1877f2; font-size:14px}
.ccard--line:hover{border-color:var(--leaf)}
.ccard--line .ccard__cta{color:var(--leaf)}

.contact__mascot{
  position:absolute;
  right:-20px; bottom:-40px;
  width:clamp(120px, 16vw, 220px);
  animation:mascotBob 6s ease-in-out infinite;
  pointer-events:none;
}

/* =========================================================
   FOOTER
========================================================= */
.foot{
  background:var(--navy-deep);
  color:rgba(255,255,255,.85);
  padding:80px var(--pad-x) 30px;
}
.foot__inner{
  max-width:var(--max); margin:0 auto;
  display:grid; grid-template-columns:1.2fr 2fr; gap:60px;
}
.foot__brand{display:flex; flex-direction:column; gap:14px}
.foot__brand img{width:80px; background:#fff; border-radius:16px; padding:8px}
.foot__brand p{margin:0; font-family:var(--display); font-weight:700; font-size:18px; line-height:1.3}
.foot__cols{display:grid; grid-template-columns:repeat(3, 1fr); gap:30px}
.foot__cols h5{
  font-family:var(--display); font-size:16px; color:#fff;
  margin:0 0 14px;
  letter-spacing:.04em;
}
.foot__cols a, .foot__cols span{
  display:block;
  font-size:14px;
  color:rgba(255,255,255,.7);
  padding:4px 0;
  transition:color .15s;
}
.foot__cols a:hover{color:var(--sun)}
.foot__bar{
  max-width:var(--max); margin:60px auto 0;
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:20px;
  font-size:13px;
  color:rgba(255,255,255,.5);
  text-align:center;
}

/* =========================================================
   RESPONSIVE
========================================================= */
@media (max-width: 980px){
  .nav__links, .nav__cta{display:none}
  .nav__lang{display:none}
  .nav__burger{display:flex}
  .nav__brand span{display:none}
  .nav{padding:8px 10px 8px 14px}

  /* mobile menu open */
  .nav.is-open{
    flex-direction:column; align-items:stretch;
    border-radius:24px; padding:14px;
    gap:6px;
  }
  .nav.is-open .nav__links{
    display:flex; flex-direction:column; gap:0; margin:8px 0 4px;
  }
  .nav.is-open .nav__links a{
    padding:14px; border-radius:14px; font-size:16px;
  }
  .nav.is-open .nav__cta{
    display:block; text-align:center; padding:14px;
    border-radius:14px;
  }
  .nav.is-open .nav__lang{
    display:inline-flex; align-self:center;
    margin-top:8px;
  }
  .nav.is-open .nav__brand span{display:inline}

  .hero{padding-top:110px}
  .hero__content{padding-bottom:200px}
  .hero__mascot{
    right:-20px; bottom:120px;
    width:60vw; max-width:280px;
  }
  .hero__polaroids{
    top:auto; bottom:340px;
    right:10px;
    width:46vw; max-width:240px;
    z-index:0;
  }

  .stats{grid-template-columns:repeat(2,1fr)}

  .zone, .zone--reverse{
    grid-template-columns:1fr;
    gap:30px;
    padding:60px var(--pad-x);
  }
  .zone--reverse .zone__media{order:0}
  .zone__media{aspect-ratio:4/3}

  .food__grid{grid-template-columns:1fr 1fr}
  .food__card--lg{grid-column:span 2; grid-template-columns:1fr}
  .food__card--lg img{min-height:240px}
  .food__card--lg .food__body{padding:28px}

  .price__grid{grid-template-columns:1fr}

  .contact__grid{grid-template-columns:1fr}
  .contact__mascot{position:relative;right:auto;bottom:auto;margin:30px auto 0;display:block}

  .foot__inner{grid-template-columns:1fr; gap:30px}
  .foot__cols{grid-template-columns:1fr 1fr}
}

@media (max-width: 560px){
  body{font-size:16px}
  .hero__title{font-size:clamp(46px, 16vw, 96px)}
  .hero__ctas .btn{flex:1; justify-content:center}
  .hero__polaroids{display:none}
  .stats{grid-template-columns:1fr 1fr; gap:12px}
  .stat{padding:24px 20px}
  .food__grid{grid-template-columns:1fr}
  .food__card--lg{grid-column:span 1}
  .ticket{padding:28px}
  .ccard{padding:24px}
  .foot__cols{grid-template-columns:1fr}
  .safety__inner{flex-direction:column; text-align:center; gap:20px}
}

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important}
}

/* =========================================================
   RENTALS — เช่าชุด & อุปกรณ์
========================================================= */
.rental{
  padding:120px var(--pad-x);
  background:
    radial-gradient(circle 280px at 90% 12%, rgba(255,208,40,.18), transparent 60%),
    radial-gradient(circle 320px at 8% 88%, rgba(43,182,240,.14), transparent 60%),
    var(--cream);
}
.rental .section-head{margin-bottom:40px}
.rental__lead{
  color:var(--ink-soft);
  font-size:clamp(15px, 1.5vw, 18px);
  margin-top:14px;
}

/* Free service callout */
.rental__free{
  max-width:900px;
  margin:0 auto 36px;
  display:flex; align-items:center; gap:20px;
  background:linear-gradient(135deg, var(--sun), #ffba1e);
  color:var(--navy-deep);
  border-radius:var(--radius);
  padding:20px 28px;
  box-shadow:0 20px 40px rgba(255,180,30,.3);
  position:relative;
  overflow:hidden;
}
.rental__free::before{
  content:""; position:absolute; right:-30px; top:-30px;
  width:140px; height:140px; border-radius:50%;
  background:rgba(255,255,255,.18);
}
.rental__free-icon{
  font-size:48px;
  flex-shrink:0;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.15));
}
.rental__free-text{flex:1; min-width:0}
.rental__free-text h4{
  font-size:clamp(20px, 2.4vw, 28px);
  margin:0;
  color:var(--navy-deep);
}
.rental__free-text p{
  margin:4px 0 0;
  font-size:15px;
  font-weight:500;
}
.rental__free-tag{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(22px, 3vw, 30px);
  background:var(--coral);
  color:#fff;
  padding:10px 22px;
  border-radius:999px;
  box-shadow:0 6px 16px rgba(255,91,138,.4);
  position:relative; z-index:1;
  flex-shrink:0;
  letter-spacing:.04em;
}

.rental__cats{
  max-width:var(--max);
  margin:0 auto;
  display:flex; flex-direction:column; gap:50px;
}
.rental__cat h3{
  font-size:clamp(22px, 2.6vw, 32px);
  color:var(--navy-deep);
  margin-bottom:24px;
  padding-bottom:12px;
  border-bottom:3px solid var(--line);
  letter-spacing:-.01em;
}
.rental__grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(180px, 1fr));
  gap:14px;
}

.ritem{
  background:#fff;
  border-radius:18px;
  padding:20px 18px 16px;
  text-align:center;
  box-shadow:0 8px 20px rgba(15,26,85,.06);
  border:2px solid transparent;
  transition:transform .25s, box-shadow .25s, border-color .25s;
  position:relative;
}
.ritem:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 36px rgba(15,26,85,.14);
  border-color:var(--wave);
}
.ritem--featured{
  background:linear-gradient(180deg, #fff, #fff8eb);
  border-color:var(--sun);
}
.ritem--featured::after{
  content:"⭐";
  position:absolute; top:8px; right:10px;
  font-size:16px;
}
.ritem__emoji{
  font-size:42px;
  margin-bottom:8px;
  filter:drop-shadow(0 4px 8px rgba(15,26,85,.12));
  height:54px;
  display:grid; place-items:center;
}
.ritem h4{
  font-family:var(--display);
  font-size:16px;
  color:var(--navy-deep);
  margin:6px 0 4px;
  line-height:1.25;
  min-height:38px;
}
.ritem p{
  margin:0 0 12px;
  font-size:12px;
  color:var(--ink-soft);
}
.ritem__price{
  display:inline-block;
  font-family:var(--display);
  font-weight:800;
  font-size:22px;
  color:#fff;
  background:var(--coral);
  padding:4px 16px;
  border-radius:999px;
  box-shadow:0 4px 10px rgba(255,91,138,.3);
}

/* ID notice at the bottom */
.rental__notice{
  max-width:900px;
  margin:50px auto 0;
  background:var(--navy-deep);
  color:#fff;
  border-radius:var(--radius);
  padding:30px 36px;
  display:flex; align-items:center; gap:24px;
  position:relative;
  overflow:hidden;
  border:3px solid var(--sun);
}
.rental__notice::before{
  content:""; position:absolute; left:-20px; bottom:-30px;
  width:160px; height:160px; border-radius:50%;
  background:rgba(255,208,40,.12);
}
.rental__notice img{
  width:100px; flex-shrink:0;
  position:relative; z-index:1;
  animation:mascotBob 5s ease-in-out infinite;
}
.rental__notice-text{flex:1; min-width:0; position:relative; z-index:1}
.rental__notice h4{
  font-size:clamp(20px, 2.4vw, 26px);
  color:var(--sun);
  margin:0 0 8px;
}
.rental__notice p{
  margin:0;
  font-size:15px;
  color:rgba(255,255,255,.85);
  line-height:1.6;
}
.rental__notice p b{color:#fff}

@media (max-width:700px){
  .rental__free{flex-direction:column; text-align:center; gap:14px}
  .rental__grid{grid-template-columns:repeat(2, 1fr); gap:10px}
  .ritem{padding:16px 12px 14px}
  .ritem__emoji{font-size:36px}
  .ritem h4{font-size:14px; min-height:34px}
  .rental__notice{flex-direction:column; text-align:center; padding:24px}
}

/* =========================================================
   GOOGLE MAPS EMBED
========================================================= */
.contact__map{
  max-width:var(--max);
  margin:60px auto 0;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 20px 50px rgba(15,26,85,.18);
  position:relative;
  background:#fff;
  border:4px solid #fff;
}
.contact__map iframe{
  display:block;
  width:100%;
  height:440px;
  border:0;
  filter:saturate(1.05);
}
.contact__map-cta{
  position:absolute;
  right:16px; bottom:16px;
  background:var(--navy-deep);
  color:#fff;
  padding:10px 18px;
  border-radius:999px;
  font-weight:600;
  font-size:14px;
  box-shadow:0 8px 20px rgba(0,0,0,.25);
  transition:.2s;
  z-index:2;
}
.contact__map-cta:hover{background:var(--coral); transform:translateY(-2px)}

@media (max-width:700px){
  .contact__map iframe{height:320px}
}
