/* ================================================================
   HCIK DESIGN 5 — PLAYFUL GRADIENT (ENHANCED)
   Commercial-grade single-page kindergarten website
   ================================================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#FFFBF5;--bg-alt:#FFF5EE;
  --text:#1A1523;--text-2:#6F6776;--text-3:#A8A0AE;
  --coral:#FF6B6B;--coral-soft:#FFE0E0;--coral-deep:#E64545;
  --teal:#2EC4B6;--teal-soft:#D4F5F2;--teal-deep:#1AA393;
  --yellow:#FFD93D;--yellow-soft:#FFF8D6;
  --purple:#9B5DE5;--purple-soft:#EDE0FF;--purple-deep:#7B3DC5;
  --blue:#4361EE;--blue-soft:#DCE4FF;
  --green:#10B981;--green-soft:#D1FAE5;
  --card:#ffffff;--border:rgba(0,0,0,0.06);
  --font:'Space Grotesk',sans-serif;--display:'Sora',sans-serif;
  --radius:24px;--radius-sm:16px;--radius-xs:12px;
  --shadow-sm:0 2px 8px rgba(0,0,0,0.04);
  --shadow-md:0 8px 24px rgba(0,0,0,0.06);
  --shadow-lg:0 16px 48px rgba(0,0,0,0.08);
  --shadow-xl:0 24px 64px rgba(0,0,0,0.1);
}
html{font-family:var(--font);color:var(--text);background:var(--bg);scroll-behavior:smooth;overflow-x:hidden}
body{overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:var(--coral);color:#fff}
img{max-width:100%;display:block}
a{color:inherit}

/* ====== KEYFRAMES ====== */
@keyframes gradMove{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes float1{0%,100%{transform:translate(0,0) rotate(0deg)}33%{transform:translate(20px,-30px) rotate(2deg)}66%{transform:translate(-15px,15px) rotate(-1deg)}}
@keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(-25px,20px)}}
@keyframes bounce{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-6px) rotate(1deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.6}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes countUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ====== NAV (REDESIGNED FOR WIDE LOGO) ====== */
.play-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid var(--border);
  padding:0 clamp(16px,4vw,40px);
  display:flex;align-items:center;justify-content:space-between;
  height:64px;
  box-shadow:0 1px 0 rgba(0,0,0,0.02);
  transition:all 0.4s ease;
}
.play-nav.scrolled{box-shadow:var(--shadow-md);background:rgba(255,255,255,0.96)}
.play-nav-brand{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.play-nav-brand img{height:38px;width:auto;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:4px}
.play-nav a.nav-link{
  text-decoration:none;color:var(--text-2);font-size:13px;font-weight:600;
  padding:8px 14px;border-radius:50px;transition:all 0.25s cubic-bezier(0.34,1.56,0.64,1);
  white-space:nowrap;position:relative;
}
.play-nav a.nav-link:hover{transform:scale(1.05);color:var(--text);background:rgba(0,0,0,0.03)}

/* ====== LIVE BADGE (Apple-style) ====== */
.nav-live-wrap{position:relative;display:inline-flex;align-items:center}
.nav-live{
  position:absolute;top:-4px;left:50%;transform:translateX(-50%);
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 7px;border-radius:50px;
  background:rgba(255,59,48,0.12);font-size:8px;font-weight:800;
  color:#FF3B30;letter-spacing:0.06em;text-transform:uppercase;
  white-space:nowrap;line-height:1;
  pointer-events:none;
}
.nav-live-dot{
  width:6px;height:6px;border-radius:50%;background:#FF3B30;
  animation:livePulse 1.5s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes livePulse{
  0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(255,59,48,0.5)}
  50%{opacity:0.7;box-shadow:0 0 0 4px rgba(255,59,48,0)}
}
/* Mobile menu live badge */
.mm-live{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 10px;border-radius:50px;margin-left:8px;
  background:rgba(255,59,48,0.1);font-size:10px;font-weight:800;
  color:#FF3B30;letter-spacing:0.05em;text-transform:uppercase;
  vertical-align:middle;
}
.play-nav .nav-cta{
  text-decoration:none;background:var(--coral);color:#fff;font-weight:700;font-size:13px;
  padding:10px 22px;border-radius:50px;white-space:nowrap;margin-left:6px;
  box-shadow:0 4px 12px rgba(255,107,107,0.3);
  transition:all 0.25s cubic-bezier(0.34,1.56,0.64,1);
  animation:ctaGlow 2.2s infinite;
}
.play-nav .nav-cta:hover{transform:scale(1.05);box-shadow:0 6px 20px rgba(255,107,107,0.5);animation:none}

@keyframes ctaGlow{
  0%{box-shadow:0 0 0 0 rgba(255,107,107,0.45),0 4px 12px rgba(255,107,107,0.3)}
  70%{box-shadow:0 0 0 8px rgba(255,107,107,0),0 4px 12px rgba(255,107,107,0.3)}
  100%{box-shadow:0 0 0 0 rgba(255,107,107,0),0 4px 12px rgba(255,107,107,0.3)}
}

/* ====== MOBILE NAV ====== */
.mobile-nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:10px;-webkit-tap-highlight-color:transparent}
.mobile-nav-toggle span{display:block;width:22px;height:2.5px;background:var(--text);margin:4px 0;border-radius:2px;transition:all 0.3s ease}
.mobile-menu{display:none}
.mobile-menu .mm-logo{height:32px;width:auto;margin-bottom:12px;opacity:0.6}

/* ====== HERO (ENHANCED — WITH IMAGERY) ====== */
.play-hero{
  min-height:100vh;display:flex;flex-direction:column;align-items:center;
  justify-content:flex-start;text-align:center;
  padding:120px 24px 60px;position:relative;overflow:hidden;
}
.hero-logo{height:clamp(64px,10vw,96px);width:auto;margin:0 auto 32px;opacity:0.95;filter:drop-shadow(0 4px 12px rgba(0,0,0,0.08));display:block}
.play-hero::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(-45deg,#FFE0E0 0%,#D4F5F2 25%,#FFF8D6 50%,#EDE0FF 75%,#FFE0E0 100%);
  background-size:400% 400%;animation:gradMove 15s ease infinite;
  opacity:0.35;z-index:-2;
}
.float-shape{position:absolute;border-radius:50%;z-index:-1}
.fs1{width:400px;height:400px;background:var(--coral);opacity:0.08;top:5%;left:-8%;animation:float1 12s ease-in-out infinite}
.fs2{width:280px;height:280px;background:var(--teal);opacity:0.1;bottom:10%;right:-5%;animation:float2 14s ease-in-out infinite}
.fs3{width:200px;height:200px;background:var(--yellow);opacity:0.1;top:55%;left:8%;animation:float1 16s ease-in-out infinite reverse}
.fs4{width:160px;height:160px;background:var(--purple);opacity:0.06;top:20%;right:12%;animation:float2 10s ease-in-out infinite reverse}

.hero-sticker{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 22px;border-radius:50px;
  background:var(--yellow);color:var(--text);
  font-size:13px;font-weight:700;
  box-shadow:0 4px 16px rgba(255,217,61,0.35);
  animation:bounce 3s ease-in-out infinite;
  margin-bottom:32px;position:relative;z-index:1;
}
.play-hero h1{
  font-family:var(--display);font-size:clamp(3rem,8vw,6.5rem);
  font-weight:800;line-height:0.95;letter-spacing:-0.04em;
  position:relative;z-index:1;
}
.play-hero h1 .coral{color:var(--coral)}
.play-hero h1 .teal{color:var(--teal)}
/* Hero Title Slideshow */
.hero-title-slider{
  display:grid;width:100%;
  z-index:1;
}
.hero-title-slide{
  grid-area:1/1;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(16px);
  transition:opacity 0.9s cubic-bezier(.4,0,.2,1), transform 0.9s cubic-bezier(.4,0,.2,1);
  pointer-events:none;
}
.hero-title-slide.active{
  opacity:1;transform:translateY(0);
  pointer-events:auto;
}
.hero-title-slider.no-slide .hero-title-slide{
  opacity:1;transform:none;
}
.hero-sub{
  max-width:540px;margin:28px auto 0;font-size:clamp(15px,2vw,18px);color:var(--text-2);
  line-height:1.75;font-weight:400;position:relative;z-index:1;
}
.hero-actions{
  display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;justify-content:center;
  position:relative;z-index:1;
}

/* ====== HERO IMAGE ROW ====== */
.hero-photos{
  display:flex;gap:16px;margin-top:56px;position:relative;z-index:1;
  justify-content:center;max-width:900px;
}
.hero-photo{
  width:180px;height:220px;border-radius:20px;overflow:hidden;
  box-shadow:var(--shadow-lg);transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);
  flex-shrink:0;
}
.hero-photo:nth-child(1){transform:rotate(-4deg) translateY(10px)}
.hero-photo:nth-child(2){transform:rotate(2deg) translateY(-8px)}
.hero-photo:nth-child(3){transform:rotate(-1deg) translateY(5px)}
.hero-photo:nth-child(4){transform:rotate(3deg) translateY(-12px)}
.hero-photo:nth-child(5){transform:rotate(-2deg) translateY(8px)}
.hero-photo:hover{transform:rotate(0deg) translateY(-6px) scale(1.06)!important;box-shadow:var(--shadow-xl);z-index:2}
.hero-photo img{width:100%;height:100%;object-fit:cover}

/* ====== HERO SLIDER ====== */
.hero-slider-wrapper {
  max-width: 1000px;
  margin: 0 auto 32px;
  padding: 0 24px;
}
.hero-slider {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 2px solid var(--border);
}
.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  z-index: 1;
}
.hero-slide.active {
  opacity: 1;
  z-index: 2;
}
.hero-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.slider-dots {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 10;
}
.slider-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.4);
  cursor: pointer;
  transition: all 0.3s ease;
}
.slider-dot.active {
  background: #fff;
  transform: scale(1.2);
  width: 20px;
  border-radius: 4px;
}

/* ====== BUTTONS ====== */
.pbtn{
  display:inline-flex;align-items:center;gap:8px;padding:16px 32px;
  border-radius:50px;font-size:15px;font-weight:700;text-decoration:none;
  transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);border:none;cursor:pointer;
  font-family:var(--font);letter-spacing:-0.01em;
}
.pbtn-coral{background:var(--coral);color:#fff;box-shadow:0 6px 24px rgba(255,107,107,0.3);animation:ctaGlow 2.2s infinite;}
.pbtn-coral:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 10px 32px rgba(255,107,107,0.5);animation:none}
.pbtn-teal{background:var(--teal-soft);color:var(--teal-deep);border:2px solid var(--teal)}
.pbtn-teal:hover{transform:translateY(-3px) scale(1.02);background:var(--teal);color:#fff}

/* ====== SECTIONS ====== */
.psec{padding:100px 24px;max-width:1200px;margin:0 auto}
.psec-head{text-align:center;margin-bottom:56px}
.psec-head .badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 20px;border-radius:50px;
  font-size:12px;font-weight:700;margin-bottom:18px;
  letter-spacing:0.02em;
}
.psec-head h2{
  font-family:var(--display);font-size:clamp(2rem,4.5vw,3.2rem);
  font-weight:800;letter-spacing:-0.03em;line-height:1.15;
}
.psec-head p{max-width:560px;margin:16px auto 0;font-size:15px;color:var(--text-2);line-height:1.7}

/* ====== STATS BAR ====== */
.stats-bar{
  display:flex;justify-content:center;gap:48px;flex-wrap:wrap;
  padding:48px 24px;margin:-20px auto 0;max-width:900px;
  position:relative;z-index:2;
}
.stat-item{text-align:center}
.stat-item .stat-num{
  font-family:var(--display);font-size:clamp(2rem,5vw,3.2rem);
  font-weight:800;letter-spacing:-0.03em;
  background:linear-gradient(135deg,var(--coral),var(--purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.stat-item .stat-label{font-size:13px;color:var(--text-2);font-weight:600;margin-top:4px}

/* ====== ABOUT — ENHANCED MISSION/VISION CARDS ====== */
.about-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ac{
  border-radius:var(--radius);padding:40px 28px;text-align:center;
  background:var(--card);border:2px solid var(--border);
  transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);
  position:relative;overflow:hidden;
}
.ac::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  transform:scaleX(0);transition:transform 0.4s ease;
}
.ac:nth-child(1)::before{background:var(--coral)}
.ac:nth-child(2)::before{background:var(--teal)}
.ac:nth-child(3)::before{background:var(--purple)}
.ac:hover{transform:translateY(-8px) rotate(-0.5deg);box-shadow:var(--shadow-lg)}
.ac:hover::before{transform:scaleX(1)}
.ac .ac-emoji{font-size:48px;margin-bottom:20px;display:block;transition:transform 0.3s ease}
.ac:hover .ac-emoji{transform:scale(1.15) rotate(8deg)}
.ac h3{font-family:var(--display);font-size:20px;font-weight:800;margin-bottom:12px;letter-spacing:-0.02em}
.ac p{font-size:14px;color:var(--text-2);line-height:1.75}
.ac:nth-child(1){border-color:var(--coral-soft)}
.ac:nth-child(2){border-color:var(--teal-soft)}
.ac:nth-child(3){border-color:var(--purple-soft)}
.ac:nth-child(1):hover{border-color:var(--coral)}
.ac:nth-child(2):hover{border-color:var(--teal)}
.ac:nth-child(3):hover{border-color:var(--purple)}

/* ====== OUR STORY — SPLIT LAYOUT ====== */
.story-split{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  margin-top:60px;
}
.story-img{position:relative}
.story-img img{
  border-radius:var(--radius);width:100%;height:400px;object-fit:cover;
  box-shadow:var(--shadow-lg);
}
.story-img .story-float{
  position:absolute;bottom:-20px;right:-20px;
  background:var(--card);border-radius:var(--radius-sm);padding:20px 24px;
  box-shadow:var(--shadow-md);display:flex;align-items:center;gap:14px;
  border:2px solid var(--coral-soft);
}
.story-float .sf-emoji{font-size:32px}
.story-float .sf-text h4{font-family:var(--display);font-size:14px;font-weight:800}
.story-float .sf-text span{font-size:12px;color:var(--text-2)}
.story-content h3{font-family:var(--display);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;letter-spacing:-0.02em;margin-bottom:20px;line-height:1.2}
.story-content h3 .coral{color:var(--coral)}
.story-content p{font-size:15px;color:var(--text-2);line-height:1.8;margin-bottom:14px}
.story-content blockquote{
  border-left:4px solid var(--coral);padding:16px 20px;margin:20px 0;
  background:var(--coral-soft);border-radius:0 var(--radius-xs) var(--radius-xs) 0;
  font-size:15px;font-style:italic;line-height:1.7;color:var(--text);
}

/* ====== LEADERSHIP WELCOME SECTION ====== */
.welcome-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  margin-top: 40px;
}
.welcome-card {
  background: var(--card);
  border: 2px solid var(--border);
  border-radius: var(--radius);
  padding: 36px;
  box-shadow: var(--shadow-sm);
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
}
.welcome-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
}
.welcome-header {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 24px;
}
.welcome-img {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--purple-soft);
}
.welcome-header h3 {
  font-family: var(--display);
  font-size: 18px;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 2px;
}
.welcome-header span {
  font-size: 13px;
  color: var(--purple);
  font-weight: 600;
}
.welcome-body {
  font-size: 14px;
  color: var(--text-2);
  line-height: 1.8;
  font-style: italic;
  position: relative;
}

/* ====== PROGRAMS — ENHANCED GRID (3-COL NOT 5) ====== */
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.prog-grid .pc-wide{grid-column:span 2}
.pc{
  border-radius:var(--radius);overflow:hidden;background:var(--card);
  border:2px solid var(--border);transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
.pc:hover{transform:translateY(-6px) rotate(0.3deg);box-shadow:var(--shadow-lg)}
.pc-img{height:200px;position:relative;overflow:hidden}
.pc-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}
.pc:hover .pc-img img{transform:scale(1.08)}
.pc-sticker{
  position:absolute;top:12px;right:12px;
  padding:6px 14px;border-radius:var(--radius-xs);font-size:12px;font-weight:700;
  transform:rotate(2deg);box-shadow:0 2px 8px rgba(0,0,0,0.15);
}
.pc:nth-child(1) .pc-sticker{background:var(--coral);color:#fff}
.pc:nth-child(2) .pc-sticker{background:var(--teal);color:#fff}
.pc:nth-child(3) .pc-sticker{background:var(--yellow);color:var(--text)}
.pc:nth-child(4) .pc-sticker{background:var(--purple);color:#fff}
.pc:nth-child(5) .pc-sticker{background:var(--blue);color:#fff}
.pc-schedule{
  position:absolute;bottom:12px;left:12px;
  padding:4px 12px;border-radius:50px;font-size:11px;font-weight:600;
  background:rgba(255,255,255,0.9);backdrop-filter:blur(8px);color:var(--text);
}
.pc-body{padding:20px 22px}
.pc-body h3{font-family:var(--display);font-size:18px;font-weight:700;margin-bottom:8px;letter-spacing:-0.01em}
.pc-body p{font-size:13px;color:var(--text-2);line-height:1.65}
.pc-body .pc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.pc-body .pc-tags span{
  padding:4px 12px;border-radius:50px;font-size:11px;font-weight:600;
  background:var(--bg-alt);color:var(--text-2);
}
.pc:nth-child(1) .pc-tags span{background:var(--coral-soft);color:var(--coral-deep)}
.pc:nth-child(2) .pc-tags span{background:var(--teal-soft);color:var(--teal-deep)}
.pc:nth-child(3) .pc-tags span{background:var(--yellow-soft);color:#B8860B}
.pc:nth-child(4) .pc-tags span{background:var(--purple-soft);color:var(--purple-deep)}
.pc:nth-child(5) .pc-tags span{background:var(--blue-soft);color:var(--blue)}

/* ====== SUMMER CAMP — FULL SECTION ====== */
#camp{background:linear-gradient(180deg,#FFFBF5 0%,#FFF8D6 30%,#FFE0E0 70%,#FFFBF5 100%)}
.camp-hero-split{
  display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center;
  margin-top:40px;
}
.camp-intro-side h3{
  font-family:var(--display);font-size:clamp(1.2rem,2.5vw,1.6rem);
  font-weight:700;margin-bottom:16px;line-height:1.4;color:var(--text-2);
}
.camp-intro-side p{font-size:15px;color:var(--text-2);line-height:1.8;margin-bottom:24px}
.camp-meta-pills{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}
.camp-meta-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 18px;border-radius:50px;font-size:13px;font-weight:600;
  background:var(--card);border:2px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.camp-poster-side{position:relative}
.camp-poster-side img{
  width:100%;border-radius:var(--radius);box-shadow:var(--shadow-xl);
  transform:rotate(1.5deg);transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
.camp-poster-side:hover img{transform:rotate(0deg) scale(1.02)}

/* Weekly Theme Timeline */
.camp-week-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.camp-week-card{
  background:var(--card);border-radius:var(--radius);padding:28px 22px;
  border:2px solid var(--border);text-align:center;
  transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);
  position:relative;overflow:hidden;
}
.camp-week-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
}
.camp-week-card:nth-child(1)::before{background:var(--coral)}
.camp-week-card:nth-child(2)::before{background:var(--yellow)}
.camp-week-card:nth-child(3)::before{background:var(--blue)}
.camp-week-card:nth-child(4)::before{background:var(--green)}
.camp-week-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.camp-week-card:nth-child(1):hover{border-color:var(--coral)}
.camp-week-card:nth-child(2):hover{border-color:var(--yellow)}
.camp-week-card:nth-child(3):hover{border-color:var(--blue)}
.camp-week-card:nth-child(4):hover{border-color:var(--green)}
.camp-week-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:50%;
  font-family:var(--display);font-size:14px;font-weight:800;color:#fff;
  margin-bottom:14px;
}
.camp-week-card:nth-child(1) .camp-week-num{background:var(--coral)}
.camp-week-card:nth-child(2) .camp-week-num{background:var(--yellow);color:var(--text)}
.camp-week-card:nth-child(3) .camp-week-num{background:var(--blue)}
.camp-week-card:nth-child(4) .camp-week-num{background:var(--green)}
.camp-week-icon{font-size:36px;display:block;margin-bottom:12px}
.camp-week-card h4{font-family:var(--display);font-size:16px;font-weight:800;margin-bottom:4px}
.camp-week-card .camp-wk-dates{font-size:12px;color:var(--text-3);font-weight:600;margin-bottom:10px}
.camp-week-card p{font-size:12px;color:var(--text-2);line-height:1.6}

/* Pricing Cards */
.camp-pricing-section{margin-top:48px}
.camp-pricing-header{
  text-align:center;margin-bottom:28px;
}
.camp-pricing-header h3{
  font-family:var(--display);font-size:clamp(20px,3vw,26px);font-weight:800;
  letter-spacing:-0.02em;margin-bottom:6px;
}
.camp-pricing-header p{font-size:13px;color:var(--text-2)}
.camp-pricing-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.camp-price-card{
  background:var(--card);border:2px solid var(--border);border-radius:var(--radius);
  padding:32px;transition:all 0.3s ease;position:relative;overflow:hidden;
}
.camp-price-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
}
.camp-price-card:nth-child(1)::before{background:var(--coral)}
.camp-price-card:nth-child(2)::before{background:var(--teal)}
.camp-price-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.camp-price-card h4{
  font-family:var(--display);font-size:18px;font-weight:800;margin-bottom:4px;
}
.camp-price-card .camp-age-badge{
  display:inline-block;padding:4px 12px;border-radius:50px;
  font-size:11px;font-weight:700;margin-bottom:20px;
}
.camp-price-card:nth-child(1) .camp-age-badge{background:var(--coral-soft);color:var(--coral-deep)}
.camp-price-card:nth-child(2) .camp-age-badge{background:var(--teal-soft);color:var(--teal-deep)}
.camp-price-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 0;border-bottom:1px solid var(--border);
}
.camp-price-row:last-child{border-bottom:none}
.camp-price-label{font-size:14px;color:var(--text-2);font-weight:600}
.camp-price-amount{
  font-family:var(--display);font-size:20px;font-weight:800;
}
.camp-price-card:nth-child(1) .camp-price-amount{color:var(--coral-deep)}
.camp-price-card:nth-child(2) .camp-price-amount{color:var(--teal-deep)}
.camp-includes-bar{
  margin-top:20px;padding:14px 18px;border-radius:var(--radius-xs);
  background:var(--bg-alt);font-size:12px;color:var(--text-2);
  line-height:1.6;text-align:center;
}

/* Camp CTA */
.camp-cta-box{
  margin-top:40px;text-align:center;
  border-radius:var(--radius);overflow:hidden;position:relative;
  background:linear-gradient(-45deg,var(--coral),var(--purple),var(--teal),var(--yellow));
  background-size:400% 400%;animation:gradMove 8s ease infinite;
  padding:4px;
}
.camp-cta-inner{
  background:var(--card);border-radius:22px;padding:40px;
  display:flex;flex-direction:column;align-items:center;gap:16px;
}
.camp-cta-inner h3{
  font-family:var(--display);font-size:22px;font-weight:800;
}
.camp-contact-row{
  display:flex;gap:24px;flex-wrap:wrap;justify-content:center;align-items:center;
}
.camp-contact-item{
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;color:var(--text-2);font-weight:500;
  white-space:nowrap;
}
.camp-contact-item a{
  color:var(--coral);text-decoration:none;font-weight:600;
}
.camp-contact-item a:hover{text-decoration:underline}

/* Camp Poster (single) */
.camp-poster-single{
  margin-top:40px;text-align:center;
}
.camp-poster-single img{
  max-width:600px;width:100%;border-radius:var(--radius);box-shadow:var(--shadow-md);
  margin:0 auto;transition:all 0.3s ease;
}
.camp-poster-single img:hover{transform:scale(1.02);box-shadow:var(--shadow-lg)}

/* ====== CAMP ANNOUNCEMENT MODAL — REDESIGN ====== */
.camp-modal-overlay{
  display:none;position:fixed;inset:0;z-index:10001;
  background:rgba(10,5,20,0.6);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  align-items:center;justify-content:center;padding:20px;
  opacity:0;transition:opacity 0.4s ease;
}
.camp-modal-overlay.open{display:flex;opacity:1}
.camp-modal-overlay.closing{opacity:0}
.camp-modal{
  position:relative;width:100%;max-width:420px;
  border-radius:28px;overflow:hidden;
  background:#fff;
  box-shadow:0 40px 100px rgba(0,0,0,0.35),0 0 0 1px rgba(255,255,255,0.08);
  transform:scale(0.88) translateY(30px);
  transition:transform 0.5s cubic-bezier(0.34,1.56,0.64,1),opacity 0.35s ease;
  opacity:0;
}
.camp-modal-overlay.open .camp-modal{transform:scale(1) translateY(0);opacity:1}
.camp-modal-overlay.closing .camp-modal{transform:scale(0.92) translateY(16px);opacity:0}

/* Close button — floating glass circle */
.camp-modal-close{
  position:absolute;top:14px;right:14px;width:36px;height:36px;
  background:rgba(255,255,255,0.85);backdrop-filter:blur(8px);
  border:none;border-radius:50%;font-size:16px;cursor:pointer;z-index:5;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 12px rgba(0,0,0,0.15);
  transition:all 0.25s ease;
  color:var(--text);
}
.camp-modal-close:hover{background:#fff;transform:scale(1.12);box-shadow:0 4px 20px rgba(0,0,0,0.2)}

/* Hero poster image */
.camp-modal-hero{
  position:relative;height:240px;overflow:hidden;
}
.camp-modal-hero img{
  width:100%;height:100%;object-fit:cover;object-position:top center;
}
.camp-modal-hero::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(255,255,255,0.5) 70%,#fff 100%);
}
/* Floating "Limited Seats" badge */
.camp-modal-urgency{
  position:absolute;top:14px;left:14px;z-index:3;
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:50px;
  background:rgba(255,107,107,0.95);color:#fff;
  font-size:11px;font-weight:800;letter-spacing:0.04em;
  text-transform:uppercase;
  box-shadow:0 4px 16px rgba(255,107,107,0.4);
  animation:urgencyPulse 2s ease-in-out infinite;
}
@keyframes urgencyPulse{
  0%,100%{box-shadow:0 4px 16px rgba(255,107,107,0.4)}
  50%{box-shadow:0 4px 24px rgba(255,107,107,0.7),0 0 0 4px rgba(255,107,107,0.15)}
}

/* Body content */
.camp-modal-body{
  padding:20px 28px 28px;text-align:center;
}
.camp-modal-body h3{
  font-family:var(--display);font-size:clamp(20px,5vw,26px);font-weight:800;
  letter-spacing:-0.03em;line-height:1.2;margin-bottom:8px;
  background:linear-gradient(135deg,var(--text) 0%,var(--coral) 50%,var(--purple) 100%);
  background-size:200% 200%;animation:gradMove 6s ease infinite;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.camp-modal-body .camp-modal-hook{
  font-size:14px;color:var(--text-2);line-height:1.7;margin-bottom:18px;
}
/* Info row */
.camp-modal-info{
  display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin-bottom:20px;
}
.camp-modal-info span{
  padding:6px 14px;border-radius:50px;font-size:12px;font-weight:700;
  border:1.5px solid var(--border);color:var(--text);
  background:var(--bg);
}
/* Price highlight */
.camp-modal-price{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 20px;border-radius:var(--radius-xs);
  background:linear-gradient(135deg,var(--yellow-soft),var(--coral-soft));
  margin-bottom:20px;
  font-family:var(--display);font-weight:800;font-size:14px;
}
.camp-modal-price .price-old{
  text-decoration:line-through;color:var(--text-3);font-weight:500;
}
.camp-modal-price .price-new{
  color:var(--coral-deep);font-size:18px;
}
/* CTA button with shine */
.camp-modal-cta{
  display:block;width:100%;padding:16px;border-radius:50px;position:relative;overflow:hidden;
  background:var(--coral);color:#fff;font-weight:700;font-size:15px;
  text-decoration:none;text-align:center;border:none;cursor:pointer;
  box-shadow:0 8px 28px rgba(255,107,107,0.35);
  transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);
  font-family:var(--font);
}
.camp-modal-cta::after{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.25),transparent);
  animation:ctaShine 2.5s infinite;
}
@keyframes ctaShine{
  0%{left:-100%}
  100%{left:200%}
}
.camp-modal-cta:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(255,107,107,0.5)}
.camp-modal-later{
  display:block;margin:14px auto 0;background:none;border:none;
  font-size:13px;color:var(--text-3);cursor:pointer;
  font-family:var(--font);transition:color 0.2s ease;
}
.camp-modal-later:hover{color:var(--text-2)}

/* Mobile: centered modal */
@media(max-width:768px){
  .camp-modal-overlay{padding:16px}
  .camp-modal{
    max-width:360px;border-radius:24px;
    max-height:calc(100dvh - 32px);overflow-y:auto;
  }
  .camp-modal-hero{height:160px}
  .camp-modal-body{padding:16px 20px 24px}
  .camp-modal-body h3{font-size:20px}
  .camp-modal-info{gap:4px}
  .camp-modal-info span{font-size:11px;padding:5px 10px}
}

/* ====== ADMISSIONS — ENHANCED TIMELINE ====== */
.adm-timeline{max-width:680px;margin:0 auto;position:relative;padding-left:40px}
.adm-timeline::before{
  content:'';position:absolute;left:19px;top:0;bottom:0;width:3px;
  background:linear-gradient(to bottom,var(--coral),var(--teal),var(--purple),var(--yellow));
  border-radius:3px;
}
.adm-step{display:flex;gap:28px;margin-bottom:36px;position:relative}
.adm-step:last-child{margin-bottom:0}
.adm-dot{
  width:40px;height:40px;min-width:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:16px;font-weight:800;color:#fff;
  position:absolute;left:-40px;
  box-shadow:0 4px 12px rgba(0,0,0,0.15);
}
.adm-step:nth-child(1) .adm-dot{background:var(--coral)}
.adm-step:nth-child(2) .adm-dot{background:var(--teal)}
.adm-step:nth-child(3) .adm-dot{background:var(--purple)}
.adm-step:nth-child(4) .adm-dot{background:var(--yellow);color:var(--text)}
.adm-card{
  background:var(--card);border:2px solid var(--border);border-radius:var(--radius);
  padding:28px;flex:1;transition:all 0.3s ease;
}
.adm-card:hover{border-color:var(--coral-soft);box-shadow:var(--shadow-md);transform:translateX(4px)}
.adm-card h3{font-family:var(--display);font-size:17px;font-weight:700;margin-bottom:8px}
.adm-card p{font-size:13px;color:var(--text-2);line-height:1.7}
.adm-card ul{margin-top:10px;padding-left:16px}
.adm-card li{font-size:12px;color:var(--text-2);line-height:1.8}
.adm-card .adm-email{
  display:inline-block;margin-top:12px;padding:6px 16px;border-radius:50px;
  background:var(--coral-soft);color:var(--coral-deep);font-size:12px;font-weight:700;
  text-decoration:none;transition:all 0.2s ease;
}
.adm-card .adm-email:hover{background:var(--coral);color:#fff}

/* ====== WHY CHOOSE HCIK ====== */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.why-card{
  padding:28px 22px;border-radius:var(--radius);background:var(--card);
  border:2px solid var(--border);text-align:center;
  transition:all 0.35s cubic-bezier(0.34,1.56,0.64,1);
}
.why-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.why-card .why-icon{font-size:36px;margin-bottom:14px;display:block}
.why-card:hover .why-icon{animation:bounce 0.5s ease}
.why-card h4{font-family:var(--display);font-size:14px;font-weight:700;margin-bottom:6px}
.why-card p{font-size:12px;color:var(--text-2);line-height:1.6}

/* ====== TEAM — ENHANCED POLAROIDS ====== */
.team-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:20px;
  max-width:1000px;margin:0 auto;
}
.polaroid{
  background:#fff;padding:10px 10px 16px;
  border-radius:6px;box-shadow:var(--shadow-md);
  transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);
  transform:rotate(var(--rot,0deg));
}
.polaroid:hover{transform:rotate(0deg) scale(1.06)!important;box-shadow:var(--shadow-xl);z-index:2}
.polaroid img{width:100%;aspect-ratio:1 / 1;height:auto;object-fit:cover;object-position:top;border-radius:2px}
.polaroid .pol-info{padding-top:10px;text-align:center}
.polaroid h4{font-family:var(--display);font-size:14.5px;font-weight:800;color:var(--text)}
.polaroid span{font-size:11px;color:var(--text-2);display:block;margin-top:2px;font-weight:500}

/* ====== GALLERY — ENHANCED WITH TABS ====== */
.gallery-tabs{display:flex;gap:8px;justify-content:center;margin-bottom:32px;flex-wrap:wrap}
.gallery-tab{
  padding:8px 20px;border-radius:50px;font-size:13px;font-weight:600;
  background:var(--card);border:2px solid var(--border);
  cursor:pointer;transition:all 0.25s ease;color:var(--text-2);
}
.gallery-tab:hover,.gallery-tab.active{background:var(--coral);color:#fff;border-color:var(--coral)}
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
}
.gallery-grid .gi{
  border-radius:var(--radius-sm);overflow:hidden;
  aspect-ratio:1;transition:all 0.4s ease;cursor:pointer;
}
.gallery-grid .gi:nth-child(1){grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
.gallery-grid .gi:hover{transform:scale(1.03);box-shadow:var(--shadow-lg);z-index:2}
.gallery-grid .gi img{width:100%;height:100%;object-fit:cover}

/* ====== DAILY SCHEDULE ====== */
.schedule-strip{
  display:flex;gap:0;overflow-x:auto;padding:0 24px;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;margin-top:40px;
}
.schedule-strip::-webkit-scrollbar{display:none}
.sched-item{
  min-width:160px;scroll-snap-align:start;
  padding:20px 16px;text-align:center;border-right:1px solid var(--border);
  transition:background 0.2s ease;flex-shrink:0;
}
.sched-item:hover{background:var(--bg-alt)}
.sched-item .time{font-family:var(--display);font-size:13px;font-weight:700;color:var(--coral);margin-bottom:6px}
.sched-item .activity{font-size:12px;color:var(--text-2);font-weight:500;line-height:1.4}

/* ====== SUPPORT US ====== */
#support{
  background:linear-gradient(180deg,#fef9f5 0%,#fff5ee 40%,#fef2e8 100%);
}
.support-story{
  display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:stretch;
  margin-top:40px;
}
.support-story-img{
  border-radius:var(--radius);overflow:hidden;
  box-shadow:0 12px 40px rgba(0,0,0,0.15);
  position:relative;
}
.support-story-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,0.3));
}
.support-story-img img{width:100%;height:100%;object-fit:cover;display:block;min-height:420px}
.support-letter{
  background:var(--card);border-radius:var(--radius);padding:40px;
  border-left:5px solid var(--coral);
  box-shadow:0 4px 24px rgba(0,0,0,0.06);
  display:flex;flex-direction:column;justify-content:center;
}
.support-letter h3{
  font-family:var(--display);font-size:22px;color:var(--text);margin-bottom:20px;
  display:flex;align-items:center;gap:10px;
}
.support-letter h3::before{content:'✉️';font-size:24px}
.support-letter p{font-size:14px;color:var(--text-2);line-height:1.85;margin-bottom:14px}
.support-letter .sign{margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}
.support-letter .sign p:first-child{font-style:italic;color:var(--text-3);font-size:13px;margin-bottom:4px}
.support-letter .founder{font-weight:700;color:var(--text);font-style:normal;font-size:16px;margin-bottom:2px}
.support-letter .org{font-size:12px;color:var(--coral);font-weight:600;text-transform:uppercase;letter-spacing:0.8px}
.support-impact-head{
  text-align:center;margin-top:56px;margin-bottom:8px;
}
.support-impact-head h3{font-family:var(--display);font-size:24px;color:var(--text);margin-bottom:6px}
.support-impact-head p{font-size:14px;color:var(--text-3)}
.impact-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:24px;
}
.impact-card{
  background:var(--card);border-radius:var(--radius);padding:32px 22px;
  text-align:center;border:1px solid var(--border);
  transition:transform 0.25s ease,box-shadow 0.25s ease;
  position:relative;overflow:hidden;
}
.impact-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
}
.impact-card:nth-child(1)::before{background:var(--coral)}
.impact-card:nth-child(2)::before{background:var(--teal)}
.impact-card:nth-child(3)::before{background:var(--purple)}
.impact-card:nth-child(4)::before{background:var(--green)}
.impact-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px rgba(0,0,0,0.10)}
.impact-card .ic-icon{
  font-size:40px;margin-bottom:14px;
  width:72px;height:72px;border-radius:50%;display:inline-flex;
  align-items:center;justify-content:center;
}
.impact-card:nth-child(1) .ic-icon{background:var(--coral-soft)}
.impact-card:nth-child(2) .ic-icon{background:var(--teal-soft)}
.impact-card:nth-child(3) .ic-icon{background:rgba(139,92,246,0.08)}
.impact-card:nth-child(4) .ic-icon{background:rgba(16,185,129,0.08)}
.impact-card h4{font-family:var(--display);font-size:16px;color:var(--text);margin-bottom:8px}
.impact-card p{font-size:13px;color:var(--text-2);line-height:1.65}
.support-video-wrap{
  margin-top:56px;text-align:center;
}
.support-video-wrap h3{
  font-family:var(--display);font-size:24px;color:var(--text);margin-bottom:24px;
}
.video-frame{
  position:relative;width:100%;max-width:840px;margin:0 auto;
  padding-bottom:45%;height:0;overflow:hidden;
  border-radius:var(--radius);
  box-shadow:0 12px 40px rgba(0,0,0,0.15);
  border:3px solid rgba(0,0,0,0.06);
}
.video-frame iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.support-video-wrap .caption{
  margin-top:20px;font-size:14px;color:var(--text-3);font-style:italic;
  max-width:600px;margin-left:auto;margin-right:auto;line-height:1.7;
}
.donate-section{
  margin-top:56px;
}
.donate-section>h3{
  font-family:var(--display);font-size:24px;color:var(--text);text-align:center;margin-bottom:28px;
}
.donate-split{
  display:grid;grid-template-columns:1fr 1.1fr;gap:0;
  border-radius:var(--radius);overflow:hidden;
  box-shadow:0 12px 40px rgba(0,0,0,0.10);
  border:1px solid var(--border);
}
.donate-photo{position:relative;min-height:340px}
.donate-photo img{width:100%;height:100%;object-fit:cover;display:block}
.donate-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 60%,rgba(255,255,255,0.3));
}
.donate-details{
  background:var(--card);padding:40px;
  display:flex;flex-direction:column;justify-content:center;
}
.donate-details h4{
  font-family:var(--display);font-size:18px;margin-bottom:24px;
  color:var(--text);display:flex;align-items:center;gap:10px;
}
.donate-details table{width:100%;border-collapse:separate;border-spacing:0 8px}
.donate-details table tr{transition:background 0.15s}
.donate-details table tr:hover{background:var(--bg-alt)}
.donate-details table td{
  padding:10px 12px;font-size:14px;color:var(--text-2);vertical-align:top;
}
.donate-details table td:first-child{
  font-weight:600;color:var(--text);white-space:nowrap;width:130px;
  border-radius:6px 0 0 6px;
}
.donate-details table td:last-child{border-radius:0 6px 6px 0}
.donate-details .acct-num{
  font-weight:700;color:var(--coral);font-size:17px;
  font-family:var(--mono, 'SF Mono', 'Menlo', monospace);letter-spacing:1px;
}
.donate-contact{
  margin-top:20px;padding-top:20px;border-top:1px solid var(--border);
}
.donate-contact h5{
  font-family:var(--display);font-size:14px;margin-bottom:12px;
  color:var(--text);text-transform:uppercase;letter-spacing:0.5px;
}
.donate-contact .dc-row{
  display:flex;align-items:center;gap:10px;margin-bottom:8px;
  font-size:13px;color:var(--text-2);
}

/* ====== CONTACT — ENHANCED ====== */
.contact-section{
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg-alt) 100%);
}
.contact-card{
  border-radius:var(--radius);overflow:hidden;position:relative;
  border:2px solid var(--border);background:var(--card);
}
.contact-gradient{
  position:absolute;inset:-2px;z-index:0;
  background:linear-gradient(-45deg,var(--coral),var(--teal),var(--purple),var(--yellow));
  background-size:400% 400%;animation:gradMove 10s ease infinite;
  border-radius:var(--radius);
}
.contact-inner{
  position:relative;z-index:1;
  background:rgba(255,255,255,0.95);backdrop-filter:blur(20px);
  border-radius:22px;margin:3px;
  padding:48px;display:grid;grid-template-columns:1fr 1fr;gap:48px;
}
.ci-left h3{font-family:var(--display);font-size:24px;font-weight:800;margin-bottom:24px;letter-spacing:-0.02em}
.ci-item{display:flex;gap:14px;margin-bottom:18px;align-items:start}
.ci-icon{
  width:44px;height:44px;min-width:44px;border-radius:var(--radius-xs);
  display:flex;align-items:center;justify-content:center;font-size:20px;
}
.ci-item:nth-child(1) .ci-icon{background:var(--coral-soft)}
.ci-item:nth-child(2) .ci-icon{background:var(--teal-soft)}
.ci-item:nth-child(3) .ci-icon{background:var(--purple-soft)}
.ci-item:nth-child(4) .ci-icon{background:var(--yellow-soft)}
.ci-item:nth-child(5) .ci-icon{background:#E8F0FE}
.ci-item h4{font-size:13px;font-weight:700;margin-bottom:3px}
.ci-item p{font-size:12px;color:var(--text-2);line-height:1.5}
.ci-item a{color:var(--coral);text-decoration:none;font-weight:600}

.ci-right h3{font-family:var(--display);font-size:20px;font-weight:800;margin-bottom:20px;letter-spacing:-0.02em}
.contact-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.contact-form-grid .full{grid-column:span 2}
.cf-input{
  width:100%;padding:14px 18px;border:2px solid var(--border);border-radius:var(--radius-sm);
  font-family:var(--font);font-size:14px;outline:none;
  background:var(--bg);transition:all 0.3s ease;resize:vertical;
}
.cf-input:focus{border-color:var(--coral);background:#fff;box-shadow:0 0 0 3px rgba(255,107,107,0.08)}
.cf-input::placeholder{color:var(--text-3)}

/* ====== MAP ====== */
.map-container{
  border-radius:var(--radius);overflow:hidden;margin-top:32px;
  border:2px solid var(--border);height:250px;
}
.map-container iframe{width:100%;height:100%;border:none}

/* ====== FOOTER (ENHANCED) ====== */
.play-footer{
  background:var(--bg-alt);color:var(--text-2);padding:60px 24px 32px;
  border-radius:48px 48px 0 0;margin-top:56px;
  border-top:3px solid var(--border);
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;max-width:1100px;margin:0 auto}
.footer-brand img{height:48px;width:auto;margin-bottom:16px;filter:none;opacity:1}
.footer-brand p{font-size:13px;line-height:1.7;color:var(--text-2)}
.footer-col h4{font-size:13px;font-weight:800;color:var(--text);margin-bottom:16px;text-transform:uppercase;letter-spacing:0.08em}
.footer-col a{display:block;font-size:13px;color:var(--text-2);text-decoration:none;margin-bottom:10px;transition:all 0.2s ease}
.footer-col a:hover{color:var(--coral);transform:translateX(4px)}
.footer-accred{
  display:flex;justify-content:center;gap:12px;flex-wrap:wrap;
  margin-top:48px;padding-top:24px;border-top:1px solid var(--border);
}
.footer-accred span{
  padding:6px 16px;border-radius:50px;font-size:11px;font-weight:700;
  border:1px solid var(--border);color:var(--text-2);background:#fff;
  text-transform:uppercase;letter-spacing:0.06em;
  box-shadow:var(--shadow-sm);
}
.footer-bottom{
  text-align:center;margin-top:24px;font-size:11px;color:var(--text-3);
}

/* ====== TUITION TABLES ====== */
.tuition-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px;
}
.tuition-block{
  background:var(--card);border:2px solid var(--border);border-radius:var(--radius);
  padding:28px;transition:all 0.3s ease;
}
.tuition-block:hover{border-color:var(--blue-soft);box-shadow:var(--shadow-sm)}
.tuition-block h3{font-family:var(--display);font-size:17px;font-weight:700;margin-bottom:14px;letter-spacing:-0.01em}
.fee-table{width:100%;border-collapse:collapse}
.fee-table td{padding:10px 14px;font-size:13px;border-bottom:1px solid var(--border)}
.fee-table tr:last-child td{border-bottom:none}
.fee-table .fee-amt{text-align:right;font-family:var(--display);font-weight:700;color:var(--text);white-space:nowrap}
.fee-table .fee-header td{font-size:11px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:0.05em;padding-bottom:8px;border-bottom:2px solid var(--border)}
.fee-table .fee-total td{border-top:2px solid var(--coral);background:var(--coral-soft);border-bottom:none}
.fee-table .fee-total .fee-amt{color:var(--coral-deep)}

/* ====== PREMIUM PAYMENT METHODS ====== */
.payment-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 16px;
}
.payment-card {
  background: var(--card);
  border: 2px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 32px;
  box-shadow: var(--shadow-sm);
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.payment-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--blue-soft);
}
.payment-card.cash-card:hover {
  border-color: var(--teal-soft);
}
.payment-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
}
.payment-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-xs);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
}
.bank-card .payment-icon { background: var(--blue-soft); color: var(--blue); }
.cash-card .payment-icon { background: var(--teal-soft); color: var(--teal); }

.payment-header h4 {
  font-family: var(--display);
  font-size: 16px;
  font-weight: 800;
  color: var(--text);
}
.payment-header span {
  font-size: 12px;
  color: var(--text-3);
  font-weight: 600;
}
.payment-detail-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 20px;
}
.payment-detail-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
  border-bottom: 1px dashed var(--border);
  padding-bottom: 8px;
}
.payment-detail-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.payment-label {
  color: var(--text-2);
  font-weight: 600;
}
.payment-val {
  color: var(--text);
  font-weight: 700;
  text-align: right;
}
.qr-container {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-top: 10px;
  padding: 16px;
  background: var(--bg-alt);
  border-radius: var(--radius-xs);
  border: 1px solid var(--border);
}
.qr-container img {
  width: 100px;
  height: 100px;
  object-fit: contain;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: #fff;
  padding: 4px;
}
.copy-btn {
  background: var(--blue-soft);
  color: var(--blue);
  border: none;
  padding: 4px 10px;
  border-radius: 50px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  margin-left: 8px;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.copy-btn:hover {
  background: var(--blue);
  color: #fff;
}
.plan-badge {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 50px;
  font-size: 11px;
  font-weight: 700;
  margin-bottom: 8px;
}
.plan-annual { background: var(--purple-soft); color: var(--purple-deep); }
.plan-semester { background: var(--teal-soft); color: var(--teal-deep); }

/* ====== FLYER MODAL ====== */
.flyer-modal{
  display:none;position:fixed;inset:0;z-index:10000;
  background:rgba(0,0,0,0.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  align-items:center;justify-content:center;padding:20px;
}
.flyer-modal.open{display:flex}
.flyer-modal-content{
  position:relative;max-width:90%;max-height:90%;
  border-radius:16px;overflow:hidden;box-shadow:var(--shadow-xl);
}
.flyer-modal-content img{max-width:100%;max-height:85vh;object-fit:contain}
.flyer-modal-close{
  position:absolute;top:16px;right:16px;width:36px;height:36px;
  background:rgba(255,255,255,0.9);border:none;border-radius:50%;
  font-size:18px;font-weight:bold;cursor:pointer;
  display:flex;align-items:center;justify-content:center;z-index:2;
}
.flyer-btn{
  display:inline-flex;align-items:center;gap:8px;margin-top:16px;
  padding:10px 20px;border-radius:50px;background:var(--blue-soft);
  color:var(--blue);font-weight:700;font-size:13px;border:none;cursor:pointer;
  transition:all 0.25s ease;
}
.flyer-btn:hover{background:var(--blue);color:#fff;transform:translateY(-2px)}

/* ====== ANIMATIONS ====== */
.pop{opacity:0;transform:translateY(28px) scale(0.97);transition:all 0.7s cubic-bezier(0.34,1.56,0.64,1)}
.pop.in{opacity:1;transform:translateY(0) scale(1)}
.pop-left{opacity:0;transform:translateX(-32px);transition:all 0.7s cubic-bezier(0.22,1,0.36,1)}
.pop-left.in{opacity:1;transform:translateX(0)}
.pop-right{opacity:0;transform:translateX(32px);transition:all 0.7s cubic-bezier(0.22,1,0.36,1)}
.pop-right.in{opacity:1;transform:translateX(0)}

/* ====== RESPONSIVE ====== */

/* --- TABLET LANDSCAPE --- */
@media(max-width:1024px){
  .prog-grid{grid-template-columns:repeat(2,1fr)}
  .prog-grid .pc-wide{grid-column:span 1}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .play-nav-brand img{height:32px}
}

/* --- TABLET PORTRAIT / SMALL SCREENS --- */
@media(max-width:768px){
  /* Nav: collapse links, show hamburger */
  .nav-links .nav-link{display:none}
  .mobile-nav-toggle{display:block}
  .play-nav{height:56px}
  .play-nav-brand img{height:26px}
  .nav-links .nav-cta{display:inline-block;padding:6px 12px;font-size:11px}
  
  /* Mobile menu overlay — premium slide-in */
  .mobile-menu{
    position:fixed;inset:0;z-index:9999;
    background:rgba(255,255,255,0.98);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
    flex-direction:column;align-items:center;
    padding:72px 24px 40px;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    /* Animation: slide from right */
    transform:translateX(100%);
    transition:transform 0.35s cubic-bezier(0.32,0.72,0,1), opacity 0.3s ease;
    opacity:0;
    display:flex;
    pointer-events:none;
  }
  .mobile-menu.open{
    transform:translateX(0);
    opacity:1;
    pointer-events:auto;
  }
  .mobile-menu > a{
    font-family:var(--display);font-size:clamp(17px, 4.5vw, 22px);font-weight:700;
    text-decoration:none;color:var(--text);padding:12px 20px;
    border-radius:var(--radius-sm);transition:background 0.2s ease, transform 0.3s ease, opacity 0.3s ease;
    min-height:44px;display:flex;align-items:center;width:100%;justify-content:center;
    /* Stagger animation */
    opacity:0;transform:translateX(20px);
  }
  .mobile-menu.open > a{
    opacity:1;transform:translateX(0);
  }
  .mobile-menu.open > a:nth-of-type(1){transition-delay:0.05s}
  .mobile-menu.open > a:nth-of-type(2){transition-delay:0.07s}
  .mobile-menu.open > a:nth-of-type(3){transition-delay:0.09s}
  .mobile-menu.open > a:nth-of-type(4){transition-delay:0.11s}
  .mobile-menu.open > a:nth-of-type(5){transition-delay:0.13s}
  .mobile-menu.open > a:nth-of-type(6){transition-delay:0.15s}
  .mobile-menu.open > a:nth-of-type(7){transition-delay:0.17s}
  .mobile-menu.open > a:nth-of-type(8){transition-delay:0.19s}
  .mobile-menu.open > a:nth-of-type(9){transition-delay:0.21s}
  .mobile-menu.open > a:nth-of-type(10){transition-delay:0.23s}
  .mobile-menu > a:active{background:var(--bg-alt);transform:scale(0.97)}
  .mobile-menu .mm-close{
    position:fixed;top:16px;right:16px;
    width:44px;height:44px;border:none;background:var(--bg-alt);
    border-radius:50%;font-size:20px;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    z-index:10001;transition:transform 0.2s ease;
  }
  .mobile-menu .mm-close:active{transform:scale(0.9)}
  .mobile-menu .mm-cta{
    color:var(--coral)!important;font-weight:800;
    background:rgba(255,107,107,0.08);border-radius:50px;
    padding:14px 28px!important;margin-top:8px;
  }
  .mobile-menu .mm-divider{
    width:40px;height:2px;background:var(--border);border-radius:2px;margin:4px 0;
  }

  /* Hero */
  .play-hero{padding:80px 20px 48px;min-height:auto;min-height:100svh;justify-content:flex-start}
  .hero-logo{height:56px;margin-bottom:24px}
  .play-hero h1{font-size:clamp(2.4rem,10vw,3.5rem)}
  .hero-sub{font-size:15px;margin-top:20px}
  .hero-actions{gap:10px;margin-top:28px}
  .pbtn{padding:14px 24px;font-size:14px}
  .hero-photos{gap:10px;margin-top:48px}
  .hero-photo{width:90px;height:120px;border-radius:14px}
  .hero-slider{height:280px}

  /* Stats */
  .stats-bar{gap:20px;padding:32px 16px}
  .stat-item .stat-num{font-size:clamp(1.6rem,6vw,2.4rem)}
  .stat-item .stat-label{font-size:11px}

  /* Sections */
  .psec{padding:64px 20px}
  .psec-head{margin-bottom:36px}
  .psec-head h2{font-size:clamp(1.6rem,6vw,2.4rem)}

  /* About */
  .about-cards{grid-template-columns:1fr;gap:16px}
  .ac{padding:28px 22px}
  .story-split{grid-template-columns:1fr;gap:28px}
  .story-img img{height:260px}
  .story-img .story-float{position:static;margin-top:16px;display:inline-flex}
  .story-content h3{font-size:1.4rem}
  .welcome-grid{grid-template-columns:1fr;gap:20px}

  /* Programs */
  .prog-grid{grid-template-columns:1fr}
  .pc-img{height:180px}

  /* Tuition layout stacking */
  .tuition-grid, .payment-grid{grid-template-columns:1fr}

  /* Admissions */
  .adm-timeline{padding-left:48px}
  .adm-dot{width:36px;height:36px;font-size:14px;left:-38px}
  .adm-card{padding:22px}

  /* Why */
  .why-grid{grid-template-columns:1fr 1fr;gap:12px}
  .why-card{padding:22px 16px}

  /* Team */
  .team-grid{grid-template-columns:repeat(3,1fr);gap:14px}

  /* Gallery */
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .gallery-grid .gi:nth-child(1){grid-column:span 2;grid-row:span 1}
  .gallery-tabs{gap:6px}
  .gallery-tab{padding:6px 14px;font-size:12px}

  /* Support Us */
  .support-story{grid-template-columns:1fr;gap:24px}
  .support-story-img img{min-height:240px}
  .support-letter{padding:24px}
  .impact-grid{grid-template-columns:1fr 1fr;gap:12px}
  .impact-card{padding:24px 16px}
  .donate-split{grid-template-columns:1fr}
  .donate-photo{min-height:220px}
  .donate-details{padding:28px 20px}
  .donate-details table td:first-child{width:100px;font-size:12px}
  .video-frame{max-width:100%;padding-bottom:56.25%}

  /* Contact */
  .contact-inner{grid-template-columns:1fr;padding:28px 22px}
  .contact-form-grid{grid-template-columns:1fr}
  .contact-form-grid .full{grid-column:span 1}
  .map-container{height:200px}

  /* Footer */
  .footer-grid{grid-template-columns:1fr}
  .play-footer{padding:48px 20px 28px;border-radius:24px 24px 0 0}
  .footer-brand img{height:28px}

  /* Summer camp */
  .camp-hero-split{grid-template-columns:1fr;gap:24px}
  .camp-poster-side img{transform:rotate(0deg)}
  .camp-meta-pills{gap:8px}
  .camp-meta-pill{padding:6px 14px;font-size:12px}
  .camp-week-grid{grid-template-columns:1fr 1fr;gap:12px}
  .camp-pricing-grid{grid-template-columns:1fr}
  .camp-cta-inner{padding:28px 20px}
  .camp-contact-row{gap:12px;flex-direction:column}
}

/* --- PHONE --- */
@media(max-width:480px){
  .play-hero{padding:72px 16px 40px;justify-content:flex-start}
  .hero-photos{display:flex;gap:6px;margin-top:48px;justify-content:center;width:100%}
  .hero-photo{width:60px;height:85px;border-radius:10px}
  .hero-slider{height:180px}
  .hero-logo{height:48px;margin-bottom:20px}
  .play-hero h1{font-size:2.2rem;line-height:1}
  .hero-sub{font-size:14px}
  .hero-actions{flex-direction:column;width:100%}
  .hero-actions .pbtn{width:100%;justify-content:center}
  .stats-bar{gap:16px;flex-wrap:wrap}
  .stat-item{min-width:calc(50% - 16px)}
  .why-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-grid .gi:nth-child(1){grid-column:span 2}
  .team-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .polaroid{padding:6px 6px 12px}
  .polaroid h4{font-size:11px}
  .polaroid span{font-size:9px}
  .adm-timeline{padding-left:42px}
  .adm-dot{width:32px;height:32px;font-size:13px;left:-34px}
  .footer-accred{flex-direction:column;align-items:center}
  .psec{padding:48px 16px}
  .play-nav-brand img{height:24px}
  .play-nav .nav-cta{font-size:10px;padding:6px 12px}
  .cf-input{padding:12px 14px;font-size:13px}
}
@media(max-width:380px){
  .play-nav .nav-cta{display:none!important}
  .play-nav-brand img{height:22px}
}

/* ====== LANGUAGE FLAG SWITCHER ====== */
.lang-flags{display:flex;align-items:center;gap:4px;margin-right:4px}
.lang-flag{
  display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;font-size:16px;
  text-decoration:none;transition:all 0.25s cubic-bezier(0.34,1.56,0.64,1);
  opacity:0.55;cursor:pointer;border:2px solid transparent;
}
.lang-flag:hover{opacity:1;transform:scale(1.15)}
.lang-flag.active{opacity:1;border-color:var(--coral);box-shadow:0 0 0 2px rgba(255,107,107,0.2)}
.mm-lang-flags{display:flex;gap:10px;justify-content:center;margin:0 0 16px;padding:12px 0;border-bottom:1px solid var(--border)}
.mm-lang-flags .lang-flag{width:38px;height:38px;font-size:24px;opacity:0.6}
.mm-lang-flags .lang-flag.active{opacity:1;border-color:var(--coral)}
@media(max-width:900px){
  .lang-flags{margin-right:0;gap:2px}
  .lang-flag{width:24px;height:24px;font-size:14px}
}

/* ====== WECHAT FLOATING BUTTON ====== */
.wechat-fab{
  position:fixed;bottom:28px;right:28px;z-index:9999;
  display:flex;align-items:center;gap:0;
  cursor:pointer;text-decoration:none;
  animation:fabEntrance 0.6s cubic-bezier(0.34,1.56,0.64,1) 1.5s both;
}
@keyframes fabEntrance{
  from{opacity:0;transform:scale(0.5) translateY(20px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}
.wechat-fab-btn{
  width:56px;height:56px;border-radius:50%;
  background:#07C160;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 24px rgba(7,193,96,0.35),0 2px 8px rgba(0,0,0,0.1);
  transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);
  flex-shrink:0;position:relative;
}
.wechat-fab-btn svg{width:28px;height:28px;fill:#fff}
.wechat-fab:hover .wechat-fab-btn{
  transform:scale(1.1);
  box-shadow:0 10px 32px rgba(7,193,96,0.45),0 4px 12px rgba(0,0,0,0.12);
}
/* Pulse ring */
.wechat-fab-btn::before{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  border:2px solid rgba(7,193,96,0.3);
  animation:wechatPing 2.5s ease-in-out infinite;
}
@keyframes wechatPing{
  0%,100%{transform:scale(1);opacity:0.6}
  50%{transform:scale(1.15);opacity:0}
}
/* Tooltip label */
.wechat-fab-label{
  padding:8px 16px;border-radius:12px 0 0 12px;
  background:#07C160;color:#fff;font-size:12px;font-weight:700;
  white-space:nowrap;margin-right:-8px;
  box-shadow:0 4px 16px rgba(7,193,96,0.3);
  opacity:0;transform:translateX(10px);
  transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);
  pointer-events:none;
  font-family:var(--font);
}
.wechat-fab:hover .wechat-fab-label{opacity:1;transform:translateX(0)}
/* WeChat popup card */
.wechat-popup{
  display:none;position:fixed;bottom:96px;right:28px;z-index:10000;
  background:#fff;border-radius:20px;padding:24px;width:280px;
  box-shadow:0 20px 60px rgba(0,0,0,0.2),0 0 0 1px rgba(0,0,0,0.04);
  text-align:center;animation:fabEntrance 0.35s cubic-bezier(0.34,1.56,0.64,1) both;
}
.wechat-popup.show{display:block}
.wechat-popup-close{
  position:absolute;top:10px;right:12px;background:none;border:none;
  font-size:16px;cursor:pointer;color:var(--text-3);
}
.wechat-popup h4{
  font-family:var(--display);font-size:15px;font-weight:800;margin-bottom:4px;
  color:var(--text);
}
.wechat-popup p{
  font-size:12px;color:var(--text-2);margin-bottom:14px;line-height:1.5;
}
.wechat-id-box{
  display:flex;align-items:center;gap:8px;justify-content:center;
  padding:10px 16px;border-radius:12px;background:var(--bg-alt);
  margin-bottom:14px;font-family:monospace;font-size:16px;font-weight:700;
  color:#07C160;letter-spacing:0.02em;
}
.wechat-copy-btn{
  padding:10px 20px;border-radius:50px;border:none;cursor:pointer;
  background:#07C160;color:#fff;font-weight:700;font-size:13px;
  font-family:var(--font);width:100%;
  transition:all 0.2s ease;
}
.wechat-copy-btn:hover{background:#06a855}
.wechat-copy-btn.copied{background:var(--text);pointer-events:none}
@media(max-width:768px){
  .wechat-fab{bottom:20px;right:20px}
  .wechat-fab-btn{width:50px;height:50px}
  .wechat-fab-btn svg{width:24px;height:24px}
  .wechat-fab-label{display:none}
  .wechat-popup{right:16px;bottom:82px;width:calc(100vw - 32px);max-width:300px}
}