/* =====================================================
   Lexikaizen — compiled stylesheet
   (mirror of sass/main.sass for direct browser preview)
   ===================================================== */

/* ---------- Base reset ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

html { font-size: 16px; scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    font-family: "Poppins", sans-serif;
    font-size: 1.0625rem;
    line-height: 1.6;
    color: #0F0E1B;
    background: #fff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Final overrides: generated hero photos, language flags, topic switcher */
.hero__card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}.flag{display:inline-block;width:2.375rem;height:1.625rem;border-radius:.3125rem;box-shadow:0 .25rem .875rem rgba(15,14,27,.16);flex:0 0 auto}.flag--gb{background:linear-gradient(33deg,transparent 0 42%,#fff 42% 48%,#c8102e 48% 52%,#fff 52% 58%,transparent 58% 100%),linear-gradient(-33deg,transparent 0 42%,#fff 42% 48%,#c8102e 48% 52%,#fff 52% 58%,transparent 58% 100%),linear-gradient(90deg,transparent 0 40%,#fff 40% 60%,transparent 60% 100%),linear-gradient(0deg,transparent 0 34%,#fff 34% 66%,transparent 66% 100%),linear-gradient(90deg,transparent 0 45%,#c8102e 45% 55%,transparent 55% 100%),linear-gradient(0deg,transparent 0 42%,#c8102e 42% 58%,transparent 58% 100%),#012169}.flag--es{background:linear-gradient(180deg,#aa151b 0 25%,#f1bf00 25% 75%,#aa151b 75% 100%)}.flag--fr{background:linear-gradient(90deg,#002654 0 33.33%,#fff 33.33% 66.66%,#ed2939 66.66% 100%)}.hero__flags a{width:auto;min-width:2.75rem;padding:0 .875rem;gap:.625rem;border-radius:999px;font-size:.875rem;font-weight:700}.hero__flags a .flag{width:1.75rem;height:1.125rem;box-shadow:none}.languages{background:linear-gradient(180deg,#fff 0%,#f5f4f8 100%)}.languages__head{max-width:48.75rem;margin-bottom:2.875rem}.languages__grid{display:grid;gap:1.75rem}.language-panel{overflow:hidden;border-radius:1.375rem;background:#fff;box-shadow:0 12px 28px rgba(15,14,27,.12);border:1px solid rgba(200,198,214,.7)}.language-panel[id]{scroll-margin-top:6rem}.language-panel__header{display:flex;align-items:center;gap:1.125rem;padding:1.625rem 1.875rem;background:linear-gradient(135deg,rgba(79,63,217,.09),rgba(255,122,89,.08))}.language-panel__header h3{margin-bottom:.25rem;font-size:1.875rem}.language-panel__header p{margin:0;color:#3a3852}.language-panel__body{display:grid;grid-template-columns:16.25rem 1fr;gap:1.625rem;padding:1.875rem}.language-panel__topics{display:flex;flex-direction:column;gap:.625rem}.language-panel__topic{border:1px solid #e8e7ee;border-radius:.5rem;background:#f5f4f8;color:#0f0e1b;cursor:pointer;padding:.875rem 1rem;text-align:left;font-weight:700;transition:background .2s ease,border-color .2s ease,color .2s ease,transform .2s ease}.language-panel__topic:hover,.language-panel__topic.is-active{background:#4f3fd9;border-color:#4f3fd9;color:#fff;transform:translateX(.25rem)}.language-panel__subtopics{min-height:15.625rem}.language-panel__subtopic{display:none}.language-panel__subtopic.is-active{display:block}.language-panel__subtopic h4{font-size:1.625rem;margin-bottom:1.125rem}.subtopic-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:3.875rem;padding:1rem 1.125rem;border:1px solid #e8e7ee;border-radius:.875rem;background:#fff;color:#0f0e1b;box-shadow:0 2px 8px rgba(15,14,27,.08);margin-bottom:.75rem;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}.subtopic-card:hover{color:#0f0e1b;border-color:#c9c2f7;transform:translateY(-.125rem);box-shadow:0 12px 28px rgba(15,14,27,.12)}.subtopic-card strong{display:inline-flex;align-items:center;min-height:1.75rem;padding:0 .625rem;border-radius:999px;background:#ffc857;color:#0f0e1b;font-size:.75rem;letter-spacing:.8px}.subtopic-card.is-free{background:linear-gradient(135deg,rgba(255,200,87,.28),#fff 48%);border-color:rgba(255,200,87,.9)}@media screen and (max-width:991px){.language-panel__body{grid-template-columns:1fr}.language-panel__topics{display:grid;grid-template-columns:repeat(2,1fr)}.language-panel__topic:hover,.language-panel__topic.is-active{transform:translateY(-.125rem)}}@media screen and (max-width:767px){.languages__head{margin-bottom:2rem}.language-panel{border-radius:.875rem}.language-panel__header,.language-panel__body{padding:1.25rem}.language-panel__header{align-items:flex-start}.language-panel__header h3{font-size:1.5rem}.subtopic-card{align-items:flex-start;flex-direction:column}}@media screen and (max-width:575px){.language-panel__topics{grid-template-columns:1fr}.hero__flags a{width:100%;justify-content:flex-start}}

img, svg, video { display: block; max-width: 100%; height: auto; }

a { color: #4F3FD9; text-decoration: none; transition: color .2s ease; }
a:hover { color: #6B5EE5; }

ul, ol { list-style: none; margin: 0; padding: 0; }

h1, h2, h3, h4, h5, h6 {
    font-family: "Kanit", sans-serif;
    font-weight: 600;
    line-height: 1.15;
    margin: 0 0 1rem;
    color: #0F0E1B;
    letter-spacing: 0.5px;
}

h1 { font-size: clamp(2rem, 5vw, 3.75rem); text-transform: uppercase; }
h2 { font-size: clamp(1.6rem, 3.4vw, 2.6rem); text-transform: uppercase; }
h3 { font-size: clamp(1.25rem, 2vw, 1.65rem); }

p { margin: 0 0 1rem; }

button, input, textarea, select { font: inherit; color: inherit; }

.container { width: 100%; max-width: 1320px; margin: 0 auto; padding: 0 1.5rem; }
@media (max-width: 767px) { .container { padding: 0 1rem; } }

.section { padding: 6rem 0; }
@media (max-width: 991px) { .section { padding: 4rem 0; } }
@media (max-width: 767px) { .section { padding: 3rem 0; } }

.section__perex {
    display: inline-flex; align-items: center; gap: .75rem;
    font-family: "Kanit", sans-serif; font-weight: 600; font-size: .9375rem;
    text-transform: uppercase; letter-spacing: 1.5px;
    color: #4F3FD9; margin-bottom: 1rem;
}
.section__perex::before {
    content: ''; width: 2.5rem; height: .125rem; background: #FF7A59; display: inline-block;
}
.section__title { margin-bottom: 1.25rem; }
.section__lead { font-size: 1.125rem; color: #3A3852; max-width: 42.5rem; margin-bottom: 3rem; }
.editable-content p,
.editable-content ul,
.editable-content ol { margin: 0 0 1em; }
.editable-content ul { list-style: disc; padding-left: 1.4em; }
.editable-content ol { list-style: decimal; padding-left: 1.4em; }
.editable-content p:last-child,
.editable-content ul:last-child,
.editable-content ol:last-child { margin-bottom: 0; }
.editable-content a { color: inherit; text-decoration: underline; }
.text-center { text-align: center; }
.text-gradient {
    background: linear-gradient(135deg, #4F3FD9 0%, #FF7A59 100%);
    -webkit-background-clip: text; background-clip: text; color: transparent;
}

.is-visually-hidden {
    position: absolute; width: 1px; height: 1px; padding: 0;
    margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0;
}

/* ---------- Buttons ---------- */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: .625rem;
    padding: .875rem 1.75rem; font-family: "Kanit", sans-serif;
    font-weight: 500; font-size: .9375rem; line-height: 1; letter-spacing: .6px;
    text-transform: uppercase; text-decoration: none;
    border: 1px solid transparent; border-radius: 14px; cursor: pointer;
    transition: transform .2s ease, background-color .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
    white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn--primary {
    background: #4F3FD9; color: #fff;
    box-shadow: 0 8px 22px rgba(79,63,217,.35);
}
.btn--primary:hover { background: #6B5EE5; color: #fff; box-shadow: 0 12px 28px rgba(79,63,217,.45); }
.btn--secondary {
    background: #FF7A59; color: #fff;
    box-shadow: 0 8px 22px rgba(255,122,89,.35);
}
.btn--secondary:hover { background: #FF9478; color: #fff; }
.btn--outline { background: transparent; color: #4F3FD9; border-color: #4F3FD9; }
.btn--outline:hover { background: #4F3FD9; color: #fff; }
.btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); }
.btn--ghost:hover { background: rgba(255,255,255,.1); border-color: #fff; }
.btn--lg { padding: 1.125rem 2.125rem; font-size: 1rem; }
.btn--sm { padding: .625rem 1.25rem; font-size: .8125rem; }
.btn--block { width: 100%; }

/* ---------- Header ---------- */
.header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
    padding: 1.125rem 0; background: transparent;
    transition: background-color .3s ease, padding .3s ease, box-shadow .3s ease;
}
@media (max-width: 767px) { .header { padding: .75rem 0; } }
.header.is-scroll {
    background: rgba(15,14,27,.92); padding: .625rem 0;
    box-shadow: 0 6px 24px rgba(0,0,0,.18);
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
}
.header > .container { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.header__left { display: flex; align-items: center; gap: 1rem; }
.header__right { display: flex; align-items: center; gap: .75rem; flex-shrink: 0; }
.header__logo { display: inline-flex; align-items: center; flex-shrink: 0; }
.header__logo img,
.header__logo svg { height: 3.375rem; width: auto; }
@media (max-width: 991px) { .header__logo img, .header__logo svg { height: 2.875rem; } }
@media (max-width: 767px) { .header__logo img, .header__logo svg { height: 2.375rem; } }

.header__actions { display: flex; align-items: center; gap: .75rem; }
@media (max-width: 991px) {
    .header__actions { gap: .5rem; }
    .header__actions .btn { padding: .5625rem 1rem; font-size: .75rem; }
}
@media (max-width: 767px) { .header__actions { display: none; } }

.header__hamburger {
    display: none; width: 2.875rem; height: 2.875rem; align-items: center; justify-content: center;
    border-radius: 14px; background: #4F3FD9; border: 0; cursor: pointer;
    transition: background-color .2s ease;
}
.header__hamburger:hover { background: #6B5EE5; }
@media (max-width: 767px) { .header__hamburger { display: inline-flex; } }
.header__hamburger span {
    width: 1.25rem; height: .125rem; background: #fff; position: relative; display: block;
}
.header__hamburger span::before,
.header__hamburger span::after {
    content: ''; position: absolute; left: 0; width: 100%; height: .125rem;
    background: #fff; transition: transform .3s ease;
}
.header__hamburger span::before { top: -.375rem; }
.header__hamburger span::after  { top:  .375rem; }
.header__hamburger.is-open span { background: transparent; }
.header__hamburger.is-open span::before { top: 0; transform: rotate(45deg); }
.header__hamburger.is-open span::after  { top: 0; transform: rotate(-45deg); }

.nav-mobile {
    position: fixed; top: 0; right: 0; bottom: 0;
    width: 82vw; max-width: 22.5rem;
    background: #0F0E1B; color: #fff; z-index: 1100;
    padding: 6rem 1.5rem 1.5rem;
    transform: translateX(100%); transition: transform .3s ease;
    box-shadow: -10px 0 40px rgba(0,0,0,.3);
    display: flex; flex-direction: column; gap: 1rem;
}
.nav-mobile.is-open { transform: translateX(0); }
.nav-mobile a {
    color: #fff; font-family: "Kanit", sans-serif; font-weight: 500;
    text-transform: uppercase; letter-spacing: 1px; font-size: 1rem;
}
.nav-mobile .btn { width: 100%; justify-content: center; }
.nav-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,.55);
    opacity: 0; visibility: hidden;
    transition: opacity .3s ease, visibility .3s ease; z-index: 1050;
}
.nav-overlay.is-open { opacity: 1; visibility: visible; }

/* ---------- Hero ---------- */
.hero {
    position: relative; width: 100%; min-height: 100vh; color: #fff;
    overflow: hidden; display: flex; align-items: center; isolation: isolate;
    background:
        radial-gradient(circle at 20% 30%, rgba(79,63,217,.55) 0%, transparent 60%),
        radial-gradient(circle at 80% 70%, rgba(255,122,89,.35) 0%, transparent 55%),
        #0F0E1B;
}
.hero__media { position: absolute; inset: 0; z-index: -1; }
.hero__media img,
.hero__media video { width: 100%; height: 100%; object-fit: cover; }
.hero::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(15,14,27,.55) 0%, rgba(15,14,27,.85) 100%);
    z-index: -1;
}
.hero > .container { position: relative; z-index: 2; padding-top: 7.5rem; padding-bottom: 5rem; }
@media (max-width: 991px) { .hero > .container { padding-top: 6.875rem; padding-bottom: 3.75rem; } }
@media (max-width: 767px) { .hero > .container { padding-top: 6rem; padding-bottom: 2.5rem; } }
@media (max-width: 767px) { .hero { min-height: auto; padding-bottom: 2.5rem; } }
.hero__inner {
    display: grid; grid-template-columns: 1.05fr 1fr; gap: 3rem; align-items: center;
}
@media (max-width: 991px) { .hero__inner { grid-template-columns: 1fr; gap: 2.5rem; } }
.hero__content { max-width: 40rem; }
.hero__eyebrow {
    display: inline-block; padding: .5rem 1rem;
    background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
    border-radius: 999px; font-size: .8125rem; letter-spacing: 1.5px;
    text-transform: uppercase; margin-bottom: 1.5rem;
    backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
}
@media (max-width: 767px) {
    .hero__eyebrow { font-size: .6875rem; letter-spacing: 1.2px; padding: .375rem .75rem; margin-bottom: 1rem; }
}
.hero__title {
    color: #fff; margin-bottom: 1.25rem;
    font-size: clamp(2.2rem, 5.5vw, 4.4rem);
}
.hero__title span {
    background: linear-gradient(135deg, #7BE0FF 0%, #4F8DFF 50%, #FF7A59 100%);
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero__lead { font-size: 1.125rem; color: rgba(255,255,255,.78); margin-bottom: 2rem; max-width: 35rem; }
@media (max-width: 767px) { .hero__lead { font-size: .9375rem; margin-bottom: 1.5rem; } }
.hero__stats { display: flex; gap: 2rem; margin: 1.5rem 0 2.25rem; flex-wrap: wrap; }
@media (max-width: 767px) { .hero__stats { gap: 1.25rem; margin: 1.25rem 0 1.75rem; } }
.hero__stats > div strong {
    display: block; font-family: "Kanit", sans-serif; font-size: 2.125rem; font-weight: 700;
    color: #FFC857; line-height: 1;
}
@media (max-width: 767px) { .hero__stats > div strong { font-size: 1.75rem; } }
.hero__stats > div span {
    display: block; font-size: .8125rem; text-transform: uppercase; letter-spacing: 1.4px;
    color: rgba(255,255,255,.7); margin-top: .375rem;
}
@media (max-width: 767px) { .hero__stats > div span { font-size: .6875rem; } }
.hero__buttons { display: flex; gap: 1rem; flex-wrap: wrap; }
@media (max-width: 575px) { .hero__buttons { gap: .75rem; } .hero__buttons .btn { width: 100%; } }
.hero__flags { display: flex; gap: .875rem; margin-top: 2.5rem; flex-wrap: wrap; align-items: center; }
@media (max-width: 767px) { .hero__flags { gap: .625rem; margin-top: 1.75rem; } }
.hero__flags span {
    font-size: .8125rem; color: rgba(255,255,255,.6);
    text-transform: uppercase; letter-spacing: 1.4px;
}
.hero__flags a {
    width: 2.75rem; height: 2.75rem; display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.5rem; border-radius: 50%; background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.15);
    transition: transform .2s ease, background-color .2s ease;
}
@media (max-width: 767px) {
    .hero__flags a { width: 2.375rem; height: 2.375rem; font-size: 1.25rem; }
}
.hero__flags a:hover { transform: translateY(-3px); background: #4F3FD9; }

.hero__collage { position: relative; height: 32.5rem; }
@media (max-width: 991px) { .hero__collage { height: 22.5rem; max-width: 32.5rem; margin: 0 auto; } }
@media (max-width: 575px) { .hero__collage { height: 17.5rem; } }
.hero__card {
    position: absolute; width: 13.75rem; height: 17.5rem; border-radius: 22px;
    background: linear-gradient(135deg, #4F3FD9 0%, #2A1B7A 100%);
    box-shadow: 0 24px 60px rgba(79,63,217,.20);
    overflow: hidden; display: flex; align-items: flex-end; padding: 1.25rem;
    color: #fff; font-family: "Kanit", sans-serif; font-weight: 600;
    text-transform: uppercase; letter-spacing: 1px;
    animation: hero-float 6s ease-in-out infinite;
}
@media (max-width: 991px) { .hero__card { width: 10.625rem; height: 13.75rem; } }
@media (max-width: 575px) {
    .hero__card { width: 8.125rem; height: 10.625rem; padding: .875rem; font-size: .8125rem; }
    .hero__card:nth-child(3) { left: 2.5rem; }
}
.hero__card::before {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,.55) 100%);
}
.hero__card span { position: relative; z-index: 2; }
.hero__card:nth-child(1) {
    top: 0; left: 1.25rem;
    background: linear-gradient(135deg, #4F3FD9, #2A1B7A);
    transform: rotate(-6deg);
}
.hero__card:nth-child(2) {
    top: 3.75rem; right: 1.25rem;
    background: linear-gradient(135deg, #FF7A59, #B83A1C);
    animation-delay: -2s; transform: rotate(5deg);
}
.hero__card:nth-child(3) {
    bottom: 1.25rem; left: 5rem;
    background: linear-gradient(135deg, #FFC857, #FF7A59);
    animation-delay: -4s; transform: rotate(-3deg);
}
@keyframes hero-float {
    0%,100% { transform: translateY(0) rotate(var(--r,0deg)); }
    50%     { transform: translateY(-10px) rotate(var(--r,0deg)); }
}

/* ---------- About ---------- */
.about { background: #F5F4F8; position: relative; overflow: hidden; }
.about::before {
    content: ''; position: absolute; top: -6.25rem; right: -6.25rem;
    width: 25rem; height: 25rem; border-radius: 50%;
    background: radial-gradient(circle, rgba(79,63,217,.10), transparent 70%);
    pointer-events: none;
}
.about__wrapper {
    display: grid; grid-template-columns: 1.1fr 1fr; gap: 4.5rem; align-items: center;
}
@media (max-width: 1199px) { .about__wrapper { gap: 3rem; } }
@media (max-width: 991px) { .about__wrapper { grid-template-columns: 1fr; gap: 3rem; } }
.about__content { max-width: 38.75rem; }
@media (max-width: 991px) { .about__visual { max-width: 28rem; margin: 0 auto; width: 100%; } }
.about__features {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; margin-top: 2rem;
}
@media (max-width: 575px) { .about__features { grid-template-columns: 1fr; } }
.about__feature {
    background: #fff; border-radius: 14px; padding: 1.5rem;
    box-shadow: 0 2px 8px rgba(15,14,27,.08); border: 1px solid #E8E7EE;
}
.about__feature__icon {
    width: 3rem; height: 3rem; border-radius: 8px;
    background: linear-gradient(135deg, #4F3FD9, #FF7A59);
    display: inline-flex; align-items: center; justify-content: center;
    color: #fff; font-size: 1.375rem; margin-bottom: .875rem;
}
.about__feature__icon--image {
    width: 3.5rem; height: 3.5rem;
    background: transparent; color: inherit; overflow: hidden;
}
.about__feature__icon img {
    display: block; width: 100%; height: 100%; object-fit: cover; border-radius: inherit;
}
.about__feature h3 { font-size: 1.125rem; margin-bottom: .5rem; }
.about__feature p { margin: 0; font-size: .9375rem; color: #3A3852; }

.about__visual { position: relative; }
.about__visual__main {
    border-radius: 22px; overflow: hidden; aspect-ratio: 4/5;
    background: linear-gradient(135deg, #4F3FD9, #FF7A59);
    box-shadow: 0 24px 60px rgba(79,63,217,.20); position: relative;
}
.about__visual__main img { width: 100%; height: 100%; object-fit: cover; }
.about__visual__main::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(15,14,27,.4) 100%);
}
.about__visual__badge {
    position: absolute; bottom: -1.5rem; left: -1.5rem;
    background: #fff; padding: 1.25rem 1.5rem; border-radius: 14px;
    box-shadow: 0 12px 28px rgba(15,14,27,.12);
    display: flex; align-items: center; gap: 1rem;
}
@media (max-width: 767px) {
    .about__visual__badge { left: .75rem; bottom: -1rem; padding: .875rem 1.125rem; }
}
.about__visual__badge__icon {
    width: 3rem; height: 3rem; border-radius: 50%;
    background: #FFEEC9; color: #B83A1C;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.375rem; flex-shrink: 0;
}
.about__visual__badge strong {
    display: block; font-family: "Kanit", sans-serif; font-size: 1.375rem; color: #0F0E1B;
}
.about__visual__badge span {
    display: block; font-size: .8125rem; color: #3A3852;
    text-transform: uppercase; letter-spacing: 1px;
}

/* ---------- Pricing ---------- */
.pricing { background: #0F0E1B; color: #fff; position: relative; overflow: hidden; }
.pricing::before {
    content: ''; position: absolute; top: 0; left: 50%;
    width: 56.25rem; height: 56.25rem; transform: translate(-50%, -50%);
    background: radial-gradient(circle, rgba(79,63,217,.25), transparent 60%);
    pointer-events: none;
}
.pricing__head { text-align: center; margin-bottom: 3.5rem; position: relative; z-index: 2; }
.pricing__head h2 { color: #fff; }
.pricing__cards {
    display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem;
    position: relative; z-index: 2;
}
@media (max-width: 1199px) { .pricing__cards { gap: 1.5rem; } }
@media (max-width: 991px) {
    .pricing__cards { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
    .pricing__card--featured { grid-column: 1 / -1; max-width: 30rem; margin: 0 auto; width: 100%; }
}
@media (max-width: 575px) {
    .pricing__cards { grid-template-columns: 1fr; }
    .pricing__card--featured { max-width: none; }
}
@media (max-width: 991px) { .pricing__card { padding: 2rem 1.5rem; } }
.pricing__card {
    background: #161526; border: 1px solid #232238; border-radius: 22px;
    padding: 2.25rem 2rem; display: flex; flex-direction: column; gap: 1.25rem;
    transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease;
    position: relative;
}
.pricing__card:hover { transform: translateY(-6px); border-color: #6B5EE5; box-shadow: 0 24px 60px rgba(79,63,217,.20); }
.pricing__card--featured {
    background: linear-gradient(180deg, #4F3FD9 0%, #2A1B7A 100%);
    border-color: #6B5EE5; transform: scale(1.03);
}
@media (max-width: 991px) { .pricing__card--featured { transform: none; } }
.pricing__card--featured .pricing__price { color: #FFC857; }
.pricing__card--featured .pricing__features li::before { background: #FFC857; }
.pricing__card__badge {
    position: absolute; top: -.875rem; left: 50%; transform: translateX(-50%);
    background: #FF7A59; color: #fff; padding: .375rem 1rem; border-radius: 999px;
    font-size: .75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 1.4px;
}
.pricing__plan {
    font-family: "Kanit", sans-serif; font-size: 1.25rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 1.5px; margin: 0;
}
.pricing__desc { font-size: .875rem; color: rgba(255,255,255,.65); margin: 0; }
.pricing__price {
    font-family: "Kanit", sans-serif; font-size: 3.375rem; font-weight: 700;
    line-height: 1; color: #fff;
}
.pricing__price sub {
    font-size: 1rem; color: rgba(255,255,255,.7); font-weight: 400; margin-left: .375rem; bottom: 0;
}
.pricing__features {
    display: flex; flex-direction: column; gap: .625rem; margin: .5rem 0; flex: 1;
}
.pricing__features li {
    position: relative; padding-left: 1.75rem; font-size: .9375rem;
    color: rgba(255,255,255,.85);
}
.pricing__features li::before {
    content: ''; position: absolute; left: 0; top: .4375rem;
    width: 1rem; height: 1rem; border-radius: 50%;
    background: #6B5EE5; box-shadow: 0 0 0 3px rgba(79,63,217,.2);
}
.pricing__features li.is-muted { color: rgba(255,255,255,.4); text-decoration: line-through; }
.pricing__features li.is-muted::before { background: #3A3852; box-shadow: none; }
.pricing__qr {
    margin-top: .5rem; padding: 1rem; border-radius: 14px;
    background: rgba(255,255,255,.05); border: 1px dashed rgba(255,255,255,.15);
    display: flex; align-items: center; gap: .875rem;
}
.pricing__qr__img {
    width: 4.5rem; height: 4.5rem; border-radius: 8px; background: #fff;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.pricing__qr__img img,
.pricing__qr__img svg { width: 4rem; height: 4rem; }
.pricing__qr__text strong {
    display: block; font-family: "Kanit", sans-serif; font-size: .875rem;
    text-transform: uppercase; letter-spacing: 1.2px; color: #fff;
}
.pricing__qr__text span {
    display: block; font-size: .75rem; color: rgba(255,255,255,.65); margin-top: .125rem;
}
.pricing__btn { margin-top: auto; }

/* ---------- License calculator ---------- */
.license-calculator {
    position: relative; z-index: 2;
    display: grid; grid-template-columns: minmax(0, 1fr) minmax(20rem, 25rem);
    gap: 2rem; align-items: stretch;
}
@media (max-width: 991px) { .license-calculator { grid-template-columns: 1fr; } }

.license-calculator__panel {
    background: #fff; color: #0F0E1B;
    border: 1px solid rgba(255,255,255,.75); border-radius: 22px;
    box-shadow: 0 24px 60px rgba(0,0,0,.22);
    min-height: 100%;
}
.license-calculator__panel--config { padding: clamp(1.25rem, 3vw, 2.5rem); }

.license-step + .license-step { margin-top: 2rem; }
.license-step h3 {
    margin: 0 0 1.125rem; font-size: clamp(1.05rem, 1.6vw, 1.25rem);
    text-transform: none; color: #123152; letter-spacing: 0;
}
.license-step__head {
    display: flex; justify-content: space-between; gap: 1rem; align-items: end;
}
@media (max-width: 575px) { .license-step__head { align-items: stretch; flex-direction: column; } }
.license-step__number {
    display: flex; flex-direction: column; gap: .375rem;
    min-width: 8.25rem; color: #3A3852; font-size: .75rem;
    text-transform: uppercase; letter-spacing: 1px;
}
.license-step__number input {
    width: 100%; height: 2.75rem; padding: .5rem .75rem;
    border: 1px solid #C8C6D6; border-radius: 8px;
    color: #0F0E1B; background: #fff; font-weight: 700;
}
.license-step__number input:focus {
    outline: none; border-color: #6B5EE5; box-shadow: 0 0 0 4px rgba(79,63,217,.15);
}
.license-step__hint {
    margin: .25rem 0 0;
    color: #6D6A80;
    font-size: .875rem;
}

.license-range {
    position: relative; padding: 2.25rem 0 .875rem;
    --license-progress: 0%;
}
.license-range input[type="range"] {
    appearance: none; -webkit-appearance: none;
    width: 100%; height: .625rem; margin: 0;
    border-radius: 999px;
    background: linear-gradient(90deg, #4F3FD9 var(--license-progress), #E8E7EE var(--license-progress));
    outline: none; cursor: pointer;
}
.license-range input[type="range"]::-webkit-slider-thumb {
    appearance: none; -webkit-appearance: none;
    width: 1.375rem; height: 1.375rem; border-radius: 50%;
    background: #FF7A59; border: 4px solid #fff;
    box-shadow: 0 4px 14px rgba(15,14,27,.28);
}
.license-range input[type="range"]::-moz-range-thumb {
    width: 1.375rem; height: 1.375rem; border-radius: 50%;
    background: #FF7A59; border: 4px solid #fff;
    box-shadow: 0 4px 14px rgba(15,14,27,.28);
}
.license-range__bubble {
    position: absolute; left: var(--license-progress); top: .125rem;
    min-width: 3.75rem; transform: translateX(-50%);
    padding: .5rem .75rem; border-radius: 8px;
    background: #4F3FD9; color: #fff;
    font-family: "Kanit", sans-serif; font-size: 1.125rem; line-height: 1;
    text-align: center; box-shadow: 0 10px 24px rgba(79,63,217,.32);
}
.license-range__bubble::after {
    content: ''; position: absolute; left: 50%; bottom: -.375rem;
    width: .75rem; height: .75rem; transform: translateX(-50%) rotate(45deg);
    background: #4F3FD9; border-radius: 2px;
}

.license-subjects {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .875rem;
}
@media (max-width: 767px) { .license-subjects { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 479px) { .license-subjects { grid-template-columns: 1fr; } }
.license-subject {
    position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: .875rem; min-height: 10.75rem; padding: 1.125rem .875rem;
    border: 1px solid #E8E7EE; border-radius: 14px;
    background: #fff; color: #123152; cursor: pointer;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease, background .2s ease;
}
.license-subject:hover {
    border-color: #C9C2F7; transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(15,14,27,.1);
}
.license-subject.is-selected {
    border-color: #4F3FD9; background: linear-gradient(180deg, #fff 0%, #F4F2FE 100%);
    box-shadow: 0 14px 34px rgba(79,63,217,.16);
}
.license-subject__symbol {
    width: 4rem; height: 4rem; border-radius: 18px;
    display: inline-flex; align-items: center; justify-content: center;
    background: #F5F4F8; color: #4F3FD9;
    font-family: "Kanit", sans-serif; font-size: 1.1rem; font-weight: 700;
    border: 1px solid #E8E7EE; box-shadow: inset -8px -8px 0 rgba(255,200,87,.42);
}
.license-subject__symbol--math span { font-size: 2rem; line-height: 1; }
.license-subject__symbol--science { box-shadow: inset -8px -8px 0 rgba(123,224,255,.32); }
.license-subject__symbol--bot { box-shadow: inset -8px -8px 0 rgba(255,122,89,.28); }
.license-subject__name {
    display: block; max-width: 100%;
    font-size: .9875rem; line-height: 1.45; text-align: center; color: #123152;
    overflow-wrap: anywhere;
}
.license-subject__meta {
    display: block; margin-top: -.5rem;
    font-size: .75rem; line-height: 1.3;
    color: #6D6A80; text-align: center;
}
.license-subject__check {
    position: absolute; left: 50%; bottom: -1.375rem; transform: translateX(-50%) scale(.75);
    width: 3rem; height: 3rem; display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%; background: #4F3FD9; color: #fff;
    font-size: 1.5rem; font-weight: 800; opacity: 0;
    box-shadow: 0 10px 22px rgba(79,63,217,.3);
    transition: opacity .2s ease, transform .2s ease;
}
.license-subject.is-selected .license-subject__check {
    opacity: 1; transform: translateX(-50%) scale(1);
}

.license-durations { display: flex; flex-wrap: wrap; gap: .75rem; }
.license-duration {
    position: relative; min-width: 7.5rem; min-height: 4.25rem;
    padding: .875rem 1.25rem; border: 1px solid #E8E7EE;
    border-radius: 14px; background: #fff; color: #123152;
    font-family: "Kanit", sans-serif; font-weight: 600; cursor: pointer;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.license-duration:hover { transform: translateY(-2px); border-color: #C9C2F7; }
.license-duration.is-selected {
    border-color: #4F3FD9; box-shadow: 0 12px 28px rgba(79,63,217,.14);
}
.license-duration__check {
    position: absolute; left: 50%; bottom: -1.125rem; transform: translateX(-50%) scale(.75);
    width: 2.5rem; height: 2.5rem; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    background: #4F3FD9; color: #fff; font-size: 1.25rem; opacity: 0;
    box-shadow: 0 10px 22px rgba(79,63,217,.3);
}
.license-duration.is-selected .license-duration__check {
    opacity: 1; transform: translateX(-50%) scale(1);
}

.license-summary {
    padding: 1.5rem; position: sticky; top: 6.5rem;
}
@media (max-width: 991px) { .license-summary { position: static; } }
.license-summary__unit {
    display: flex; align-items: baseline; justify-content: space-between; gap: 1rem;
    margin-bottom: 2rem; padding: .875rem 1rem;
    border-radius: 14px; background: #F5F4F8; color: #123152;
}
.license-summary__unit span { font-size: .9875rem; }
.license-summary__unit strong {
    font-family: "Kanit", sans-serif; font-size: 1.75rem; white-space: nowrap;
}
.license-summary__rows { margin: 0; }
.license-summary__rows > div {
    display: grid; grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem; align-items: start; padding: .875rem 0;
    border-top: 1px solid #DAD8E5;
}
.license-summary__rows dt,
.license-summary__rows dd { margin: 0; }
.license-summary__rows dt { color: #123152; }
.license-summary__rows dd { font-weight: 700; color: #123152; text-align: right; }
.license-summary__discount dt span { color: #FF7A59; }
.license-summary__discount small {
    display: block; margin-top: .125rem; color: #123152; font-size: .875rem;
}
.license-summary__discount dd span {
    display: block; font-weight: 500; color: #123152;
}
.license-summary__discount dd strong {
    display: block; margin-top: .125rem; font-size: 1rem;
}
.license-summary__rows dd [data-license-student-discount-price],
.license-summary__discount dd strong {
    color: #123152;
}
.license-summary__total dd {
    font-family: "Kanit", sans-serif; font-size: 1.875rem; line-height: 1;
}
.license-summary__button { margin-top: 1.25rem; }
.license-summary__note {
    margin: .875rem 0 0; color: #6D6A80; font-size: .8125rem; line-height: 1.5;
}
@media (max-width: 575px) {
    .license-summary__unit { align-items: flex-start; flex-direction: column; }
    .license-summary__rows > div { grid-template-columns: 1fr; gap: .35rem; }
    .license-summary__rows dd { text-align: left; }
}

/* ---------- Order ---------- */
.order-page {
    min-height: 100vh;
    padding: 8.5rem 0 5rem;
    background:
        linear-gradient(135deg, rgba(79,63,217,.08), rgba(255,122,89,.08)),
        #F7F6FB;
}
.order-page--success {
    display: flex;
    align-items: center;
}
.order-head {
    max-width: 48rem;
    margin-bottom: 2rem;
}
.order-head h1,
.order-success h1 {
    margin-bottom: .875rem;
    color: #0F0E1B;
}
.order-head p,
.order-success p {
    max-width: 42rem;
    color: #3A3852;
    font-size: 1.0625rem;
}
.order-errors {
    position: static;
    width: 100%;
    transform: none;
    margin-bottom: 1.25rem;
}
.order-errors ul {
    margin: 0;
    padding: 0;
    list-style: none;
}
.order-shell,
.order-success {
    width: 100%;
    background: rgba(255,255,255,.98);
    border: 1px solid #E6E3F0;
    border-radius: 22px;
    box-shadow: 0 24px 60px rgba(15,14,27,.14);
    padding: clamp(1.25rem, 3vw, 2.5rem);
    color: #0F0E1B;
}
.order-success {
    max-width: 48rem;
    margin: 0 auto;
}
.order-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .75rem;
    margin-bottom: 2rem;
}
.order-steps li {
    display: flex;
    align-items: center;
    gap: .75rem;
    min-height: 3.5rem;
    padding: .75rem .875rem;
    border: 1px solid #E6E3F0;
    border-radius: 14px;
    background: #F7F6FB;
    color: #6D6A80;
    font-family: "Kanit", sans-serif;
    font-weight: 600;
    transition: border-color .2s ease, background .2s ease, color .2s ease, transform .2s ease;
}
.order-steps li.is-clickable {
    cursor: pointer;
}
.order-steps li.is-clickable:hover,
.order-steps li.is-clickable:focus-visible {
    border-color: #6B5EE5;
    color: #0F0E1B;
    transform: translateY(-1px);
    outline: none;
}
.order-steps span {
    width: 2rem;
    height: 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #E8E7EE;
    color: #4F3FD9;
    flex-shrink: 0;
}
.order-steps li.is-active,
.order-steps li.is-complete {
    border-color: #4F3FD9;
    color: #123152;
    background: linear-gradient(180deg, #fff 0%, #F4F2FE 100%);
}
.order-steps li.is-active span,
.order-steps li.is-complete span {
    background: #4F3FD9;
    color: #fff;
}
.order-panel {
    display: none;
}
.order-panel.is-active {
    display: block;
}
.order-panel__head {
    margin-bottom: 1.5rem;
}
.order-panel__head span {
    display: inline-flex;
    align-items: center;
    gap: .625rem;
    margin-bottom: .5rem;
    color: #4F3FD9;
    font-family: "Kanit", sans-serif;
    font-size: .8125rem;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
}
.order-panel__head span::before {
    content: '';
    width: 1.625rem;
    height: .125rem;
    background: #FF7A59;
}
.order-panel__head h2 {
    margin: 0;
    font-size: clamp(1.625rem, 3vw, 2.375rem);
}
.order-login-box {
    display: flex;
    justify-content: space-between;
    gap: 1.25rem;
    align-items: center;
    margin-bottom: 1.5rem;
    padding: 1rem;
    border: 1px solid #E6E3F0;
    border-radius: 14px;
    background: #F7F6FB;
}
.order-login-box strong {
    display: block;
    margin-bottom: .25rem;
    color: #123152;
}
.order-login-box p {
    margin: 0;
    color: #6D6A80;
    font-size: .9375rem;
}
.order-login-box__actions {
    display: flex;
    flex-wrap: wrap;
    gap: .625rem;
    justify-content: flex-end;
}
.order-fields {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem 1.25rem;
    max-width: 62rem;
}
.order-fields .auth-field--wide {
    grid-column: 1 / -1;
}
.order-subsection {
    max-width: 62rem;
}
.order-subsection + .order-subsection {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid #ECEAF3;
}
.order-subsection h3 {
    margin: 0 0 1rem;
    color: #123152;
    font-size: 1.25rem;
}
.order-subsection__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}
.order-subsection__head h3 {
    margin-bottom: 0;
}
.order-check--inline {
    align-items: center;
    max-width: 30rem;
    padding: 0;
    font-weight: 600;
}
.order-check--inline input {
    margin-top: 0;
}
.order-billing-fields.is-hidden {
    display: none;
}
.order-summary-grid {
    display: grid;
    grid-template-columns: minmax(0, 26rem) minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}
.order-summary {
    position: static;
    border: 1px solid #E6E3F0;
    box-shadow: none;
}
.order-confirm {
    padding: 1.5rem;
    border: 1px solid #E6E3F0;
    border-radius: 18px;
    background: #F7F6FB;
}
.order-confirm h3 {
    margin-bottom: 1rem;
    color: #123152;
}
.order-confirm p {
    margin: 1rem 0 0;
    color: #6D6A80;
    font-size: .9375rem;
}
.order-check {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    padding: .875rem 0;
    color: #232238;
}
.order-check input {
    width: 1.25rem;
    height: 1.25rem;
    margin-top: .125rem;
    accent-color: #4F3FD9;
    flex-shrink: 0;
}
.order-actions {
    display: flex;
    justify-content: space-between;
    gap: .875rem;
    margin-top: 2rem;
}
.order-actions--success {
    justify-content: flex-start;
}
.order-shell.is-first-step [data-order-prev],
.order-shell:not(.is-last-step) [data-order-submit],
.order-shell.is-last-step [data-order-next] {
    display: none;
}
.order-success__list {
    display: grid;
    gap: .875rem;
    margin: 1.5rem 0 0;
}
.order-success__list div {
    display: grid;
    grid-template-columns: 10rem minmax(0, 1fr);
    gap: 1rem;
    padding-bottom: .875rem;
    border-bottom: 1px solid #ECEAF3;
}
.order-success__list div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}
.order-success__list dt {
    color: #6D6A80;
    font-weight: 700;
}
.order-success__list dd {
    margin: 0;
    color: #0F0E1B;
    font-weight: 600;
}
.order-payment {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 18rem;
    gap: 1.5rem;
    align-items: center;
    margin-top: 1.5rem;
    padding: 1.25rem;
    border: 1px solid #E6E3F0;
    border-radius: 18px;
    background: #F7F6FB;
}
.order-payment h2 {
    margin-bottom: .5rem;
    font-size: 1.5rem;
}
.order-payment p {
    margin: 0;
    color: #3A3852;
}
.order-payment__list {
    display: grid;
    gap: .625rem;
    margin: 1rem 0 0;
}
.order-payment__list div {
    display: grid;
    grid-template-columns: 9rem minmax(0, 1fr);
    gap: .75rem;
}
.order-payment__list dt {
    color: #6D6A80;
    font-weight: 700;
}
.order-payment__list dd {
    margin: 0;
    color: #0F0E1B;
    font-weight: 800;
    overflow-wrap: anywhere;
}
.order-payment__notice {
    color: #785100;
}
.order-payment__qr {
    display: flex;
    justify-content: center;
}
.order-payment__qr img {
    width: 100%;
    max-width: 16.25rem;
    height: auto;
    border-radius: .875rem;
    background: #fff;
    border: 1px solid #E6E3F0;
    padding: .75rem;
}
@media (max-width: 991px) {
    .order-summary-grid {
        grid-template-columns: 1fr;
    }
    .order-payment {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 767px) {
    .order-page {
        padding: 6.5rem 0 3rem;
    }
    .order-steps {
        grid-template-columns: 1fr;
    }
    .order-fields {
        grid-template-columns: 1fr;
    }
    .order-subsection__head {
        flex-direction: column;
    }
    .order-login-box,
    .order-actions {
        align-items: stretch;
        flex-direction: column;
    }
    .order-login-box__actions {
        justify-content: flex-start;
    }
    .order-actions .btn {
        width: 100%;
    }
    .order-success__list div {
        grid-template-columns: 1fr;
        gap: .25rem;
    }
    .order-payment__list div {
        grid-template-columns: 1fr;
        gap: .25rem;
    }
}

/* ---------- Contact ---------- */
.contact { background: #fff; position: relative; }
.contact__wrapper {
    display: grid; grid-template-columns: 1fr 1.2fr; gap: 4rem; align-items: stretch;
}
@media (max-width: 1199px) { .contact__wrapper { gap: 2.5rem; } }
@media (max-width: 991px) { .contact__wrapper { grid-template-columns: 1fr; gap: 2.5rem; } }
.contact__info { display: flex; flex-direction: column; gap: 1.75rem; }
.contact__lead { color: #3A3852; font-size: 1.0625rem; margin-bottom: .5rem; }
.contact__items { display: flex; flex-direction: column; gap: 1.25rem; }
.contact__item { display: flex; align-items: flex-start; gap: 1.125rem; }
.contact__item__icon {
    width: 3.25rem; height: 3.25rem; border-radius: 14px;
    background: linear-gradient(135deg, #4F3FD9, #FF7A59);
    color: #fff; display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.375rem; flex-shrink: 0;
    box-shadow: 0 2px 8px rgba(15,14,27,.08);
}
.contact__item__icon--image {
    background: transparent;
    box-shadow: none;
}
.contact__item__icon img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: drop-shadow(0 2px 8px rgba(15,14,27,.08));
}
.contact__item__body strong {
    display: block; font-family: "Kanit", sans-serif; font-size: .8125rem;
    text-transform: uppercase; letter-spacing: 1.4px; color: #4F3FD9; margin-bottom: .25rem;
}
.contact__item__body a,
.contact__item__body span {
    display: block; font-size: 1.0625rem; color: #0F0E1B; font-weight: 500;
}
.contact__item__body a:hover { color: #4F3FD9; }
.contact__map {
    margin-top: .5rem; border-radius: 14px; overflow: hidden;
    background: #E8E7EE; aspect-ratio: 16/9;
    display: flex; align-items: center; justify-content: center;
    color: #8B89A1; font-size: .8125rem; text-transform: uppercase; letter-spacing: 1.4px;
}
.contact__form-wrap {
    background: #F5F4F8; border-radius: 22px; padding: 2.5rem;
    border: 1px solid #E8E7EE;
}
@media (max-width: 767px) { .contact__form-wrap { padding: 1.5rem; } }

.form-alert {
    margin-bottom: 1.25rem; padding: .875rem 1rem; border-radius: 10px;
    font-size: .9375rem; font-weight: 600; line-height: 1.45;
}
.form-alert--success {
    background: rgba(71, 186, 127, .12); color: #20724A; border: 1px solid rgba(71, 186, 127, .25);
}
.form-alert--danger {
    background: rgba(255, 122, 89, .12); color: #A33822; border: 1px solid rgba(255, 122, 89, .28);
}

.form { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
@media (max-width: 575px) { .form { grid-template-columns: 1fr; } }
.form__field { display: flex; flex-direction: column; gap: .5rem; }
.form__field--full { grid-column: 1 / -1; }
.form__label {
    font-family: "Kanit", sans-serif; font-size: .8125rem; font-weight: 500;
    text-transform: uppercase; letter-spacing: 1.2px; color: #232238;
}
.form__label .is-required { color: #FF7A59; }
.form__input, .form__textarea {
    font-family: "Poppins", sans-serif; width: 100%;
    padding: .875rem 1.125rem; background: #fff; color: #0F0E1B;
    border: 1px solid #C8C6D6; border-radius: 8px;
    font-size: .9375rem; line-height: 1.4;
    transition: border-color .2s ease, box-shadow .2s ease;
}
.form__input::placeholder, .form__textarea::placeholder { color: #8B89A1; }
.form__input:focus, .form__textarea:focus {
    outline: none; border-color: #6B5EE5;
    box-shadow: 0 0 0 4px rgba(79,63,217,.15);
}
.form__textarea { min-height: 8.75rem; resize: vertical; }

.form__check {
    display: flex; align-items: flex-start; gap: .75rem; cursor: pointer;
    font-size: .875rem; color: #3A3852; line-height: 1.5; position: relative;
}
.form__check input {
    position: absolute; opacity: 0; pointer-events: none;
}
.form__check input:checked + .form__check__box {
    background: #4F3FD9; border-color: #4F3FD9;
}
.form__check input:checked + .form__check__box::after {
    opacity: 1; transform: rotate(45deg) scale(1);
}
.form__check__box {
    position: relative; width: 1.25rem; height: 1.25rem;
    border-radius: .3125rem; border: 1.5px solid #C8C6D6;
    background: #fff; flex-shrink: 0; margin-top: .125rem;
    transition: all .2s ease;
}
.form__check__box::after {
    content: ''; position: absolute; top: .125rem; left: .375rem;
    width: .3125rem; height: .625rem;
    border: solid #fff; border-width: 0 2px 2px 0;
    transform: rotate(45deg) scale(0); opacity: 0;
    transition: all .2s ease;
}
.form__check a { color: #4F3FD9; text-decoration: underline; }
.form__submit { margin-top: .5rem; }

/* ---------- Footer ---------- */
.footer { background: #0F0E1B; color: rgba(255,255,255,.75); padding: 4.5rem 0 1.5rem; }
@media (max-width: 991px) { .footer { padding: 3.5rem 0 1.25rem; } }
.footer__top {
    display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 3.5rem; align-items: flex-start;
}
@media (max-width: 1199px) { .footer__top { gap: 2.5rem; } }
@media (max-width: 991px) {
    .footer__top { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
    .footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 575px) { .footer__top { grid-template-columns: 1fr; } }
.footer__brand { display: flex; flex-direction: column; gap: 1.25rem; }
.footer__brand img,
.footer__brand svg { height: 3.375rem; width: auto; }
.footer__about { font-size: .9375rem; color: rgba(255,255,255,.6); max-width: 22.5rem; line-height: 1.6; }
.footer__socials { display: flex; gap: .75rem; margin-top: .5rem; }
.footer__socials a {
    width: 2.5rem; height: 2.5rem; display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%; background: #161526; color: #fff; font-size: 1rem;
    transition: background-color .2s ease, transform .2s ease;
}
.footer__socials a:hover { background: #4F3FD9; transform: translateY(-2px); color: #fff; }
.footer__col h4 {
    color: #fff; font-size: .875rem; text-transform: uppercase;
    letter-spacing: 1.5px; margin-bottom: 1.25rem;
}
.footer__list { display: flex; flex-direction: column; gap: .75rem; }
.footer__list a { color: rgba(255,255,255,.7); font-size: .9375rem; }
.footer__list a:hover { color: #9B91F0; }
.footer__contact { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .875rem; }
.footer__contact li { display: flex; align-items: center; gap: .75rem; font-size: .9375rem; color: rgba(255,255,255,.78); }
.footer__contact i {
    width: 2.125rem; height: 2.125rem; display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%; background: rgba(255,255,255,.06);
    font-style: normal; color: #9B91F0; font-size: .875rem;
}
.footer__contact a:hover { color: #FFB7A4; }
.footer__bottom {
    display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap;
    gap: 1rem; margin-top: 3.5rem; padding-top: 1.5rem;
    border-top: 1px solid rgba(255,255,255,.08);
    font-size: .8125rem; color: rgba(255,255,255,.5);
}
@media (max-width: 767px) { .footer__bottom { flex-direction: column; align-items: flex-start; } }
.footer__legal { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.footer__legal a { color: rgba(255,255,255,.6); font-size: .8125rem; }
.footer__legal a:hover { color: #fff; }

/* ---------- Text page ---------- */
.text-page {
    min-height: 100vh;
    padding: 8.5rem 0 5rem;
    background:
        linear-gradient(135deg, rgba(79,63,217,.12), rgba(255,122,89,.08)),
        #F7F6FB;
}
.text-page__head {
    max-width: 52rem;
    margin-bottom: 2rem;
}
.text-page__head h1 {
    margin-bottom: 0;
    font-size: clamp(2.25rem, 4vw, 4rem);
}
.text-page__content {
    max-width: 58rem;
    padding: clamp(1.5rem, 3vw, 2.5rem);
    background: rgba(255,255,255,.96);
    border: 1px solid #E6E3F0;
    border-radius: 1rem;
    box-shadow: 0 18px 42px rgba(15,14,27,.1);
    color: #3A3852;
    font-size: 1rem;
    line-height: 1.8;
}
.text-page__content p {
    margin: 0 0 1.25rem;
}
.text-page__content p:last-child {
    margin-bottom: 0;
}

/* ---------- Profile ---------- */
.profile-page {
    min-height: 100vh;
    padding: 8.5rem 0 5rem;
    background:
        linear-gradient(135deg, rgba(79,63,217,.12), rgba(255,122,89,.08)),
        #F7F6FB;
}
.profile-hero {
    max-width: 52rem;
    margin-bottom: 2.25rem;
}
.profile-hero h1 {
    margin-bottom: .75rem;
    font-size: clamp(2.25rem, 4vw, 4rem);
}
.profile-hero p {
    margin: 0;
    color: #3A3852;
    font-size: 1.125rem;
}
.profile-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .875rem;
    margin-top: 1.5rem;
}
.profile-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1.25rem;
}
.profile-card {
    width: 100%;
    background: rgba(255,255,255,.96);
    border: 1px solid #E6E3F0;
    border-radius: 1rem;
    box-shadow: 0 18px 42px rgba(15,14,27,.1);
    padding: clamp(1.375rem, 3vw, 2rem);
}
.profile-card--wide {
    grid-column: 1 / -1;
}
.profile-card__label {
    display: inline-flex;
    align-items: center;
    gap: .625rem;
    margin-bottom: .75rem;
    color: #4F3FD9;
    font-family: "Kanit", sans-serif;
    font-size: .8125rem;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
}
.profile-card__label::before {
    content: '';
    width: 1.625rem;
    height: .125rem;
    background: #FF7A59;
}
.profile-card h2 {
    margin-bottom: 1.25rem;
    font-size: 1.75rem;
}
.profile-form {
    max-width: 50%;
}
.profile-form .auth-actions {
    justify-items: flex-start;
}
.profile-form .auth-actions .btn {
    width: auto;
}
.profile-list {
    display: grid;
    gap: .875rem;
    margin: 0;
}
.profile-list div {
    display: grid;
    grid-template-columns: 10rem minmax(0, 1fr);
    gap: 1rem;
    padding-bottom: .875rem;
    border-bottom: 1px solid #ECEAF3;
}
.profile-list div:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}
.profile-list dt {
    color: #6D6A80;
    font-weight: 700;
}
.profile-list dd {
    margin: 0;
    color: #0F0E1B;
    overflow-wrap: anywhere;
}
.profile-pill {
    display: inline-flex;
    align-items: center;
    min-height: 1.875rem;
    padding: 0 .75rem;
    border-radius: 999px;
    font-size: .8125rem;
    font-weight: 800;
}
.profile-pill--success {
    background: #E9F9EF;
    color: #176C35;
}
.profile-pill--warning {
    background: #FFF7DF;
    color: #785100;
}
.profile-access {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}
.profile-access div {
    min-height: 7rem;
    padding: 1.25rem;
    border-radius: .875rem;
    background: #F5F4F8;
    border: 1px solid #E8E7EE;
}
.profile-access strong {
    display: block;
    color: #4F3FD9;
    font-family: "Kanit", sans-serif;
    font-size: 2.25rem;
    line-height: 1;
}
.profile-access span {
    display: block;
    margin-top: .5rem;
    color: #3A3852;
    font-weight: 700;
}
.profile-tags {
    display: flex;
    flex-wrap: wrap;
    gap: .625rem;
    margin-top: 1.25rem;
}
.profile-tags span {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0 .75rem;
    border-radius: 999px;
    background: #FFF1DA;
    color: #0F0E1B;
    font-weight: 800;
}
.profile-empty {
    margin: 0;
    color: #6D6A80;
}
.profile-orders {
    display: grid;
    gap: 1rem;
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid #ECEAF3;
}
.profile-orders h3 {
    margin: 0;
    color: #123152;
    font-size: 1.25rem;
}
.profile-order {
    padding: 1.125rem;
    border: 1px solid #E6E3F0;
    border-radius: 1rem;
    background: #F7F6FB;
}
.profile-order__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .875rem;
    margin-bottom: 1rem;
}
.profile-order__head strong {
    color: #123152;
    font-family: "Kanit", sans-serif;
    font-size: 1.125rem;
}
.profile-order__list,
.profile-order__payment dl {
    display: grid;
    gap: .5rem;
    margin: 0;
}
.profile-order__list div,
.profile-order__payment dl div {
    display: grid;
    grid-template-columns: 8.5rem minmax(0, 1fr);
    gap: .75rem;
}
.profile-order__list dt,
.profile-order__payment dt {
    color: #6D6A80;
    font-weight: 700;
}
.profile-order__list dd,
.profile-order__payment dd {
    margin: 0;
    color: #0F0E1B;
    font-weight: 700;
    overflow-wrap: anywhere;
}
.profile-order__payment {
    display: grid;
    grid-template-columns: 10rem minmax(0, 1fr);
    gap: 1rem;
    align-items: center;
    margin-top: 1rem;
}
.profile-order__payment img {
    width: 10rem;
    height: 10rem;
    border-radius: .75rem;
    background: #fff;
    border: 1px solid #E6E3F0;
    padding: .5rem;
}
.profile-order__notice {
    margin: 1rem 0 0;
    color: #785100;
    font-weight: 700;
}
.profile-license-manager {
    display: grid;
    gap: 1.125rem;
    padding: 1.125rem;
    border: 1px solid #E6E3F0;
    border-radius: 1rem;
    background: #F7F6FB;
}
.profile-license-manager + .profile-license-manager {
    margin-top: 1rem;
}
.profile-license-manager__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}
.profile-license-manager__head h3 {
    margin: 0 0 .25rem;
    color: #123152;
    font-size: 1.25rem;
}
.profile-license-manager__head p {
    margin: 0;
    color: #6D6A80;
    font-weight: 700;
}
.profile-invite-form {
    display: grid;
    gap: .875rem;
}
.profile-invite-form .auth-actions {
    justify-items: flex-start;
}
.profile-invitations {
    display: grid;
    gap: .625rem;
}
.profile-invitation {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .875rem 1rem;
    border: 1px solid #ECEAF3;
    border-radius: .875rem;
    background: #fff;
}
.profile-invitation strong,
.profile-invitation span {
    display: block;
}
.profile-invitation strong {
    color: #0F0E1B;
}
.profile-invitation__main {
    min-width: 0;
}
.profile-invitation__main span {
    margin-top: .125rem;
    color: #6D6A80;
    font-size: .875rem;
}
.profile-invitation__meta,
.profile-invitation__actions {
    display: flex;
    align-items: center;
    gap: .5rem;
}
.profile-invitation__actions form {
    margin: 0;
}
.profile-invitation__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.375rem;
    height: 2.375rem;
    border: 1px solid rgba(79, 63, 217, .2);
    border-radius: .75rem;
    background: rgba(79, 63, 217, .08);
    color: #4F3FD9;
    cursor: pointer;
    transition: background .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
}
.profile-invitation__action svg {
    width: 1.125rem;
    height: 1.125rem;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.profile-invitation__action:hover {
    background: #4F3FD9;
    border-color: #4F3FD9;
    color: #fff;
    transform: translateY(-.0625rem);
}
.profile-invitation__action--danger {
    border-color: rgba(255, 122, 89, .25);
    background: rgba(255, 122, 89, .1);
    color: #FF6F55;
}
.profile-invitation__action--danger:hover {
    background: #FF6F55;
    border-color: #FF6F55;
    color: #fff;
}
.evaluation-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
}
.evaluation-table-wrap {
    overflow-x: auto;
}
.evaluation-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 48rem;
}
.evaluation-table th {
    padding: .875rem 1rem;
    border-bottom: 1px solid #DCD9EA;
    color: #6D6A80;
    font-size: .75rem;
    letter-spacing: .8px;
    text-align: left;
    text-transform: uppercase;
}
.evaluation-table td {
    padding: 1rem;
    border-bottom: 1px solid #ECEAF3;
    color: #0F0E1B;
    vertical-align: middle;
}
.evaluation-table tbody tr:last-child td {
    border-bottom: 0;
}
.evaluation-table td strong,
.evaluation-table td span,
.evaluation-table td small {
    display: block;
}
.evaluation-table td span {
    margin-top: .1875rem;
    color: #6D6A80;
    font-size: .875rem;
    font-weight: 600;
}
.evaluation-score {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-width: 4.25rem;
    min-height: 2.125rem;
    margin: 0 0 .25rem;
    border-radius: 999px;
    font-family: "Kanit", sans-serif;
    font-size: 1rem !important;
    font-weight: 800 !important;
}
.evaluation-score--good {
    background: #E9F9EF;
    color: #176C35 !important;
}
.evaluation-score--mid {
    background: #FFF7DF;
    color: #785100 !important;
}
.evaluation-score--low {
    background: #FFEDE8;
    color: #A63721 !important;
}
@media (max-width: 575px) {
    .text-page { padding: 7rem 0 3rem; }
    .profile-page { padding: 7rem 0 3rem; }
    .profile-form { max-width: 100%; }
    .profile-list div { grid-template-columns: 1fr; gap: .25rem; }
    .profile-access { grid-template-columns: 1fr; }
    .profile-order__head,
    .profile-order__payment {
        align-items: flex-start;
        grid-template-columns: 1fr;
    }
    .profile-order__head {
        flex-direction: column;
    }
    .profile-license-manager__head,
    .profile-invitation {
        flex-direction: column;
        align-items: flex-start;
    }
    .profile-invitation__meta {
        width: 100%;
        justify-content: space-between;
    }
    .profile-order__list div,
    .profile-order__payment dl div {
        grid-template-columns: 1fr;
        gap: .25rem;
    }
    .evaluation-card__head {
        flex-direction: column;
    }
}
/* Generated hero thumbnails + language topic panels */
.hero__card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}.flag{display:inline-block;width:2.375rem;height:1.625rem;border-radius:.3125rem;box-shadow:0 .25rem .875rem rgba(15,14,27,.16);flex:0 0 auto}.flag--gb{background:linear-gradient(90deg,transparent 42%,#fff 42% 58%,transparent 58%),linear-gradient(0deg,transparent 38%,#fff 38% 62%,transparent 62%),linear-gradient(90deg,transparent 46%,#c8102e 46% 54%,transparent 54%),linear-gradient(0deg,transparent 44%,#c8102e 44% 56%,transparent 56%),#012169}.flag--es{background:linear-gradient(180deg,#aa151b 0 25%,#f1bf00 25% 75%,#aa151b 75% 100%)}.flag--fr{background:linear-gradient(90deg,#002654 0 33.33%,#fff 33.33% 66.66%,#ed2939 66.66% 100%)}.hero__flags a{width:auto;min-width:2.75rem;padding:0 .875rem;gap:.625rem;border-radius:999px;font-size:.875rem;font-weight:700}.hero__flags a .flag{width:1.75rem;height:1.125rem;box-shadow:none}.languages{background:linear-gradient(180deg,#fff 0%,#f5f4f8 100%)}.languages__head{max-width:48.75rem;margin-bottom:2.875rem}.languages__grid{display:grid;gap:1.75rem}.language-panel{overflow:hidden;border-radius:1.375rem;background:#fff;box-shadow:0 12px 28px rgba(15,14,27,.12);border:1px solid rgba(200,198,214,.7)}.language-panel[id]{scroll-margin-top:6rem}.language-panel__header{display:flex;align-items:center;gap:1.125rem;padding:1.625rem 1.875rem;background:linear-gradient(135deg,rgba(79,63,217,.09),rgba(255,122,89,.08))}.language-panel__header h3{margin-bottom:.25rem;font-size:1.875rem}.language-panel__header p{margin:0;color:#3a3852}.language-panel__body{display:grid;grid-template-columns:16.25rem 1fr;gap:1.625rem;padding:1.875rem}.language-panel__topics{display:flex;flex-direction:column;gap:.625rem}.language-panel__topic{border:1px solid #e8e7ee;border-radius:.5rem;background:#f5f4f8;color:#0f0e1b;cursor:pointer;padding:.875rem 1rem;text-align:left;font-weight:700;transition:background .2s ease,border-color .2s ease,color .2s ease,transform .2s ease}.language-panel__topic:hover,.language-panel__topic.is-active{background:#4f3fd9;border-color:#4f3fd9;color:#fff;transform:translateX(.25rem)}.language-panel__subtopics{min-height:15.625rem}.language-panel__subtopic{display:none}.language-panel__subtopic.is-active{display:block}.language-panel__subtopic h4{font-size:1.625rem;margin-bottom:1.125rem}.subtopic-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:3.875rem;padding:1rem 1.125rem;border:1px solid #e8e7ee;border-radius:.875rem;background:#fff;color:#0f0e1b;box-shadow:0 2px 8px rgba(15,14,27,.08);margin-bottom:.75rem;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}.subtopic-card:hover{color:#0f0e1b;border-color:#c9c2f7;transform:translateY(-.125rem);box-shadow:0 12px 28px rgba(15,14,27,.12)}.subtopic-card strong{display:inline-flex;align-items:center;min-height:1.75rem;padding:0 .625rem;border-radius:999px;background:#ffc857;color:#0f0e1b;font-size:.75rem;letter-spacing:.8px}.subtopic-card.is-free{background:linear-gradient(135deg,rgba(255,200,87,.28),#fff 48%);border-color:rgba(255,200,87,.9)}@media screen and (max-width:991px){.language-panel__body{grid-template-columns:1fr}.language-panel__topics{display:grid;grid-template-columns:repeat(2,1fr)}.language-panel__topic:hover,.language-panel__topic.is-active{transform:translateY(-.125rem)}}@media screen and (max-width:767px){.languages__head{margin-bottom:2rem}.language-panel{border-radius:.875rem}.language-panel__header,.language-panel__body{padding:1.25rem}.language-panel__header{align-items:flex-start}.language-panel__header h3{font-size:1.5rem}.subtopic-card{align-items:flex-start;flex-direction:column}}@media screen and (max-width:575px){.language-panel__topics{grid-template-columns:1fr}.hero__flags a{width:100%;justify-content:flex-start}}
.language-panel__topics-wrap{display:flex;flex-direction:column;gap:.875rem}.language-panel__topic.is-hidden{display:none}.language-panel.is-topics-expanded .language-panel__topic.is-hidden{display:block}.language-panel__more{width:100%;min-height:2.75rem;border:1px dashed #c9c2f7;border-radius:.5rem;background:rgba(244,242,254,.85);color:#4f3fd9;cursor:pointer;font-weight:800;transition:background .2s ease,border-color .2s ease,transform .2s ease}.language-panel__more:hover{background:#f4f2fe;border-color:#4f3fd9;transform:translateY(-.125rem)}
.subtopic-card__text{display:grid;gap:.1875rem}.subtopic-card__text small{color:#77738b;font-size:.75rem;font-weight:600}.subtopic-card__badge--unlocked{background:#4f3fd9;color:#fff}.subtopic-card__badge--locked{background:#e8e7ee;color:#3a3852}.subtopic-card.is-unlocked:not(.is-free){border-color:rgba(79,63,217,.35)}.subtopic-card.is-locked{background:linear-gradient(135deg,rgba(232,231,238,.82),#fff 58%);color:#3a3852}.subtopic-card.is-locked:hover{border-color:#c8c6d6;box-shadow:0 2px 8px rgba(15,14,27,.08)}
.flag--gb{background:url("../img/flag-gb.svg") center/cover no-repeat!important}
.hero__flags a,.hero__flags a:hover{color:#fff}
