﻿ .auth-page{background:linear-gradient(135deg, var(--color-primary-50) 0%, #fff 50%, var(--color-primary-100) 100%);min-height:100vh;padding:var(--space-4);justify-content:center;align-items:center;display:flex}.auth-card{background-color:var(--color-surface);border-radius:var(--radius-2xl);width:100%;max-width:420px;box-shadow:var(--shadow-xl);padding:var(--space-10)}.auth-logo{margin-bottom:var(--space-8);justify-content:center;align-items:center;display:flex}.auth-title{font-size:var(--text-2xl);font-weight:var(--font-extrabold);text-align:center;color:var(--color-text);margin-bottom:var(--space-2)}.auth-subtitle{font-size:var(--text-sm);text-align:center;color:var(--color-text-muted);margin-bottom:var(--space-8)}.auth-form{gap:var(--space-4);flex-direction:column;display:flex}.auth-footer{text-align:center;margin-top:var(--space-6);font-size:var(--text-sm);color:var(--color-text-muted)}.stats-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.stat-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);gap:var(--space-2);flex-direction:column;display:flex}.stat-card__label{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--font-medium)}.stat-card__value{font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-text)}.stat-card__delta{font-size:var(--text-xs);font-weight:var(--font-medium)}.stat-card__delta--up{color:var(--color-success)}.stat-card__delta--down{color:var(--color-error)}.vocab-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.vocab-card{background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);box-shadow:var(--shadow-3d-sm)}.vocab-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-3d);transform:translateY(-2px)}.vocab-card__term{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin-bottom:var(--space-1)}.vocab-card__reading{font-size:var(--text-sm);color:var(--color-primary);margin-bottom:var(--space-3)}.vocab-card__definition{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed)}.exercise-container{max-width:720px;margin:0 auto}.exercise-progress{margin-bottom:var(--space-8)}.exercise-question{font-size:var(--text-2xl);font-weight:var(--font-bold);text-align:center;margin-bottom:var(--space-8);color:var(--color-text)}.exercise-options{gap:var(--space-4);margin-bottom:var(--space-8);grid-template-columns:1fr 1fr;display:grid}.exercise-option{padding:var(--space-4) var(--space-5);background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;font-size:var(--text-base);font-weight:var(--font-medium);text-align:center;transition:all var(--duration-fast) var(--ease-default);box-shadow:var(--shadow-3d-sm)}.exercise-option:hover{border-color:var(--color-primary);background-color:var(--color-primary-50);transform:translateY(-2px)}.exercise-option--correct{border-color:var(--color-success);color:var(--color-success);background-color:#f0fdf4}.exercise-option--incorrect{border-color:var(--color-error);color:var(--color-error);background-color:#fef2f2}.reading-list{gap:var(--space-4);flex-direction:column;display:flex}.reading-card{align-items:flex-start;gap:var(--space-4);padding:var(--space-5);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;color:inherit;transition:all var(--duration-fast) var(--ease-default);text-decoration:none;display:flex}.reading-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.reading-card__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-1)}.reading-card__excerpt{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.article-viewer{max-width:720px;margin:0 auto}.article-content{font-size:var(--text-lg);line-height:var(--leading-relaxed);color:var(--color-text)}.clickable-word{cursor:pointer;border-radius:var(--radius-sm);transition:background-color var(--duration-fast) var(--ease-default);padding:0 2px}.clickable-word:hover{background-color:var(--color-primary-100);color:var(--color-primary-dark)}.clickable-word--highlighted{background-color:var(--color-secondary-light);color:var(--color-neutral-900)}.filter-bar{align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.search-input-wrapper{flex:1;min-width:200px;position:relative}.search-input-wrapper .input{padding-left:var(--space-10)}.search-icon{left:var(--space-3);color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.dashboard{gap:var(--space-6);flex-direction:column;display:flex}.dashboard-welcome{justify-content:space-between;align-items:flex-end;gap:var(--space-4);flex-wrap:wrap;display:flex}.dashboard-welcome__text{gap:var(--space-1);flex-direction:column;display:flex}.dashboard-welcome__greeting{font-size:var(--text-base);color:var(--color-text-muted);font-weight:var(--font-medium)}.dashboard-welcome__name{font-family:var(--font-display);font-size:clamp(var(--text-2xl), 3vw, var(--text-4xl));font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.03em;margin:0;line-height:1.1}.dashboard-welcome__sub{font-size:var(--text-base);color:var(--color-text-muted)}.dashboard-welcome__meta{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.dashboard-welcome__level{background:var(--color-primary-container);color:var(--color-on-primary-container);padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);flex-direction:column;align-items:center;gap:2px;display:flex}.dark .dashboard-welcome__level{color:var(--color-primary);background:#4ade8026}.dashboard-welcome__level-label{font-size:10px;font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.08em;opacity:.7}.dashboard-welcome__level-value{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-extrabold)}.dashboard-upgrade-btn{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-bold);font-family:var(--font-display);color:var(--primary-foreground);background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));border-radius:var(--radius-full);box-shadow:0 2px 0 var(--color-primary-dark);transition:all var(--duration-fast) var(--ease-bounce);white-space:nowrap;text-decoration:none;display:inline-flex}.dashboard-upgrade-btn:hover{box-shadow:0 4px 0 var(--color-primary-dark), var(--shadow-primary);color:#fff;transform:translateY(-1px)}.streak-banner{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-radius:var(--radius-2xl);background:linear-gradient(135deg,#fff7ed,#ffedd5);border:1px solid #fed7aa;display:flex;position:relative;overflow:hidden}.dark .streak-banner{background:linear-gradient(135deg,#c2410c26,#9a34121a);border-color:#c2410c40}.streak-banner__flame{flex-shrink:0;font-size:2.5rem;animation:.8s ease-in-out infinite streakFlame}.streak-banner__content{flex-direction:column;flex:1;gap:2px;display:flex}.streak-banner__count{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-extrabold);color:var(--color-streak)}.streak-banner__sub{font-size:var(--text-sm);color:var(--color-text-muted)}.streak-banner__badge{font-size:var(--text-2xl);flex-shrink:0}.dashboard-section-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin-bottom:var(--space-4);letter-spacing:-.01em}.dashboard-bottom-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}@media (max-width:640px){.dashboard-bottom-row{grid-template-columns:1fr}.dashboard-welcome{flex-direction:column;align-items:flex-start}}.dashboard-plan-card{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-5);gap:var(--space-4);flex-direction:column;display:flex}.dashboard-plan-card__label{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);display:flex}.dashboard-plan-card__label strong{color:var(--color-text)}.dashboard-plan-card__cta{gap:var(--space-2);flex-direction:column;display:flex}.dashboard-plan-card__cta-text{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed)}.dashboard-plan-card__cta-btn{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);transition:gap var(--duration-fast) var(--ease-default);align-items:center;gap:var(--space-1);text-decoration:none;display:inline-flex}.dashboard-plan-card__cta-btn:hover{gap:var(--space-2);color:var(--color-primary-dark)}.dashboard-reading-card{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-5);align-items:center;gap:var(--space-4);display:flex}.dashboard-reading-card__icon{flex-shrink:0;font-size:2.5rem}.dashboard-reading-card__value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-text);line-height:1}.dashboard-reading-card__label{font-size:var(--text-sm);color:var(--color-text-muted)}.dashboard-reading-card__link{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);white-space:nowrap;flex-shrink:0;margin-left:auto;text-decoration:none}.dashboard-reading-card__link:hover{color:var(--color-primary-dark);text-decoration:underline}.auth-layout{background:linear-gradient(135deg, var(--color-primary-50) 0%, #fff 50%, var(--color-primary-100) 100%);min-height:100vh;padding:var(--space-4);justify-content:center;align-items:center;display:flex}.dark .auth-layout{background:linear-gradient(135deg, var(--color-bg) 0%, var(--color-surface) 100%)}.auth-layout__card{background-color:var(--color-surface);border-radius:var(--radius-2xl);width:100%;max-width:420px;box-shadow:var(--shadow-xl);padding:var(--space-8);gap:var(--space-6);flex-direction:column;display:flex}.auth-layout__logo{text-align:center}.auth-layout__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);letter-spacing:-.02em;margin:0}.auth-layout__subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0}.auth-divider{text-align:center;margin:var(--space-2) 0;position:relative}.auth-divider:before{content:"";background:var(--color-border);height:1px;position:absolute;top:50%;left:0;right:0}.auth-divider__text{background:var(--color-surface);padding:0 var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);position:relative}.auth-card__header{text-align:center;margin-bottom:var(--space-6)}.auth-card__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text);margin-bottom:var(--space-2)}.auth-card__subtitle{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed)}.auth-card__body{gap:var(--space-5);flex-direction:column;display:flex}.auth-card__footer{text-align:center;margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--color-border)}.auth-card__footer-text{font-size:var(--text-sm);color:var(--color-text-muted)}.auth-card__footer-link{color:var(--color-primary);font-weight:var(--font-semibold)}.dark .stat-card,.dark .card,.dark .dashboard-plan-card,.dark .dashboard-reading-card,.dark .quick-action-card{background-color:var(--color-surface)}.reading-card-grid{gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.reading-card-v2{background:var(--color-surface);border-radius:var(--radius-2xl);color:inherit;transition:all var(--duration-fast) var(--ease-bounce);flex-direction:column;text-decoration:none;display:flex;overflow:hidden}.reading-card-v2:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.reading-card-v2__cover{justify-content:center;align-items:center;height:120px;font-size:3.5rem;display:flex;position:relative;overflow:hidden}.reading-card-v2__level{top:var(--space-3);right:var(--space-3);position:absolute}.reading-card-v2__body{padding:var(--space-4) var(--space-5) var(--space-5);gap:var(--space-2);flex-direction:column;flex:1;display:flex}.reading-card-v2__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text)}.reading-card-v2__sub{font-size:var(--text-sm);color:var(--color-text-muted)}.reading-card-v2__meta{align-items:center;gap:var(--space-2);padding-top:var(--space-2);margin-top:auto;display:flex}.reading-card-v2__time{font-size:var(--text-xs);color:var(--color-text-subtle)}.report-wrap{align-items:center;margin-left:auto;display:inline-flex;position:relative}.report-trigger{border-radius:var(--radius-full);width:22px;height:22px;color:var(--color-text-muted);cursor:pointer;opacity:0;transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.trans-card:hover .report-trigger,.tc__bubble:hover .report-trigger,.report-trigger:focus{opacity:1}.report-trigger:hover{color:#ef4444;opacity:1;background:#ef44441a}.report-panel{background:var(--color-surface);border-radius:var(--radius-2xl);width:280px;box-shadow:var(--shadow-xl);z-index:100;position:absolute;bottom:calc(100% + 8px);right:0;overflow:hidden}.report-panel__header{padding:var(--space-3) var(--space-4);background:var(--color-surface-container-low);justify-content:space-between;align-items:center;display:flex}.report-panel__title{align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);display:flex}.report-panel__close{border-radius:var(--radius-full);width:22px;height:22px;color:var(--color-text-muted);cursor:pointer;transition:background var(--duration-fast) var(--ease-default);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.report-panel__close:hover{background:var(--color-surface-container-high)}.report-panel__form{gap:var(--space-3);padding:var(--space-4);flex-direction:column;display:flex}.report-panel__presets{gap:var(--space-1-5,6px);flex-direction:column;display:flex}.report-preset{text-align:left;padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);background:var(--color-surface-container-low);color:var(--color-text);font-size:var(--text-xs);font-family:var(--font-body);cursor:pointer;transition:background var(--duration-fast) var(--ease-default);border:none}.report-preset:hover{background:var(--color-surface-container-high)}.report-preset--active{color:#ef4444;background:#ef44441a}.report-panel__textarea{width:100%;padding:var(--space-3);background:var(--color-surface-container-low);border-radius:var(--radius-lg);font-size:var(--text-xs);font-family:var(--font-body);color:var(--color-text);resize:none;transition:border-color var(--duration-fast) var(--ease-default);border:2px solid #0000;outline:none}.report-panel__textarea:focus{border-color:#ef4444}.report-panel__error{color:#ef4444;margin:0;font-size:11px}.report-panel__done{padding:var(--space-4) var(--space-5);font-size:var(--text-sm);color:var(--color-primary);text-align:center}.report-panel__submit{justify-content:center;align-items:center;gap:var(--space-2);padding:8px var(--space-4);border-radius:var(--radius-lg);color:#fff;font-size:var(--text-xs);font-weight:var(--font-bold);font-family:var(--font-body);cursor:pointer;transition:opacity var(--duration-fast) var(--ease-default);background:#ef4444;border:none;display:inline-flex}.report-panel__submit:hover:not(:disabled){opacity:.85}.report-panel__submit:disabled{opacity:.4;cursor:not-allowed}.tc__report-btn,.trans-card__report{margin-left:auto}.trans-editor__badges{align-items:center;gap:var(--space-2);display:flex}.trans-editor__dirty-badge{font-size:10px;font-weight:var(--font-semibold);color:#f59e0b;animation:1.5s ease-in-out infinite pulse}.trans-editor__hint--published{align-items:flex-start;gap:var(--space-2);color:var(--color-primary);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);background:#4ade800f;display:flex}.trans-editor__textarea--dirty{border-color:#f59e0b66!important}.speak-btn{justify-content:center;align-items:center;gap:var(--space-1-5,6px);cursor:pointer;font-family:var(--font-body);transition:all var(--duration-fast) var(--ease-bounce);-webkit-tap-highlight-color:transparent;border:none;flex-shrink:0;display:inline-flex}.speak-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.speak-btn--icon{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;width:36px;height:36px}.speak-btn--icon:hover{transform:scale(1.1);box-shadow:0 4px 14px #4ade8059}.speak-btn--icon:active{transform:scale(.92)}.speak-btn--compact{border-radius:var(--radius-full);background:var(--color-surface-container-high);width:28px;height:28px;color:var(--color-text-muted)}.speak-btn--compact:hover{background:var(--color-primary);color:#fff;transform:scale(1.08)}.speak-btn--full{padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);background:var(--color-surface-container-low);color:var(--color-text-muted);font-size:var(--text-sm);font-weight:var(--font-medium)}.speak-btn--full:hover{background:var(--color-primary);color:#fff;box-shadow:0 4px 14px #4ade804d}.speak-btn--full .speak-btn__label{white-space:nowrap}.speak-btn--active{background:var(--color-primary)!important;color:#fff!important}.speak-btn--active .speak-btn__icon{animation:1s ease-in-out infinite speak-pulse}@keyframes speak-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.15)}}.dark .speak-btn--compact{background:#ffffff14}.dark .speak-btn--compact:hover{background:var(--color-primary)}.dark .speak-btn--full{background:#ffffff0f}@media (max-width:640px){.speak-btn--icon{width:32px;height:32px}.speak-btn--full{padding:var(--space-1-5,6px) var(--space-3);font-size:var(--text-xs)}}
.dict-page__hero-icon{flex-shrink:0;font-size:3rem}.dict-page__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.02em;margin:0}.dict-page__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0}.dict-page__levels{gap:var(--space-2);flex-wrap:wrap;align-self:flex-end;display:flex}.dict-page__level-pill{padding:var(--space-1) var(--space-3);font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-text-muted);background:var(--color-surface-container-high);border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-bounce);text-decoration:none}.dict-page__level-pill:hover{background:var(--color-primary-container);color:var(--color-on-primary-container);transform:translateY(-1px)}.dict-page__level-pill--active{background:var(--color-primary-container);color:var(--color-on-primary-container)}.dark .dict-page__level-pill--active{color:var(--color-primary);background:#4ade8026}.dict-results-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.dict-results-header__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text)}.dict-results-header__count{font-size:var(--text-sm);color:var(--color-text-muted);background:var(--color-surface-container-high);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full)}.dict-empty{align-items:center;gap:var(--space-4);padding:var(--space-16) 0;text-align:center;flex-direction:column;display:flex}.dict-empty__icon{font-size:4rem}.pagination{justify-content:center;align-items:center;gap:var(--space-3);margin-top:var(--space-8);flex-wrap:wrap;display:flex}.pagination__btn{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);background:var(--color-surface);border-radius:var(--radius-xl);transition:all var(--duration-fast) var(--ease-bounce);box-shadow:var(--shadow-sm);text-decoration:none}.pagination__btn:hover{background:var(--color-primary-container);box-shadow:var(--shadow-md);transform:translateY(-1px)}.pagination__info{font-size:var(--text-sm);color:var(--color-text-muted)}.pagination__page{width:36px;height:36px;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);background:var(--color-surface);border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-default);justify-content:center;align-items:center;text-decoration:none;display:flex}.pagination__page:hover{background:var(--color-surface-container-high);color:var(--color-text)}.dict-page{gap:var(--space-6);flex-direction:column;display:flex}.dict-page__header{justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.dict-page__hero{align-items:center;gap:var(--space-4);display:flex}.dict-page__hero-icon{filter:drop-shadow(0 4px 12px #3b82f640);flex-shrink:0;font-size:3rem}.dict-page__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);letter-spacing:-.03em;color:var(--color-text);margin:0;line-height:1.1}.dict-page__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0;line-height:var(--leading-vi)}.dict-page__levels{gap:var(--space-2);flex-wrap:wrap;display:flex}.dict-page__level-pill{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-text-muted);background:var(--color-surface);transition:all var(--duration-fast) var(--ease-default);align-items:center;padding:4px 12px;text-decoration:none;display:inline-flex}.dict-page__level-pill:hover,.dict-page__level-pill--active{background:var(--color-primary);color:var(--color-on-primary)}.dict-search{gap:var(--space-3);background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-5);flex-direction:column;display:flex}.dict-search__back-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-primary);background:var(--color-primary-container);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);font-family:var(--font-body);border:none;width:fit-content;display:inline-flex}.dict-search__back-btn:hover{background:var(--color-primary);color:var(--color-on-primary)}.dark .dict-search__back-btn{background:#4ade801a}.dark .dict-search__back-btn:hover{background:var(--color-primary);color:#111}.dict-search__active-level{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);background:var(--color-primary);color:var(--color-on-primary);align-items:center;padding:1px 8px;display:inline-flex}.dict-search__back-btn:hover .dict-search__active-level{color:var(--color-on-primary);background:#ffffff40}.dict-search__tabs{gap:var(--space-1);background:var(--color-surface-container-low);border-radius:var(--radius-xl);width:fit-content;padding:4px;display:flex}.dict-search__tab{align-items:center;gap:var(--space-1-5,6px);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);white-space:nowrap;font-family:var(--font-body);background:0 0;border:none;display:inline-flex}.dict-search__tab:hover{color:var(--color-text)}.dict-search__tab--active{background:var(--color-surface);color:var(--color-text);font-weight:var(--font-semibold);box-shadow:0 1px 3px #0000001f}.dict-search__form{align-items:center;display:flex;position:relative}.dict-search__search-icon{left:var(--space-4);color:var(--color-text-muted);pointer-events:none;flex-shrink:0;position:absolute}.dict-search__input{width:100%;height:52px;padding:0 var(--space-10) 0 calc(var(--space-10) + 4px);background:var(--color-surface-container-low);border-radius:var(--radius-xl);font-size:var(--text-base);color:var(--color-text);font-family:var(--font-body);transition:border-color var(--duration-fast) var(--ease-default), background var(--duration-fast) var(--ease-default);-webkit-appearance:none;border:2px solid #0000;outline:none}.dict-search__input:focus{border-color:var(--color-primary);background:var(--color-surface-container-low)}.dict-search__input::placeholder{color:var(--color-text-muted)}.dict-search__input::-webkit-search-cancel-button{display:none}.dict-search__clear{right:var(--space-4);border-radius:var(--radius-full);background:var(--color-surface-container-high);width:24px;height:24px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);border:none;justify-content:center;align-items:center;display:flex;position:absolute}.dict-search__clear:hover{color:#ef4444;background:#ef444426}.dict-search__umlauts{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.dict-search__umlaut-btn{min-width:32px;height:28px;padding:0 var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-container-low);color:var(--color-primary);font-size:var(--text-sm);font-weight:var(--font-semibold);font-family:var(--font-body);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;line-height:1;display:inline-flex}.dict-search__umlaut-btn:hover{background:var(--color-primary-container);border-color:var(--color-primary);color:var(--color-on-primary-container);transform:translateY(-1px);box-shadow:0 2px 4px #00000014}.dict-search__umlaut-btn:active{box-shadow:none;background:var(--color-primary);color:var(--color-on-primary);transform:translateY(0)}.dark .dict-search__umlaut-btn{color:var(--color-primary);background:#ffffff0d;border-color:#ffffff1a}.dark .dict-search__umlaut-btn:hover{border-color:var(--color-primary);background:#4ade8026}.dark .dict-search__umlaut-btn:active{background:var(--color-primary);color:#111}.detail-search{gap:var(--space-2);background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-4);flex-direction:column;display:flex}.detail-search__umlauts{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.detail-search__umlaut-btn{min-width:28px;height:24px;padding:0 var(--space-1-5,6px);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-container-low);color:var(--color-primary);font-size:var(--text-xs);font-weight:var(--font-semibold);font-family:var(--font-body);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;line-height:1;display:inline-flex}.detail-search__umlaut-btn:hover{background:var(--color-primary-container);border-color:var(--color-primary);color:var(--color-on-primary-container);transform:translateY(-1px);box-shadow:0 1px 3px #0000000f}.detail-search__umlaut-btn:active{background:var(--color-primary);color:var(--color-on-primary);transform:translateY(0)}.dark .detail-search__umlaut-btn{color:var(--color-primary);background:#ffffff0d;border-color:#ffffff1a}.dark .detail-search__umlaut-btn:hover{border-color:var(--color-primary);background:#4ade8026}.dark .detail-search__umlaut-btn:active{background:var(--color-primary);color:#111}.detail-search__form{align-items:center;gap:var(--space-2);display:flex;position:relative}.detail-search__icon{left:var(--space-3);color:var(--color-text-muted);pointer-events:none;flex-shrink:0;position:absolute}.detail-search__input{width:100%;height:40px;padding:0 calc(var(--space-8) + var(--space-3)) 0 calc(var(--space-8) + 4px);background:var(--color-surface-container-low);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--color-text);font-family:var(--font-body);transition:border-color var(--duration-fast) var(--ease-default), background var(--duration-fast) var(--ease-default);-webkit-appearance:none;border:2px solid #0000;outline:none}.detail-search__input:focus{border-color:var(--color-primary)}.detail-search__input::placeholder{color:var(--color-text-muted)}.detail-search__input::-webkit-search-cancel-button{display:none}.detail-search__clear{right:calc(var(--space-3) + 32px);border-radius:var(--radius-full);background:var(--color-surface-container-high);width:22px;height:22px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);border:none;justify-content:center;align-items:center;display:flex;position:absolute}.detail-search__clear:hover{color:#ef4444;background:#ef444426}.detail-search__submit{right:var(--space-1);border-radius:var(--radius-md);background:var(--color-primary);width:32px;height:32px;color:var(--color-on-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);border:none;justify-content:center;align-items:center;display:flex;position:absolute}.detail-search__submit:hover{opacity:.9;transform:scale(1.05)}.detail-search__submit:active{transform:scale(.95)}.dict-filters{gap:var(--space-3);padding-top:var(--space-3);flex-direction:column;display:flex}.dict-filters__group{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.dict-filters__label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);white-space:nowrap;min-width:56px}.dict-filters__chips{gap:var(--space-1-5,6px);flex-wrap:wrap;display:flex}.dict-chip{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);background:var(--color-surface-container-high);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);font-family:var(--font-body);border:none;align-items:center;padding:4px 12px;display:inline-flex}.dict-chip:hover{color:var(--color-text)}.dict-chip--active{background:var(--color-primary);color:var(--color-on-primary);font-weight:var(--font-semibold)}.dict-results-header{justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.dict-results-header__left{align-items:center;gap:var(--space-3);display:flex}.dict-results-header__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin:0}.dict-results-header__count{padding:3px var(--space-3);background:var(--color-primary-container);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-on-primary-container);align-items:center;display:inline-flex}.dark .dict-results-header__count{color:var(--color-primary);background:#4ade801f}.dict-list{background:var(--color-surface);border-radius:var(--radius-2xl);flex-direction:column;gap:0;display:flex;overflow:hidden}.dict-row{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);color:inherit;transition:background var(--duration-fast) var(--ease-default);text-decoration:none;display:flex;position:relative}.dict-row+.dict-row{background-image:linear-gradient(to right, transparent 0, var(--color-surface-container-low) 16px, var(--color-surface-container-low) calc(100% - 16px), transparent 100%);background-position:top;background-repeat:no-repeat;background-size:100% 1px}.dict-row:hover{background:var(--color-surface-container-low)}.dict-row__gender-bar{border-radius:var(--radius-full);flex-shrink:0;align-self:center;width:3px;height:36px}.dict-row__word-col{flex-direction:column;flex-shrink:0;gap:2px;width:200px;min-width:160px;display:flex}.dict-row__word-line{align-items:baseline;gap:var(--space-2);flex-wrap:wrap;display:flex}.dict-row__gender{font-size:var(--text-xs);font-weight:var(--font-bold);opacity:.85;flex-shrink:0}.dict-row__word{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);letter-spacing:-.01em}.dict-row__plural{color:var(--color-text-muted);white-space:nowrap;font-size:11px}.dict-row__ipa{color:var(--color-text-muted);align-items:center;gap:4px;font-family:monospace;font-size:11px;line-height:1;display:flex}.dict-row__meaning-col{flex:1;min-width:0}.dict-row__meaning{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-snug);-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.dict-row__tags-col{align-items:center;gap:var(--space-1-5,6px);flex-shrink:0;display:flex}.dict-row__level-badge{border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-bold);color:var(--color-primary);background:#4ade801f;align-items:center;padding:2px 8px;display:inline-flex}.dark .dict-row__level-badge{background:#4ade8026}.dict-row__pos-badge{border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-medium);background:var(--color-surface-container-high);color:var(--color-text-muted);align-items:center;padding:2px 8px;display:inline-flex}.dict-row__actions{align-items:center;gap:var(--space-2);opacity:0;transition:opacity var(--duration-fast) var(--ease-default);flex-shrink:0;display:flex}.dict-row:hover .dict-row__actions{opacity:1}.dict-row__actions .wd__add-nb-trigger{background:var(--color-surface-container-high);width:28px;height:28px;color:var(--color-text-muted);border:none;position:static}.dict-row__actions .wd__add-nb-trigger:hover{background:var(--color-primary);color:#fff;transform:scale(1.1)}.dict-row__actions .wd__add-nb-trigger--added{background:var(--color-primary);color:#fff}.dict-row__arrow{color:var(--color-text-muted)}.dict-empty{align-items:center;gap:var(--space-4);padding:var(--space-16) var(--space-4);text-align:center;background:var(--color-surface);border-radius:var(--radius-2xl);flex-direction:column;display:flex}.dict-empty__icon{opacity:.6;font-size:3.5rem}.dict-empty__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.dict-empty__sub{font-size:var(--text-sm);color:var(--color-text-muted);max-width:360px;line-height:var(--leading-vi)}.dict-section-divider{background:var(--color-surface-container-high);height:1px;margin:var(--space-4) 0}.pagination{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-4) 0;display:flex}.pagination__btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);background:var(--color-surface);transition:all var(--duration-fast) var(--ease-default);align-items:center;text-decoration:none;display:inline-flex}.pagination__btn:hover{background:var(--color-surface-container-low)}.pagination__pages{gap:var(--space-1);display:flex}.pagination__page{border-radius:var(--radius-lg);width:36px;height:36px;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);background:var(--color-surface);transition:all var(--duration-fast) var(--ease-default);justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.pagination__page:hover{color:var(--color-text);background:var(--color-surface-container-low)}.pagination__page--active{background:var(--color-primary);color:var(--color-on-primary);font-weight:var(--font-bold)}@media (max-width:768px){.dict-page__header{flex-direction:column;align-items:flex-start}.dict-page__title{font-size:var(--text-2xl)}.dict-row{gap:var(--space-3);padding:var(--space-3) var(--space-4)}.dict-row__word-col{width:150px;min-width:130px}.dict-row__tags-col{display:none}.dict-row__actions{opacity:1}.dict-search{padding:var(--space-4)}.dict-search__tabs{width:100%}.dict-search__tab{flex:1;justify-content:center}}@media (max-width:480px){.dict-row__ipa,.dict-row__plural{display:none}.dict-row__word-col{width:120px;min-width:100px}}.level-grid{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}@media (max-width:640px){.level-grid{grid-template-columns:1fr}}@media (min-width:960px){.level-grid{grid-template-columns:repeat(4,1fr)}}.level-card{gap:var(--space-3);padding:var(--space-5);background:var(--color-surface);border-radius:var(--radius-2xl);color:inherit;transition:transform var(--duration-fast) var(--ease-bounce), box-shadow var(--duration-fast) var(--ease-default);flex-direction:column;min-height:180px;text-decoration:none;display:flex;position:relative;overflow:hidden}.level-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px -4px #0000001a,0 4px 8px -2px #0000000f}.dark .level-card:hover{box-shadow:0 8px 24px -4px #0000004d,0 4px 8px -2px #0003}.level-card__accent{border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;height:4px;position:absolute;top:0;left:0;right:0}.level-card__icon{border-radius:var(--radius-xl);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.level-card__body{gap:var(--space-2);flex-direction:column;flex:1;display:flex}.level-card__header{align-items:center;gap:var(--space-2);display:flex}.level-card__level{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-extrabold);letter-spacing:.04em;align-items:center;padding:3px 10px;line-height:1;display:inline-flex}.level-card__sublabel{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted)}.level-card__desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi);margin:0}.level-card__stats{align-items:center;gap:var(--space-1-5,6px);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);padding-top:var(--space-2);margin-top:auto;display:flex}.level-card__arrow{top:var(--space-4);right:var(--space-4);font-size:var(--text-lg);font-weight:var(--font-bold);opacity:0;transition:opacity var(--duration-fast) var(--ease-default), transform var(--duration-fast) var(--ease-default);position:absolute;transform:translate(-4px)}.level-card:hover .level-card__arrow{opacity:1;transform:translate(0)}
﻿ .fc-page{gap:var(--space-6);flex-direction:column;display:flex}.fc-page__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.fc-page__hero{align-items:center;gap:var(--space-4);display:flex}.fc-page__hero-icon{flex-shrink:0;font-size:3rem}.fc-page__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);letter-spacing:-.02em;color:var(--color-text);margin:0}.fc-page__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0;line-height:var(--leading-vi)}.fc-summary{align-items:center;gap:var(--space-6);background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-5) var(--space-6);display:flex}.fc-summary__item{align-items:center;gap:var(--space-3);display:flex}.fc-summary__icon{font-size:var(--text-2xl)}.fc-summary__value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text);line-height:1}.fc-summary__label{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px}.fc-summary__divider{background:var(--color-border);flex-shrink:0;width:1px;height:40px}.fc-due-alert{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-radius:var(--radius-2xl);background:linear-gradient(135deg,#fff7ed,#ffedd5);border:1px solid #fed7aa;display:flex}.dark .fc-due-alert{background:#c2410c1a;border-color:#c2410c33}.fc-due-alert__icon{font-size:var(--text-2xl)}.fc-due-alert__text{font-size:var(--text-sm);color:var(--color-text-muted);flex:1}.fc-due-alert__text strong{color:var(--color-streak)}.fc-due-alert__btn{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-bold);font-family:var(--font-display);color:#fff;background:var(--color-streak);border-radius:var(--radius-full);white-space:nowrap;transition:all var(--duration-fast) var(--ease-bounce);text-decoration:none;box-shadow:0 2px #c2410c}.fc-due-alert__btn:hover{color:#fff;transform:translateY(-1px);box-shadow:0 4px #c2410c}.fc-deck-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.fc-deck-card{background:var(--color-surface);border-radius:var(--radius-2xl);color:inherit;transition:all var(--duration-fast) var(--ease-bounce);flex-direction:column;text-decoration:none;display:flex;overflow:hidden}.fc-deck-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.fc-deck-card__cover{background:linear-gradient(135deg, var(--color-surface-container-low), var(--color-surface-container));height:100px;transition:background var(--duration-normal) var(--ease-default);justify-content:center;align-items:center;font-size:3rem;display:flex;position:relative}.fc-deck-card:hover .fc-deck-card__cover{background:linear-gradient(135deg, var(--color-primary-50), var(--color-primary-100))}.dark .fc-deck-card:hover .fc-deck-card__cover{background:#4ade801a}.fc-deck-card__emoji{transition:transform var(--duration-fast) var(--ease-bounce)}.fc-deck-card:hover .fc-deck-card__emoji{animation:none;transform:scale(1.15)rotate(-5deg)}.fc-deck-card__due-badge{top:var(--space-2);right:var(--space-2);min-width:24px;height:24px;padding:0 var(--space-2);background:var(--color-streak);color:#fff;font-size:11px;font-weight:var(--font-bold);border-radius:var(--radius-full);justify-content:center;align-items:center;animation:2s ease-in-out infinite pulse;display:flex;position:absolute}.fc-deck-card__body{padding:var(--space-4) var(--space-4) var(--space-4);gap:var(--space-2);flex-direction:column;flex:1;display:flex}.fc-deck-card__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);line-height:var(--leading-snug)}.fc-deck-card__desc{font-size:var(--text-xs);color:var(--color-text-muted);line-height:var(--leading-relaxed);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.fc-deck-card__meta{align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-top:auto;display:flex}.fc-deck-card__count{font-size:var(--text-xs);color:var(--color-text-muted);align-items:center;gap:4px;display:flex}.fc-deck-card__done{font-size:var(--text-xs);color:var(--color-success);font-weight:var(--font-medium)}.fc-deck-card__action{align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);padding-top:var(--space-2);border-top:1px solid var(--color-border);margin-top:var(--space-2);transition:gap var(--duration-fast) var(--ease-default);display:flex}.fc-deck-card:hover .fc-deck-card__action{gap:var(--space-3)}.fc-deck-card__arrow{transition:transform var(--duration-fast) var(--ease-default);margin-left:auto}.fc-deck-card:hover .fc-deck-card__arrow{transform:translate(4px)}.fc-new-deck-card{background:var(--color-surface-container-low);border:2px dashed var(--color-border);border-radius:var(--radius-2xl);justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-8);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);flex-direction:column;min-height:200px;display:flex}.fc-new-deck-card:hover{border-color:var(--color-primary);background:var(--color-primary-50)}.dark .fc-new-deck-card:hover{background:#4ade800d}.fc-new-deck-card__icon{border-radius:var(--radius-full);background:var(--color-surface-container-high);width:48px;height:48px;font-size:var(--text-2xl);font-weight:var(--font-thin);color:var(--color-text-muted);transition:all var(--duration-fast) var(--ease-bounce);justify-content:center;align-items:center;display:flex}.fc-new-deck-card:hover .fc-new-deck-card__icon{background:var(--color-primary);color:#fff;transform:rotate(90deg)}.fc-new-deck-card__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted)}.fc-empty{align-items:center;gap:var(--space-4);padding:var(--space-16) 0;text-align:center;flex-direction:column;display:flex}.fc-empty__icon{font-size:5rem}.fc-empty__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text)}.fc-empty__sub{font-size:var(--text-sm);color:var(--color-text-muted);max-width:360px;line-height:var(--leading-vi)}.fc-tips{background:var(--color-surface-container-low);border-radius:var(--radius-2xl);padding:var(--space-5);gap:var(--space-4);flex-direction:column;display:flex}.dark .fc-tips{background:var(--color-surface)}.fc-tips__header{align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);display:flex}.fc-tips__grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.fc-tips__item{gap:var(--space-3);align-items:flex-start;display:flex}.fc-tips__item-icon{font-size:var(--text-xl);flex-shrink:0}.fc-tips__item-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.fc-tips__item-desc{font-size:var(--text-xs);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin-top:2px}@media (max-width:640px){.fc-summary{gap:var(--space-4);flex-wrap:wrap}.fc-page__header,.dict-page__header{flex-direction:column}.dict-page__levels{align-self:flex-start}.fc-deck-grid{grid-template-columns:1fr 1fr}}@media (max-width:400px){.fc-deck-grid{grid-template-columns:1fr}}.fcd{gap:var(--space-6);flex-direction:column;display:flex}.fcd__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.fcd__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.02em;align-items:center;gap:var(--space-2);margin:0;display:flex}.fcd__desc{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0}.fcd__actions{align-items:center;gap:var(--space-2);flex-wrap:wrap;flex-shrink:0;display:flex}.add-card-trigger,.import-trigger{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-semibold);font-family:var(--font-display);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);white-space:nowrap;border:none;display:inline-flex}.add-card-trigger{background:var(--color-primary);color:#fff;box-shadow:0 3px 0 var(--color-primary-dark)}.add-card-trigger:hover{box-shadow:0 4px 0 var(--color-primary-dark);transform:translateY(-1px)}.import-trigger{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.import-trigger:hover{background:var(--color-surface-container-high);transform:translateY(-1px)}.fcd__section-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);align-items:center;gap:var(--space-2);margin:0;display:flex}.fcd__review-section{gap:var(--space-4);flex-direction:column;display:flex}.fcd__done-state{padding:var(--space-12) var(--space-4);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.fcd__done-icon{border-radius:var(--radius-2xl);padding:var(--space-6);margin-bottom:var(--space-4);background:#10b9811a;background:lab(66.6921% -50.6677 17.059/.1)}.fcd__done-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-1)}.fcd__done-desc{font-size:var(--text-sm);color:var(--color-text-muted);max-width:400px;margin:0}.fcd__cards-section{gap:var(--space-4);flex-direction:column;display:flex}.fcd__card-list{gap:var(--space-2);flex-direction:column;display:flex}.fcd__card-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:border-color var(--duration-fast) var(--ease-default);display:flex}.fcd__card-item:hover{border-color:color-mix(in oklch, var(--color-primary) 30%, transparent)}.fcd__card-dot{border-radius:var(--radius-full);flex-shrink:0;width:8px;height:8px}.fcd__card-dot--new{background:var(--color-surface-container-high)}.fcd__card-dot--learning{background:#3b82f6}.fcd__card-dot--mastered{background:var(--color-primary)}.fcd__card-content{align-items:baseline;gap:0 var(--space-1);flex-wrap:wrap;flex:1;min-width:0;display:flex}.fcd__card-front{font-weight:var(--font-semibold);color:var(--color-text)}.fcd__card-arrow{color:var(--color-text-muted);margin:0 var(--space-1)}.fcd__card-back{color:var(--color-text-muted)}.fcd__card-meta{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.fc-review-ipa{font-family:Noto Sans,Segoe UI,system-ui,sans-serif;font-size:var(--text-base);color:var(--color-primary);font-weight:var(--font-medium);letter-spacing:.02em;margin:var(--space-1) 0;opacity:.85}.fc-card-ipa{font-family:Noto Sans,Segoe UI,system-ui,sans-serif;font-size:var(--text-xs);color:var(--color-primary);font-weight:var(--font-medium);margin-left:var(--space-1);opacity:.8}.fc-cards-list-header{justify-content:space-between;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.fc-cards-list-legend{align-items:center;gap:var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);display:flex}.fc-legend-item{align-items:center;gap:4px;display:flex}.fc-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.fc-legend-dot--new{background:var(--color-surface-container-high)}.fc-legend-dot--learning{background:#3b82f6}.fc-legend-dot--mastered{background:var(--color-primary)}.fc-empty-deck{align-items:center;gap:var(--space-4);padding:var(--space-12) 0;text-align:center;flex-direction:column;display:flex}.fc-empty-deck__icon{font-size:4rem}.fc-empty-deck__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.fc-empty-deck__desc{font-size:var(--text-sm);color:var(--color-text-muted);max-width:360px;line-height:var(--leading-vi)}.fc-empty-deck__actions{align-items:center;gap:var(--space-3);margin-top:var(--space-2);display:flex}@media (max-width:768px){.fcd__header{flex-direction:column}.fcd__card-meta{display:none}}.fcr{align-items:center;gap:var(--space-6);flex-direction:column;width:100%;max-width:560px;margin:0 auto;display:flex}.fcr__progress{align-items:center;gap:var(--space-3);width:100%;display:flex}.fcr__progress-bar{background:var(--color-surface-container-high);border-radius:var(--radius-full);flex:1;height:6px;overflow:hidden}.fcr__progress-fill{background:var(--color-primary);border-radius:var(--radius-full);height:100%;transition:width .3s var(--ease-default)}.fcr__progress-text{font-size:var(--text-sm);color:var(--color-text-muted);white-space:nowrap}.fcr__card-wrapper{perspective:1000px;cursor:pointer;outline:none;width:100%;min-height:280px}.fcr__card-wrapper:focus-visible{outline:2px solid var(--color-primary);outline-offset:4px;border-radius:var(--radius-2xl)}.fcr__card-inner{width:100%;min-height:280px;transition:transform .5s var(--ease-bounce);transform-style:preserve-3d;position:relative}.fcr__card-inner--flipped{transform:rotateY(180deg)}.fcr__card-face{backface-visibility:hidden;border-radius:var(--radius-2xl);border:1px solid var(--color-border);background:var(--color-surface);padding:var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.fcr__card-back{border-color:color-mix(in oklch, var(--color-primary) 30%, transparent);transform:rotateY(180deg)}.fcr__card-front-text{font-size:var(--text-3xl);font-weight:var(--font-bold);font-family:var(--font-display);color:var(--color-text);margin:0 0 var(--space-1)}.fcr__card-back-text{font-size:var(--text-2xl);font-weight:var(--font-bold);font-family:var(--font-display);color:var(--color-primary);margin:0 0 var(--space-3)}.fcr__card-extra{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-2) 0 0}.fcr__card-hint{font-size:var(--text-xs);color:color-mix(in oklch, var(--color-text-muted) 50%, transparent);margin:var(--space-6) 0 0;align-items:center;gap:var(--space-1);display:flex}.fcr__rating{gap:var(--space-3);flex-direction:column;width:100%;display:flex}.fcr__rating-label{font-size:var(--text-sm);text-align:center;color:var(--color-text-muted);margin:0}.fcr__rating-grid{gap:var(--space-2);grid-template-columns:repeat(4,1fr);display:grid}.fcr__rate-btn{align-items:center;gap:var(--space-1);padding:var(--space-3) var(--space-2);border-radius:var(--radius-xl);color:#fff;font-weight:var(--font-semibold);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);border:none;flex-direction:column;display:flex}.fcr__rate-btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px)}.fcr__rate-btn:active:not(:disabled){transform:translateY(0)}.fcr__rate-btn:disabled{opacity:.5;cursor:not-allowed}.fcr__rate-btn--again{background:#ef4444;box-shadow:0 3px #dc2626}.fcr__rate-btn--hard{background:#f97316;box-shadow:0 3px #ea580c}.fcr__rate-btn--good{background:#10b981;box-shadow:0 3px #059669}.fcr__rate-btn--easy{background:#3b82f6;box-shadow:0 3px #2563eb}.fcr__rate-btn-label{font-weight:var(--font-bold)}.fcr__rate-btn-hint{opacity:.7;font-size:10px;font-weight:var(--font-normal)}.fcr__complete{padding:var(--space-16) var(--space-4);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.fcr__complete-icon{border-radius:var(--radius-2xl);padding:var(--space-8);margin-bottom:var(--space-6);background:#10b9811a;background:lab(66.6921% -50.6677 17.059/.1)}.fcr__complete-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-2)}.fcr__complete-desc{font-size:var(--text-base);color:var(--color-text-muted);margin:0 0 var(--space-1)}.fcr__complete-sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.animate-fade-in-up{animation:fadeInUp .3s var(--ease-default) both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.fcr__card-wrapper,.fcr__card-inner{min-height:220px}.fcr__card-front-text{font-size:var(--text-2xl)}.fcr__card-back-text{font-size:var(--text-xl)}.fcr__card-face{padding:var(--space-6)}}.fcr__card-wrapper--exit{opacity:0;transition:opacity .15s,transform .15s;transform:scale(.95)}.fcr__swipe-indicator{top:var(--space-4);z-index:10;padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-bold);color:#fff;pointer-events:none;animation:fadeInUp .15s var(--ease-default) both;position:absolute}.fcr__swipe-indicator--left{right:var(--space-4);background:#f97316}.fcr__swipe-indicator--right{left:var(--space-4);background:#10b981}.fcr__swipe-hint{font-size:var(--text-xs);color:color-mix(in oklch, var(--color-text-muted) 60%, transparent);text-align:center;margin:calc(var(--space-2) * -1) 0;display:none}@media (hover:none) and (pointer:coarse){.fcr__swipe-hint{display:block}}.fcr__shortcut-hint{font-size:var(--text-xs);text-align:center;color:color-mix(in oklch, var(--color-text-muted) 50%, transparent);margin:0}@media (hover:none) and (pointer:coarse){.fcr__shortcut-hint{display:none}}.fcr__reload-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);background:var(--color-primary);color:#fff;font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;margin-top:var(--space-6);transition:all var(--duration-fast) var(--ease-bounce);box-shadow:0 3px 0 var(--color-primary-dark);border:none;display:inline-flex}.fcr__reload-btn:hover{box-shadow:0 4px 0 var(--color-primary-dark);transform:translateY(-1px)}
﻿ .prc-wrapper{position:relative}.prc-wrapper__back{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;padding:var(--space-1) 0;margin-bottom:var(--space-4);transition:color var(--duration-fast) var(--ease-default);background:0 0;border:none;display:inline-flex}.prc-wrapper__back:hover{color:var(--color-primary)}.prc-menu__header{margin-bottom:var(--space-5)}.prc-menu__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-extrabold);color:var(--color-text);margin:0 0 var(--space-1) 0}.prc-menu__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.prc-menu__grid{gap:var(--space-3);margin-bottom:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(160px,1fr));display:grid}.prc-menu__card{align-items:center;gap:var(--space-2);padding:var(--space-5) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);cursor:pointer;transition:all var(--duration-normal) var(--ease-default);text-align:center;flex-direction:column;display:flex;position:relative;overflow:hidden}.prc-menu__card:before{content:"";background:var(--prc-color,var(--color-primary));opacity:0;height:3px;transition:opacity var(--duration-fast) var(--ease-default);position:absolute;top:0;left:0;right:0}.prc-menu__card:hover:not(:disabled){border-color:var(--prc-color,var(--color-primary));transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.prc-menu__card:hover:not(:disabled):before{opacity:1}.dark .prc-menu__card{background:var(--color-surface-container-low)}.prc-menu__card--locked{opacity:.5;cursor:not-allowed}.prc-menu__card-emoji{font-size:var(--text-3xl)}.prc-menu__card-title{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text)}.prc-menu__card-desc{font-size:var(--text-xs);color:var(--color-text-muted);line-height:var(--leading-relaxed)}.prc-menu__card-lock{color:var(--color-text-muted);margin-top:var(--space-1);align-items:center;gap:4px;font-size:11px;display:flex}.prc-menu__hint{font-size:var(--text-sm);color:var(--color-text-muted);text-align:center;padding:var(--space-3);border-radius:var(--radius-xl);background:#f59e0b0f}.prc-done{text-align:center;padding:var(--space-8) var(--space-4);flex-direction:column;align-items:center;display:flex}.prc-done__icon{font-size:var(--text-5xl);margin-bottom:var(--space-3)}.prc-done__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text);margin:0 0 var(--space-1) 0}.prc-done__type{font-size:var(--text-sm);color:var(--color-text-muted);margin:0 0 var(--space-5) 0}.prc-done__score{width:120px;height:120px;margin-bottom:var(--space-4);position:relative}.prc-done__ring{width:120px;height:120px}.prc-done__score-text{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.prc-done__score-pct{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text)}.prc-done__score-detail{font-size:var(--text-xs);color:var(--color-text-muted)}.prc-done__message{font-size:var(--text-sm);color:var(--color-text-muted);margin:0 0 var(--space-5) 0}.prc-done__actions{gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.prc-done__btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-bold);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);border:none;display:inline-flex}.prc-done__btn--retry{background:var(--color-primary);color:var(--color-on-primary)}.prc-done__btn--retry:hover{opacity:.9;transform:translateY(-1px)}.prc-done__btn--back{background:var(--color-surface-container-high);color:var(--color-text)}.prc-done__btn--back:hover{background:var(--color-surface-container)}.prc-match{max-width:600px;margin:0 auto}.prc-match__header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.prc-match__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin:0}.prc-match__progress{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted);background:var(--color-surface-container-high);border-radius:var(--radius-full);padding:3px 12px}.prc-match__grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.prc-match__col{gap:var(--space-2);flex-direction:column;display:flex}.prc-match__item{padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);border:2px solid var(--color-border);background:var(--color-surface);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);text-align:center;line-height:var(--leading-relaxed);justify-content:center;align-items:center;min-height:44px;display:flex}.dark .prc-match__item{background:var(--color-surface-container-low)}.prc-match__item:hover:not(:disabled){border-color:var(--color-primary)}.prc-match__item--selected{background:#3b82f60f;border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f633}.prc-match__item--matched{opacity:.6;cursor:default;background:#22c55e0f;border-color:#22c55e}.prc-match__item--wrong{background:#ef44440f;border-color:#ef4444;animation:.4s shake}.prc-match__mistakes{text-align:center;font-size:var(--text-sm);color:#ef4444;margin-top:var(--space-3)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.prc-fill{max-width:520px;margin:0 auto}.prc-fill__header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.prc-fill__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin:0}.prc-fill__progress{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted);background:var(--color-surface-container-high);border-radius:var(--radius-full);padding:3px 12px}.prc-fill__bar{background:var(--color-surface-container-high);border-radius:var(--radius-full);height:4px;margin-bottom:var(--space-5);overflow:hidden}.prc-fill__bar-fill{background:linear-gradient(90deg, var(--color-primary), #34d399);border-radius:var(--radius-full);height:100%;transition:width var(--duration-normal) var(--ease-default)}.prc-fill__question{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-5);margin-bottom:var(--space-4)}.dark .prc-fill__question{background:var(--color-surface-container-low)}.prc-fill__meaning{font-size:var(--text-base);color:var(--color-text);margin:0 0 var(--space-3) 0}.prc-fill__meaning-label{font-weight:var(--font-bold);color:var(--color-text-muted);margin-right:var(--space-2)}.prc-fill__hint{font-size:var(--text-sm);color:var(--color-text-muted);align-items:center;gap:var(--space-2);flex-wrap:wrap;margin:0;display:flex}.prc-fill__hint-label{font-weight:var(--font-semibold)}.prc-fill__hint code{font-family:var(--font-mono);background:var(--color-surface-container-high);border-radius:var(--radius-md);letter-spacing:1px;padding:2px 8px}.prc-fill__hint-len{font-size:var(--text-xs);opacity:.7}.prc-fill__input-row{gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.prc-fill__input{padding:var(--space-3) var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-xl);font-size:var(--text-base);background:var(--color-surface);color:var(--color-text);transition:border-color var(--duration-fast) var(--ease-default);flex:1}.dark .prc-fill__input{background:var(--color-surface-container-low)}.prc-fill__input:focus{border-color:var(--color-primary);outline:none}.prc-fill__input--correct{background:#22c55e0a;border-color:#22c55e}.prc-fill__input--wrong{background:#ef44440a;border-color:#ef4444}.prc-fill__btn{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-bold);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);white-space:nowrap;border:none;display:inline-flex}.prc-fill__btn--check{background:var(--color-primary);color:var(--color-on-primary)}.prc-fill__btn--check:disabled{opacity:.5;cursor:not-allowed}.prc-fill__btn--next{color:#fff;background:#3b82f6}.prc-fill__btn:hover:not(:disabled){transform:translateY(-1px)}.prc-fill__result{align-items:flex-start;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);font-size:var(--text-sm);display:flex}.prc-fill__result--correct{color:#16a34a;background:#22c55e14;border:1px solid #22c55e33}.prc-fill__result--wrong{color:#dc2626;background:#ef444414;border:1px solid #ef444433}.prc-fill__result-note{font-size:var(--text-xs);opacity:.9;margin:2px 0 0}.prc-listen{max-width:520px;margin:0 auto}.prc-listen__header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.prc-listen__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin:0}.prc-listen__progress{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted);background:var(--color-surface-container-high);border-radius:var(--radius-full);padding:3px 12px}.prc-listen__speaker-area{align-items:center;gap:var(--space-3);padding:var(--space-6) 0;flex-direction:column;display:flex}.prc-listen__speaker{border-radius:var(--radius-full);color:#f59e0b;cursor:pointer;width:80px;height:80px;transition:all var(--duration-fast) var(--ease-default);background:#f59e0b14;border:3px solid #f59e0b;justify-content:center;align-items:center;display:flex}.prc-listen__speaker:hover{background:#f59e0b26;transform:scale(1.05)}.prc-listen__speaker:active{transform:scale(.95)}.prc-listen__instruction{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.prc-listen__options{gap:var(--space-2);margin-bottom:var(--space-4);flex-direction:column;display:flex}.prc-listen__option{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-surface);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);display:flex}.dark .prc-listen__option{background:var(--color-surface-container-low)}.prc-listen__option:hover:not(:disabled){border-color:var(--color-primary)}.prc-listen__option-text{font-size:var(--text-sm);color:var(--color-text);text-align:left}.prc-listen__option--correct{background:#22c55e0f;border-color:#22c55e}.prc-listen__option--wrong{background:#ef44440f;border-color:#ef4444}.prc-listen__option--disabled{opacity:.5}.prc-listen__feedback{gap:var(--space-3);flex-direction:column;align-items:center;display:flex}.prc-scr{max-width:520px;margin:0 auto}.prc-scr__header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.prc-scr__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin:0}.prc-scr__progress{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted);background:var(--color-surface-container-high);border-radius:var(--radius-full);padding:3px 12px}.prc-scr__meaning{align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);margin-bottom:var(--space-5);flex-wrap:wrap;display:flex}.dark .prc-scr__meaning{background:var(--color-surface-container-low)}.prc-scr__meaning-label{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text-muted)}.prc-scr__meaning-text{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text)}.prc-scr__gender{font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic}.prc-scr__answer{gap:var(--space-2);padding:var(--space-4);background:var(--color-surface-container-high);border-radius:var(--radius-xl);min-height:56px;margin-bottom:var(--space-4);flex-wrap:wrap;justify-content:center;display:flex}.prc-scr__slot{border:2px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);width:38px;height:42px;font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);justify-content:center;align-items:center;display:flex}.prc-scr__slot--filled{background:#3b82f60f;border-style:solid;border-color:#3b82f6}.prc-scr__slot--correct{color:#16a34a;background:#22c55e14;border-color:#22c55e}.prc-scr__slot--wrong{color:#dc2626;background:#ef444414;border-color:#ef4444;animation:.4s shake}.prc-scr__tiles{gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap;justify-content:center;display:flex}.prc-scr__tile{border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);width:38px;height:42px;font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);justify-content:center;align-items:center;display:flex}.dark .prc-scr__tile{background:var(--color-surface-container-low)}.prc-scr__tile:hover:not(:disabled){border-color:var(--color-primary);transform:translateY(-2px)}.prc-scr__tile--used{opacity:.25;cursor:default;transform:scale(.9)}.prc-scr__actions{align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.prc-scr__btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-surface);color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);display:inline-flex}.prc-scr__btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.prc-scr__btn:disabled{opacity:.4;cursor:not-allowed}.prc-quick__banner{text-align:center;padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-bold);color:#06b6d4;margin-bottom:var(--space-4);background:linear-gradient(135deg,#06b6d414 0%,#3b82f614 100%);border:1px solid #06b6d426}.prc-quick__summary{gap:var(--space-2);width:100%;max-width:280px;margin:var(--space-4) auto;flex-direction:column;display:flex}.prc-quick__summary-row{padding:var(--space-2) var(--space-3);background:var(--color-surface-container-high);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--color-text);justify-content:space-between;align-items:center;display:flex}.prc-quick__summary-score{font-weight:var(--font-bold);font-family:var(--font-mono)}@media (max-width:480px){.prc-menu__grid{gap:var(--space-2);grid-template-columns:repeat(2,1fr)}.prc-menu__card{padding:var(--space-4) var(--space-2)}.prc-menu__card-emoji{font-size:var(--text-2xl)}.prc-match__grid{gap:var(--space-3);grid-template-columns:1fr}.prc-scr__slot,.prc-scr__tile{width:34px;height:38px;font-size:var(--text-sm)}.prc-listen__speaker{width:64px;height:64px}}.import-dialog{max-width:620px!important}.import-body{gap:var(--space-4);flex-direction:column;display:flex}.import-tabs{gap:var(--space-2);background:var(--color-surface-container-low);border-radius:var(--radius-xl);padding:4px;display:flex}.import-tab{justify-content:center;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;flex:1;display:flex}.import-tab:hover{color:var(--color-text);background:var(--color-surface-container)}.import-tab--active{background:var(--color-surface);color:var(--color-text);font-weight:var(--font-semibold);box-shadow:var(--shadow-sm)}.dark .import-tab--active{background:var(--color-surface-container-high)}.import-format-desc{font-size:var(--text-xs);color:var(--color-text-muted);margin:0}.import-error{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);color:var(--color-error);border-radius:var(--radius-lg);font-size:var(--text-sm);background:#fef2f2;display:flex}.dark .import-error{background:#ef44441a}.import-input-area{position:relative}.import-textarea{width:100%;min-height:160px;padding:var(--space-3) var(--space-4);font-family:JetBrains Mono,Fira Code,monospace;font-size:var(--text-xs);line-height:var(--leading-relaxed);color:var(--color-text);background:var(--color-surface-container-low);border:1px solid var(--color-border);border-radius:var(--radius-xl);resize:vertical;transition:border-color var(--duration-fast) var(--ease-default)}.import-textarea::placeholder{color:var(--color-text-subtle);font-size:var(--text-xs);white-space:pre-wrap}.import-textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #4ade8026}.import-actions-row{align-items:center;gap:var(--space-2);display:flex}.import-action-btn{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);background:var(--color-surface-container-low);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);display:inline-flex}.import-action-btn:hover{background:var(--color-surface-container-high);color:var(--color-text)}.import-preview{background:var(--color-surface-container-low);border-radius:var(--radius-xl);overflow:hidden}.import-preview__header{padding:var(--space-2) var(--space-4);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);border-bottom:1px solid var(--color-border);text-transform:uppercase;letter-spacing:.05em}.import-preview__table-wrap{overflow-x:auto}.import-preview__table{border-collapse:collapse;width:100%;font-size:var(--text-xs)}.import-preview__table th{padding:var(--space-2) var(--space-3);text-align:left;font-weight:var(--font-semibold);color:var(--color-text-muted);background:var(--color-surface-container);white-space:nowrap}.import-preview__table td{padding:var(--space-2) var(--space-3);color:var(--color-text);border-top:1px solid var(--color-border);text-overflow:ellipsis;white-space:nowrap;max-width:160px;overflow:hidden}.import-preview__ipa{font-family:Noto Sans,Segoe UI,system-ui,sans-serif;font-weight:var(--font-medium);color:var(--color-primary)!important}.import-preview__more{font-style:italic;text-align:center!important;color:var(--color-text-muted)!important}.import-submit{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-bold);font-family:var(--font-display);color:#fff;background:var(--color-primary);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);box-shadow:0 3px 0 var(--color-primary-dark);border:none;display:inline-flex}.import-submit:hover:not(:disabled){box-shadow:0 4px 0 var(--color-primary-dark);transform:translateY(-1px)}.import-submit:disabled{opacity:.5;cursor:not-allowed}.import-success{align-items:center;gap:var(--space-3);padding:var(--space-8) 0;text-align:center;animation:scaleIn .3s var(--ease-bounce);flex-direction:column;display:flex}.import-success__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.import-success__count{font-size:var(--text-sm);color:var(--color-text-muted)}.import-success__count strong{color:var(--color-primary);font-weight:var(--font-bold)}.add-card-form{gap:var(--space-4);flex-direction:column;display:flex}.add-card-field{gap:var(--space-1);flex-direction:column;flex:1;display:flex}.add-card-row{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.add-card-success{padding:var(--space-2) var(--space-3);color:var(--color-success);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);text-align:center;animation:scaleIn .2s var(--ease-bounce);background:#f0fdf4}.dark .add-card-success{background:#22c55e1a}.add-card-error{padding:var(--space-2) var(--space-3);color:var(--color-error);border-radius:var(--radius-lg);font-size:var(--text-sm);text-align:center;background:#fef2f2}.dark .add-card-error{background:#ef44441a}.add-card-submit{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-bold);font-family:var(--font-display);color:#fff;background:var(--color-primary);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);box-shadow:0 3px 0 var(--color-primary-dark);border:none;display:inline-flex}.add-card-submit:hover:not(:disabled){box-shadow:0 4px 0 var(--color-primary-dark);transform:translateY(-1px)}.add-card-submit:disabled{opacity:.5;cursor:not-allowed}@media (max-width:640px){.fc-detail-header{flex-direction:column}.fc-detail-actions{align-self:flex-start}.add-card-row{grid-template-columns:1fr}.fc-cards-list-legend{display:none}.import-tabs{flex-direction:column}}.ex-page{gap:var(--space-6);flex-direction:column;display:flex}.ex-page__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.ex-page__hero{align-items:center;gap:var(--space-4);display:flex}.ex-page__hero-icon{flex-shrink:0;font-size:3rem}.ex-page__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);letter-spacing:-.02em;color:var(--color-text);margin:0}.ex-page__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0;line-height:var(--leading-vi)}.ex-page__type-pills{gap:var(--space-2);flex-wrap:wrap;align-self:flex-end;display:flex}.ex-page__type-pill{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--color-surface);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);display:flex}.ex-page__type-pill-count{background:var(--color-surface-container-high);border-radius:var(--radius-full);min-width:18px;height:18px;font-size:10px;font-weight:var(--font-bold);color:var(--color-text-muted);justify-content:center;align-items:center;display:inline-flex}.ex-quick-cta{margin-top:calc(-1 * var(--space-2))}.ex-quick-cta__link{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-radius:var(--radius-2xl);transition:all var(--duration-fast) var(--ease-default);cursor:pointer;background:linear-gradient(135deg,#4ade8014,#06b6d414);border:2px solid #4ade8033;text-decoration:none;display:flex}.ex-quick-cta__link:hover{border-color:var(--color-primary);background:linear-gradient(135deg,#4ade801f,#06b6d41f);transform:translateY(-2px);box-shadow:0 8px 24px #4ade8026}.dark .ex-quick-cta__link{background:linear-gradient(135deg,#4ade800f,#06b6d40f)}.dark .ex-quick-cta__link:hover{background:linear-gradient(135deg,#4ade801a,#06b6d41a)}.ex-quick-cta__icon{filter:drop-shadow(0 2px 8px #facc154d);flex-shrink:0;font-size:32px;line-height:1}.ex-quick-cta__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.ex-quick-cta__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text)}.ex-quick-cta__desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi)}.ex-quick-cta__arrow{font-size:var(--text-xl);color:var(--color-primary);font-weight:var(--font-bold);transition:transform var(--duration-fast) var(--ease-default);flex-shrink:0}.ex-quick-cta__link:hover .ex-quick-cta__arrow{transform:translate(4px)}.ex-filters{gap:var(--space-3);background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-4) var(--space-5);flex-direction:column;display:flex}.ex-filters__group{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.ex-filters__label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;min-width:60px}.ex-filters__tabs{gap:var(--space-2);flex-wrap:wrap;display:flex}.ex-filter-tab{padding:5px var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);background:var(--color-surface-container-low);border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-bounce);white-space:nowrap;text-decoration:none}.ex-filter-tab:hover{background:var(--color-surface-container-high);color:var(--color-text)}.ex-filter-tab--active{background:var(--color-primary-container);color:var(--color-on-primary-container);font-weight:var(--font-semibold)}.dark .ex-filter-tab--active{color:var(--color-primary);background:#4ade8026}.ex-results-info{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);flex-wrap:wrap;display:flex}.ex-results-info strong{color:var(--color-text)}.ex-results-info__tag{padding:2px var(--space-2);background:var(--color-surface-container-high);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium)}.ex-grid{gap:var(--space-3);flex-direction:column;display:flex}.ex-card{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-surface);border-radius:var(--radius-2xl);color:inherit;transition:all var(--duration-fast) var(--ease-bounce);text-decoration:none;display:flex}.ex-card:hover{box-shadow:var(--shadow-md);transform:translate(4px)}.ex-card__icon{border-radius:var(--radius-xl);width:56px;height:56px;transition:transform var(--duration-fast) var(--ease-bounce);flex-shrink:0;justify-content:center;align-items:center;display:flex}.ex-card:hover .ex-card__icon{transform:scale(1.1)rotate(-5deg)}.ex-card__emoji{font-size:1.75rem}.ex-card__body{gap:var(--space-2);flex-direction:column;flex:1;min-width:0;display:flex}.ex-card__badges{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.ex-card__type-badge{padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold)}.ex-card__level-badge{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);background:var(--color-primary-container);color:var(--color-on-primary-container);padding:2px 8px}.dark .ex-card__level-badge{color:var(--color-primary);background:#4ade8026}.ex-card__level-desc{font-size:var(--text-xs);color:var(--color-text-subtle)}.ex-card__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);line-height:var(--leading-snug);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.ex-card__desc{font-size:var(--text-xs);color:var(--color-text-muted);margin:0}.ex-card__meta{align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted);display:flex}.ex-card__meta-item{align-items:center;gap:4px;display:flex}.ex-card__meta-dot{background:var(--color-text-subtle);border-radius:50%;width:3px;height:3px}.ex-card__cta{font-size:var(--text-xl);color:var(--color-text-subtle);transition:all var(--duration-fast) var(--ease-default);flex-shrink:0}.ex-card:hover .ex-card__cta{color:var(--color-primary);transform:translate(4px)}.ex-empty{align-items:center;gap:var(--space-4);padding:var(--space-16) 0;text-align:center;flex-direction:column;display:flex}.ex-empty__icon{font-size:4rem}.ex-empty__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.ex-empty__sub{font-size:var(--text-sm);color:var(--color-text-muted);max-width:320px;line-height:var(--leading-vi)}@media (max-width:640px){.ex-page__header{flex-direction:column}.ex-page__type-pills{display:none}.ex-filters{padding:var(--space-3)}.ex-card{padding:var(--space-3);gap:var(--space-3)}.ex-card__icon{width:44px;height:44px}.ex-card__emoji{font-size:1.4rem}}.game-page{gap:var(--space-4);flex-direction:column;width:100%;max-width:800px;margin:0 auto;display:flex}.game-page__back{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-default);text-decoration:none;display:inline-flex}.game-page__back:hover{color:var(--color-primary)}.game-container{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-6)}.game-wrap{gap:var(--space-5);flex-direction:column;display:flex}.game-header{align-items:center;gap:var(--space-3);display:flex}.game-header__icon{border-radius:var(--radius-xl);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.game-header__icon--purple{background:#7c3aed}.game-header__icon--blue{background:#1d4ed8}.game-header__icon--orange{background:#c2410c}.game-header__info{flex:1;min-width:0}.game-header__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);line-height:var(--leading-snug);margin:0}.game-header__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:4px 0 0}.game-level-badge{padding:4px var(--space-3);background:var(--color-primary-container);color:var(--color-on-primary-container);font-family:var(--font-display);font-size:var(--text-xs);font-weight:var(--font-bold);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0}.dark .game-level-badge{color:var(--color-primary);background:#4ade8026}.game-progress{align-items:center;gap:var(--space-3);display:flex}.game-progress__bar{background:var(--color-surface-container-high);border-radius:var(--radius-full);flex:1;height:8px;overflow:hidden}.game-progress__fill{background:linear-gradient(90deg, var(--color-primary), var(--color-secondary));border-radius:var(--radius-full);height:100%;transition:width .4s var(--ease-bounce)}.game-progress__label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted);text-align:right;min-width:36px}.matching-grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.matching-col{gap:var(--space-2);flex-direction:column;min-width:0;display:flex;overflow:hidden}.matching-col__label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-1)}.matching-btn{text-align:left;width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface-container-low);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);align-items:center;gap:var(--space-2);overflow-wrap:break-word;word-break:break-word;border:2px solid #0000;display:flex}.matching-btn:hover:not(:disabled){border-color:var(--color-primary);transform:translate(2px)}.matching-btn--selected{color:var(--color-primary);background:#4ade801a;box-shadow:0 0 0 3px #4ade8033;border-color:var(--color-primary)!important}.matching-btn--matched{border-color:var(--color-primary);color:var(--color-primary);opacity:.8;cursor:default;background:#4ade801f}.matching-btn--wrong{background:#ef44441a;border-color:#ef4444;animation:.4s ease-in-out shake}.matching-btn__check{color:var(--color-primary);font-weight:var(--font-bold);flex-shrink:0}.matching-fail{align-items:center;gap:var(--space-4);padding:var(--space-8) var(--space-4);text-align:center;animation:fadeInUp .35s var(--ease-bounce);flex-direction:column;display:flex}.matching-fail__icon{color:#ef4444;animation:.5s ease-in-out shake}.matching-fail__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:#ef4444;margin:0}.matching-fail__score{font-size:var(--text-base);color:var(--color-text-muted);line-height:var(--leading-vi);margin:0}.matching-fail__score strong{color:var(--color-primary);font-size:var(--text-xl)}.matching-fail__detail{gap:var(--space-2);background:var(--color-surface-container-low);border-radius:var(--radius-xl);width:100%;max-width:360px;padding:var(--space-4);text-align:left;flex-direction:column;display:flex}.matching-fail__row{align-items:baseline;gap:var(--space-2);font-size:var(--text-sm);line-height:var(--leading-vi);display:flex}.matching-fail__label{color:var(--color-text-muted);font-size:var(--text-xs);flex-shrink:0;min-width:70px}.matching-fail__wrong{color:#ef4444;opacity:.8;text-decoration:line-through}.matching-fail__correct{color:var(--color-primary);font-weight:var(--font-bold)}@media (max-width:640px){.matching-fail{padding:var(--space-6) var(--space-3)}.matching-fail__title{font-size:var(--text-xl)}.matching-fail__detail{padding:var(--space-3)}}.matching-page-info{text-align:center;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);padding:var(--space-2) var(--space-3);background:var(--color-surface-container-low);border-radius:var(--radius-full);align-self:center}.matching-pagination{justify-content:center;align-items:center;gap:var(--space-3);padding-top:var(--space-2);display:flex}.matching-pagination__btn{border-radius:var(--radius-full);border:1.5px solid var(--color-border);background:var(--color-surface-container-low);width:36px;height:36px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.matching-pagination__btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:#4ade800f;transform:scale(1.05)}.matching-pagination__btn:disabled{opacity:.35;cursor:not-allowed}.matching-pagination__dots{align-items:center;gap:var(--space-1-5,6px);display:flex}.matching-pagination__dot{border-radius:var(--radius-full);border:2px solid var(--color-border);cursor:pointer;width:10px;height:10px;transition:all var(--duration-fast) var(--ease-bounce);background:0 0;padding:0}.matching-pagination__dot:hover{border-color:var(--color-primary);transform:scale(1.3)}.matching-pagination__dot--active{border-color:var(--color-primary);background:var(--color-primary);transform:scale(1.2);box-shadow:0 0 0 3px #4ade8033}.matching-pagination__dot--partial{border-color:var(--color-primary);background:#4ade8059}.matching-pagination__dot--done{border-color:var(--color-primary);background:var(--color-primary);opacity:.7}.matching-page-next{animation:fadeInUp .35s var(--ease-bounce);justify-content:center;display:flex}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width:640px){.matching-pagination__btn{width:32px;height:32px}.matching-pagination__dot{width:8px;height:8px}.matching-pagination__dots{gap:4px}.matching-page-info{font-size:11px}}.game-sentence-card{background:var(--color-surface-container-low);border-radius:var(--radius-2xl);padding:var(--space-8) var(--space-6);text-align:center}.game-sentence{font-size:var(--text-xl);line-height:var(--leading-relaxed);color:var(--color-text)}.game-blank{min-width:80px;margin:0 var(--space-1);padding:2px var(--space-3);border:2px dashed var(--color-border);border-radius:var(--radius-lg);font-weight:var(--font-bold);transition:all var(--duration-fast) var(--ease-default);display:inline-block}.game-blank--filled{border-color:var(--color-primary);color:var(--color-primary);background:#4ade801a;border-style:solid}.game-blank--correct{border-color:var(--color-primary);color:var(--color-primary);background:#4ade8026;border-style:solid}.game-blank--wrong{color:#ef4444;background:#ef44441a;border-style:solid;border-color:#ef4444}.game-options-grid{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.game-option{padding:var(--space-3) var(--space-4);background:var(--color-surface-container-low);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);align-items:center;gap:var(--space-2);text-align:left;border:2px solid #0000;display:flex}.game-option:hover:not(:disabled){border-color:var(--color-primary);transform:translateY(-1px)}.game-option--selected{border-color:var(--color-primary);color:var(--color-primary);background:#4ade801a}.game-option--correct{border-color:var(--color-primary);color:var(--color-primary);background:#4ade8026}.game-option--wrong{color:#ef4444;background:#ef44441a;border-color:#ef4444}.game-option--dim{opacity:.4;cursor:default}.game-next-wrap{justify-content:center;display:flex}.game-hint{padding:var(--space-3) var(--space-4);background:var(--color-surface-container-low);border-radius:var(--radius-xl);font-size:var(--text-sm);color:var(--color-text-muted);align-items:center;gap:var(--space-2);display:flex}.game-hint__label{opacity:.7}.game-hint strong{color:var(--color-text)}.game-answer-area{min-height:80px;padding:var(--space-4);border:2px dashed var(--color-border);border-radius:var(--radius-2xl);gap:var(--space-2);transition:all var(--duration-fast) var(--ease-default);flex-wrap:wrap;align-items:center;display:flex}.game-answer-area--correct{border-color:var(--color-primary);background:#4ade8012}.game-answer-area--wrong{background:#ef44440d;border-color:#ef4444}.game-answer-area__placeholder{text-align:center;width:100%;font-size:var(--text-sm);color:var(--color-text-subtle)}.game-answer-icon{font-size:var(--text-xl);color:var(--color-primary);margin-left:auto}.game-answer-icon--wrong{color:#ef4444}.game-word-chip{padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);border:none}.game-word-chip--bank{background:var(--color-surface-container-low);color:var(--color-text);border:2px solid var(--color-border)}.game-word-chip--bank:hover{border-color:var(--color-primary);transform:translateY(-2px)}.game-word-chip--placed{color:var(--color-primary);background:#4ade801a;border:2px solid #4ade804d}.game-word-chip--placed:hover:not(:disabled){color:#ef4444;background:#ef44441a;border-color:#ef44444d}.game-word-chip--correct{color:var(--color-primary);border:2px solid var(--color-primary);background:#4ade8026}.game-word-bank{gap:var(--space-2);padding:var(--space-4);background:var(--color-surface-container-low);border-radius:var(--radius-2xl);flex-wrap:wrap;justify-content:center;display:flex}.game-correct-answer{padding:var(--space-3) var(--space-4);border:1px solid var(--color-primary);border-radius:var(--radius-xl);font-size:var(--text-sm);color:var(--color-text);align-items:center;gap:var(--space-2);background:#4ade8014;display:flex}.game-correct-answer__label{color:var(--color-text-muted)}.game-actions{justify-content:center;gap:var(--space-3);display:flex}.game-complete{align-items:center;gap:var(--space-5);padding:var(--space-12) var(--space-4);text-align:center;flex-direction:column;display:flex}.game-complete__icon{font-size:5rem}.game-complete__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);letter-spacing:-.02em;color:var(--color-text)}.game-complete__sub{font-size:var(--text-base);color:var(--color-text-muted);margin-top:calc(-1 * var(--space-2))}.game-complete__stats{align-items:center;gap:var(--space-6);background:var(--color-surface-container-low);border-radius:var(--radius-2xl);padding:var(--space-5) var(--space-8);display:flex}.game-complete__stat{align-items:center;gap:var(--space-1);flex-direction:column;display:flex}.game-complete__stat-value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-primary);line-height:1}.game-complete__stat-label{font-size:var(--text-xs);color:var(--color-text-muted)}.game-complete__stat-divider{background:var(--color-border);width:1px;height:48px}@media (max-width:640px){.game-container{padding:var(--space-4)}.matching-grid{gap:var(--space-2);grid-template-columns:1fr 1fr}.matching-col{gap:6px}.matching-col__label{margin-bottom:2px;font-size:10px}.matching-btn{padding:var(--space-2) var(--space-2-5,10px);font-size:var(--text-xs);border-radius:var(--radius-lg);line-height:var(--leading-snug);word-break:break-word;-webkit-hyphens:auto;hyphens:auto;border-width:1.5px}.matching-btn:hover:not(:disabled){transform:none}.game-options-grid{grid-template-columns:1fr}.game-complete__stats{padding:var(--space-4);gap:var(--space-4)}.game-complete__stat-value{font-size:var(--text-2xl)}}@media (max-width:400px){.matching-grid{gap:6px}.matching-btn{padding:6px 8px;font-size:11px}.game-header__title{font-size:var(--text-base)}.game-header__sub{font-size:var(--text-xs)}.game-header__icon{width:36px;height:36px}}.qp-page{gap:var(--space-6);max-width:720px;padding:var(--space-6) var(--space-4);flex-direction:column;margin:0 auto;display:flex}.qp-hero{text-align:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.qp-hero__icon{filter:drop-shadow(0 4px 12px #facc154d);font-size:48px;line-height:1}.qp-hero__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text);background:linear-gradient(135deg, var(--color-primary), #06b6d4);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0}.qp-hero__sub{font-size:var(--text-sm);color:var(--color-text-muted);max-width:420px;line-height:var(--leading-vi);margin:0}.qp-section{gap:var(--space-4);flex-direction:column;display:flex}.qp-section__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin:0}.qp-options{gap:var(--space-3);display:grid}.qp-options--type{grid-template-columns:repeat(2,1fr)}.qp-options--level{grid-template-columns:repeat(3,1fr)}.qp-options--qty{grid-template-columns:repeat(4,1fr)}.qp-option{align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);text-align:center;flex-direction:column;display:flex}.qp-option:hover{border-color:var(--color-primary-glow);background:var(--color-surface-container-low);box-shadow:var(--shadow-md);transform:translateY(-2px)}.qp-option--active{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow);background:#4ade800f}.dark .qp-option--active{background:#4ade8014}.qp-option--sm{padding:var(--space-3)}.qp-option__emoji{font-size:28px;line-height:1}.qp-option__label{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text)}.qp-option__desc{font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.4}.qp-error{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:#ef4444;font-size:var(--text-sm);font-weight:var(--font-medium);background:#ef444414;border:1px solid #ef444433;display:flex}.dark .qp-error{background:#ef44441f}.qp-cta{padding-top:var(--space-2);justify-content:center;display:flex}.qp-actions{padding-top:var(--space-4);justify-content:center;display:flex}@media (max-width:640px){.qp-page{padding:var(--space-4) var(--space-3);gap:var(--space-5)}.qp-hero__title{font-size:var(--text-xl)}.qp-options--type{grid-template-columns:1fr 1fr}.qp-options--level{grid-template-columns:repeat(3,1fr)}.qp-options--qty{grid-template-columns:repeat(2,1fr)}.qp-option{padding:var(--space-3)}.qp-option__emoji{font-size:22px}}
