.ui-panel{background:var(--accent-soft);color:var(--text-secondary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);border-left:3px solid var(--accent);padding:12px 14px;font-size:.9rem}.ui-panel strong{color:var(--text-primary)}.toggle-container{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-secondary);align-items:center;gap:12px;min-height:20px;font-size:.9rem;font-weight:500;display:inline-flex}.checkbox-wrapper{flex-shrink:0;width:16px;height:16px;position:relative}.checkbox-wrapper input{opacity:0;cursor:pointer;pointer-events:none;width:0;height:0;position:absolute}.checkmark{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:16px;height:16px;transition:background-color var(--transition-fast), border-color var(--transition-fast);position:absolute;top:0;left:0}.toggle-container:hover input:not(:disabled)~.checkmark{border-color:var(--accent)}.toggle-container input:checked~.checkmark{background-color:var(--accent);border-color:var(--accent)}.checkmark:after{content:"";display:none;position:absolute}.toggle-container input:checked~.checkmark:after{display:block}.toggle-container .checkmark:after{border:2px solid #fff;border-width:0 2px 2px 0;width:3px;height:8px;top:1px;left:5px;transform:rotate(45deg)}.label-text{line-height:1.2}.is-disabled input{cursor:not-allowed}.ui-input{border:1px solid var(--border-color);background:var(--bg-card);width:100%;color:var(--text-primary);font-family:var(--sans);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:12px 16px;font-size:.95rem;border-radius:var(--radius-sm)!important}.ui-input::placeholder{color:var(--text-muted)}.ui-input:focus{border-color:var(--accent);box-shadow:var(--shadow-glow)}.ui-input:disabled{opacity:.6;cursor:not-allowed}.custom-select{border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-family:var(--sans);cursor:pointer;appearance:none;width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236a6456' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:12px;outline:none;padding:10px 32px 10px 12px;font-size:.9rem;border-radius:var(--radius-sm)!important}.custom-select:hover:not(:disabled){border-color:var(--text-muted)}.custom-select:focus{border-color:var(--accent);box-shadow:var(--shadow-glow)}.custom-select:disabled{opacity:.35;cursor:not-allowed}:global(.dark) .custom-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23b3ab98' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E")}.dark .custom-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23b3ab98' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E")!important}.tabs-container.nav{border:1px solid var(--border-color);background:var(--bg-card);border-radius:var(--radius-sm);width:100%;display:flex;overflow:hidden}.tabs-container.nav .tab-item-link,.tabs-container.nav .tab-item-btn{color:var(--text-secondary);transition:background var(--transition-fast), color var(--transition-fast);text-align:center;cursor:pointer;background:0 0;flex:1;justify-content:center;align-items:center;padding:10px 4px;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex;border-right:1px solid var(--border-color)!important;border-top:none!important;border-bottom:none!important;border-left:none!important;border-radius:0!important}.tabs-container.nav .tab-item-link:last-child,.tabs-container.nav .tab-item-btn:last-child{border-right:none!important}.tabs-container.nav .tab-item-link.active,.tabs-container.nav .tab-item-btn.active{font-weight:700;background:var(--bg-active)!important;color:var(--text-active)!important}.tabs-container.nav.desktop-menu{background:0 0;border:none;border-radius:0;gap:2px;width:auto;overflow:visible}.tabs-container.nav.desktop-menu .tab-item-link,.tabs-container.nav.desktop-menu .tab-item-btn{color:var(--text-secondary);letter-spacing:.01em;flex:none;padding:8px 16px;font-weight:600;position:relative;background:0 0!important;border:none!important}.tabs-container.nav.desktop-menu .tab-item-link:after,.tabs-container.nav.desktop-menu .tab-item-btn:after{content:"";background:var(--accent);border-radius:var(--radius-pill);height:2px;transition:transform var(--transition-normal);position:absolute;bottom:0;left:16px;right:16px;transform:scaleX(0)}.tabs-container.nav.desktop-menu .tab-item-link:hover,.tabs-container.nav.desktop-menu .tab-item-btn:hover{color:var(--text-primary);background:0 0!important}.tabs-container.nav.desktop-menu .tab-item-link:hover:after,.tabs-container.nav.desktop-menu .tab-item-btn:hover:after{transform:scaleX(.5)}.tabs-container.nav.desktop-menu .tab-item-link.active,.tabs-container.nav.desktop-menu .tab-item-btn.active{color:var(--text-primary)!important;background:0 0!important}.tabs-container.nav.desktop-menu .tab-item-link.active:after,.tabs-container.nav.desktop-menu .tab-item-btn.active:after{transform:scaleX(1)}.tabs-container.pills{background:0 0;border:none;flex-wrap:wrap;gap:8px;display:flex}.tabs-container.pills .tab-item-btn{color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast) ease;background:0 0;padding:8px 14px;font-size:.85rem;font-weight:600;border:1px solid var(--border-color)!important;border-radius:var(--radius-sm)!important}.tabs-container.pills .tab-item-btn:hover{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent)!important}.tabs-container.pills .tab-item-btn.active{background:var(--bg-active)!important;color:var(--text-active)!important;border-color:var(--bg-active)!important}.modal-backdrop{-webkit-backdrop-filter:blur(3px);z-index:100;background:#1a18146b;justify-content:center;align-items:center;padding:20px;animation:.25s backdropFade;display:flex;position:fixed;inset:0}@keyframes backdropFade{0%{opacity:0}to{opacity:1}}.modal-content{flex-direction:column;width:100%;max-width:420px;padding:24px;animation:.3s cubic-bezier(.34,1.56,.64,1) modalScale;display:flex;position:relative;border-radius:var(--radius-card)!important;border:1px solid var(--border-subtle)!important;box-shadow:var(--shadow-lg)!important;background:var(--bg-card)!important}.modal-close{border:1px solid var(--border-color);background:var(--bg-card);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;z-index:10;justify-content:center;align-items:center;padding:0;font-size:.85rem;display:flex;position:absolute;top:16px;right:16px;border-radius:var(--radius-sm)!important}.modal-close:hover{background:var(--bg-active);color:var(--text-active);border-color:var(--bg-active)}@keyframes modalScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.theme-toggle{color:var(--text-primary);justify-content:center;align-items:center;padding:4px;font-size:1.2rem;display:inline-flex;background:0 0!important;border:none!important}.theme-toggle:hover:not(:disabled){background-color:var(--bg-subtle)!important;color:var(--text-primary)!important}.desktop-menu{display:none!important}@media (width>=768px){.desktop-menu{display:flex!important}}.mobile-menu{display:none!important}@media (width<=767px){.mobile-menu{z-index:100;padding-bottom:env(safe-area-inset-bottom);-webkit-backdrop-filter:blur(10px)saturate(1.1);position:fixed;bottom:0;left:0;right:0;background:color-mix(in srgb, var(--bg-card) 88%, transparent)!important;border-top:1px solid var(--border-subtle)!important;border-bottom:none!important;border-left:none!important;border-right:none!important;border-radius:0!important;margin:0!important;display:flex!important;box-shadow:0 -4px 16px #211f1a0f!important}.mobile-menu .tab-item-link,.mobile-menu .tab-item-btn{transition:color var(--transition-fast);font-size:.82rem;position:relative;color:var(--text-secondary)!important;border-right:none!important;padding:13px 4px!important}.mobile-menu .tab-item-link:before,.mobile-menu .tab-item-btn:before{content:"";background:var(--accent);border-radius:var(--radius-pill);width:26px;height:2px;transition:transform var(--transition-normal);position:absolute;top:0;left:50%;transform:translate(-50%)scaleX(0)}.mobile-menu .tab-item-link.active,.mobile-menu .tab-item-btn.active{font-weight:700;color:var(--accent)!important;background:0 0!important}.mobile-menu .tab-item-link.active:before,.mobile-menu .tab-item-btn.active:before{transform:translate(-50%)scaleX(1)}}.app-header{-webkit-backdrop-filter:blur(10px)saturate(1.1);z-index:50;grid-template-columns:1fr minmax(auto,600px) 1fr;align-items:center;gap:16px;width:100%;padding:12px 24px;display:grid;position:sticky;top:0;border-bottom:1px solid var(--border-subtle)!important;background:color-mix(in srgb, var(--bg-app) 82%, transparent)!important;box-shadow:var(--shadow-sm)!important;border-top:none!important;border-left:none!important;border-right:none!important;border-radius:0!important;margin-bottom:24px!important}.logo-area{cursor:pointer;white-space:nowrap;flex-shrink:0;justify-self:start;align-items:center;gap:10px;display:flex}.logo-area .logo-icon{filter:drop-shadow(0 1px 2px #211f1a1f);flex-shrink:0;width:30px;height:30px}.logo-lockup{white-space:nowrap;flex-direction:column;line-height:1.05;display:flex}.logo-title{font-family:var(--font-hanzi);letter-spacing:.01em;color:var(--text-primary);font-size:1.05rem;font-weight:700}.logo-sub{font-family:var(--font-serif);letter-spacing:.28em;color:var(--accent);margin-top:1px;font-size:.66rem;font-weight:500}.header-menu-center{justify-content:center;justify-self:center;align-items:center;width:100%;display:flex}.header-menu-center .desktop-menu{width:100%!important;margin-bottom:0!important}.header-actions{justify-self:end;align-items:center;gap:8px;display:flex}.header-btn{color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast) ease;background:0 0;padding:6px 12px;font-size:.75rem}.header-btn:hover:not(:disabled){background-color:var(--bg-active);color:var(--text-active);border-color:var(--bg-active)}.header-btn:disabled{opacity:.5;cursor:default}.auth-btn{font-family:var(--sans)}@media (width<=767px){.app-header{justify-content:space-between;gap:8px;padding:10px 16px;display:flex;margin-bottom:16px!important}.logo-area{gap:8px}.logo-area .logo-icon{width:26px;height:26px}.logo-title{white-space:nowrap;font-size:.98rem}.logo-sub{letter-spacing:.22em;font-size:.6rem}.header-menu-center{display:none!important}}.filter-checkbox{pointer-events:none}.dropdown-divider{background-color:var(--border-color);height:1px;margin:4px 0}.select-all-item{font-weight:600}.dropdown-checkbox-wrapper{align-items:center;padding-right:4px;display:flex}.dropdown-label-wrapper{cursor:pointer;flex:1;justify-content:space-between;align-items:center;display:flex}.dropdown-label-text{color:var(--text-secondary);font-size:.9rem;font-weight:500}.only-indicator{text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border-color);opacity:0;transition:opacity var(--transition-fast) ease, color var(--transition-fast) ease;margin-left:8px;padding:1px 4px;font-size:.65rem;font-weight:700;line-height:1}.dropdown-label-wrapper:hover .only-indicator{opacity:1;color:var(--accent);border-color:var(--accent)}.dropdown-filter{width:100%;position:relative}.dropdown-trigger{background:var(--bg-card);border:1px solid var(--border-color);width:100%;color:var(--text-primary);font-family:var(--sans);text-align:left;cursor:pointer;transition:border-color var(--transition-fast), background-color var(--transition-fast);outline:none;justify-content:space-between;align-items:center;padding:10px 12px;font-size:.9rem;display:flex}.dropdown-trigger:hover:not(:disabled){border-color:var(--text-muted)}.dropdown-trigger:focus{border-color:var(--accent);box-shadow:var(--shadow-glow)}.trigger-text{text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:8px;overflow:hidden}.trigger-arrow{width:12px;height:12px;transition:transform var(--transition-fast) ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236a6456' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:contain;flex-shrink:0}.is-open .trigger-arrow{transform:rotate(180deg)}.dark .trigger-arrow{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23b3ab98' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E")!important}.dropdown-menu{z-index:100;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-lg);max-height:250px;margin-top:6px;position:absolute;top:100%;left:0;overflow-y:auto}.dark .dropdown-menu{box-shadow:0 4px 16px #00000080!important}.dropdown-options{padding:4px 0}.dropdown-item{cursor:pointer;transition:background-color var(--transition-fast);align-items:center;padding:8px 12px;display:flex}.dropdown-item:hover{background-color:var(--bg-subtle)}.is-disabled{opacity:.5;cursor:not-allowed}.is-disabled .dropdown-trigger{cursor:not-allowed}.page-intro{align-items:center;gap:16px;margin-bottom:4px;padding:8px 4px 20px;display:flex;position:relative;overflow:hidden}.page-intro-mark{font-family:var(--font-hanzi);color:var(--accent);opacity:.14;-webkit-user-select:none;user-select:none;flex-shrink:0;margin-left:-4px;font-size:4.6rem;font-weight:900;line-height:.9}.page-intro-text{flex-direction:column;gap:4px;display:flex}.page-intro-title{font-family:var(--font-hanzi);letter-spacing:.02em;color:var(--text-primary);text-align:left;border:none;margin:0;padding:0;font-size:1.7rem;font-weight:700}.page-intro-title:after{display:none}.page-intro-sub{color:var(--text-secondary);word-break:keep-all;margin:0;font-size:.88rem}@media (width<=600px){.page-intro-mark{font-size:3.4rem}.page-intro-title{font-size:1.4rem}}.section-title{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:2px;padding-bottom:6px;display:flex}.section-title-label{font-family:var(--font-serif);color:var(--text-primary);letter-spacing:.02em;padding-left:11px;font-size:.95rem;font-weight:600;position:relative}.section-title-label:before{content:"";background:var(--accent);border-radius:var(--radius-pill);width:3px;height:.95em;position:absolute;top:50%;left:0;transform:translateY(-50%)}.section-title-hint{color:var(--text-muted);text-align:right;white-space:nowrap;font-size:.76rem;font-weight:500}.stat-tile{background:var(--bg-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius-md);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:16px 8px;display:flex}.stat-tile-value{font-family:var(--font-serif);color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:1.7rem;font-weight:700;line-height:1.1}.stat-tile-label{color:var(--text-secondary);font-size:.76rem;font-weight:500}.stat-tile.unk .stat-tile-value,.stat-tile.positive .stat-tile-value{color:var(--color-unknown)}.stat-tile.know .stat-tile-value,.stat-tile.neutral .stat-tile-value{color:var(--color-known)}.stat-tile.mast .stat-tile-value,.stat-tile.negative .stat-tile-value{color:var(--color-mastered)}.progress-ring{flex-shrink:0;position:relative}.progress-ring-fill{transition:stroke-dashoffset var(--transition-normal)}.progress-ring-center{flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex;position:absolute;inset:0}.progress-ring-value{font-family:var(--font-serif);color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:1.6rem;font-weight:700;line-height:1}.progress-ring-sub{color:var(--text-muted);font-size:.7rem;font-weight:500}.sticky-action-bar{display:none}@media (width<=767px){.sticky-action-bar{left:0;right:0;bottom:calc(50px + env(safe-area-inset-bottom));z-index:90;background:color-mix(in srgb, var(--bg-card) 92%, transparent);-webkit-backdrop-filter:blur(10px)saturate(1.1);border-top:1px solid var(--border-subtle);align-items:center;gap:12px;padding:10px 16px;display:flex;position:fixed;box-shadow:0 -4px 16px #211f1a12}.sticky-action-info{color:var(--text-secondary);flex-shrink:0;font-size:.8rem;font-weight:600;line-height:1.2}.sticky-action-info strong{color:var(--accent-strong)}.sticky-action-cta{flex:1}.sticky-action-cta button{width:100%}}.home-view{flex-direction:column;align-items:center;gap:28px;padding-top:8px;display:flex}.home-hero{text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}.home-logo-frame{justify-content:center;align-items:center;padding:18px 28px;display:flex}.home-logo{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:260px;max-width:62vw;height:auto;display:block}.dark .home-logo{filter:invert()}.home-tagline{font-family:var(--font-serif);color:var(--text-secondary);letter-spacing:.02em;word-break:keep-all;margin:0;font-size:1rem}.home-menu{grid-template-columns:1fr;gap:12px;width:100%;max-width:720px;display:grid}@media (width>=640px){.home-menu{grid-template-columns:1fr 1fr;gap:14px}}.home-menu-card{text-align:left;cursor:pointer;background:var(--bg-card);border:1px solid var(--border-subtle);width:100%;transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);align-items:center;gap:16px;padding:18px 20px;display:flex}.home-menu-card .incorrect-badge{color:var(--text-muted);background-color:var(--bg-subtle);border:1px solid var(--border-color);transition:all var(--transition-fast) ease;border-radius:999px;padding:1px 7px;font-size:.72rem;font-weight:700}.home-menu-card .incorrect-badge.active{color:#fff;background-color:var(--color-unknown);border-color:var(--color-unknown)}.home-menu-card:hover:not(:disabled){border-color:var(--accent);background:var(--bg-card);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.home-menu-card:hover:not(:disabled) .home-menu-arrow{color:var(--accent);transform:translate(4px)}.home-menu-card:hover:not(:disabled) .home-menu-glyph{color:var(--accent)}.home-menu-card:active{transform:translateY(-1px)}.home-menu-glyph{width:52px;height:52px;font-family:var(--font-hanzi);color:var(--text-primary);background:var(--accent-soft);border-radius:var(--radius-md);transition:color var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;font-size:2rem;font-weight:700;display:flex}.home-menu-text{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.home-menu-title-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;width:100%;display:flex}.home-menu-title{font-family:var(--font-serif);color:var(--text-primary);letter-spacing:.01em;font-size:1.05rem;font-weight:700}.home-menu-account{-webkit-user-select:text;user-select:text;font-size:.75rem;font-weight:500}.home-menu-account .account-email{border:1px solid #0000;border-radius:9999px;align-items:center;padding:2px 8px;display:inline-flex}.home-menu-account .account-email.active{color:#27ae60;background:#27ae6014;border-color:#27ae6033}.home-menu-account .account-email.inactive{color:var(--text-muted,#718096);background:var(--bg-subtle,#f1f5f9);border-color:var(--border-color,#e2e8f0);cursor:pointer;transition:all var(--transition-fast) ease}.home-menu-account .account-email.inactive:hover{color:var(--text-primary);border-color:var(--text-muted);transform:translateY(-.5px)}.home-menu-desc{color:var(--text-secondary);word-break:keep-all;font-size:.82rem}.home-menu-arrow{color:var(--text-muted);transition:transform var(--transition-fast), color var(--transition-fast);flex-shrink:0;font-size:1.1rem}@media (width<=480px){.home-logo{width:200px}.home-tagline{font-size:.9rem}}.settings-view{flex-direction:column;display:flex}.settings-layout{grid-template-columns:1fr;align-items:start;gap:20px;display:grid}@media (width>=860px){.settings-layout{grid-template-columns:minmax(0,1fr) 320px}}.config-card{border-radius:var(--radius-card);flex-direction:column;gap:26px;padding:24px;display:flex}.settings-section{flex-direction:column;gap:14px;display:flex}.form-group{text-align:left;flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.form-group .range-label-row{justify-content:space-between;align-items:center;width:100%;display:flex}.form-group .range-label-row label{margin:0}.form-group .range-label-row .range-val{color:var(--accent);font-size:.85rem;font-weight:700}.form-group .range-slider{cursor:pointer;width:100%;height:38px;accent-color:var(--accent)}.form-row{flex-wrap:wrap;gap:16px;display:flex}.form-row .form-group{min-width:140px}.toggle-options{text-align:left;flex-direction:column;gap:14px;display:flex}@media (width>=860px){.settings-summary{position:sticky;top:90px}}.summary-panel{border-radius:var(--radius-card);flex-direction:column;gap:16px;padding:20px;display:flex}.summary-pool{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.summary-pool .summary-pool-count{font-family:var(--font-serif);color:var(--accent);font-variant-numeric:tabular-nums;font-size:2.6rem;font-weight:700;line-height:1}.summary-pool .summary-pool-unit{color:var(--text-secondary);font-size:.85rem;font-weight:500}.summary-dist{flex-direction:column;gap:8px;display:flex}.summary-dist .progress-bar-multi-sm{height:8px}.summary-dist-legend{flex-wrap:wrap;gap:4px 14px;font-size:.76rem;font-weight:600;display:flex}.summary-dist-legend .leg{color:var(--text-secondary);padding-left:13px;position:relative}.summary-dist-legend .leg:before{content:"";border-radius:var(--radius-pill);width:8px;height:8px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.summary-dist-legend .leg.unk:before{background:var(--segment-unk)}.summary-dist-legend .leg.know:before{background:var(--segment-know)}.summary-dist-legend .leg.mast:before{background:var(--segment-mast)}.start-round-btn{border-radius:var(--radius-sm);padding:14px 20px;font-size:1.02rem}.summary-start{width:100%}@media (width<=859px){.summary-start{display:none}}@media (width<=767px){.settings-view{padding-bottom:64px}}.hanja-card{cursor:default;width:100%;min-height:280px;transition:transform var(--transition-normal), background var(--transition-normal);-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:space-between;padding:24px;display:flex;border-radius:var(--radius-card)!important}.hanja-card.phase-2-hidden{cursor:pointer}.hanja-card.phase-2-hidden:hover{transform:translateY(-3px);background:var(--bg-card-hover)!important;box-shadow:var(--shadow-lg)!important}.card-header{width:100%;color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.card-star-btn{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;margin-left:auto;padding:0 4px;font-size:1.3rem;line-height:1}.card-star-btn:hover{color:#f1c40f}.card-star-btn.starred{color:#f39c12}.stroke-details{opacity:.9;color:var(--text-primary);font-weight:600}.card-body{text-align:center;flex-direction:column;flex-grow:1;justify-content:center;align-items:center;padding:16px 0;display:flex}.meaning-view,.answer-view{flex-direction:column;align-items:center;animation:.35s cubic-bezier(.4,0,.2,1) fadeIn;display:flex}.label{letter-spacing:.05em;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;font-size:.85rem;font-weight:600}.meaning-text{color:var(--text-primary);word-break:keep-all;font-size:2.5rem;font-weight:700;line-height:1.2}.hint-text{color:var(--text-muted);border:1px dashed var(--text-muted);margin-top:24px;padding:6px 12px;font-size:.85rem;animation:2s ease-in-out infinite pulse;border-radius:var(--radius-sm)!important}.hanja-display{font-family:var(--font-hanzi);color:var(--text-primary);margin-bottom:8px;font-size:5.5rem;font-weight:700;line-height:1;text-shadow:none!important}.sound-display{color:var(--text-primary);margin-bottom:8px;font-size:1.8rem;font-weight:700}.full-meaning-detail{color:var(--text-secondary);word-break:keep-all;max-width:80%;font-size:.95rem}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)translateY(4px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}.pinyin-container{background:var(--bg-subtle);border:1px solid var(--border-color);align-items:center;gap:8px;margin-top:4px;margin-bottom:16px;padding:6px 12px;display:flex;border-radius:var(--radius-sm)!important}.pinyin-label{color:var(--text-muted);font-size:.8rem;font-weight:500}.pinyin-value{color:var(--text-primary);font-size:1.1rem;font-weight:700;font-family:var(--sans)}.tts-play-btn{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast) ease;color:var(--text-primary);justify-content:center;align-items:center;padding:4px 10px;font-size:.8rem;font-weight:600;display:inline-flex;border-radius:var(--radius-sm)!important}.tts-play-btn:hover{background:var(--bg-active);border-color:var(--bg-active);color:var(--text-active)}.tts-play-btn:active{transform:translateY(0)}.hanzi-pad{flex-direction:column;align-items:center;gap:16px;width:100%;display:flex}.hanzi-pad .pad-canvas{aspect-ratio:1;border:1.5px dashed var(--border-color);background:var(--bg-subtle);touch-action:none;border-radius:12px;width:300px;max-width:80vw;transition:border-color .2s,box-shadow .2s}.hanzi-pad .pad-canvas svg{width:100%;height:100%;display:block}.hanzi-pad .pad-canvas.done{border-style:solid;border-color:var(--color-correct);box-shadow:0 0 0 3px var(--color-correct-bg)}.hanzi-pad .pad-controls{justify-content:center;gap:12px;width:100%;display:flex}.hanzi-pad .pad-btn{cursor:pointer;padding:10px 16px;font-size:.85rem;font-weight:600}.hanzi-pad.load-error{text-align:center;color:var(--text-secondary);word-break:keep-all;padding:24px 16px;font-size:.9rem;line-height:1.5}.study-view{flex-direction:column;gap:16px;display:flex}.session-view{flex-direction:column;display:flex}.session-layout{grid-template-columns:1fr;align-items:start;gap:16px;display:grid}@media (width>=860px){.session-layout{grid-template-columns:248px minmax(0,1fr);gap:28px}.session-rail{position:sticky;top:90px}}.session-rail-inner{flex-direction:column;gap:16px;padding:16px;display:flex}.session-rail-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.session-rail-head .quit-btn{flex-shrink:0}.session-progress{flex-direction:column;gap:8px;display:flex}.session-hint{color:var(--text-muted);letter-spacing:.02em;font-size:.74rem}.session-main{flex-direction:column;gap:16px;display:flex}@media (width>=860px){.session-main{max-width:var(--w-focus);width:100%;margin:0 auto}}@media (width<=859px){.session-hint{display:none}.session-rail-inner{flex-flow:wrap;align-items:center;gap:12px;padding:12px 16px}.session-rail-head{flex:100%}.session-progress{flex-direction:row;flex:100%;align-items:center;gap:12px}.session-progress .progress-bar-container{flex:1}}.study-header{border-radius:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.phase-info{align-items:center;gap:8px;display:flex}.phase-badge{font-size:.75rem}.phase-badge.p1{background:var(--bg-subtle);color:var(--text-primary)}.phase-badge.p2{background:var(--bg-subtle);color:var(--text-secondary);border:1px solid var(--text-secondary)}.round-progress-text{color:var(--text-secondary);align-items:baseline;gap:4px;font-size:.9rem;display:flex}.round-progress-text strong{font-family:var(--font-serif);color:var(--accent);font-variant-numeric:tabular-nums;font-size:1.5rem;font-weight:700;line-height:1}.round-progress-text i{color:var(--text-muted);font-style:normal}.quit-btn{border-radius:0;padding:6px 12px;font-size:.85rem}.progress-bar-container{background:var(--progress-track);border-radius:0;width:100%;height:3px;overflow:hidden}.progress-bar{background:var(--accent);height:100%;transition:width var(--transition-normal)}.card-area{margin:8px 0}.tracing-card{flex-direction:column;align-items:center;gap:20px;padding:24px 16px;display:flex}.tracing-card .tracing-prompt{text-align:center}.tracing-card .tracing-prompt .label{color:var(--text-secondary);margin-bottom:8px;font-size:.8rem;font-weight:600;display:block}.tracing-card .tracing-prompt .meaning-text{color:var(--text-primary);word-break:keep-all;font-size:1.25rem;font-weight:700}.tracing-card .tracing-fallback{flex-direction:column;align-items:center;gap:8px;display:flex}.tracing-card .tracing-fallback .fallback-note{color:var(--text-muted);text-align:center;word-break:keep-all;margin-bottom:8px;font-size:.82rem}.tracing-card .tracing-fallback .answer-hanja{font-family:var(--font-hanzi);color:var(--text-primary);font-size:5rem;line-height:1}.tracing-card .tracing-fallback .answer-sound{color:var(--text-secondary);font-size:1rem;font-weight:600}.trace-hint{text-align:center;color:var(--text-muted);padding:12px 0;font-size:.9rem;font-weight:600}.study-controls{flex-direction:column;justify-content:center;min-height:140px;display:flex}.phase-nav-btns{gap:16px;display:flex}.nav-btn{flex:1;padding:12px 20px;font-size:.95rem}.reveal-btn{width:100%;padding:14px 20px;font-size:1rem}.grading-panel{flex-direction:column;align-items:center;gap:12px;display:flex}.grading-title{color:var(--text-secondary);font-size:.85rem;font-weight:600}.status-options{gap:8px;width:100%;display:flex}.status-options .status-btn{border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);border-radius:0;flex:1;padding:12px 6px;font-size:.9rem;font-weight:600}.status-options .status-btn.unk:hover{background-color:var(--bg-subtle);color:var(--color-unknown);border-color:var(--color-unknown)}.status-options .status-btn.unk.active{background-color:var(--segment-unk);color:var(--text-active);border-color:var(--segment-unk)}.status-options .status-btn.know:hover{background-color:var(--bg-subtle);color:var(--color-known);border-color:var(--color-known)}.status-options .status-btn.know.active{background-color:var(--segment-know);color:var(--text-active);border-color:var(--segment-know)}.status-options .status-btn.mast:hover{background-color:var(--bg-subtle);color:var(--color-mastered);border-color:var(--color-mastered)}.status-options .status-btn.mast.active{background-color:var(--segment-mast);color:var(--text-active);border-color:var(--segment-mast)}.manual-nav{justify-content:space-between;width:100%;margin-top:8px;display:flex}.nav-btn-sm{border-radius:0;padding:6px 12px;font-size:.8rem}.speak-btn{border-color:var(--border-color)}.choices-container{grid-template-columns:1fr;gap:12px;width:100%;margin-top:16px;padding:0 4px;display:grid}@media (width>=600px){.choices-container{grid-template-columns:1fr 1fr}}.choice-btn{text-align:left;background:var(--bg-card);cursor:pointer;transition:all var(--transition-fast) ease;color:var(--text-primary);align-items:center;gap:12px;width:100%;padding:16px;font-size:1.1rem;font-weight:600;display:flex;border:1px solid var(--border-color)!important;border-radius:var(--radius-sm)!important}.choice-btn:hover:not(:disabled){border-color:var(--accent)!important;background:var(--accent-soft)!important}.choice-btn:disabled{cursor:default}.choice-btn.correct{background-color:var(--color-correct-bg)!important;border-color:var(--color-correct)!important;color:var(--color-correct)!important}.choice-btn.correct .choice-index{background-color:var(--color-correct)!important;color:#fff!important;border-color:var(--color-correct)!important}.choice-btn.incorrect{background-color:var(--color-incorrect-bg)!important;border-color:var(--color-incorrect)!important;color:var(--color-incorrect)!important}.choice-btn.incorrect .choice-index{background-color:var(--color-incorrect)!important;color:#fff!important;border-color:var(--color-incorrect)!important}.choice-btn.faded{opacity:.45}.choice-index{background:var(--bg-subtle);width:26px;height:26px;color:var(--text-secondary);border:1px solid var(--border-color);flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:inline-flex;border-radius:50%!important}.question-hanja{margin-top:12px;margin-bottom:12px;font-size:7rem!important}.summary-view{flex-direction:column;align-items:center;display:flex}.summary-card{border-radius:var(--radius-card);text-align:center;width:100%;max-width:var(--w-focus);flex-direction:column;align-items:center;padding:44px 28px 32px;display:flex}.summary-seal{width:72px;height:72px;font-family:var(--font-hanzi);color:#fff;background:var(--accent);border:2px solid var(--accent-strong);box-shadow:var(--shadow-md);border-radius:18px;justify-content:center;align-items:center;margin-bottom:18px;font-size:2.6rem;font-weight:900;animation:.4s cubic-bezier(.34,1.56,.64,1) sealPop;display:flex}.dark .summary-seal{color:var(--text-active)}@keyframes sealPop{0%{opacity:0;transform:scale(.6)rotate(-8deg)}to{opacity:1;transform:scale(1)rotate(0)}}.summary-title{font-family:var(--font-hanzi);color:var(--text-primary);letter-spacing:.03em;margin-bottom:6px;font-size:1.6rem;font-weight:700}.summary-desc{color:var(--text-secondary);margin-bottom:28px;font-size:.95rem}.summary-desc strong{color:var(--accent-strong);font-weight:700}.summary-results-grid{gap:10px;width:100%;margin-bottom:28px;display:flex}.summary-actions{flex-direction:column;gap:10px;width:100%;display:flex}.action-btn{border-radius:var(--radius-sm);padding:13px;font-size:.95rem}.hanja-stroke-animator{flex-direction:column;align-items:center;gap:12px;width:100%;display:flex}.hanja-stroke-animator .animator-canvas-frame{border:1px solid var(--border-color);border-radius:var(--radius-card);background-color:var(--bg-card);box-shadow:var(--shadow-sm);box-sizing:border-box;transition:border-color var(--transition-fast), background-color var(--transition-fast);justify-content:center;align-items:center;padding:8px;display:flex}.hanja-stroke-animator .anim-replay-btn{border:1px solid var(--border-color);border-radius:var(--radius-pill);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast) ease;-webkit-user-select:none;user-select:none;background:0 0;padding:6px 14px;font-size:.75rem;font-weight:600}.hanja-stroke-animator .anim-replay-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background-color:var(--accent-soft)}.hanja-stroke-animator .anim-replay-btn:disabled{color:var(--text-muted);border-color:var(--border-subtle);cursor:default}.modal-header{justify-content:flex-start;align-items:center;gap:12px;margin-bottom:12px;display:flex}.modal-star-btn{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:0 4px;font-size:1.4rem;line-height:1}.modal-star-btn:hover{color:#f1c40f}.modal-star-btn.starred{color:#f39c12}.modal-body{text-align:center;flex-direction:column;align-items:center;margin-bottom:24px;display:flex}.detail-hanja-anim-wrap{justify-content:center;align-items:center;margin-top:4px;margin-bottom:12px;display:flex}.detail-sound{font-family:var(--font-serif);color:var(--text-primary);margin-bottom:16px;font-size:1.8rem;font-weight:700}.detail-grid{background:var(--bg-subtle);border:1px solid var(--border-subtle);gap:16px;width:100%;margin-bottom:16px;padding:10px 16px;display:flex;border-radius:var(--radius-md)!important}.detail-cell{flex-direction:column;padding:4px 8px;display:flex}.detail-cell .lbl{color:var(--text-muted);margin-bottom:2px;font-size:.75rem;font-weight:600}.detail-cell .val{color:var(--text-primary);font-size:.95rem;font-weight:700}.detail-desc{color:var(--text-secondary);word-break:keep-all;font-size:.85rem;line-height:1.4}.modal-footer{border-top:1px solid var(--border-color);flex-direction:column;gap:10px;padding-top:16px;display:flex}.status-buttons{gap:8px;display:flex}.status-btn{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:0 0;flex:1;padding:9px 4px;font-size:.85rem;font-weight:600;border-radius:var(--radius-sm)!important}.status-btn.unk.active{background-color:var(--segment-unk);color:var(--text-active);border-color:var(--segment-unk)}.status-btn.know.active{background-color:var(--segment-know);color:var(--text-active);border-color:var(--segment-know)}.status-btn.mast.active{background-color:var(--segment-mast);color:var(--text-active);border-color:var(--segment-mast)}.modal-tts-section{justify-content:center;gap:12px;width:100%;margin-top:20px;display:flex}.modal-tts-btn{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast) ease;color:var(--text-primary);align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:600;display:inline-flex;border-radius:var(--radius-sm)!important}.modal-tts-btn:hover{background:var(--bg-active);border-color:var(--bg-active);color:var(--text-active)}.modal-tts-btn:active{transform:translateY(0)}.flex-1{flex:1}.flex-2{flex:2}.rad-meaning{color:var(--text-muted);font-size:.75rem;font-weight:500}.pinyin-val{font-family:var(--sans);color:var(--text-primary)!important}.mode-status-row{flex-direction:column;gap:6px;width:100%;margin-bottom:12px;display:flex}.mode-status-row:last-child{margin-bottom:0}.mode-status-label{color:var(--text-secondary);text-align:left;font-size:.8rem;font-weight:700}.modal-print-section{justify-content:center;width:100%;margin-top:12px;display:flex}.modal-print-section .modal-print-btn{width:100%;padding:10px 16px;font-weight:700}@media (width<=767px){.modal-print-section{display:none!important}}.hanja-grid-card{text-align:center;cursor:pointer;background:var(--bg-card);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);flex-direction:column;align-items:center;padding:14px 8px;display:flex;position:relative;border-radius:var(--radius-md)!important}.hanja-grid-card:hover{background:var(--bg-card);border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.hanja-grid-card.selection-mode{border-color:var(--border-subtle)}.hanja-grid-card.selection-mode:hover{background:var(--bg-card);border-color:var(--accent)}.hanja-grid-card.is-selected{box-shadow:0 0 0 1.5px var(--accent);background-color:var(--accent-soft)!important;border-color:var(--accent)!important}.card-checkbox-wrapper{cursor:pointer;z-index:5;justify-content:center;align-items:center;display:flex;position:absolute;top:6px;right:8px}.card-checkbox-wrapper .card-checkbox{cursor:pointer;width:16px;height:16px;accent-color:var(--accent);margin:0}.grid-hanja{font-family:var(--font-hanzi);color:var(--text-primary);margin-bottom:2px;font-size:2.2rem;font-weight:700;line-height:1.1}.grid-pinyin{color:var(--text-muted);font-size:.75rem;font-family:var(--sans);margin-bottom:4px;font-weight:500}.grid-sound{color:var(--text-primary);word-break:keep-all;margin-bottom:8px;font-size:.85rem;font-weight:700}.card-star{color:#f39c12;font-size:.95rem;position:absolute;top:6px;right:8px}.grid-status-badges{flex-direction:column;gap:4px;width:100%;margin-top:6px;display:flex}.badge-mini{text-align:center;width:100%;display:block;padding:1px 6px!important;font-size:.65rem!important;font-weight:500!important}.library-container{flex-direction:column;gap:16px;width:100%;display:flex}.filters-card{border:1px solid var(--border-subtle);box-shadow:var(--shadow-md);flex-direction:column;gap:12px;padding:18px;display:flex;border-radius:var(--radius-card)!important}.search-box{width:100%;position:relative}.search-input{border:1px solid var(--border-color);background:var(--bg-card);width:100%;color:var(--text-primary);font-family:var(--sans);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:12px 40px 12px 16px;font-size:.95rem;border-radius:var(--radius-sm)!important}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--accent);box-shadow:var(--shadow-glow)}.search-icon{pointer-events:none;opacity:.6;font-size:1rem;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.clear-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:.9rem;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.filter-selectors{flex-wrap:wrap;gap:12px;display:flex}.filter-group{min-width:150px}.starred-filter-row{align-items:center;margin-top:4px;display:flex}.filter-group{flex-direction:column;flex:1;gap:6px;display:flex}.filter-group label{color:var(--text-secondary);text-align:left;font-size:.75rem;font-weight:700}.filter-select{border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-family:var(--sans);cursor:pointer;outline:none;padding:10px 12px;font-size:.9rem;border-radius:var(--radius-sm)!important}.filter-select:focus{border-color:var(--border-focus)}.results-info-row{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.results-info{color:var(--text-secondary);text-align:left;font-size:.85rem;font-weight:700}.results-info .selected-count{color:var(--accent);font-weight:700}.selection-actions{gap:8px;display:flex}.selection-actions .selection-toggle-btn{padding:6px 12px;font-size:.8rem}.selection-actions .selection-toggle-btn.active{background-color:var(--accent);color:#fff;border-color:var(--accent)}.selection-toolbar{border:1px solid var(--border-subtle);background:var(--accent-soft);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:16px;animation:.25s cubic-bezier(.4,0,.2,1) slideDown;display:flex;border-radius:var(--radius-card)!important}.selection-toolbar .selected-hanja-tags-row{align-items:flex-start;gap:8px;width:100%;display:flex}.selection-toolbar .selected-hanja-tags-row .tags-label{color:var(--text-primary);flex-shrink:0;margin-top:5px;font-size:.8rem;font-weight:700}.selection-toolbar .selected-hanja-tags-row .tags-container{flex-wrap:wrap;flex:1;gap:6px;max-height:120px;padding-right:4px;display:flex;overflow-y:auto}.selection-toolbar .selected-hanja-tags-row .hanja-block-card{background-color:var(--bg-card);border:1px solid var(--border-color);width:58px;height:70px;box-shadow:var(--shadow-sm);box-sizing:border-box;-webkit-user-select:none;user-select:none;border-radius:6px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;padding:6px 4px;transition:border-color .2s,box-shadow .2s,background-color .2s;display:inline-flex;position:relative}.selection-toolbar .selected-hanja-tags-row .hanja-block-card .block-char{font-family:var(--font-serif);color:var(--text-primary);margin-bottom:2px;font-size:1.2rem;font-weight:700;line-height:1.1}.selection-toolbar .selected-hanja-tags-row .hanja-block-card .block-desc{color:var(--text-secondary);text-align:center;white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:.65rem;line-height:1.2;overflow:hidden}.selection-toolbar .selected-hanja-tags-row .hanja-block-card .block-remove-btn{background-color:var(--color-unknown,#b83b30);color:#fff;cursor:pointer;opacity:0;z-index:10;border:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:.6rem;font-weight:700;transition:opacity .15s,transform .15s;display:flex;position:absolute;top:-6px;right:-6px;transform:scale(.8);box-shadow:0 1px 3px #00000026}.selection-toolbar .selected-hanja-tags-row .hanja-block-card:hover{border-color:var(--color-unknown,#b83b30);box-shadow:0 2px 6px #b83b3026}.selection-toolbar .selected-hanja-tags-row .hanja-block-card:hover .block-remove-btn{opacity:1;transform:scale(1)}.selection-toolbar .toolbar-actions-row{border-top:1px dashed var(--border-subtle);justify-content:space-between;align-items:center;gap:16px;width:100%;padding-top:10px;display:flex}.selection-toolbar .toolbar-left{gap:8px;display:flex}.selection-toolbar .toolbar-right{display:flex}.selection-toolbar .toolbar-print-btn{font-weight:700}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.hanja-grid{grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:12px;display:grid}@media (width>=768px){.hanja-grid{grid-template-columns:repeat(auto-fill,minmax(124px,1fr));gap:14px}}.scroll-trigger{opacity:0;pointer-events:none;grid-column:1/-1;width:100%;height:1px}.no-results{text-align:center;color:var(--text-muted);grid-column:1/-1;padding:40px;font-size:.95rem}@media (width<=767px){.selection-actions,.selection-toolbar{display:none!important}}.stats-container{flex-direction:column;gap:16px;width:100%;display:flex}.global-card,.levels-card,.trend-card,.danger-zone{border:1px solid var(--border-subtle);box-shadow:var(--shadow-md);padding:22px;border-radius:var(--radius-card)!important}h3{color:var(--text-primary);border-left:3px solid var(--accent);margin-bottom:16px;padding-left:10px;font-size:1.05rem;font-weight:600;line-height:1.1}.global-headline{flex-wrap:wrap;align-items:center;gap:24px;margin-bottom:20px;display:flex}.global-tiles{flex:1;gap:10px;min-width:220px;display:flex}@media (width<=560px){.global-headline{flex-direction:column;align-items:center;gap:18px}.global-tiles{width:100%;min-width:0}}.stats-trends{grid-template-columns:1fr;gap:16px;display:grid}@media (width>=900px){.stats-trends{grid-template-columns:1fr 1fr}}.global-counts{justify-content:space-around;margin-bottom:20px;display:flex}.count-item{border:1px solid var(--border-subtle);flex-direction:column;flex:1;align-items:center;padding:10px 8px;display:flex;border-radius:var(--radius-md)!important}.count-val{font-size:1.5rem;font-weight:700;line-height:1.2}.count-lbl{color:var(--text-secondary);margin-top:4px;font-size:.75rem;font-weight:600}.count-item.unk .count-val{color:var(--color-unknown)}.count-item.know .count-val{color:var(--color-known)}.count-item.mast .count-val{color:var(--color-mastered)}.count-item.unk,.count-item.know{background:var(--bg-subtle);border-color:var(--border-color);margin-right:8px}.count-item.mast{background:var(--bg-subtle);border-color:var(--border-color)}.progress-bar-multi{background:var(--progress-bar-bg);border:1px solid var(--border-subtle);height:12px;box-shadow:none;margin-bottom:8px;display:flex;overflow:hidden;border-radius:var(--radius-pill)!important}.progress-bar-multi-sm{background:var(--progress-bar-bg);border:1px solid var(--border-subtle);height:6px;display:flex;overflow:hidden;border-radius:var(--radius-pill)!important}.segment{height:100%;transition:width var(--transition-normal);border-right:1px solid #fbf9f359;border-radius:0!important}.segment:last-child{border-right:none}.segment.unk{background-color:var(--segment-unk)}.segment.know{background-color:var(--segment-know)}.segment.mast{background-color:var(--segment-mast)}.progress-legend{color:var(--text-secondary);justify-content:space-between;font-size:.8rem;font-weight:500;display:flex}.trend-card{flex-direction:column;gap:16px;display:flex;position:relative}.trend-header{justify-content:space-between;align-items:center;display:flex}.trend-header h3{margin-bottom:0}.chart-toggles{border:1px solid var(--border-color);background:0 0;gap:0;padding:0;display:flex;overflow:hidden;border-radius:var(--radius-sm)!important}.chart-toggles button{border:none;border-right:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast) ease;background:0 0;padding:6px 12px;font-size:.8rem;font-weight:600;border-radius:0!important}.chart-toggles button:last-child{border-right:none}.chart-toggles button.active{background:var(--bg-active);color:var(--text-active)!important}.chart-wrapper{width:100%;position:relative}.trend-svg{width:100%;height:auto;overflow:visible}.axis-text{fill:var(--text-muted);font-size:10px;font-weight:500;font-family:var(--sans);-webkit-user-select:none;user-select:none}.date-label{fill:var(--text-secondary);transition:fill var(--transition-fast), font-weight var(--transition-fast)}.date-label.highlighted{fill:var(--text-primary);font-weight:700}.chart-tooltip{background:var(--bg-card);pointer-events:none;z-index:10;text-align:left;flex-direction:column;gap:6px;min-width:160px;padding:10px 14px;transition:left .15s,top .15s;display:flex;position:absolute;transform:translate(-50%,-100%);border:1px solid var(--border-subtle)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important}.tooltip-date{color:var(--text-primary);border-bottom:1px solid var(--border-subtle);margin-bottom:2px;padding-bottom:4px;font-size:.75rem;font-weight:700}.tooltip-row{align-items:center;gap:8px;font-size:.8rem;font-weight:500;display:flex}.tooltip-row .dot{width:8px;height:8px;border-radius:var(--radius-pill)!important}.tooltip-row .label{color:var(--text-secondary);flex-grow:1}.tooltip-row .val{font-variant-numeric:tabular-nums;font-weight:700}.tooltip-row.unk .dot{background-color:var(--color-unknown)}.tooltip-row.unk .val{color:var(--color-unknown)}.tooltip-row.know .dot{background-color:var(--color-known)}.tooltip-row.know .val{color:var(--color-known)}.tooltip-row.mast .dot{background-color:var(--color-mastered)}.tooltip-row.mast .val{color:var(--color-mastered)}.level-rows{flex-direction:column;gap:12px;display:flex}.level-progress-row{flex-direction:column;gap:6px;display:flex}.level-label-info{justify-content:space-between;font-size:.85rem;font-weight:500;display:flex}.level-name{color:var(--text-primary);font-weight:600}.level-ratio{color:var(--text-secondary)}.no-records-wrapper{border:1px dashed var(--border-color);background:var(--bg-subtle);justify-content:center;align-items:center;height:200px;display:flex;border-radius:var(--radius-md)!important}.no-records-text{color:var(--text-secondary);font-size:.9rem;font-weight:500}.stats-mode-header{justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;display:flex}@media (width<=600px){.stats-mode-header{flex-direction:column;align-items:flex-start;gap:12px}.stats-mode-header .chart-toggles{width:100%;display:flex}.stats-mode-header .chart-toggles button{text-align:center;flex:1;padding:8px 4px;font-size:.85rem}}.stats-target-header{flex-direction:column;gap:8px;margin-bottom:8px;padding:16px;display:flex}.stats-target-header .target-select-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;width:100%;display:flex}.stats-target-header .target-select-label{color:var(--text-primary);font-size:.95rem;font-weight:700}.stats-target-header .target-select-dropdown{width:220px}.stats-target-header .target-select-desc{color:var(--text-muted);text-align:left;margin:0;font-size:.8rem;line-height:1.4}.danger-zone p{color:var(--text-secondary);margin-top:0;margin-bottom:16px;font-size:.85rem;line-height:1.4}.danger-zone .danger-btn{font-weight:700;border-color:var(--color-incorrect)!important;color:var(--color-incorrect)!important}.danger-zone .danger-btn:hover{background-color:var(--color-incorrect-bg)!important}.stroke-order-diagram{-webkit-user-select:none;user-select:none;flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:6px;margin:6px 0;display:flex}@media print{.stroke-order-diagram{page-break-inside:avoid;break-inside:avoid}}.stroke-step-box{border:1px solid var(--border-color,#e2e8f0);background-color:var(--card-bg,#fff);box-sizing:border-box;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;padding:2px;display:flex}@media print{.stroke-step-box{-webkit-print-color-adjust:exact;print-color-adjust:exact;background-color:#fff;border-color:#d1d5db}}.stroke-svg-wrap{justify-content:center;align-items:center;display:flex;overflow:hidden}.stroke-svg{pointer-events:none;display:block}.stroke-number{color:var(--text-muted,#718096);margin-top:2px;font-size:9px;font-weight:500;line-height:12px}@media print{.stroke-number{color:#4b5563}}.stroke-order-loading{color:var(--text-muted,#718096);padding:8px 0;font-size:11px;font-style:italic}.stroke-order-error{color:var(--color-incorrect,#e53e3e);padding:8px 0;font-size:11px}.hanja-print-container{background-color:var(--bg-primary,#f8fafc);height:max(84vh,640px);color:var(--text-primary,#1e293b);display:flex;overflow:hidden}.hanja-print-container .print-settings-sidebar{background-color:var(--card-bg,#fff);border-right:1px solid var(--border-color,#e2e8f0);box-sizing:border-box;z-index:10;flex-direction:column;gap:20px;width:280px;height:100%;padding:24px;display:flex;overflow-y:auto}.hanja-print-container .print-settings-sidebar .sidebar-header h2{color:var(--color-primary,#2c3e50);margin:0 0 6px;font-size:1.25rem;font-weight:700}.hanja-print-container .print-settings-sidebar .sidebar-header .desc{color:var(--text-muted,#64748b);font-size:.8rem;line-height:1.4}.hanja-print-container .print-settings-sidebar .settings-body{flex-direction:column;gap:16px;display:flex}.hanja-print-container .print-settings-sidebar .settings-body .setting-group{flex-direction:column;gap:6px;display:flex}.hanja-print-container .print-settings-sidebar .settings-body .setting-group .setting-label{color:var(--text-secondary,#475569);font-size:.85rem;font-weight:600}.hanja-print-container .print-settings-sidebar .settings-body .setting-group .btn-toggle-group{border:1px solid var(--border-color,#cbd5e1);border-radius:6px;display:flex;overflow:hidden}.hanja-print-container .print-settings-sidebar .settings-body .setting-group .btn-toggle-group .toggle-btn{background:var(--bg-secondary,#f1f5f9);cursor:pointer;color:var(--text-secondary,#475569);border:none;flex:1;padding:8px;font-size:.8rem;transition:all .2s}.hanja-print-container .print-settings-sidebar .settings-body .setting-group .btn-toggle-group .toggle-btn:not(:last-child){border-right:1px solid var(--border-color,#cbd5e1)}.hanja-print-container .print-settings-sidebar .settings-body .setting-group .btn-toggle-group .toggle-btn.active{background-color:var(--color-primary,#34495e);color:#fff;font-weight:600}.hanja-print-container .print-settings-sidebar .settings-body .setting-group .range-input{cursor:pointer;width:100%}.hanja-print-container .print-settings-sidebar .settings-body .setting-group .range-value{color:var(--color-primary,#34495e);align-self:flex-end;font-size:.8rem;font-weight:600}.hanja-print-container .print-settings-sidebar .settings-body .setting-group .select-input{border:1px solid var(--border-color,#cbd5e1);background-color:var(--card-bg,#fff);color:var(--text-primary,#1e293b);cursor:pointer;border-radius:6px;padding:8px;font-size:.85rem}.hanja-print-container .print-settings-sidebar .settings-body .setting-group-checkbox{flex-direction:column;gap:4px;display:flex}.hanja-print-container .print-settings-sidebar .settings-body .setting-group-checkbox .checkbox-label{color:var(--text-secondary,#475569);cursor:pointer;align-items:center;gap:8px;font-size:.85rem;font-weight:600;display:flex}.hanja-print-container .print-settings-sidebar .settings-body .setting-group-checkbox .checkbox-label input{cursor:pointer;width:16px;height:16px}.hanja-print-container .print-settings-sidebar .settings-body .setting-group-checkbox .checkbox-desc{color:var(--text-muted,#64748b);margin:0;padding-left:24px;font-size:.75rem;line-height:1.4}.hanja-print-container .print-settings-sidebar .sidebar-footer{border-top:1px solid var(--border-color,#e2e8f0);flex-direction:column;gap:10px;margin-top:auto;padding-top:16px;display:flex}.hanja-print-container .print-settings-sidebar .sidebar-footer .print-btn{width:100%;padding:12px;font-weight:700}.hanja-print-container .print-settings-sidebar .sidebar-footer .back-btn{width:100%}.hanja-print-container .print-preview-workspace{box-sizing:border-box;flex-direction:column;flex:1;align-items:center;gap:30px;height:100%;padding:40px 20px;display:flex;overflow:auto}.hanja-print-container .print-preview-workspace .empty-print-state{text-align:center;width:100%;max-width:400px;margin-top:60px;padding:40px}.hanja-print-container .print-preview-workspace .empty-print-state p{color:var(--text-secondary,#475569);margin-bottom:20px;font-weight:500}.hanja-print-container .print-page{box-sizing:border-box;color:#000;width:210mm;min-width:210mm;min-height:297mm;font-family:var(--sans);background-color:#fff;border-radius:4px;flex-direction:column;flex-shrink:0;padding:10mm 15mm;display:flex;box-shadow:0 4px 20px #00000014}.hanja-print-container .print-page .page-header{color:#333;border-bottom:1.5px solid #1a1a1a;justify-content:flex-end;gap:24px;margin-bottom:10px;padding-bottom:8px;font-size:11px;font-weight:500;display:flex}.hanja-print-container .print-page .page-content{flex-direction:column;flex:1;justify-content:flex-start;gap:20px;display:flex}.hanja-print-container .print-page .page-content.items-count-2,.hanja-print-container .print-page .page-content.items-count-3{justify-content:space-evenly;gap:0}.hanja-print-container .print-page .page-footer{color:#64748b;border-top:1px solid #e2e8f0;justify-content:center;margin-top:15px;padding-top:8px;font-size:10px;font-weight:500;display:flex}.hanja-print-container .print-card{background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;flex-direction:column;gap:6px;padding:8px 12px;display:flex}.hanja-print-container .print-card .card-top-info{align-items:flex-start;gap:12px;display:flex}.hanja-print-container .print-card .large-hanja-box{background-color:#fff;border:1.5px solid #1a1a1a;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.hanja-print-container .print-card .large-hanja-box .large-hanja{color:#000;font-family:KyoboHandwriting2020,cursive,Noto Serif KR,serif;font-size:26px;font-weight:700}.hanja-print-container .print-card .hanja-meta-details{flex-direction:column;flex:1;gap:3px;display:flex}.hanja-print-container .print-card .hanja-meta-details .meta-row{color:#333;flex-wrap:wrap;align-items:center;gap:8px;font-size:10.5px;display:flex}.hanja-print-container .print-card .hanja-meta-details .meta-row.main-info{margin-bottom:0;font-size:11.5px}.hanja-print-container .print-card .hanja-meta-details .meta-row .badge-level{color:#1e293b;background-color:#e2e8f0;border-radius:4px;padding:1px 5px;font-size:9.5px;font-weight:700}.hanja-print-container .print-card .hanja-meta-details .meta-row .meaning-sound-title{color:#000;font-weight:700}.hanja-print-container .print-card .hanja-meta-details .meta-row .highlight-text{color:#1a1a1a;text-underline-offset:3px;font-size:12px;text-decoration:underline}.hanja-print-container .print-card .hanja-meta-details .meta-row .meta-cell{color:#4b5563;font-size:10px}.hanja-print-container .print-card .hanja-meta-details .vocab-info{border-top:1px dashed #e2e8f0;align-items:center;gap:6px;margin-top:1px;padding-top:2px;font-size:10px;display:flex}.hanja-print-container .print-card .hanja-meta-details .vocab-info .vocab-label{color:#000;font-weight:700}.hanja-print-container .print-card .hanja-meta-details .vocab-info .vocab-list{flex-wrap:wrap;gap:8px;display:flex}.hanja-print-container .print-card .hanja-meta-details .vocab-info .vocab-item{color:#334155;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:3px;padding:1px 4px;font-weight:500}.hanja-print-container .print-card .hanja-meta-details .vocab-info .vocab-empty-line{color:#94a3b8;font-size:8.5px;font-style:italic}.hanja-print-container .print-card .card-stroke-order-section{border-top:1px solid #f1f5f9;padding-top:2px}.hanja-print-container .print-card .card-stroke-order-section .section-title-lbl{color:#4b5563;margin-bottom:2px;font-size:10px;font-weight:700;display:block}.hanja-print-container .print-card .card-writing-grid-section{border-top:1px solid #f1f5f9;padding-top:4px}.hanja-print-container .print-card .card-writing-grid-section .grid-row{justify-content:flex-start;align-items:center;display:flex}.hanja-print-container .print-card .card-writing-grid-section .grid-row.margin-top-sm{margin-top:4px}.hanja-print-container .print-card .card-writing-grid-section .grid-cell{aspect-ratio:1;box-sizing:border-box;background-color:#fff;border:1px solid #4b5563;flex:1;justify-content:center;align-items:center;margin-right:-1px;display:flex;position:relative;container-type:inline-size}.hanja-print-container .print-card .card-writing-grid-section .grid-cell:before,.hanja-print-container .print-card .card-writing-grid-section .grid-cell:after{content:"";pointer-events:none;position:absolute}.hanja-print-container .print-card .card-writing-grid-section .grid-cell:before{border-top:1px dashed #0000;width:100%;top:50%;left:0}.hanja-print-container .print-card .card-writing-grid-section .grid-cell:after{border-left:1px dashed #0000;height:100%;top:0;left:50%}.hanja-print-container .print-card .card-writing-grid-section .grid-cell.dotted:before{border-top-style:dotted;border-top-color:#d1d5db}.hanja-print-container .print-card .card-writing-grid-section .grid-cell.dotted:after{border-left-style:dotted;border-left-color:#d1d5db}.hanja-print-container .print-card .card-writing-grid-section .grid-cell.dashed:before{border-top-style:dashed;border-top-color:#cbd5e1}.hanja-print-container .print-card .card-writing-grid-section .grid-cell.dashed:after{border-left-style:dashed;border-left-color:#cbd5e1}.hanja-print-container .print-card .card-writing-grid-section .grid-cell.solid:before{border-top-style:solid;border-top-color:#e2e8f0}.hanja-print-container .print-card .card-writing-grid-section .grid-cell.solid:after{border-left-style:solid;border-left-color:#e2e8f0}.hanja-print-container .print-card .card-writing-grid-section .grid-cell.original-cell{background-color:#f8fafc}.hanja-print-container .print-card .card-writing-grid-section .grid-cell.original-cell .cell-char-original{color:#000;z-index:2;font-family:KyoboHandwriting2020,Noto Serif KR,serif;font-size:55cqw;font-weight:700}.hanja-print-container .print-card .card-writing-grid-section .grid-cell.trace-cell .cell-char-trace{color:#d1d5db;z-index:2;font-family:KyoboHandwriting2020,Noto Serif KR,serif;font-size:55cqw;font-weight:400}.hanja-print-container .print-card .card-writing-grid-section .grid-cell .cell-hint-text{color:#94a3b8;text-align:center;white-space:nowrap;text-overflow:ellipsis;box-sizing:border-box;z-index:1;width:100%;padding:0 2px;font-size:16cqw;line-height:1.2;position:absolute;bottom:4%;overflow:hidden}@media print{.hanja-print-container .print-card .card-writing-grid-section .grid-cell .cell-hint-text{color:#9ca3af}body{color:#000!important;background-color:#fff!important;margin:0!important;padding:0!important}#app{background:0 0!important;margin:0!important;padding:0!important}.app-header,.app-footer,.offline-banner,.print-settings-sidebar,.mobile-nav-container{display:none!important}.app-main{background:0 0!important;width:100%!important;max-width:none!important;margin:0!important;padding:0!important}.hanja-print-container{background:0 0!important;width:100%!important;height:auto!important;margin:0!important;padding:0!important;display:block!important;overflow:visible!important}.hanja-print-container .print-preview-workspace{width:100%!important;height:auto!important;margin:0!important;padding:0!important;display:block!important;overflow:visible!important}.print-page{width:210mm!important;height:297mm!important;min-height:297mm!important;box-shadow:none!important;page-break-after:always!important;break-after:page!important;box-sizing:border-box!important;color:#000!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background-color:#fff!important;border-radius:0!important;flex-direction:column!important;margin:0!important;padding:10mm 12mm!important;display:flex!important}.print-page:last-child{page-break-after:avoid!important;break-after:avoid!important}.print-page .page-header{color:#000!important;border-bottom-color:#000!important}.print-page .print-card{page-break-inside:avoid!important;break-inside:avoid!important;border-color:#94a3b8!important}.print-page .print-card .large-hanja-box{border-color:#000!important}.print-page .print-card .badge-level{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background-color:#e2e8f0!important;border:1px solid #cbd5e1!important}.print-page .print-card .vocab-item{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background-color:#f8fafc!important;border:1px solid #e2e8f0!important}.print-page .print-card .grid-cell{border-color:#475569!important}.print-page .print-card .grid-cell.original-cell{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background-color:#f1f5f9!important}.print-page .print-card .grid-cell.trace-cell .cell-char-trace{color:#d1d5db!important}}:root{--bg-app:#f3efe6;--bg-card:#fbf9f3;--bg-card-hover:#f6f2e8;--bg-subtle:#ece7da;--bg-active:#211f1a;--border-color:#cec7b6;--border-strong:#211f1a;--border-focus:#3f6e63;--border-subtle:#e5dfcf;--shadow-sm:0 1px 2px #211f1a0d;--shadow-md:0 2px 4px #211f1a0a, 0 8px 20px #211f1a0f;--shadow-lg:0 14px 40px #211f1a21;--shadow-glow:0 0 0 3px #3f6e632e;--text-primary:#211f1a;--text-secondary:#6a6456;--text-muted:#9c9484;--text-active:#f7f4ea;--accent:#3f6e63;--accent-strong:#335a51;--accent-soft:#e7efea;--accent-2:#2e4a5b;--color-unknown:#b83b30;--color-unknown-bg:#f9ebea;--color-unknown-border:#cd5c5c;--color-known:#8a8273;--color-known-bg:#efeadf;--color-known-border:#8a8273;--color-mastered:#3f6e63;--color-mastered-bg:#e7efea;--color-mastered-border:#3f6e63;--sans:"Noto Sans KR", system-ui, -apple-system, "Segoe UI", sans-serif;--font-hanzi:"Noto Serif KR", "Nanum Myeongjo", "Batang", serif;--font-serif:"Noto Serif KR", serif;--radius-card:14px;--radius-md:10px;--radius-sm:3px;--radius-pill:999px;--w-page:1040px;--w-focus:640px;--gap-grid:20px;--transition-fast:.12s ease;--transition-normal:.25s cubic-bezier(.2, .8, .2, 1);--color-correct:#4a8a6f;--color-correct-bg:#4a8a6f1a;--color-incorrect:#b5544a;--color-incorrect-bg:#b5544a1a;--chart-grid:#e5dfcf;--chart-node-stroke:#3f6e63;--segment-unk:#b83b30;--segment-know:#8a8273;--segment-mast:#3f6e63;--progress-track:#e5dfcf;--progress-bar-bg:#ece7da;--color-primary:#3f6e63}.dark{--bg-app:#1a1916;--bg-card:#221f1a;--bg-card-hover:#2a2620;--bg-subtle:#2a2620;--bg-active:#ece7db;--border-color:#3a352c;--border-strong:#ece7db;--border-focus:#6fa89b;--border-subtle:#2c2823;--shadow-sm:0 1px 2px #0006;--shadow-md:0 2px 6px #00000059, 0 10px 28px #00000073;--shadow-lg:0 18px 44px #0009;--shadow-glow:0 0 0 3px #6fa89b3d;--text-primary:#ece7db;--text-secondary:#b3ab98;--text-muted:#837c6b;--text-active:#1a1916;--accent:#6fa89b;--accent-strong:#84bbad;--accent-soft:#1f2b27;--accent-2:#6f93a6;--color-unknown:#e74c3c;--color-unknown-bg:#2d1c1a;--color-unknown-border:#e74c3c;--color-known:#9a9282;--color-known-bg:#262219;--color-known-border:#9a9282;--color-mastered:#6fa89b;--color-mastered-bg:#1f2b27;--color-mastered-border:#6fa89b;--color-correct:#5fae8c;--color-correct-bg:#5fae8c24;--color-incorrect:#d2786d;--color-incorrect-bg:#d2786d24;--chart-grid:#3a352c;--chart-node-stroke:#6fa89b;--segment-unk:#e74c3c;--segment-know:#9a9282;--segment-mast:#6fa89b;--progress-track:#3a352c;--progress-bar-bg:#2a2620;--color-primary:#6fa89b}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{font-family:var(--sans);background-color:var(--bg-app);color:var(--text-primary);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;background-image:radial-gradient(circle at 18% 22%,#3f6e6306,#0000 42%),radial-gradient(circle at 84% 12%,#2e4a5b06,#0000 40%);background-attachment:fixed;justify-content:center;align-items:stretch;min-height:100svh;transition:background-color .4s,color .4s;display:flex;overflow-x:hidden}.glass-panel,.hanja-card,.config-card,.summary-card,.trend-card,.global-card,.levels-card,.modal-content,.search-box,.filters-card,.selection-toolbar,.danger-zone{border-radius:var(--radius-card)!important}button,input,select,.ui-input,.custom-select,.search-input,.filter-select,.form-select,.tabs-nav,.tab-item-btn,.tab-item-link,.level-pill,.status-btn,.action-btn,.nav-btn,.nav-btn-sm,.quit-btn,.choice-btn,.modal-close,.modal-tts-btn,.dropdown-trigger,.header-btn,.pad-btn,.pinyin-container,.hint-text,.chart-tooltip{border-radius:var(--radius-sm)!important}.badge,.segment,.choice-index,.progress-bar-container,.progress-bar,.progress-bar-multi,.progress-bar-multi-sm{border-radius:var(--radius-pill)!important}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass-panel{background:var(--bg-card);border:1px solid var(--border-subtle);box-shadow:var(--shadow-md);transition:background var(--transition-normal), border-color var(--transition-normal), box-shadow var(--transition-normal);-webkit-backdrop-filter:none!important}button{font-family:var(--sans);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);cursor:pointer;letter-spacing:.01em;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);outline:none;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:.92rem;font-weight:600;display:inline-flex}button:active{transform:translateY(1px)}button:focus-visible{box-shadow:var(--shadow-glow);border-color:var(--accent)}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:var(--shadow-sm)}button.primary:hover:not(:disabled){background:var(--accent-strong);border-color:var(--accent-strong);box-shadow:var(--shadow-md)}button.secondary{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-color)}button.secondary:hover:not(:disabled){background:var(--bg-subtle);border-color:var(--text-muted)}button.outline{color:var(--text-primary);border-color:var(--border-strong);background:0 0}button.outline:hover:not(:disabled){background:var(--bg-active);color:var(--text-active);border-color:var(--bg-active)}.dark button.primary{color:var(--text-active)}h1{font-family:var(--font-hanzi);color:var(--text-primary);text-align:center;letter-spacing:.04em;margin-bottom:24px;padding-bottom:10px;font-size:2rem;font-weight:700;position:relative}h1:after{content:"";background:var(--accent);border-radius:var(--radius-pill);width:44px;height:2px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}h2{font-family:var(--font-serif);color:var(--text-primary);letter-spacing:.01em;margin-bottom:12px;font-size:1.2rem;font-weight:600}h3{font-family:var(--font-serif);color:var(--text-primary);letter-spacing:.01em;font-size:1.05rem;font-weight:600}p{color:var(--text-secondary);font-size:.9rem;line-height:1.6}#app{flex-direction:column;align-items:stretch;width:100%;max-width:none;min-height:100vh;margin:0;padding:0;display:flex;position:relative}.app-main{width:100%;max-width:var(--w-page);flex:1;margin:0 auto;padding:16px}@media (width>=768px){.app-main{padding:24px 28px 40px}}.tab-content,.fade-in{animation:.35s cubic-bezier(.2,.8,.2,1) contentRise}@keyframes contentRise{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.badge{letter-spacing:.03em;padding:3px 11px;font-size:.72rem;border:1px solid var(--border-color)!important;color:var(--text-secondary)!important;background:0 0!important;font-weight:600!important}.badge.level{border-color:var(--accent)!important;color:var(--accent)!important}.badge.status-unk{border-color:var(--color-unknown)!important;color:var(--color-unknown)!important}.badge.status-know{border-color:var(--color-known)!important;color:var(--color-known)!important}.badge.status-mast{border-color:var(--color-mastered)!important;color:var(--color-mastered)!important}.hanja-card{background:var(--bg-card)!important;border:1px solid var(--border-subtle)!important;box-shadow:var(--shadow-md)!important}.hanja-display{font-family:var(--font-hanzi)!important;color:var(--text-primary)!important;text-shadow:none!important;font-size:8rem!important;font-weight:900!important;line-height:1!important}.meaning-text{font-family:var(--font-serif)!important;color:var(--text-primary)!important;font-size:2.6rem!important;font-weight:700!important}.sound-display{font-family:var(--font-serif)!important;color:var(--text-primary)!important;font-size:2rem!important;font-weight:700!important}.level-pill{border:1px solid var(--border-color);color:var(--text-secondary);background:0 0;font-weight:600}.level-pill.active{background:var(--bg-active)!important;color:var(--text-active)!important;border-color:var(--bg-active)!important}.fade-enter-active,.fade-leave-active{transition:opacity .2s,transform .2s}.fade-enter-from,.fade-leave-to{opacity:0;transform:scale(.98)}@media (width<=767px){.app-main{padding-bottom:72px}}.app-footer{padding:18px 24px calc(18px + env(safe-area-inset-bottom));margin-top:32px;border:none!important;border-top:1px solid var(--border-subtle)!important;box-shadow:none!important;background:0 0!important;border-radius:0!important}.footer-content{max-width:var(--w-page);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin:0 auto;display:flex}.footer-content .footer-left{font-family:var(--font-serif);color:var(--text-secondary);letter-spacing:.02em;font-size:.8rem}.footer-content .footer-right{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;font-size:.66rem}@media (width<=767px){.footer-content{text-align:center;justify-content:center}.footer-content .footer-right{display:none}}.offline-banner{background:var(--accent-soft);color:var(--accent-strong);border-bottom:1px solid var(--border-subtle);text-align:center;letter-spacing:.01em;padding:10px 16px;font-size:.8rem;font-weight:600;animation:.3s cubic-bezier(.4,0,.2,1) fadeInDown}.dark .offline-banner{color:var(--accent-strong)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.pwa-toast{z-index:1000;flex-direction:column;gap:12px;width:320px;padding:16px;display:flex;position:fixed;bottom:24px;right:24px;border-radius:var(--radius-card)!important;background:var(--bg-card)!important;border:1px solid var(--border-subtle)!important;box-shadow:var(--shadow-lg)!important}@media (width<=767px){.pwa-toast{width:calc(100% - 32px);bottom:76px;left:16px;right:16px}}.pwa-toast .toast-body{color:var(--text-primary);text-align:left;font-size:.85rem;font-weight:500;line-height:1.5}.pwa-toast .toast-actions{justify-content:flex-end;gap:8px;display:flex}.app-header{padding-top:calc(12px + env(safe-area-inset-top))!important}.inline-icon{vertical-align:-.15em;flex-shrink:0;margin-left:5px;display:inline-block}.pinyin-val,.pinyin-value,.pinyin-display{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif!important}
