
.little-genie-page {
    --little-genie-purple: #A78BFA;
    --little-genie-pink: #FFBDBD;
    --little-genie-mint: #AAF2E1;
    --little-genie-yellow: #FFF9C4;
    --little-genie-blue: #2196F3;
    --little-genie-text: #2D3748;
    --little-genie-gray-500: #6B7280;
    --little-genie-gray-600: #4B5563;
    --little-genie-gray-700: #374151;
    --little-genie-bg-gray: #F9FAFB;

    --little-genie-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);
    --little-genie-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);
    --little-genie-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);
    --little-genie-shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);

    font-family: 'Fredoka', 'Poppins', system-ui, -apple-system, sans-serif;
    color: var(--little-genie-text);
    font-size: 16px;
    line-height: 1.5;
    overflow-x: hidden;
}

.little-genie-page *,
.little-genie-page *::before,
.little-genie-page *::after {
    box-sizing: border-box;
}

.little-genie-page,
.little-genie-page h1, .little-genie-page h2, .little-genie-page h3,
.little-genie-page h4, .little-genie-page h5, .little-genie-page h6,
.little-genie-page p, .little-genie-page a, .little-genie-page span,
.little-genie-page button, .little-genie-page input,
.little-genie-page select, .little-genie-page textarea,
.little-genie-page label, .little-genie-page div {
    font-family: 'Fredoka', 'Poppins', system-ui, -apple-system, sans-serif;
}

.little-genie-page h1,
.little-genie-page h2,
.little-genie-page h3,
.little-genie-page p {
    margin-top: 0;
    padding: 0;
}

/* Typography scale aligned with app.min.css */
.little-genie-page h1 { font-size: 50px; line-height: 1.2; }
.little-genie-page h2 { font-size: 36px; line-height: 1.39; }
.little-genie-page h3 { font-size: 28px; line-height: 1.43; }
.little-genie-page h4 { font-size: 20px; line-height: 1.4; }
.little-genie-page h5 { font-size: 18px; line-height: 1.45; }
.little-genie-page h6 { font-size: 16px; line-height: 1.5; }
.little-genie-page p  { font-size: 16px; line-height: 1.73; }

@media (max-width: 991px) {
    .little-genie-page h1 { font-size: 38px; }
    .little-genie-page h2 { font-size: 30px; }
    .little-genie-page h3 { font-size: 24px; }
    .little-genie-page h4 { font-size: 18px; }
}
@media (max-width: 767px) {
    .little-genie-page h1 { font-size: 34px; }
    .little-genie-page h2 { font-size: 26px; }
    .little-genie-page h3 { font-size: 22px; }
    .little-genie-page h4 { font-size: 18px; }
}

/* Keep card/component titles at their UI sizes (override the base h3 scale) */
.little-genie-page .little-genie-card-title { font-size: 20px; }
.little-genie-page .little-genie-card-title-lg { font-size: 24px; }

.little-genie-page img {
    max-width: 100%;
    display: block;
}

.little-genie-page button {
    font-family: inherit;
    cursor: pointer;
    border: none;
}

.little-genie-container {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    padding-right: 12px;
    padding-left: 12px;
}
@media (min-width: 576px)  { .little-genie-container { max-width: 540px; } }
@media (min-width: 768px)  { .little-genie-container { max-width: 720px; } }
@media (min-width: 992px)  { .little-genie-container { max-width: 960px; } }
@media (min-width: 1200px) { .little-genie-container { max-width: 1140px; } }
@media (min-width: 1400px) { .little-genie-container { max-width: 1320px; } }

.little-genie-section {
    padding: 52px 0;
    position: relative;
}

.little-genie-bg-white { background: #ffffff; }
.little-genie-bg-gray { background: var(--little-genie-bg-gray); }

.little-genie-head {
    text-align: center;
    margin-bottom: 40px;
}

.little-genie-h2 {
    font-size: 48px;
    font-weight: 700;
    line-height: 1.2;
    color: var(--little-genie-text);
    margin-bottom: 24px;
}

.little-genie-sub {
    font-size: 22px;
    color: #353d49;
    line-height: 1.9;
    max-width: 500px;
    margin: 0 auto;
}

.little-genie-sub-mid { max-width: 768px; }
.little-genie-sub-wide { max-width: 896px; }
.little-genie-sub-full { max-width: 100%; }

.little-genie-found-tagline {
    margin-bottom: 20px;
}
.little-genie-found-tagline .little-genie-pill {
    background: linear-gradient(135deg, #8B5CF6 0%, #EC4899 100%);
    padding: 8px 24px;
    white-space: normal;
    box-shadow: 0 8px 22px rgba(139, 92, 246, .35);
}
.little-genie-found-intro {
    font-size: 17px;
    line-height: 1.7;
    color: var(--little-genie-gray-500);
    max-width: 680px;
    margin: 0 auto;
}

.little-genie-best {
    background: linear-gradient(135deg, #F3F0FF 0%, #E3F2FD 50%, #E6FBF5 100%);
}
.little-genie-best-grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 48px;
    max-width: 1080px;
    margin: 0 auto;
}
@media (min-width: 768px) {
    .little-genie-best-grid { grid-template-columns: repeat(3, 1fr); gap: 0; }
    .little-genie-best-item + .little-genie-best-item {
        border-left: 2px dashed rgba(124, 58, 237, .2);
    }
    .little-genie-best-item { padding: 0 32px; }
}
.little-genie-best-item {
    text-align: center;
}
.little-genie-best-icon {
    width: 88px;
    height: 88px;
    border-radius: 9999px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 36px;
    margin: 0 auto 24px;
    box-shadow: var(--little-genie-shadow-lg);
}
.little-genie-best-title {
    font-size: 23px;
    font-weight: 700;
    color: var(--little-genie-text);
    line-height: 1.3;
    margin-bottom: 14px;
}
.little-genie-best-text {
    font-size: 17px;
    line-height: 1.75;
    color: var(--little-genie-gray-600);
    max-width: 320px;
    margin: 0 auto;
}

.little-genie-pillars {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 24px;
    width: 100%;
}
@media (min-width: 768px) {
    .little-genie-pillars { grid-template-columns: repeat(2, 1fr); }
}
.little-genie-pillar {
    display: flex;
    align-items: center;
    gap: 24px;
    width: 100%;
    padding: 28px 32px;
    border-radius: 24px;
    box-shadow: var(--little-genie-shadow-lg);
    transition: transform .3s ease, box-shadow .3s ease;
}
.little-genie-pillar:hover {
    transform: translateY(-8px);
    box-shadow: var(--little-genie-shadow-2xl);
}
.little-genie-pillar .little-genie-icon-square { margin-bottom: 0; }
.little-genie-pillar-body { flex: 1; }
.little-genie-pillar-body .little-genie-card-title { margin-bottom: 6px; }

@media (max-width: 767px) {
    .little-genie-pillar { flex-direction: column; text-align: center; }
    .little-genie-pillar .little-genie-icon-square { margin: 0 auto; }
}

.little-genie-mb-4 { margin-bottom: 16px !important; }
.little-genie-mb-6 { margin-bottom: 24px !important; }


.little-genie-grid {
    display: grid;
    gap: 32px;
}
.little-genie-grid-2 { grid-template-columns: repeat(1, 1fr); }
.little-genie-grid-2-lg { grid-template-columns: repeat(1, 1fr); }
.little-genie-grid-3 { grid-template-columns: repeat(1, 1fr); }
.little-genie-grid-4 { grid-template-columns: repeat(1, 1fr); }
.little-genie-grid-5 { grid-template-columns: repeat(1, 1fr); gap: 24px; }

@media (min-width: 768px) {
    .little-genie-grid-2 { grid-template-columns: repeat(2, 1fr); }
    .little-genie-grid-3 { grid-template-columns: repeat(2, 1fr); }
    .little-genie-grid-4 { grid-template-columns: repeat(2, 1fr); }
    .little-genie-grid-5 { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
    .little-genie-grid-2 { grid-template-columns: repeat(2, 1fr); }
    .little-genie-grid-2-lg { grid-template-columns: repeat(2, 1fr); }
    .little-genie-grid-3 { grid-template-columns: repeat(3, 1fr); }
    .little-genie-grid-4 { grid-template-columns: repeat(4, 1fr); }
    .little-genie-grid-5 { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1280px) {
    .little-genie-grid-5 { grid-template-columns: repeat(5, 1fr); }
}


.little-genie-icon-circle,
.little-genie-icon-square {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    box-shadow: var(--little-genie-shadow-md);
    flex-shrink: 0;
}
.little-genie-icon-circle {
    width: 80px;
    height: 80px;
    border-radius: 9999px;
    margin-bottom: 24px;
    font-size: 33.6px;
}
.little-genie-icon-square {
    width: 64px;
    height: 64px;
    border-radius: 16px;
    margin-bottom: 24px;
    font-size: 29.6px;
}
.little-genie-icon-square.little-genie-icon-lg {
    width: 80px;
    height: 80px;
    font-size: 33.6px;
    margin-bottom: 0;
}


.little-genie-card {
    padding: 32px;
    border-radius: 24px;
    height: 100%;
    box-shadow: var(--little-genie-shadow-lg);
    transition: transform .3s ease, box-shadow .3s ease;
}
.little-genie-card-center { text-align: center; }
.little-genie-card-center .little-genie-icon-circle { margin-left: auto; margin-right: auto; }

.little-genie-card:hover {
    transform: translateY(-10px);
    box-shadow: var(--little-genie-shadow-2xl);
}

.little-genie-card-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--little-genie-text);
    margin-bottom: 12px;
    line-height: 1.3;
}
.little-genie-card-title-lg { font-size: 24px; }

.little-genie-card-text {
    color: var(--little-genie-gray-600);
    line-height: 1.625;
}
.little-genie-card-text-lg { font-size: 18px; }

.little-genie-compact .little-genie-card { padding: 22px 18px; border-radius: 18px; }
.little-genie-compact .little-genie-icon-circle { width: 58px; height: 58px; font-size: 24px; margin-bottom: 14px; }


.little-genie-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 16px 32px;
    border-radius: 9999px;
    font-weight: 600;
    font-size: 18px;
    box-shadow: var(--little-genie-shadow-lg);
    transition: transform .25s ease, box-shadow .25s ease, opacity .25s ease;
}
.little-genie-btn:hover { transform: scale(1.05); }
.little-genie-btn:active { transform: scale(.95); }

.little-genie-btn-gradient {
    background: linear-gradient(135deg, #2196F3 0%, #A78BFA 100%);
    color: #fff;
}
.little-genie-btn-gradient:hover { box-shadow: 0 20px 40px rgba(33, 150, 243, .3); }

.little-genie-btn-purple {
    background: linear-gradient(135deg, #A78BFA 0%, #7C3AED 100%);
    color: #fff;
}
.little-genie-btn-purple:hover { box-shadow: 0 20px 40px rgba(124, 58, 237, .35); }

.little-genie-btn-white-blue {
    background: #fff;
    color: var(--little-genie-blue);
}


.little-genie-page .little-genie-btn-outline {
    background: rgba(255, 255, 255, .15);
    border: 4px solid #fff;
    color: #fff;
    backdrop-filter: blur(10px);
}

.little-genie-btn-lg { padding: 16px 40px; font-size: 18px; font-weight: 700; }
.little-genie-btn-xl { padding: 20px 48px; font-size: 20px; }
.little-genie-btn-bold { font-weight: 700; }

.little-genie-cta-row {
    text-align: center;
    margin-top: 48px;
}


.little-genie-btn-block {
    width: 100%;
    padding: 12px 0;
    border-radius: 9999px;
    font-weight: 600;
    background: #fff;
    box-shadow: var(--little-genie-shadow-md);
    transition: transform .25s ease;
}
.little-genie-btn-block:hover { transform: scale(1.05); }
.little-genie-btn-block:active { transform: scale(.95); }
.little-genie-btn-block-solid { color: #fff !important; box-shadow: none; }


.little-genie-pill {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 9999px;
    font-size: 14px;
    font-weight: 600;
    color: #fff;
    white-space: nowrap;
}


.little-genie-hero {
    position: relative;
    overflow: hidden;
}
.little-genie-hero-bg {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, #A78BFA 0%, #AAF2E1 50%, #FFF9C4 100%);
}
.little-genie-hero-inner {
    position: relative;
    z-index: 10;
    padding-top: 96px;
    padding-bottom: 40px;
}
.little-genie-hero-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 48px;
    align-items: center;
}
@media (min-width: 1024px) {
    .little-genie-hero-grid { grid-template-columns: repeat(2, 1fr); }
}

.little-genie-hero-title {
    font-size: 56px;
    font-weight: 700;
    line-height: 1.2;
    color: #2D3748;
    margin-bottom: 24px;
}
.little-genie-hero-sub {
    font-size: 28px;
    font-weight: 600;
    color: #4B5563;
    line-height: 1.6;
    margin-bottom: 32px;
}
.little-genie-intro-section {
    background: linear-gradient(135deg, #F3F0FF 0%, #E3F2FD 50%, #E6FBF5 100%);
}
.little-genie-intro {
    text-align: center;
}
.little-genie-intro-text {
    font-size: 20px;
    line-height: 1.9;
    color: var(--little-genie-gray-700);
    margin-bottom: 24px;
}
.little-genie-intro-text:last-of-type {
    margin-bottom: 0;
}
.little-genie-hl-purple { color: #7C3AED; font-weight: 700; }
.little-genie-hl-blue   { color: var(--little-genie-blue); font-weight: 700; }
.little-genie-hl-pink   { color: #DB2777; font-weight: 700; }
.little-genie-intro-emojis {
    display: flex;
    justify-content: center;
    gap: 16px;
    margin-top: 32px;
}
.little-genie-intro-emojis span {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    font-size: 26px;
    box-shadow: var(--little-genie-shadow-md);
    animation: little-genie-bob 3s ease-in-out infinite;
}
.little-genie-intro-emojis span:nth-child(1) { animation-delay: 0s; }
.little-genie-intro-emojis span:nth-child(2) { animation-delay: .4s; }
.little-genie-intro-emojis span:nth-child(3) { animation-delay: .8s; }
.little-genie-intro-emojis span:nth-child(4) { animation-delay: 1.2s; }
.little-genie-hero-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}
.little-genie-hero-stats {
    margin-top: 48px;
    display: flex;
    flex-wrap: wrap;
    gap: 32px;
}
.little-genie-stat-num {
    font-size: 30px;
    font-weight: 700;
}
.little-genie-stat-label { color: var(--little-genie-gray-600); }


.little-genie-floating-shapes {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 1;
}
.little-genie-shape {
    position: absolute;
    font-size: 32px;
    opacity: .6;
    animation: little-genie-float-rotate 4s ease-in-out infinite;
}
@keyframes little-genie-float-rotate {
    0%   { transform: translateY(0) rotate(0deg); }
    25%  { transform: translateY(-20px) rotate(10deg); }
    50%  { transform: translateY(0) rotate(0deg); }
    75%  { transform: translateY(-20px) rotate(-10deg); }
    100% { transform: translateY(0) rotate(0deg); }
}


.little-genie-hero-visual { position: relative; z-index: 10; }
.little-genie-hero-float { position: relative; animation: little-genie-bob 3s ease-in-out infinite; }
@keyframes little-genie-bob {
    0%   { transform: translateY(0); }
    50%  { transform: translateY(-15px); }
    100% { transform: translateY(0); }
}
.little-genie-hero-image-card {
    background: #fff;
    padding: 24px;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: var(--little-genie-shadow-2xl);
}
.little-genie-hero-image {
    width: 100%;
    height: 400px;
    object-fit: cover;
    border-radius: 16px;
}
.little-genie-hero-mini-card {
    position: absolute;
    padding: 16px;
    border-radius: 16px;
    box-shadow: var(--little-genie-shadow-xl);
    background: #fff;
    display: flex;
    align-items: center;
    gap: 12px;
}
.little-genie-hero-mini-tr { top: -24px; right: -24px; }
.little-genie-hero-mini-bl { bottom: -24px; left: -24px; }
.little-genie-hero-mini-icon {
    width: 48px;
    height: 48px;
    border-radius: 9999px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
}
.little-genie-hero-mini-title { font-weight: 700; color: #1F2937; }
.little-genie-hero-mini-sub { font-size: 14px; color: var(--little-genie-gray-600); }


.little-genie-program-card {
    position: relative;
    overflow: hidden;
    border-radius: 24px;
    padding: 24px;
    height: 100%;
    box-shadow: var(--little-genie-shadow-xl);
    transition: transform .3s ease, box-shadow .3s ease;
}
.little-genie-program-card:hover {
    transform: translateY(-15px) scale(1.02);
    box-shadow: var(--little-genie-shadow-2xl);
}
.little-genie-program-illus {
    position: absolute;
    top: 0;
    right: 0;
    font-size: 128px;
    line-height: 1;
    opacity: .1;
    pointer-events: none;
}
.little-genie-program-card .little-genie-icon-square {
    position: relative;
    z-index: 1;
    margin-bottom: 16px;
    box-shadow: var(--little-genie-shadow-lg);
}
.little-genie-program-age {
    display: inline-block;
    padding: 4px 16px;
    border-radius: 9999px;
    font-size: 14px;
    font-weight: 600;
    background: rgba(255, 255, 255, .9);
    margin-bottom: 16px;
}
.little-genie-program-text {
    color: var(--little-genie-gray-700);
    line-height: 1.625;
    margin-bottom: 24px;
}


.little-genie-found-card {
    display: flex;
    align-items: center;
    gap: 24px;
    border-radius: 24px;
    padding: 24px;
    box-shadow: var(--little-genie-shadow-lg);
    transition: transform .3s ease, box-shadow .3s ease;
}
.little-genie-found-card:hover {
    transform: scale(1.03);
    box-shadow: var(--little-genie-shadow-2xl);
}
.little-genie-found-body { flex: 1; }
.little-genie-found-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 8px;
}


.little-genie-course-card {
    background: #fff;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: var(--little-genie-shadow-lg);
    height: 100%;
    transition: transform .3s ease, box-shadow .3s ease;
    display: flex;
    flex-direction: column;
}
.little-genie-course-card:hover {
    transform: translateY(-15px);
    box-shadow: var(--little-genie-shadow-2xl);
}
.little-genie-course-media {
    position: relative;
    height: 190px;
    overflow: hidden;
}
.little-genie-course-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.little-genie-course-badge {
    position: absolute;
    top: 16px;
    right: 16px;
    padding: 8px 16px;
    border-radius: 9999px;
    color: #fff;
    font-weight: 600;
    font-size: 14px;
}
.little-genie-course-body {
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.little-genie-course-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
.little-genie-course-duration {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--little-genie-gray-600);
    font-size: 14px;
}
.little-genie-course-rating {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-weight: 600;
    color: var(--little-genie-text);
}
.little-genie-course-rating i { color: #FFC107; }
.little-genie-course-body .little-genie-btn-block { margin-top: auto; width: auto; align-self: flex-start; padding: 10px 32px; }


.little-genie-structure { overflow: hidden; }
.little-genie-structure-bg { position: absolute; inset: 0; opacity: .05; pointer-events: none; }
.little-genie-structure-bg span {
    position: absolute;
    font-size: 128px;
    line-height: 1;
}
.little-genie-structure-inner { position: relative; z-index: 10; }

.little-genie-timeline { position: relative; }
.little-genie-timeline-line {
    display: none;
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 4px;
    transform: translateX(-50%);
    background: linear-gradient(180deg, #A78BFA 0%, #2196F3 50%, #FFBDBD 100%);
}
.little-genie-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 32px;
    margin-bottom: 48px;
}
.little-genie-step:last-child { margin-bottom: 0; }
.little-genie-step-card-wrap { width: 100%; }
.little-genie-step-card {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 32px;
    border-radius: 24px;
    box-shadow: var(--little-genie-shadow-lg);
    transition: transform .3s ease, box-shadow .3s ease;
}
.little-genie-step-card:hover {
    transform: scale(1.05);
    box-shadow: var(--little-genie-shadow-2xl);
}
.little-genie-step-card .little-genie-icon-square { margin-bottom: 0; }
.little-genie-step-badge {
    width: 80px;
    height: 80px;
    border-radius: 9999px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 36px;
    border: 4px solid #fff;
    box-shadow: var(--little-genie-shadow-xl);
    position: relative;
    z-index: 10;
}
.little-genie-step-spacer { display: none; }

@media (min-width: 1024px) {
    .little-genie-timeline-line { display: block; }
    .little-genie-step {
        flex-direction: row;
    }
    .little-genie-step-rev { flex-direction: row-reverse; }
    .little-genie-step-card-wrap { width: 41.6667%; }
    .little-genie-step-spacer { display: block; width: 41.6667%; }
}


@media (max-width: 1023px) {
    .little-genie-step-badge { order: -1; }
}

.little-genie-structure-cta { text-align: center; margin-top: 64px; }
.little-genie-structure-cta-box {
    display: inline-block;
    padding: 32px;
    border-radius: 24px;
    box-shadow: var(--little-genie-shadow-xl);
    background: linear-gradient(135deg, #A78BFA 0%, #2196F3 100%);
}
.little-genie-structure-cta-text {
    color: #fff;
    font-size: 20px;
    margin-bottom: 16px;
}


.little-genie-nac-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 12px;
}


.little-genie-video-card {
    height: 100%;
    transition: transform .3s ease;
}
.little-genie-video-card:hover { transform: translateY(-6px); }
.little-genie-video-name {
    text-align: center;
    font-size: 18px;
    font-weight: 700;
    color: var(--little-genie-text);
    margin-top: 16px;
}
.little-genie-video-media {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: 16px;
    cursor: pointer;
    background: #0f172a;
    box-shadow: var(--little-genie-shadow-lg);
}
.little-genie-video-facade { cursor: pointer; }
.little-genie-video-media img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .4s ease;
}
.little-genie-video-media:hover img { transform: scale(1.05); }
.little-genie-video-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
}
.little-genie-video-play {
    width: 60px;
    height: 60px;
    border-radius: 9999px;
    background: rgba(255, 255, 255, .92);
    color: #FF1A1A;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--little-genie-shadow-lg);
    font-size: 20px;
    padding-left: 4px;
    transition: transform .25s ease, background .25s ease;
}
.little-genie-video-media:hover .little-genie-video-play {
    transform: scale(1.1);
    background: #fff;
}
.little-genie-video-rating {
    position: absolute;
    top: 16px;
    right: 16px;
    padding: 4px 12px;
    border-radius: 9999px;
    color: #fff;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 2.4px;
}
.little-genie-video-rating i { color: #fff; font-size: 12.8px; }
.little-genie-video-body { padding: 24px; }
.little-genie-card-title + .little-genie-video-course { margin-top: 8px; }
.little-genie-video-course { font-size: 14px; font-weight: 600; }


.little-genie-testi { overflow: hidden; }
.little-genie-testi-bg { position: absolute; inset: 0; opacity: .05; pointer-events: none; }
.little-genie-testi-bg span { position: absolute; font-size: 72px; line-height: 1; }
.little-genie-testi-inner { position: relative; z-index: 10; }

.little-genie-carousel { position: relative; }
.little-genie-carousel-viewport { overflow: hidden; padding: 14px 0 36px; }
.little-genie-carousel-track {
    display: flex;
    transition: transform .5s ease;
}
.little-genie-slide {
    flex: 0 0 100%;
    max-width: 100%;
    padding: 0 16px;
    box-sizing: border-box;
}
@media (min-width: 640px) {
    .little-genie-slide { flex-basis: 50%; max-width: 50%; }
}
@media (min-width: 1024px) {
    .little-genie-slide { flex-basis: 33.3333%; max-width: 33.3333%; }
}

.little-genie-testi-card {
    padding: 32px;
    border-radius: 24px;
    box-shadow: var(--little-genie-shadow-lg);
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .05);
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: transform .3s ease, box-shadow .3s ease;
}
.little-genie-testi-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--little-genie-shadow-2xl);
}
.little-genie-testi-stars {
    display: flex;
    gap: 3px;
    justify-content: center;
    margin-bottom: 16px;
    color: #FFC107;
    font-size: 15px;
}
.little-genie-testi-text {
    color: var(--little-genie-gray-700);
    margin-bottom: 0;
    font-size: 18px;
    line-height: 1.625;
    text-align: center;
    font-style: italic;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.little-genie-testi-card { cursor: pointer; }

.little-genie-testi-modal {
    position: fixed;
    inset: 0;
    z-index: 1100;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(0, 0, 0, .55);
}
.little-genie-testi-modal.is-open { display: flex; }
.little-genie-testi-modal-box {
    position: relative;
    width: 100%;
    max-width: 560px;
    max-height: 85vh;
    overflow-y: auto;
    background: #fff;
    border-radius: 24px;
    padding: 48px 32px 40px;
    box-shadow: var(--little-genie-shadow-2xl);
    text-align: center;
}
.little-genie-testi-modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 40px;
    height: 40px;
    border-radius: 9999px;
    background: var(--little-genie-bg-gray);
    color: var(--little-genie-gray-700);
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.little-genie-testi-modal-text {
    color: var(--little-genie-gray-700);
    font-size: 18px;
    line-height: 1.75;
    font-style: italic;
    margin: 0;
}
.little-genie-testi-person {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 20px;
}
.little-genie-testi-avatar {
    width: 80px;
    height: 80px;
    border-radius: 9999px;
    overflow: hidden;
    margin-bottom: 16px;
    box-shadow: var(--little-genie-shadow-lg);
    border: 4px solid;
    transition: transform .25s ease;
}
.little-genie-testi-avatar img { width: 100%; height: 100%; object-fit: cover; }
.little-genie-testi-card:hover .little-genie-testi-avatar { transform: scale(1.1); }
.little-genie-testi-name { font-weight: 700; font-size: 20px; color: var(--little-genie-text); }
.little-genie-testi-role { color: var(--little-genie-gray-500); font-size: 14px; margin-top: 4px; }

.little-genie-carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    border-radius: 9999px;
    background: var(--little-genie-blue);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--little-genie-shadow-xl);
    font-size: 13px;
    z-index: 10;
    transition: transform .2s ease;
}
.little-genie-carousel-btn:hover { transform: translateY(-50%) scale(1.1); }
.little-genie-carousel-prev { left: 0; margin-left: -16px; }
.little-genie-carousel-next { right: 0; margin-right: -16px; }

.little-genie-carousel-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 32px;
}
.little-genie-dot {
    width: 12px;
    height: 12px;
    border-radius: 9999px;
    background: #D1D5DB;
    transition: transform .25s ease, background .25s ease;
}
.little-genie-dot.is-active {
    background: var(--little-genie-blue);
    transform: scale(1.5);
}


.little-genie-form-section {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #F3F0FF 0%, #E3F2FD 50%, #E6FBF5 100%);
    padding: 80px 24px;
}
.little-genie-form-box {
    width: 100%;
    max-width: 1140px;
    padding: 0 12px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    align-items: center;
}
@media (min-width: 768px) {
    .little-genie-form-box { grid-template-columns: repeat(2, 1fr); }
}
.little-genie-form-mascot {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
.little-genie-form-blob {
    position: absolute;
    width: 300px;
    height: 300px;
    border-radius: 42% 58% 56% 44% / 49% 45% 55% 51%;
    background: linear-gradient(135deg, #A78BFA 0%, #2196F3 100%);
    opacity: .14;
    z-index: 0;
    animation: little-genie-bob 5s ease-in-out infinite;
}
.little-genie-form-emoji {
    position: absolute;
    font-size: 30px;
    z-index: 2;
    opacity: .9;
    animation: little-genie-bob 3s ease-in-out infinite;
    pointer-events: none;
}
.little-genie-form-mascot img {
    position: relative;
    z-index: 1;
    width: 220px;
}
@media (min-width: 768px) {
    .little-genie-form-mascot img { width: 280px; }
}
.little-genie-form-title {
    font-size: 32px;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 24px;
    color: var(--little-genie-text);
}

.little-genie-form-fields .join-compact-form {
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
}


.little-genie-cta {
    position: relative;
    overflow: hidden;
    padding: 96px 0;
    background: linear-gradient(135deg, #A78BFA 0%, #2196F3 50%, #AAF2E1 100%);
}
.little-genie-cta-shapes { position: absolute; inset: 0; opacity: .1; }
.little-genie-cta-emoji {
    position: absolute;
    font-size: 128px;
    line-height: 1;
    animation: little-genie-bob 5s ease-in-out infinite;
}
.little-genie-cta-letters { position: absolute; inset: 0; opacity: .1; pointer-events: none; }
.little-genie-cta-letters span {
    position: absolute;
    font-size: 60px;
    font-weight: 700;
    color: #fff;
}
.little-genie-cta-inner {
    position: relative;
    z-index: 10;
    text-align: center;
}
.little-genie-cta-title {
    font-size: 56px;
    font-weight: 700;
    line-height: 1.2;
    color: #fff;
    margin-bottom: 24px;
}
.little-genie-cta-text {
    font-size: 20px;
    color: rgba(255, 255, 255, .95);
    margin: 0 auto 40px;
    max-width: 100%;
    line-height: 1.625;
}
.little-genie-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    justify-content: center;
}
.little-genie-cta-note {
    margin-top: 32px;
    color: #fff;
    font-size: 18px;
}



.little-genie-page [data-sal] {
    opacity: 1;
    transform: none;
    transition: opacity .6s ease, transform .6s ease;
}


.little-genie-page [data-sal].little-genie-reveal { opacity: 0; }
.little-genie-page [data-sal="slide-up"].little-genie-reveal    { transform: translateY(30px); }
.little-genie-page [data-sal="slide-right"].little-genie-reveal { transform: translateX(-40px); }
.little-genie-page [data-sal="slide-left"].little-genie-reveal  { transform: translateX(40px); }
.little-genie-page [data-sal].little-genie-reveal.little-genie-shown { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
    .little-genie-page *,
    .little-genie-page *::before,
    .little-genie-page *::after {
        animation: none !important;
        transition: none !important;
    }

    .little-genie-page [data-sal].little-genie-reveal { opacity: 1 !important; transform: none !important; }
}


@media (max-width: 1024px) {
    .little-genie-hero-title { font-size: 48px; }
    .little-genie-cta-title { font-size: 48px; }
}

@media (max-width: 767px) {
    .little-genie-container { padding-right: 15px; padding-left: 15px; }
    .little-genie-section { padding: 36px 0; }
    .little-genie-head { margin-bottom: 28px; }
    .little-genie-h2 { font-size: 32px; }
    .little-genie-sub { font-size: 16.8px; }
    .little-genie-hero-inner { padding-top: 112px; padding-bottom: 56px; }
    .little-genie-hero-title { font-size: 36px; }
    .little-genie-hero-sub { font-size: 17.6px; }
    .little-genie-hero-image { height: 320px; }
    .little-genie-hero-stats { gap: 20px; }

    .little-genie-hero-content { text-align: center; }
    .little-genie-hero-stats { justify-content: center; }

    .little-genie-page .little-genie-found-tagline .little-genie-pill {
        font-size: 13px;
        padding: 7px 18px;
    }

    .little-genie-hero-buttons { flex-wrap: nowrap; gap: 10px; justify-content: center; }
    .little-genie-hero-buttons .little-genie-btn {
        flex: 1 1 0;
        min-width: 0;
        padding-left: 12px;
        padding-right: 12px;
        font-size: 14px;
        gap: 6px;
        white-space: nowrap;
    }
    .little-genie-cta { padding: 64px 0; }
    .little-genie-cta-title { font-size: 33.6px; }
    .little-genie-cta-text { font-size: 16.8px; }
    .little-genie-cta-emoji,
    .little-genie-structure-bg span,
    .little-genie-program-illus { font-size: 80px; }
    .little-genie-carousel-prev { margin-left: 0; }
    .little-genie-carousel-next { margin-right: 0; }
    .little-genie-step-card { padding: 24px; }
    .little-genie-form-box { padding: 24px; }
}

@media (max-width: 480px) {
    .little-genie-hero-title { font-size: 30.4px; }
    .little-genie-h2 { font-size: 28px; }
    .little-genie-found-card { flex-direction: column; text-align: center; align-items: center; }
    .little-genie-found-head { flex-direction: column; align-items: center; gap: 8px; }
    .little-genie-hero-mini-tr { right: 0; top: -16px; }
    .little-genie-hero-mini-bl { left: 0; bottom: -16px; }
}


/* ===== Student Success Stories (video testimonials) spacing ===== */
.little-genie-testi-videos .video-area-5.page_section_gap { padding-top: 0; padding-bottom: 0; }
.little-genie-testi-videos .video-area-5 .container { padding-left: 0; padding-right: 0; }
.little-genie-testi-videos .video-area-5 .swiper-slide { padding-top: 10px !important; padding-bottom: 10px !important; }
.little-genie-testi-videos .video-area-5 .text-center.mt-4 { margin-top: 8px !important; }
.little-genie-testi-videos .swiper-pagination.testimonial-dots { margin-top: 10px !important; }
.little-genie-testi-section { padding-bottom: 32px; }


/* ===== FAQ accordion ===== */
.little-genie-faq-list {
    max-width: 1000px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 16px;
}
.little-genie-faq-item {
    background: #ffffff;
    border-radius: 16px;
    box-shadow: var(--little-genie-shadow-md);
    overflow: hidden;
    transition: box-shadow .3s ease, transform .3s ease;
}
.little-genie-faq-item:hover {
    box-shadow: var(--little-genie-shadow-lg);
    transform: translateY(-3px);
}
.little-genie-faq-item.is-open {
    box-shadow: var(--little-genie-shadow-lg);
}
.little-genie-faq-q {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    text-align: left;
    background: transparent;
    padding: 20px 24px;
    font-size: 17px;
    font-weight: 500;
    color: var(--little-genie-text);
    line-height: 1.4;
}
.little-genie-faq-q:hover { color: #a125c2; }
.little-genie-faq-item.is-open .little-genie-faq-q { color: #a125c2; }
.little-genie-faq-icon {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #a125c2;
    font-size: 16px;
    -webkit-text-stroke: 0.6px #a125c2;
    transition: transform .3s ease;
}
.little-genie-faq-item.is-open .little-genie-faq-icon {
    transform: rotate(180deg);
}
.little-genie-faq-a {
    max-height: 0;
    overflow: hidden;
    transition: max-height .35s ease;
}
.little-genie-faq-a-inner {
    padding: 0 26px 22px;
    color: var(--little-genie-gray-600);
    font-size: 16px;
    line-height: 1.7;
}
.little-genie-faq-a-inner ul {
    margin: 8px 0 0;
    padding-left: 20px;
}
.little-genie-faq-a-inner li { margin-bottom: 4px; }
@media (max-width: 767px) {
    .little-genie-faq-q { font-size: 16px; padding: 18px 20px; }
    .little-genie-faq-a-inner { padding: 0 20px 18px; }
}

