.activity-chart-wrap{padding:1rem;border:1px solid var(--outline-variant);background:linear-gradient(180deg,var(--surface-container-low) 0,var(--surface-container) 100%)}.activity-chart-wrap__title{margin:0 0 1.1rem}.activity-chart{display:flex;gap:.375rem;align-items:flex-end}.activity-chart__column{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:.375rem}.activity-chart__bar-container{width:100%;height:8rem;display:flex;align-items:flex-end;justify-content:center}.activity-chart__bar{width:55%;min-width:12px;max-width:28px;border-radius:.4rem .4rem 0 0;background:var(--surface-container-highest);transition:height .3s ease}.activity-chart__bar--active{background:linear-gradient(180deg,var(--primary) 0,var(--tertiary) 100%)}.activity-chart__value{min-height:1rem;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.activity-chart__label{opacity:.6}@media (min-width:48rem){.activity-chart-wrap{padding:1.25rem}.activity-chart{gap:.5rem}}.badge-gallery{display:flex;flex-direction:column;gap:.9rem}.badge-gallery__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.badge-gallery__header h6{margin:0}.badge-gallery__count{opacity:.72;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.badge-gallery__grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:.75rem;gap:.75rem}@media (min-width:40rem){.badge-gallery__grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:64rem){.badge-gallery__grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.badge-gallery__empty{display:flex;flex-direction:column;align-items:center;padding:2rem;text-align:center;opacity:.5}.badge-gallery .tabs{border:1px solid var(--outline-variant);border-radius:.9rem;overflow:hidden}.badge-gallery .tabs>a{justify-content:center;min-height:2.5rem}.generation-status{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:2rem;text-align:center;gap:2rem}.generation-status__steps{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:20rem}.generation-status__step{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;border-radius:1rem;transition:all .4s ease}.generation-status__reassurance{max-width:24rem;transition:opacity .6s ease}.generation-status__fallback{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:24rem}.grade-controls{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;width:100%}.grade-controls__btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1 1;min-width:4.5rem;max-width:7rem;padding:.875rem .75rem;cursor:pointer;transition:opacity .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;text-align:center}.grade-controls__btn:hover{opacity:.85}.grade-controls__label{font-weight:600;font-size:.875rem}.grade-controls__sublabel{opacity:.6}.navbar{position:fixed;top:0;left:0;right:0;z-index:50;transition:background-color .3s,box-shadow .3s}.navbar__inner{display:flex;align-items:center;gap:1rem;width:100%;max-width:75rem;margin:0 auto;padding:0 1.5rem;height:64px;min-width:0}.navbar__inner>.navbar__brand{margin-right:auto;text-decoration:none;color:inherit;flex-shrink:0}.navbar__brand h5{white-space:nowrap}.navbar__links{display:flex;align-items:center;gap:1.5rem;min-width:0}.navbar__link{text-decoration:none;color:inherit;white-space:nowrap}.navbar__cta{flex-shrink:0;white-space:nowrap}.navbar__menu-toggle{display:none}.navbar__avatar-btn{padding:0}.navbar__avatar-img{width:2rem;height:2rem;object-fit:cover}.navbar__avatar-initials{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem}@media (max-width:600px){.navbar__inner{gap:.75rem;padding:0 1rem}.navbar__brand h5{font-size:1.75rem}}@media (max-width:980px){.navbar__cta,.navbar__links{display:none!important}.navbar__menu-toggle{display:inline-flex!important}}@media (max-width:420px){.navbar__brand h5{font-size:1.5rem}}.onboarding-stepper{display:flex;min-height:100dvh}.onboarding-stepper__rail{display:none;flex-direction:column;gap:.25rem;padding:2rem 1.5rem;min-width:14rem}.onboarding-stepper__rail-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border-radius:1rem;cursor:default;transition:background .2s ease}.onboarding-stepper__rail-item--active{font-weight:600}.onboarding-stepper__rail-indicator{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;font-size:.75rem;font-weight:600}.onboarding-stepper__main{flex:1 1;display:flex;flex-direction:column;padding:2rem 1.5rem;max-width:44rem;margin:0 auto;width:100%}.onboarding-stepper__header{text-align:center;-webkit-margin-after:2rem;margin-block-end:2rem}.onboarding-stepper__options{display:grid;grid-gap:.75rem;gap:.75rem;grid-template-columns:1fr;align-content:start}.onboarding-stepper__option{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;min-height:3.5rem;cursor:pointer;text-align:left;border:1px solid var(--outline-variant);border-radius:1rem;transition:background .2s ease,border-color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.onboarding-stepper__option:hover{background:var(--surface-container-high)}.onboarding-stepper__option[aria-pressed=true]{border-color:var(--primary)}.onboarding-stepper__option-text{display:flex;flex-direction:column;gap:.125rem;flex:1 1;min-width:0}.onboarding-stepper__footer{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0;-webkit-margin-before:auto;margin-block-start:auto;position:-webkit-sticky;position:sticky;bottom:0;z-index:1}.onboarding-stepper__footer-spacer{width:5rem}@media (min-width:48rem){.onboarding-stepper__rail{display:flex}.onboarding-stepper__options{grid-template-columns:1fr 1fr}}.page-header{display:grid;grid-gap:.35rem;gap:.35rem;-webkit-margin-after:1.5rem;margin-block-end:1.5rem}.page-header h4{margin:0;line-height:1.15}.page-header p{margin:0;opacity:.75}.placement-quiz{display:flex;min-height:100dvh}.placement-quiz__sidebar{display:none;flex-direction:column;gap:1rem;padding:2rem 1.5rem;min-width:16rem}.placement-quiz__level-list{display:flex;flex-direction:column;gap:.25rem}.placement-quiz__level-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border-radius:.75rem}.placement-quiz__level-indicator{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;font-size:.75rem;font-weight:600}.placement-quiz__main{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;max-width:36rem;margin:0 auto;width:100%}.placement-quiz__progress-header{width:100%;text-align:center;-webkit-margin-after:2rem;margin-block-end:2rem}.placement-quiz__question{width:100%;text-align:center;-webkit-margin-after:1.5rem;margin-block-end:1.5rem}.placement-quiz__options{display:flex;flex-direction:column;gap:.75rem;width:100%}.placement-quiz__option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1rem 1.25rem;border-radius:1rem;text-align:left;cursor:pointer;transition:all .2s ease}.placement-quiz__feedback{display:flex;align-items:flex-start;gap:.75rem;width:100%;padding:1rem;border-radius:1rem;-webkit-margin-before:1rem;margin-block-start:1rem}.placement-quiz__actions{display:flex;gap:.75rem;-webkit-margin-before:1.5rem;margin-block-start:1.5rem}.placement-quiz__completion{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center;padding:2rem}.placement-quiz__level-badge{width:6rem;height:6rem;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1.5rem;font-weight:700}.placement-quiz__intro{display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center;padding:2rem}@media (min-width:48rem){.placement-quiz__sidebar{display:flex}}.avatar-wrapper{position:relative;flex-shrink:0}.avatar,.avatar-wrapper{display:inline-flex;align-items:center;justify-content:center}.avatar{overflow:hidden;z-index:1}.avatar__initials{font-size:.75em;text-transform:uppercase;-webkit-user-select:none;-moz-user-select:none;user-select:none}.avatar__ring{position:absolute;top:0;left:0;z-index:0}.avatar__ring circle{fill:none}.avatar__ring-track{stroke:var(--surface-container-high)}.avatar__ring-fill{stroke:var(--primary);transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1)}.lesson-list-item{position:relative;overflow:hidden;padding:0;border:1px solid color-mix(in srgb,var(--outline-variant) 70%,transparent);background:color-mix(in srgb,var(--surface) 82%,var(--surface-container-low) 18%);transition:border-color .22s ease,box-shadow .22s ease,transform .22s ease}.lesson-list-item__body{display:grid;grid-template-columns:minmax(0,1fr);align-items:stretch;grid-gap:.95rem;gap:.95rem}.lesson-list-item--with-image .lesson-list-item__body{grid-template-columns:9.5rem minmax(0,1fr)}.lesson-list-item__media{overflow:hidden}.lesson-list-item__image,.lesson-list-item__media{min-height:100%;border-top-left-radius:inherit;border-bottom-left-radius:inherit;border-top-right-radius:0;border-bottom-right-radius:0}.lesson-list-item__image{width:100%;height:100%;object-fit:cover;border-right:1px solid color-mix(in srgb,var(--outline-variant) 55%,transparent)}.lesson-list-item__content{min-width:0;display:grid;grid-gap:.72rem;gap:.72rem;padding:1rem}.lesson-list-item--with-image .lesson-list-item__content{padding-left:0}.lesson-list-item__header{display:block}.lesson-list-item__title{margin:0;font-size:clamp(1.18rem,1.5vw,1.45rem);line-height:1.14;letter-spacing:-.02em}.lesson-list-item__subtitle{margin:.35rem 0 0;color:var(--on-surface-variant);line-height:1.42}.lesson-list-item__meta{margin:0;color:var(--on-surface-variant);font-size:.84rem;display:flex;align-items:center;flex-wrap:wrap;gap:.45rem}.lesson-list-item__meta-item{display:inline-flex;align-items:center}.lesson-list-item__meta-item:not(:last-child):after{content:"•";margin-left:.45rem;color:color-mix(in srgb,var(--on-surface-variant) 42%,transparent)}.lesson-list-item__progress{width:100%;height:.32rem;border-radius:999px;overflow:hidden;background:color-mix(in srgb,var(--outline-variant) 28%,var(--surface-container-highest))}.lesson-list-item__progress-fill{height:100%;border-radius:inherit;background:color-mix(in srgb,var(--primary) 72%,var(--surface));transition:width .26s ease}.lesson-list-item__footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.lesson-list-item__status{display:inline-flex;align-items:center;gap:.28rem;color:var(--on-surface-variant);font-size:.88rem}.lesson-list-item__action{border-radius:999px;min-height:2.15rem;padding:0 .9rem;border:1px solid color-mix(in srgb,var(--outline) 40%,transparent);font-weight:600;font-size:.9rem;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease}.lesson-list-item__action:focus-visible:not(:disabled),.lesson-list-item__action:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--elevation-1);outline:none}.lesson-list-item__action--primary{background:color-mix(in srgb,var(--primary-container) 72%,var(--surface));color:var(--on-primary-container);border-color:color-mix(in srgb,var(--primary) 24%,transparent)}.lesson-list-item__action--secondary{background:transparent;color:var(--on-surface)}.lesson-list-item--in_progress{border-color:color-mix(in srgb,var(--primary) 26%,var(--outline-variant))}.lesson-list-item--completed{border-color:color-mix(in srgb,var(--outline-variant) 72%,transparent)}.lesson-list-item--locked{border-color:color-mix(in srgb,var(--outline-variant) 80%,transparent);background:color-mix(in srgb,var(--surface-container-low) 92%,var(--outline-variant) 8%)}.lesson-list-item--locked .lesson-list-item__meta,.lesson-list-item--locked .lesson-list-item__status,.lesson-list-item--locked .lesson-list-item__subtitle,.lesson-list-item--locked .lesson-list-item__title{color:color-mix(in srgb,var(--on-surface) 72%,transparent)}.lesson-list-item--locked .lesson-list-item__action{opacity:.72}@media (max-width:48rem){.lesson-list-item--with-image .lesson-list-item__body{grid-template-columns:7.6rem minmax(0,1fr);align-items:start}.lesson-list-item__content{padding:.9rem 1rem}.lesson-list-item--with-image .lesson-list-item__content{padding-left:.75rem}.lesson-list-item__header{display:block}}@media (max-width:36rem){.lesson-list-item--with-image .lesson-list-item__body{grid-template-columns:1fr;gap:0}.lesson-list-item__content{padding:.95rem 1rem 1rem}.lesson-list-item__image,.lesson-list-item__media{border-top-left-radius:inherit;border-top-right-radius:inherit;border-bottom-left-radius:0;border-bottom-right-radius:0}.lesson-list-item__image{min-height:8.5rem;max-height:9.5rem;border-right:0;border-bottom:1px solid color-mix(in srgb,var(--outline-variant) 55%,transparent)}.lesson-list-item__action{margin-left:auto}.lesson-list-item__footer{padding-bottom:.05rem}}.lesson-list-item__details{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;background:color-mix(in srgb,var(--surface-container-highest) 50%,transparent);border-radius:.5rem;margin-top:.25rem}.lesson-list-item__detail-group{display:flex;flex-direction:column;gap:.25rem}.lesson-list-item__detail-group>.bold{color:var(--on-surface)}.lesson-list-item__detail-list{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:.25rem .75rem;color:var(--on-surface-variant)}.lesson-list-item__detail-list li{position:relative}.lesson-list-item__detail-list li:not(:last-child):after{content:"•";position:absolute;right:-.5rem;color:color-mix(in srgb,var(--on-surface-variant) 40%,transparent)}.progress-bar-wrap{width:100%}.progress-bar-wrap__header{display:flex;justify-content:space-between;-webkit-margin-after:.25rem;margin-block-end:.25rem}.progress-bar-wrap__value{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.scenario-browser{display:flex;flex-direction:column;gap:1.25rem}.scenario-browser__categories{display:flex;flex-wrap:wrap;gap:.5rem}.scenario-browser__grid{gap:1rem}.scenario-browser__empty{display:flex;flex-direction:column;align-items:center;padding:3rem 1rem;opacity:.5;text-align:center}.profile-header{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-gap:1.05rem;gap:1.05rem;padding:1.5rem;border-radius:1.5rem;background:linear-gradient(130deg,var(--primary-container) 0,var(--surface-container-low) 46%,var(--tertiary-container) 130%)}.profile-header__identity{display:flex;align-items:flex-start;gap:1rem;grid-column:span 12;min-width:0}.profile-header__identity .avatar{-webkit-margin-before:.15rem;margin-block-start:.15rem}.profile-header__info{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem}.profile-header__name{margin:0;line-height:1.2}.profile-header__level-row{gap:.5rem}.profile-header__xp-text{opacity:.8;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.profile-header__joined{margin:0;opacity:.72}.profile-header__streak{grid-column:span 12;padding:1.05rem;border-radius:18px;background:var(--surface-container-low);box-shadow:var(--elevate1);border:none}.profile-header__stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:1.05rem;gap:1.05rem;grid-column:span 12}.profile-header__stat{display:flex;flex-direction:column;align-items:center;gap:.125rem;padding:1.05rem .6rem;text-align:center;border-radius:18px;background:var(--surface-container-low);box-shadow:var(--elevate1);border:none;min-width:0}.profile-header__stat-value{font-size:clamp(1.25rem,3vw,1.5rem);line-height:1.2;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.profile-header__stat-label{opacity:.7;line-height:1.35}@media (max-width:26rem){.profile-header__stats{grid-template-columns:1fr}}@media (min-width:48rem){.profile-header{padding:1.2rem;gap:1rem}.profile-header__identity{grid-column:span 12;align-self:start}}@media (min-width:72rem){.profile-header__streak{grid-column:span 4}.profile-header__stats{grid-column:span 8}}.profile-page{padding-block:1rem 2rem}.profile-page,.profile-page__content{display:flex;flex-direction:column;gap:1rem}@media (min-width:48rem){.profile-page{gap:1.25rem}}.review-card{display:flex;flex-direction:column;align-items:center;gap:2rem;max-width:32rem;margin:0 auto}.review-card__progress{width:100%}.review-card__progress-text{display:flex;justify-content:space-between;align-items:baseline;-webkit-margin-after:.5rem;margin-block-end:.5rem}.review-card__stats{display:flex;justify-content:center;gap:1.5rem;-webkit-margin-before:.5rem;margin-block-start:.5rem}.review-card__flashcard{width:100%;display:flex;justify-content:center}.review-card__complete{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;padding:3rem 2rem}.roleplay-chat{display:grid;grid-gap:1rem;gap:1rem;height:100%}.roleplay-chat__toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.roleplay-chat__toolbar-left{display:flex;align-items:center;gap:1rem}.roleplay-chat__main{display:grid;grid-gap:1rem;gap:1rem;grid-template-columns:1fr}@media (min-width:993px){.roleplay-chat__main{grid-template-columns:1fr 20rem}}.roleplay-chat__conversation{display:grid;grid-gap:.75rem;gap:.75rem;min-height:0}.roleplay-chat__suggestions{display:grid;grid-gap:.5rem;gap:.5rem}.roleplay-chat__suggestion-chips{display:flex;flex-wrap:wrap;gap:.5rem}.roleplay-chat__side-panel{display:none}@media (min-width:993px){.roleplay-chat__side-panel{display:block}}.waitlist-section{padding:4rem 1rem;text-align:center}.waitlist-section__container{max-width:560px;margin-inline:auto}.waitlist-section__headline{font-size:2rem;font-weight:700;margin-bottom:1rem}.waitlist-section__subtext{font-size:1.125rem;opacity:.8;margin-bottom:1.5rem}.waitlist-section__form{margin-top:1.5rem}.waitlist-section__input-wrapper{display:flex;align-items:center;gap:0;background:var(--surface);border:1px solid var(--outline);border-radius:9999px;padding:4px;overflow:hidden}.waitlist-section__input{flex:1 1;height:48px;padding-inline:1rem;border:none;background:transparent;font-size:1rem;color:var(--on-surface);outline:none}.waitlist-section__input::placeholder{color:var(--on-surface-variant)}.waitlist-section__input:disabled{opacity:.5;cursor:not-allowed}.waitlist-section__btn{height:48px;padding-inline:1.5rem;border-radius:9999px;border:none;background:var(--primary);color:var(--on-primary);font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;white-space:nowrap;transition:opacity .2s ease}.waitlist-section__btn:hover:not(:disabled){opacity:.9}.waitlist-section__btn:disabled{opacity:.5;cursor:not-allowed}.waitlist-section__note{margin-top:.75rem;font-size:.875rem;opacity:.7}.waitlist-section__error{margin-top:.5rem;font-size:.875rem;color:var(--error)}.waitlist-section__success{margin-top:1.5rem;padding:1.5rem;background:var(--secondary-container);border-radius:1rem;text-align:center}.waitlist-section__success-icon{font-size:3rem;margin-bottom:.75rem;color:var(--success)}.waitlist-section__resubmit{margin-top:.75rem;height:40px;padding-inline:1rem;border:1px solid var(--outline);border-radius:9999px;background:var(--surface);color:var(--on-surface);font-size:.875rem;font-weight:500;cursor:pointer;transition:opacity .2s ease}.waitlist-section__resubmit:hover{opacity:.9}.waitlist-section__progress{width:4rem;height:.25rem}.word-detail{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem}.word-detail__header{text-align:center}.word-detail__word{margin:0;font-size:1.75rem}.word-detail__translation{margin:.25rem 0 0;opacity:.85}.word-detail__phonetic{margin:.25rem 0 0;opacity:.5;font-style:italic}.word-detail__badges{flex-wrap:wrap}.word-detail__actions,.word-detail__badges{display:flex;gap:.5rem;justify-content:center}.word-detail__action-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;border:1px solid var(--outline-variant);border-radius:2rem;cursor:pointer;font-size:.875rem;color:var(--primary);transition:background-color .15s ease}.word-detail__action-btn:hover{background:var(--surface-container-high)}.word-detail__action-btn--danger{color:var(--error)}.word-detail__section{display:flex;flex-direction:column;gap:.375rem}.word-detail__example{display:flex;align-items:flex-start;gap:.375rem;margin:0;opacity:.85}.word-detail__mastery-value{opacity:.7;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.word-detail__next-review{display:flex;align-items:center;gap:.375rem;margin:0;opacity:.7}.vocab-library{display:grid;grid-template-columns:1fr;grid-gap:1.5rem;gap:1.5rem}.vocab-library--empty{display:block}.vocab-library__empty-state.empty-state{width:100%;border-radius:1.25rem;border:1px solid color-mix(in srgb,var(--outline) 42%,transparent);background:color-mix(in srgb,var(--surface-container) 65%,transparent);margin-inline:auto}@media (min-width:56rem){.vocab-library{grid-template-columns:1fr 1fr;align-items:start}}.vocab-library__list{display:flex;flex-direction:column;gap:0}.vocab-library__count{margin:0;padding:.5rem 1rem;opacity:.6}.vocab-library__items{overflow-y:auto;max-height:32rem}.vocab-library__word-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background-color .15s ease}.vocab-library__word-row:hover{background:var(--surface-container)}.vocab-library__word-row--selected{background:var(--surface-container-high)}.vocab-library__word-avatar{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:50%;background:var(--primary-container);color:var(--on-primary-container);font-weight:700;font-size:1rem;flex-shrink:0}.vocab-library__word-text{flex:1 1;display:flex;flex-direction:column;min-width:0}.vocab-library__word-text>span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vocab-library__word-sub{opacity:.7}.vocab-library__due-label{flex-shrink:0;opacity:.6;white-space:nowrap}.vocab-library__no-results{text-align:center;padding:2rem 1rem;opacity:.6}.vocab-library__detail{position:-webkit-sticky;position:sticky;top:1rem}.vocab-library__detail-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:3rem;text-align:center;opacity:.5}.unit-roadmap{width:100%}.unit-roadmap__timeline{display:flex;flex-direction:column;max-width:72rem;margin-inline:auto;gap:.05rem}.unit-roadmap__summary{max-width:72rem;margin:0 auto 1rem;-webkit-margin-start:max(3.75rem,calc((100% - 72rem) / 2 + 3.75rem));margin-inline-start:max(3.75rem,calc((100% - 72rem) / 2 + 3.75rem));width:min(calc(72rem - 3.75rem),calc(100% - 3.75rem));padding:.85rem 1rem;border:1px solid color-mix(in srgb,var(--outline-variant) 52%,transparent);display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.75rem;gap:.75rem}.unit-roadmap__summary-item{display:flex;flex-direction:column;gap:.2rem}.unit-roadmap__summary-item strong{font-size:1.1rem;line-height:1.2}.unit-roadmap__summary-label{opacity:.74;font-size:.84rem}.unit-roadmap__item{--roadmap-accent:var(--outline-variant);--roadmap-accent-soft:color-mix(in srgb,var(--outline-variant) 42%,transparent);display:grid;grid-template-columns:2.75rem minmax(0,1fr);grid-gap:1rem;gap:1rem}.unit-roadmap__item--completed{--roadmap-accent:var(--tertiary);--roadmap-accent-soft:color-mix(in srgb,var(--tertiary) 36%,transparent)}.unit-roadmap__item--in_progress{--roadmap-accent:var(--primary);--roadmap-accent-soft:color-mix(in srgb,var(--primary) 34%,transparent)}.unit-roadmap__item--available{--roadmap-accent:color-mix(in srgb,var(--primary) 70%,var(--tertiary));--roadmap-accent-soft:color-mix(in srgb,var(--primary) 26%,transparent)}.unit-roadmap__item--locked{--roadmap-accent:color-mix(in srgb,var(--outline-variant) 75%,var(--surface-container-highest));--roadmap-accent-soft:color-mix(in srgb,var(--outline-variant) 22%,transparent)}.unit-roadmap__connector{display:flex;flex-direction:column;align-items:center}.unit-roadmap__dot{width:2.75rem;height:2.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:color-mix(in srgb,var(--roadmap-accent) 72%,white 28%);background:color-mix(in srgb,var(--roadmap-accent) 24%,var(--surface-container-high));border:1px solid color-mix(in srgb,var(--roadmap-accent) 56%,transparent);box-shadow:0 0 0 .27rem var(--roadmap-accent-soft);z-index:1}.unit-roadmap__dot--completed{color:color-mix(in srgb,var(--tertiary) 82%,white 18%)}.unit-roadmap__dot--locked{color:color-mix(in srgb,var(--outline) 70%,transparent)}.unit-roadmap__line{width:2px;flex:1 1;min-height:1.35rem;margin-block:.3rem 0;background:linear-gradient(180deg,color-mix(in srgb,var(--roadmap-accent) 78%,transparent) 0,color-mix(in srgb,var(--roadmap-accent) 34%,transparent) 100%)}.unit-roadmap__card{--unit-card-pad-y:1.15rem;--unit-card-pad-x:1.25rem;position:relative;overflow:hidden;-webkit-margin-before:0!important;margin-block-start:0!important;margin-bottom:1.5rem;padding:var(--unit-card-pad-y) var(--unit-card-pad-x);border:1px solid color-mix(in srgb,var(--roadmap-accent) 33%,var(--outline-variant));background:linear-gradient(132deg,color-mix(in srgb,var(--roadmap-accent) 9%,var(--surface-container)) 0,var(--surface-container) 62%,color-mix(in srgb,var(--roadmap-accent) 7%,var(--surface-container-low)) 100%);cursor:pointer;transition:box-shadow .24s ease,transform .24s ease,border-color .24s ease}.unit-roadmap__card:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:linear-gradient(180deg,var(--roadmap-accent) 0,transparent 100%);opacity:.82}.unit-roadmap__card:focus-visible:not(.unit-roadmap__card--locked),.unit-roadmap__card:hover:not(.unit-roadmap__card--locked){border-color:color-mix(in srgb,var(--roadmap-accent) 56%,var(--outline));box-shadow:var(--elevation-2);transform:translateY(-2px);outline:none}.unit-roadmap__card--locked{opacity:.7;filter:saturate(.7);cursor:default}.unit-roadmap__card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.9rem}.unit-roadmap__body{display:grid;grid-template-columns:minmax(0,1fr);grid-gap:.9rem;gap:.9rem}.unit-roadmap__body--with-image{margin:calc(-1 * var(--unit-card-pad-y)) calc(-1 * var(--unit-card-pad-x));grid-template-columns:minmax(8rem,32%) minmax(0,1fr);gap:0;align-items:stretch}.unit-roadmap__side-media{border-radius:0;overflow:hidden;border:0}.unit-roadmap__side-image{display:block;width:100%;height:100%;min-height:9.8rem;object-fit:cover}.unit-roadmap__content{min-width:0;padding:var(--unit-card-pad-y) var(--unit-card-pad-x)}.unit-roadmap__title-cluster{display:flex;align-items:flex-start;gap:.85rem;min-width:0}.unit-roadmap__card-icon{width:2.75rem;height:2.75rem;display:flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--roadmap-accent) 42%,transparent);overflow:hidden}.unit-roadmap__title-copy{min-width:0}.unit-roadmap__title-copy h6{margin:0;font-size:clamp(1.75rem,2.2vw,2.9rem);letter-spacing:-.02em;line-height:1.05}.unit-roadmap__title-copy p{margin:.5rem 0 0;max-width:58ch;line-height:1.45;opacity:.84}.unit-roadmap__card-chips{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}.unit-roadmap__progress-wrap{margin-top:.95rem}.unit-roadmap .progress-bar-wrap__header{-webkit-margin-after:.42rem;margin-block-end:.42rem;opacity:.9}.unit-roadmap .progress-bar-wrap progress{width:100%;height:.33rem;border:0;border-radius:999px;overflow:hidden;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:color-mix(in srgb,var(--outline-variant) 30%,var(--surface-container-highest))}.unit-roadmap .progress-bar-wrap progress::-webkit-progress-bar{background:color-mix(in srgb,var(--outline-variant) 30%,var(--surface-container-highest))}.unit-roadmap .progress-bar-wrap progress::-webkit-progress-value{border-radius:999px;background:linear-gradient(90deg,color-mix(in srgb,var(--roadmap-accent) 72%,white 28%) 0,var(--roadmap-accent) 100%)}.unit-roadmap .progress-bar-wrap progress::-moz-progress-bar{border-radius:999px;background:linear-gradient(90deg,color-mix(in srgb,var(--roadmap-accent) 72%,white 28%) 0,var(--roadmap-accent) 100%)}@media (min-width:64rem){.unit-roadmap{display:grid;grid-template-columns:1fr 20rem;grid-template-areas:"timeline summary";grid-gap:0 4rem;gap:0 4rem;align-items:start;max-width:72rem;margin-inline:auto}.unit-roadmap__timeline{grid-area:timeline;margin-inline:0;max-width:100%}.unit-roadmap__summary{grid-area:summary;position:-webkit-sticky;position:sticky;top:6rem;margin:0;width:100%;grid-template-columns:1fr;gap:1.25rem;padding:1.5rem}.unit-roadmap__summary-item strong{font-size:1.75rem}.unit-roadmap__summary-label{font-size:.95rem}}@media (max-width:64rem){.unit-roadmap__title-copy h6{font-size:clamp(1.52rem,2.55vw,2.2rem)}}@media (max-width:48rem){.unit-roadmap__item{grid-template-columns:2.25rem minmax(0,1fr);gap:.8rem}.unit-roadmap__dot{width:2.25rem;height:2.25rem}.unit-roadmap__title-copy h6{font-size:clamp(1.22rem,4.3vw,1.68rem);line-height:1.12}.unit-roadmap__card{--unit-card-pad-y:0.9rem;--unit-card-pad-x:1rem}.unit-roadmap__summary{-webkit-margin-start:max(3.05rem,calc((100% - 72rem) / 2 + 3.05rem));margin-inline-start:max(3.05rem,calc((100% - 72rem) / 2 + 3.05rem));width:min(calc(72rem - 3.05rem),calc(100% - 3.05rem));grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;padding:.75rem .85rem}.unit-roadmap__summary-item strong{font-size:1.02rem}.unit-roadmap__summary-label{font-size:.78rem}.unit-roadmap__body--with-image{grid-template-columns:1fr}.unit-roadmap__side-image{min-height:8.5rem}}@media (max-width:37.5rem){.unit-roadmap__summary{-webkit-margin-start:auto;margin-inline-start:auto;width:100%}.unit-roadmap__item{grid-template-columns:1fr}.unit-roadmap__connector{display:none}.unit-roadmap__card-header{flex-direction:column;gap:.75rem}.unit-roadmap__card-chips{justify-content:flex-start}.unit-roadmap__title-cluster{gap:.72rem}.unit-roadmap__card-icon{width:2.5rem;height:2.5rem}.unit-roadmap__title-copy p{margin-top:.35rem;font-size:1.03rem;line-height:1.35}.unit-roadmap__card{margin-bottom:.8rem;padding:.85rem}}@media (max-width:22.5rem){.unit-roadmap__summary{grid-template-columns:1fr;gap:.48rem}}.unit-detail{display:flex;flex-direction:column;gap:1.5rem;width:100%}.unit-detail__back{margin-bottom:-.25rem}.unit-detail__hero{position:relative;overflow:hidden;min-height:18rem;border-radius:1.45rem;border:1px solid color-mix(in srgb,var(--outline-variant) 70%,transparent);box-shadow:var(--elevation-1);isolation:isolate}.unit-detail__hero-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}@media (min-width:48rem){.unit-detail__hero-image{object-position:center top}}.unit-detail__hero-overlay{position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 18%,transparent) 0,color-mix(in srgb,var(--surface-container-highest) 70%,transparent) 100%),linear-gradient(115deg,color-mix(in srgb,var(--primary) 28%,transparent) 0,color-mix(in srgb,var(--surface-container) 84%,transparent) 58%,color-mix(in srgb,var(--tertiary) 22%,transparent) 100%)}.unit-detail__hero-content{position:relative;z-index:1;min-height:18rem;display:flex;flex-direction:column;justify-content:flex-end;gap:1rem;padding:1.25rem}.unit-detail__hero-top{display:flex;justify-content:space-between;gap:1rem;align-items:center}.unit-detail__icon{width:3.5rem;height:3.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid color-mix(in srgb,var(--primary) 44%,transparent)}.unit-detail__hero-info h2{margin:0;font-size:clamp(2.1rem,3vw,3rem);line-height:1.05;letter-spacing:-.02em}.unit-detail__hero-info p{margin:.6rem 0 0;max-width:52ch;color:color-mix(in srgb,var(--on-surface) 92%,transparent);line-height:1.5}.unit-detail__hero-meta{font-weight:600;font-size:.94rem;letter-spacing:.01em;color:color-mix(in srgb,var(--on-surface) 74%,transparent)!important}.unit-detail__chips{display:flex;gap:.35rem;flex-wrap:wrap}.unit-detail__layout{display:grid;grid-template-columns:minmax(16rem,20rem) minmax(0,1fr);grid-gap:1rem;gap:1rem;align-items:start}.unit-detail__sidebar{position:-webkit-sticky;position:sticky;top:1rem;display:grid;grid-gap:1rem;gap:1rem}.unit-detail__sidebar h6{margin:0}.unit-detail__stats{display:grid;grid-gap:.6rem;gap:.6rem}.unit-detail__stat-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;color:var(--on-surface-variant)}.unit-detail__stat-row strong{color:var(--on-surface);font-size:.95rem}.unit-detail__path{display:grid;grid-gap:.7rem;gap:.7rem}.unit-detail__path ol{margin:0;padding:0;list-style:none;display:grid;grid-gap:.5rem;gap:.5rem}.unit-detail__path-item{display:grid;grid-template-columns:1.6rem minmax(0,1fr);grid-gap:.6rem;gap:.6rem;align-items:center}.unit-detail__path-index{width:1.6rem;height:1.6rem;border-radius:999px;background:var(--surface-container-highest);display:inline-flex;align-items:center;justify-content:center;font-size:.78rem;color:var(--on-surface-variant)}.unit-detail__path-copy p{margin:0;display:flex;align-items:center;line-height:1.3;font-weight:600}.unit-detail__path-title{min-width:0}.unit-detail__path-item--completed .unit-detail__path-index{background:color-mix(in srgb,var(--tertiary) 22%,var(--surface-container-highest));color:color-mix(in srgb,var(--tertiary) 72%,var(--on-surface))}.unit-detail__path-item--in_progress .unit-detail__path-index{background:color-mix(in srgb,var(--primary) 22%,var(--surface-container-highest));color:color-mix(in srgb,var(--primary) 80%,var(--on-surface))}.unit-detail__path-item--not_started .unit-detail__path-index{background:color-mix(in srgb,var(--surface-container-highest) 88%,var(--surface));color:var(--on-surface-variant)}.unit-detail__path-item--locked .unit-detail__path-index{opacity:.72}.unit-detail__outcomes{padding-top:.15rem}.unit-detail__outcomes .unit-detail__path-copy p{font-weight:500;line-height:1.35}.unit-detail__lessons-title{margin:0}.unit-detail__lessons-panel{display:grid;grid-gap:.95rem;gap:.95rem;padding:1rem;border:1px solid color-mix(in srgb,var(--outline-variant) 65%,transparent);box-shadow:var(--elevation-1)}.unit-detail__lesson-list{display:flex;flex-direction:column;gap:.95rem}.unit-detail__lesson-row{border-radius:2rem}.unit-detail__lesson-row--in_progress{box-shadow:0 0 0 1px color-mix(in srgb,var(--primary) 26%,transparent)}.unit-detail__lessons-panel .unit-detail__lesson-row--in_progress{box-shadow:0 0 0 1px color-mix(in srgb,var(--primary) 22%,transparent),0 6px 18px color-mix(in srgb,var(--shadow) 8%,transparent)}.unit-detail .progress-bar-wrap{gap:.45rem}.unit-detail .progress-bar-wrap__header{color:color-mix(in srgb,var(--on-surface) 78%,transparent)}.unit-detail .progress-bar-wrap progress{height:.35rem;border-radius:999px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:color-mix(in srgb,var(--outline-variant) 32%,var(--surface-container-highest))}.unit-detail .progress-bar-wrap progress::-webkit-progress-bar{background:color-mix(in srgb,var(--outline-variant) 32%,var(--surface-container-highest))}.unit-detail .progress-bar-wrap progress::-webkit-progress-value{border-radius:999px;background:linear-gradient(90deg,color-mix(in srgb,var(--primary) 64%,white 36%) 0,var(--primary) 100%)}.unit-detail .progress-bar-wrap progress::-moz-progress-bar{border-radius:999px;background:linear-gradient(90deg,color-mix(in srgb,var(--primary) 64%,white 36%) 0,var(--primary) 100%)}@media (max-width:599px){.unit-detail{width:100%}.unit-detail__hero{min-height:15rem}.unit-detail__hero-content{min-height:15rem;padding:1rem}.unit-detail__hero-top{flex-direction:column;align-items:center;text-align:center}.unit-detail__chips{justify-content:center}.unit-detail__hero-info{text-align:center}.unit-detail__back{margin-bottom:.1rem}.unit-detail__lessons-panel{padding:.85rem}}@media (max-width:68rem){.unit-detail__layout{grid-template-columns:1fr}.unit-detail__sidebar{position:static}}.scenario-filter-rail{display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.scenario-filter-rail__header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.scenario-filter-rail__body{display:flex;flex-direction:column;gap:1.25rem}.scenario-filter-rail__group{display:flex;flex-direction:column;gap:.5rem}.scenario-filter-rail__chips{display:flex;flex-wrap:wrap;gap:.5rem}.scenario-detail{display:grid;grid-gap:1.5rem;gap:1.5rem}.scenario-detail__header{display:grid;grid-gap:1rem;gap:1rem}.scenario-detail__title-row{display:flex;gap:1rem;align-items:flex-start}.scenario-detail__emoji{font-size:2.5rem;line-height:1}.scenario-detail__title-text{display:grid;grid-gap:.25rem;gap:.25rem}.scenario-detail__meta{display:flex;flex-wrap:wrap;gap:.5rem}.scenario-detail__stats{display:flex;gap:1rem;align-items:center}.scenario-detail__stats span{display:flex;align-items:center;gap:.25rem}.scenario-detail__section{display:grid;grid-gap:.75rem;gap:.75rem}.scenario-detail__goals{display:grid;grid-gap:.5rem;gap:.5rem}.scenario-detail__goal{display:flex;align-items:center;gap:.5rem}.scenario-detail__replies{display:grid;grid-gap:.5rem;gap:.5rem}.scenario-detail__reply{display:flex;align-items:center;gap:.5rem}.scenario-detail__vocab{display:grid;grid-template-columns:repeat(auto-fill,minmax(12rem,1fr));grid-gap:.5rem;gap:.5rem}.scenario-detail__vocab-item{display:flex;flex-direction:column;gap:.125rem}.roleplay-side-panel{display:grid;grid-template-rows:auto 1fr;overflow:hidden}.roleplay-side-panel__tabs{display:flex;border-bottom:1px solid var(--outline-variant)}.roleplay-side-panel__tabs a{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;cursor:pointer;opacity:.6;transition:opacity .2s;text-decoration:none}.roleplay-side-panel__tabs a.active{opacity:1;border-bottom:2px solid var(--primary)}.roleplay-side-panel__content{overflow-y:auto}.roleplay-side-panel__grammar,.roleplay-side-panel__hints,.roleplay-side-panel__vocab{display:grid;grid-gap:.5rem;gap:.5rem}.roleplay-side-panel__grammar-item,.roleplay-side-panel__hint{display:flex;align-items:flex-start;gap:.5rem}.roleplay-side-panel__vocab-item{display:grid;grid-gap:.125rem;gap:.125rem;padding-block:.375rem;border-bottom:1px solid var(--outline-variant)}.roleplay-side-panel__vocab-item:last-child{border-bottom:none}