:root {
    --color-background: #101010;
    --color-surface: #1A1A1A;
    --color-primary: #FFA500;
    --color-primary-dark: #E59400;
    --color-text-primary: #F5F5F5;
    --color-text-secondary: #A0A0A0;
    --color-border: #2A2A2A;
    --color-shadow: rgba(0, 0, 0, 0.5);

    --font-family-base: cursive;
    --font-size-base: 10px;

    --container-width: 1240px;
    --container-padding: 2rem;

    --border-radius-small: 6px;
    --border-radius-medium: 12px;
    --border-radius-large: 20px;

    --transition-speed: 0.3s;
    --transition-speed-fast: 0.2s;
    --transition-easing: ease-in-out;
}


*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: var(--font-size-base); scroll-behavior: smooth; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { font-family: var(--font-family-base); font-size: 1.6rem; line-height: 1.7; background-color: var(--color-background); color: var(--color-text-primary); }
ul { list-style: none; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; height: auto; display: block; }
button { font-family: inherit; border: none; background: none; cursor: pointer; color: inherit; }

.container { max-width: var(--container-width); margin: 0 auto; padding: 0 var(--container-padding); }
.section-title { font-size: 4.2rem; font-weight: 800; text-align: left; line-height: 1.2; margin-bottom: 1.6rem; }
.section-description { font-size: 1.8rem; color: var(--color-text-secondary); max-width: 60ch; text-align: left; margin: 0 auto; margin-bottom: 3rem; }
.button { display: inline-block; padding: 1.4rem 3.2rem; border-radius: var(--border-radius-small); font-weight: 700; font-size: 1.6rem; text-align: center; transition: all var(--transition-speed) var(--transition-easing); border: 2px solid transparent; }
.button--primary { background-color: var(--color-primary); color: var(--color-background); }
.button--primary:hover { background-color: var(--color-primary-dark); transform: translateY(-3px); box-shadow: 0 8px 15px var(--color-shadow); }
.button--outline { border-color: var(--color-border); color: var(--color-text-primary); }
.button--outline:hover { border-color: var(--color-primary); background-color: var(--color-primary); color: var(--color-background); }
.button--large { padding: 1.8rem 4rem; font-size: 1.8rem; }
.main > section { padding: 12rem 0; }

.header { position: fixed; top: 0; left: 0; width: 100%; z-index: 1000; padding: 2rem 0; transition: background-color var(--transition-speed), box-shadow var(--transition-speed), padding var(--transition-speed); }
.header--scrolled { background-color: rgba(26, 26, 26, 0.85); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); padding: 1.5rem 0; box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1); }
.header__container { display: flex; justify-content: space-between; align-items: center; }
.header__logo img { height: 3.5rem; width: auto; color: var(--color-primary); transition: color var(--transition-speed); }
.header__logo:hover img { color: var(--color-text-primary); }
.nav__list { display: flex; gap: 3.2rem; }
.nav__link { font-weight: 600; position: relative; padding-bottom: 0.5rem; }
.nav__link::after { content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 2px; background-color: var(--color-primary); transition: width var(--transition-speed); }
.nav__link:hover::after, .nav__link--active::after { width: 100%; }
.header__burger { display: none; flex-direction: column; gap: 0.5rem; width: 2.5rem; height: 2rem; }
.header__burger-line { width: 100%; height: 3px; background-color: var(--color-text-primary); border-radius: 3px; transition: transform var(--transition-speed), opacity var(--transition-speed); }
.header__burger--active .header__burger-line:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.header__burger--active .header__burger-line:nth-child(2) { opacity: 0; }
.header__burger--active .header__burger-line:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

.hero { padding-top: 15rem; padding-bottom: 10rem; min-height: 100vh; display: flex; align-items: center; background: var(--color-background); position: relative; }
.hero::before { content: ''; position: absolute; top: 0; left: 50%; width: 100%; height: 100%; background: radial-gradient(circle at top right, rgba(255,165,0,0.1), transparent 40%); transform: translateX(-50%); opacity: 0.5;}
.hero__container { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 6rem; position: relative; }
.hero__title { font-size: clamp(4rem, 6vw, 7.2rem); font-weight: 800; line-height: 1.1; }
.hero__subtitle { font-size: 2rem; color: var(--color-text-secondary); margin: 2.4rem 0 3.2rem; max-width: 45ch; }
.hero__actions { display: flex; gap: 1.6rem; align-items: center; }
.hero__visual { position: relative; }
.hero__image { width: 100%; max-width: 45rem; margin: 0 auto; border-radius: var(--border-radius-large); object-fit: cover; aspect-ratio: 4/5; }
.hero__scroll-down { position: absolute; bottom: -8rem; left: 50%; transform: translateX(-50%); width: 2.4rem; height: 4.8rem; border: 2px solid var(--color-border); border-radius: 50px; }
.hero__scroll-down::before { content: ''; position: absolute; top: 1rem; left: 50%; transform: translateX(-50%); width: 4px; height: 8px; background-color: var(--color-primary); border-radius: 2px; animation: scroll-anim 2s infinite; }
@keyframes scroll-anim { 0% { transform: translate(-50%, 0); opacity: 1; } 100% { transform: translate(-50%, 20px); opacity: 0; } }

.features { background-color: var(--color-surface); }
.features__container { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8rem; align-items: center; }
.features__visual { position: relative; }
.features__image-wrapper { border-radius: var(--border-radius-large); overflow: hidden; border: 1px solid var(--color-border); }
.features__image { width: 100%; height: 100%; object-fit: cover; }
.features__title, .features__description { text-align: left; max-width: 100%; margin-left: 0; }
.features__list { display: flex; flex-direction: column; gap: 2.4rem; margin-top: 4rem; }
.features__item { display: flex; align-items: flex-start; gap: 2rem; background-color: var(--color-background); padding: 2rem; border-radius: var(--border-radius-medium); border: 1px solid var(--color-border); transition: transform var(--transition-speed-fast), border-color var(--transition-speed-fast); }
.features__item:hover { transform: translateY(-5px); border-color: var(--color-primary); }
.features__item-icon { color: var(--color-primary); flex-shrink: 0; }
.features__item-title { font-size: 2rem; font-weight: 700; margin-bottom: 0.5rem; }
.features__item-text p { color: var(--color-text-secondary); }

.courses { background-color: var(--color-background); }
.courses__header { text-align: center; max-width: 70ch; margin: 0 auto 6rem; }
.courses__header .section-title, .courses__header .section-description { text-align: center; }
.courses__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 3.2rem; grid-template-areas: "featured featured" "side-1 side-2"; }
.courses__card { background-color: var(--color-surface); border-radius: var(--border-radius-medium); display: flex; flex-direction: column; border: 1px solid var(--color-border); overflow: hidden; transition: box-shadow var(--transition-speed); }
.courses__card:hover { box-shadow: 0 10px 40px var(--color-shadow); }
.courses__card--featured { grid-area: featured; flex-direction: row; }
.courses__card--featured .courses__card-image { width: 55%; aspect-ratio: 16/10; }
.courses__card--featured .courses__card-content { width: 45%; justify-content: center; }
.courses__card[data-aos=fade-left] { grid-area: side-1; }
.courses__card[data-aos=fade-left][data-aos-delay="300"] { grid-area: side-2; }
.courses__card-image { width: 100%; aspect-ratio: 16/10; object-fit: cover; }
.courses__card-content { padding: 3.2rem; display: flex; flex-direction: column; flex-grow: 1; }
.courses__card-label { color: var(--color-primary); font-weight: 700; margin-bottom: 1rem; display: block; }
.courses__card-title { font-size: 2.4rem; font-weight: 700; margin-bottom: 1.2rem; }
.courses__card-text { color: var(--color-text-secondary); margin-bottom: 2.4rem; flex-grow: 1; }
.courses__card--featured .courses__card-title { font-size: 3.2rem; }

.tutors { background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-background) 100%); }
.tutors__container { display: grid; grid-template-columns: 1fr 2fr; align-items: center; gap: 4rem; }
.tutors__content .section-title, .tutors__content .section-description { text-align: left; margin-left: 0; }
.tutors__slider-nav { margin-top: 4rem; display: flex; gap: 1.6rem; }
.tutors__slider-next, .tutors__slider-prev { position: static; width: 5rem; height: 5rem; margin: 0; background-color: var(--color-surface); border-radius: 50%; border: 1px solid var(--color-border); color: var(--color-text-primary); transition: background-color var(--transition-speed), border-color var(--transition-speed); }
.tutors__slider-next:hover, .tutors__slider-prev:hover { background-color: var(--color-primary); border-color: var(--color-primary); color: var(--color-background); }
.tutors__slider-next::after, .tutors__slider-prev::after { font-size: 2rem; }
.swiper-button-disabled { opacity: 0.5; cursor: not-allowed; }
.tutors__slider { width: 100%; height: 55rem; }
.tutors__slide { background-position: center; background-size: cover; width: 35rem; height: 55rem; border-radius: var(--border-radius-large); overflow: hidden; position: relative; }
.tutors__slide-img { width: 100%; height: 180%; object-fit: cover; transition: transform 0.4s var(--transition-easing); }
.tutors__slide:hover .tutors__slide-img { transform: scale(1.05); }
.tutors__slide-info { position: absolute; bottom: 0; left: 0; width: 100%; padding: 4rem 2.4rem 2.4rem; background: linear-gradient(0deg, rgba(16, 16, 16, 1) 0%, rgba(16, 16, 16, 0) 100%); }
.tutors__slide-name { font-size: 2.2rem; font-weight: 700; }
.tutors__slide-specialty { color: var(--color-primary); font-weight: 600; }

.process { background-color: var(--color-background); }
.process__header { text-align: center; max-width: 70ch; margin: 0 auto 8rem; }
.process__header .section-title, .process__header .section-description { text-align: center; }
.process__steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 3.2rem; counter-reset: step-counter; }
.process__step { position: relative; padding: 4rem 3rem; background-color: var(--color-surface); border-radius: var(--border-radius-medium); border: 1px solid var(--color-border); }
.process__step::before { counter-increment: step-counter; content: "0" counter(step-counter); position: absolute; top: -2rem; right: 2rem; font-size: 6rem; font-weight: 800; color: rgba(255, 255, 255, 0.05); line-height: 1; }
.process__step-title { font-size: 2.2rem; font-weight: 700; margin-bottom: 1.6rem; color: var(--color-primary); }
.process__step-text { color: var(--color-text-secondary); }

.faq { background-color: var(--color-surface); }
.faq__container { display: grid; grid-template-columns: 1fr 1.2fr; gap: 8rem; align-items: center; }
.faq__content .section-title, .faq__content .section-description { text-align: left; margin-left: 0; }
.faq__image { border-radius: var(--border-radius-medium); margin-top: 3rem; }
.faq__accordion { display: flex; flex-direction: column; gap: 1.6rem; }
.faq__item { background-color: var(--color-background); border-radius: var(--border-radius-medium); border: 1px solid var(--color-border); }
.faq__question { width: 100%; padding: 2rem; text-align: left; font-size: 1.8rem; font-weight: 600; display: flex; justify-content: space-between; align-items: center; gap: 1.6rem; }
.faq__icon { flex-shrink: 0; transition: transform var(--transition-speed); }
.faq__item.faq__item--active .faq__icon { transform: rotate(180deg); }
.faq__item.faq__item--active .faq__question { color: var(--color-primary); }
.faq__answer { max-height: 0; overflow: hidden; transition: max-height 0.4s ease-out; }
.faq__answer p { padding: 0 2rem 2rem; color: var(--color-text-secondary); }

.cta { padding: 10rem 0; background: var(--color-background); }
.cta__container { background-color: var(--color-surface); border-radius: var(--border-radius-large); padding: 8rem; text-align: center; border: 1px solid var(--color-border); }
.cta__title { font-size: 4rem; font-weight: 800; line-height: 1.2; margin-bottom: 2rem; }
.cta__text { color: var(--color-text-secondary); max-width: 60ch; margin: 0 auto 4rem; font-size: 1.8rem; }

.footer {
    padding: 0;
    background-color: var(--color-background);
    border-top: 1px solid var(--color-border);
    position: relative;
    overflow: hidden;
}

.footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 150%;
    height: 40rem;
    background: radial-gradient(circle, rgba(var(--color-primary-rgb), 0.08), transparent 50%);
    pointer-events: none;
}

.footer__container {
    position: relative;
    z-index: 2;
}

.footer__cta {
    padding: 6rem 4rem;
    margin: 8rem 0;
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-large);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.6rem;
}

.footer__cta-title {
    font-size: 3.2rem;
    font-weight: 700;
}

.footer__cta-text {
    color: var(--color-text-secondary);
    max-width: 45ch;
    margin-bottom: 1.6rem;
}

.footer__main {
    display: grid;
    grid-template-columns: 2fr 3fr 1.5fr;
    gap: 6rem;
    padding-bottom: 8rem;
    padding-top: 8rem;
}

.footer__brand {
    max-width: 32rem;
}

.footer__logo img {
    height: 4rem;
    width: auto;
    color: var(--color-primary);
    margin-bottom: 2rem;
}

.footer__description {
    color: var(--color-text-secondary);
    font-size: 1.5rem;
    line-height: 1.6;
}

.footer__nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
}

.footer__nav-title {
    font-size: 2rem;
    font-weight: 600;
    margin-bottom: 2.4rem;
    color: var(--color-text-primary);
    position: relative;
    padding-bottom: 0.8rem;
}

.footer__nav-title::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 2.4rem;
    height: 2px;
    background-color: var(--color-primary);
}

.footer__list {
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
}

.footer__link {
    color: var(--color-text-secondary);
    transition: color var(--transition-speed-fast), transform var(--transition-speed-fast) var(--transition-easing);
    display: inline-block;
}

.footer__link:hover {
    color: var(--color-primary);
    transform: translateX(5px);
}

.footer__location {
    margin-top: 2.4rem;
    font-size: 1.4rem;
    font-style: italic;
    color: var(--color-text-secondary);
    border-left: 2px solid var(--color-primary);
    padding-left: 1.2rem;
}

.footer__bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 2rem;
    padding: 3rem 0;
    border-top: 1px solid var(--color-border);
}

.footer__copyright {
    color: var(--color-text-secondary);
    font-size: 1.4rem;
}

.footer__legal {
    display: flex;
    gap: 2.4rem;
}

.footer__link--small {
    font-size: 1.4rem;
}

.footer__link--small:hover {
    transform: none;
    text-decoration: underline;
    text-decoration-color: var(--color-primary);
}

@media (max-width: 1024px) {
    .main > section { padding: 10rem 0; }
    .hero__container { grid-template-columns: 1fr; text-align: center; }
    .hero__content { order: 2; }
    .hero__visual { order: 1; margin-bottom: 4rem; }
    .hero__image { max-width: 35rem; }
    .hero__actions { justify-content: center; }
    .hero__scroll-down { display: none; }
    .section-title, .section-description { text-align: center; max-width: 70ch; margin-left: auto; margin-right: auto; }
    .features__container { grid-template-columns: 1fr; }
    .features__visual { max-width: 50rem; margin: 0 auto 4rem; }
    .courses__grid { grid-template-columns: 1fr; grid-template-areas: "featured" "side-1" "side-2"; }
    .courses__card--featured { flex-direction: column; }
    .courses__card--featured .courses__card-image, .courses__card--featured .courses__card-content { width: 100%; }
    .tutors__container { grid-template-columns: 1fr; }
    .tutors__content { text-align: center; }
    .tutors__slider-nav { justify-content: center; }
    .faq__container { grid-template-columns: 1fr; }
    .faq__content { text-align: center; }
    .faq__image { max-width: 100%; margin: 3rem auto 0; }
    .footer__main {
        grid-template-columns: 1fr;
        text-align: center;
    }
    .footer__brand {
        margin: 0 auto;
    }
    .footer__logo {
        margin: 0 auto 2rem;
    }
    .footer__nav {
        grid-template-columns: 1fr 1fr;
    }
    .footer__nav-title::after {
        left: 50%;
        transform: translateX(-50%);
    }
    .footer__link:hover {
        transform: none;
    }
    .footer__location {
        margin: 2.4rem auto 0;
    }
    .footer__contact {
        margin-top: 2rem;
    }
}

@media (max-width: 768px) {
    html { font-size: 9.375px; }
    .header__nav {padding-top: 30px;position: fixed; top: 0; left: -100%; width: 80%; max-width: 32rem; height: 100vh; background-color: var(--color-surface); flex-direction: column; justify-content: center; align-items: center; transition: left var(--transition-speed) ease-in-out; z-index: 998; }
    .header__nav.header__nav--active { left: 0; }
    .nav__list { flex-direction: column; align-items: center; gap: 4rem; }
    .nav__link { font-size: 2.4rem; }
    .header__cta { display: none; }
    .header__burger { display: flex; z-index: 999; }
    .process__steps { grid-template-columns: 1fr 1fr; }
    .cta__container { padding: 6rem 4rem; }
    .footer__bottom {
        flex-direction: column;
    }
}

@media (max-width: 480px) {
    .main > section { padding: 8rem 0; }
    .hero__actions { flex-direction: column; align-items: center; }
    .button { width: 100%; max-width: 30rem; }
    .process__steps { grid-template-columns: 1fr; }
    .footer__nav {
        grid-template-columns: 1fr;
    }
}

.about-hero {
    padding: 15rem 0;
    background-color: var(--color-background);
    overflow: hidden;
}
.about-hero__container {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    align-items: center;
    gap: 6rem;
}
.about-hero__tagline {
    color: var(--color-primary);
    font-weight: 700;
    margin-bottom: 1.6rem;
    letter-spacing: 1px;
}
.about-hero__title {
    font-size: clamp(4rem, 6vw, 7rem);
    font-weight: 800;
    line-height: 1.1;
}
.about-hero__line {
    display: block;
    width: 8rem;
    height: 3px;
    background-color: var(--color-primary);
    margin-top: 3.2rem;
    transform: scaleX(0);
    transform-origin: left;
    animation: scale-line 1s cubic-bezier(0.2, 1, 0.2, 1) 0.5s forwards;
}
@keyframes scale-line { to { transform: scaleX(1); } }
.about-hero__visual {
    border-radius: var(--border-radius-large);
    overflow: hidden;
}
.about-hero__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 3/4;
}

.manifesto {
    padding: 12rem 0;
    background-color: var(--color-surface);
}
.manifesto__container {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 2.4rem;
    align-items: center;
    border: 1px solid var(--color-border);
    padding: 6rem;
    border-radius: var(--border-radius-large);
}
.manifesto__title {
    grid-column: 1 / 8;
    font-size: clamp(2.8rem, 4vw, 4rem);
    font-weight: 700;
    line-height: 1.3;
}
.manifesto__content {
    grid-column: 1 / 7;
    grid-row: 2;
    color: var(--color-text-secondary);
}
.manifesto__visual {
    grid-column: 7 / 13;
    grid-row: 1 / 3;
    border-radius: var(--border-radius-medium);
    overflow: hidden;
}

.pillars {
    padding: 15rem 0;
}
.pillars__container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8rem;
}
.pillars__sticky-visual {
    position: sticky;
    top: 15rem;
    height: calc(100vh - 20rem);
}
.pillars__title {
    margin-bottom: 3.2rem;
}
.pillars__image-container {
    width: 100%;
    height: 70%;
    border-radius: var(--border-radius-large);
    overflow: hidden;
}
.pillars__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity 0.5s ease-in-out;
}
.pillars__card {
    padding: 4rem 0;
    margin-bottom: 8rem;
    border-bottom: 1px solid var(--color-border);
}
.pillars__card:last-child {
    border-bottom: none;
}
.pillars__card-number {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: 1.6rem;
}
.pillars__card-title {
    font-size: 3.2rem;
    font-weight: 700;
    margin-bottom: 1.6rem;
}
.pillars__card-text {
    color: var(--color-text-secondary);
    max-width: 50ch;
}

.team {
    padding: 12rem 0;
    background-color: var(--color-surface);
}
.team__title, .team__description { text-align: center; }
.team__description { margin-bottom: 8rem; }
.team__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 3.2rem;
}
.team__card {
    position: relative;
    border-radius: var(--border-radius-medium);
    overflow: hidden;
    aspect-ratio: 5/7;
}
.team__card-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s var(--transition-easing), filter 0.4s var(--transition-easing);
}
.team__card-info {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 4rem 2.4rem 2.4rem;
    background: linear-gradient(0deg, rgba(16, 16, 16, 0.9) 0%, transparent 100%);
    transform: translateY(30%);
    opacity: 0;
    transition: transform 0.4s var(--transition-easing), opacity 0.4s var(--transition-easing);
}
.team__card:hover .team__card-info {
    transform: translateY(0);
    opacity: 1;
}
.team__card:hover .team__card-image {
    transform: scale(1.05);
    filter: brightness(0.8);
}
.team__card-name {
    font-size: 2.4rem;
    font-weight: 700;
}
.team__card-role {
    color: var(--color-primary);
}

.founder-statement {
    padding: 15rem 0;
    background: var(--color-background);
    text-align: center;
}
.founder-statement__quote {
    font-size: clamp(3rem, 5vw, 5rem);
    font-weight: 700;
    line-height: 1.4;
    max-width: 25ch;
    margin: 0 auto;
    font-style: italic;
}
.founder-statement__cite {
    display: block;
    margin-top: 3.2rem;
    color: var(--color-primary);
    font-style: normal;
    font-weight: 600;
    font-size: 1.8rem;
}

.studio {
    padding: 12rem 0;
    background-color: var(--color-surface);
}
.studio__title, .studio__description { text-align: center; }
.studio__description { margin-bottom: 8rem; }
.studio__gallery {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 30rem);
    gap: 3.2rem;
}
.studio__gallery-item {
    border-radius: var(--border-radius-medium);
    overflow: hidden;
}
.studio__gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.studio__gallery-item--large {
    grid-column: 1 / 2;
    grid-row: 1 / 3;
}

.join {
    padding: 15rem 0;
}
.join__container {
    border-radius: var(--border-radius-large);
    padding: 10rem 6rem;
    text-align: center;
}
.join__content {
    max-width: 65ch;
    margin: 0 auto;
}
.join__title {
    font-size: 4.8rem;
    font-weight: 800;
    margin-bottom: 2.4rem;
}
.join__text {
    font-size: 1.8rem;
    color: var(--color-text-secondary);
    margin-bottom: 3.2rem;
}

@media(max-width: 1024px) {
    .about-hero__container { grid-template-columns: 1fr; text-align: center; }
    .about-hero__content { order: 2; }
    .about-hero__visual { order: 1; max-width: 40rem; margin: 0 auto 4rem; }
    .about-hero__line { margin: 3.2rem auto 0; }
    .manifesto__container { grid-template-columns: 1fr; padding: 4rem; }
    .manifesto__title, .manifesto__content, .manifesto__visual { grid-column: auto; grid-row: auto; }
    .manifesto__title { text-align: center; }
    .manifesto__content { text-align: center; margin: 2rem 0 4rem; }
    .pillars__container { grid-template-columns: 1fr; }
    .pillars__sticky-visual { position: static; height: auto; text-align: center; margin-bottom: 6rem; }
    .pillars__image-container { max-width: 50rem; height: auto; aspect-ratio: 4/5; margin: 0 auto; }
    .team__grid { grid-template-columns: 1fr; max-width: 40rem; margin: 0 auto; }
}
@media(max-width: 768px) {
    .studio__gallery { grid-template-columns: 1fr; grid-template-rows: auto; }
    .studio__gallery-item { aspect-ratio: 4/3; }
    .studio__gallery-item--large { grid-row: auto; }
}


/* --- NEW Education Page --- */

.edu-hero {
    padding: 20rem 0 15rem;
    text-align: center;
    background-color: var(--color-background);
    position: relative;
    overflow: hidden;
}
.edu-hero::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background-image: radial-gradient(var(--color-border) 1px, transparent 1px);
    background-size: 20px 20px;
    opacity: 0.3;
}
.edu-hero__container {
    position: relative;
}
.edu-hero__tagline {
    color: var(--color-primary);
    font-weight: 700;
}
.edu-hero__title {
    font-size: clamp(4.8rem, 7vw, 8rem);
    font-weight: 800;
    line-height: 1.1;
    margin: 1rem 0 2rem;
}
.edu-hero__subtitle {
    font-size: 2rem;
    color: var(--color-text-secondary);
    max-width: 60ch;
    margin: 0 auto;
}

.pathway-interactive {
    padding: 15rem 0;
    background: var(--color-surface);
}
.pathway-interactive__container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8rem;
}
.pathway-interactive__sticky-content {
    position: sticky;
    top: 15rem;
    height: calc(100vh - 100rem);
}
.interactive-card {
    background: var(--color-background);
    padding: 4rem;
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-large);
    margin-bottom: 4rem;
    transform: scale(0.95);
    transition: opacity var(--transition-speed) var(--transition-easing), transform var(--transition-speed) var(--transition-easing);
}
.interactive-card--active {
    opacity: 1;
    transform: scale(1);
    border-color: var(--color-primary);
}
.interactive-card__level {
    color: var(--color-primary);
    font-weight: 700;
}
.interactive-card__title {
    font-size: 3.2rem;
    font-weight: 700;
    margin: 1rem 0;
}
.interactive-card__description {
    color: var(--color-text-secondary);
    margin-bottom: 2.4rem;
}
.interactive-card__tags {
    display: flex;
    gap: 1rem;
    margin-bottom: 3.2rem;
}
.interactive-card__tags span {
    background-color: var(--color-surface);
    padding: 0.5rem 1.2rem;
    border-radius: 50px;
    font-size: 1.4rem;
    font-weight: 600;
}
.interactive-card__link {
    font-weight: 700;
    color: var(--color-primary);
}

.pathway-comparison {
    padding: 12rem 0;
    background: var(--color-background);
}
.pathway-comparison__title {
    text-align: center;
    margin-bottom: 8rem;
}
.pathway-comparison__grid {
    display: grid;
    grid-template-columns: 0.8fr repeat(3, 1fr);
    background: var(--color-surface);
    border-radius: var(--border-radius-large);
    border: 1px solid var(--color-border);
    overflow: hidden;
}
.pathway-comparison__feature-labels, .pathway-comparison__pathway {
    display: grid;
    grid-template-rows: repeat(4, 1fr);
}
.pathway-comparison__feature-labels span, .pathway-comparison__pathway span, .pathway-comparison__pathway-title {
    padding: 2.4rem;
    display: flex;
    align-items: center;
    border-bottom: 1px solid var(--color-border);
}
.pathway-comparison__feature-labels span:last-child, .pathway-comparison__pathway span:last-child {
    border-bottom: none;
}
.pathway-comparison__feature-labels {
    font-weight: 700;
}
.pathway-comparison__pathway {
    border-left: 1px solid var(--color-border);
    text-align: center;
}
.pathway-comparison__pathway-title {
    font-size: 2.2rem;
    font-weight: 700;
    justify-content: center;
    color: var(--color-primary);
}
.pathway-comparison__pathway span {
    justify-content: center;
    color: var(--color-text-secondary);
}

.learning-ecosystem {
    padding: 15rem 0;
    background: var(--color-surface);
}
.learning-ecosystem__header {
    text-align: center;
    margin-bottom: 8rem;
}
.learning-ecosystem__title, .learning-ecosystem__description { text-align: center; margin: 0 auto;}
.learning-ecosystem__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(2, auto);
    gap: 4rem;
}
.learning-ecosystem__visual {
    grid-column: 1 / 4;
    grid-row: 1 / 2;
    border-radius: var(--border-radius-large);
    overflow: hidden;
}
.learning-ecosystem__item {
    background: var(--color-background);
    padding: 3.2rem;
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-medium);
}
.learning-ecosystem__item-title {
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 1.6rem;
}
.learning-ecosystem__item-text {
    color: var(--color-text-secondary);
}

.student-spotlight {
    padding: 12rem 0;
    background: var(--color-background);
}
.student-spotlight__container {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    align-items: center;
    gap: 8rem;
}
.student-spotlight__visual {
    border-radius: var(--border-radius-large);
    overflow: hidden;
}
.student-spotlight__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 4/5;
}
.student-spotlight__tagline {
    color: var(--color-primary);
    font-weight: 700;
    margin-bottom: 1.6rem;
}
.student-spotlight__quote {
    font-size: clamp(2.4rem, 3vw, 3.6rem);
    font-weight: 600;
    line-height: 1.5;
    font-style: italic;
}
.student-spotlight__cite {
    display: block;
    margin-top: 2.4rem;
    color: var(--color-text-secondary);
}

.edu-cta {
    padding: 12rem 0;
    background: var(--color-surface);
}
.edu-cta__container {
    text-align: center;
}
.edu-cta__title {
    font-size: 4.8rem;
    font-weight: 800;
    margin-bottom: 3.2rem;
}

@media (max-width: 1024px) {
    .pathway-interactive__container { grid-template-columns: 1fr; }
    .pathway-interactive__sticky-content { position: static; height: auto; text-align: center; margin-bottom: 6rem; }
    .pathway-comparison__grid { display: block; }
    .pathway-comparison__feature-labels { display: none; }
    .pathway-comparison__pathway { grid-template-rows: auto; border-left: none; }
    .pathway-comparison__pathway:not(:last-child) { border-bottom: 1px solid var(--color-border); }
    .pathway-comparison__pathway span { justify-content: space-between; text-align: right; }
    .pathway-comparison__pathway span::before { content: attr(data-label); font-weight: 700; color: var(--color-text-primary); }
    .learning-ecosystem__grid { grid-template-columns: 1fr; }
    .student-spotlight__container { grid-template-columns: 1fr; text-align: center; }
    .student-spotlight__visual { max-width: 40rem; margin: 0 auto 4rem; order: -1; }
}

.service-hero {
    position: relative;
    padding: 25rem 0 15rem;
    color: var(--color-text-primary);
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 80vh;
    overflow: hidden;
}
.service-hero__bg {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background-size: cover;
    background-position: center;
    z-index: -2;
    transform: scale(1.1);
    animation: zoom-out 15s ease-out forwards;
}
@keyframes zoom-out { to { transform: scale(1); } }
.service-hero::after {
    content: '';
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background: linear-gradient(180deg, rgba(16,16,16,0.2) 0%, var(--color-background) 95%);
    z-index: -1;
}
.service-hero__tagline {
    color: var(--color-primary);
    font-weight: 700;
}
.service-hero__title {
    font-size: clamp(4.8rem, 7vw, 8rem);
    font-weight: 800;
    line-height: 1.1;
    margin: 1rem 0 2rem;
}
.service-hero__subtitle {
    font-size: 2.2rem;
    color: var(--color-text-secondary);
    max-width: 60ch;
    margin: 0 auto;
}

.service-intro {
    padding: 12rem 0;
    background-color: var(--color-surface);
}
.service-intro__container {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 8rem;
    align-items: center;
}
.service-intro__title {
    margin-bottom: 2.4rem;
}
.service-intro__text {
    color: var(--color-text-secondary);
    max-width: 60ch;
}
.service-intro__stats {
    display: flex;
    flex-direction: column;
    gap: 3.2rem;
    background-color: var(--color-background);
    padding: 4rem;
    border-radius: var(--border-radius-large);
    border: 1px solid var(--color-border);
}
.service-intro__stat-item {
    text-align: center;
}
.service-intro__stat-number {
    font-size: 4.8rem;
    font-weight: 800;
    color: var(--color-primary);
    line-height: 1;
}
.service-intro__stat-label {
    font-size: 1.6rem;
    color: var(--color-text-secondary);
}

.curriculum-timeline {
    padding: 15rem 0;
    background-color: var(--color-background);
}
.curriculum-timeline__title {
    text-align: center;
    margin-bottom: 10rem;
}
.curriculum-timeline__timeline {
    position: relative;
    max-width: 80rem;
    margin: 0 auto;
}
.curriculum-timeline__line {
    position: absolute;
    top: 1rem;
    left: 1rem;
    width: 2px;
    height: 100%;
    background: var(--color-border);
}
.curriculum-timeline__item {
    position: relative;
    padding-left: 6rem;
    margin-bottom: 8rem;
}
.curriculum-timeline__item:last-child {
    margin-bottom: 0;
}
.curriculum-timeline__node {
    position: absolute;
    left: 0;
    top: 0;
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 50%;
    background-color: var(--color-surface);
    border: 3px solid var(--color-primary);
    transform: scale(0);
    animation: pop-in 0.5s var(--transition-easing) forwards;
}
.curriculum-timeline__item[data-aos="fade-up"] .curriculum-timeline__node {
    animation-delay: 0.3s;
}
@keyframes pop-in { to { transform: scale(1); } }

.curriculum-timeline__weeks {
    display: block;
    color: var(--color-primary);
    font-weight: 700;
    margin-bottom: 1rem;
}
.curriculum-timeline__module-title {
    font-size: 2.8rem;
    font-weight: 700;
    margin-bottom: 1rem;
}
.curriculum-timeline__module-desc {
    color: var(--color-text-secondary);
    max-width: 60ch;
}

.key-outcomes {
    padding: 12rem 0;
    background-color: var(--color-surface);
}
.key-outcomes__container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8rem;
    align-items: center;
}
.key-outcomes__list {
    list-style: none;
    margin-top: 4rem;
    display: flex;
    flex-direction: column;
    gap: 3.2rem;
}
.key-outcomes__item {
    position: relative;
    padding-left: 3.2rem;
}
.key-outcomes__item::before {
    content: '✓';
    position: absolute;
    left: 0;
    top: 0.3rem;
    color: var(--color-primary);
    font-weight: 800;
    font-size: 2rem;
}
.key-outcomes__item-title {
    font-size: 2.2rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
}
.key-outcomes__item-text {
    color: var(--color-text-secondary);
}
.key-outcomes__visual {
    border-radius: var(--border-radius-large);
    overflow: hidden;
}
.key-outcomes__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 4/5;
}

.service-enroll {
    padding: 12rem 0;
    background: var(--color-background);
}
.service-enroll__container {
    max-width: 60rem;
    margin: 0 auto;
    text-align: center;
    background-color: var(--color-surface);
    padding: 6rem;
    border-radius: var(--border-radius-large);
    border: 1px solid var(--color-border);
}
.service-enroll__title {
    font-size: 3.6rem;
    font-weight: 700;
}
.service-enroll__price {
    font-size: 4.8rem;
    font-weight: 800;
    color: var(--color-primary);
    margin: 1rem 0 3.2rem;
}
.service-enroll__features {
    list-style: none;
    margin-bottom: 3.2rem;
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    color: var(--color-text-secondary);
}
.service-enroll__guarantee {
    margin-top: 1.6rem;
    font-size: 1.4rem;
    color: var(--color-text-secondary);
    font-style: italic;
}

@media (max-width: 1024px) {
    .service-intro__container {
        grid-template-columns: 1fr;
    }
    .service-intro__stats {
        flex-direction: row;
        justify-content: space-around;
        margin-top: 4rem;
    }
    .key-outcomes__container {
        grid-template-columns: 1fr;
    }
    .key-outcomes__visual {
        order: -1;
        max-width: 50rem;
        margin: 0 auto 4rem;
    }
}
@media (max-width: 768px) {
    .curriculum-timeline__line {
        left: 1.1rem;
    }
    .service-intro__stats {
        flex-direction: column;
    }
}

.setup-hero {
    padding: 15rem 0 10rem;
    text-align: center;
    background-color: var(--color-surface);
}
.setup-hero__title {
    font-size: clamp(4rem, 6vw, 7rem);
    font-weight: 800;
}
.setup-hero__subtitle {
    font-size: 2rem;
    color: var(--color-text-secondary);
    max-width: 55ch;
    margin: 1.6rem auto 0;
}

.setup-main {
    padding: 12rem 0;
}
.setup-main__container {
    display: grid;
    grid-template-columns: 1fr 3fr;
    gap: 8rem;
    align-items: start;
}
.setup-main__nav {
    position: sticky;
    top: 12rem;
}
.setup-main__nav-title {
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 2.4rem;
}
.setup-main__nav-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.setup-main__nav-button {
    width: 100%;
    text-align: left;
    padding: 1.6rem 2.4rem;
    font-size: 1.8rem;
    font-weight: 600;
    border-radius: var(--border-radius-medium);
    transition: background-color var(--transition-speed-fast), color var(--transition-speed-fast);
}
.setup-main__nav-button:hover {
    background-color: var(--color-surface);
}
.setup-main__nav-button--active {
    background-color: var(--color-primary);
    color: var(--color-background);
}

.setup-main__pane {
    display: none;
}
.setup-main__pane--active {
    display: block;
}
.setup-main__pane-title {
    font-size: 3.6rem;
    font-weight: 700;
}
.setup-main__pane-desc {
    font-size: 1.8rem;
    color: var(--color-text-secondary);
    margin: 1.6rem 0 4rem;
}
.setup-animation {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-large);
    padding: 4rem;
    margin-bottom: 4rem;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 40rem;
}
.setup-animation__svg {
    width: 15rem;
    height: auto;
    fill: none;
    stroke: var(--color-text-secondary);
    stroke-width: 2;
}
.setup-animation__body--electric { stroke: var(--color-primary); }
.setup-animation__body--bass { stroke-width: 3; }
.setup-animation__headstock--classical { stroke-linecap: square; }
.setup-animation__headstock--12 { stroke-width: 1.5; }

.setup-animation__peg { fill: var(--color-border); animation: pulse 2s infinite ease-in-out; }
@keyframes pulse { 50% { fill: var(--color-primary); } }
.setup-animation__string { stroke: var(--color-primary); animation: vibrate 3s infinite ease-in-out; }
@keyframes vibrate { 50% { transform: translateX(1px); } }
.setup-animation__pickup { fill: var(--color-border); animation: glow 2.5s infinite ease-in-out; }
@keyframes glow { 50% { fill: var(--color-primary); } }

/* --- Legal Pages --- */

.legal-page {
    padding: 12rem 0;
}
.legal-page__container {
    max-width: 80ch;
    margin: 0 auto;
}
.legal-page__title {
    font-size: 4.8rem;
    font-weight: 800;
    margin-bottom: 1rem;
}
.legal-page__effective-date {
    color: var(--color-text-secondary);
    margin-bottom: 4rem;
}
.legal-page h2 {
    font-size: 2.8rem;
    font-weight: 700;
    margin: 4rem 0 2rem;
    border-bottom: 2px solid var(--color-border);
    padding-bottom: 1rem;
}
.legal-page p, .legal-page li {
    font-size: 1.8rem;
    line-height: 1.8;
    color: var(--color-text-secondary);
}
.legal-page ul {
    list-style: disc;
    padding-left: 3rem;
    margin: 2rem 0;
}
.legal-page a {
    color: var(--color-primary);
    text-decoration: underline;
}

@media(max-width: 1024px) {
    .setup-main__container {
        grid-template-columns: 1fr;
    }
    .setup-main__nav {
        position: static;
        margin-bottom: 6rem;
    }
    .setup-main__nav-list {
        flex-direction: row;
        flex-wrap: wrap;
    }
}

.wall-of-love {
    padding: 12rem 0;
    background-color: var(--color-surface);
}
.wall-of-love__header {
    text-align: center;
    margin-bottom: 8rem;
}
.wall-of-love__title, .wall-of-love__description {
    text-align: center;
}

.wall-of-love__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 3.2rem;
    max-height: 80vh;
    overflow: hidden;
    position: relative;
    -webkit-mask-image: linear-gradient(to bottom, transparent, black 10%, black 90%, transparent);
    mask-image: linear-gradient(to bottom, transparent, black 10%, black 90%, transparent);
}

.wall-of-love__column-wrapper {
    display: flex;
    flex-direction: column;
    gap: 3.2rem;
    will-change: transform;
}
.wall-of-love__column:nth-child(1) .wall-of-love__column-wrapper {
    animation: scroll-up 40s linear infinite;
}
.wall-of-love__column:nth-child(2) .wall-of-love__column-wrapper {
    animation: scroll-down 60s linear infinite;
}
.wall-of-love__column:nth-child(3) .wall-of-love__column-wrapper {
    animation: scroll-up 45s linear infinite;
}
.wall-of-love__column:nth-child(4) .wall-of-love__column-wrapper {
    animation: scroll-down 55s linear infinite;
}
.wall-of-love__column:hover .wall-of-love__column-wrapper {
    animation-play-state: paused;
}

@keyframes scroll-up {
    from { transform: translateY(0); }
    to { transform: translateY(-50%); }
}
@keyframes scroll-down {
    from { transform: translateY(-50%); }
    to { transform: translateY(0); }
}

.wall-of-love__card {
    background: var(--color-background);
    padding: 2.4rem;
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-medium);
}
.wall-of-love__card-header {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    margin-bottom: 1.6rem;
}
.wall-of-love__card-avatar {
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    object-fit: cover;
}
.wall-of-love__card-name {
    font-weight: 700;
    font-size: 1.6rem;
}
.wall-of-love__card-text {
    color: var(--color-text-secondary);
    font-size: 1.5rem;
    line-height: 1.6;
}

@media (max-width: 1024px) {
    .wall-of-love__grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .wall-of-love__column:nth-child(3),
    .wall-of-love__column:nth-child(4) {
        display: none;
    }
}
@media (max-width: 768px) {
    .wall-of-love__grid {
        grid-template-columns: 1fr;
        max-height: 70vh;
    }
    .wall-of-love__column:nth-child(2) {
        display: none;
    }
    .wall-of-love__column:nth-child(1) .wall-of-love__column-wrapper {
        animation-duration: 60s;
    }
}

.ds
{
    display: none;
}