/*
Theme Name: Máº§m Non Landing Page
Theme URI: https://example.com
Description: Theme chuyÃªn dá»¥ng cho landing page tuyá»ƒn sinh trÆ°á»ng máº§m non - Sá»­ dá»¥ng ACF Flexible Content
Author: Your Name
Author URI: https://example.com
Version: 1.0.0
Text Domain: mamnon-landing
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: landing-page, education, kindergarten
*/

/* ==========================================================================
   Reset & Base Styles
   ========================================================================== */

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    /* Colors */
    --primary-color: #FF6B9D;
    --secondary-color: #FFA94D;
    --accent-color: #FFD93D;
    --text-dark: #2C3E50;
    --text-light: #6C757D;
    --bg-light: #FFF9F5;
    --bg-white: #FFFFFF;
    --success-color: #4CAF50;
    --border-color: #E8E8E8;
    
    /* Typography */
    --font-primary: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-heading: 'Quicksand', var(--font-primary);
    
    /* Spacing */
    --spacing-xs: 0.5rem;
    --spacing-sm: 1rem;
    --spacing-md: 2rem;
    --spacing-lg: 3rem;
    --spacing-xl: 4rem;
    --spacing-xxl: 6rem;
    
    /* Border Radius */
    --radius-sm: 8px;
    --radius-md: 16px;
    --radius-lg: 24px;
    --radius-full: 9999px;
    
    /* Shadows */
    --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.08);
    --shadow-md: 0 4px 16px rgba(0, 0, 0, 0.12);
    --shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.16);
    
    /* Container */
    --container-width: 1200px;
}

body {
    font-family: var(--font-primary);
    font-size: 16px;
    line-height: 1.6;
    color: var(--text-dark);
    background: var(--bg-white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ==========================================================================
   Typography
   ========================================================================== */

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: var(--spacing-sm);
    color: var(--text-dark);
}

h1 {
    font-size: clamp(2rem, 5vw, 3.5rem);
    margin-bottom: var(--spacing-md);
}

h2 {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
}

h3 {
    font-size: clamp(1.5rem, 3vw, 2rem);
}

h4 {
    font-size: 1.5rem;
}

p {
    margin-bottom: var(--spacing-sm);
    color: var(--text-light);
}

/* ==========================================================================
   Layout Components
   ========================================================================== */

.container {
    max-width: var(--container-width);
    margin: 0 auto;
    padding: 0 var(--spacing-md);
}

.section {
    padding: var(--spacing-xxl) 0;
    position: relative;
    overflow: hidden;
}

.section--hero {
    padding: var(--spacing-xl) 0 var(--spacing-xxl);
    background: linear-gradient(135deg, #FFF9F5 0%, #FFE8F0 100%);
    min-height: 100vh;
    display: flex;
    align-items: center;
}

.section--alt {
    background: var(--bg-light);
}

.section__header {
    text-align: center;
    max-width: 800px;
    margin: 0 auto var(--spacing-lg);
}

.section__subtitle {
    color: var(--primary-color);
    font-weight: 600;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--spacing-xs);
}

.section__title {
    margin-bottom: var(--spacing-sm);
}

.section__description {
    font-size: 1.125rem;
    color: var(--text-light);
}

/* ==========================================================================
   Slide Section
   ========================================================================== */

.slides-section {
    position: relative;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    border-radius: 0;
    overflow: hidden;
    background: #111;
    box-shadow: none;
}

.slides-section__track {
    position: relative;
    min-height: min(760px, 90vh);
}

.slides-section__item {
    display: none;
    grid-template-columns: 1fr;
    align-items: stretch;
    position: relative;
    min-height: min(760px, 90vh);
}

.slides-section__item.is-active {
    display: grid;
}

.slides-section__image-wrap {
    position: relative;
    background: #111;
    min-height: inherit;
}

.slides-section__image-wrap::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0) 42%),
        linear-gradient(180deg, rgba(0, 0, 0, 0.48) 0%, rgba(0, 0, 0, 0.68) 100%);
    z-index: 1;
    pointer-events: none;
}

.slides-section__image {
    width: 100%;
    height: 100%;
    min-height: min(760px, 90vh);
    object-fit: cover;
    display: block;
}

.slides-section__content {
    position: absolute;
    inset: 0;
    z-index: 2;
    width: min(92%, 920px);
    margin: auto;
    padding: clamp(20px, 4vw, 40px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    color: #fff;
    pointer-events: none;
}

.slides-section__content .btn {
    pointer-events: auto;
}

.slides-section__content > * {
    opacity: 0;
    transform: translateY(26px);
}

.slides-section__item.is-active .slides-section__title {
    animation: slideTextRise 700ms cubic-bezier(0.16, 1, 0.3, 1) 130ms forwards;
}

.slides-section__item.is-active .slides-section__description {
    animation: slideTextRise 700ms cubic-bezier(0.16, 1, 0.3, 1) 240ms forwards;
}

.slides-section__item.is-active .btn {
    animation: slideTextRise 700ms cubic-bezier(0.16, 1, 0.3, 1) 360ms forwards;
}

.slides-section__title {
    margin-bottom: var(--spacing-sm);
    font-size: clamp(1.9rem, 4.2vw, 3.75rem);
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: #fff;
    text-shadow:
        0 2px 4px rgba(0, 0, 0, 0.45),
        0 10px 28px rgba(0, 0, 0, 0.45);
    background: rgba(0, 0, 0, 0.34);
    padding: 0.14em 0.34em;
    border-radius: 0.28em;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}

.slides-section__description {
    margin-bottom: var(--spacing-md);
    font-size: clamp(1rem, 1.8vw, 1.25rem);
    max-width: 64ch;
    color: rgba(255, 255, 255, 0.92);
    text-shadow:
        0 1px 2px rgba(0, 0, 0, 0.5),
        0 6px 22px rgba(0, 0, 0, 0.35);
    background: rgba(0, 0, 0, 0.28);
    padding: 0.34em 0.6em;
    border-radius: 0.7em;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}

.slides-section__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 42px;
    height: 42px;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.16);
    font-size: 26px;
    line-height: 1;
    color: var(--text-dark);
    cursor: pointer;
    z-index: 3;
}

.slides-section__nav--prev { left: clamp(12px, 2vw, 28px); }
.slides-section__nav--next { right: clamp(12px, 2vw, 28px); }

.slides-section__dots {
    position: absolute;
    left: 50%;
    bottom: 12px;
    transform: translateX(-50%);
    z-index: 3;
    display: flex;
    justify-content: center;
    gap: 8px;
    padding: 0;
}

.slides-section__dot {
    width: 10px;
    height: 10px;
    border: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.55);
    cursor: pointer;
    transition: width 220ms ease, background-color 220ms ease;
}

.slides-section__dot.is-active {
    width: 26px;
    background: #fff;
}

@keyframes slideTextRise {
    from {
        opacity: 0;
        transform: translateY(26px);
        filter: blur(4px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
        filter: blur(0);
    }
}

@media (max-width: 767px) {
    .slides-section__track,
    .slides-section__item,
    .slides-section__image {
        min-height: 72vh;
    }

    .slides-section__nav {
        width: 36px;
        height: 36px;
        font-size: 20px;
    }
}

/* ==========================================================================
   Hero Section
   ========================================================================== */

.hero {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
    align-items: center;
}

@media (min-width: 768px) {
    .hero {
        grid-template-columns: 1fr 1fr;
    }
}

.hero__content {
    text-align: center;
}

@media (min-width: 768px) {
    .hero__content {
        text-align: left;
    }
}

.hero__school-name {
    font-size: 1.25rem;
    color: var(--primary-color);
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
}

.hero__title {
    margin-bottom: var(--spacing-sm);
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hero__description {
    font-size: 1.125rem;
    margin-bottom: var(--spacing-md);
}

.hero__cta-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
    justify-content: center;
}

@media (min-width: 768px) {
    .hero__cta-group {
        justify-content: flex-start;
    }
}

.hero__hotline {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm);
    background: var(--bg-white);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    justify-content: center;
}

@media (min-width: 768px) {
    .hero__hotline {
        justify-content: flex-start;
    }
}

.hero__hotline-icon {
    width: 40px;
    height: 40px;
    background: var(--primary-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.25rem;
}

.hero__hotline-text small {
    display: block;
    font-size: 0.875rem;
    color: var(--text-light);
}

.hero__hotline-text strong {
    display: block;
    font-size: 1.5rem;
    color: var(--primary-color);
    font-weight: 700;
}

.hero__image {
    position: relative;
}

.hero__image img {
    width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
}

/* ==========================================================================
   Buttons
   ========================================================================== */

.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: 1rem 2rem;
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: var(--radius-full);
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    font-family: var(--font-primary);
    text-align: center;
    justify-content: center;
}

.btn--primary {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: white;
    box-shadow: var(--shadow-md);
}

.btn--primary:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.btn--outline {
    background: white;
    color: var(--primary-color);
    border: 2px solid var(--primary-color);
}

.btn--outline:hover {
    background: var(--primary-color);
    color: white;
}

.btn--large {
    padding: 1.25rem 2.5rem;
    font-size: 1.125rem;
}

/* ==========================================================================
   Features Grid
   ========================================================================== */

.features {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
}

@media (min-width: 640px) {
    .features {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .features {
        grid-template-columns: repeat(3, 1fr);
    }
}

.feature-card {
    background: white;
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    transition: all 0.3s ease;
}

.feature-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.feature-card__icon {
    width: 64px;
    height: 64px;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: white;
    margin-bottom: var(--spacing-sm);
    margin: 10px auto;
}

.feature-card__title {
    font-size: 1.25rem;
    margin-bottom: var(--spacing-xs);
}

.feature-card__description {
    color: var(--text-light);
    font-size: 0.938rem;
}

/* ==========================================================================
   Program Cards
   ========================================================================== */

.programs {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
}

@media (min-width: 768px) {
    .programs {
        grid-template-columns: repeat(2, 1fr);
    }
}

.program-card {
    background: white;
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: all 0.3s ease;
}

.program-card:hover {
    box-shadow: var(--shadow-md);
}

.program-card__image {
    width: 100%;
    height: 200px;
    object-fit: cover;
}

.program-card__content {
    padding: var(--spacing-md);
}

.program-card__title {
    font-size: 1.25rem;
    margin-bottom: var(--spacing-xs);
}

.program-card__age {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background: var(--bg-light);
    border-radius: var(--radius-full);
    font-size: 0.875rem;
    color: var(--primary-color);
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
}

.program-card__description {
    color: var(--text-light);
    font-size: 0.938rem;
    margin-bottom: var(--spacing-sm);
}

.program-card__skills {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
}

.skill-tag {
    padding: 0.375rem 0.75rem;
    background: var(--bg-light);
    border-radius: var(--radius-sm);
    font-size: 0.813rem;
    color: var(--text-dark);
}

/* ==========================================================================
   Image Gallery
   ========================================================================== */

.gallery {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm);
}

@media (min-width: 768px) {
    .gallery {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1024px) {
    .gallery {
        grid-template-columns: repeat(4, 1fr);
    }
}

.gallery__item {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-md);
    aspect-ratio: 1;
}

.gallery__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.gallery__item:hover img {
    transform: scale(1.1);
}

.gallery__caption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent);
    color: white;
    padding: var(--spacing-sm);
    font-size: 0.875rem;
    transform: translateY(100%);
    transition: transform 0.3s ease;
}

.gallery__item:hover .gallery__caption {
    transform: translateY(0);
}

/* ==========================================================================
   Team Members
   ========================================================================== */

.team {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
}

@media (min-width: 640px) {
    .team {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .team {
        grid-template-columns: repeat(4, 1fr);
    }
}

.team-member {
    text-align: center;
    background: white;
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    transition: all 0.3s ease;
}

.team-member:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.team-member__avatar {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    margin: 0 auto var(--spacing-sm);
    border: 4px solid var(--bg-light);
}

.team-member__name {
    font-size: 1.125rem;
    margin-bottom: 0.25rem;
}

.team-member__role {
    color: var(--primary-color);
    font-size: 0.875rem;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
}

.team-member__bio {
    font-size: 0.875rem;
    color: var(--text-light);
}

/* ==========================================================================
   Schedule Table
   ========================================================================== */

.schedule {
    background: white;
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.schedule__table {
    width: 100%;
    border-collapse: collapse;
}

.schedule__table th,
.schedule__table td {
    padding: var(--spacing-sm);
    text-align: left;
    border-bottom: 1px solid var(--border-color);
}

.schedule__table th {
    background: var(--bg-light);
    font-weight: 600;
    color: var(--text-dark);
}

.schedule__table td:first-child {
    color: var(--primary-color);
    font-weight: 600;
}

.schedule__table tr:last-child td {
    border-bottom: none;
}

/* ==========================================================================
   Menu Grid
   ========================================================================== */

.menu-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
}

@media (min-width: 768px) {
    .menu-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.menu-card {
    background: white;
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}

.menu-card__day {
    display: inline-block;
    padding: 0.375rem 1rem;
    background: var(--primary-color);
    color: white;
    border-radius: var(--radius-full);
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
}

.menu-card__meals {
    list-style: none;
}

.menu-card__meals li {
    padding: var(--spacing-xs) 0;
    border-bottom: 1px dashed var(--border-color);
}

.menu-card__meals li:last-child {
    border-bottom: none;
}

.meal-name {
    font-weight: 600;
    color: var(--text-dark);
}

.meal-items {
    color: var(--text-light);
    font-size: 0.938rem;
}

/* ==========================================================================
   Pricing Cards
   ========================================================================== */

.pricing {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
}

@media (min-width: 768px) {
    .pricing {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .pricing {
        grid-template-columns: repeat(3, 1fr);
    }
}

.pricing-card {
    background: white;
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    border: 2px solid transparent;
    transition: all 0.3s ease;
}

.pricing-card--featured {
    border-color: var(--primary-color);
    transform: scale(1.05);
}

.pricing-card:hover {
    border-color: var(--primary-color);
    box-shadow: var(--shadow-md);
}

.pricing-card__badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background: var(--primary-color);
    color: white;
    border-radius: var(--radius-full);
    font-size: 0.75rem;
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
}

.pricing-card__title {
    font-size: 1.5rem;
    margin-bottom: var(--spacing-xs);
}

.pricing-card__price {
    font-size: 2rem;
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: var(--spacing-sm);
}

.pricing-card__price small {
    font-size: 1rem;
    font-weight: 400;
    color: var(--text-light);
}

.pricing-card__features {
    list-style: none;
    margin-bottom: var(--spacing-md);
}

.pricing-card__features li {
    padding: var(--spacing-xs) 0;
    color: var(--text-light);
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-xs);
}

.pricing-card__features li:before {
    content: "\2713"; /* ✓ */
    color: var(--success-color);
    font-weight: bold;
    flex-shrink: 0;
}

/* ==========================================================================
   Process Steps
   ========================================================================== */

.process {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
}

@media (min-width: 768px) {
    .process {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .process {
        grid-template-columns: repeat(4, 1fr);
    }
}

.process-step {
    position: relative;
    text-align: center;
    padding: var(--spacing-md);
}

.process-step__number {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0 auto var(--spacing-sm);
}

.process-step__title {
    font-size: 1.125rem;
    margin-bottom: var(--spacing-xs);
}

.process-step__description {
    color: var(--text-light);
    font-size: 0.938rem;
}

/* ==========================================================================
   Testimonials
   ========================================================================== */

.testimonials {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
}

@media (min-width: 768px) {
    .testimonials {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .testimonials {
        grid-template-columns: repeat(3, 1fr);
    }
}

.testimonial {
    background: white;
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    position: relative;
}

.testimonial__quote {
    font-size: 3rem;
    color: var(--primary-color);
    opacity: 0.2;
    line-height: 1;
    margin-bottom: var(--spacing-xs);
}

.testimonial__content {
    font-style: italic;
    color: var(--text-light);
    margin-bottom: var(--spacing-sm);
}

.testimonial__author {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.testimonial__avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
}

.testimonial__name {
    font-weight: 600;
    color: var(--text-dark);
    font-size: 0.938rem;
}

.testimonial__role {
    color: var(--text-light);
    font-size: 0.813rem;
}

/* ==========================================================================
   FAQ Accordion
   ========================================================================== */

.faq {
    max-width: 800px;
    margin: 0 auto;
}

.faq-item {
    background: white;
    margin-bottom: var(--spacing-sm);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: box-shadow 0.3s ease;
}

.faq-item:hover {
    box-shadow: var(--shadow-md);
}

.faq-item__question {
    width: 100%;
    padding: var(--spacing-md);
    background: none;
    border: none;
    text-align: left;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--text-dark);
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: all 0.3s ease;
    outline: none;
}

.faq-item__question:hover {
    color: var(--primary-color);
    background: rgba(0, 0, 0, 0.02);
}

.faq-item__question:focus {
    outline: 2px solid var(--primary-color);
    outline-offset: -2px;
}

.faq-item__icon {
    font-size: 1.5rem;
    font-weight: normal;
    color: var(--primary-color);
    transition: transform 0.3s ease;
    flex-shrink: 0;
    margin-left: 1rem;
}

.faq-item.active .faq-item__icon {
    transform: rotate(45deg);
}

.faq-item__answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease;
}

.faq-item.active .faq-item__answer {
    max-height: 2000px;
}

.faq-item__answer-content {
    padding: 0 var(--spacing-md) var(--spacing-md);
    color: var(--text-light);
    line-height: 1.8;
}

/* ==========================================================================
   Contact Form
   ========================================================================== */

.contact-form {
    max-width: 600px;
    margin: 0 auto;
    background: white;
    padding: var(--spacing-lg);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
}

.form-group {
    margin-bottom: var(--spacing-md);
}

.form-label {
    display: block;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
    color: var(--text-dark);
}

.form-input,
.form-textarea,
.form-select {
    width: 100%;
    padding: var(--spacing-sm);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-sm);
    font-family: var(--font-primary);
    font-size: 1rem;
    transition: all 0.3s ease;
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(255, 107, 157, 0.1);
}

.form-textarea {
    resize: vertical;
    min-height: 120px;
}

.form-checkbox-group {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.form-checkbox {
    width: 20px;
    height: 20px;
    cursor: pointer;
}

.form-submit {
    width: 100%;
}

/* ==========================================================================
   CTA Banner
   ========================================================================== */

.cta-banner {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: white;
    text-align: center;
    padding: var(--spacing-xl);
    border-radius: var(--radius-lg);
    margin: var(--spacing-lg) 0;
}

.cta-banner__title {
    color: white;
    margin-bottom: var(--spacing-sm);
}

.cta-banner__description {
    font-size: 1.125rem;
    margin-bottom: var(--spacing-md);
    opacity: 0.9;
    color: #fff;
}

.cta-banner__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    justify-content: center;
}

/* ==========================================================================
   Footer
   ========================================================================== */

.footer {
    background: var(--text-dark);
    color: white;
    padding: var(--spacing-lg) 0 var(--spacing-md);
}

.footer__content {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

@media (min-width: 768px) {
    .footer__content {
        grid-template-columns: repeat(3, 1fr);
    }
}

.footer__section h4 {
    color: white;
    margin-bottom: var(--spacing-sm);
}

.footer__section p,
.footer__section a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    line-height: 2;
}

.footer__section a:hover {
    color: var(--primary-color);
}

.footer__bottom {
    text-align: center;
    padding-top: var(--spacing-md);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.5);
}

/* ==========================================================================
   Utilities
   ========================================================================== */

.text-center {
    text-align: center;
}

.mt-lg {
    margin-top: var(--spacing-lg);
}

.mb-lg {
    margin-bottom: var(--spacing-lg);
}

.hidden {
    display: none;
}

@media (max-width: 767px) {
    .hide-mobile {
        display: none;
    }
}

@media (min-width: 768px) {
    .hide-desktop {
        display: none;
    }
}

/* ==========================================================================
   Landing Header Navigation
   ========================================================================== */

.landing-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background: var(--bg-white);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
}

.landing-header.header-scrolled {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.header-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 0;
    gap: 2rem;
}

.header-logo a {
    display: block;
    transition: opacity 0.3s ease;
}

.header-logo img {
    max-height: 60px;
    width: auto;
    display: block;
}

.header-logo .site-name {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-color);
    text-decoration: none;
    font-family: var(--font-heading);
}

.header-logo a:hover {
    opacity: 0.8;
}

/* Mobile Menu Toggle */
.mobile-menu-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    z-index: 1001;
}

.mobile-menu-toggle span {
    display: block;
    width: 25px;
    height: 3px;
    background: var(--primary-color);
    transition: all 0.3s ease;
    border-radius: 3px;
}

.mobile-menu-toggle[aria-expanded="true"] span:nth-child(1) {
    transform: rotate(45deg) translate(8px, 8px);
}

.mobile-menu-toggle[aria-expanded="true"] span:nth-child(2) {
    opacity: 0;
}

.mobile-menu-toggle[aria-expanded="true"] span:nth-child(3) {
    transform: rotate(-45deg) translate(7px, -7px);
}

/* Navigation Menu */
.header-nav {
    flex: 1;
    display: flex;
    justify-content: flex-end;
}

.nav-menu {
    display: flex;
    list-style: none;
    gap: 1rem;
    align-items: center;
    margin: 0;
    padding: 0;
}

.nav-item {
    margin: 0;
}

.nav-link {
    display: block;
    padding: 0.5rem 5px;
    color: var(--text-dark);
    text-decoration: none;
    font-weight: 500;
    transition: all 0.3s ease;
    border-radius: var(--radius-sm);
}

.nav-link:hover {
    color: var(--primary-color);
    background: rgba(255, 107, 157, 0.1);
}

.nav-item-highlight .nav-link {
    background: var(--secondary-color);
    color: var(--bg-white);
    font-weight: 600;
    padding: 0.75rem 1.5rem;
}

.nav-item-highlight .nav-link:hover {
    background: var(--primary-color);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(255, 107, 157, 0.3);
}

/* Add padding to body to account for fixed header */
body.page-template-page-landing {
    padding-top: 80px;
}

/* ==========================================================================
   Landing Footer
   ========================================================================== */

.landing-footer {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: var(--bg-white);
    padding: 3rem 0 1rem;
    margin-top: 4rem;
}

.footer-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 2rem;
    margin-bottom: 2rem;
}

.footer-col {
    padding: 0;
}

.footer-title {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 1rem;
    font-family: var(--font-heading);
    color: #fff;
}

.footer-text {
    line-height: 1.7;
    opacity: 0.95;
    margin-bottom: 0;
}

.footer-contact-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-contact-item {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 1rem;
    line-height: 1.7;
}

.footer-contact-item svg {
    flex-shrink: 0;
    margin-top: 2px;
    opacity: 0.9;
}

.footer-contact-item a {
    color: var(--bg-white);
    text-decoration: none;
    transition: opacity 0.3s ease;
}

.footer-contact-item a:hover {
    opacity: 0.8;
    text-decoration: underline;
}

.footer-social-links {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    color: var(--bg-white);
    text-decoration: none;
    transition: all 0.3s ease;
}

.social-link:hover {
    background: var(--bg-white);
    color: var(--primary-color);
    transform: translateY(-3px);
}

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    padding-top: 1.5rem;
    margin-top: 2rem;
    text-align: center;
}

.footer-copyright {
    opacity: 0.9;
    font-size: 0.9rem;
    margin: 0;
    color: #fff;
}

/* ==========================================================================
   Floating Contact Buttons
   ========================================================================== */

.floating-contacts {
    position: fixed;
    right: 20px;
    bottom: 20px;
    z-index: 999;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.floating-btn {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-radius: 50px;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9rem;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
    min-width: 60px;
    justify-content: center;
}

.floating-btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
}

.floating-btn svg {
    flex-shrink: 0;
}

.floating-btn-zalo {
    background: linear-gradient(135deg, #0068FF, #0095FF);
    color: #fff;
}

.floating-btn-facebook {
    background: linear-gradient(135deg, #1877F2, #42A5F5);
    color: #fff;
}

.floating-btn-phone {
    background: linear-gradient(135deg, #4CAF50, #66BB6A);
    color: #fff;
}

/* Desktop: Show with text */
@media (min-width: 768px) {
    .floating-btn-text {
        display: inline;
    }
}

/* Mobile: Fixed bottom bar */
@media (max-width: 767px) {
    .floating-contacts {
        left: 0;
        right: 0;
        bottom: 0;
        flex-direction: row;
        justify-content: space-around;
        background: var(--bg-white);
        padding: 10px;
        box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
        border-radius: 0;
        gap: 8px;
    }
    
    .floating-btn {
        flex: 1;
        border-radius: 4px;
        padding: 8px;
        flex-direction: row;
        gap: 4px;
        font-size: 0.75rem;
        min-width: auto;
    }
    
    .floating-btn svg {
        width: 24px;
        height: 24px;
    }
    
    .floating-btn-text {
        display: block;
        font-size: 0.7rem;
    }
    
    /* Add padding to body for mobile floating bar */
    body.page-template-page-landing {
        padding-bottom: 70px;
    }
}

/* ==========================================================================
   Mobile Header Navigation
   ========================================================================== */

@media (max-width: 991px) {
    .mobile-menu-toggle {
        display: flex;
    }
    
    .header-nav {
        position: fixed;
        top: 0;
        left: -100%;
        width: 280px;
        height: 100vh;
        background: var(--bg-white);
        box-shadow: 2px 0 10px rgba(0, 0, 0, 0.1);
        transition: left 0.3s ease;
        padding: 80px 20px 20px;
        overflow-y: auto;
    }
    
    .header-nav.menu-open {
        left: 0;
    }
    
    .nav-menu {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
    }
    
    .nav-link {
        padding: 1rem;
        border-bottom: 1px solid var(--border-color);
    }
    
    .nav-item-highlight .nav-link {
        margin: 1rem 0;
        border-bottom: none;
        text-align: center;
    }
}

/* ==========================================================================
   Dynamic Section Backgrounds
   ========================================================================== */

.section-with-bg {
    position: relative;
    overflow: hidden;
}

.section-bg-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -2;
}

.section-bg-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
}

/* Ensure text is readable on background images */
.section-with-bg.has-image {
    color: var(--bg-white);
}

.section-with-bg.has-image .section__title,
.section-with-bg.has-image .section__subtitle,
.section-with-bg.has-image .section__description {
    color: var(--bg-white);
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

/* ==========================================================================
   Photo Gallery
   ========================================================================== */

.photo-gallery {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm);
}

@media (min-width: 640px) {
    .photo-gallery {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1024px) {
    .photo-gallery {
        grid-template-columns: repeat(4, 1fr);
    }
}

.photo-gallery__item {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-md);
    aspect-ratio: 1;
    background: var(--bg-light);
    cursor: pointer;
    transition: transform 0.3s ease;
}

.photo-gallery__item:hover {
    transform: scale(1.02);
    box-shadow: var(--shadow-md);
}

.photo-gallery__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.photo-gallery__item:hover img {
    transform: scale(1.1);
}

.photo-gallery__caption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8), transparent);
    color: var(--bg-white);
    padding: var(--spacing-sm);
    font-size: 0.875rem;
    transform: translateY(100%);
    transition: transform 0.3s ease;
}

.photo-gallery__item:hover .photo-gallery__caption {
    transform: translateY(0);
}

/* ==========================================================================
   Video Gallery
   ========================================================================== */

.video-gallery {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
}

@media (min-width: 768px) {
    .video-gallery {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .video-gallery {
        grid-template-columns: repeat(3, 1fr);
    }
}

.video-gallery__item {
    background: var(--bg-white);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: all 0.3s ease;
}

.video-gallery__item:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-4px);
}

.video-gallery__player {
    position: relative;
    padding-bottom: 56.25%; /* 16:9 aspect ratio */
    height: 0;
    overflow: hidden;
    background: #000;
}

.video-gallery__player iframe,
.video-gallery__player video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.video-gallery__player video {
    object-fit: cover;
}

/* YouTube thumbnail with play button */
.video-embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.video-thumbnail {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.video-play-btn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    transition: transform 0.3s ease;
    z-index: 2;
}

.video-play-btn:hover {
    transform: translate(-50%, -50%) scale(1.1);
}

.video-play-btn svg {
    filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.3));
}

.video-gallery__content {
    padding: var(--spacing-md);
}

.video-gallery__title {
    font-size: 1.125rem;
    margin-bottom: var(--spacing-xs);
    color: var(--text-dark);
}

.video-gallery__description {
    font-size: 0.938rem;
    color: var(--text-light);
    line-height: 1.6;
}
.no-padding{padding:0px !important;}
.footer-text *{color: #fff;}
/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

@media (max-width: 767px) {
    .header-logo img {
        max-height: 45px;
    }
    
    body.page-template-page-landing {
        padding-top: 70px;
    }
    
    .footer-content {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    
    .landing-footer {
        padding: 2rem 0 1rem;
    }
    .header-nav {
    flex: 1;
    display: block;
    justify-content: flex-end;
}
}

@media (min-width: 768px) and (max-width: 991px) {
    .nav-menu {
        gap: 0.5rem;
    }
    
    .nav-link {
        padding: 0.5rem 0.75rem;
        font-size: 0.9rem;
    }
}

/* ==========================================================================
   Landing Fun Template (page-landing-fun.php)
   ========================================================================== */

body.page-template-page-landing-signature {
    padding-top: 80px;
    background: #fff9ef;
}

.landing-signature {
    --fun-primary: #ff7a59;
    --fun-secondary: #00b8a9;
    --fun-accent: #ffd166;
    --fun-lilac: #7f7fd5;
    --fun-card: #ffffff;
}

.landing-signature .section {
    position: relative;
    padding: clamp(64px, 9vw, 112px) 0;
}

.landing-signature .section::before {
    content: "";
    position: absolute;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 209, 102, 0.35) 0%, rgba(255, 209, 102, 0) 68%);
    top: -50px;
    right: -80px;
    pointer-events: none;
}

.landing-signature .section:nth-of-type(even)::before {
    background: radial-gradient(circle, rgba(0, 184, 169, 0.24) 0%, rgba(0, 184, 169, 0) 68%);
    left: -70px;
    right: auto;
}

.landing-signature .section__header {
    max-width: 860px;
    margin-bottom: clamp(1.75rem, 4vw, 3rem);
}

.landing-signature .section__subtitle {
    /* color: var(--fun-secondary); */
    font-size: 0.85rem;
    letter-spacing: 1.5px;
    font-weight: 800;
}

.landing-signature .section__title {
    font-size: clamp(1.8rem, 4vw, 3rem);
    color: #2f2a45;
    text-wrap: balance;
}

.landing-signature .section__description {
    color: #635f7c;
    text-wrap: pretty;
}

.landing-signature .btn {
    border-radius: 16px;
    transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}

.landing-signature .btn:hover {
    transform: translateY(-3px) scale(1.02);
    filter: saturate(1.08);
}

.landing-signature .btn--primary {
    background: linear-gradient(135deg, var(--fun-primary), #ff9f45);
}

.landing-signature .btn--outline {
    border-color: var(--fun-secondary);
    color: var(--fun-secondary);
}

.landing-signature .section--hero {
    background:
        radial-gradient(circle at 12% 18%, rgba(255, 209, 102, 0.3), rgba(255, 209, 102, 0) 36%),
        radial-gradient(circle at 85% 12%, rgba(127, 127, 213, 0.2), rgba(127, 127, 213, 0) 38%),
        linear-gradient(180deg, #fff9ef 0%, #fff3fe 100%);
}

.landing-signature .hero {
    grid-template-columns: 1fr;
    gap: clamp(1.5rem, 4vw, 3rem);
}

.landing-signature .hero__image img {
    border-radius: 32px;
    transform: rotate(-1.4deg);
}

.landing-signature .hero__content {
    background: rgba(255, 255, 255, 0.72);
    backdrop-filter: blur(5px);
    border: 2px dashed rgba(255, 122, 89, 0.35);
    border-radius: 28px;
    padding: clamp(1.25rem, 3vw, 2rem);
}

.landing-signature .hero__title {
    color: #2f2a45;
    background: none;
    -webkit-text-fill-color: #2f2a45;
}

.landing-signature .features,
.landing-signature .programs,
.landing-signature .team,
.landing-signature .pricing,
.landing-signature .testimonials,
.landing-signature .video-gallery {
    gap: clamp(1rem, 2.5vw, 1.5rem);
}

.landing-signature .feature-card,
.landing-signature .program-card,
.landing-signature .team-member,
.landing-signature .pricing-card,
.landing-signature .testimonial,
.landing-signature .menu-card,
.landing-signature .video-gallery__item,
.landing-signature .photo-gallery__item {
    background: var(--fun-card);
    border: 2px solid rgba(127, 127, 213, 0.13);
    border-radius: 24px;
    box-shadow: 0 14px 30px rgba(23, 29, 58, 0.08);
}

.landing-signature .features .feature-card:nth-child(odd),
.landing-signature .programs .program-card:nth-child(odd),
.landing-signature .team .team-member:nth-child(odd),
.landing-signature .pricing .pricing-card:nth-child(odd) {
    transform: translateY(-8px);
}

.landing-signature .features .feature-card:nth-child(even),
.landing-signature .programs .program-card:nth-child(even),
.landing-signature .team .team-member:nth-child(even),
.landing-signature .pricing .pricing-card:nth-child(even) {
    transform: translateY(6px);
}

.landing-signature .feature-card:hover,
.landing-signature .program-card:hover,
.landing-signature .team-member:hover,
.landing-signature .pricing-card:hover,
.landing-signature .testimonial:hover {
    transform: translateY(-10px) rotate(-0.4deg);
}

.landing-signature .feature-card__icon {
    background: linear-gradient(135deg, var(--fun-secondary), #35d0ba);
    border-radius: 18px;
    animation: funFloat 3.4s ease-in-out infinite;
}

.landing-signature .program-card__age,
.landing-signature .menu-card__day,
.landing-signature .pricing-card__badge {
    background: linear-gradient(135deg, rgba(255, 122, 89, 0.16), rgba(255, 209, 102, 0.2));
    color: #da5d3f;
}

.landing-signature .skill-tag {
    background: rgba(0, 184, 169, 0.12);
    color: #16867d;
    border: 1px solid rgba(0, 184, 169, 0.18);
}

.landing-signature .process-step {
    border-radius: 22px;
    border: 2px dashed rgba(0, 184, 169, 0.24);
    background: #fff;
    padding: clamp(1rem, 2vw, 1.5rem);
}

.landing-signature .process-step__number {
    background: linear-gradient(135deg, var(--fun-secondary), var(--fun-lilac));
    color: #fff;
    box-shadow: 0 10px 20px rgba(0, 184, 169, 0.25);
}

.landing-signature .faq-item {
    border-radius: 18px;
    border: 1px solid rgba(127, 127, 213, 0.2);
    background: #fff;
}

.landing-signature .faq-item__question {
    color: #2f2a45;
}

.landing-signature .contact-form {
    border-radius: 28px;
    border: 2px dashed rgba(255, 122, 89, 0.28);
    background:
        radial-gradient(circle at 90% 8%, rgba(255, 209, 102, 0.22), rgba(255, 209, 102, 0) 34%),
        #fff;
}

.landing-signature .cta-banner {
    background:
        radial-gradient(circle at 8% 18%, rgba(255, 255, 255, 0.35), rgba(255, 255, 255, 0) 34%),
        linear-gradient(135deg, var(--fun-primary), var(--fun-secondary));
    border-radius: 34px;
}

@keyframes funFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}

@media (min-width: 992px) {
    .landing-signature .hero {
        grid-template-columns: 1.05fr 0.95fr;
    }
}

@media (max-width: 767px) {
    body.page-template-page-landing-signature {
        padding-top: 70px;
    }

    .landing-signature .features .feature-card:nth-child(odd),
    .landing-signature .programs .program-card:nth-child(odd),
    .landing-signature .team .team-member:nth-child(odd),
    .landing-signature .pricing .pricing-card:nth-child(odd),
    .landing-signature .features .feature-card:nth-child(even),
    .landing-signature .programs .program-card:nth-child(even),
    .landing-signature .team .team-member:nth-child(even),
    .landing-signature .pricing .pricing-card:nth-child(even) {
        transform: none;
    }
}

/* ==========================================================================
   Modern Private Kindergarten Overrides
   ========================================================================== */

.landing-signature {
    --fun-primary: #ff6f61;
    --fun-secondary: #12b3a8;
    --fun-ink: #2a2b4a;
    --fun-muted: #646781;
    --fun-surface: #ffffff;
    --fun-surface-soft: #f7f9ff;
    --fun-stroke: #e6e9f6;
}

.landing-signature .section {
    padding: clamp(72px, 10vw, 120px) 0;
}

.landing-signature .section--fun .container--fun {
    max-width: 1220px;
}

.landing-signature .section__header--fun .section__subtitle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid var(--fun-stroke);
    background: #fff;
    border-radius: 999px;
    padding: 0.35rem 0.85rem;
    font-size: 0.75rem;
}

.landing-signature .section__header--fun .section__title {
    color: var(--fun-ink);
    font-size: clamp(1.8rem, 3.6vw, 3.2rem);
    line-height: 1.1;
}

.landing-signature .section__header--fun .section__description {
    color: var(--fun-muted);
    font-size: 1.05rem;
}


.landing-signature .section--fun-program .container--fun,
.landing-signature .section--fun-pricing .container--fun {
    display: grid;
    grid-template-columns: minmax(0, 330px) minmax(0, 1fr);
    gap: clamp(18px, 3.2vw, 34px);
    align-items: start;
}
.landing-signature .section--fun-pricing .container--fun {
    display: grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap: clamp(18px, 3.2vw, 34px);
    align-items: start;
}



.landing-signature .section--fun-program .section__header--fun,
.landing-signature .section--fun-pricing .section__header--fun,
.landing-signature .section--fun-registration .section__header--fun {
    position: sticky;
    top: 96px;
    margin: 0;
    text-align: left;
}

.landing-signature .section--fun-facility .container--fun,
.landing-signature .section--fun-teacher .container--fun,
.landing-signature .section--fun-menu .container--fun,
.landing-signature .section--fun-process .container--fun,
.landing-signature .section--fun-testimonial .container--fun,
.landing-signature .section--fun-faq .container--fun,
.landing-signature .section--fun-gallery .container--fun,
.landing-signature .section--fun-video .container--fun {
    display: block;
}

.landing-signature .section--fun-facility .section__header--fun,
.landing-signature .section--fun-teacher .section__header--fun,
.landing-signature .section--fun-menu .section__header--fun,
.landing-signature .section--fun-process .section__header--fun,
.landing-signature .section--fun-testimonial .section__header--fun,
.landing-signature .section--fun-faq .section__header--fun,
.landing-signature .section--fun-gallery .section__header--fun,
.landing-signature .section--fun-video .section__header--fun {
    position: static;
    text-align: center;
    margin: 0 auto clamp(1.4rem, 3vw, 2.25rem);
}

.landing-signature .section--fun-slides .container--fun {
    display: block;
    max-width: none;
    padding: 0;
}

.landing-signature .section--fun-slides .section__header--fun {
    position: static;
    text-align: center;
    max-width: 860px;
    margin: 0 auto 1.5rem;
    padding: 0 var(--spacing-md);
}

.landing-signature .hero--fun {
    grid-template-columns: minmax(0, 0.7fr) minmax(0, 0.88fr);
    gap: clamp(16px, 3vw, 30px);
}

.landing-signature .hero__image--fun img {
    border-radius: 28px;
    box-shadow: 0 24px 44px rgba(40, 32, 90, 0.16);
    transform: none;
}

.landing-signature .hero__content--fun {
    border-radius: 28px;
    border: 1px solid var(--fun-stroke);
    padding: clamp(1.1rem, 2.8vw, 2rem);
    background: linear-gradient(160deg, #fff 0%, #f8fbff 100%);
}

.landing-signature .hero__slogan--fun {
    font-size: 1.03rem;
    color: var(--fun-muted);
    margin-bottom: 1rem;
}

.landing-signature .features--fun {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.landing-signature .features--fun .feature-card {
    border: 1px solid var(--fun-stroke);
    border-radius: 22px;
    transform: none;
}

.landing-signature .programs--fun {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.landing-signature .section--fun-program .section__header--fun {
    grid-column: 1;
    grid-row: 1 / span 2;
}

.landing-signature .section--fun-program .fun-note--philosophy {
    grid-column: 2;
    margin-top: 0;
}

.landing-signature .section--fun-program .programs--fun {
    grid-column: 2;
}

.landing-signature .programs--fun .program-card {
    grid-column: auto !important;
    border: 1px solid var(--fun-stroke);
    border-radius: 24px;
    transform: none;
    box-shadow: 0 12px 28px rgba(34, 38, 86, 0.08);
}

.landing-signature .section--fun-program .program-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 30px rgba(34, 38, 86, 0.12);
}

.landing-signature .section--fun-program .program-card__image {
    aspect-ratio: 16 / 10;
    object-fit: cover;
}

.landing-signature .section--fun-program .program-card__content {
    padding: 1.1rem 1.2rem 1.25rem;
}

.landing-signature .section--fun-program .program-card__title {
    font-size: 1.25rem;
    margin-bottom: 0.4rem;
}

.landing-signature .section--fun-program .program-card__description {
    margin-bottom: 0.8rem;
    min-height: 72px;
}

/* ==========================================================================
   Conversion Polish 2026
   ========================================================================== */

body.page-template-page-landing-signature {
    background:
        radial-gradient(circle at 0% 0%, rgba(255, 111, 97, 0.08), transparent 36%),
        radial-gradient(circle at 100% 0%, rgba(18, 179, 168, 0.08), transparent 35%),
        #f6f8ff;
}

.landing-signature .section {
    padding: clamp(84px, 11vw, 132px) 0;
}

.landing-signature .section--fun-hero {
    padding-top: clamp(96px, 12vw, 148px);
}

.landing-signature .hero__content--fun {
    position: relative;
    overflow: hidden;
}

.landing-signature .hero__content--fun::after {
    content: "";
    position: absolute;
    inset: auto -18% -42% auto;
    width: 210px;
    height: 210px;
    background: radial-gradient(circle, rgba(255, 111, 97, 0.16), transparent 70%);
    pointer-events: none;
}

.landing-signature .hero__title {
    color: var(--fun-ink);
    background: none;
    -webkit-text-fill-color: currentColor;
    font-size: clamp(2.15rem, 4.8vw, 4.2rem);
    letter-spacing: -0.03em;
    line-height: 1.05;
}

.landing-signature .hero__description {
    font-size: clamp(1rem, 1.6vw, 1.18rem);
    color: var(--fun-muted);
    max-width: 52ch;
}

.landing-signature .hero__cta-group .btn {
    min-height: 54px;
    padding-inline: 1.5rem;
}

.landing-signature .hero__cta-group .btn--primary {
    box-shadow: 0 16px 28px rgba(255, 111, 97, 0.24);
}

.landing-signature .hero__cta-group .btn--primary:hover {
    box-shadow: 0 20px 34px rgba(255, 111, 97, 0.28);
}

.landing-signature .hero__image--fun img,
.landing-signature .hero__content--fun,
.landing-signature .hero__floating-badge {
    animation: funHeroEnter 720ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.landing-signature .hero__image--fun img {
    animation-delay: 90ms;
}

.landing-signature .hero__content--fun {
    animation-delay: 180ms;
}

.landing-signature .hero__floating-badge--right {
    animation-delay: 260ms;
}

.landing-signature .hero__floating-badge--left {
    animation-delay: 320ms;
}

.landing-signature .btn,
.landing-signature .feature-card,
.landing-signature .program-card,
.landing-signature .team-member,
.landing-signature .pricing-card,
.landing-signature .testimonial,
.landing-signature .menu-card,
.landing-signature .faq-item,
.landing-signature .photo-gallery__item,
.landing-signature .video-gallery__item {
    transition: transform 0.4s ease-in-out, box-shadow 0.4s ease-in-out, border-color 0.4s ease-in-out;
}

.landing-signature .btn:hover,
.landing-signature .feature-card:hover,
.landing-signature .program-card:hover,
.landing-signature .team-member:hover,
.landing-signature .pricing-card:hover,
.landing-signature .testimonial:hover,
.landing-signature .menu-card:hover,
.landing-signature .faq-item:hover {
    transform: translateY(-6px);
}

.landing-signature .program-card__image,
.landing-signature .gallery__item img,
.landing-signature .photo-gallery__item img,
.landing-signature .video-thumbnail {
    transition: transform 0.4s ease-in-out, filter 0.4s ease-in-out;
}

.landing-signature .program-card:hover .program-card__image,
.landing-signature .gallery__item:hover img,
.landing-signature .photo-gallery__item:hover img,
.landing-signature .video-gallery__item:hover .video-thumbnail {
    transform: scale(1.03);
}

.landing-signature .section--fun-cta .cta-banner--fun {
    padding: clamp(2rem, 4vw, 3rem);
    border: 1px solid rgba(255, 255, 255, 0.28);
    box-shadow: 0 28px 50px rgba(28, 32, 72, 0.2);
}

.landing-signature .section--fun-cta .cta-banner__title {
    font-size: clamp(1.75rem, 3.4vw, 2.75rem);
    line-height: 1.15;
}

.landing-signature .section--fun-registration .contact-form--fun {
    backdrop-filter: blur(6px);
    box-shadow: 0 20px 40px rgba(25, 32, 78, 0.08);
}

.landing-signature .reveal-up {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.45s ease-in-out, transform 0.45s ease-in-out;
}

.landing-signature .reveal-up.is-visible {
    opacity: 1;
    transform: translateY(0);
    text-align: center;
}

.fun-sticky-cta {
    position: fixed;
    left: 50%;display: none !important;
    bottom: 14px;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(226, 231, 248, 0.92);
    box-shadow: 0 14px 28px rgba(26, 32, 82, 0.14);
    z-index: 1200;
    transition: opacity 0.35s ease-in-out, transform 0.35s ease-in-out;
    will-change: opacity, transform;
}

.fun-sticky-cta__primary,
.fun-sticky-cta__secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 1rem;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 700;
    white-space: nowrap;
    transition: transform 0.4s ease-in-out, filter 0.4s ease-in-out;
}

.fun-sticky-cta__primary {
    background: linear-gradient(135deg, var(--fun-primary), #ff8a4c);
    color: #fff;
}

.fun-sticky-cta__secondary {
    background: #eef9f8;
    color: #118d84;
}

.fun-sticky-cta__primary:hover,
.fun-sticky-cta__secondary:hover {
    transform: translateY(-3px);
    filter: saturate(1.05);
}

@keyframes funHeroEnter {
    from {
        opacity: 0;
        transform: translateY(18px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.landing-signature .fun-note {
    margin-top: 1.6rem;
    padding: 1.15rem 1.2rem;
    border-radius: 18px;
    border: 1px solid var(--fun-stroke);
    background: var(--fun-surface-soft);
}

.landing-signature .fun-note__title {
    margin-bottom: 0.75rem;
    color: var(--fun-primary);
    font-size: 1.1rem;
}

.landing-signature .fun-note__content,
.landing-signature .fun-note--policy {
    color: var(--fun-muted);
    line-height: 1.75;
}

.landing-signature .gallery--fun,
.landing-signature .team--fun,
.landing-signature .pricing--fun,
.landing-signature .testimonials--fun,
.landing-signature .video-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}
.landing-signature .gallery--fun,
.landing-signature .team--fun,
.landing-signature .pricing--fun,
.landing-signature .testimonials--fun,
.landing-signature .video-gallery {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}
.landing-signature .pricing--fun
 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 16px;
}
.landing-signature .gallery--fun .gallery__item,
.landing-signature .team--fun .team-member,
.landing-signature .pricing--fun .pricing-card,
.landing-signature .testimonials--fun .testimonial,
.landing-signature .video-gallery .video-gallery__item {
    grid-column: auto !important;
    transform: none !important;
}

.landing-signature .team--fun .team-member {
    text-align: left;
    
    grid-template-columns: 84px 1fr;
    gap: 0.85rem;
    align-items: center;
}

.landing-signature .team--fun .team-member__avatar {
    margin: 0;
    width: 84px;
    height: 84px;
}

.landing-signature .section--fun-schedule .schedule {
    border: 1px solid var(--fun-stroke);
    border-radius: 22px;
    overflow: hidden;
    box-shadow: none;
}

.landing-signature .section--fun-schedule .schedule__table th {
    background: #f3f6ff;
    color: var(--fun-ink);
}

.landing-signature .menu-grid--fun {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.landing-signature .menu-grid--fun .menu-card {
    border: 1px solid var(--fun-stroke);
    border-radius: 20px;
}

.landing-signature .pricing-card__cta {
    width: 100%;
}

.landing-signature .process--fun {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.landing-signature .process--fun .process-step {
    grid-column: auto !important;
    border-style: solid;
    border-color: var(--fun-stroke);
}

.landing-signature .faq--fun {
    grid-template-columns: 1fr;
}

.landing-signature .faq--fun .faq-item {
    border: 1px solid var(--fun-stroke);
    border-radius: 16px;
}

.landing-signature .section--fun-registration .container--fun {
    display: grid;
    grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
    gap: 20px;
    align-items: start;
}

.landing-signature .section--fun-registration .section__header--fun {
    position: sticky;
    top: 96px;
    margin: 0;
    text-align: left;
}

.landing-signature .contact-form--fun {
    border: 1px solid var(--fun-stroke);
    border-radius: 24px;
    background: #fff;
    padding: 1.25rem;
}

.landing-signature .form-consent-label {
    font-weight: 400;
    margin-bottom: 0;
}

.landing-signature .form-commitment {
    margin-top: 1.25rem;
    text-align: center;
    color: var(--fun-muted);
    font-size: 0.88rem;
}

.landing-signature .cta-banner__primary {
    background: #fff;
    color: var(--fun-primary);
}

.landing-signature .section--fun-slides .slides-section--fun {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    border-radius: 0;
    box-shadow: none;
}

.landing-signature .section--fun-slides .slides-section__track,
.landing-signature .section--fun-slides .slides-section__item,
.landing-signature .section--fun-slides .slides-section__image {
    min-height: min(780px, 88vh);
}

.landing-signature .section--fun-slides .slides-section__content {
    width: min(90%, 980px);
}

.landing-signature .section--fun-slides .slides-section__title {
    font-size: clamp(2rem, 5vw, 4rem);
    background: rgba(47, 42, 69, 0.48);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 14px;
}

.landing-signature .section--fun-slides .slides-section__description {
    font-size: clamp(1rem, 1.7vw, 1.2rem);
    max-width: 62ch;
}

.landing-signature .section--fun-gallery .photo-gallery,
.landing-signature .section--fun-video .video-gallery {
    margin: 0;
}

@media (max-width: 991px) {
    .landing-signature .section--fun-why .container--fun,
    .landing-signature .section--fun-program .container--fun,
    .landing-signature .section--fun-pricing .container--fun,
    .landing-signature .section--fun-registration .container--fun {
        grid-template-columns: 1fr;
    }

    .landing-signature .section--fun-why .section__header--fun,
    .landing-signature .section--fun-program .section__header--fun,
    .landing-signature .section--fun-pricing .section__header--fun,
    .landing-signature .section--fun-registration .section__header--fun {
        position: static;
        text-align: center;
    }

    .landing-signature .hero--fun,
    .landing-signature .features--fun,
    .landing-signature .programs--fun,
    .landing-signature .gallery--fun,
    .landing-signature .team--fun,
    .landing-signature .pricing--fun,
    .landing-signature .testimonials--fun,
    .landing-signature .video-gallery,
    .landing-signature .menu-grid--fun,
    .landing-signature .process--fun {
        grid-template-columns: 1fr;
    }

    .landing-signature .team--fun .team-member {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .landing-signature .team--fun .team-member__avatar {
        margin: 0 auto;
    }

    .landing-signature .section--fun-slides .container--fun {
        padding: 0 var(--spacing-md);
    }

    .landing-signature .section--fun-slides .slides-section--fun {
        width: 100%;
        margin-left: 0;
        margin-right: 0;
        border-radius: 20px;
    }

    .landing-signature .section--fun-slides .slides-section__track,
    .landing-signature .section--fun-slides .slides-section__item,
    .landing-signature .section--fun-slides .slides-section__image {
        min-height: 72vh;
    }

    .landing-signature .section--fun-program .section__header--fun,
    .landing-signature .section--fun-program .fun-note--philosophy,
    .landing-signature .section--fun-program .programs--fun {
        grid-column: auto;
        grid-row: auto;
    }

    .landing-signature .section--fun-program .program-card__description {
        min-height: 0;
    }
 
    .landing-signature .hero__title {
        font-size: clamp(1.9rem, 8vw, 3rem);
    }

    .fun-sticky-cta {
        width: calc(100% - 20px);
        bottom: 10px;
        padding: 8px;
        border-radius: 18px;
        justify-content: center;
    }

    .fun-sticky-cta__primary,
    .fun-sticky-cta__secondary {
        flex: 1;
        min-width: 0;
        font-size: 0.9rem;
        padding: 0 0.7rem;
    }
}

/* ==========================================================================
   Signature Layout System (Diverse Sections)
   ========================================================================== */

.landing-signature {
    --sig-primary: #ff7b54;
    --sig-secondary: #11b4a3;
    --sig-ink: #232540;
    --sig-muted: #60647e;
    --sig-line: #e4e9f6;
    --sig-soft: #f5f8ff;
}

.landing-signature .section {
    padding: clamp(84px, 11vw, 132px) 0;
}

.landing-signature .section__header--signature .section__title {
    color: var(--sig-ink);
    letter-spacing: -0.02em;
}

.landing-signature .section__header--signature .section__description {
    color: var(--sig-muted);
}

.landing-signature .hero--signature {
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
    gap: clamp(18px, 3vw, 32px);
}

.landing-signature .section--signature-hero {
    position: relative;
    padding-top: clamp(104px, 12vw, 156px);
    overflow: clip;
}

.landing-signature .section--signature-hero::before {
    content: "";
    position: absolute;
    width: 460px;
    height: 460px;
    right: -120px;
    top: -140px;
    background: radial-gradient(circle, rgba(255, 123, 84, 0.18), rgba(255, 123, 84, 0) 68%);
    pointer-events: none;
}

.landing-signature .section--signature-hero::after {
    content: "";
    position: absolute;
    width: 420px;
    height: 420px;
    left: -120px;
    bottom: -180px;
    background: radial-gradient(circle, rgba(17, 180, 163, 0.14), rgba(17, 180, 163, 0) 70%);
    pointer-events: none;
}

.landing-signature .section--signature-hero .hero__content--signature {
    position: relative;
    z-index: 2;
    border: 1px solid rgba(228, 233, 246, 0.95);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.97), rgba(247, 250, 255, 0.95));
    box-shadow: 0 18px 40px rgba(26, 34, 82, 0.08);
}

.landing-signature .section--signature-hero .hero__title {
    font-size: clamp(2.3rem, 5.1vw, 4.5rem);
    line-height: 1.02;
    letter-spacing: -0.035em;
    color: var(--sig-ink);
    text-wrap: balance;
}

.landing-signature .section--signature-hero .hero__description {
    font-size: clamp(1rem, 1.6vw, 1.18rem);
    line-height: 1.75;
    color: var(--sig-muted);
    max-width: 54ch;
}

.landing-signature .section--signature-hero .hero__cta-group {
    gap: 0.8rem;
}

.landing-signature .section--signature-hero .hero__cta-group .btn {
    min-height: 54px;
    padding-inline: 1.35rem;
    border-radius: 14px;
    position: relative;
    overflow: hidden;
    isolation: isolate;
}

.landing-signature .section--signature-hero .hero__cta-group .btn::after {
    content: "";
    position: absolute;
    inset: 0 auto 0 -160%;
    width: 150%;
    transform: skewX(-20deg);
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.42), transparent);
    transition: left 0.55s ease-in-out;
    z-index: -1;
}

.landing-signature .section--signature-hero .hero__cta-group .btn:hover::after {
    left: 120%;
}

.landing-signature .section--signature-hero .hero__cta-group .btn--primary {
    box-shadow: 0 16px 32px rgba(255, 123, 84, 0.26);
}

.landing-signature .section--signature-hero .hero__cta-group .btn--primary:hover {
    transform: translateY(-4px) scale(1.01);
    box-shadow: 0 22px 36px rgba(255, 123, 84, 0.3);
}

.landing-signature .section--signature-hero .hero__cta-group .btn--outline:hover {
    transform: translateY(-4px);
}

.landing-signature .section--signature-hero .hero__image--signature {
    position: relative;
    z-index: 2;
}

.landing-signature .section--signature-hero .hero__image--signature img {
    border-radius: 30px;
    transform: none;
    box-shadow: 0 28px 48px rgba(26, 33, 80, 0.16);
    transition: transform 0.55s ease-in-out, box-shadow 0.55s ease-in-out;
}

.landing-signature .section--signature-hero .hero__image--signature:hover img {
    transform: scale(1.02) translateY(-2px);
    box-shadow: 0 32px 58px rgba(26, 33, 80, 0.2);
}

.landing-signature .section--signature-hero .hero__floating-badge {
    animation: signatureFloat 4s ease-in-out infinite;
}

.landing-signature .section--signature-hero .hero__floating-badge--right {
    animation-delay: 0.5s;
}

.landing-signature .section--signature-hero .hero__school-name,
.landing-signature .section--signature-hero .hero__slogan--signature,
.landing-signature .section--signature-hero .hero__title,
.landing-signature .section--signature-hero .hero__description,
.landing-signature .section--signature-hero .hero__cta-group,
.landing-signature .section--signature-hero .hero__hotline {
    opacity: 0;
    animation: signatureRiseIn 640ms cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.landing-signature .section--signature-hero .hero__school-name { animation-delay: 90ms; }
.landing-signature .section--signature-hero .hero__slogan--signature { animation-delay: 160ms; }
.landing-signature .section--signature-hero .hero__title { animation-delay: 230ms; }
.landing-signature .section--signature-hero .hero__description { animation-delay: 320ms; }
.landing-signature .section--signature-hero .hero__cta-group { animation-delay: 420ms; }
.landing-signature .section--signature-hero .hero__hotline { animation-delay: 500ms; }

@keyframes signatureRiseIn {
    from {
        opacity: 0;
        transform: translateY(16px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes signatureFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}

.landing-signature .section--signature-why .container--signature,
.landing-signature .section--signature-pricing .container--signature,
.landing-signature .section--signature-registration .container--signature {
    display: grid;
    grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
    gap: clamp(20px, 3vw, 36px);
    align-items: start;
}
 
.landing-signature .section--signature-pricing .container--signature
 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(20px, 3vw, 36px);
    align-items: start;
}

.landing-signature .section--signature-why .section__header--signature,
.landing-signature .section--signature-pricing .section__header--signature,
.landing-signature .section--signature-registration .section__header--signature {
    position: sticky;
    top: 94px;
    text-align: left;
    margin: 0;
}

.landing-signature .section--signature-program .container--signature,
.landing-signature .section--signature-facility .container--signature,
.landing-signature .section--signature-teacher .container--signature,
.landing-signature .section--signature-schedule .container--signature,
.landing-signature .section--signature-menu .container--signature,
.landing-signature .section--signature-process .container--signature,
.landing-signature .section--signature-testimonial .container--signature,
.landing-signature .section--signature-faq .container--signature,
.landing-signature .section--signature-gallery .container--signature,
.landing-signature .section--signature-video .container--signature {
    display: block;
}

.landing-signature .section--signature-program .section__header--signature,
.landing-signature .section--signature-facility .section__header--signature,
.landing-signature .section--signature-teacher .section__header--signature,
.landing-signature .section--signature-schedule .section__header--signature,
.landing-signature .section--signature-menu .section__header--signature,
.landing-signature .section--signature-process .section__header--signature,
.landing-signature .section--signature-testimonial .section__header--signature,
.landing-signature .section--signature-faq .section__header--signature,
.landing-signature .section--signature-gallery .section__header--signature,
.landing-signature .section--signature-video .section__header--signature {
    max-width: 860px;
    margin: 0 auto clamp(1.5rem, 3vw, 2.4rem);
    text-align: center;
}

.landing-signature .section--signature-program .programs--signature {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.landing-signature .section--signature-program .fun-note--philosophy {
    max-width: 860px;
    margin: 0 auto 1.2rem;
}

.landing-signature .section--signature-facility .gallery--signature {
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 14px;
}

.landing-signature .section--signature-facility .gallery__item {
    grid-column: span 3;
}

.landing-signature .section--signature-facility .gallery__item:nth-child(5n + 1) {
    grid-column: span 6;
}

.landing-signature .section--signature-teacher .team--signature {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.landing-signature .section--signature-teacher .team-member:first-child {
    /* grid-column: span 2; */
    /* display: grid; */
    grid-template-columns: 112px 1fr;
    text-align: left;
    align-items: center;
    gap: 1rem;
}

.landing-signature .section--signature-teacher .team-member:first-child .team-member__avatar {
    margin: 0;
}

.landing-signature .section--signature-menu .menu-grid--signature {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.landing-signature .section--signature-pricing .pricing--signature {
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 16px;
}

.landing-signature .section--signature-process .process--signature {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.landing-signature .section--signature-process .process-step {
    border: 1px solid var(--sig-line);
    border-radius: 20px;
    background: #fff;
}

.landing-signature .section--signature-testimonial .testimonials--signature {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.landing-signature .section--signature-testimonial .testimonial:nth-child(3n + 1) {
    grid-column: span 2;
}

.landing-signature .section--signature-faq .faq--signature {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    max-width: none;
}

.landing-signature .section--signature-gallery .photo-gallery {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 12px;
}

.landing-signature .section--signature-gallery .photo-gallery__item {
    grid-column: span 3;
}

.landing-signature .section--signature-gallery .photo-gallery__item:nth-child(6n + 1),
.landing-signature .section--signature-gallery .photo-gallery__item:nth-child(6n + 6) {
    grid-column: span 6;
}

.landing-signature .section--signature-video .video-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.landing-signature .section--signature-video .video-gallery__item:first-child {
    grid-column: span 2;
}

.landing-signature .section--signature-slides .container--signature {
    display: block;
    max-width: none;
    padding: 0;
}

.landing-signature .section--signature-slides .section__header--signature {
    text-align: center;
    position: static;
    max-width: 860px;
    margin: 0 auto 1.2rem;
    padding: 0 var(--spacing-md);
}

.landing-signature .section--signature-slides .slides-section--signature {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    border-radius: 0;
}

.landing-signature .section--signature-slides .slides-section__track,
.landing-signature .section--signature-slides .slides-section__item,
.landing-signature .section--signature-slides .slides-section__image {
    min-height: min(780px, 88vh);
}

.landing-signature .section--signature-registration .contact-form--signature {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem 1.1rem;
}

.landing-signature .section--signature-registration .contact-form--signature .form-group:nth-last-child(-n + 3),
.landing-signature .section--signature-registration .contact-form--signature .form-submit {
    grid-column: 1 / -1;
}

.landing-signature .btn,
.landing-signature .feature-card,
.landing-signature .program-card,
.landing-signature .team-member,
.landing-signature .menu-card,
.landing-signature .pricing-card,
.landing-signature .process-step,
.landing-signature .testimonial,
.landing-signature .faq-item {
    transition: transform 0.4s ease-in-out, box-shadow 0.4s ease-in-out, border-color 0.4s ease-in-out;
}

.landing-signature .feature-card:hover,
.landing-signature .program-card:hover,
.landing-signature .team-member:hover,
.landing-signature .menu-card:hover,
.landing-signature .pricing-card:hover,
.landing-signature .process-step:hover,
.landing-signature .testimonial:hover,
.landing-signature .faq-item:hover {
    transform: translateY(-6px);
}

.landing-signature .program-card__image,
.landing-signature .gallery__item img,
.landing-signature .photo-gallery__item img,
.landing-signature .video-thumbnail {
    transition: transform 0.4s ease-in-out;
}

.landing-signature .program-card:hover .program-card__image,
.landing-signature .gallery__item:hover img,
.landing-signature .photo-gallery__item:hover img,
.landing-signature .video-gallery__item:hover .video-thumbnail {
    transform: scale(1.03);
}

.landing-signature .reveal-up {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 0.45s ease-in-out, transform 0.45s ease-in-out;
}

.landing-signature .reveal-up.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.signature-sticky-cta {
    position: fixed;
    left: 50%;
    bottom: 14px;
    transform: translateX(-50%);
    z-index: 1200;
    display: flex;
    gap: 10px;
    padding: 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid var(--sig-line);
    box-shadow: 0 14px 30px rgba(27, 31, 77, 0.16);
    transition: opacity 0.35s ease-in-out, transform 0.35s ease-in-out;
}

.signature-sticky-cta__primary,
.signature-sticky-cta__secondary {
    min-height: 44px;
    padding: 0 1rem;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.signature-sticky-cta__primary {
    background: linear-gradient(135deg, var(--sig-primary), #ff9861);
    color: #fff;
}

.signature-sticky-cta__secondary {
    background: #ecf8f6;
    color: #0f867d;
}

@media (max-width: 1023px) {
    .landing-signature .hero--signature,
    .landing-signature .section--signature-why .container--signature,
    .landing-signature .section--signature-pricing .container--signature,
    .landing-signature .section--signature-registration .container--signature,
    .landing-signature .section--signature-program .programs--signature,
    .landing-signature .section--signature-menu .menu-grid--signature,
    .landing-signature .section--signature-pricing .pricing--signature,
    .landing-signature .section--signature-process .process--signature,
    .landing-signature .section--signature-testimonial .testimonials--signature,
    .landing-signature .section--signature-faq .faq--signature,
    .landing-signature .section--signature-video .video-gallery,
    .landing-signature .section--signature-registration .contact-form--signature {
        grid-template-columns: 1fr;
    }

    .landing-signature .section--signature-hero {
        padding-top: clamp(96px, 16vw, 132px);
    }

    .landing-signature .section--signature-hero .hero__title {
        font-size: clamp(2rem, 9vw, 3.1rem);
    }

    .landing-signature .section--signature-hero .hero__description {
        max-width: none;
    }

    .landing-signature .section--signature-why .section__header--signature,
    .landing-signature .section--signature-pricing .section__header--signature,
    .landing-signature .section--signature-registration .section__header--signature {
        position: static;
        text-align: center;
    }

    .landing-signature .section--signature-facility .gallery--signature,
    .landing-signature .section--signature-gallery .photo-gallery {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .landing-signature .section--signature-facility .gallery__item,
    .landing-signature .section--signature-facility .gallery__item:nth-child(5n + 1),
    .landing-signature .section--signature-gallery .photo-gallery__item,
    .landing-signature .section--signature-gallery .photo-gallery__item:nth-child(6n + 1),
    .landing-signature .section--signature-gallery .photo-gallery__item:nth-child(6n + 6),
    .landing-signature .section--signature-testimonial .testimonial:nth-child(3n + 1),
    .landing-signature .section--signature-video .video-gallery__item:first-child {
        grid-column: span 1;
    }

    .landing-signature .section--signature-teacher .team--signature {
        grid-template-columns: 1fr;
    }

    .landing-signature .section--signature-teacher .team-member:first-child {
        grid-column: span 1;
        grid-template-columns: 1fr;
        text-align: center;
    }

    .landing-signature .section--signature-teacher .team-member:first-child .team-member__avatar {
        margin: 0 auto var(--spacing-sm);
    }

    .landing-signature .section--signature-slides .container--signature {
        padding: 0 var(--spacing-md);
    }

    .landing-signature .section--signature-slides .slides-section--signature {
        width: 100%;
        margin-left: 0;
        margin-right: 0;
        border-radius: 20px;
    }

    .signature-sticky-cta {
        width: calc(100% - 20px);
        border-radius: 18px;
        justify-content: center;
    }

    .signature-sticky-cta__primary,
    .signature-sticky-cta__secondary {
        flex: 1;
        min-width: 0;
        font-size: 0.9rem;
    }
}
