.admin-logo{align-items:center;gap:var(--space-3);display:flex}.admin-logo__icon{width:24px;height:24px;color:var(--color-error);flex-shrink:0}.admin-logo__text{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text)}.sidebar__link--active-admin{color:var(--color-error);font-weight:var(--font-semibold);background-color:#fef2f2}.sidebar__link--active-admin:hover{color:var(--color-error);background-color:#fee2e2}.admin-layout{min-height:100vh;display:flex}.admin-main{margin-left:var(--sidebar-width);background-color:var(--color-bg-subtle);flex-direction:column;flex:1;min-height:100vh;display:flex}.admin-topbar{height:var(--header-height);padding:0 var(--space-8);background-color:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:var(--z-raised);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.admin-content{padding:var(--space-8);flex:1}.admin-topbar__spacer{flex:1}.admin-topbar__title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted)}.admin-section{gap:var(--space-6);max-width:var(--content-max);flex-direction:column;display:flex}.admin-header{gap:var(--space-1);margin-bottom:var(--space-2);flex-direction:column;display:flex}.admin-header__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.02em;line-height:var(--leading-tight);margin:0}.admin-header__subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.admin-page-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.admin-page-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text);margin-bottom:var(--space-6)}.admin-filter{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.admin-filter__search{flex:1;min-width:200px;max-width:360px;position:relative}.admin-filter__search-icon{width:16px;height:16px;color:var(--color-text-subtle);pointer-events:none;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.admin-select{appearance:none;height:40px;padding:0 var(--space-8) 0 var(--space-3);font-family:inherit;font-size:var(--text-sm);color:var(--color-text);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--duration-fast) var(--ease-default), box-shadow var(--duration-fast) var(--ease-default);background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.25em 1.25em}.admin-select:hover{border-color:var(--color-primary-200)}.admin-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow);outline:none}.dark .admin-select{background-color:var(--color-surface-container-low);border-color:var(--color-border);color:var(--color-text);background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%238fa99a' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e")}.admin-stats{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.admin-stat{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);transition:box-shadow var(--duration-fast) var(--ease-default), transform var(--duration-fast) var(--ease-default)}.admin-stat:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.admin-stat__header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.admin-stat__icon{border-radius:var(--radius-lg);background-color:var(--color-primary-100);width:36px;height:36px;color:var(--color-primary);justify-content:center;align-items:center;display:flex}.admin-stat__icon-wrap{border-radius:var(--radius-xl);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.admin-stat__icon-wrap svg{width:20px;height:20px}.admin-stat__icon-wrap--blue{color:#2563eb;background-color:#dbeafe}.dark .admin-stat__icon-wrap--blue{color:#60a5fa;background-color:#2563eb26}.admin-stat__icon-wrap--green{color:#16a34a;background-color:#dcfce7}.dark .admin-stat__icon-wrap--green{color:#4ade80;background-color:#16a34a26}.admin-stat__icon-wrap--violet{color:#7c3aed;background-color:#ede9fe}.dark .admin-stat__icon-wrap--violet{color:#a78bfa;background-color:#7c3aed26}.admin-stat__icon-wrap--orange{color:#ea580c;background-color:#fff7ed}.dark .admin-stat__icon-wrap--orange{color:#fb923c;background-color:#ea580c26}.admin-stat__value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.03em;line-height:1}.admin-stat__label{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1);font-weight:var(--font-medium)}.admin-plans{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5) var(--space-6)}.admin-plans__header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);display:flex}.admin-plans__icon{color:#f59e0b;width:20px;height:20px}.admin-plans__title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text)}.admin-plans__grid{gap:var(--space-4);text-align:center;grid-template-columns:repeat(4,1fr);display:grid}.admin-plans__item-value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);line-height:var(--leading-tight);margin:0}.admin-plans__item-value--muted{color:var(--color-text-muted)}.admin-plans__item-value--blue{color:#2563eb}.admin-plans__item-value--violet{color:#7c3aed}.admin-plans__item-value--amber{color:#f59e0b}.admin-plans__item-label{font-size:var(--text-xs);color:var(--color-text-muted);margin:var(--space-1) 0 0;text-transform:uppercase;letter-spacing:.05em;font-weight:var(--font-semibold)}.admin-actions{align-items:center;gap:var(--space-1);display:flex}.admin-actions-bar{justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.admin-actions-bar__left{align-items:center;gap:var(--space-3);flex:1;min-width:0;display:flex}.admin-actions-bar__right{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.admin-pagination{padding-top:var(--space-4);border-top:1px solid var(--color-border-muted);justify-content:space-between;align-items:center;display:flex}.admin-pagination__info{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.admin-pagination__actions{align-items:center;gap:var(--space-2);display:flex}.admin-data-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.admin-data-card__header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-muted);justify-content:space-between;align-items:center;display:flex}.admin-data-card__title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text)}.admin-data-card__count{font-size:var(--text-sm);color:var(--color-text-muted)}.admin-form-grid{gap:var(--space-4);display:grid}.admin-form-grid--2{grid-template-columns:repeat(2,1fr)}.admin-form-grid--3{grid-template-columns:repeat(3,1fr)}.admin-form-grid--4{grid-template-columns:repeat(4,1fr)}.table__empty{text-align:center;color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-10) var(--space-4)!important}.admin-skeleton{gap:var(--space-6);flex-direction:column;display:flex}.admin-skeleton__header{justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.admin-skeleton__header-left{gap:var(--space-2);flex-direction:column;display:flex}.admin-skeleton__table{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.admin-skeleton__table-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);background-color:var(--color-bg-subtle)}.admin-skeleton__table-header-row{align-items:center;gap:var(--space-8);display:flex}.admin-skeleton__table-row{border-bottom:1px solid var(--color-border-muted)}.admin-skeleton__table-row:last-child{border-bottom:none}.admin-skeleton__table-row-inner{align-items:center;gap:var(--space-6);padding:var(--space-4) var(--space-6);display:flex}.admin-skeleton__table-actions{align-items:center;gap:var(--space-2);margin-left:auto;display:flex}.bulk-import__tabs{border-bottom:2px solid var(--color-border);margin-bottom:var(--space-4);display:flex}.bulk-import__tab{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);cursor:pointer;transition:color var(--duration-fast) var(--ease-default), border-color var(--duration-fast) var(--ease-default);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-2px}.bulk-import__tab:hover{color:var(--color-text)}.bulk-import__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:var(--font-semibold)}.bulk-import__textarea{width:100%;min-height:180px;padding:var(--space-3) var(--space-4);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);resize:vertical;line-height:var(--leading-relaxed);transition:border-color var(--duration-fast) var(--ease-default), box-shadow var(--duration-fast) var(--ease-default)}.bulk-import__textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow);outline:none}.bulk-import__textarea::placeholder{color:var(--color-text-subtle)}.dark .bulk-import__textarea{background-color:var(--color-surface-container-low)}.bulk-import__help{margin-top:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--color-bg-subtle);border-radius:var(--radius-lg);border:1px solid var(--color-border-muted)}.bulk-import__help-title{align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);margin-bottom:var(--space-2);display:flex}.bulk-import__help-code{font-size:var(--text-xs);color:var(--color-text-muted);white-space:pre-line;line-height:var(--leading-loose)}.bulk-import__download-link{align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-primary);cursor:pointer;padding:var(--space-1) 0;transition:opacity var(--duration-fast) var(--ease-default);background:0 0;border:none;display:inline-flex}.bulk-import__download-link:hover{opacity:.75;text-decoration:underline}.bulk-import__dropzone{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-8) var(--space-4);border:2px dashed 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}.bulk-import__dropzone:hover,.bulk-import__dropzone--active{border-color:var(--color-primary);background-color:var(--color-primary-50)}.bulk-import__dropzone-icon{width:32px;height:32px;color:var(--color-text-subtle)}.bulk-import__dropzone-text{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.bulk-import__dropzone-text strong{color:var(--color-primary)}.bulk-import__dropzone-hint{font-size:var(--text-xs);color:var(--color-text-subtle);margin:0}.bulk-import__file-info{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--color-bg-subtle);border:1px solid var(--color-border-muted);border-radius:var(--radius-lg);margin-top:var(--space-3);display:flex}.bulk-import__file-icon{width:20px;height:20px;color:var(--color-primary);flex-shrink:0}.bulk-import__file-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.bulk-import__file-size{font-size:var(--text-xs);color:var(--color-text-muted);flex-shrink:0}.bulk-import__file-remove{border-radius:var(--radius-md);width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.bulk-import__file-remove:hover{color:var(--color-error);background-color:#b0250014}.bulk-import__preview{margin-top:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.bulk-import__preview-header{padding:var(--space-3) var(--space-4);background-color:var(--color-bg-subtle);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.bulk-import__preview-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.bulk-import__preview-count{font-size:var(--text-xs);color:var(--color-primary);background:var(--color-primary-100);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-weight:var(--font-semibold)}.bulk-import__preview-table-wrap{max-height:280px;overflow-y:auto}.bulk-import__preview-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.bulk-import__preview-table th{padding:var(--space-2) var(--space-3);text-align:left;font-weight:var(--font-semibold);font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;background-color:var(--color-bg-subtle);border-bottom:1px solid var(--color-border);white-space:nowrap}.bulk-import__preview-table td{padding:var(--space-2) var(--space-3);color:var(--color-text);border-bottom:1px solid var(--color-border-muted);vertical-align:middle}.bulk-import__preview-table tbody tr:last-child td{border-bottom:none}.bulk-import__preview-table tbody tr:hover{background-color:var(--color-bg-subtle)}.bulk-import__options{margin-top:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--color-bg-subtle);border-radius:var(--radius-lg)}.bulk-import__checkbox-label{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;display:flex}.bulk-import__checkbox-label input[type=checkbox]{accent-color:var(--color-primary);width:16px;height:16px}.bulk-import__actions{justify-content:flex-end;align-items:center;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border-muted);display:flex}.bulk-import__progress{align-items:center;gap:var(--space-4);padding:var(--space-10) var(--space-4);text-align:center;flex-direction:column;display:flex}.bulk-import__progress-text{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.bulk-import__progress-bar{background-color:var(--color-bg-muted);border-radius:var(--radius-full);width:100%;max-width:300px;height:4px;overflow:hidden}.bulk-import__progress-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-primary-light));border-radius:var(--radius-full);height:100%}.bulk-import__result{align-items:center;gap:var(--space-4);padding:var(--space-6) var(--space-4);text-align:center;flex-direction:column;display:flex}.bulk-import__result-icon{border-radius:var(--radius-full);justify-content:center;align-items:center;width:56px;height:56px;display:flex}.bulk-import__result-icon svg{width:28px;height:28px}.bulk-import__result-icon--success{color:#16a34a;background-color:#dcfce7}.bulk-import__result-icon--error{color:#dc2626;background-color:#fef2f2}.bulk-import__result-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin:0}.bulk-import__result-stats{gap:var(--space-8);display:flex}.bulk-import__result-stat-value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);line-height:var(--leading-tight)}.bulk-import__result-stat-value--green{color:#16a34a}.bulk-import__result-stat-value--yellow{color:#d97706}.bulk-import__result-stat-value--red{color:#dc2626}.bulk-import__result-stat-label{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.bulk-import__result-errors{border-radius:var(--radius-lg);width:100%;max-height:140px;padding:var(--space-3);text-align:left;background-color:#fef2f2;border:1px solid #fecaca;overflow-y:auto}.dark .bulk-import__result-errors{background-color:#dc262614;border-color:#dc262633}.bulk-import__result-error-item{font-size:var(--text-xs);color:#b91c1c;padding:var(--space-1) 0}.dark .bulk-import__result-error-item{color:#fca5a5}.import-textarea{font-family:var(--font-mono);font-size:var(--text-sm);min-height:200px}.import-preview{border:1px solid var(--color-border);border-radius:var(--radius-lg);max-height:300px;overflow:hidden auto}.import-preview__row{gap:var(--space-4);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-muted);font-size:var(--text-sm);display:grid}.import-preview__row:last-child{border-bottom:none}.import-preview__row--header{background-color:var(--color-bg-subtle);font-weight:var(--font-semibold);color:var(--color-text-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em}.import-preview__row--error{background-color:#fef2f2}@media (max-width:1024px){.admin-main{margin-left:0}.admin-content{padding:var(--space-4)}.admin-stats{grid-template-columns:repeat(2,1fr)}.admin-page-header{gap:var(--space-3);flex-direction:column}.admin-filter{flex-direction:column;align-items:stretch}.admin-filter__search{max-width:100%}.admin-pagination{gap:var(--space-3);flex-direction:column;align-items:flex-start}.admin-plans__grid{grid-template-columns:repeat(2,1fr)}.admin-form-grid--2,.admin-form-grid--3,.admin-form-grid--4{grid-template-columns:1fr}}@media (max-width:640px){.admin-stats{grid-template-columns:1fr}.admin-plans__grid{grid-template-columns:repeat(2,1fr)}.bulk-import__result-stats{gap:var(--space-4)}}.admin-fb__toast{top:calc(var(--header-height) + var(--space-4));right:var(--space-6);padding:var(--space-3) var(--space-5);background:var(--color-surface);border:1px solid var(--color-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);z-index:1000;animation:.3s ease-out slideDown;position:fixed}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.admin-fb__tabs{gap:var(--space-1);background:var(--color-surface-container-low);border-radius:var(--radius-xl);padding:4px;display:flex}.admin-fb__tab{align-items:center;gap:var(--space-2);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);background:0 0;border:none;flex:1;justify-content:center;display:inline-flex}.admin-fb__tab:hover{color:var(--color-text);background:var(--color-surface)}.admin-fb__tab--active{background:var(--color-surface);color:var(--color-text);font-weight:var(--font-semibold);box-shadow:var(--shadow-sm)}.admin-fb__tab-count{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;min-width:20px;height:20px;font-size:11px;font-weight:var(--font-bold);justify-content:center;align-items:center;padding:0 6px;display:inline-flex}.admin-fb__filters{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.admin-fb__filter{padding:var(--space-1) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-full);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);background:0 0}.admin-fb__filter:hover{border-color:var(--color-primary);color:var(--color-primary)}.admin-fb__filter--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.admin-fb__search{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);flex:1;max-width:300px;display:flex}.admin-fb__search input{font-size:var(--text-sm);color:var(--color-text);background:0 0;border:none;outline:none;width:100%}.admin-fb__search svg{color:var(--color-text-subtle);flex-shrink:0}.admin-fb__toggle-hidden{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-text-muted);cursor:pointer;display:flex}.admin-fb__toggle-hidden input{accent-color:var(--color-primary)}.admin-fb__list{gap:var(--space-3);flex-direction:column;display:flex}.admin-fb__empty{align-items:center;gap:var(--space-2);padding:var(--space-10);color:var(--color-text-subtle);text-align:center;flex-direction:column;display:flex}.admin-fb__empty p{font-size:var(--text-sm);margin:0}.admin-fb__loading{text-align:center;padding:var(--space-10);color:var(--color-text-muted);font-size:var(--text-sm)}.admin-fb__report-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-4);gap:var(--space-3);transition:box-shadow var(--duration-fast) var(--ease-default);flex-direction:column;display:flex}.admin-fb__report-card:hover{box-shadow:var(--shadow-md)}.admin-fb__report-header{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.admin-fb__status{font-size:11px;font-weight:var(--font-bold);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;padding:2px 8px}.admin-fb__status--pending{color:#f59e0b;background:#f59e0b1f}.admin-fb__status--reviewed{color:#10b981;background:#10b9811f}.admin-fb__status--dismissed{color:#6b7280;background:#6b72801f}.admin-fb__report-reason{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.admin-fb__report-time{color:var(--color-text-subtle);margin-left:auto;font-size:11px}.admin-fb__report-meta{font-size:var(--text-sm);color:var(--color-text-muted);gap:var(--space-1);flex-direction:column;display:flex}.admin-fb__report-detail{color:var(--color-text-subtle);font-style:italic}.admin-fb__feedback-preview{padding:var(--space-3);background:var(--color-surface-container-low);border-radius:var(--radius-lg);border-left:3px solid var(--color-primary)}.admin-fb__feedback-author{align-items:center;gap:var(--space-2);font-size:var(--text-sm);margin-bottom:var(--space-1);display:flex}.admin-fb__feedback-type{color:var(--color-text-subtle);font-size:11px}.admin-fb__feedback-text{font-size:var(--text-sm);color:var(--color-text);line-height:var(--leading-vi);margin:0}.admin-fb__report-actions{gap:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border);display:flex}.admin-fb__action{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-xs);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);background:0 0;display:inline-flex}.admin-fb__action--approve{color:#10b981;border-color:#10b9814d}.admin-fb__action--approve:hover{background:#10b98114;border-color:#10b981}.admin-fb__action--dismiss{color:var(--color-text-muted)}.admin-fb__action--dismiss:hover{background:var(--color-surface-container-low);color:var(--color-text)}.admin-fb__action--toggle{color:#3b82f6;border-color:#3b82f64d}.admin-fb__action--toggle:hover{background:#3b82f614}.admin-fb__action--delete{color:#ef4444;border-color:#ef44444d}.admin-fb__action--delete:hover{background:#ef444414;border-color:#ef4444}.admin-fb__feedback-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-4);gap:var(--space-2);transition:box-shadow var(--duration-fast) var(--ease-default);flex-direction:column;display:flex}.admin-fb__feedback-card:hover{box-shadow:var(--shadow-md)}.admin-fb__feedback-card--hidden{opacity:.5;border-style:dashed}.admin-fb__feedback-header{align-items:center;gap:var(--space-2);font-size:var(--text-sm);flex-wrap:wrap;display:flex}.admin-fb__feedback-time{color:var(--color-text-subtle);margin-left:auto;font-size:11px}.admin-fb__hidden-badge{font-size:10px;font-weight:var(--font-bold);border-radius:var(--radius-full);color:#ef4444;background:#ef44441a;padding:1px 6px}.admin-fb__feedback-stats{font-size:var(--text-xs);color:var(--color-text-subtle)}.admin-fb__feedback-actions{gap:var(--space-2);padding-top:var(--space-2);display:flex}.admin-fb__pagination{justify-content:center;align-items:center;gap:var(--space-3);padding-top:var(--space-4);display:flex}.admin-fb__page-btn{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);justify-content:center;align-items:center;display:flex}.admin-fb__page-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.admin-fb__page-btn:disabled{opacity:.3;cursor:not-allowed}.admin-fb__page-info{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--font-medium)}.ea-alert{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);animation:ea-slideIn .3s var(--ease-default);display:flex}@keyframes ea-slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.ea-alert--success{color:#166534;background-color:#dcfce7;border:1px solid #bbf7d0}.ea-alert--error{color:#991b1b;background-color:#fef2f2;border:1px solid #fecaca}.ea-alert--warning{color:#854d0e;background-color:#fefce8;border:1px solid #fef08a}.dark .ea-alert--success{color:#4ade80;background-color:#16a34a1f;border-color:#16a34a40}.dark .ea-alert--error{color:#fca5a5;background-color:#ef44441f;border-color:#ef444440}.dark .ea-alert--warning{color:#fcd34d;background-color:#f59e0b1f;border-color:#f59e0b40}.ea-alert__close{font-size:var(--text-base);cursor:pointer;opacity:.5;color:inherit;transition:opacity var(--duration-fast);background:0 0;border:none}.ea-alert__close:hover{opacity:1}.ea-loading{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-16) 0;color:var(--color-text-muted);font-size:var(--text-sm);display:flex}.ea-loading__spinner{width:20px;height:20px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.ea-status-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.ea-status-card__header{justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-muted);flex-wrap:wrap;display:flex}.ea-status-card__info{align-items:center;gap:var(--space-4);display:flex}.ea-status-card__title{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin:0}.ea-status-card__config{padding:var(--space-5) var(--space-6);gap:var(--space-3);flex-direction:column;display:flex}.ea-status-badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.05em;display:inline-flex}.ea-status-badge--on{color:#166534;background-color:#dcfce7}.ea-status-badge--off{color:#6b7280;background-color:#f3f4f6}.dark .ea-status-badge--on{color:#4ade80;background-color:#16a34a26}.dark .ea-status-badge--off{color:#9ca3af;background-color:#6b728026}.ea-toggle-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) 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);border:none;display:inline-flex}.ea-toggle-btn--on{color:#fff;background-color:#16a34a}.ea-toggle-btn--on:hover{background-color:#15803d;transform:translateY(-1px);box-shadow:0 2px 8px #16a34a4d}.ea-toggle-btn--off{color:#6b7280;background-color:#f3f4f6;border:1px solid #e5e7eb}.ea-toggle-btn--off:hover{color:#374151;background-color:#e5e7eb}.dark .ea-toggle-btn--off{color:#9ca3af;background-color:#6b728026;border-color:#6b72804d}.ea-config-row{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.ea-config-row__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.ea-config-note{align-items:flex-start;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted);background-color:var(--color-bg-subtle);padding:var(--space-3);border-radius:var(--radius-md);display:flex}.ea-stats-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.ea-stat{align-items:flex-start;gap:var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);transition:box-shadow var(--duration-fast), transform var(--duration-fast);display:flex}.ea-stat:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.ea-stat__icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.ea-stat--total .ea-stat__icon{color:#2563eb;background-color:#dbeafe}.ea-stat--paid .ea-stat__icon{color:#16a34a;background-color:#dcfce7}.ea-stat--unpaid .ea-stat__icon{color:#d97706;background-color:#fef3c7}.ea-stat--breakdown .ea-stat__icon{color:#7c3aed;background-color:#ede9fe}.dark .ea-stat--total .ea-stat__icon{color:#60a5fa;background-color:#2563eb26}.dark .ea-stat--paid .ea-stat__icon{color:#4ade80;background-color:#16a34a26}.dark .ea-stat--unpaid .ea-stat__icon{color:#fbbf24;background-color:#d9770626}.dark .ea-stat--breakdown .ea-stat__icon{color:#a78bfa;background-color:#7c3aed26}.ea-stat__value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.02em;line-height:1}.ea-stat__label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:var(--font-medium);margin-top:var(--space-1)}.ea-breakdown{gap:var(--space-1);flex-wrap:wrap;display:flex}.ea-breakdown__item{font-size:var(--text-xs);font-weight:var(--font-semibold);padding:2px var(--space-2);border-radius:var(--radius-md)}.ea-breakdown__item--free{color:#6b7280;background:#f3f4f6}.ea-breakdown__item--basic{color:#2563eb;background:#dbeafe}.ea-breakdown__item--premium{color:#7c3aed;background:#ede9fe}.ea-breakdown__item--lifetime{color:#d97706;background:#fef3c7}.dark .ea-breakdown__item--free{color:#9ca3af;background:#6b728026}.dark .ea-breakdown__item--basic{color:#60a5fa;background:#2563eb26}.dark .ea-breakdown__item--premium{color:#a78bfa;background:#7c3aed26}.dark .ea-breakdown__item--lifetime{color:#fbbf24;background:#d9770626}.ea-breakdown__empty{font-size:var(--text-xs);color:var(--color-text-subtle);font-style:italic}.ea-downgrade-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);border-left:4px solid #ef4444}.ea-downgrade-card__header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.ea-downgrade-card__title{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin:0}.ea-downgrade-card__desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin:0 0 var(--space-4)}.ea-downgrade-card__actions{align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.ea-downgrade-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);color:#fff;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);background-color:#ef4444;border:none;display:inline-flex}.ea-downgrade-btn:hover:not(:disabled){background-color:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.ea-downgrade-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.ea-confirm-overlay{z-index:9999;padding:var(--space-4);background-color:#00000080;justify-content:center;align-items:center;animation:.2s ea-fadeIn;display:flex;position:fixed;inset:0}@keyframes ea-fadeIn{0%{opacity:0}to{opacity:1}}.ea-confirm-modal{background-color:var(--color-surface);border-radius:var(--radius-2xl);padding:var(--space-8);text-align:center;width:100%;max-width:420px;box-shadow:var(--shadow-2xl);animation:ea-scaleIn .25s var(--ease-spring)}@keyframes ea-scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.ea-confirm-modal__title{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-3)}.ea-confirm-modal__text{font-size:var(--text-sm);color:var(--color-text-muted);margin:0 0 var(--space-2);line-height:var(--leading-relaxed)}.ea-confirm-modal__actions{gap:var(--space-3);margin-top:var(--space-6);justify-content:center;display:flex}.ea-confirm-modal__btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);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);border:none;display:inline-flex}.ea-confirm-modal__btn--cancel{background-color:var(--color-bg-subtle);color:var(--color-text-muted);border:1px solid var(--color-border)}.ea-confirm-modal__btn--cancel:hover{background-color:var(--color-border-muted)}.ea-confirm-modal__btn--confirm{color:#fff;background-color:#ef4444}.ea-confirm-modal__btn--confirm:hover{background-color:#dc2626;box-shadow:0 2px 8px #ef44444d}.ea-downgrade-result{margin-top:var(--space-4);padding:var(--space-4);border-radius:var(--radius-lg);background-color:#f0fdf4;border:1px solid #bbf7d0}.dark .ea-downgrade-result{background-color:#16a34a14;border-color:#16a34a33}.ea-downgrade-result__title{font-size:var(--text-sm);font-weight:var(--font-bold);color:#166534;margin:0 0 var(--space-3)}.dark .ea-downgrade-result__title{color:#4ade80}.ea-downgrade-result__list{gap:var(--space-1);flex-direction:column;max-height:200px;display:flex;overflow-y:auto}.ea-downgrade-result__item{font-size:var(--text-xs);color:var(--color-text-muted);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);justify-content:space-between;display:flex}.ea-downgrade-result__item:nth-child(2n){background-color:#00000005}.dark .ea-downgrade-result__item:nth-child(2n){background-color:#ffffff05}.ea-downgrade-result__old{font-weight:var(--font-semibold);color:#d97706}.ea-downgrade-result__more{font-size:var(--text-xs);color:var(--color-text-subtle);text-align:center;padding-top:var(--space-2);font-style:italic}.ea-howto{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6)}.ea-howto__title{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-4)}.ea-howto__steps{gap:var(--space-4);flex-direction:column;display:flex}.ea-howto__step{gap:var(--space-4);align-items:flex-start;display:flex}.ea-howto__step-num{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-primary), var(--color-primary-700));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;display:flex}.ea-howto__step strong{font-size:var(--text-sm);color:var(--color-text);margin-bottom:var(--space-1);display:block}.ea-howto__step p{font-size:var(--text-xs);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin:0}@media (max-width:768px){.ea-stats-grid{grid-template-columns:1fr 1fr}.ea-status-card__header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.ea-downgrade-card__actions{flex-direction:column;align-items:flex-start}}@media (max-width:480px){.ea-stats-grid{grid-template-columns:1fr}}
.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--radius-full);width:24px;height:24px;animation:.7s linear infinite spin;display:inline-block}.spinner--sm{border-width:2px;width:16px;height:16px}.spinner--lg{border-width:4px;width:40px;height:40px}.loading-screen{justify-content:center;align-items:center;gap:var(--space-4);background-color:var(--color-bg);flex-direction:column;min-height:100vh;display:flex}.loading-screen__text{font-size:var(--text-base);color:var(--color-text-muted);animation:2s infinite pulse}.loading-section{padding:var(--space-16);justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.skeleton-line{background-color:var(--color-neutral-200);border-radius:var(--radius-md);background:linear-gradient(90deg, var(--color-neutral-100) 25%, var(--color-neutral-200) 50%, var(--color-neutral-100) 75%);background-size:200% 100%;height:16px;animation:1.5s infinite shimmer}.skeleton-line--sm{height:12px}.skeleton-line--lg{height:24px}.skeleton-line--short{width:40%}.skeleton-line--medium{width:65%}.skeleton-block{border-radius:var(--radius-xl);background:linear-gradient(90deg, var(--color-neutral-100) 25%, var(--color-neutral-200) 50%, var(--color-neutral-100) 75%);background-size:200% 100%;animation:1.5s infinite shimmer}.empty-state{padding:var(--space-16);text-align:center;justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.empty-state__icon{opacity:.4;font-size:3rem}.empty-state__title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text)}.empty-state__description{font-size:var(--text-base);color:var(--color-text-muted);max-width:360px;line-height:var(--leading-relaxed)}.error-page{justify-content:center;align-items:center;gap:var(--space-6);min-height:100vh;padding:var(--space-8);text-align:center;background-color:var(--color-bg);flex-direction:column;display:flex}.error-page__code{font-size:6rem;font-weight:var(--font-extrabold);color:var(--color-primary);line-height:1}.error-page__title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text)}.error-page__description{font-size:var(--text-base);color:var(--color-text-muted);max-width:480px;line-height:var(--leading-relaxed)}.error-page__actions{gap:var(--space-4);flex-wrap:wrap;justify-content:center;display:flex}.inline-error{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--color-error);background-color:#fef2f2;border:1px solid #fecaca;display:flex}.success-state{padding:var(--space-12);text-align:center;justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.success-state__icon{border-radius:var(--radius-full);background-color:var(--color-primary-100);width:64px;height:64px;color:var(--color-primary);animation:bounceIn .6s var(--ease-bounce);justify-content:center;align-items:center;font-size:2rem;display:flex}.success-state__title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text)}.success-state__description{font-size:var(--text-base);color:var(--color-text-muted)}
.dm{gap:var(--space-4);flex-direction:column;display:flex}.dm__header{gap:var(--space-1);flex-direction:column;display:flex}.dm__title-row{align-items:center;gap:var(--space-2);display:flex}.dm__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.dm__count{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-primary);background:var(--color-primary-50);border-radius:var(--radius-full);padding:2px 8px}.dm__desc{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.dm__message{align-items:center;gap:var(--space-2);font-size:var(--text-sm);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);display:flex}.dm__message--success{background:var(--color-primary-50);color:var(--color-primary-dark);border:1px solid var(--color-primary-200)}.dm__message--error{color:var(--color-error);background:#fef2f2;border:1px solid #fecaca}.dm__loading{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-8) 0;color:var(--color-text-muted);font-size:var(--text-sm);display:flex}.dm__list{border:1px solid var(--color-border);border-radius:var(--radius-xl);flex-direction:column;display:flex;overflow:hidden}.dm__item{align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface);transition:background var(--duration-fast) var(--ease-default);display:flex}.dm__item:not(:last-child){border-bottom:1px solid var(--color-border-muted)}.dm__item:hover{background:var(--color-bg-subtle)}.dm__item--current{background:var(--color-primary-50);border-left:3px solid var(--color-primary)}.dm__item--current:hover{background:var(--color-primary-100)}.dm__item--inactive{opacity:.6}.dm__item-icon{border-radius:var(--radius-lg);background:var(--color-bg-muted);width:40px;height:40px;color:var(--color-text-muted);flex-shrink:0;justify-content:center;align-items:center;display:flex}.dm__item--current .dm__item-icon{background:var(--color-primary-100);color:var(--color-primary)}.dm__item-icon--inactive{background:var(--color-bg-subtle);color:var(--color-text-subtle)}.dm__item-info{flex:1;min-width:0}.dm__item-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.dm__item-name--inactive{color:var(--color-text-muted)}.dm__item-meta{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px;display:flex}.dm__badge{font-size:10px;font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full);padding:1px 6px}.dm__badge--current{background:var(--color-primary);color:#fff}.dm__revoke-btn{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);width:36px;height:36px;color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);flex-shrink:0;justify-content:center;align-items:center;display:flex}.dm__revoke-btn:hover{color:var(--color-error);background:#fef2f2;border-color:#fecaca}.dm__revoke-btn:active{transform:scale(.95)}.dm__revoke-btn:disabled{opacity:.5;cursor:not-allowed}.dm__revoke-all{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);color:var(--color-error);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);display:flex}.dm__revoke-all:hover{background:#fef2f2;border-color:#fecaca}.dm__revoke-all:disabled{opacity:.5;cursor:not-allowed}.dm__history{border:1px solid var(--color-border-muted);border-radius:var(--radius-xl);flex-direction:column;gap:0;display:flex;overflow:hidden}.dm__history-title{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-subtle);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-3) var(--space-4);background:var(--color-bg-subtle);border-bottom:1px solid var(--color-border-muted);margin:0}.dark .dm__message--success{color:var(--color-primary);background:#4ade801a;border-color:#4ade8033}.dark .dm__message--error{background:#f871711a;border-color:#f8717133}.dark .dm__revoke-btn:hover,.dark .dm__revoke-all:hover{background:#f871711a;border-color:#f871714d}@media (max-width:480px){.dm__item-meta{flex-wrap:wrap}.dm__item-name{font-size:var(--text-xs)}}
.grammar-page{max-width:var(--content-max);padding:var(--space-6) var(--space-4);margin:0 auto}.grammar-page__header{margin-bottom:var(--space-8)}.grammar-page__hero{align-items:center;gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.grammar-page__hero-icon{background:var(--color-primary-50);border-radius:var(--radius-xl);flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:2.5rem;display:flex}.grammar-page__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-text);line-height:var(--leading-tight);margin:0}.grammar-page__sub{font-size:var(--text-base);color:var(--color-text-muted);margin:var(--space-1) 0 0;line-height:var(--leading-relaxed)}.grammar-page__features{gap:var(--space-2);flex-wrap:wrap;display:flex}.grammar-page__feature{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-text-muted);display:inline-flex}.grammar-page__breadcrumb{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-6);display:flex}.grammar-page__breadcrumb a{color:var(--color-primary);transition:opacity var(--duration-fast) var(--ease-default);text-decoration:none}.grammar-page__breadcrumb a:hover{opacity:.8}.grammar-page__breadcrumb-sep{color:var(--color-text-subtle)}.grammar-levels{gap:var(--space-2);margin-bottom:var(--space-6);scrollbar-width:none;-ms-overflow-style:none;padding-bottom:var(--space-2);display:flex;overflow-x:auto}.grammar-levels::-webkit-scrollbar{display:none}.grammar-level-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);white-space:nowrap;transition:all var(--duration-fast) var(--ease-default);cursor:pointer;text-decoration:none;display:flex}.grammar-level-tab:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.grammar-level-tab--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:var(--shadow-primary)}.grammar-level-tab--active:hover{color:#fff}.grammar-level-tab__desc{display:none}@media (min-width:640px){.grammar-level-tab__desc{opacity:.8;display:inline}}.grammar-topic-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.grammar-topic-card{padding:var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);color:var(--color-text);transition:all var(--duration-normal) var(--ease-default);animation:grammarCardIn var(--duration-normal) var(--ease-out) both;cursor:pointer;flex-direction:column;text-decoration:none;display:flex}.grammar-topic-card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-primary);transform:translateY(-3px)}@keyframes grammarCardIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.grammar-topic-card__icon{margin-bottom:var(--space-3);background:var(--color-primary-50);border-radius:var(--radius-lg);justify-content:center;align-items:center;width:48px;height:48px;font-size:2rem;display:flex}.grammar-topic-card__name{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0 0 var(--space-1);color:var(--color-text)}.grammar-topic-card__name-de{font-size:var(--text-sm);color:var(--color-text-muted);margin:0 0 var(--space-3);font-style:italic}.grammar-topic-card__meta{margin-top:auto}.grammar-topic-card__count{font-size:var(--text-sm);color:var(--color-text-muted);background:var(--color-bg-subtle);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.grammar-topic-card__progress{margin-top:var(--space-3);align-items:center;gap:var(--space-2);display:flex}.grammar-topic-card__progress-bar{background:var(--color-bg-muted);border-radius:var(--radius-full);flex:1;height:4px;overflow:hidden}.grammar-topic-card__progress-fill{background:var(--color-primary);border-radius:var(--radius-full);height:100%;transition:width var(--duration-slow) var(--ease-default)}.grammar-topic-card__progress-text{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap}.grammar-lesson-list{gap:var(--space-2);flex-direction:column;display:flex}.grammar-lesson-card{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-lg);color:var(--color-text);transition:all var(--duration-fast) var(--ease-default);animation:grammarCardIn var(--duration-normal) var(--ease-out) both;text-decoration:none;display:flex}.grammar-lesson-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translate(4px)}.grammar-lesson-card__order{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-primary);background:var(--color-primary-50);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.grammar-lesson-card__body{flex:1;min-width:0}.grammar-lesson-card__title{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin:0;overflow:hidden}.grammar-lesson-card__title-de{font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0;white-space:nowrap;text-overflow:ellipsis;font-style:italic;overflow:hidden}.grammar-lesson-card__meta{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.grammar-lesson-card__level{font-size:var(--text-xs);font-weight:var(--font-bold);border-radius:var(--radius-sm);text-transform:uppercase;padding:2px 8px}.grammar-lesson-card__level--a1{color:#166534;background:#dcfce7}.grammar-lesson-card__level--a2{color:#1e40af;background:#dbeafe}.grammar-lesson-card__level--b1{color:#5b21b6;background:#ede9fe}.grammar-lesson-card__level--b2{color:#9a3412;background:#fed7aa}.grammar-lesson-card__level--c1{color:#991b1b;background:#fecaca}.grammar-lesson-card__time{font-size:var(--text-xs);color:var(--color-text-subtle)}.grammar-lesson-card__arrow{font-size:var(--text-lg);color:var(--color-text-subtle);transition:transform var(--duration-fast) var(--ease-default)}.grammar-lesson-card:hover .grammar-lesson-card__arrow{color:var(--color-primary);transform:translate(4px)}.grammar-lesson{max-width:var(--content-max);padding:var(--space-4);margin:0 auto}.grammar-lesson__breadcrumb{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.grammar-lesson__breadcrumb a{color:var(--color-primary);text-decoration:none}.grammar-lesson__breadcrumb a:hover{opacity:.8}.grammar-lesson__breadcrumb-sep{color:var(--color-text-subtle)}.grammar-lesson__breadcrumb-current{color:var(--color-text);font-weight:var(--font-medium)}.grammar-lesson__layout{gap:var(--space-6);grid-template-columns:1fr;display:grid}@media (min-width:1024px){.grammar-lesson__layout{grid-template-columns:1fr 280px}}.grammar-lesson__content{min-width:0}.grammar-lesson__header{margin-bottom:var(--space-6);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border)}.grammar-lesson__meta{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.grammar-lesson__level{font-size:var(--text-xs);font-weight:var(--font-bold);border-radius:var(--radius-sm);text-transform:uppercase;padding:3px 10px}.grammar-lesson__level--a1{color:#166534;background:#dcfce7}.grammar-lesson__level--a2{color:#1e40af;background:#dbeafe}.grammar-lesson__level--b1{color:#5b21b6;background:#ede9fe}.grammar-lesson__level--b2{color:#9a3412;background:#fed7aa}.grammar-lesson__level--c1{color:#991b1b;background:#fecaca}.grammar-lesson__time{font-size:var(--text-sm);color:var(--color-text-muted)}.grammar-lesson__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text);line-height:var(--leading-snug);margin:0}@media (min-width:640px){.grammar-lesson__title{font-size:var(--text-3xl)}}.grammar-lesson__title-de{font-size:var(--text-lg);color:var(--color-text-muted);margin:var(--space-2) 0 0;font-style:italic}.grammar-lesson__empty{text-align:center;padding:var(--space-12) var(--space-4);color:var(--color-text-muted)}.grammar-lang-toggle{align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);padding:var(--space-3) var(--space-4);background:var(--color-surface-container-low);border-radius:var(--radius-lg);display:flex}.grammar-lang-toggle__label{font-size:var(--text-sm);color:var(--color-text-muted);white-space:nowrap}.grammar-lang-toggle__buttons{gap:var(--space-1);display:flex}.grammar-lang-toggle__btn{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);display:flex}.grammar-lang-toggle__btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.grammar-lang-toggle__btn--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);font-weight:var(--font-semibold)}.grammar-lang-toggle__btn-label{font-weight:var(--font-medium)}.grammar-lesson__blocks{gap:var(--space-4);margin-bottom:var(--space-8);flex-direction:column;display:flex}.grammar-block{line-height:var(--leading-vi)}.grammar-block--heading{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text);margin:var(--space-4) 0 var(--space-1);padding-top:var(--space-4);border-top:1px solid var(--color-border-muted)}.grammar-block--rule{gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-primary-50);border-left:4px solid var(--color-primary);border-radius:0 var(--radius-lg) var(--radius-lg) 0;color:var(--color-on-primary-container);display:flex}.dark .grammar-block--rule{background:var(--color-primary-100)}.grammar-block--example{gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid var(--color-info);border-radius:0 var(--radius-lg) var(--radius-lg) 0;display:flex}.grammar-block__example-icon{flex-shrink:0;font-size:1.25rem}.grammar-block__example-content{flex:1;min-width:0}.grammar-block__de{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text);margin:0 0 var(--space-1);align-items:flex-start;gap:var(--space-2);display:flex}.grammar-block__vi{font-size:var(--text-sm);color:var(--color-text-muted);margin:0 0 var(--space-1);align-items:flex-start;gap:var(--space-2);display:flex}.grammar-block__lang-badge{font-size:var(--text-xs);flex-shrink:0}.grammar-block--note{gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-streak-bg);border-left:4px solid var(--color-warning);border-radius:0 var(--radius-lg) var(--radius-lg) 0;display:flex}.grammar-block--tip{gap:var(--space-3);padding:var(--space-4) var(--space-5);border-left:4px solid var(--color-info);border-radius:0 var(--radius-lg) var(--radius-lg) 0;background:#eff6ff;display:flex}.dark .grammar-block--tip{background:#172554}.grammar-block__icon{flex-shrink:0;font-size:1.25rem;line-height:1}.grammar-block__content{flex:1;min-width:0}.grammar-block--text{color:var(--color-text)}.grammar-block__text-line{margin:0 0 var(--space-2)}.grammar-block__text-line:last-child{margin-bottom:0}.grammar-block--table{overflow-x:auto}.grammar-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.grammar-table th{background:var(--color-primary);color:#fff;padding:var(--space-2) var(--space-3);text-align:left;font-weight:var(--font-semibold)}.grammar-table td{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border)}.grammar-table tbody tr:nth-child(2n) td{background:var(--color-bg-subtle)}.grammar-table tbody tr:hover td{background:var(--color-primary-50)}.grammar-block__pre{font-family:var(--font-mono);font-size:var(--text-sm);white-space:pre-wrap;word-break:break-word;padding:var(--space-4);background:var(--color-bg-subtle);border-radius:var(--radius-md);border:1px solid var(--color-border);margin:0}.grammar-lesson__sidebar{gap:var(--space-4);flex-direction:column;display:flex}@media (min-width:1024px){.grammar-lesson__sidebar{top:calc(var(--header-height) + var(--space-4));align-self:start;position:sticky}}.grammar-sidebar-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5)}.grammar-sidebar-card__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-semibold);margin:0 0 var(--space-3);color:var(--color-text)}.grammar-sidebar-card__desc{font-size:var(--text-sm);color:var(--color-text-muted);margin:0 0 var(--space-3)}.grammar-sidebar-card__list{gap:var(--space-2) var(--space-3);font-size:var(--text-sm);grid-template-columns:auto 1fr;margin:0;display:grid}.grammar-sidebar-card__list dt{color:var(--color-text-muted)}.grammar-sidebar-card__list dd{color:var(--color-text);font-weight:var(--font-medium);margin:0}.grammar-sidebar-card__more{font-size:var(--text-xs);color:var(--color-text-subtle);margin-top:var(--space-2);text-align:center}.grammar-vocab-list{gap:var(--space-1);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.grammar-vocab-item__link{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text);transition:background var(--duration-fast) var(--ease-default);flex-direction:column;text-decoration:none;display:flex}.grammar-vocab-item__link:hover{background:var(--color-bg-subtle)}.grammar-vocab-item__word{font-weight:var(--font-medium);font-size:var(--text-sm);align-items:center;gap:var(--space-1);display:flex}.grammar-vocab-item__gender{font-size:var(--text-xs);color:var(--color-primary);font-style:italic}.grammar-vocab-item__ipa{font-size:var(--text-xs);color:var(--color-text-subtle);font-family:var(--font-mono)}.grammar-vocab-item__meaning{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:1px}.grammar-nav{align-items:stretch;gap:var(--space-3);margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-border);display:flex}.grammar-nav__btn{align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);transition:all var(--duration-fast) var(--ease-default);flex:1;text-decoration:none;display:flex}.grammar-nav__btn:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.grammar-nav__btn--next{text-align:right;justify-content:flex-end}.grammar-nav__arrow{font-size:var(--text-xl);color:var(--color-primary);font-weight:var(--font-bold);flex-shrink:0}.grammar-nav__btn-content{flex-direction:column;gap:2px;min-width:0;display:flex}.grammar-nav__btn-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.grammar-nav__btn-title{font-size:var(--text-sm);font-weight:var(--font-medium);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.grammar-nav__back{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--color-primary);white-space:nowrap;justify-content:center;align-items:center;text-decoration:none;display:flex}.grammar-nav__back:hover{text-decoration:underline}.grammar-progress-btn{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-6);background:var(--color-primary);color:#fff;border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);box-shadow:var(--shadow-primary);border:none;display:flex}.grammar-progress-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #006a2c66}.grammar-progress-btn:active{transform:translateY(0)}.grammar-progress-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.grammar-progress-btn__spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.grammar-progress-done{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--color-primary-50);color:var(--color-primary);border-radius:var(--radius-lg);font-weight:var(--font-semibold);border:1px solid var(--color-primary-200);display:flex}.grammar-empty{text-align:center;padding:var(--space-16) var(--space-4)}.grammar-empty__icon{margin-bottom:var(--space-4);font-size:3rem}.grammar-empty__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-semibold);margin:0 0 var(--space-2)}.grammar-empty__sub{font-size:var(--text-base);color:var(--color-text-muted);margin:0 0 var(--space-6)}@media (max-width:639px){.grammar-page{padding:var(--space-4) var(--space-3)}.grammar-page__hero-icon{width:48px;height:48px;font-size:1.75rem}.grammar-page__title{font-size:var(--text-2xl)}.grammar-topic-grid{grid-template-columns:1fr}.grammar-lesson-card{padding:var(--space-3);gap:var(--space-3)}.grammar-lesson-card__title{font-size:var(--text-sm)}.grammar-lesson{padding:var(--space-3)}.grammar-nav{flex-direction:column}.grammar-nav__btn--next{text-align:left;flex-direction:row-reverse;justify-content:flex-start}.grammar-nav__back{order:-1}}
.lb{max-width:900px;padding:var(--space-6) var(--space-4);gap:var(--space-6);flex-direction:column;margin:0 auto;display:flex}.lb__header{text-align:center}.lb__badge{padding:var(--space-1) var(--space-3);background:linear-gradient(135deg, var(--color-primary-light), var(--color-primary));color:#fff;border-radius:var(--radius-full);font-size:var(--text-sm);margin-bottom:var(--space-3);font-weight:700;display:inline-block}.lb__title{font-size:var(--text-2xl);color:var(--color-heading);margin:0 0 var(--space-2);font-weight:800}.lb__sub{color:var(--color-muted);font-size:var(--text-base);margin:0}.lb__footer{text-align:center;padding:var(--space-4) 0}.lb__back{color:var(--color-muted);font-size:var(--text-sm);text-decoration:none;transition:color .2s}.lb__back:hover{color:var(--color-primary)}.lb-rank-banner{background:linear-gradient(135deg, var(--color-primary), #059669);border-radius:var(--radius-xl);padding:var(--space-5);justify-content:space-between;align-items:center;gap:var(--space-4);color:#fff;display:flex}.lb-rank-banner__rank{align-items:center;gap:var(--space-1);flex-direction:column;display:flex}.lb-rank-banner__rank-num{font-size:var(--text-3xl);font-weight:900;line-height:1}.lb-rank-banner__rank-label{font-size:var(--text-xs);opacity:.8;text-transform:uppercase;letter-spacing:.05em}.lb-rank-banner__stats{gap:var(--space-6);display:flex}.lb-rank-banner__stat{align-items:center;gap:var(--space-1);flex-direction:column;display:flex}.lb-rank-banner__stat-value{font-size:var(--text-xl);font-weight:800}.lb-rank-banner__stat-label{font-size:var(--text-xs);opacity:.75}.lb-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.lb-section__header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.lb-section__title{font-size:var(--text-lg);color:var(--color-heading);margin:0;font-weight:700}.lb-section__count{font-size:var(--text-sm);color:var(--color-muted);background:var(--color-bg);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}.lb-empty{text-align:center;padding:var(--space-10) var(--space-4)}.lb-empty__icon{margin-bottom:var(--space-3);font-size:3rem;display:block}.lb-empty__text{font-size:var(--text-lg);color:var(--color-heading);margin:0 0 var(--space-1);font-weight:600}.lb-empty__sub{color:var(--color-muted);font-size:var(--text-sm);margin:0}.lb-podium{justify-content:center;align-items:flex-end;gap:var(--space-3);padding:var(--space-6) var(--space-4) var(--space-4);display:flex}.lb-podium__item{align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-3);border-radius:var(--radius-xl);background:var(--color-bg);border:2px solid var(--color-border);flex-direction:column;min-width:120px;transition:transform .3s,box-shadow .3s;display:flex}.lb-podium__item:hover{transform:translateY(-4px)}.lb-podium__item--gold{background:linear-gradient(#f59e0b14,#0000);border-color:#f59e0b;min-height:200px;box-shadow:0 4px 24px #f59e0b26}.lb-podium__item--silver{background:linear-gradient(#94a3b814,#0000);border-color:#94a3b8;min-height:170px}.lb-podium__item--bronze{background:linear-gradient(#d9770614,#0000);border-color:#d97706;min-height:160px}.lb-podium__item--me{box-shadow:0 0 0 2px var(--color-primary), 0 4px 16px #05966933}.lb-podium__medal{font-size:1.75rem}.lb-podium__avatar{border:3px solid var(--color-border);border-radius:50%;width:56px;height:56px;overflow:hidden}.lb-podium__item--gold .lb-podium__avatar{border-color:#f59e0b}.lb-podium__avatar-img{object-fit:cover;width:100%;height:100%}.lb-podium__avatar-fallback{background:var(--color-primary-light);width:100%;height:100%;color:var(--color-primary);font-weight:700;font-size:var(--text-sm);justify-content:center;align-items:center;display:flex}.lb-podium__name{font-weight:700;font-size:var(--text-sm);color:var(--color-heading);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:100px;margin:0;overflow:hidden}.lb-podium__xp{font-size:var(--text-sm);color:var(--color-primary);margin:0;font-weight:800}.lb-podium__streak{font-size:var(--text-xs);color:var(--color-muted)}.lb-table-wrap{overflow-x:auto}.lb-table{border-collapse:collapse;width:100%}.lb-table__th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);border-bottom:1px solid var(--color-border);font-weight:600}.lb-table__th--rank{text-align:center;width:60px}.lb-table__th--xp{text-align:right}.lb-table__th--streak,.lb-table__th--level{text-align:center}.lb-table__row{transition:background .15s}.lb-table__row:hover{background:var(--color-bg)}.lb-table__row--me{border-left:3px solid var(--color-primary);background:#0596690f!important}.lb-table__row--top3{font-weight:600}.lb-table__td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);font-size:var(--text-sm)}.lb-table__td--rank{text-align:center}.lb-table__td--xp{text-align:right}.lb-table__td--streak,.lb-table__td--level{text-align:center}.lb-table__separator{height:40px}.lb-table__separator td{text-align:center;color:var(--color-muted);border:none}.lb-table__separator-dots{font-size:var(--text-lg);letter-spacing:.5em}.lb-rank{min-width:32px;height:32px;font-weight:700;font-size:var(--text-sm);color:var(--color-muted);justify-content:center;align-items:center;display:inline-flex}.lb-rank--gold,.lb-rank--silver,.lb-rank--bronze{font-size:1.4rem}.lb-user{align-items:center;gap:var(--space-3);display:flex}.lb-user__avatar{border-radius:50%;flex-shrink:0;width:36px;height:36px;overflow:hidden}.lb-user__avatar-img{object-fit:cover;width:100%;height:100%}.lb-user__avatar-fallback{background:var(--color-primary-light);width:100%;height:100%;color:var(--color-primary);font-weight:700;font-size:var(--text-xs);justify-content:center;align-items:center;display:flex}.lb-user__name{color:var(--color-heading);align-items:center;gap:var(--space-1);font-weight:600;display:flex}.lb-user__plan{font-size:var(--text-xs)}.lb-user__me{color:#fff;background:var(--color-primary);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;padding:1px 6px;font-size:10px;font-weight:700}.lb-level{border-radius:var(--radius-sm);background:var(--color-bg);font-size:var(--text-xs);color:var(--color-heading);padding:2px 8px;font-weight:700;display:inline-block}.lb-streak{font-size:var(--text-sm)}.lb-streak--zero{color:var(--color-muted)}.lb-xp{color:var(--color-primary);font-weight:800}.ach{padding:var(--space-4) var(--space-5);gap:var(--space-5);flex-direction:column;display:flex}.ach-progress{gap:var(--space-2);flex-direction:column;display:flex}.ach-progress__header{justify-content:space-between;align-items:center;display:flex}.ach-progress__label{font-size:var(--text-sm);color:var(--color-heading);font-weight:600}.ach-progress__count{font-size:var(--text-sm);color:var(--color-primary);font-weight:700}.ach-progress__bar{background:var(--color-bg);border-radius:var(--radius-full);height:10px;overflow:hidden}.ach-progress__fill{background:linear-gradient(90deg, var(--color-primary), #10b981);border-radius:var(--radius-full);min-width:2%;height:100%;transition:width 1s}.ach-progress__percent{font-size:var(--text-xs);color:var(--color-muted)}.ach-category{gap:var(--space-3);flex-direction:column;display:flex}.ach-category__title{font-size:var(--text-base);color:var(--color-heading);margin:0;font-weight:700}.ach-category__grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.ach-card{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-surface);transition:transform .2s,box-shadow .2s;display:flex;position:relative}.ach-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000f}.ach-card--unlocked{border-color:var(--color-primary);background:linear-gradient(135deg,#0596690a,#0000)}.ach-card--locked{opacity:.55}.ach-card--locked:hover{opacity:.75}.ach-card__icon{background:var(--color-bg);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.75rem;line-height:1;display:flex}.ach-card--unlocked .ach-card__icon{background:#0596691a}.ach-card__content{flex:1;min-width:0}.ach-card__title{font-size:var(--text-sm);color:var(--color-heading);margin:0 0 2px;font-weight:700}.ach-card__desc{font-size:var(--text-xs);color:var(--color-muted);margin:0 0 var(--space-1)}.ach-card__reward{border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-muted);padding:1px 6px;font-size:10px;font-weight:700;display:inline-block}.ach-card__reward--earned{color:var(--color-primary);background:#0596691a}.ach-card__date{top:var(--space-2);right:var(--space-3);color:var(--color-primary);font-size:10px;font-weight:600;position:absolute}@media (max-width:768px){.lb{padding:var(--space-4) var(--space-3);gap:var(--space-4)}.lb__title{font-size:var(--text-xl)}.lb-rank-banner{text-align:center;gap:var(--space-3);padding:var(--space-4);flex-direction:column}.lb-rank-banner__stats{gap:var(--space-4)}.lb-podium{gap:var(--space-2);padding:var(--space-4) var(--space-2)}.lb-podium__item{min-width:90px;padding:var(--space-3) var(--space-2)}.lb-podium__avatar{width:44px;height:44px}.lb-podium__name{max-width:75px;font-size:var(--text-xs)}.lb-podium__xp{font-size:var(--text-xs)}.lb-table__th--level,.lb-table__td--level{display:none}.ach{padding:var(--space-3)}.ach-category__grid{grid-template-columns:1fr}}@media (max-width:480px){.lb-podium__item--gold{min-height:160px}.lb-podium__item--silver{min-height:140px}.lb-podium__item--bronze{min-height:130px}.lb-table__th--streak,.lb-table__td--streak{display:none}}
.pwa-prompt{z-index:9999;background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;flex-direction:column;gap:12px;max-width:400px;margin:0 auto;padding:16px;animation:.4s ease-out both pwaSlideUp;display:flex;position:fixed;bottom:16px;left:16px;right:16px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014}@keyframes pwaSlideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.pwa-prompt__content{align-items:center;gap:12px;display:flex}.pwa-prompt__icon{background:#0596691a;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.75rem;display:flex}.pwa-prompt__text{flex:1;min-width:0}.pwa-prompt__title{color:var(--color-heading);white-space:nowrap;text-overflow:ellipsis;margin:0 0 2px;font-size:14px;font-weight:700;overflow:hidden}.pwa-prompt__sub{color:var(--color-muted);word-break:break-word;margin:0;font-size:12px;line-height:1.5}.pwa-prompt__ios-icon{color:#007aff;vertical-align:middle;justify-content:center;align-items:center;margin:0 1px;display:inline-flex}.pwa-prompt__sub strong{color:var(--color-heading);font-weight:600}.pwa-prompt__actions{justify-content:flex-end;gap:8px;display:flex}.pwa-prompt__btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.pwa-prompt__btn--install{background:var(--color-primary);color:#fff}.pwa-prompt__btn--install:hover{opacity:.9}.pwa-prompt__btn--dismiss{color:var(--color-muted);background:0 0}.pwa-prompt__btn--dismiss:hover{background:var(--color-bg);color:var(--color-text)}@media (display-mode:standalone){.pwa-prompt{display:none}}@media (max-width:768px){.pwa-prompt{padding:14px;bottom:80px;left:12px;right:12px}.pwa-prompt__title{font-size:13px}.pwa-prompt__sub{font-size:11px}}
.ana{max-width:960px;padding:var(--space-6) var(--space-4);gap:var(--space-5);flex-direction:column;margin:0 auto;display:flex}.ana__header{text-align:center}.ana__badge{padding:var(--space-1) var(--space-3);background:linear-gradient(135deg, var(--color-info), #3b82f6);color:#fff;border-radius:var(--radius-full);font-size:var(--text-sm);margin-bottom:var(--space-3);font-weight:700;display:inline-block}.ana__title{font-size:var(--text-2xl);color:var(--color-heading);margin:0 0 var(--space-2);font-weight:800}.ana__sub{color:var(--color-muted);font-size:var(--text-base);margin:0}.ana__footer{text-align:center;padding:var(--space-4) 0}.ana__back{color:var(--color-muted);font-size:var(--text-sm);text-decoration:none;transition:color .2s}.ana__back:hover{color:var(--color-primary)}.ana-cards{gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));display:grid}.ana-card{align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:transform .2s,box-shadow .2s;display:flex}.ana-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.ana-card__icon{background:var(--color-bg);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.5rem;display:flex}.ana-card__data{flex-direction:column;display:flex}.ana-card__value{font-size:var(--text-lg);color:var(--color-heading);font-weight:800;line-height:1.2}.ana-card__label{font-size:var(--text-xs);color:var(--color-muted)}.ana-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.ana-section__header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.ana-section__title{font-size:var(--text-base);color:var(--color-heading);margin:0;font-weight:700}.ana-section__count{font-size:var(--text-sm);color:var(--color-muted);background:var(--color-bg);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}.ana-section__body{padding:var(--space-4) var(--space-5)}.ana-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.chart-empty{text-align:center;padding:var(--space-8) var(--space-4);color:var(--color-muted);font-size:var(--text-sm)}.heatmap{gap:var(--space-2);flex-direction:column;display:flex}.heatmap__months{gap:3px;padding-left:28px;display:flex}.heatmap__month-cell{width:14px;color:var(--color-muted);text-align:center;font-size:10px}.heatmap__day-spacer{flex-shrink:0;width:24px}.heatmap__grid{gap:4px;display:flex}.heatmap__day-labels{flex-direction:column;flex-shrink:0;gap:3px;width:24px;display:flex}.heatmap__day-label{height:14px;color:var(--color-muted);align-items:center;font-size:10px;display:flex}.heatmap__weeks{gap:3px;display:flex;overflow-x:auto}.heatmap__week{flex-direction:column;gap:3px;display:flex}.heatmap__cell{cursor:default;border-radius:3px;width:14px;height:14px;transition:transform .1s}.heatmap__cell:hover{transform:scale(1.3)}.heatmap__cell--empty{background:0 0}.heatmap__cell--0{background:var(--color-bg-muted)}.heatmap__cell--1{background:#05966940}.heatmap__cell--2{background:#05966973}.heatmap__cell--3{background:#059669b3}.heatmap__cell--4{background:var(--color-primary)}.dark .heatmap__cell--0{background:var(--color-surface-container)}.dark .heatmap__cell--1{background:#4ade8026}.dark .heatmap__cell--2{background:#4ade804d}.dark .heatmap__cell--3{background:#4ade8080}.dark .heatmap__cell--4{background:var(--color-primary)}.heatmap__legend{align-items:center;gap:var(--space-1);padding-top:var(--space-2);justify-content:flex-end;display:flex}.heatmap__legend .heatmap__cell{cursor:default}.heatmap__legend .heatmap__cell:hover{transform:none}.heatmap__legend-label{color:var(--color-muted);font-size:10px}.stype-chart{gap:var(--space-3);flex-direction:column;display:flex}.stype-chart__row{align-items:center;gap:var(--space-3);display:flex}.stype-chart__label{align-items:center;gap:var(--space-2);flex-shrink:0;width:110px;display:flex}.stype-chart__dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.stype-chart__name{font-size:var(--text-sm);color:var(--color-heading);font-weight:500}.stype-chart__bar-wrap{background:var(--color-bg);border-radius:var(--radius-full);flex:1;height:24px;overflow:hidden}.stype-chart__bar{border-radius:var(--radius-full);opacity:.85;min-width:4px;height:100%;transition:width 1s}.stype-chart__value{align-items:center;gap:var(--space-1);width:70px;font-size:var(--text-sm);color:var(--color-heading);flex-shrink:0;justify-content:flex-end;display:flex}.stype-chart__pct{font-size:var(--text-xs);color:var(--color-muted)}.mastery-chart{gap:var(--space-4);flex-direction:column;display:flex}.mastery-chart__bar{border-radius:var(--radius-full);background:var(--color-bg);height:28px;display:flex;overflow:hidden}.mastery-chart__segment{min-width:2px;transition:width 1s}.mastery-chart__legend{gap:var(--space-2) var(--space-4);flex-wrap:wrap;display:flex}.mastery-chart__legend-item{align-items:center;gap:var(--space-1);font-size:var(--text-xs);display:flex}.mastery-chart__legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.mastery-chart__legend-label{color:var(--color-muted)}.mastery-chart__legend-count{color:var(--color-heading);font-weight:700}.weekly-chart{gap:var(--space-4);flex-direction:column;display:flex}.weekly-chart__bars{align-items:flex-end;gap:var(--space-2);height:160px;display:flex}.weekly-chart__col{align-items:center;gap:var(--space-2);flex-direction:column;flex:1;height:100%;display:flex}.weekly-chart__bar-container{flex:1;justify-content:center;align-items:flex-end;width:100%;display:flex}.weekly-chart__bar{background:var(--color-bg-muted);border-radius:var(--radius-md) var(--radius-md) 0 0;width:100%;max-width:48px;min-height:4px;transition:height 1s;position:relative}.weekly-chart__bar--active{background:linear-gradient(to top, var(--color-primary-dark), var(--color-primary))}.weekly-chart__bar-value{color:var(--color-primary);font-size:11px;font-weight:700;position:absolute;top:-20px;left:50%;transform:translate(-50%)}.weekly-chart__label{color:var(--color-muted);white-space:nowrap;font-size:10px}.weekly-chart__summary{justify-content:center;gap:var(--space-8);padding-top:var(--space-3);border-top:1px solid var(--color-border);display:flex}.weekly-chart__stat{flex-direction:column;align-items:center;gap:2px;display:flex}.weekly-chart__stat-value{font-size:var(--text-lg);color:var(--color-heading);font-weight:800}.weekly-chart__stat-label{font-size:var(--text-xs);color:var(--color-muted)}@media (max-width:768px){.ana{padding:var(--space-4) var(--space-3);gap:var(--space-4)}.ana__title{font-size:var(--text-xl)}.ana-cards{grid-template-columns:repeat(2,1fr)}.ana-row{grid-template-columns:1fr}.heatmap__cell{width:11px;height:11px}.heatmap__weeks,.heatmap__week{gap:2px}.stype-chart__label{width:85px}.stype-chart__name{font-size:var(--text-xs)}.stype-chart__value{width:55px}.weekly-chart__bars{height:120px}.weekly-chart__summary{gap:var(--space-4)}}@media (max-width:480px){.ana-cards{gap:var(--space-2);grid-template-columns:repeat(2,1fr)}.ana-card{padding:var(--space-3)}.ana-card__icon{width:32px;height:32px;font-size:1.2rem}.ana-card__value{font-size:var(--text-base)}}
.export-btn{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-sm);cursor:pointer;font-weight:500;transition:all .2s;display:inline-flex}.export-btn:hover{background:var(--color-bg);border-color:var(--color-primary);color:var(--color-primary)}.export-btn__icon{font-size:1rem}.export-btn__text{display:inline}.export-modal-overlay{z-index:var(--z-modal);padding:var(--space-4);background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.export-modal{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-5);width:100%;max-width:400px;box-shadow:var(--shadow-xl);animation:.3s slideUp}.export-modal__header{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.export-modal__title{font-size:var(--text-lg);color:var(--color-heading);margin:0;font-weight:700}.export-modal__close{background:var(--color-bg);border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-muted);cursor:pointer;border:none;justify-content:center;align-items:center;font-size:14px;transition:all .15s;display:flex}.export-modal__close:hover{background:var(--color-bg-muted);color:var(--color-text)}.export-modal__sub{font-size:var(--text-sm);color:var(--color-muted);margin:0 0 var(--space-4)}.export-modal__formats{gap:var(--space-2);flex-direction:column;display:flex}.export-format{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;width:100%;transition:all .2s;display:flex}.export-format:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-primary-50);transform:translate(4px)}.export-format:disabled{opacity:.6;cursor:not-allowed}.export-format--loading{border-color:var(--color-primary)}.export-format__icon{flex-shrink:0;font-size:1.5rem}.export-format__info{flex-direction:column;flex:1;display:flex}.export-format__label{font-weight:700;font-size:var(--text-sm);color:var(--color-heading)}.export-format__desc{font-size:var(--text-xs);color:var(--color-muted)}.export-format__arrow{color:var(--color-muted);font-size:var(--text-lg);transition:transform .2s}.export-format:hover:not(:disabled) .export-format__arrow{color:var(--color-primary);transform:translate(4px)}.export-format__spinner{animation:1s linear infinite spin}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
.chat-layout{height:calc(100vh - var(--header-height) - var(--space-8) * 2);border-radius:var(--radius-xl);background:var(--color-surface);box-shadow:var(--shadow-lg);grid-template-columns:340px 1fr;gap:0;display:grid;overflow:hidden}@media (max-width:1024px){.chat-layout{height:calc(100dvh - var(--header-height) - var(--space-4) * 2);border-radius:var(--radius-lg)}}@media (max-width:768px){.chat-layout{height:calc(100dvh - var(--header-height) - var(--space-4) * 2);border-radius:var(--radius-lg);grid-template-columns:1fr}}@media (max-width:480px){.chat-layout{height:calc(100dvh - var(--header-height) - var(--space-3) * 2);border-radius:var(--radius-md)}}.chat-sidebar{border-right:1px solid var(--color-border);background:var(--color-surface);flex-direction:column;display:flex;overflow:hidden}@media (max-width:768px){.chat-sidebar{border-right:none}.chat-sidebar--hidden{display:none}}.chat-sidebar__header{padding:var(--space-4) var(--space-4) var(--space-3);border-bottom:1px solid var(--color-border-muted);justify-content:space-between;align-items:center;display:flex;position:relative}.chat-sidebar__header:after{content:"";bottom:-1px;left:var(--space-4);right:var(--space-4);background:linear-gradient(90deg, var(--color-primary), var(--color-primary-light), transparent);border-radius:var(--radius-full);height:2px;position:absolute}.chat-sidebar__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);display:flex}.chat-sidebar__actions{gap:var(--space-2);display:flex}.chat-sidebar__tabs{border-bottom:1px solid var(--color-border-muted);display:flex}.chat-sidebar__tab{padding:var(--space-3) var(--space-4);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;border:none;border-bottom:2px solid #0000;flex:1}.chat-sidebar__tab:hover{color:var(--color-text);background:var(--color-bg-subtle)}.chat-sidebar__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:var(--font-semibold)}.chat-sidebar__search{padding:var(--space-2) var(--space-3);position:relative}.chat-sidebar__search-icon{left:calc(var(--space-3) + 12px);width:16px;height:16px;color:var(--color-text-subtle);pointer-events:none;transition:color var(--duration-fast) var(--ease-default);position:absolute;top:50%;transform:translateY(-50%)}.chat-sidebar__search:focus-within .chat-sidebar__search-icon{color:var(--color-primary)}.chat-sidebar__search-input{width:100%;padding:var(--space-2-5,10px) var(--space-3) var(--space-2-5,10px) 38px;font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text);background:var(--color-surface-container-low);border:1.5px solid var(--color-border-muted);border-radius:var(--radius-xl);transition:all var(--duration-fast) var(--ease-default);outline:none}.chat-sidebar__search-input::placeholder{color:var(--color-text-subtle)}.chat-sidebar__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)}.chat-sidebar__list{padding:var(--space-2);flex:1;overflow-y:auto}.join-code-form{align-items:center;gap:var(--space-2);padding:var(--space-3);border-top:1px solid var(--color-border-muted);background:var(--color-surface);display:flex}.join-code-form__input{min-width:0;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-family:var(--font-mono);letter-spacing:.05em;color:var(--color-text);background:var(--color-surface-container-low);border:1.5px solid var(--color-border-muted);border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-default);outline:none;flex:1}.join-code-form__input::placeholder{color:var(--color-text-subtle);font-family:var(--font-sans);letter-spacing:normal}.join-code-form__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)}.chat-sidebar__empty{padding:var(--space-12) var(--space-6);text-align:center;color:var(--color-text-muted);justify-content:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.chat-sidebar__empty-icon{width:56px;height:56px;padding:var(--space-3);border-radius:var(--radius-2xl);background:linear-gradient(135deg, var(--color-primary-50), var(--color-primary-100));color:var(--color-primary);opacity:.8;animation:3s ease-in-out infinite float-subtle}@keyframes float-subtle{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.chat-sidebar__empty-text{font-size:var(--text-sm);line-height:var(--leading-relaxed);max-width:220px}.group-item{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);color:inherit;text-decoration:none;display:flex}.group-item:hover{background:var(--color-bg-subtle)}.group-item--active{background:var(--color-primary-50);border:1px solid var(--color-primary-200)}.group-item__avatar{border-radius:var(--radius-xl);background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff;width:44px;height:44px;font-weight:var(--font-bold);font-size:var(--text-lg);box-shadow:var(--shadow-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.group-item__info{flex:1;min-width:0}.group-item__name{font-weight:var(--font-semibold);font-size:var(--text-sm);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.group-item__last-msg{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;overflow:hidden}.group-item__meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.group-item__time{color:var(--color-text-subtle);font-size:.65rem}.group-item__members{font-size:var(--text-xs);color:var(--color-text-subtle);align-items:center;gap:2px;display:flex}.chat-panel{background:var(--color-bg);flex-direction:column;display:flex;overflow:hidden}@media (max-width:768px){.chat-panel--hidden{display:none}}.chat-panel__placeholder{height:100%;color:var(--color-text-muted);justify-content:center;align-items:center;gap:var(--space-4);background:radial-gradient(ellipse at 30% 20%, color-mix(in oklch, var(--color-primary) 4%, transparent), transparent 60%), radial-gradient(ellipse at 70% 80%, color-mix(in oklch, var(--color-primary) 3%, transparent), transparent 60%), var(--color-bg);flex-direction:column;display:flex}.chat-panel__placeholder-icon{width:72px;height:72px;padding:var(--space-4);border-radius:var(--radius-3xl);background:linear-gradient(135deg, var(--color-primary-50), var(--color-primary-100));color:var(--color-primary);opacity:.7;animation:3s ease-in-out infinite float-subtle}.chat-panel__placeholder-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text)}.chat-panel__placeholder-hint{font-size:var(--text-sm);color:var(--color-text-subtle)}.chat-header{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-surface);display:flex}.chat-header__back{padding:var(--space-2);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-muted);transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;display:none}.chat-header__back:hover{background:var(--color-bg-subtle);color:var(--color-text)}@media (max-width:768px){.chat-header__back{display:flex}}.chat-header__avatar{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff;width:36px;height:36px;font-weight:var(--font-bold);font-size:var(--text-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.chat-header__info{flex:1;min-width:0}.chat-header__name{font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--color-text)}.chat-header__status{font-size:var(--text-xs);color:var(--color-text-muted)}.chat-header__actions{gap:var(--space-1);display:flex}.chat-header__btn{border-radius:var(--radius-md);cursor:pointer;width:36px;height:36px;color:var(--color-text-muted);transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.chat-header__btn:hover{background:var(--color-bg-subtle);color:var(--color-primary)}.chat-messages{padding:var(--space-4);gap:var(--space-1);scroll-behavior:smooth;flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-messages__date-separator{align-items:center;gap:var(--space-4);margin:var(--space-4) 0;display:flex}.chat-messages__date-line{background:var(--color-border-muted);flex:1;height:1px}.chat-messages__date-text{font-size:var(--text-xs);color:var(--color-text-subtle);white-space:nowrap;padding:var(--space-1) var(--space-3);background:var(--color-bg-muted);border-radius:var(--radius-full)}.message{gap:var(--space-2);max-width:85%;animation:message-in var(--duration-normal) var(--ease-spring);display:flex}@keyframes message-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message--mine{flex-direction:row-reverse;align-self:flex-end}.message--system{align-self:center;max-width:100%}.message__avatar{border-radius:var(--radius-full);flex-shrink:0;width:32px;height:32px;margin-top:2px;overflow:hidden}.message__avatar img{object-fit:cover;width:100%;height:100%}.message__avatar-fallback{background:var(--color-primary-100);width:100%;height:100%;color:var(--color-primary-dark);font-weight:var(--font-bold);font-size:var(--text-xs);justify-content:center;align-items:center;display:flex}.message__avatar-spacer{flex-shrink:0;width:32px}.message__edited{opacity:.6;margin-left:4px;font-size:.6rem}.message__body{flex-direction:column;gap:2px;display:flex}.message__sender{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-primary);padding-left:var(--space-1)}.message--mine .message__sender{display:none}.message__bubble{padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);background:var(--color-surface);border:1px solid var(--color-border-muted);color:var(--color-text);font-size:var(--text-sm);line-height:var(--leading-relaxed);word-break:break-word;box-shadow:var(--shadow-xs);position:relative}.message--mine .message__bubble{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-primary);border-color:#0000}.message__bubble--system{background:var(--color-bg-muted);text-align:center;font-size:var(--text-xs);color:var(--color-text-muted);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);box-shadow:none;border:none}.message__reply-preview{padding:var(--space-1) var(--space-2);margin-bottom:var(--space-1);border-left:2px solid var(--color-primary-light);background:var(--color-primary-50);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:var(--text-xs);color:var(--color-text-muted)}.message--mine .message__reply-preview{color:#fffc;background:#ffffff26;border-left-color:#ffffff80}.message__time{color:var(--color-text-subtle);padding:0 var(--space-1);font-size:.65rem}.message--mine .message__time{text-align:right}.message__actions{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);gap:2px;padding:2px;display:none;position:absolute;top:-8px;right:4px}.message:hover .message__actions{display:flex}.message__action-btn{cursor:pointer;width:24px;height:24px;color:var(--color-text-muted);border-radius:var(--radius-sm);transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.message__action-btn:hover{background:var(--color-bg-subtle);color:var(--color-primary)}.chat-input{align-items:flex-end;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border);background:var(--color-surface);display:flex}.chat-input__reply{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-primary-50);border-left:3px solid var(--color-primary);border-radius:0 var(--radius-md) var(--radius-md) 0;font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-2);display:flex}.chat-input__reply-close{cursor:pointer;width:20px;height:20px;color:var(--color-text-muted);border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-default);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.chat-input__reply-close:hover{background:var(--color-bg-muted);color:var(--color-accent)}.chat-input__wrapper{flex-direction:column;flex:1;display:flex}.chat-input__field{resize:none;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);min-height:44px;max-height:120px;line-height:var(--leading-snug);transition:all var(--duration-fast) var(--ease-default);outline:none;flex:1}.chat-input__field:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-glow)}.chat-input__field::placeholder{color:var(--color-text-subtle)}.chat-input__send{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;cursor:pointer;width:44px;height:44px;transition:all var(--duration-fast) var(--ease-default);box-shadow:var(--shadow-primary);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.chat-input__send:hover{background:var(--color-primary-dark);transform:scale(1.05)}.chat-input__send:active{transform:scale(.95)}.chat-input__send:disabled{opacity:.4;cursor:not-allowed;transform:none}.create-group-form__toggle-card{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface-container-low);border:1px solid var(--color-border-muted);border-radius:var(--radius-lg);transition:all var(--duration-fast) var(--ease-default);display:flex}.create-group-form__toggle-card:hover{border-color:var(--color-border);background:var(--color-surface-container)}.create-group-form__switch{border-radius:var(--radius-full);background:var(--color-bg-muted);border:2px solid var(--color-border);cursor:pointer;width:44px;height:24px;transition:all var(--duration-fast) var(--ease-default);flex-shrink:0;position:relative}.create-group-form__switch--on{background:var(--color-primary);border-color:var(--color-primary-dark)}.create-group-form__switch:after{content:"";border-radius:var(--radius-full);width:18px;height:18px;transition:transform var(--duration-fast) var(--ease-spring);box-shadow:var(--shadow-sm);background:#fff;position:absolute;top:1px;left:1px}.create-group-form__switch--on:after{transform:translate(20px)}.create-group-form__toggle-info{flex:1;min-width:0}.create-group-form__toggle-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);display:block}.create-group-form__toggle-desc{font-size:var(--text-xs);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin-top:2px}.create-group-form__actions{justify-content:flex-end;align-items:center;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--color-border-muted);display:flex}.members-panel{border-left:1px solid var(--color-border);background:var(--color-surface);width:260px;padding:var(--space-4);overflow-y:auto}@media (max-width:1024px){.members-panel{display:none}}.members-panel__title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.members-panel__list{gap:var(--space-2);flex-direction:column;display:flex}.member-item{align-items:center;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-default);display:flex}.member-item:hover{background:var(--color-bg-subtle)}.member-item__avatar{border-radius:var(--radius-full);flex-shrink:0;width:32px;height:32px;overflow:hidden}.member-item__avatar img{object-fit:cover;width:100%;height:100%}.member-item__avatar-fallback{background:var(--color-primary-100);width:100%;height:100%;color:var(--color-primary-dark);font-weight:var(--font-bold);font-size:var(--text-xs);justify-content:center;align-items:center;display:flex}.member-item__info{flex:1;min-width:0}.member-item__name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.member-item__role{font-size:var(--text-xs);color:var(--color-text-subtle)}.member-item__role--owner{color:var(--color-streak);font-weight:var(--font-semibold)}.member-item__role--admin{color:var(--color-primary);font-weight:var(--font-medium)}.invite-code{align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--color-bg-subtle);border-radius:var(--radius-lg);border:1px dashed var(--color-border);margin-top:var(--space-4);display:flex}.invite-code__label{font-size:var(--text-xs);color:var(--color-text-muted)}.invite-code__value{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-primary);letter-spacing:.1em}.invite-code__copy{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;cursor:pointer;width:32px;height:32px;transition:all var(--duration-fast) var(--ease-default);border:none;justify-content:center;align-items:center;margin-left:auto;display:flex}.invite-code__copy:hover{background:var(--color-primary-dark)}.group-info{gap:var(--space-4);padding:0 var(--space-6) var(--space-6);flex-direction:column;display:flex}.group-info__desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed);padding:var(--space-3);background:var(--color-surface-container-low);border-radius:var(--radius-lg);border-left:3px solid var(--color-primary-light)}.group-info__members{gap:var(--space-2);flex-direction:column;display:flex}.group-info__members-title{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:var(--space-2);display:flex}.group-info__actions{padding-top:var(--space-4);border-top:1px solid var(--color-border-muted)}.member-item__you{font-size:var(--text-xs);color:var(--color-text-subtle);font-weight:var(--font-normal);margin-left:4px}.chat-gate{height:calc(100vh - var(--header-height) - 4rem);text-align:center;padding:var(--space-8);justify-content:center;align-items:center;gap:var(--space-5);background:radial-gradient(ellipse at 50% 30%, color-mix(in oklch, var(--color-primary) 6%, transparent), transparent 60%), var(--color-bg);flex-direction:column;display:flex}.chat-gate__icon{width:80px;height:80px;padding:var(--space-5);border-radius:var(--radius-3xl);background:linear-gradient(135deg, var(--color-primary-50), var(--color-primary-100));color:var(--color-primary);animation:3s ease-in-out infinite float-subtle}.chat-gate__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-text);letter-spacing:-.02em}.chat-gate__desc{font-size:var(--text-base);color:var(--color-text-muted);max-width:420px;line-height:var(--leading-relaxed)}.chat-loading{padding:var(--space-8);color:var(--color-text-muted);justify-content:center;align-items:center;gap:var(--space-2);display:flex}.chat-loading__dot{border-radius:var(--radius-full);background:var(--color-primary);width:8px;height:8px;animation:1.2s infinite chat-dot-bounce}.chat-loading__dot:nth-child(2){animation-delay:.2s}.chat-loading__dot:nth-child(3){animation-delay:.4s}@keyframes chat-dot-bounce{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-8px)}}
.eb-overlay{z-index:9999;-webkit-backdrop-filter:blur();backdrop-filter:blur();padding:var(--space-4);background:0 0;justify-content:center;align-items:center;transition:background .35s,-webkit-backdrop-filter .35s,backdrop-filter .35s;display:flex;position:fixed;inset:0}.eb-overlay--visible{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000008c}.eb-popup{background:var(--color-surface);border-radius:var(--radius-2xl);width:100%;max-width:460px;max-height:90vh;padding:var(--space-8) var(--space-6) var(--space-6);text-align:center;align-items:center;gap:var(--space-4);opacity:0;flex-direction:column;transition:opacity .4s cubic-bezier(.34,1.56,.64,1),transform .4s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative;overflow-y:auto;transform:scale(.85)translateY(30px);box-shadow:0 0 0 1px #4ade8026,0 24px 80px #0000004d,0 0 100px #4ade800d}.eb-popup--visible{opacity:1;transform:scale(1)translateY(0)}.eb-popup::-webkit-scrollbar{width:4px}.eb-popup::-webkit-scrollbar-track{background:0 0}.eb-popup::-webkit-scrollbar-thumb{background:var(--color-border-muted);border-radius:4px}.eb-popup__close{top:var(--space-3);right:var(--space-3);border-radius:var(--radius-full);background:var(--color-surface-container-high);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;z-index:10;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute}.eb-popup__close svg{width:16px;height:16px}.eb-popup__close:hover{background:var(--color-surface-container);color:var(--color-text);transform:rotate(90deg)}.eb-popup__confetti{pointer-events:none;border-radius:inherit;position:absolute;inset:0;overflow:hidden}.eb-popup__confetti-dot{border-radius:var(--radius-full);width:8px;height:8px;animation:3s ease-in-out infinite eb-confetti-float;position:absolute}.eb-popup__confetti-dot--1{background:#4ade80;animation-delay:0s;top:8%;left:10%}.eb-popup__confetti-dot--2{background:#60a5fa;animation-delay:.5s;top:15%;right:12%}.eb-popup__confetti-dot--3{background:#f472b6;width:6px;height:6px;animation-delay:1s;top:25%;left:20%}.eb-popup__confetti-dot--4{background:#fbbf24;width:6px;height:6px;animation-delay:1.5s;top:5%;right:25%}.eb-popup__confetti-dot--5{background:#a78bfa;width:5px;height:5px;animation-delay:2s;top:20%;left:5%}.eb-popup__confetti-dot--6{background:#f97316;width:5px;height:5px;animation-delay:.8s;top:10%;right:5%}@keyframes eb-confetti-float{0%,to{opacity:.6;transform:translateY(0)rotate(0)}50%{opacity:1;transform:translateY(-12px)rotate(180deg)}}.eb-popup__badge{padding:5px var(--space-4);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-primary);letter-spacing:.06em;text-transform:uppercase;background:linear-gradient(135deg,#4ade8026,#06b6d41a);border:1px solid #4ade8040;align-items:center;gap:6px;animation:2s ease-in-out infinite alternate eb-badge-glow;display:inline-flex}.eb-popup__badge-icon{width:14px;height:14px}@keyframes eb-badge-glow{0%{box-shadow:0 0 #4ade8000}to{box-shadow:0 0 16px 2px #4ade8026}}.eb-popup__hero-icon{justify-content:center;align-items:center;display:flex;position:relative}.eb-popup__hero-circle{border-radius:var(--radius-2xl);background:linear-gradient(135deg,#4ade80,#22d3ee);justify-content:center;align-items:center;width:72px;height:72px;animation:2.5s ease-in-out infinite eb-hero-pulse;display:flex;box-shadow:0 8px 32px #4ade804d}.eb-popup__hero-svg{color:#fff;width:32px;height:32px}.eb-popup__sparkle{color:#fbbf24;width:18px;height:18px;animation:1.5s ease-in-out infinite eb-sparkle;position:absolute}.eb-popup__sparkle--tl{animation-delay:0s;top:-4px;left:-14px}.eb-popup__sparkle--br{animation-delay:.75s;bottom:-4px;right:-14px}@keyframes eb-hero-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes eb-sparkle{0%,to{opacity:.5;transform:scale(.8)rotate(0)}50%{opacity:1;transform:scale(1.2)rotate(15deg)}}.eb-popup__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;line-height:1.2}.eb-popup__title-highlight{background:linear-gradient(135deg,#4ade80,#22d3ee);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.eb-popup__body{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi);max-width:380px;margin:0}.eb-popup__offer{border-radius:var(--radius-xl);background:linear-gradient(160deg,#4ade800a 0%,#06b6d408 50%,#a855f708 100%);border:1.5px solid #4ade8040;width:100%;overflow:hidden}.eb-popup__offer-ribbon{padding:8px var(--space-4);color:#fff;font-size:var(--text-xs);font-weight:var(--font-bold);letter-spacing:.04em;text-transform:uppercase;background:linear-gradient(135deg,#4ade80,#22d3ee);justify-content:center;align-items:center;gap:6px;display:flex}.eb-popup__offer-ribbon-icon{width:14px;height:14px}.eb-popup__offer-body{padding:var(--space-4);gap:var(--space-3);flex-direction:column;display:flex}.eb-popup__offer-row{justify-content:center;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text);font-weight:var(--font-medium);display:flex}.eb-popup__offer-heart{color:#f43f5e;width:16px;height:16px;animation:1.2s ease-in-out infinite eb-heart-beat}@keyframes eb-heart-beat{0%,to{transform:scale(1)}15%{transform:scale(1.25)}30%{transform:scale(1)}45%{transform:scale(1.15)}60%{transform:scale(1)}}.eb-popup__offer-price{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;display:flex}.eb-popup__offer-old{font-size:var(--text-base);color:var(--color-text-subtle);opacity:.6;text-decoration:line-through}.eb-popup__offer-arrow{font-size:var(--text-lg);color:var(--color-primary);font-weight:var(--font-bold)}.eb-popup__offer-new{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:var(--color-primary);letter-spacing:-.02em;text-shadow:0 0 20px #4ade804d;animation:2s ease-in-out infinite alternate eb-price-glow}@keyframes eb-price-glow{0%{text-shadow:0 0 20px #4ade8033}to{text-shadow:0 0 30px #4ade8066}}.eb-popup__offer-desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-vi);margin:0}.eb-popup__offer-perks{grid-template-columns:1fr 1fr;gap:6px;display:grid}.eb-popup__perk{color:var(--color-text);text-align:left;font-size:12px;line-height:1.4}.eb-popup__actions{gap:var(--space-2);flex-direction:column;width:100%;display:flex}.eb-popup__btn{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:13px var(--space-5);border-radius:var(--radius-xl);font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--font-bold);cursor:pointer;border:none;text-decoration:none;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:flex}.eb-popup__btn--primary{color:#fff;background:linear-gradient(135deg,#4ade80,#22d3ee);animation:2.5s ease-in-out infinite eb-btn-pulse;box-shadow:0 4px 20px #4ade804d,0 0 #4ade8000}.eb-popup__btn--primary:hover{transform:translateY(-2px)scale(1.02);box-shadow:0 6px 28px #4ade8066}.eb-popup__btn-icon{width:16px;height:16px;transition:transform .2s}.eb-popup__btn--primary:hover .eb-popup__btn-icon{transform:translate(4px)}@keyframes eb-btn-pulse{0%,to{box-shadow:0 4px 20px #4ade804d,0 0 #4ade8026}50%{box-shadow:0 4px 20px #4ade804d,0 0 0 6px #4ade8000}}.eb-popup__btn--ghost{color:var(--color-text-muted);font-weight:var(--font-medium);font-family:var(--font-body);background:0 0}.eb-popup__btn--ghost:hover{color:var(--color-text);background:var(--color-surface-container-low)}.eb-popup__footer-note{color:var(--color-text-subtle);margin:0;font-size:11px;font-style:italic}@media (max-width:480px){.eb-popup{padding:var(--space-6) var(--space-4) var(--space-4);max-height:92vh}.eb-popup__title{font-size:var(--text-xl)}.eb-popup__offer-new{font-size:var(--text-2xl)}.eb-popup__offer-perks{grid-template-columns:1fr}.eb-popup__hero-circle{width:60px;height:60px}.eb-popup__hero-svg{width:26px;height:26px}}.dark .eb-popup{box-shadow:0 0 0 1px #4ade801a,0 24px 80px #00000080,0 0 120px #4ade800a}.dark .eb-popup__offer{background:linear-gradient(160deg,#4ade800f 0%,#06b6d40a 50%,#a855f70a 100%)}
