.pricing-card{display:flex;flex-direction:column;padding:1.5rem;height:100%}.pricing-card--highlighted{border:2px solid var(--primary)}.pricing-card__badge{align-self:flex-start;-webkit-margin-after:.5rem;margin-block-end:.5rem}.pricing-card__name{margin:0}.pricing-card__price-row{display:flex;align-items:baseline;gap:.25rem;-webkit-margin-before:.25rem;margin-block-start:.25rem}.pricing-card__price{font-size:2rem;line-height:1.2}.pricing-card__subtitle{margin:.5rem 0 0;opacity:.7}.pricing-card__divider{height:1px;background:var(--outline-variant);margin:1rem 0}.pricing-card__features{display:flex;flex-direction:column;gap:.625rem;flex:1 1}.pricing-card__feature{display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem}.pricing-card__feature--excluded{opacity:.4}.pricing-card__cta{display:flex;align-items:center;justify-content:center;padding:.625rem 1.25rem;border:1px solid var(--outline-variant);border-radius:2rem;-webkit-margin-before:1.25rem;margin-block-start:1.25rem;font-weight:500;text-decoration:none;cursor:pointer;color:var(--on-surface);transition:background-color .15s ease}.pricing-card__cta:hover{background:var(--surface-container-high)}.pricing-card__cta--primary{background:var(--primary);color:var(--on-primary);border-color:var(--primary)}.pricing-card__cta--primary:hover{opacity:.9;background:var(--primary)}.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}}.chat-mockup{max-width:420px;overflow:hidden;margin:0 auto}.chat-mockup__header{border-radius:1rem 1rem 0 0}.chat-mockup__body{display:flex;flex-direction:column;gap:.75rem;min-height:280px}.chat-mockup__footer{border-radius:0 0 1rem 1rem}.chat-mockup__input-wrap{display:flex;align-items:center;gap:.5rem;background:var(--surface);border:1px solid var(--outline-variant);border-radius:1.5rem;padding:.25rem .25rem .25rem 1rem}.chat-mockup__input-wrap:focus-within{border-color:var(--primary)}.chat-mockup__input{all:unset;flex:1 1;font:inherit;font-size:.875rem;color:var(--on-surface);min-width:0}.chat-mockup__input::placeholder{color:var(--on-surface-variant);opacity:.6}.chat-mockup__send-btn{flex-shrink:0;background:var(--primary)!important;color:var(--on-primary)!important;width:2rem!important;height:2rem!important}.chat-mockup__bubble{max-width:85%;font-size:.875rem;line-height:1.5}.chat-mockup__bubble--user{align-self:flex-end;border-radius:1rem 1rem .25rem 1rem}.chat-mockup__bubble--bot{align-self:flex-start;border-radius:.25rem 1rem 1rem 1rem}.chat-mockup__typing{display:flex;gap:4px;padding:4px 2px}.chat-mockup__typing span{width:8px;height:8px;border-radius:50%;background:var(--on-surface-variant);animation:chat-typing-pulse 1.4s infinite both}.chat-mockup__typing span:nth-child(2){animation-delay:.2s}.chat-mockup__typing span:nth-child(3){animation-delay:.4s}@keyframes chat-typing-pulse{0%,80%,to{transform:translateY(0);opacity:.3}40%{transform:translateY(-6px);opacity:1}}.flash-card{perspective:800px;cursor:pointer;width:100%;max-width:28rem}.flash-card__inner{position:relative;width:100%;transition:transform .5s ease;transform-style:preserve-3d}.flash-card--flipped .flash-card__inner{transform:rotateY(180deg)}.flash-card__face{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;-webkit-backface-visibility:hidden;backface-visibility:hidden;min-height:18rem;padding:2rem}.flash-card__front{position:relative}.flash-card__back{position:absolute;inset:0;transform:rotateY(180deg)}.flash-card__badges{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.flash-card__word{font-size:2rem;font-weight:700;margin:.5rem 0;text-align:center}.flash-card__phonetic{opacity:.7;margin:0}.flash-card__hint{opacity:.4;margin:0}.flash-card__example{text-align:center;opacity:.85;margin:0;line-height:1.5}.dialog-component{max-width:min(90vw,32rem);border:none;padding:0}.dialog-component::-webkit-backdrop{background:rgba(0,0,0,.5)}.dialog-component::backdrop{background:rgba(0,0,0,.5)}.dialog-component__header{display:flex;align-items:center;gap:.5rem;-webkit-margin-after:1rem;margin-block-end:1rem}.bottom-sheet{position:fixed;inset:auto 0 0 0;width:100%;max-width:100%;max-height:80vh;margin:0;border:none;padding:0;background:transparent}.bottom-sheet::-webkit-backdrop{background:rgba(0,0,0,.5)}.bottom-sheet::backdrop{background:rgba(0,0,0,.5)}.bottom-sheet__content{background:var(--surface);overflow-y:auto;max-height:80vh}.bottom-sheet__handle{width:2rem;height:.25rem;border-radius:999px;background:var(--outline-variant);margin:0 auto 1rem}.bottom-sheet__header{display:flex;align-items:center;gap:.5rem;-webkit-margin-after:1rem;margin-block-end:1rem}.chat-conversation{display:flex;flex-direction:column;height:100%;max-height:36rem;overflow:hidden}.chat-conversation__header nav{display:flex;align-items:center;gap:.5rem}.chat-conversation__emoji{font-size:1.25rem}.chat-conversation__body{flex:1 1;overflow-y:auto;display:flex;flex-direction:column}.chat-conversation__footer{border-top:1px solid var(--outline-variant)}.chat-conversation__typing{display:flex;gap:4px;padding:.25rem 0}.chat-conversation__typing span{width:8px;height:8px;border-radius:50%;background:var(--on-surface-variant);opacity:.4;animation:typing-pulse 1.4s ease-in-out infinite}.chat-conversation__typing span:nth-child(2){animation-delay:.2s}.chat-conversation__typing span:nth-child(3){animation-delay:.4s}@keyframes typing-pulse{0%,60%,to{opacity:.4}30%{opacity:1}}.grammar-quiz{max-width:32rem;margin:0 auto}.grammar-quiz__progress{text-align:center;-webkit-margin-after:1.5rem;margin-block-end:1.5rem}.grammar-quiz__prompt{-webkit-margin-after:1rem;margin-block-end:1rem;text-align:center}.grammar-quiz__options{display:flex;flex-direction:column;gap:.5rem}.grammar-quiz__option{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left}.grammar-quiz__explanation{display:flex;align-items:flex-start;gap:.5rem;-webkit-margin-before:1rem;margin-block-start:1rem}.grammar-quiz__done{gap:.5rem;padding:2rem}.grammar-quiz__done,.lesson-complete{display:flex;flex-direction:column;align-items:center;text-align:center}.lesson-complete{gap:.75rem;padding:2rem 1.5rem;max-width:100%;margin:0 auto}.lesson-complete__trophy{position:relative;display:flex;align-items:center;justify-content:center;width:5rem;height:5rem;border-radius:50%;background:var(--tertiary-container);animation:trophy-pop .5s cubic-bezier(.34,1.56,.64,1) both}.lesson-complete__trophy-icon{font-family:var(--font-icon);font-size:2.75rem;color:var(--tertiary);font-variation-settings:"FILL" 1}.lesson-complete__sparkle{position:absolute;font-family:var(--font-icon);font-size:1rem;color:var(--tertiary);font-variation-settings:"FILL" 1;animation:sparkle-pop .6s ease both}.lesson-complete__sparkle--1{top:-.25rem;right:-.25rem;animation-delay:.3s}.lesson-complete__sparkle--2{top:-.5rem;left:0;font-size:.75rem;animation-delay:.45s}.lesson-complete__sparkle--3{bottom:0;right:-.5rem;font-size:.75rem;animation-delay:.6s}@keyframes trophy-pop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes sparkle-pop{0%{transform:scale(0) rotate(-30deg);opacity:0}60%{transform:scale(1.3) rotate(10deg);opacity:1}to{transform:scale(1) rotate(0deg);opacity:1}}.lesson-complete__title{display:flex;align-items:center;gap:.25rem;opacity:.7}.lesson-complete__stats{display:grid;grid-template-columns:1fr 1fr;grid-gap:.85rem;gap:.85rem;width:100%;max-width:22rem;margin-block:1rem}.lesson-complete__stat{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-height:5.5rem;justify-content:center}.lesson-complete__stat-value{font-size:1.5rem;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.lesson-complete__actions{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:22rem;align-items:center}.lesson-complete__actions>button{width:100%}@media (min-width:720px){.lesson-complete{padding:2.25rem 2rem}}.daily-challenge__header{display:flex;align-items:center;gap:.5rem;-webkit-margin-after:.5rem;margin-block-end:.5rem}.daily-challenge--completed{opacity:.7}.daily-challenge__title{margin-block:0 .25rem}.daily-challenge__desc{margin-block:0 .75rem}.daily-challenge__footer{display:flex;align-items:center;justify-content:space-between}.daily-challenge__timer{display:flex;align-items:center;gap:.25rem;opacity:.7}.lb-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:.75rem}.lb-row--current{font-weight:600}.lb-row__rank{width:2rem;text-align:center;flex-shrink:0}.lb-row__avatar{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;flex-shrink:0;overflow:hidden}.lb-row__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-row__stat{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;flex-shrink:0}.dashboard-page{width:100%;min-height:100vh;background:var(--surface);overflow:visible!important}.dashboard-page--narrow{max-width:56rem;margin-inline:auto}.dashboard-page--default,.dashboard-page--wide{max-width:100%}.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}@media (max-width:600px){.grid.medium-space{gap:.75rem}.grid.large-space{gap:1rem}}.db-container{max-inline-size:min(100%,75rem);margin-inline:auto;padding-inline:1.5rem}.db-container--sm{max-width:500px;margin-inline:auto}.db-container--md{max-width:800px;margin-inline:auto}.db-container--lg{max-width:900px;margin-inline:auto}.centered-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:1rem;padding:1.5rem}.centered-loading-state--full{min-height:100dvh}.centered-loading-state--section{min-height:18rem}.centered-loading-state__description{opacity:.75;margin:0;max-width:34ch}@keyframes heroSlideFromLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes heroSlideFromRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.hero-section{padding-top:6rem;padding-bottom:4rem;padding-inline:1.5rem}.hero-section__text{animation:heroSlideFromLeft .6s ease both;align-self:center}.hero-section__media{animation:heroSlideFromRight .6s ease .2s both}.hero-section__badge{display:inline-flex}.hero-section__headline{font-size:clamp(2.25rem,5vw,3.5rem);line-height:1.15}.hero-section__subheadline{margin-top:1rem}.hero-section__cta-row{gap:.75rem}.hero-section__cta-row,.hero-section__trust{margin-top:1.5rem;display:flex;flex-wrap:wrap}.hero-section__trust{gap:1rem}.hero-section__trust-icon{vertical-align:middle}@media (max-width:600px){.hero-section__cta-row{flex-direction:column}.hero-section__cta-row>a,.hero-section__cta-row>button{width:100%;max-width:100%;box-sizing:border-box;justify-content:center}}.plan-comparison__grid{display:grid;grid-template-columns:1fr;grid-gap:.75rem;gap:.75rem}@media (min-width:40rem){.plan-comparison__grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:64rem){.plan-comparison__grid{grid-template-columns:repeat(3,1fr)}}.billing-page{display:flex;flex-direction:column;gap:2rem}.billing-page__section-title{margin:0 0 .75rem}.billing-page__current-plan{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding:1.5rem}.billing-page__plan-info{display:flex;flex-direction:column;gap:.125rem}.billing-page__plan-name{margin:0}.billing-page__plan-meta{margin:0;opacity:.8}.billing-page__portal-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:1px solid var(--outline-variant);border-radius:2rem;color:var(--on-primary-container);font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;transition:background-color .15s ease}.billing-page__portal-btn:hover{background:rgba(0,0,0,.08)}.billing-page__usage-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(20rem,1fr));grid-gap:1rem;gap:1rem}@media (max-width:32rem){.billing-page__usage-grid{grid-template-columns:1fr;gap:.85rem}}.billing-page__upgrade{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding:1.5rem}.billing-page__upgrade-text{display:flex;flex-direction:column;gap:.375rem;max-width:32rem}.billing-page__upgrade-title{margin:0}.billing-page__upgrade-body{margin:0;opacity:.85}.billing-page__upgrade-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:2rem;background:var(--primary);color:var(--on-primary);font-weight:500;text-decoration:none;cursor:pointer;border:none;transition:opacity .15s ease}.billing-page__upgrade-btn:hover{opacity:.9}.conjugation-table-block{display:flex;flex-direction:column;gap:.75rem}.conjugation-table-block__table{width:100%;border-collapse:collapse}.conjugation-table-block__table th{text-align:left;padding:.5rem .75rem;font-weight:600;border-bottom:2px solid var(--outline-variant)}.conjugation-table-block__table td{padding:.5rem .75rem;border-bottom:1px solid var(--outline-variant)}.conjugation-table-block__table tr:last-child td{border-bottom:none}.conjugation-table-block__cell--highlight{background:var(--primary-container);color:var(--on-primary-container);border-radius:.25rem;font-weight:600}.conjugation-table-block__footnote{margin-top:.25rem}@media (max-width:599px){.conjugation-table-block__table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}}.cta-section__box{max-width:500px;margin-inline:auto}.cta-section__btn{margin-top:1rem}.cta-section__note{margin-top:.75rem;opacity:.7}.example-sentences-block{display:flex;flex-direction:column;gap:.75rem}.example-sentences-block__list{display:flex;flex-direction:column;gap:.5rem}.example-sentences-block__pair{display:flex;flex-direction:column;gap:.125rem}.example-sentences-block__row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.explanation-block{display:flex;flex-direction:column;gap:.75rem}.explanation-block__content{line-height:1.6}.explanation-block__content ol,.explanation-block__content ul{padding-left:1.25rem;margin:.5rem 0}.explanation-block__content li{margin-bottom:.25rem}.explanation-block__examples{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.explanation-block__example{display:flex;flex-direction:column;gap:.125rem}.explanation-block__image{max-height:240px;object-fit:cover}.explanation-block__image--hero,.explanation-block__image--inline{width:100%}.explanation-block__image--float-left,.explanation-block__image--float-right{max-width:50%}.explanation-block__image--float-left{float:left;margin-right:1rem;margin-bottom:.5rem}.explanation-block__image--float-right{float:right;margin-left:1rem;margin-bottom:.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}.media-placeholder{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--surface-container-high,#e6e0e9)}.media-placeholder__shimmer{position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4) 50%,transparent);animation:media-placeholder-shimmer 1.8s ease-in-out infinite}@keyframes media-placeholder-shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.media-placeholder__icon{position:relative;z-index:1;font-size:2rem;color:var(--on-surface-variant,#79747e);opacity:.4;font-family:Material Symbols Outlined,sans-serif;font-style:normal}.media-placeholder--hero{width:100%;aspect-ratio:16/9;max-height:280px}.media-placeholder--thumbnail{width:100%;aspect-ratio:4/3}.media-placeholder--scene{width:100%;aspect-ratio:16/9;max-height:240px}.lesson-introduction{display:flex;flex-direction:column;gap:.85rem}.lesson-introduction h5,.lesson-introduction h6{margin:0}.lesson-introduction__objectives{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.lesson-introduction__objective{display:flex;align-items:flex-start;gap:.5rem;line-height:1.45}.lesson-introduction__objective span{max-width:76ch}.lesson-introduction__prerequisites{margin:.25rem 0 0;padding-left:1.1rem;list-style:disc;display:grid;grid-gap:.35rem;gap:.35rem}.lesson-introduction__prerequisite{margin:0;line-height:1.45}.lesson-introduction__prerequisite span{display:inline}.lesson-introduction__meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.lesson-introduction__hero{width:100%;max-height:280px;object-fit:cover}.phrase-bank-block{display:flex;flex-direction:column;gap:1rem}.phrase-bank-block__category,.phrase-bank-block__phrases{display:flex;flex-direction:column;gap:.5rem}.phrase-bank-block__phrase{display:flex;flex-direction:column;gap:.125rem}.phrase-bank-block__row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.phrase-bank-block__scene{width:100%;max-height:240px;object-fit:cover}.practice-exercise{display:flex;flex-direction:column;gap:1rem}.practice-exercise__header{display:flex;align-items:center;gap:.4rem;line-height:1.2}.practice-exercise__progress{display:flex;align-items:center;gap:.75rem}.practice-exercise__progress progress{flex:1 1}.practice-exercise__question{display:flex;flex-direction:column;gap:1rem}.practice-exercise__prompt{font-size:1.05rem;line-height:1.5}.practice-exercise__options{display:flex;flex-direction:column;gap:.5rem}.practice-exercise__option{display:flex;cursor:pointer;width:100%;max-width:100%;font-size:inherit;transition:background .2s ease,box-shadow .15s ease,transform .15s ease;font-family:inherit;box-sizing:border-box;block-size:auto;margin:0;overflow:hidden}.practice-exercise__option--default{align-items:center;justify-content:space-between;padding:.75rem 1rem;text-align:left}.practice-exercise__option--minimal{align-items:center;justify-content:center;text-align:center;padding:.75rem 1rem!important;border:0;min-height:unset;line-height:1.2}.practice-exercise__option-content{display:inline-flex;align-items:center;justify-content:center;gap:.45rem}.practice-exercise__option-icon{width:1.1rem;height:1.1rem;display:inline-flex;align-items:center;justify-content:center;visibility:hidden}.practice-exercise__option-icon--visible{visibility:visible}.practice-exercise__option--default:hover:not(:disabled):not(.practice-exercise__option--correct):not(.practice-exercise__option--incorrect){background:var(--surface-container-high)}.practice-exercise__option--minimal:hover:not(:disabled){box-shadow:var(--elevate1);transform:translateY(-1px)}.practice-exercise--minimal .practice-exercise__options{gap:.5rem}.practice-exercise--minimal .practice-exercise__option-content{width:100%;text-align:center}.practice-exercise--minimal .practice-exercise__option span:last-child{flex:0 1 auto}.practice-exercise__option:disabled{cursor:default}.practice-exercise__option--correct{border:2px solid var(--primary);background:var(--primary-container)!important;color:var(--on-primary-container)!important}.practice-exercise__option--incorrect{border:2px solid var(--error);background:var(--error-container)!important;color:var(--on-error-container)!important}.practice-exercise__explanation{display:flex;align-items:flex-start;gap:.5rem}.practice-exercise__next{display:flex;justify-content:flex-end}.practice-exercise--done,.practice-exercise__result{display:flex;flex-direction:column;gap:1rem}.practice-exercise__result{align-items:center}.practice-exercise__result-icon{font-size:2.35rem}.practice-exercise__score-bar{width:100%;max-width:20rem}.practice-exercise__score-info{display:flex;justify-content:space-between;margin-bottom:.25rem}.practice-exercise__retry{margin-top:.5rem}.practice-exercise__result-progress{--_size:0.35rem;color:var(--primary);background-color:var(--outline-variant);background-image:none}.practice-exercise__result-progress.error{color:var(--error)}.lesson-phase-tabs{display:flex;flex-direction:column;gap:1.125rem}.lesson-phase-tabs__header{display:flex;flex-direction:column;gap:.35rem}.lesson-phase-tabs__meta{display:flex;align-items:center;gap:.5rem}.lesson-phase-tabs__content{min-height:0}.lesson-phase-tabs__completion-nav{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-top:1rem}.learn-phase,.lesson-phase-tabs__practice{display:flex;flex-direction:column;gap:1rem}.learn-phase__section{display:flex;flex-direction:column;gap:.75rem}.learn-phase__example{display:flex;flex-direction:column;gap:.25rem}.learn-phase__tip{display:flex;align-items:center;gap:.5rem}.apply-phase{display:flex;flex-direction:column;gap:1rem}.apply-phase__scenario{display:flex;align-items:flex-start;gap:.5rem}.apply-phase__prompts{display:flex;flex-direction:column;gap:.5rem}.apply-phase__prompt{display:flex;align-items:center;gap:.5rem}.apply-phase__writing{margin-top:.5rem}.apply-phase__writing textarea{width:100%;resize:vertical}.apply-phase__action{display:flex;justify-content:flex-end;margin-top:.5rem}.db-footer__inner{max-inline-size:min(100%,75rem);margin-inline:auto;padding:2rem 1.5rem}.db-footer__link{display:block;margin-top:.5rem}.db-footer__copyright{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--outline-variant);opacity:.7}.ps-card{padding:2rem;height:100%}.ps-card h6{margin-bottom:.5rem}.ps-card--problem{border-left:3px solid var(--error)}.ps-card--solution{border-left:3px solid var(--primary)}.ps-card__row{display:flex;align-items:flex-start;gap:.75rem;margin-top:1rem}.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}.activity-item{align-items:flex-start;gap:.55rem;padding-block:.15rem}.activity-item__icon{opacity:.6;margin-top:.05rem}.activity-item__content{-webkit-margin-start:0;margin-inline-start:0;display:grid;grid-gap:.2rem;gap:.2rem}.activity-item__time{opacity:.5}.dashboard-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:0;margin-bottom:.65rem}.dashboard-page-header .chip{flex-shrink:0}.dashboard-page-header h4{font-size:clamp(1.75rem,3.4vw,2.95rem);line-height:1.06;letter-spacing:-.02em}.dashboard-page-header__subtitle{opacity:.84;margin-top:.45rem!important;max-width:44rem;font-size:clamp(1rem,1.2vw,1.32rem)}@media (max-width:700px){.dashboard-page-header{flex-wrap:wrap;gap:.75rem;margin-bottom:.4rem}}.home-grid{display:grid;grid-gap:1.25rem;gap:1.25rem;grid-template-columns:1fr;grid-template-areas:"main" "left" "right";align-items:start}.home-grid>*{min-width:0;margin:0!important}.home-grid__left{display:block;grid-area:left}.home-grid__main{grid-area:main}.home-grid__right{display:block;grid-area:right}@media (min-width:601px){.home-grid{grid-template-columns:minmax(0,1.9fr) minmax(15.5rem,1fr);grid-template-areas:"main left" "main right";gap:1.4rem}.home-grid--has-right:not(.home-grid--has-left){grid-template-columns:minmax(0,1.9fr) minmax(15.5rem,1fr);grid-template-areas:"main right"}}@media (min-width:1480px){.home-grid{grid-template-columns:minmax(0,2.55fr) minmax(18.5rem,1fr);grid-template-areas:"main left" "main right";gap:1.5rem}.home-grid--has-right:not(.home-grid--has-left){grid-template-columns:minmax(0,2.55fr) minmax(18.5rem,1fr);grid-template-areas:"main right"}}.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}}.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}}.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}.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}.mistake-queue{display:flex;flex-direction:column;gap:1rem}.mistake-queue__filters{display:flex;gap:.5rem;flex-wrap:wrap}.mistake-queue__item,.mistake-queue__list{display:flex;flex-direction:column}.mistake-queue__item{gap:.5rem;padding:.75rem;-webkit-border-after:1px solid var(--outline-variant);border-block-end:1px solid var(--outline-variant);cursor:pointer;transition:background .15s ease}.mistake-queue__item:hover{background:var(--surface-container)}.mistake-queue__item-chips{display:flex;gap:.375rem;flex-wrap:wrap;-webkit-padding-start:3rem;padding-inline-start:3rem}.mistake-queue__no-results{text-align:center;opacity:.6}.mistake-drill{display:flex;flex-direction:column;gap:1rem;max-width:36rem}.mistake-drill--resolved{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;padding:2rem}.mistake-drill__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.mistake-drill__attempts{display:flex;align-items:center;gap:.25rem;opacity:.7}.mistake-drill__prompt{margin:0}.mistake-drill__answers{display:flex;flex-direction:column;gap:.75rem}.mistake-drill__answer{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;grid-gap:.25rem .5rem;gap:.25rem .5rem;align-items:center}.mistake-drill__answer>span{grid-column:1}.mistake-drill__answer>i{grid-column:2;grid-row:1/-1}.mistake-drill__answer-text{margin:0;grid-column:1}.mistake-drill__hint-section{display:flex;flex-direction:column;gap:.75rem}.mistake-drill__hint{display:flex;align-items:flex-start;gap:.5rem}.mistake-drill__hint-text{margin:0}.mistake-drill__actions{display:flex;gap:.5rem;flex-wrap:wrap}.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}}.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}