.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)}.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)}.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(8px)}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)}.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}}.reading-page{gap:var(--space-6);flex-direction:column;display:flex}.reading-page__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.reading-page__hero{align-items:center;gap:var(--space-4);display:flex}.reading-page__hero-icon{flex-shrink:0;font-size:3rem}.reading-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}.reading-page__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0;line-height:var(--leading-vi)}.reading-page__features{gap:var(--space-2);flex-wrap:wrap;align-self:flex-end;display:flex}.reading-page__feature{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}.reading-levels{gap:var(--space-2);flex-wrap:wrap;display:flex}.reading-level-tab{padding:var(--space-2) var(--space-4);background:var(--color-surface);border-radius:var(--radius-xl);color:var(--color-text-muted);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--duration-fast) var(--ease-bounce);align-items:center;gap:6px;text-decoration:none;display:flex}.reading-level-tab:hover{background:var(--color-surface-container-high);color:var(--color-text);transform:translateY(-1px)}.reading-level-tab--active{background:var(--color-primary-container);color:var(--color-on-primary-container);font-weight:var(--font-semibold)}.dark .reading-level-tab--active{color:var(--color-primary);background:#4ade8026}.reading-level-tab__label{font-family:var(--font-display);font-weight:var(--font-bold)}.reading-level-tab__desc{font-size:var(--text-xs);opacity:.75}.reading-tip{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-vi);background:linear-gradient(135deg,#f0fdf4,#dcfce7);display:flex}.dark .reading-tip{background:#4ade8014}.reading-tip__icon{font-size:var(--text-xl);flex-shrink:0;margin-top:1px}.reading-empty{align-items:center;gap:var(--space-4);padding:var(--space-16) 0;text-align:center;flex-direction:column;display:flex}.reading-empty__icon{font-size:4rem}.reading-empty__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.reading-empty__sub{font-size:var(--text-sm);color:var(--color-text-muted);max-width:320px;line-height:var(--leading-vi)}@media (max-width:640px){.reading-page__header{flex-direction:column}.reading-page__features,.reading-level-tab__desc{display:none}.reading-levels{gap:var(--space-1)}.reading-level-tab{padding:var(--space-2) var(--space-3)}}.settings-page{gap:var(--space-8);width:100%;max-width:640px;padding-bottom:var(--space-8);flex-direction:column;margin:0 auto;display:flex}.settings-page__header{gap:var(--space-1);flex-direction:column;display:flex}.settings-page__title{align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);letter-spacing:-.02em;color:var(--color-text);margin:0;display:flex}.settings-page__title svg{color:var(--color-primary);flex-shrink:0}.settings-page__sub{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi);margin:0}.settings-section{background:var(--color-surface);border-radius:var(--radius-2xl);overflow:hidden}.settings-section--admin{border:1px solid #ef444433}.settings-section__header{align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-6) 0;color:var(--color-text-muted);display:flex}.settings-section__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin:0}.settings-section__body{padding:var(--space-5) var(--space-6);gap:var(--space-4);flex-direction:column;display:flex}.settings-section__action{padding-top:var(--space-3);border-top:1px solid var(--color-border-muted)}.settings-info-grid{gap:var(--space-3) var(--space-4);font-size:var(--text-sm);grid-template-columns:140px 1fr;display:grid}.settings-info-grid__label{color:var(--color-text-muted)}.settings-info-grid__value{font-weight:var(--font-medium);color:var(--color-text);word-break:break-word}.settings-plan{align-items:center;gap:var(--space-3);display:flex}.settings-plan__badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-bold);background:var(--color-primary-container);color:var(--color-on-primary-container);align-items:center;display:inline-flex}.settings-plan__badge--basic{color:#1d4ed8;background:#dbeafe}.settings-plan__badge--premium{color:#7c3aed;background:#ede9fe}.settings-plan__badge--lifetime{color:#b45309;background:#fef3c7}.dark .settings-plan__badge--basic{color:#60a5fa;background:#3b82f626}.dark .settings-plan__badge--premium{color:#a78bfa;background:#8b5cf626}.dark .settings-plan__badge--lifetime{color:#fbbf24;background:#f59e0b26}.settings-plan__note{font-size:var(--text-sm);color:var(--color-text-muted)}.settings-link{align-items:center;gap:var(--space-1);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-primary);transition:opacity var(--duration-fast) var(--ease-default);text-decoration:none;display:inline-flex}.settings-link:hover{opacity:.8;text-decoration:underline}.settings-link--admin{color:#ef4444}.settings-icon--amber{color:#f59e0b}.settings-icon--red{color:#ef4444}.settings-footer{gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--color-border-muted);flex-direction:column;display:flex}.settings-footer__links{gap:var(--space-4);display:flex}.settings-footer__link{font-size:var(--text-sm);color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-default);text-decoration:none}.settings-footer__link:hover{color:var(--color-text)}.settings-footer__copy{font-size:var(--text-xs);color:var(--color-text-subtle);margin:0}@media (max-width:640px){.settings-page{gap:var(--space-6)}.settings-section__header{padding:var(--space-4) var(--space-4) 0}.settings-section__body{padding:var(--space-4)}.settings-info-grid{gap:var(--space-2);grid-template-columns:1fr}.settings-info-grid__label{font-weight:var(--font-semibold);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em}}.pf{gap:var(--space-8);width:100%;max-width:640px;padding-bottom:var(--space-10);flex-direction:column;margin:0 auto;display:flex}.pf-hero{background:var(--color-surface);border-radius:var(--radius-2xl);position:relative;overflow:hidden}.pf-hero__cover{background:linear-gradient(135deg,#22c55e 0%,#06b6d4 50%,#3b82f6 100%);height:100px;position:relative}.pf-hero__cover:after{content:"";background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.08'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;inset:0}.dark .pf-hero__cover{background:linear-gradient(135deg,#166534 0%,#155e75 50%,#1e3a5f 100%)}.pf-hero__body{padding:0 var(--space-6) var(--space-6);z-index:1;flex-direction:column;align-items:center;margin-top:-48px;display:flex;position:relative}.pf-hero__avatar-area{align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.pf-hero__avatar-ring{background:var(--color-surface);border-radius:50%;justify-content:center;align-items:center;width:96px;height:96px;padding:4px;display:flex;box-shadow:0 4px 20px #0000001a,0 0 0 3px #4ade804d}.dark .pf-hero__avatar-ring{box-shadow:0 4px 20px #0000004d,0 0 0 3px #4ade8040}.pf-hero__avatar{object-fit:cover;border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.pf-hero__avatar--initials{background:linear-gradient(135deg, var(--color-primary), #06b6d4);color:#fff;font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);letter-spacing:.05em}.av-upload{align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.av-upload__container{display:inline-flex;position:relative}.av-upload__ring{background:var(--color-surface);cursor:pointer;width:96px;height:96px;transition:box-shadow var(--duration-normal) var(--ease-default);border-radius:50%;justify-content:center;align-items:center;padding:4px;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #0000001a,0 0 0 3px #4ade804d}.av-upload__ring:hover{box-shadow:0 4px 24px #00000026,0 0 0 3px #4ade8080}.av-upload__ring--processing{cursor:wait;box-shadow:0 4px 24px #0000001a,0 0 0 3px #4ade8099}.dark .av-upload__ring{box-shadow:0 4px 20px #0000004d,0 0 0 3px #4ade8040}.dark .av-upload__ring:hover{box-shadow:0 4px 24px #0006,0 0 0 3px #4ade8073}.av-upload__img{object-fit:cover;border-radius:50%;width:100%;height:100%}.av-upload__fallback{background:linear-gradient(135deg, var(--color-primary), #06b6d4);color:#fff;width:100%;height:100%;font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);letter-spacing:.05em;border-radius:50%;justify-content:center;align-items:center;display:flex}.av-upload__overlay{opacity:0;transition:opacity var(--duration-fast) var(--ease-default);pointer-events:none;background:#00000080;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex;position:absolute;inset:4px}.av-upload__ring:hover .av-upload__overlay,.av-upload__ring--processing .av-upload__overlay{opacity:1}.av-upload__overlay-icon{color:#fff;width:20px;height:20px}.av-upload__overlay-icon--spin{animation:.8s linear infinite spin}.av-upload__overlay-text{font-size:11px;font-weight:var(--font-semibold);color:#fff;white-space:nowrap}.av-upload__remove{border:2px solid var(--color-surface);cursor:pointer;width:28px;height:28px;transition:all var(--duration-fast) var(--ease-bounce);z-index:2;background:#ef4444;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;bottom:0;right:-4px}.av-upload__remove:hover{background:#dc2626;transform:scale(1.1)}.av-upload__remove-icon{color:#fff;width:13px;height:13px}.av-upload__input{opacity:0;clip:rect(0, 0, 0, 0);width:1px;height:1px;position:absolute;overflow:hidden}.av-upload__hint{font-size:var(--text-xs);color:var(--color-text-subtle);margin:0}.av-upload__error{font-size:var(--text-xs);color:#ef4444;font-weight:var(--font-medium);margin:0}.dark .av-upload__error{color:#f87171}@media (max-width:640px){.av-upload__ring{width:80px;height:80px}.av-upload__fallback{font-size:var(--text-xl)}}.pf-hero__plan{padding:3px var(--space-3);background:var(--color-primary);color:#fff;font-size:var(--text-xs);font-weight:var(--font-bold);border-radius:var(--radius-full);white-space:nowrap;letter-spacing:.02em;align-items:center;display:inline-flex}.pf-hero__identity{text-align:center;margin-top:var(--space-4)}.pf-hero__name{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);letter-spacing:-.02em;color:var(--color-text);margin:0;line-height:1.2}.pf-hero__email{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 var(--space-3)}.pf-hero__tags{justify-content:center;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.pf-hero__tag{padding:3px var(--space-3);background:var(--color-surface-container-low);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);align-items:center;gap:4px;display:inline-flex}.pf-hero__tag--level{background:var(--color-primary-container);color:var(--color-on-primary-container);font-weight:var(--font-bold)}.dark .pf-hero__tag--level{color:var(--color-primary);background:#4ade8026}.pf-hero__stats{padding:var(--space-5) var(--space-6);border-top:1px solid var(--color-border-muted);background:var(--color-surface-container-low);grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;align-items:center;display:grid}.pf-hero__stat{justify-content:center;align-items:center;gap:var(--space-2);display:flex}.pf-hero__stat-icon{font-size:1.4rem;line-height:1}.pf-hero__stat-data{flex-direction:column;display:flex}.pf-hero__stat-value{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-extrabold);color:var(--color-text);line-height:1.2}.pf-hero__stat-label{color:var(--color-text-muted);font-size:11px;line-height:1.3}.pf-hero__stat-sep{background:var(--color-border-muted);flex-shrink:0;width:1px;height:32px}.pf-form-card{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-6)}.pf-form-card__header{margin-bottom:var(--space-6)}.pf-form-card__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin:0}.pf-form-card__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0;line-height:var(--leading-vi)}.pf-form{gap:var(--space-6);flex-direction:column;display:flex}.pf-form__alert{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-medium);line-height:var(--leading-vi);display:flex}.pf-form__alert--success{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.dark .pf-form__alert--success{color:#4ade80;background:#22c55e14;border-color:#22c55e33}.pf-form__alert--error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.dark .pf-form__alert--error{color:#f87171;background:#ef444414;border-color:#ef444433}.pf-form__alert-icon{font-size:var(--text-base);flex-shrink:0}.pf-fieldset{gap:var(--space-4);border:none;flex-direction:column;margin:0;padding:0;display:flex}.pf-fieldset__legend{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin-bottom:var(--space-3);padding:0;padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-muted);width:100%}.pf-field{flex-direction:column;gap:6px;display:flex}.pf-field--inline{align-items:center;gap:var(--space-3);flex-direction:row}.pf-field__label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.pf-field__input,.pf-field__select,.pf-field__textarea{width:100%;padding:10px var(--space-3);font-size:var(--text-sm);color:var(--color-text);background:var(--color-surface-container-low);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);transition:border-color var(--duration-fast) var(--ease-default), box-shadow var(--duration-fast) var(--ease-default);outline:none;font-family:inherit}.pf-field__select{appearance:none;padding-right:var(--space-8);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat}.pf-field__textarea{resize:none;min-height:80px;line-height:var(--leading-relaxed)}.pf-field__input:focus,.pf-field__select:focus,.pf-field__textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4ade8026}.pf-field__input--disabled{opacity:.6;cursor:not-allowed;background:var(--color-surface-container-high)}.pf-field__hint{font-size:var(--text-xs);color:var(--color-text-subtle)}.pf-field-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.pf-plan-chip{padding:4px var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);letter-spacing:.02em;align-items:center;display:inline-flex}.pf-plan-chip--free{background:var(--color-surface-container-high);color:var(--color-text-muted)}.pf-plan-chip--basic{color:#1d4ed8;background:#dbeafe}.pf-plan-chip--premium{color:#b45309;background:#fef3c7}.pf-plan-chip--lifetime{color:#065f46;background:#d1fae5}.dark .pf-plan-chip--basic{color:#60a5fa;background:#3b82f626}.dark .pf-plan-chip--premium{color:#fbbf24;background:#f59e0b26}.dark .pf-plan-chip--lifetime{color:#34d399;background:#10b98126}.pf-form__actions{padding-top:var(--space-2);display:flex}.pf-form__submit{align-items:center;gap:var(--space-2);padding:10px var(--space-6);background:var(--color-primary);color:#fff;font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-bold);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);border:none;display:inline-flex;box-shadow:0 2px 8px #4ade8040}.pf-form__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #4ade8059}.pf-form__submit:active:not(:disabled){transform:translateY(0)}.pf-form__submit:disabled{opacity:.6;cursor:not-allowed}.pf-form__submit-icon{flex-shrink:0;width:16px;height:16px}.pf-form__submit-icon--spin{animation:.8s linear infinite spin}.pf-error{align-items:center;gap:var(--space-3);padding:var(--space-16) 0;text-align:center;color:var(--color-text-muted);font-size:var(--text-sm);flex-direction:column;display:flex}.pf-error__icon{font-size:3rem}@media (max-width:640px){.pf{gap:var(--space-6)}.pf-hero__cover{height:80px}.pf-hero__body{padding:0 var(--space-4) var(--space-4);margin-top:-40px}.pf-hero__avatar-ring{width:80px;height:80px}.pf-hero__avatar--initials,.pf-hero__name{font-size:var(--text-xl)}.pf-hero__stats{gap:var(--space-3);padding:var(--space-4);grid-template-columns:1fr 1fr}.pf-hero__stat-sep{display:none}.pf-hero__stat{justify-content:flex-start}.pf-form-card{padding:var(--space-4)}.pf-fieldset__legend{font-size:var(--text-sm)}.pf-field-row{grid-template-columns:1fr}}.nb-page{gap:var(--space-8);flex-direction:column;display:flex}.nb-page__header{justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.nb-page__hero{align-items:center;gap:var(--space-4);display:flex}.nb-page__hero-icon{filter:drop-shadow(0 4px 12px #4ade8040);flex-shrink:0;font-size:3.5rem}.nb-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}.nb-page__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0;line-height:var(--leading-vi)}.nb-summary{background:var(--color-surface);border-radius:var(--radius-2xl);align-items:stretch;display:flex;overflow:hidden}.nb-summary__item{align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-6);flex:1;display:flex}.nb-summary__icon{font-size:var(--text-2xl);flex-shrink:0}.nb-summary__value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-primary);line-height:1}.nb-summary__label{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:3px}.nb-summary__divider{background:var(--color-surface-container-high);flex-shrink:0;align-self:stretch;width:1px}.nb-section-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);display:flex}.nb-section-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);letter-spacing:-.01em;margin:0}.nb-section-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);justify-content:center;align-items:center;min-width:24px;display:inline-flex}.dark .nb-section-count{color:var(--color-primary);background:#4ade8026}.nb-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.nb-card{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;text-decoration:none;display:flex;position:relative;overflow:hidden}.nb-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #00000026,0 2px 8px #00000014}.dark .nb-card:hover{box-shadow:0 10px 30px #00000073,0 2px 8px #0000004d}.nb-card--system{cursor:default}.nb-card--system:hover{transform:translateY(-3px)}.nb-card__color-strip{width:4px;position:absolute;top:0;bottom:0;left:0}.nb-card__body{padding:var(--space-5) var(--space-5) var(--space-4) calc(var(--space-5) + 10px);gap:var(--space-3);flex-direction:column;flex:1;display:flex}.nb-card__top{align-items:flex-start;gap:var(--space-2);display:flex}.nb-card__emoji{flex-shrink:0;margin-top:1px;font-size:1.6rem;line-height:1}.nb-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);letter-spacing:-.01em;margin:0}.nb-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;flex:1;display:-webkit-box;overflow:hidden}.nb-card__footer{padding:var(--space-3) var(--space-5) var(--space-3) calc(var(--space-5) + 10px);background:var(--color-surface-container-low);justify-content:space-between;align-items:center;display:flex}.nb-card__count{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted)}.nb-card__action{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-primary);text-decoration:none}.nb-card:hover .nb-card__action{text-decoration:underline}.nb-new-card{background:var(--color-surface-container-low);border:2px dashed var(--color-surface-container-high);border-radius:var(--radius-2xl);justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-4);cursor:pointer;min-height:180px;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);transition:all var(--duration-fast) var(--ease-bounce);text-align:center;flex-direction:column;display:flex}.nb-new-card:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-3px)}.dark .nb-new-card:hover{background:#4ade800a}.nb-new-card__icon{border-radius:var(--radius-full);background:var(--color-surface-container-high);width:48px;height:48px;font-size:var(--text-2xl);color:var(--color-text-muted);transition:all var(--duration-fast) var(--ease-bounce);justify-content:center;align-items:center;line-height:1;display:flex}.nb-new-card:hover .nb-new-card__icon{background:var(--color-primary);color:#fff;transform:rotate(90deg)scale(1.1)}.nb-topic-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.nb-topic-card{background:var(--color-surface);border-radius:var(--radius-xl);transition:transform var(--duration-fast) var(--ease-bounce);flex-direction:column;display:flex;position:relative;overflow:hidden}.nb-topic-card:hover{transform:translateY(-3px)}.nb-topic-card__accent{flex-shrink:0;height:3px}.nb-topic-card__body{padding:var(--space-3) var(--space-4);gap:var(--space-2);flex-direction:column;flex:1;display:flex}.nb-topic-card__top{align-items:center;gap:var(--space-2);display:flex}.nb-topic-card__emoji{flex-shrink:0;font-size:1.3rem}.nb-topic-card__title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text);line-height:var(--leading-snug);margin:0}.nb-topic-card__desc{color:var(--color-text-muted);font-size:11px;line-height:var(--leading-relaxed);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.nb-topic-card__footer{padding:var(--space-2) var(--space-4) var(--space-3);background:var(--color-surface-container-low);justify-content:space-between;align-items:center;display:flex}.nb-topic-card__count{color:var(--color-text-muted);font-size:11px;font-weight:var(--font-semibold)}.nb-topic-card__actions{align-items:center;gap:var(--space-1-5,6px);display:flex}.nb-topic-card__link{font-size:11px;font-weight:var(--font-bold);color:var(--color-primary);text-decoration:none}.nb-topic-card__link:hover{text-decoration:underline}.nb-empty{align-items:center;gap:var(--space-4);padding:var(--space-12) var(--space-4);text-align:center;background:var(--color-surface-container-low);border:2px dashed var(--color-surface-container-high);border-radius:var(--radius-2xl);flex-direction:column;display:flex}.nb-empty__icon{font-size:4rem}.nb-empty__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.nb-empty__sub{font-size:var(--text-sm);color:var(--color-text-muted);max-width:320px;line-height:var(--leading-vi)}@media (max-width:768px){.nb-page{gap:var(--space-6)}.nb-page__header{flex-direction:column;align-items:flex-start}.nb-page__title{font-size:var(--text-2xl)}.nb-summary{flex-wrap:wrap}.nb-summary__item{min-width:120px;padding:var(--space-4);flex:1}.nb-grid{grid-template-columns:1fr 1fr}.nb-topic-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@media (max-width:480px){.nb-grid{grid-template-columns:1fr}.nb-topic-grid{grid-template-columns:1fr 1fr}}@media (max-width:400px){.nb-grid{grid-template-columns:1fr}}.nb-delete-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-text-muted);border:1px solid var(--color-border);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);white-space:nowrap;background:0 0;display:inline-flex}.nb-delete-btn:hover{color:var(--color-error);border-color:var(--color-error);background:color-mix(in oklch, var(--color-error) 8%, transparent)}.nb-delete-btn--danger{color:#fff;background:var(--color-error);border-color:var(--color-error)}.nb-delete-btn--danger:hover{background:color-mix(in oklch, var(--color-error) 85%, #000)}.nb-delete-btn--cancel{color:var(--color-text-muted);background:var(--color-surface-container-low);border-color:var(--color-border)}.nb-delete-btn--cancel:hover{background:var(--color-surface-container-high);color:var(--color-text)}.nb-delete-btn--loading{opacity:.6;cursor:not-allowed}.nb-delete-confirm{gap:var(--space-2);flex-direction:column;display:flex}.nb-delete-confirm__text{font-size:var(--text-xs);color:var(--color-error);font-weight:var(--font-medium);line-height:var(--leading-relaxed)}.nb-delete-confirm__actions{gap:var(--space-2);flex-wrap:wrap;display:flex}@media (max-width:768px){.nb-delete-btn__label{display:none}}.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}@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}}.word-popup{z-index:var(--z-modal,400);background:var(--color-surface);border-radius:var(--radius-2xl);min-width:240px;max-width:340px;position:fixed;overflow:visible;box-shadow:0 4px 6px -1px #0000001f,0 12px 32px -4px #0003,0 0 0 1px #ffffff0f}.dark .word-popup{box-shadow:0 4px 6px -1px #0006,0 12px 32px -4px #00000080,0 0 0 1px #ffffff14}.word-popup__arrow{background:var(--color-surface);border-top:1px solid #ffffff0f;border-left:1px solid #ffffff0f;border-radius:2px 0 0;width:14px;height:14px;position:absolute;top:-7px;left:50%;transform:rotate(45deg)}.word-popup__loading{align-items:center;gap:var(--space-2);padding:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted);display:flex}.word-popup__spinner{color:var(--color-primary);flex-shrink:0;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.word-popup__body{gap:var(--space-2);padding:var(--space-4);flex-direction:column;display:flex}.word-popup__header{justify-content:space-between;align-items:flex-start;gap:var(--space-2);display:flex}.word-popup__title-row{align-items:center;gap:var(--space-1-5);flex-wrap:wrap;flex:1;min-width:0;display:flex}.word-popup__gender{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);letter-spacing:.04em;text-transform:lowercase;flex-shrink:0;align-items:center;padding:2px 8px;display:inline-flex}.word-popup__word{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);line-height:1.2}.word-popup__word-class{font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic}.word-popup__close{background:var(--color-surface-container-high);border-radius:var(--radius-full);width:24px;height:24px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.word-popup__close:hover{color:#ef4444;background:#ef444426}.word-popup__pronunciation{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-text-muted);font-family:monospace;display:flex}.word-popup__meaning{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);line-height:var(--leading-snug);padding:var(--space-2) var(--space-3);background:var(--color-primary-container);border-radius:var(--radius-lg)}.dark .word-popup__meaning{background:#4ade801a}.word-popup__link{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-text-muted);padding-top:var(--space-2);border-top:1px solid var(--color-surface-container-high);margin-top:var(--space-1);transition:color var(--duration-fast) var(--ease-default);text-decoration:none;display:inline-flex}.word-popup__link:hover{color:var(--color-primary)}.word-popup__not-found{align-items:center;gap:var(--space-3);padding:var(--space-4);display:flex}.word-popup__not-found-icon{opacity:.6;flex-shrink:0;font-size:1.5rem}.word-popup__not-found-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.word-popup__not-found-sub{font-size:var(--text-xs);color:var(--color-text-muted)}.reading-word{cursor:pointer;transition:background var(--duration-fast) var(--ease-default), color var(--duration-fast) var(--ease-default);border-radius:3px;margin:0 -2px;padding:0 2px;display:inline}.reading-word:hover{color:var(--color-primary);background:#4ade802e}.word-popup-overlay{z-index:calc(var(--z-modal,400) - 1);-webkit-backdrop-filter:blur(2px);animation:fade-in var(--duration-fast) var(--ease-default);background:#00000059;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@media (max-width:640px){.word-popup--mobile{border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;min-width:100%;max-width:100%;animation:slide-up-sheet .25s var(--ease-bounce);padding-bottom:env(safe-area-inset-bottom,8px);box-shadow:0 -8px 40px #00000040;position:fixed!important;inset:auto 0 0!important;transform:none!important}.word-popup--mobile .word-popup__arrow{display:none}.word-popup--mobile:before{content:"";background:var(--color-text-subtle,#ccc);width:40px;height:4px;margin:var(--space-2) auto var(--space-1);opacity:.5;border-radius:100px;display:block}.word-popup--mobile .word-popup__body,.word-popup--mobile .word-popup__not-found{padding:var(--space-4) var(--space-5) var(--space-6)}.word-popup--mobile .word-popup__close{width:32px;height:32px}}@keyframes slide-up-sheet{0%{opacity:.5;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.clone-btn{align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-primary);cursor:pointer;transition:opacity var(--duration-fast) var(--ease-default);white-space:nowrap;font-family:var(--font-body);background:0 0;border:none;padding:0;display:inline-flex}.clone-btn:hover:not(:disabled){opacity:.75}.clone-btn:disabled{opacity:.5;cursor:not-allowed}.clone-btn--icon{border-radius:var(--radius-full);background:var(--color-surface-container-high);width:26px;height:26px;color:var(--color-text-muted);transition:background var(--duration-fast) var(--ease-default), color var(--duration-fast) var(--ease-default), transform var(--duration-fast) var(--ease-bounce);flex-shrink:0;justify-content:center}.clone-btn--icon:hover:not(:disabled){background:var(--color-primary);color:#fff;opacity:1;transform:scale(1.1)}.clone-btn__spinner{animation:.7s linear infinite spin}.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-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__bookmark{border-radius:var(--radius-full);background:var(--color-surface-container-high);width:28px;height:28px;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}.dict-row__bookmark:hover{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)}.wd{gap:var(--space-5);max-width:720px;padding-bottom:var(--space-16);flex-direction:column;margin:0 auto;display:flex}.wd__back{align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-default);width:fit-content;text-decoration:none;display:inline-flex}.wd__back:hover{color:var(--color-primary)}.wd__hero{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-8) var(--space-8) var(--space-6);background-image:linear-gradient(135deg, var(--color-surface) 0%, var(--color-surface-container-low) 100%);position:relative;overflow:hidden}.wd__hero-accent{border-radius:0 var(--radius-sm) var(--radius-sm) 0;width:5px;position:absolute;top:0;bottom:0;left:0}.wd__hero.wd__gender--der .wd__hero-accent{background:#3b82f6}.wd__hero.wd__gender--die .wd__hero-accent{background:#f43f5e}.wd__hero.wd__gender--das .wd__hero-accent{background:#10b981}.wd__hero.wd__gender--der{background-image:linear-gradient(135deg, #3b82f60a 0%, var(--color-surface) 40%)}.wd__hero.wd__gender--die{background-image:linear-gradient(135deg, #f43f5e0a 0%, var(--color-surface) 40%)}.wd__hero.wd__gender--das{background-image:linear-gradient(135deg, #10b9810a 0%, var(--color-surface) 40%)}.dark .wd__hero.wd__gender--der{background-image:linear-gradient(135deg, #3b82f614 0%, var(--color-surface) 40%)}.dark .wd__hero.wd__gender--die{background-image:linear-gradient(135deg, #f43f5e14 0%, var(--color-surface) 40%)}.dark .wd__hero.wd__gender--das{background-image:linear-gradient(135deg, #10b98114 0%, var(--color-surface) 40%)}.wd__hero-body{gap:var(--space-3);flex-direction:column;display:flex}.wd__word-row{align-items:baseline;gap:var(--space-3);display:flex}.wd__article{font-size:var(--text-xl);font-weight:var(--font-bold);opacity:.7;text-transform:lowercase}.wd__gender--der .wd__article{color:#3b82f6}.wd__gender--die .wd__article{color:#f43f5e}.wd__gender--das .wd__article{color:#10b981}.wd__word{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.04em;margin:0;line-height:1.1}.wd__plural{font-size:var(--text-sm);color:var(--color-text-muted)}.wd__plural-label{font-weight:var(--font-semibold);color:var(--color-text-subtle);margin-right:2px}.wd__ipa-row{align-items:center;gap:var(--space-2);margin-top:var(--space-1);display:flex}.wd__ipa{font-family:var(--font-mono);font-size:var(--text-base);color:var(--color-text-muted);background:var(--color-surface-container-low);padding:var(--space-1) var(--space-3);border-radius:var(--radius-lg);letter-spacing:.02em}.wd__audio-btn{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;cursor:pointer;width:36px;height:36px;transition:all var(--duration-fast) var(--ease-bounce);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.wd__audio-btn:hover{box-shadow:var(--shadow-primary);transform:scale(1.1)}.wd__audio-btn:active{transform:scale(.95)}.wd__tags{align-items:center;gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.wd__tag{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);letter-spacing:.02em;align-items:center;padding:3px 12px;display:inline-flex}.wd__tag--level{color:var(--color-primary);background:#4ade801f}.dark .wd__tag--level{background:#4ade8026}.wd__tag--pos{background:var(--color-surface-container-high);color:var(--color-text-muted);font-weight:var(--font-medium)}.wd__tag--irregular{color:#ea580c;background:#f973161f}.dark .wd__tag--irregular{color:#fb923c;background:#f9731626}.wd__section{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-6);gap:var(--space-5);flex-direction:column;display:flex}.wd__section-header{align-items:center;gap:var(--space-3);display:flex}.wd__section-icon{border-radius:var(--radius-xl);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.wd__section-icon--meanings{color:var(--color-primary);background:#4ade801f}.wd__section-icon--grammar{color:#3b82f6;background:#3b82f61f}.wd__section-icon--collocations{color:#a855f7;background:#a855f71f}.wd__section-icon--related{color:#ec4899;background:#ec48991f}.wd__section-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);flex:1;margin:0}.wd__section-count{border-radius:var(--radius-full);background:var(--color-surface-container-high);min-width:24px;height:24px;color:var(--color-text-muted);font-size:11px;font-weight:var(--font-bold);justify-content:center;align-items:center;padding:0 6px;display:inline-flex}.wd__meanings{gap:var(--space-4);flex-direction:column;display:flex}.wd__meaning-item{gap:var(--space-3);padding:var(--space-4);background:var(--color-surface-container-low);border-radius:var(--radius-xl);transition:background var(--duration-fast) var(--ease-default);display:flex}.wd__meaning-item:hover{background:var(--color-surface-container)}.wd__meaning-num{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;width:28px;height:28px;font-size:var(--text-xs);font-weight:var(--font-bold);flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;display:flex}.wd__meaning-body{gap:var(--space-2);flex-direction:column;flex:1;min-width:0;display:flex}.wd__meaning-text{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);line-height:var(--leading-vi);margin:0}.wd__meaning-context{font-size:var(--text-sm);color:var(--color-text-muted);margin:0;font-style:italic}.wd__examples{gap:var(--space-2);margin-top:var(--space-1);flex-direction:column;display:flex}.wd__example{padding:var(--space-3);background:var(--color-surface);border-radius:var(--radius-lg);border-left:3px solid var(--color-primary);flex-direction:column;gap:4px;display:flex}.wd__example-de,.wd__example-vi{align-items:flex-start;gap:var(--space-2);font-size:var(--text-sm);line-height:var(--leading-vi);display:flex}.wd__example-flag{flex-shrink:0;margin-top:2px;font-size:13px}.wd__example-de{color:var(--color-text);font-weight:var(--font-medium)}.wd__example-vi{color:var(--color-text-muted)}.vconj{gap:var(--space-5);flex-direction:column;display:flex}.vconj__header{gap:var(--space-2);flex-direction:column;display:flex}.vconj__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin:0}.vconj__meta{gap:var(--space-3);flex-wrap:wrap;display:flex}.vconj__aux,.vconj__partizip{font-size:var(--text-xs);color:var(--color-text-muted);background:var(--color-surface-container-low);border-radius:var(--radius-full);padding:3px 10px}.vconj__aux strong,.vconj__partizip strong{color:var(--color-text);font-weight:var(--font-semibold)}.vconj__imperativ{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.vconj__imperativ-label{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.vconj__imperativ-forms{gap:var(--space-2);flex-wrap:wrap;display:flex}.vconj__imperativ-chip{align-items:center;gap:var(--space-1);border-radius:var(--radius-full);font-size:var(--text-sm);background:#3b82f614;padding:4px 12px;display:inline-flex}.dark .vconj__imperativ-chip{background:#3b82f61f}.vconj__imperativ-person{font-weight:var(--font-medium);color:var(--color-text-muted);font-size:var(--text-xs)}.vconj__imperativ-person:after{content:":"}.vconj__imperativ-form{font-weight:var(--font-bold);color:#3b82f6}.vconj__mood{gap:var(--space-3);flex-direction:column;display:flex}.vconj__mood-label{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-extrabold);color:#3b82f6;text-transform:uppercase;letter-spacing:.08em;padding-bottom:var(--space-1);border-bottom:2px solid #3b82f633;margin:0}.vconj__scroll{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--color-text-subtle) transparent;margin:0 calc(-1 * var(--space-6));padding:0 var(--space-6);overflow:auto hidden}.vconj__scroll::-webkit-scrollbar{height:4px}.vconj__scroll::-webkit-scrollbar-track{background:0 0}.vconj__scroll::-webkit-scrollbar-thumb{background:var(--color-text-subtle);border-radius:10px}.vconj__cards{gap:var(--space-3);padding-bottom:var(--space-2);display:flex}.vconj__card{border-radius:var(--radius-xl);background:var(--color-surface-container-low);transition:box-shadow var(--duration-fast) var(--ease-default);flex:0 0 200px;overflow:hidden}.vconj__card:hover{box-shadow:var(--shadow-sm)}.vconj__card-header{padding:var(--space-2) var(--space-3);background:var(--color-surface-container);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text);text-align:center;letter-spacing:.02em}.vconj__card-body{padding:var(--space-2) 0}.vconj__row{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);transition:background var(--duration-fast) var(--ease-default);display:flex}.vconj__row:hover{background:var(--color-surface-container)}.vconj__row:before{content:"";border-radius:var(--radius-full);background:var(--color-text-subtle);flex-shrink:0;width:5px;height:5px}.vconj__pronoun{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--font-medium);white-space:nowrap;min-width:52px}.vconj__form{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);white-space:nowrap}.vconj__stem{color:var(--color-text)}.vconj__ending{color:#3b82f6;font-weight:var(--font-bold)}.dark .vconj__ending{color:#60a5fa}@media (max-width:640px){.vconj__card{flex:0 0 180px}.vconj__scroll{margin:0 calc(-1 * var(--space-4));padding:0 var(--space-4)}}.wd__grammar{gap:var(--space-5);flex-direction:column;display:flex}.wd__grammar-note{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-vi);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);background:#3b82f60f;border-left:3px solid #3b82f6;margin:0}.wd__grammar-block{gap:var(--space-3);flex-direction:column;display:flex}.wd__grammar-block-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0}.wd__conjugation-grid{gap:var(--space-1);grid-template-columns:repeat(2,1fr);display:grid}.wd__conjugation-row{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--color-surface-container-low);border-radius:var(--radius-md);display:flex}.wd__conjugation-pronoun{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--font-medium);min-width:50px}.wd__conjugation-form{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text)}.wd__declension-table{background:var(--color-surface-container-low);border-radius:var(--radius-xl);flex-direction:column;gap:2px;padding:2px;display:flex;overflow:hidden}.wd__declension-header,.wd__declension-row{grid-template-columns:100px 1fr 1fr;gap:2px;display:grid}.wd__declension-header{font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.wd__declension-header>span{padding:var(--space-2) var(--space-3);background:var(--color-surface-container);border-radius:var(--radius-md);text-align:center}.wd__declension-header>span:first-child{text-align:left;background:0 0}.wd__declension-row>span{padding:var(--space-2) var(--space-3);background:var(--color-surface);border-radius:var(--radius-md);font-size:var(--text-sm)}.wd__declension-case{font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:capitalize}.wd__declension-form{font-weight:var(--font-medium);color:var(--color-text);text-align:center}.wd__comparison{align-items:center;gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.wd__comparison-item{padding:var(--space-3) var(--space-5);background:var(--color-surface-container-low);border-radius:var(--radius-xl);text-align:center;flex-direction:column;align-items:center;gap:4px;min-width:100px;display:flex}.wd__comparison-label{font-size:11px;font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.wd__comparison-value{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text)}.wd__comparison-arrow{font-size:var(--text-lg);color:var(--color-text-subtle);flex-shrink:0}.wd__collocations{gap:var(--space-2);flex-direction:column;display:flex}.wd__collocation-item{padding:var(--space-3) var(--space-4);background:var(--color-surface-container-low);border-radius:var(--radius-lg);transition:background var(--duration-fast) var(--ease-default)}.wd__collocation-item:hover{background:var(--color-surface-container)}.wd__collocation-phrase{align-items:baseline;gap:var(--space-3);flex-wrap:wrap;display:flex}.wd__collocation-de{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text)}.wd__collocation-vi{font-size:var(--text-sm);color:var(--color-text-muted)}.wd__collocation-vi:before{content:"— "}.wd__collocation-example{font-size:var(--text-xs);color:var(--color-text-muted);margin:var(--space-1) 0 0;font-style:italic}.wd__section--tip{background:linear-gradient(135deg, #fbbf2414 0%, var(--color-surface) 50%);border:1px solid #fbbf2433}.dark .wd__section--tip{background:linear-gradient(135deg, #fbbf240f 0%, var(--color-surface) 50%);border-color:#fbbf241f}.wd__tip{gap:var(--space-4);display:flex}.wd__tip-icon{border-radius:var(--radius-xl);color:#f59e0b;background:#fbbf2426;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.dark .wd__tip-icon{color:#fbbf24;background:#fbbf241f}.wd__tip-body{flex:1;min-width:0}.wd__tip-title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:#b45309;margin:0 0 var(--space-2);align-items:center;gap:var(--space-1);display:flex}.dark .wd__tip-title{color:#fbbf24}.wd__tip-text{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-vi);margin:0}.wd__related{gap:var(--space-4);flex-direction:column;display:flex}.wd__related-group{align-items:flex-start;gap:var(--space-3);display:flex}.wd__related-label{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;min-width:80px;padding-top:4px}.wd__related-chips{gap:var(--space-2);flex-wrap:wrap;display:flex}.wd__related-chip{border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--duration-fast) var(--ease-default);cursor:default;align-items:center;padding:4px 14px;display:inline-flex}.wd__related-chip--syn{color:var(--color-primary);background:#4ade801a}.wd__related-chip--syn:hover{background:#4ade8033}.wd__related-chip--ant{color:#ef4444;background:#ef444414}.wd__related-chip--ant:hover{background:#ef444426}.dark .wd__related-chip--ant{color:#f87171;background:#ef44441f}.fbk{margin-top:var(--space-2)}.fbk__toggle{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);justify-content:space-between;align-items:center;display:flex}.fbk__toggle:hover{background:var(--color-surface-container-low);border-color:var(--color-primary)}.fbk__toggle-left{align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);display:flex}.fbk__toggle-action{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-primary)}.fbk__body{gap:var(--space-4);margin-top:var(--space-3);padding:var(--space-4);background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);flex-direction:column;animation:.2s ease-out fadeInUp;display:flex}.fbk__alert{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-xs);font-weight:var(--font-medium);display:flex}.fbk__alert--error{color:#ef4444;background:#ef444414;border:1px solid #ef444433}.dark .fbk__alert--error{color:#f87171;background:#ef44441f}.fbk__alert--success{color:var(--color-primary);background:#4ade8014;border:1px solid #4ade8033}.fbk__alert-close{color:inherit;cursor:pointer;border-radius:var(--radius-full);background:0 0;border:none;margin-left:auto;padding:2px}.fbk__alert-close:hover{opacity:.7}.fbk__form{gap:var(--space-2);flex-direction:column;display:flex}.fbk__input{width:100%;padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface-container-low);color:var(--color-text);font-size:var(--text-sm);resize:vertical;min-height:60px;transition:all var(--duration-fast) var(--ease-default);outline:none;font-family:inherit}.fbk__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in oklch, var(--color-primary) 12%, transparent);background:var(--color-surface)}.fbk__input::placeholder{color:var(--color-text-subtle)}.fbk__input:disabled{opacity:.5;cursor:not-allowed}.fbk__form-actions{justify-content:space-between;align-items:center;display:flex}.fbk__char-count{color:var(--color-text-subtle);font-size:11px}.fbk__submit{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);background:var(--color-primary);color:#fff;font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);border:none;display:inline-flex}.fbk__submit:hover:not(:disabled){box-shadow:var(--shadow-primary);transform:translateY(-1px)}.fbk__submit:active:not(:disabled){transform:translateY(0)}.fbk__submit:disabled{opacity:.4;cursor:not-allowed}.fbk__list{gap:var(--space-3);flex-direction:column;display:flex}.fbk__empty{font-size:var(--text-sm);color:var(--color-text-subtle);text-align:center;padding:var(--space-4);margin:0}.fbk__item{gap:var(--space-2);padding:var(--space-3);background:var(--color-surface-container-low);border-radius:var(--radius-lg);transition:background var(--duration-fast) var(--ease-default);flex-direction:column;display:flex}.fbk__item:hover{background:var(--color-surface-container)}.fbk__item-header{align-items:center;gap:var(--space-2);display:flex}.fbk__avatar{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;width:28px;height:28px;font-size:12px;font-weight:var(--font-bold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.fbk__item-info{align-items:baseline;gap:var(--space-2);flex:1;min-width:0;display:flex}.fbk__author{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);align-items:center;gap:var(--space-1);display:flex}.fbk__own-tag{border-radius:var(--radius-full);color:#3b82f6;font-size:10px;font-weight:var(--font-bold);background:#3b82f61a;padding:1px 6px}.fbk__time{color:var(--color-text-subtle);font-size:11px}.fbk__content{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-vi);margin:0;padding-left:36px}.fbk__item-actions{align-items:center;gap:var(--space-1);padding-left:36px;display:flex}.fbk__action-btn{border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-subtle);transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;align-items:center;gap:3px;padding:3px 8px;font-size:12px;display:inline-flex}.fbk__action-btn:hover:not(:disabled){background:var(--color-surface-container);color:var(--color-text-muted)}.fbk__action-btn:disabled{opacity:.3;cursor:not-allowed}.fbk__action-btn--voted{color:var(--color-primary);background:#4ade801a}.fbk__action-btn--voted:hover{color:var(--color-primary)!important;background:#4ade8026!important}.fbk__action-btn--report:hover{color:#f59e0b!important}.fbk__action-btn--delete:hover{color:#ef4444!important}.fbk__modal-overlay{z-index:1000;padding:var(--space-4);background:#00000080;justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}.fbk__modal{background:var(--color-surface);border-radius:var(--radius-2xl);width:100%;max-width:420px;box-shadow:var(--shadow-xl);animation:.2s ease-out slideUp;overflow:hidden}.fbk__modal-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.fbk__modal-header h3{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin:0}.fbk__modal-close{border-radius:var(--radius-full);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.fbk__modal-close:hover{background:var(--color-surface-container);color:var(--color-text)}.fbk__modal-body{padding:var(--space-4) var(--space-5);gap:var(--space-3);flex-direction:column;display:flex}.fbk__modal-label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.fbk__report-reasons{gap:var(--space-2);flex-direction:column;display:flex}.fbk__report-reason{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);cursor:pointer;transition:background var(--duration-fast) var(--ease-default);font-size:var(--text-sm);color:var(--color-text);display:flex}.fbk__report-reason:hover{background:var(--color-surface-container-low)}.fbk__report-reason input[type=radio]{accent-color:var(--color-primary)}.fbk__modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-top:1px solid var(--color-border);display:flex}.fbk__modal-cancel{padding:var(--space-2) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);background:0 0}.fbk__modal-cancel:hover{background:var(--color-surface-container-low);color:var(--color-text)}.fbk__modal-submit{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);color:#fff;font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);background:#ef4444;border:none;display:inline-flex}.fbk__modal-submit:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.fbk__modal-submit:disabled{opacity:.5;cursor:not-allowed}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.nbd{gap:var(--space-6);flex-direction:column;display:flex}.nbd__header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.nbd__title-row{align-items:center;gap:var(--space-3);margin-bottom:var(--space-1);display:flex}.nbd__emoji{font-size:var(--text-3xl)}.nbd__color-dot{border-radius:var(--radius-full);flex-shrink:0;width:12px;height:12px}.nbd__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.02em;margin:0}.nbd__desc{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.nbd__actions{align-items:center;gap:var(--space-2);flex-wrap:wrap;flex-shrink:0;display:flex}.nbd__flashcard-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-semibold);color:#d97706;cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);white-space:nowrap;background:linear-gradient(135deg,#fbbf241a 0%,#f59e0b14 100%);border:1px solid #fbbf244d;display:inline-flex}.dark .nbd__flashcard-btn{color:#fbbf24;background:linear-gradient(135deg,#fbbf2414 0%,#f59e0b0d 100%);border-color:#fbbf2433}.nbd__flashcard-btn:hover:not(:disabled){background:linear-gradient(135deg,#fbbf242e 0%,#f59e0b1f 100%);border-color:#fbbf2480;transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b26}.nbd__flashcard-btn:active:not(:disabled){transform:translateY(0)}.nbd__flashcard-btn:disabled{opacity:.5;cursor:not-allowed}.nbd__wl{gap:var(--space-4);flex-direction:column;display:flex}.nbd__wl-toolbar{gap:var(--space-3);flex-direction:column;display:flex}.nbd__wl-search{align-items:center;display:flex;position:relative}.nbd__wl-search-icon{left:var(--space-3);width:16px;height:16px;color:var(--color-text-muted);pointer-events:none;position:absolute}.nbd__wl-search-input{width:100%;height:40px;padding:0 var(--space-10) 0 var(--space-10);border-radius:var(--radius-xl);border:1px solid var(--color-border);background:var(--color-surface-container-low);font-size:var(--text-sm);color:var(--color-text);transition:all var(--duration-fast) var(--ease-default);outline:none}.nbd__wl-search-input::placeholder{color:var(--color-text-subtle,color-mix(in oklch, var(--color-text-muted) 60%, transparent))}.nbd__wl-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in oklch, var(--color-primary) 12%, transparent);background:var(--color-surface)}.nbd__wl-search-clear{right:var(--space-2);border-radius:var(--radius-full);width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute}.nbd__wl-search-clear:hover{background:var(--color-bg-muted);color:var(--color-text)}.nbd__wl-filters{gap:var(--space-2);flex-wrap:wrap;display:flex}.nbd__wl-filter{align-items:center;gap:var(--space-1-5,6px);border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);white-space:nowrap;padding:6px 12px;display:inline-flex}.nbd__wl-filter:hover{border-color:var(--color-primary);color:var(--color-text)}.nbd__wl-filter--active{border-color:var(--color-primary);background:color-mix(in oklch, var(--color-primary) 8%, transparent);color:var(--color-primary);font-weight:var(--font-semibold)}.nbd__wl-filter-emoji{font-size:13px}.nbd__wl-filter-count{font-size:11px;font-weight:var(--font-bold);border-radius:var(--radius-full);background:var(--color-surface-container-high);color:var(--color-text-muted);text-align:center;min-width:20px;padding:0 5px}.nbd__wl-filter--active .nbd__wl-filter-count{background:color-mix(in oklch, var(--color-primary) 15%, transparent);color:var(--color-primary)}.nbd__wl-result-info{font-size:var(--text-sm);color:var(--color-text-muted);padding:var(--space-2) var(--space-3);background:var(--color-surface-container-low);border-radius:var(--radius-lg);border-left:3px solid var(--color-primary)}.nbd__wl-empty{align-items:center;gap:var(--space-3);padding:var(--space-12) var(--space-4);text-align:center;color:var(--color-text-muted);flex-direction:column;display:flex}.nbd__wl-empty-icon{font-size:var(--text-3xl);opacity:.6}.nbd__wl-empty p{font-size:var(--text-sm);margin:0}.nbd__wl-empty-reset{padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);border:1px solid var(--color-border);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);background:0 0}.nbd__wl-empty-reset:hover{background:color-mix(in oklch, var(--color-primary) 6%, transparent);border-color:var(--color-primary)}.nbd__wl-load-more{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);border:1px dashed var(--color-border);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);background:0 0;display:flex}.nbd__wl-load-more:hover{border-color:var(--color-primary);color:var(--color-primary);background:color-mix(in oklch, var(--color-primary) 4%, transparent)}.nbd__wl-load-more-count{font-size:var(--text-xs);opacity:.6}.nbd__word-list{gap:var(--space-3);flex-direction:column;display:flex}.nbd__word-item{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);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}.nbd__word-item:hover{border-color:#4ade804d}.nbd__mastery{align-items:center;gap:var(--space-1);flex-direction:column;flex-shrink:0;width:56px;display:flex}.nbd__mastery-dots{gap:3px;display:flex}.nbd__mastery-dot{border-radius:var(--radius-full);background:var(--color-surface-container-high);width:8px;height:8px;transition:background var(--duration-fast) var(--ease-default)}.nbd__mastery-dot--filled{background:var(--color-primary)}.nbd__mastery-label{color:var(--color-text-subtle);white-space:nowrap;font-size:10px}.nbd__word-info{min-width:0;color:inherit;gap:var(--space-1);flex-direction:column;flex:1;text-decoration:none;display:flex}.nbd__word-info:hover .nbd__word-text{color:var(--color-primary)}.nbd__word-top{align-items:baseline;gap:var(--space-2);flex-wrap:wrap;display:flex}.nbd__word-gender{font-size:var(--text-sm);font-weight:var(--font-semibold);opacity:.7}.nbd__word-gender--der{color:#3b82f6}.nbd__word-gender--die{color:#f43f5e}.nbd__word-gender--das{color:#10b981}.nbd__word-text{font-weight:var(--font-semibold);color:var(--color-text);transition:color var(--duration-fast) var(--ease-default)}.nbd__word-ipa{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-subtle)}.nbd__word-meaning{font-size:var(--text-sm);color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.nbd__word-tags{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.nbd__word-remove{flex-shrink:0}@media (max-width:768px){.nbd__header{flex-direction:column}.nbd__word-item{padding:var(--space-3) var(--space-4);gap:var(--space-3)}.nbd__mastery,.nbd__word-tags{display:none}}.wd__add-nb-trigger{top:var(--space-4);right:var(--space-4);border-radius:var(--radius-full);width:36px;height:36px;color:var(--color-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);z-index:2;background:#4ade801a;border:1.5px solid #4ade8033;justify-content:center;align-items:center;display:flex;position:absolute}.wd__add-nb-trigger:hover{background:#4ade8033;border-color:#4ade8066;transform:scale(1.1);box-shadow:0 4px 14px #4ade8033}.wd__add-nb-trigger:active{transform:scale(.95)}.wd__add-nb-trigger--added{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.wd__add-nb-trigger--added:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);box-shadow:0 4px 14px #4ade804d}.dark .wd__add-nb-trigger{background:#4ade8014;border-color:#4ade8026}.dark .wd__add-nb-trigger:hover{background:#4ade802e;border-color:#4ade8059}.wd__nb-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#00000080;animation:.2s wdOverlayIn;position:fixed;inset:0}@keyframes wdOverlayIn{0%{opacity:0}to{opacity:1}}.wd__nb-dialog{z-index:101;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);width:92vw;max-width:400px;max-height:80vh;animation:wdDialogIn .25s var(--ease-bounce);flex-direction:column;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 20px 60px #0003,0 8px 20px #0000001a}.dark .wd__nb-dialog{box-shadow:0 20px 60px #00000080,0 8px 20px #0000004d}@keyframes wdDialogIn{0%{opacity:0;transform:translate(-50%,-48%)scale(.95)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.wd__nb-dialog-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.wd__nb-dialog-header-left{align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);display:flex}.wd__nb-dialog-close{border-radius:var(--radius-full);width:30px;height:30px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.wd__nb-dialog-close:hover{background:var(--color-surface-container-high);color:var(--color-text)}.wd__nb-dialog-word{padding:var(--space-3) var(--space-5);font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-extrabold);color:var(--color-primary);background:var(--color-surface-container-low);border-bottom:1px solid var(--color-border);letter-spacing:-.02em}.wd__nb-dialog-error{padding:var(--space-2) var(--space-5);font-size:var(--text-xs);color:var(--color-error);background:#ef44440f}.wd__nb-dialog-loading{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-10) var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted);display:flex}.wd__nb-list{padding:var(--space-2) 0;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;flex:1;max-height:280px;overflow-y:auto}.wd__nb-empty{padding:var(--space-8) var(--space-5);text-align:center;font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed)}.wd__nb-item{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-5);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);text-align:left;background:0 0;border:none;display:flex}.wd__nb-item:hover:not(:disabled){background:var(--color-surface-container-low)}.wd__nb-item--added{background:#4ade800f}.wd__nb-item--added:hover:not(:disabled){background:#4ade8014}.wd__nb-item:disabled{cursor:default}.wd__nb-item-dot{border-radius:var(--radius-full);flex-shrink:0;width:10px;height:10px;box-shadow:0 1px 3px #00000026}.wd__nb-item-name{font-weight:var(--font-medium);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:var(--space-2);flex:1;display:flex;overflow:hidden}.wd__nb-item-badge{font-size:10px;font-weight:var(--font-bold);color:var(--color-primary);border-radius:var(--radius-full);background:#4ade801a;flex-shrink:0;padding:1px 6px}.wd__nb-item-count{font-size:var(--text-xs);color:var(--color-text-subtle);flex-shrink:0}.wd__nb-item-action{border-radius:var(--radius-full);width:26px;height:26px;color:var(--color-text-muted);transition:all var(--duration-fast) var(--ease-default);flex-shrink:0;justify-content:center;align-items:center;display:flex}.wd__nb-item:hover:not(:disabled) .wd__nb-item-action{color:var(--color-primary);background:#4ade801a}.wd__nb-item--added .wd__nb-item-action{color:var(--color-primary);background:#4ade801f}.wd__nb-dialog-footer{border-top:1px solid var(--color-border);padding:var(--space-3) var(--space-4)}.wd__nb-create-trigger{align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;display:flex}.wd__nb-create-trigger:hover{background:#4ade8014}.wd__nb-create-form{align-items:center;gap:var(--space-2);display:flex}.wd__nb-create-input{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--color-text);background:var(--color-surface-container-low);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color var(--duration-fast) var(--ease-default);outline:none;flex:1}.wd__nb-create-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4ade801a}.wd__nb-create-input::placeholder{color:var(--color-text-subtle)}.wd__nb-create-submit{border-radius:var(--radius-lg);background:var(--color-primary);color:#fff;cursor:pointer;width:32px;height:32px;transition:all var(--duration-fast) var(--ease-bounce);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.wd__nb-create-submit:hover:not(:disabled){transform:scale(1.05);box-shadow:0 2px 8px #4ade804d}.wd__nb-create-submit:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.wd{gap:var(--space-4);padding-bottom:var(--space-10)}.wd__hero{padding:var(--space-6) var(--space-5) var(--space-5)}.wd__word{font-size:var(--text-3xl)}.wd__section{padding:var(--space-5) var(--space-4)}.wd__conjugation-grid{grid-template-columns:1fr}.wd__declension-header,.wd__declension-row{grid-template-columns:80px 1fr 1fr}.wd__comparison{flex-direction:column;align-items:stretch}.wd__comparison-arrow{text-align:center;margin:calc(-1 * var(--space-2)) auto;transform:rotate(90deg)}.wd__comparison-item{text-align:left;min-width:auto;padding:var(--space-3) var(--space-4);flex-direction:row;justify-content:space-between}.wd__tip{gap:var(--space-3);flex-direction:column}.wd__related-group{gap:var(--space-2);flex-direction:column}}@media (max-width:480px){.wd__hero{padding:var(--space-5) var(--space-4)}.wd__word{font-size:var(--text-2xl)}.wd__article{font-size:var(--text-lg)}.wd__meaning-item{padding:var(--space-3)}.wd__meaning-num{width:24px;height:24px;font-size:10px}.wd__meaning-text{font-size:var(--text-sm)}.wd__declension-header,.wd__declension-row{font-size:var(--text-xs);grid-template-columns:70px 1fr 1fr}}.gd{gap:var(--space-5);max-width:760px;padding-bottom:var(--space-16);flex-direction:column;margin:0 auto;display:flex}.gd__back{align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-default);width:fit-content;text-decoration:none;display:inline-flex}.gd__back:hover{color:var(--color-primary)}.gd__hero{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-8);background-image:linear-gradient(135deg, var(--color-surface) 0%, var(--color-surface-container-low) 100%);position:relative;overflow:hidden}.gd__hero-accent{border-radius:0 var(--radius-sm) var(--radius-sm) 0;width:5px;position:absolute;top:0;bottom:0;left:0}.gd__hero-body{align-items:flex-start;gap:var(--space-5);display:flex}.gd__hero-icon{border-radius:var(--radius-xl);flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.gd__hero-content{gap:var(--space-3);flex-direction:column;flex:1;min-width:0;display:flex}.gd__title{font-family:var(--font-display);font-size:clamp(var(--text-xl), 2.5vw, var(--text-2xl));font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.02em;margin:0;line-height:1.2}.gd__desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin:0}.gd__tags{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.gd__tag{border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-bold);letter-spacing:.03em;align-items:center;gap:4px;padding:3px 10px;display:inline-flex}.gd__tag--cat{background:var(--color-surface-container-high);color:var(--color-text-muted)}.gd__section{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-6);gap:var(--space-4);flex-direction:column;display:flex}.gd__section-header{align-items:center;gap:var(--space-3);display:flex}.gd__section-num{border-radius:var(--radius-full);width:28px;height:28px;font-size:var(--text-xs);font-weight:var(--font-extrabold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.gd__section-title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);letter-spacing:-.01em;margin:0}.gd__section-content{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin:0}.gd__table-wrap{border-radius:var(--radius-xl);border:1px solid var(--color-border);-webkit-overflow-scrolling:touch;overflow-x:auto}.gd__table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.gd__table thead th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);background:var(--color-surface-container-high);border-bottom:1px solid var(--color-border);white-space:nowrap}.gd__table tbody td{padding:var(--space-2-5,10px) var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-text);line-height:var(--leading-relaxed)}.gd__table tbody tr:last-child td{border-bottom:none}.gd__table tbody tr:hover{background:var(--color-surface-container-low)}.gd__table-label{font-weight:var(--font-semibold)}.gd__examples{gap:var(--space-2);flex-direction:column;display:flex}.gd__examples-label{font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin:0}.gd__example{padding-left:var(--space-4);border-left:3px solid var(--color-primary);padding-top:var(--space-1);padding-bottom:var(--space-1);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:#4ade8008;flex-direction:column;gap:2px;display:flex}.dark .gd__example{background:#4ade800a}.gd__example-de{align-items:baseline;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text);font-weight:var(--font-medium);display:flex}.gd__example-vi{align-items:baseline;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);display:flex}.gd__example-flag{font-size:var(--text-xs);flex-shrink:0}.gd__tip{gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-xl);background:linear-gradient(135deg,#f59e0b14 0%,#f59e0b08 100%);border:1px solid #f59e0b2e;display:flex}.dark .gd__tip{background:linear-gradient(135deg,#f59e0b1a 0%,#f59e0b0a 100%);border-color:#f59e0b26}.gd__tip-icon{color:#f59e0b;flex-shrink:0;margin-top:1px}.gd__tip-text{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-relaxed);margin:0}@media (max-width:640px){.gd__hero{padding:var(--space-5)}.gd__hero-body{gap:var(--space-3);flex-direction:column}.gd__hero-icon{width:44px;height:44px}.gd__section{padding:var(--space-4)}.gd__table thead th,.gd__table tbody td{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}}.grammar-grid{gap:var(--space-3);grid-template-columns:1fr;display:grid}@media (min-width:640px){.grammar-grid{grid-template-columns:repeat(2,1fr)}}.grammar-card{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5) var(--space-4) calc(var(--space-5) + 8px);background:var(--color-surface);border-radius:var(--radius-2xl);color:inherit;transition:transform var(--duration-fast) var(--ease-bounce), background var(--duration-fast) var(--ease-default);text-decoration:none;display:flex;position:relative;overflow:hidden}.grammar-card:hover{background:var(--color-surface-container-low);transform:translateY(-2px)}.grammar-card__accent{border-radius:0;width:4px;position:absolute;top:0;bottom:0;left:0}.grammar-card__icon{border-radius:var(--radius-xl);width:44px;height:44px;transition:transform var(--duration-fast) var(--ease-bounce);flex-shrink:0;justify-content:center;align-items:center;display:flex}.grammar-card:hover .grammar-card__icon{transform:scale(1.08)rotate(-3deg)}.grammar-card__body{gap:var(--space-1-5,6px);flex-direction:column;flex:1;min-width:0;display:flex}.grammar-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);letter-spacing:-.01em;text-overflow:ellipsis;white-space:nowrap;margin:0;overflow:hidden}.grammar-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}.grammar-card__footer{align-items:center;gap:var(--space-2);margin-top:2px;display:flex}.grammar-card__level{border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-bold);letter-spacing:.03em;align-items:center;padding:2px 8px;display:inline-flex}.grammar-card__cat{font-size:11px;font-weight:var(--font-medium);color:var(--color-text-muted);background:var(--color-surface-container-high);border-radius:var(--radius-full);padding:2px 8px}.grammar-card__arrow{color:var(--color-text-muted);opacity:.4;transition:opacity var(--duration-fast) var(--ease-default), transform var(--duration-fast) var(--ease-bounce);flex-shrink:0}.grammar-card:hover .grammar-card__arrow{opacity:1;transform:translate(3px)}.trans-list-page{gap:var(--space-6);flex-direction:column;display:flex}.trans-list-page__header{justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.trans-list-page__hero{align-items:center;gap:var(--space-4);display:flex}.trans-list-page__hero-icon{filter:drop-shadow(0 4px 12px #3b82f640);flex-shrink:0;font-size:3rem}.trans-list-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}.trans-list-page__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0;line-height:var(--leading-vi)}.trans-summary{background:var(--color-surface);border-radius:var(--radius-2xl);align-items:stretch;display:flex;overflow:hidden}.trans-summary__item{align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-6);flex:1;display:flex}.trans-summary__icon{font-size:var(--text-2xl);flex-shrink:0}.trans-summary__value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-primary);line-height:1}.trans-summary__label{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:3px}.trans-summary__divider{background:var(--color-surface-container-high);flex-shrink:0;width:1px}.trans-how{align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-5);background:var(--color-surface);border-radius:var(--radius-2xl);flex-wrap:wrap;display:flex}.trans-how__step{align-items:center;gap:var(--space-3);flex:1;min-width:120px;display:flex}.trans-how__num{border-radius:var(--radius-full);background:var(--color-primary);width:28px;height:28px;color:var(--color-on-primary);font-size:var(--text-xs);font-weight:var(--font-extrabold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.trans-how__step strong{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text);display:block}.trans-how__step span{color:var(--color-text-muted);font-size:11px}.trans-how__arrow{font-size:var(--text-lg);color:var(--color-text-muted);flex-shrink:0}.trans-passages{gap:var(--space-3);flex-direction:column;display:flex}.trans-passage-card{align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-5) var(--space-5) calc(var(--space-5) + 8px);background:var(--color-surface);border-radius:var(--radius-2xl);color:inherit;transition:transform var(--duration-fast) var(--ease-bounce), background var(--duration-fast) var(--ease-default);text-decoration:none;display:flex;position:relative;overflow:hidden}.trans-passage-card:hover{background:var(--color-surface-container-low);transform:translate(4px)}.trans-passage-card__accent{width:4px;position:absolute;top:0;bottom:0;left:0}.trans-passage-card__body{gap:var(--space-2);flex-direction:column;flex:1;min-width:0;display:flex}.trans-passage-card__top{align-items:center;gap:var(--space-2);display:flex}.trans-passage-card__level{border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-bold);align-items:center;padding:2px 10px;display:inline-flex}.trans-passage-card__status{font-size:11px;font-weight:var(--font-semibold);color:var(--color-text-muted);background:var(--color-surface-container-high);border-radius:var(--radius-full);padding:2px 8px}.trans-passage-card__status--published{color:var(--color-primary);background:#4ade801f}.trans-passage-card__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);letter-spacing:-.01em;margin:0}.trans-passage-card__summary{font-size:var(--text-xs);color:var(--color-text-muted);line-height:var(--leading-relaxed);-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.trans-passage-card__meta{align-items:center;gap:var(--space-3);display:flex}.trans-passage-card__meta-item{color:var(--color-text-muted);align-items:center;gap:4px;font-size:11px;display:flex}.trans-passage-card__arrow{color:var(--color-text-muted);opacity:.4;transition:all var(--duration-fast) var(--ease-default);flex-shrink:0}.trans-passage-card:hover .trans-passage-card__arrow{opacity:1;transform:translate(3px)}.trans-page{gap:var(--space-8);flex-direction:column;display:flex}.trans-page__header{gap:var(--space-3);flex-direction:column;display:flex}.trans-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);width:fit-content;text-decoration:none;display:inline-flex}.trans-page__back:hover{color:var(--color-text)}.trans-page__meta-row{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.trans-page__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:3px 10px;display:inline-flex}.trans-page__meta-item{font-size:var(--text-xs);color:var(--color-text-muted);align-items:center;gap:4px;display:flex}.trans-page__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);letter-spacing:-.02em;color:var(--color-text);margin:0;line-height:1.2}.trans-page__summary{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi);font-style:italic}.trans-split{gap:var(--space-5);grid-template-columns:1fr 1fr;align-items:flex-start;display:grid}.trans-split__original,.trans-split__editor{background:var(--color-surface);border-radius:var(--radius-2xl);flex-direction:column;display:flex;overflow:hidden}.trans-split__panel-header{padding:var(--space-4) var(--space-5);background:var(--color-surface-container-low);justify-content:space-between;align-items:center;display:flex}.trans-split__panel-label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.trans-split__published-badge{font-size:11px;font-weight:var(--font-bold);color:var(--color-primary);border-radius:var(--radius-full);background:#4ade801f;padding:2px 8px}.trans-original-content{padding:var(--space-5);max-height:70vh;overflow-y:auto}.trans-original-content__para{font-size:var(--text-base);color:var(--color-text);margin-bottom:var(--space-4);line-height:1.9}.trans-original-content__para:last-child{margin-bottom:0}.trans-editor{gap:var(--space-4);padding:var(--space-5);flex-direction:column;display:flex}.trans-editor__header{gap:var(--space-1);flex-direction:column;display:flex}.trans-editor__title-row{justify-content:space-between;align-items:center;display:flex}.trans-editor__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin:0}.trans-editor__word-count{color:var(--color-text-muted);font-size:11px}.trans-editor__hint{font-size:var(--text-xs);color:var(--color-text-muted);line-height:var(--leading-relaxed)}.trans-editor__textarea{width:100%;min-height:400px;max-height:60vh;padding:var(--space-4);background:var(--color-surface-container-low);border-radius:var(--radius-xl);font-size:var(--text-base);font-family:var(--font-body);color:var(--color-text);resize:vertical;transition:border-color var(--duration-fast) var(--ease-default);border:2px solid #0000;outline:none;line-height:1.8}.trans-editor__textarea:focus{border-color:var(--color-primary)}.trans-editor__textarea::placeholder{color:var(--color-text-muted)}.trans-editor__error{padding:var(--space-3) var(--space-4);color:#ef4444;border-radius:var(--radius-lg);font-size:var(--text-sm);background:#ef444414}.trans-editor__published-notice{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);color:var(--color-primary);border-radius:var(--radius-lg);font-size:var(--text-sm);background:#4ade8014;display:flex}.trans-editor__actions{gap:var(--space-3);display:flex}.trans-editor__btn{align-items:center;gap:var(--space-2);padding:var(--space-2-5,10px) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);font-family:var(--font-body);border:none;display:inline-flex}.trans-editor__btn:disabled{opacity:.5;cursor:not-allowed}.trans-editor__btn--save{background:var(--color-surface-container-high);color:var(--color-text);flex:1;justify-content:center}.trans-editor__btn--save:hover:not(:disabled){background:var(--color-surface-container)}.trans-editor__btn--publish{background:var(--color-primary);color:var(--color-on-primary);flex:2;justify-content:center}.trans-editor__btn--publish:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.trans-community{gap:var(--space-4);flex-direction:column;display:flex}.trans-community__header{align-items:center;gap:var(--space-3);display:flex}.trans-community__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin:0}.trans-community__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 .trans-community__count{color:var(--color-primary);background:#4ade801f}.trans-community__hint{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi);margin:0}.trans-list{gap:var(--space-3);flex-direction:column;display:flex}.trans-card{background:var(--color-surface);border-radius:var(--radius-2xl);transition:transform var(--duration-fast) var(--ease-bounce);flex-direction:column;gap:0;display:flex;overflow:hidden}.trans-card:hover{transform:translateY(-2px)}.trans-card--own{background:#4ade800a}.trans-card__author{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-surface-container-low);display:flex}.trans-card__avatar{border-radius:var(--radius-full);background:var(--color-surface-container-high);width:28px;height:28px;color:var(--color-text-muted);flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.trans-card__author-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.trans-card__date{color:var(--color-text-muted);margin-left:auto;font-size:11px}.trans-card__content{padding:var(--space-5);font-size:var(--text-sm);color:var(--color-text);white-space:pre-wrap;max-height:200px;line-height:1.8;overflow-y:auto}.trans-card__footer{padding:var(--space-3) var(--space-5);background:var(--color-surface-container-low);align-items:center;display:flex}.trans-vote-btn{align-items:center;gap:var(--space-1-5,6px);padding:var(--space-1-5,6px) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted);background:var(--color-surface-container-high);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);font-family:var(--font-body);border:none;display:inline-flex}.trans-vote-btn:hover:not(.trans-vote-btn--disabled):not(:disabled){color:var(--color-primary);background:#4ade801f;transform:scale(1.05)}.trans-vote-btn--active{color:var(--color-primary);background:#4ade8026}.trans-vote-btn--disabled{cursor:default;opacity:.6}.trans-empty{align-items:center;gap:var(--space-3);padding:var(--space-10) var(--space-4);text-align:center;background:var(--color-surface);border-radius:var(--radius-2xl);flex-direction:column;display:flex}.trans-empty__icon{opacity:.5;font-size:3rem}.trans-empty__text{font-size:var(--text-sm);color:var(--color-text-muted);max-width:320px;line-height:var(--leading-vi)}@media (max-width:900px){.trans-split{grid-template-columns:1fr}.trans-original-content{max-height:300px}.trans-editor__textarea{min-height:250px}}@media (max-width:640px){.trans-list-page__title{font-size:var(--text-2xl)}.trans-how{gap:var(--space-1);padding:var(--space-3)}.trans-how__arrow{display:none}.trans-how__step{min-width:calc(50% - var(--space-1))}.trans-summary{flex-wrap:wrap}.trans-summary__item{min-width:100px;padding:var(--space-3) var(--space-4);flex:1}}.tc__toggle{align-items:center;gap:var(--space-1-5,6px);border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-semibold);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;padding:4px 10px;display:inline-flex}.tc__toggle:hover{color:var(--color-text);background:var(--color-surface-container)}.tc__body{padding:var(--space-4) var(--space-5);background:var(--color-surface-container-low);gap:var(--space-4);border-top:1px solid var(--color-surface-container-high);flex-direction:column;display:flex}.tc__context{font-size:var(--text-xs);color:var(--color-text-muted);margin:0}.tc__empty{font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;padding:var(--space-3)}.tc__list{gap:var(--space-3);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.tc__item{gap:var(--space-3);align-items:flex-start;display:flex}.tc__item--own .tc__bubble{background:#4ade800f}.tc__avatar{border-radius:var(--radius-full);background:var(--color-surface-container-high);width:28px;height:28px;color:var(--color-text-muted);flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.tc__bubble{background:var(--color-surface-container-high);border-radius:var(--radius-lg);min-width:0;padding:var(--space-3) var(--space-4);gap:var(--space-1);flex-direction:column;flex:1;display:flex}.tc__bubble-header{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.tc__author{font-size:11px;font-weight:var(--font-semibold);color:var(--color-text)}.tc__time{color:var(--color-text-muted);margin-left:auto;font-size:10px}.tc__delete{border-radius:var(--radius-full);width:20px;height:20px;color:var(--color-text-muted);cursor:pointer;opacity:0;transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.tc__bubble:hover .tc__delete{opacity:1}.tc__delete:hover{color:#ef4444;background:#ef44441f}.tc__text{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-relaxed);white-space:pre-wrap;word-break:break-word;margin:0}.tc__form{gap:var(--space-3);align-items:flex-start;display:flex}.tc__form-avatar{border-radius:var(--radius-full);background:var(--color-primary);width:28px;height:28px;color:var(--color-on-primary);flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;display:flex}.tc__form-main{gap:var(--space-2);flex-direction:column;flex:1;display:flex}.tc__input{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border-radius:var(--radius-xl);font-size:var(--text-sm);font-family:var(--font-body);color:var(--color-text);line-height:var(--leading-relaxed);resize:none;transition:border-color var(--duration-fast) var(--ease-default);border:2px solid #0000;outline:none}.tc__input:focus{border-color:var(--color-primary)}.tc__input::placeholder{color:var(--color-text-muted)}.tc__error{color:#ef4444;margin:0;font-size:11px}.tc__form-footer{align-items:center;gap:var(--space-3);display:flex}.tc__char-count{color:var(--color-text-muted);font-size:10px}.tc__shortcut{color:var(--color-text-muted);margin-left:auto;font-size:10px}.tc__submit{align-items:center;gap:var(--space-1-5,6px);border-radius:var(--radius-lg);font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-on-primary);background:var(--color-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);font-family:var(--font-body);border:none;padding:6px 14px;display:inline-flex}.tc__submit:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.tc__submit:disabled{opacity:.5;cursor:not-allowed}.tc__login-hint{font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;padding:var(--space-3);margin:0}.trans-card__footer{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);flex-wrap:wrap;display:flex}.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)}}.rv{flex-direction:column;gap:0;max-width:720px;margin:0 auto;display:flex}.rv__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);width:fit-content;margin-bottom:var(--space-6);text-decoration:none;display:inline-flex}.rv__back:hover{color:var(--color-text)}.rv__header{gap:var(--space-3);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-5);flex-direction:column;display:flex}.rv__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);letter-spacing:-.02em;color:var(--color-text);margin:0;line-height:1.2}@media (min-width:640px){.rv__title{font-size:var(--text-3xl)}}.rv__summary{font-size:var(--text-sm);color:var(--color-text-muted);font-style:italic;line-height:var(--leading-relaxed);padding-left:var(--space-3);border-left:2px solid #4ade804d;margin:0}.rv__section{margin-bottom:var(--space-5)}.rv__section--quiz{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-border);margin-bottom:0}.rv__tip{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);margin-bottom:var(--space-6);background:#4ade800a;border:1px solid #4ade801a;display:flex}.dark .rv__tip{background:#4ade800f;border-color:#4ade801f}.rv__tip-icon{font-size:var(--text-base);flex-shrink:0;line-height:1}.rv__tip-text{font-size:var(--text-xs);color:var(--color-text-muted);line-height:var(--leading-relaxed)}.rv__content-section{margin-bottom:var(--space-2)}.rv__content{font-size:var(--text-base);color:var(--color-text);line-height:2}@media (min-width:640px){.rv__content{font-size:var(--text-lg);line-height:2.2}}.rv__paragraph{margin:0 0 var(--space-5)}.rv__paragraph:last-child{margin-bottom:0}.rv__word{cursor:pointer;transition:all var(--duration-fast) var(--ease-default);border-radius:2px;margin:0 -2px;padding:0 2px}.rv__word:hover{color:var(--color-primary);background:#4ade801a}.rv__word:active{background:#4ade8033}.reading-audio{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-3) var(--space-4);transition:all var(--duration-normal) var(--ease-default)}.dark .reading-audio{background:var(--color-surface-container-low)}.reading-audio--playing{box-shadow:0 0 0 1px #3b82f633,0 2px 12px #3b82f60f}.reading-audio__row{align-items:center;gap:var(--space-2-5,10px);display:flex}.reading-audio__btn{border-radius:var(--radius-full);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);font-family:var(--font-body);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.reading-audio__btn--play{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#6366f1 100%);width:36px;height:36px;box-shadow:0 2px 10px #3b82f633}.reading-audio__btn--play:hover{transform:scale(1.08);box-shadow:0 4px 16px #3b82f64d}.reading-audio__btn--pause{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#ef4444 100%);width:36px;height:36px;box-shadow:0 2px 10px #f59e0b33}.reading-audio__btn--pause:hover{transform:scale(1.08)}.reading-audio__btn--stop{background:var(--color-surface-container-high);width:28px;height:28px;color:var(--color-text-muted)}.reading-audio__btn--stop:hover{color:#ef4444;background:#ef44441f}.reading-audio__label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);white-space:nowrap;flex-shrink:0}.reading-audio__progress{background:var(--color-surface-container-high);border-radius:var(--radius-full);flex:1;min-width:40px;height:4px;overflow:hidden}.reading-audio__progress-fill{border-radius:var(--radius-full);background:linear-gradient(90deg,#3b82f6 0%,#8b5cf6 100%);height:100%;transition:width .2s linear}.reading-audio__speed{background:var(--color-surface-container-high);border-radius:var(--radius-full);flex-shrink:0;gap:1px;padding:2px;display:flex}.reading-audio__speed-btn{border-radius:var(--radius-full);font-size:10px;font-weight:var(--font-semibold);color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);font-family:var(--font-body);background:0 0;border:none;padding:3px 8px}.reading-audio__speed-btn:hover{color:var(--color-text)}.reading-audio__speed-btn--active{background:var(--color-surface);color:var(--color-text);box-shadow:0 1px 3px #00000014}@media (max-width:480px){.reading-audio__row{gap:var(--space-2);flex-wrap:wrap}.reading-audio__progress{flex-basis:100%;order:10;min-width:0;margin-top:2px}.reading-audio__speed{order:5;margin-left:auto}.reading-audio__label{font-size:var(--text-xs)}}.reading-quiz{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-6);gap:var(--space-5);flex-direction:column;display:flex}.reading-quiz__header{justify-content:space-between;align-items:center;display:flex}.reading-quiz__header-left{align-items:center;gap:var(--space-2);color:var(--color-text);display:flex}.reading-quiz__header-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);letter-spacing:-.01em}.reading-quiz__counter{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}.reading-quiz__progress{align-items:center;gap:6px;display:flex}.reading-quiz__dot{border-radius:var(--radius-full);background:var(--color-surface-container-high);width:10px;height:10px;transition:all var(--duration-fast) var(--ease-bounce)}.reading-quiz__dot--current{background:var(--color-primary);transform:scale(1.3);box-shadow:0 0 8px #4ade8066}.reading-quiz__dot--correct{background:#22c55e}.reading-quiz__dot--wrong{background:#ef4444}.reading-quiz__question{gap:var(--space-2);animation:quiz-slide-in .3s var(--ease-bounce);flex-direction:column;display:flex}@keyframes quiz-slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.reading-quiz__question-de{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);line-height:var(--leading-relaxed);margin:0}.reading-quiz__question-vi{font-size:var(--text-sm);color:var(--color-text-muted);margin:0;font-style:italic}.reading-quiz__options{gap:var(--space-2);flex-direction:column;display:flex}.reading-quiz__option{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface-container-low);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text);text-align:left;border:2px solid #0000;width:100%;display:flex}.reading-quiz__option:hover:not(:disabled):not(.reading-quiz__option--correct):not(.reading-quiz__option--wrong):not(.reading-quiz__option--disabled){border-color:var(--color-primary);background:#4ade800a;transform:translate(4px)}.reading-quiz__option-label{border-radius:var(--radius-full);background:var(--color-surface-container-high);width:28px;height:28px;font-size:var(--text-xs);font-weight:var(--font-extrabold);color:var(--color-text-muted);transition:all var(--duration-fast) var(--ease-default);flex-shrink:0;justify-content:center;align-items:center;display:flex}.reading-quiz__option:hover:not(:disabled) .reading-quiz__option-label{background:var(--color-primary);color:var(--color-on-primary)}.reading-quiz__option-text{flex:1}.reading-quiz__option-icon{flex-shrink:0}.reading-quiz__option--correct{cursor:default;background:#22c55e14;border-color:#22c55e}.reading-quiz__option--correct .reading-quiz__option-label{color:#fff;background:#22c55e}.reading-quiz__option--correct .reading-quiz__option-icon{color:#22c55e}.reading-quiz__option--wrong{cursor:default;background:#ef444414;border-color:#ef4444}.reading-quiz__option--wrong .reading-quiz__option-label{color:#fff;background:#ef4444}.reading-quiz__option--wrong .reading-quiz__option-icon{color:#ef4444}.reading-quiz__option--disabled{opacity:.5;cursor:default}.reading-quiz__explanation{gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-xl);font-size:var(--text-sm);line-height:var(--leading-relaxed);animation:quiz-slide-in .3s var(--ease-bounce);display:flex}.reading-quiz__explanation--correct{color:var(--color-text);background:#22c55e0f;border:1px solid #22c55e26}.reading-quiz__explanation--correct .reading-quiz__explanation-icon{color:#22c55e}.reading-quiz__explanation--wrong{color:var(--color-text);background:#ef44440f;border:1px solid #ef444426}.reading-quiz__explanation--wrong .reading-quiz__explanation-icon{color:#ef4444}.reading-quiz__explanation-icon{flex-shrink:0;margin-top:1px}.reading-quiz__explanation-content{line-height:var(--leading-relaxed)}.reading-quiz__actions{justify-content:flex-end;display:flex}.reading-quiz__btn{align-items:center;gap:var(--space-2);padding:var(--space-2-5,10px) 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-bounce);font-family:var(--font-body);border:none;display:inline-flex}.reading-quiz__btn--next{background:var(--color-primary);color:var(--color-on-primary);box-shadow:0 4px 16px #4ade8033}.reading-quiz__btn--next:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4ade804d}.reading-quiz__btn--retry{background:var(--color-surface-container-high);color:var(--color-text)}.reading-quiz__btn--retry:hover{background:var(--color-surface-container);transform:translateY(-1px)}.reading-quiz__result{align-items:center;gap:var(--space-4);text-align:center;padding:var(--space-4) 0;flex-direction:column;display:flex}.reading-quiz__result-circle{border-radius:var(--radius-full);border:3px solid var(--color-primary);background:linear-gradient(135deg,#4ade8014 0%,#3b82f60f 100%);flex-direction:column;justify-content:center;align-items:center;width:120px;height:120px;display:flex}.reading-quiz__result-emoji{font-size:2rem;line-height:1}.reading-quiz__result-score{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-extrabold);color:var(--color-text)}.reading-quiz__result-pct{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-primary)}.reading-quiz__result-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-extrabold);color:var(--color-text);margin:0}.reading-quiz__result-sub{font-size:var(--text-sm);color:var(--color-text-muted);max-width:300px;line-height:var(--leading-vi);margin:0}.reading-quiz__review{gap:var(--space-2);flex-direction:column;width:100%;max-width:280px;display:flex}.reading-quiz__review-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-sm);display:flex}.reading-quiz__review-item--correct{background:#22c55e0f}.reading-quiz__review-item--wrong{background:#ef44440f}.reading-quiz__review-num{font-weight:var(--font-semibold);color:var(--color-text);min-width:48px}.reading-quiz__review-label{font-size:var(--text-xs);color:var(--color-text-muted)}@media (max-width:640px){.reading-quiz{padding:var(--space-4);gap:var(--space-4)}.reading-quiz__question-de{font-size:var(--text-base)}.reading-quiz__option{padding:var(--space-2-5,10px) var(--space-3)}.reading-quiz__result-circle{width:100px;height:100px}}.prc{gap:var(--space-10);width:100%;max-width:1100px;padding-bottom:var(--space-12);flex-direction:column;margin:0 auto;display:flex}.prc__header{text-align:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.prc__badge{padding:5px var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);letter-spacing:.02em;background:linear-gradient(135deg,#4ade801f,#06b6d414);border:1px solid #4ade8033;align-items:center;display:inline-flex}.prc__title{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:var(--font-extrabold);letter-spacing:-.03em;color:var(--color-text);margin:0;line-height:1.15}.prc__sub{font-size:var(--text-base);color:var(--color-text-muted);max-width:460px;line-height:var(--leading-vi);margin:0}.prc__grid{gap:var(--space-5);grid-template-columns:repeat(4,1fr);display:grid}.prc-card{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-6);border:1.5px solid var(--color-border);transition:all var(--duration-normal) var(--ease-default);flex-direction:column;align-items:center;display:flex;position:relative}.prc-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.prc-card--popular{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f626,0 8px 32px #3b82f61a}.prc-card--popular:hover{box-shadow:0 0 0 1px #3b82f640,0 12px 40px #3b82f626}.prc-card--current{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary-glow)}.prc-card__ribbon{color:#fff;padding:4px var(--space-4);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);white-space:nowrap;letter-spacing:.02em;background:linear-gradient(135deg,#3b82f6,#2563eb);position:absolute;top:-1px;left:50%;transform:translate(-50%)translateY(-50%);box-shadow:0 2px 8px #3b82f64d}.prc-card__current-badge{top:var(--space-3);right:var(--space-3);background:var(--color-primary);color:#fff;padding:3px var(--space-3);border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-bold);align-items:center;gap:4px;display:flex;position:absolute}.prc-card__current-icon{width:12px;height:12px}.prc-card__icon{border-radius:var(--radius-xl);width:56px;height:56px;margin-bottom:var(--space-4);justify-content:center;align-items:center;display:flex}.prc-card__icon--free{background:linear-gradient(135deg,#f3f4f6,#e5e7eb)}.prc-card__icon--basic{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.prc-card__icon--premium{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.prc-card__icon--lifetime{background:linear-gradient(135deg,#fef3c7,#fde68a)}.dark .prc-card__icon--free{background:linear-gradient(135deg,#1f2937,#374151)}.dark .prc-card__icon--basic{background:linear-gradient(135deg,#1e3a5f,#1e40af33)}.dark .prc-card__icon--premium{background:linear-gradient(135deg,#2e1065,#4c1d9533)}.dark .prc-card__icon--lifetime{background:linear-gradient(135deg,#451a03,#78350f33)}.prc-card__icon-svg{width:24px;height:24px}.prc-card--free .prc-card__icon-svg{color:var(--color-text-muted)}.prc-card--basic .prc-card__icon-svg{color:#3b82f6}.prc-card--premium .prc-card__icon-svg{color:#7c3aed}.prc-card--lifetime .prc-card__icon-svg{color:#d97706}.prc-card__name{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)}.prc-card__desc{font-size:var(--text-sm);color:var(--color-text-muted);margin:0 0 var(--space-4)}.prc-card__price{align-items:baseline;gap:var(--space-1);margin-bottom:var(--space-4);display:flex}.prc-card__amount{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.02em;line-height:1}.prc-card__period{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--font-medium)}.prc-card__divider{background:var(--color-border-muted);width:100%;height:1px;margin-bottom:var(--space-4)}.prc-card__features{flex-direction:column;flex:1;gap:10px;width:100%;margin:0;padding:0;list-style:none;display:flex}.prc-card__feature{align-items:flex-start;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text);line-height:1.4;display:flex}.prc-card__feature--disabled{color:var(--color-text-subtle)}.prc-card__feature--highlight{font-weight:var(--font-semibold);color:var(--color-primary)}.prc-card__feature--note{color:var(--color-text-muted);font-style:italic}.prc-card__info{border-radius:var(--radius-full);color:#3b82f6;width:16px;height:16px;font-size:11px;font-weight:var(--font-bold);background:#3b82f61f;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-style:normal;display:inline-flex}.prc-card__check{width:16px;height:16px;color:var(--color-success);flex-shrink:0;margin-top:1px}.prc-card__x{width:16px;height:16px;color:var(--color-text-subtle);opacity:.5;flex-shrink:0;margin-top:1px}.prc-card__cta{width:100%;margin-top:var(--space-5)}.prc-card__btn{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:11px var(--space-4);border-radius:var(--radius-xl);font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-bold);cursor:pointer;transition:all var(--duration-fast) var(--ease-bounce);border:none;text-decoration:none;display:flex}.prc-card__btn--current{background:var(--color-surface-container-high);color:var(--color-text-muted);cursor:default}.prc-card__btn--free{background:var(--color-surface-container-low);color:var(--color-text-muted);cursor:default}.prc-card__btn--basic{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 12px #3b82f64d}.prc-card__btn--basic:hover{transform:translateY(-2px);box-shadow:0 4px 20px #3b82f666}.prc-card__btn--premium{color:#fff;background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 2px 12px #7c3aed4d}.prc-card__btn--premium:hover{transform:translateY(-2px);box-shadow:0 4px 20px #7c3aed66}.prc-card__btn--lifetime{color:#fff;background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 2px 12px #d977064d}.prc-card__btn--lifetime:hover{transform:translateY(-2px);box-shadow:0 4px 20px #d9770666}.prc-card__btn-arrow{width:16px;height:16px;transition:transform var(--duration-fast) var(--ease-default)}.prc-card__btn:hover .prc-card__btn-arrow{transform:translate(3px)}.prc-compare{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-6);overflow:hidden}.prc-compare__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-5)}.prc-compare__table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.prc-compare__table{border-collapse:collapse;text-align:center;width:100%;font-size:var(--text-sm)}.prc-compare__th{padding:var(--space-3) var(--space-4);font-weight:var(--font-bold);color:var(--color-text);border-bottom:2px solid var(--color-border-muted);white-space:nowrap;font-family:var(--font-display)}.prc-compare__th--feature{text-align:left;min-width:140px}.prc-compare__th--highlight{color:#3b82f6;background:#3b82f60f;border-bottom-color:#3b82f6}.dark .prc-compare__th--highlight{color:#60a5fa;background:#3b82f614}.prc-compare__row:nth-child(2n){background:var(--color-surface-container-low)}.prc-compare__td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-muted);vertical-align:middle}.prc-compare__td--feature{text-align:left;font-weight:var(--font-medium);color:var(--color-text)}.prc-compare__td--highlight{background:#3b82f60a}.dark .prc-compare__td--highlight{background:#3b82f60f}.prc-compare__icon{width:18px;height:18px;margin:0 auto}.prc-compare__icon--yes{color:var(--color-success)}.prc-compare__icon--no{color:var(--color-text-subtle);opacity:.5}.prc-compare__text{font-weight:var(--font-semibold);color:var(--color-text);font-size:var(--text-xs)}.prc-payment{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-8);gap:var(--space-6);flex-direction:column;display:flex}.prc-payment__header{align-items:center;gap:var(--space-3);display:flex}.prc-payment__header-icon{width:28px;height:28px;color:var(--color-primary);flex-shrink:0}.prc-payment__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin:0}.prc-payment__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:2px 0 0}.prc-payment__steps{gap:var(--space-5);grid-template-columns:repeat(3,1fr);display:grid}.prc-step{gap:var(--space-3);flex-direction:column;display:flex}.prc-step__number{background:var(--color-primary);color:#fff;width:36px;height:36px;font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-extrabold);box-shadow:var(--shadow-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.prc-step__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin:0}.prc-step__body{background:var(--color-surface-container-low);border-radius:var(--radius-xl);padding:var(--space-4);gap:var(--space-2);flex-direction:column;flex:1;display:flex}.prc-step__qr{align-items:center;gap:var(--space-2);padding:var(--space-3);margin-bottom:var(--space-2);border-radius:var(--radius-lg);border:1px solid var(--color-border-muted);background:#fff;flex-direction:column;display:flex}.prc-step__qr-img{border-radius:var(--radius-md);object-fit:contain}.prc-step__qr-label{color:var(--color-text-muted);font-size:11px;font-weight:var(--font-medium)}.prc-step__row{font-size:var(--text-sm);color:var(--color-text);padding:var(--space-1) 0;justify-content:space-between;align-items:center;display:flex}.prc-step__row+.prc-step__row{border-top:1px solid var(--color-border-muted)}.prc-step__label{color:var(--color-text-muted);font-size:var(--text-sm)}.prc-step__mono{font-family:var(--font-mono);letter-spacing:.05em}.prc-step__transfer-note{margin-top:var(--space-2);padding-top:var(--space-3);border-top:1px solid var(--color-border-muted);gap:var(--space-2);flex-direction:column;display:flex}.prc-step__code{background:var(--color-surface-container-high);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-primary);word-break:break-all;display:block}.prc-step__text{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-vi);margin:0}.prc-step__text--muted{color:var(--color-text-muted)}.prc-step__contact{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text);display:flex}.prc-step__contact-icon{color:#3b82f6;flex-shrink:0;width:16px;height:16px}.prc-step__time{align-items:center;gap:var(--space-2);margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border-muted);font-size:var(--text-xs);color:var(--color-text-muted);display:flex}.prc-step__time-icon{flex-shrink:0;width:14px;height:14px}.prc-payment__note{border-radius:var(--radius-xl);padding:var(--space-4) var(--space-5);background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fde68a}.dark .prc-payment__note{background:#d9770614;border-color:#d9770633}.prc-payment__note-header{align-items:center;gap:var(--space-2);font-weight:var(--font-bold);font-size:var(--text-sm);color:#92400e;margin-bottom:var(--space-3);display:flex}.dark .prc-payment__note-header{color:#fbbf24}.prc-payment__note-icon{flex-shrink:0;width:18px;height:18px}.prc-payment__note-list{padding:0 0 0 var(--space-4);gap:var(--space-2);font-size:var(--text-sm);color:#78350f;line-height:var(--leading-vi);flex-direction:column;margin:0;display:flex}.dark .prc-payment__note-list{color:#fcd34d}.prc-referral{background:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-8);gap:var(--space-6);background-image:linear-gradient(var(--color-surface), var(--color-surface)), linear-gradient(135deg, #4ade804d, #fbbf244d);background-origin:border-box;background-clip:padding-box,border-box;border:1.5px solid #0000;flex-direction:column;display:flex}.prc-referral__header{align-items:center;gap:var(--space-4);display:flex}.prc-referral__icon-wrap{border-radius:var(--radius-xl);background:linear-gradient(135deg,#f0fdf4,#fef3c7);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.dark .prc-referral__icon-wrap{background:linear-gradient(135deg,#4ade8026,#fbbf2426)}.prc-referral__icon{color:#d97706;width:24px;height:24px}.prc-referral__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin:0}.prc-referral__sub{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi);margin:2px 0 0}.prc-referral__highlight{justify-content:center;align-items:center;gap:var(--space-6);padding:var(--space-5) var(--space-6);border-radius:var(--radius-xl);background:linear-gradient(135deg,#4ade8014,#fbbf2414);display:flex}.prc-referral__highlight-item{text-align:center;flex-direction:column;align-items:center;gap:4px;display:flex}.prc-referral__highlight-value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-primary);line-height:1}.prc-referral__highlight-label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:var(--font-medium);max-width:140px;line-height:1.4}.prc-referral__highlight-sep{background:var(--color-border-muted);flex-shrink:0;width:1px;height:48px}.prc-referral__steps{gap:var(--space-4);flex-direction:column;display:flex}.prc-referral__steps-title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin:0}.prc-referral__steps-grid{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.prc-referral__step{gap:var(--space-3);align-items:flex-start;display:flex}.prc-referral__step-num{background:linear-gradient(135deg, var(--color-primary), #06b6d4);color:#fff;width:28px;height:28px;font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-extrabold);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.prc-referral__step-content{flex-direction:column;gap:4px;display:flex}.prc-referral__step-content strong{font-size:var(--text-sm);color:var(--color-text)}.prc-referral__step-content p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi);margin:0}.prc-referral__table-wrap{gap:var(--space-3);flex-direction:column;display:flex}.prc-referral__table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.prc-referral__th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-bold);font-family:var(--font-display);color:var(--color-text);border-bottom:2px solid var(--color-border-muted);white-space:nowrap}.prc-referral__th--green{color:var(--color-primary);border-bottom-color:var(--color-primary);background:#4ade800f}.dark .prc-referral__th--green{background:#4ade8014}.prc-referral__row:nth-child(2n){background:var(--color-surface-container-low)}.prc-referral__td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-muted);color:var(--color-text)}.prc-referral__td--plan{font-weight:var(--font-semibold)}.prc-referral__td--green{color:var(--color-primary);font-weight:var(--font-bold);background:#4ade800a}.dark .prc-referral__td--green{background:#4ade800f}.prc-referral__notes{gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--color-border-muted);flex-direction:column;display:flex}.prc-referral__note-item{align-items:flex-start;gap:var(--space-3);font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi);display:flex}.prc-referral__note-item strong{color:var(--color-text)}.prc-referral__note-icon{width:18px;height:18px;color:var(--color-primary);flex-shrink:0;margin-top:2px}.prc-faq{gap:var(--space-5);flex-direction:column;display:flex}.prc-faq__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin:0}.prc-faq__grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.prc-faq__item{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-5);transition:box-shadow var(--duration-fast) var(--ease-default)}.prc-faq__item:hover{box-shadow:var(--shadow-md)}.prc-faq__q{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-2);line-height:1.4}.prc-faq__a{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi);margin:0}.prc__footer{text-align:center;padding-top:var(--space-4)}.prc__back{align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-default);text-decoration:none;display:inline-flex}.prc__back:hover{color:var(--color-primary)}@media (max-width:1024px){.prc__grid{grid-template-columns:repeat(2,1fr)}.prc-payment__steps,.prc-referral__steps-grid{grid-template-columns:1fr}}@media (max-width:640px){.prc__header{gap:var(--space-2)}.prc__title{font-size:var(--text-2xl)}.prc__sub{font-size:var(--text-sm)}.prc__grid{gap:var(--space-4);grid-template-columns:1fr}.prc-card{padding:var(--space-5)}.prc-card__amount{font-size:var(--text-2xl)}.prc-compare{padding:var(--space-4)}.prc-compare__table{font-size:var(--text-xs)}.prc-compare__th,.prc-compare__td{padding:var(--space-2) var(--space-3)}.prc-payment{padding:var(--space-5)}.prc-faq__grid{grid-template-columns:1fr}.prc-referral{padding:var(--space-5)}.prc-referral__highlight{gap:var(--space-4);padding:var(--space-4);flex-direction:column}.prc-referral__highlight-sep{width:60px;height:1px}.prc-referral__highlight-value{font-size:var(--text-2xl)}.prc-referral__table{font-size:var(--text-xs)}.prc-referral__th,.prc-referral__td{padding:var(--space-2) var(--space-3)}}.ref-section{gap:var(--space-5);flex-direction:column;display:flex}.ref-section--loading{align-items:center;gap:var(--space-3);padding:var(--space-6);color:var(--color-text-muted);font-size:var(--text-sm);display:flex}.ref-section__spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.ref-section__header{align-items:center;gap:var(--space-3);display:flex}.ref-section__header-icon{color:#d97706;flex-shrink:0;width:22px;height:22px}.ref-section__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin:0}.ref-section__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin:2px 0 0}.ref-code{background:var(--color-surface-container-low);border-radius:var(--radius-xl);padding:var(--space-4);gap:var(--space-3);flex-direction:column;display:flex}.ref-code__label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:.05em}.ref-code__row{align-items:center;gap:var(--space-2);display:flex}.ref-code__value{font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-primary);letter-spacing:.15em;padding:var(--space-2) var(--space-4);background:var(--color-surface);border:2px dashed var(--color-primary-glow);border-radius:var(--radius-lg);text-align:center;flex:1}.ref-code__copy{border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;width:44px;height:44px;transition:all var(--duration-fast) var(--ease-default);flex-shrink:0;justify-content:center;align-items:center;display:flex}.ref-code__copy:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.ref-code__copy-icon{width:18px;height:18px}.ref-code__link-btn{cursor:pointer;font-size:var(--text-sm);color:var(--color-primary);font-weight:var(--font-medium);text-align:left;transition:opacity var(--duration-fast);background:0 0;border:none;padding:0}.ref-code__link-btn:hover{opacity:.8}.ref-stats{gap:var(--space-3);grid-template-columns:repeat(3,1fr);display:grid}.ref-stats__item{align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-surface-container-low);border-radius:var(--radius-lg);display:flex}.ref-stats__icon{flex-shrink:0;width:20px;height:20px}.ref-stats__icon--blue{color:#3b82f6}.ref-stats__icon--amber{color:#d97706}.ref-stats__icon--green{color:var(--color-success)}.ref-stats__item>div{flex-direction:column;display:flex}.ref-stats__value{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text)}.ref-stats__label{font-size:var(--text-xs);color:var(--color-text-muted)}.ref-rates{gap:var(--space-3);flex-direction:column;display:flex}.ref-rates__title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text);margin:0}.ref-rates__grid{gap:var(--space-3);grid-template-columns:repeat(3,1fr);display:grid}.ref-rates__item{padding:var(--space-3);background:var(--color-surface-container-low);border-radius:var(--radius-lg);text-align:center;flex-direction:column;align-items:center;gap:4px;display:flex}.ref-rates__plan{font-size:var(--text-xs);font-weight:var(--font-bold);padding:2px var(--space-2);border-radius:var(--radius-sm)}.ref-rates__plan--basic{color:#1d4ed8;background:#dbeafe}.ref-rates__plan--premium{color:#6d28d9;background:#ede9fe}.ref-rates__plan--lifetime{color:#b45309;background:#fef3c7}.dark .ref-rates__plan--basic{color:#60a5fa;background:#3b82f626}.dark .ref-rates__plan--premium{color:#a78bfa;background:#7c3aed26}.dark .ref-rates__plan--lifetime{color:#fbbf24;background:#d9770626}.ref-rates__percent{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-extrabold);color:var(--color-primary)}.ref-rates__amount{font-size:var(--text-xs);color:var(--color-text-muted)}.ref-calc{background:var(--color-surface-container-low);border-radius:var(--radius-xl);padding:var(--space-4);gap:var(--space-3);flex-direction:column;display:flex}.ref-calc__title{align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text);margin:0;display:flex}.ref-calc__title-icon{width:16px;height:16px;color:var(--color-primary)}.ref-calc__sub{font-size:var(--text-xs);color:var(--color-text-muted);margin:0}.ref-calc__inputs{gap:var(--space-2);flex-direction:column;display:flex}.ref-calc__input-group{align-items:center;gap:var(--space-2);grid-template-columns:70px 60px 1fr;display:grid}.ref-calc__label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.ref-calc__input{width:100%;padding:var(--space-1) var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);text-align:center;background:var(--color-surface);color:var(--color-text)}.ref-calc__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-glow);outline:none}.ref-calc__result{font-size:var(--text-sm);color:var(--color-primary);font-weight:var(--font-semibold)}.ref-calc__total{padding-top:var(--space-3);border-top:1px solid var(--color-border-muted);font-size:var(--text-sm);color:var(--color-text-muted);justify-content:space-between;align-items:center;display:flex}.ref-calc__total-value{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-primary)}.ref-history{gap:var(--space-3);flex-direction:column;display:flex}.ref-history__title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text);margin:0}.ref-history__list{gap:var(--space-2);flex-direction:column;display:flex}.ref-history__item{padding:var(--space-3);background:var(--color-surface-container-low);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.ref-history__info{flex-direction:column;min-width:0;display:flex}.ref-history__email{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ref-history__date{font-size:var(--text-xs);color:var(--color-text-muted)}.ref-history__details{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.ref-history__amount{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-primary);white-space:nowrap}.ref-badge{padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:11px;font-weight:var(--font-bold);white-space:nowrap;display:inline-flex}.ref-badge--pending{color:#92400e;background:#fef3c7}.ref-badge--approved{color:#1d4ed8;background:#dbeafe}.ref-badge--paid{color:#166534;background:#dcfce7}.ref-badge--rejected{color:#991b1b;background:#fee2e2}.ref-badge--plan-basic{color:#1d4ed8;background:#dbeafe}.ref-badge--plan-premium{color:#6d28d9;background:#ede9fe}.ref-badge--plan-lifetime{color:#b45309;background:#fef3c7}.dark .ref-badge--pending{color:#fbbf24;background:#d9770626}.dark .ref-badge--approved{color:#60a5fa;background:#3b82f626}.dark .ref-badge--paid{color:#86efac;background:#16a34a26}.dark .ref-badge--rejected{color:#f87171;background:#ef444426}.dark .ref-badge--plan-basic{color:#60a5fa;background:#3b82f626}.dark .ref-badge--plan-premium{color:#a78bfa;background:#7c3aed26}.dark .ref-badge--plan-lifetime{color:#fbbf24;background:#d9770626}@media (max-width:640px){.ref-stats,.ref-rates__grid{grid-template-columns:1fr}.ref-code__value{font-size:var(--text-lg)}.ref-calc__input-group{grid-template-columns:60px 50px 1fr}}.ref-terms{gap:var(--space-2);padding-top:var(--space-3);border-top:1px solid var(--color-border-muted);flex-direction:column;display:flex}.ref-terms__list{padding-left:var(--space-5);gap:var(--space-1);flex-direction:column;margin:0;display:flex}.ref-terms__list li{font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.6}.ref-terms__list li strong{color:var(--color-text);font-weight:var(--font-semibold)}.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}}
