/* Kawaii Kids — subpage styles */
.sub-hero { padding: calc(var(--banner-h) + 130px) 24px 60px; background: linear-gradient(135deg, var(--pink-soft), var(--peach-soft)); text-align: center; position: relative; overflow: hidden; }
.sub-hero-shapes { position: absolute; inset: 0; pointer-events: none; }
.sub-hero-shape { position: absolute; border-radius: 50%; opacity: 0.4; animation: shape-float 9s ease-in-out infinite; }
.sub-hero-shape.s1 { width: 140px; height: 140px; background: var(--mint); top: 20%; left: 10%; }
.sub-hero-shape.s2 { width: 100px; height: 100px; background: var(--yellow); top: 30%; right: 12%; animation-delay: -4s; }
.sub-breadcrumb { font-size: 0.86rem; color: var(--ink-soft); margin-bottom: 16px; font-weight: 600; position: relative; z-index: 2; }
.sub-breadcrumb a { color: var(--pink); text-decoration: none; transition: color .2s; }
.sub-breadcrumb a:hover { color: var(--peach); }
.sub-eyebrow { display: inline-block; padding: 6px 16px; background: rgba(255,255,255,0.85); color: var(--pink); border-radius: 999px; font-size: 0.78rem; font-weight: 700; margin-bottom: 12px; position: relative; z-index: 2; }
.sub-hero h1 { font-family: "Jua", sans-serif; font-size: clamp(2.4rem, 5vw, 3.6rem); margin: 0 0 16px; position: relative; z-index: 2; color: var(--ink); }
.sub-hero p { max-width: 600px; margin: 0 auto 32px; font-size: 1.05rem; position: relative; z-index: 2; }
.sub-intro-stats { max-width: 800px; margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 16px; position: relative; z-index: 2; }
.sub-stat { background: rgba(255,255,255,0.85); padding: 16px; border-radius: 16px; text-align: center; backdrop-filter: blur(8px); }
.sub-stat-num { font-family: "Jua", sans-serif; font-size: 1.6rem; color: var(--pink); display: block; line-height: 1; margin-bottom: 4px; }
.sub-stat-label { font-size: 0.78rem; color: var(--ink-soft); font-weight: 600; }

.sub-back { display: inline-block; margin: 24px 0; color: var(--pink); font-weight: 700; padding: 10px 18px; border: 2px solid var(--pink); border-radius: 999px; transition: all .25s; }
.sub-back:hover { background: var(--pink); color: #fff; transform: translateX(-4px); }

.sub-section { padding: 80px 24px; max-width: 1200px; margin: 0 auto; }
.sub-section-head { text-align: center; margin-bottom: 48px; }
.sub-section-head h2 { font-family: "Jua", sans-serif; margin-bottom: 12px; }
.sub-section-head p { color: var(--ink-soft); }

/* Teachers detail */
.teacher-detail-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 32px; }
.teacher-detail-card { background: #fff; border-radius: 28px; overflow: hidden; box-shadow: var(--shadow-soft); transition: transform .3s; }
.teacher-detail-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-pop); }
.teacher-detail-photo { aspect-ratio: 4/5; background-size: cover; background-position: center; }
.teacher-detail-body { padding: 24px; }
.teacher-detail-body h3 { font-family: "Jua", sans-serif; margin-bottom: 4px; font-size: 1.3rem; }
.teacher-detail-role { color: var(--pink); font-weight: 600; font-size: 0.92rem; margin-bottom: 16px; }
.teacher-detail-bio { color: var(--ink-soft); font-size: 0.92rem; line-height: 1.6; margin-bottom: 16px; }
.teacher-detail-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.teacher-detail-tag { padding: 4px 10px; background: var(--pink-soft); color: var(--pink); border-radius: 999px; font-size: 0.74rem; font-weight: 600; }

/* Programs detail */
.program-detail-stack { display: flex; flex-direction: column; gap: 32px; }
.program-detail-card { background: #fff; border-radius: 32px; overflow: hidden; box-shadow: var(--shadow-soft); display: grid; grid-template-columns: 1fr 1fr; }
.program-detail-card:nth-child(even) { grid-template-columns: 1fr 1fr; }
.program-detail-card:nth-child(even) .program-detail-img { order: 2; }
.program-detail-img { aspect-ratio: 4/3; background-size: cover; background-position: center; }
.program-detail-body { padding: 32px; display: flex; flex-direction: column; justify-content: center; }
.program-detail-icon { font-size: 36px; margin-bottom: 12px; }
.program-detail-body h3 { font-family: "Jua", sans-serif; font-size: 1.6rem; margin-bottom: 12px; }
.program-detail-body p { line-height: 1.6; margin-bottom: 16px; }
.program-detail-meta { display: flex; gap: 24px; padding-top: 16px; border-top: 2px dashed var(--line); font-size: 0.86rem; color: var(--ink-soft); }
.program-detail-meta strong { color: var(--ink); display: block; font-family: "Jua", sans-serif; }

/* Alumni gallery */
.alumni-wall-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 20px; }
.alumni-wall-card { background: #fff; border-radius: 28px; padding: 28px 20px; text-align: center; box-shadow: var(--shadow-soft); transition: transform .3s cubic-bezier(.34,1.56,.64,1); }
.alumni-wall-card:nth-child(odd) { transform: rotate(-1deg); }
.alumni-wall-card:nth-child(even) { transform: rotate(1deg); }
.alumni-wall-card:hover { transform: translateY(-8px) rotate(0); box-shadow: var(--shadow-pop); }
.alumni-wall-photo { width: 100px; height: 100px; border-radius: 50%; background-size: cover; background-position: center; margin: 0 auto 14px; border: 4px solid var(--pink-soft); }
.alumni-wall-card h3 { font-family: "Jua", sans-serif; font-size: 1rem; margin-bottom: 4px; }
.alumni-wall-program { font-size: 0.78rem; color: var(--ink-soft); margin-bottom: 12px; }
.alumni-wall-quote { font-family: "Gaegu", cursive; color: var(--pink); font-weight: 700; font-size: 1rem; line-height: 1.3; }

/* Secondary content */
.sub-secondary { background: var(--bg-2); padding: 80px 24px; }
.sub-faq-grid { max-width: 900px; margin: 0 auto; display: grid; gap: 16px; }
.sub-faq-item { background: #fff; border-radius: 20px; padding: 24px; box-shadow: var(--shadow-soft); }
.sub-faq-item h3 { font-family: "Jua", sans-serif; font-size: 1.1rem; color: var(--pink); margin-bottom: 8px; }
.sub-faq-item p { font-size: 0.92rem; line-height: 1.6; }

/* Related / footer */
.sub-related { padding: 64px 24px; max-width: 1200px; margin: 0 auto; }
.sub-rel-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
.sub-rel-card { background: linear-gradient(135deg, var(--pink-soft), var(--peach-soft)); padding: 28px 24px; border-radius: 24px; transition: transform .3s; cursor: pointer; }
.sub-rel-card:hover { transform: translateY(-4px) scale(1.02); }
.sub-rel-card .label { font-size: 0.78rem; font-weight: 700; color: var(--pink); margin-bottom: 8px; display: block; }
.sub-rel-card h3 { font-family: "Jua", sans-serif; margin-bottom: 8px; }
.sub-rel-card p { font-size: 0.86rem; }

.sub-footer-cta { padding: 80px 24px; text-align: center; background: linear-gradient(135deg, var(--pink), var(--peach)); color: #fff; }
.sub-footer-cta h3 { font-family: "Jua", sans-serif; font-size: clamp(1.6rem, 4vw, 2.4rem); margin-bottom: 12px; color: #fff; }
.sub-footer-cta p { color: rgba(255,255,255,0.95); margin-bottom: 24px; }
.sub-footer-cta .btn { display: inline-block; padding: 14px 32px; background: #fff; color: var(--pink); border-radius: 999px; font-weight: 700; transition: transform .25s; margin: 0 8px; }
.sub-footer-cta .btn:hover { transform: translateY(-3px) scale(1.05); }
.sub-footer-cta .btn-ghost { background: transparent; color: #fff; border: 2px solid #fff; }

@media (max-width: 768px) {
    .program-detail-card, .program-detail-card:nth-child(even) { grid-template-columns: 1fr; }
    .program-detail-card:nth-child(even) .program-detail-img { order: 0; }
    .program-detail-meta { flex-direction: column; gap: 8px; }
    .sub-section { padding: 56px 16px; }
}
