@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.fixed{position:fixed}.relative{position:relative}.static{position:static}.isolate{isolation:isolate}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.hidden{display:none}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.italic{font-style:italic}.ordinal{--tw-ordinal:ordinal;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.ring-2{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg-color:#f9f8f6;--paper-color:#fff;--text-primary:#1a1a1a;--text-secondary:#666;--accent-color:#2563eb;--accent-light:#eff6ff;--highlight-bg:#fef3c7;--border-color:#e5e5e5;--max-width:760px;--player-height:88px}[data-theme=dark]{--bg-color:#1f2937;--paper-color:#111827;--text-primary:#f9fafb;--text-secondary:#9ca3af;--accent-color:#3b82f6;--accent-light:#1e3a8a;--highlight-bg:#78350f;--border-color:#374151;--paper-color-rgb:17,24,39;--text-primary-rgb:249,250,251}*{box-sizing:border-box;margin:0;padding:0}html{background-color:var(--bg-color);scrollbar-gutter:stable;width:100%;height:100%;min-height:100vh;margin:0;padding:0;transition:background-color .3s;overflow:hidden scroll}html.login-page-active{height:100%;overflow:hidden}[data-theme=dark] html{background-color:var(--bg-color)}body{background-color:var(--bg-color);background:var(--bg-color);color:var(--text-primary);scrollbar-gutter:stable;width:100%;min-height:100vh;margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;transition:background-color .3s,color .3s;overflow-y:scroll}body.login-page-active{height:100vh;overflow:hidden}.top-nav{z-index:100;background:var(--bg-color);background:rgba(var(--bg-color-rgb,249,248,246),.9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:12px 32px;transition:background-color .3s,border-color .3s;display:flex;position:sticky;top:0}[data-theme=dark] .top-nav{background:#1f2937e6;border-bottom:1px solid #ffffff1a}.logo{letter-spacing:-.5px;align-items:center;gap:10px;font-family:Noto Serif SC,serif;font-size:20px;font-weight:700;display:flex}.logo-image{-o-object-fit:contain;object-fit:contain;width:28px;height:28px;transition:transform .3s}.logo-clickable:hover .logo-image{transform:scale(1.1)rotate(5deg)}.logo-clickable{cursor:pointer;color:var(--text-primary);background:0 0;border:none;align-items:center;gap:12px;padding:0;transition:all .2s;display:inline-flex}.logo-clickable:hover{opacity:.8;transform:scale(1.05)}.logo-clickable:active{transform:scale(.98)}.logo .dot{color:var(--accent-color);transition:color .3s}.nav-right{flex-shrink:0;align-items:center;gap:16px;display:flex}.nav-info{color:var(--text-secondary);white-space:nowrap;text-transform:none;letter-spacing:normal;text-overflow:ellipsis;flex-shrink:1;align-items:center;gap:4px;min-width:0;font-size:14px;font-weight:500;display:flex;overflow:hidden}.total-read-time{color:var(--accent-color);font-weight:600}.user-menu{align-items:center;gap:12px;display:flex;position:relative}.wordbook-btn{color:var(--accent-color);cursor:pointer;background:#2563eb1a;border:none;border-radius:10px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.wordbook-btn .nav-icon{-o-object-fit:contain;object-fit:contain;width:18px;height:18px}.wordbook-btn:hover{background:#2563eb33;transform:scale(1.02)}.wordbook-btn.active{color:#ffc107;background:#ffc10733;border:1px solid #ffc1074d;transform:scale(1.05);box-shadow:0 0 15px #ffc10766}[data-theme=dark] .wordbook-btn{color:#60a5fa;background:#3b82f626}[data-theme=dark] .wordbook-btn.active{color:#ffca28;background:#ffc10740;box-shadow:0 0 20px #ffc10780}.vocabulary-btn{color:#7c3aed;cursor:pointer;background:#8b5cf61a;border:none;border-radius:10px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.vocabulary-btn .nav-icon{-o-object-fit:contain;object-fit:contain;width:18px;height:18px}.vocabulary-btn:hover{background:#8b5cf633;transform:scale(1.02)}.nav-badge{color:#fff;border:2px solid var(--bg-color);z-index:10;background:#ef4444;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;animation:.3s cubic-bezier(.175,.885,.32,1.275) badge-pop;display:flex;position:absolute;top:-2px;right:-2px;box-shadow:0 1px 2px #0000001a}@keyframes badge-pop{0%{transform:scale(0)}to{transform:scale(1)}}.vocabulary-btn.active{color:#7c3aed;background:#8b5cf633;border:1px solid #8b5cf64d;transform:scale(1.05);box-shadow:0 0 15px #8b5cf666}[data-theme=dark] .vocabulary-btn{color:#a78bfa;background:#8b5cf626}[data-theme=dark] .vocabulary-btn:hover{background:#8b5cf640}.user-avatar-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;padding:0;transition:transform .2s,box-shadow .2s;position:relative}.user-avatar-btn:hover{transform:scale(1.05);box-shadow:0 2px 8px #2563eb4d}.user-avatar{-o-object-fit:cover;object-fit:cover;border:2px solid var(--accent-color);border-radius:50%;width:32px;height:32px;display:block}.floating-level-badge{z-index:800;cursor:pointer;filter:drop-shadow(0 8px 20px #667eea4d);transition:all .4s cubic-bezier(.4,0,.2,1);animation:.8s cubic-bezier(.4,0,.2,1) floatIn;position:fixed;top:120px;right:40px;box-shadow:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;background:0 0!important;border:none!important}.floating-level-badge:hover{filter:drop-shadow(0 12px 30px #667eea80);transform:scale(1.15)rotate(5deg)}@keyframes floatIn{0%{opacity:0;transform:translate(100px)rotate(-20deg)}to{opacity:1;transform:translate(0)rotate(0)}}.app-container{box-sizing:border-box;justify-content:center;width:100%;padding:40px 20px;display:flex;position:relative}.reading-area{width:100%;max-width:var(--max-width);box-sizing:border-box}.paper-content{width:100%;max-width:var(--max-width);box-sizing:border-box;background:0 0;margin:0 auto}.article-header-decoration{justify-content:space-between;align-items:center;gap:15px;margin-bottom:40px;display:flex}.header-right-actions{align-items:center;gap:12px;display:flex}.theme-btn{background:var(--accent-light);cursor:pointer;width:32px;height:32px;color:var(--accent-color);border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.theme-btn svg{width:18px;height:18px}.theme-btn:hover{background:var(--accent-color);color:#fff;transform:scale(1.05)}[data-theme=dark] .theme-btn{color:#fbbf24;background:#fbbf2426}[data-theme=dark] .theme-btn:hover{color:#1a1a1a;background:#fbbf24}.immersive-btn{background:var(--accent-light);cursor:pointer;width:32px;height:32px;color:var(--accent-color);border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.immersive-btn svg{width:18px;height:18px}.immersive-btn:hover{background:var(--accent-color);color:#fff;transform:scale(1.05)}.immersive-controls{gap:12px;transition:none;display:flex;z-index:10001!important;box-shadow:none!important;opacity:1!important;background:0 0!important;border:none!important;margin:0!important;padding:0!important;position:fixed!important;top:20px!important;left:20px!important;right:auto!important;transform:none!important}.immersive-controls:hover{opacity:1!important}.immersive-theme-btn{cursor:pointer;color:#fff;-webkit-backdrop-filter:blur(10px);background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .3s;display:flex;box-shadow:0 2px 8px #0000001a}.immersive-theme-btn svg{width:22px;height:22px}.immersive-theme-btn:hover{background:#3b82f6cc;transform:scale(1.1)}[data-theme=dark] .immersive-theme-btn{background:#ffffff26;box-shadow:0 2px 8px #0003}[data-theme=dark] .immersive-theme-btn:hover{background:#fbbf24cc;box-shadow:0 4px 12px #fbbf2466}.exit-immersive-btn{cursor:pointer;color:#fff;-webkit-backdrop-filter:blur(10px);background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .3s;display:flex;box-shadow:0 2px 8px #0000001a}.exit-immersive-btn svg{width:22px;height:22px}.exit-immersive-btn:hover{background:#ef4444cc;transform:scale(1.1)}[data-theme=dark] .exit-immersive-btn{background:#ffffff26;box-shadow:0 2px 8px #0003}[data-theme=dark] .exit-immersive-btn:hover{background:#ef4444cc;box-shadow:0 4px 12px #ef444466}.immersive-mode{background:var(--paper-color)!important}.immersive-mode .top-nav{opacity:0;pointer-events:none;width:100%;position:fixed;transform:translateY(-100%)}.immersive-mode .bottom-player{opacity:.95;-webkit-backdrop-filter:blur(20px)}.immersive-mode .sidebar-toggle,.immersive-mode .article-sidebar,.immersive-mode .floating-action-badge,.immersive-mode .floating-level-badge{transform:translate(100px);opacity:0!important;pointer-events:none!important}.immersive-mode .reading-area{padding-top:60px;padding-bottom:60px}.immersive-mode .paper-content{max-width:720px;box-shadow:none;background:0 0;margin:0 auto}.immersive-mode .article-header-decoration{display:none}.immersive-mode .immersive-controls{margin:0!important;position:fixed!important;top:20px!important;left:20px!important;right:auto!important;transform:none!important}.top-nav,.bottom-player,.sidebar-toggle,.article-sidebar,.floating-action-badge,.floating-level-badge{transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s cubic-bezier(.4,0,.2,1)}.category-tag{color:#fff;text-transform:uppercase;letter-spacing:1px;background:#1a1a1a;border-radius:4px;padding:4px 10px;font-size:12px;font-weight:700;transition:background-color .3s,color .3s}[data-theme=dark] .category-tag{color:#1a1a1a;background:#f9fafb}.read-time{color:var(--text-secondary);font-family:Inter,sans-serif;font-size:13px}.sidebar-dictation-entry{border-top:1px solid var(--border-color);background:var(--paper-color);padding:16px}.dictation-sidebar-btn{background:var(--paper-color);border:1px solid var(--border-color);cursor:pointer;width:100%;color:var(--text-primary);text-align:left;border-radius:12px;align-items:center;gap:12px;padding:16px;font-size:16px;font-weight:600;transition:all .2s;display:flex}.dictation-sidebar-btn:hover{background:var(--accent-light);border-color:#2563eb33;transform:translate(4px)}.dictation-sidebar-btn svg{width:20px;height:20px;color:var(--text-secondary);flex-shrink:0}.dictation-sidebar-btn:hover svg{color:var(--accent-color)}.article-body{color:var(--text-primary);text-align:left;box-sizing:border-box;width:100%;max-width:100%;padding-left:0;padding-right:0;font-family:Noto Serif SC,Georgia,serif;overflow:visible}.article-body h1{color:var(--text-primary);letter-spacing:-.5px;text-align:left;margin:0 0 32px;font-family:Noto Serif SC,serif;font-size:36px;font-weight:700;line-height:1.3}.article-body h2{color:var(--accent-color);text-align:left;align-items:center;margin:48px 0 24px;font-family:Inter,sans-serif;font-size:20px;font-weight:600;display:flex}.article-body h2:before{content:"";background:var(--accent-color);flex-shrink:0;width:20px;height:1px;margin-right:10px;display:inline-block}.article-body h3{color:var(--text-primary);text-align:left;margin:32px 0 20px;font-size:18px;font-weight:600}.article-body p{color:var(--text-primary);text-align:left;text-indent:0;margin:0 0 24px;padding-left:0;padding-right:0;font-size:18px;line-height:1.9;transition:color .3s;overflow:visible}.article-body p:has(.highlight),.article-body div:has(.highlight),.article-body h1:has(.highlight),.article-body h2:has(.highlight),.article-body h3:has(.highlight){position:relative;opacity:1!important;filter:none!important;-webkit-backdrop-filter:none!important;margin-left:0!important;margin-right:0!important;padding-left:0!important;padding-right:0!important;overflow:visible!important}.article-body blockquote:has(.highlight){position:relative;opacity:1!important;filter:none!important;-webkit-backdrop-filter:none!important;margin-left:0!important;margin-right:0!important;overflow:visible!important}.article-body li:has(.highlight){position:relative;opacity:1!important;filter:none!important;-webkit-backdrop-filter:none!important;overflow:visible!important}.article-body blockquote{border-left:3px solid var(--accent-color);color:var(--text-secondary);text-align:left;margin:32px 0;padding-left:24px;font-size:19px;font-style:italic}.article-body strong{color:var(--text-primary);background:linear-gradient(#0000 60%,#2563eb1a 60%)}.article-body ul,.article-body ol{text-align:left;margin-top:0;margin-bottom:24px;padding-left:24px}.article-body li{text-align:left;margin-top:0;margin-bottom:12px;font-size:17px;line-height:1.8}.article-body .highlight,.article-body p .highlight,.article-body div .highlight,.article-body h1 .highlight,.article-body h2 .highlight,.article-body h3 .highlight,.article-body blockquote .highlight,.article-body li .highlight,.highlight{text-align:left;z-index:10;box-sizing:border-box;border-radius:8px;display:block;position:relative;box-shadow:0 4px 20px #00000008;opacity:1!important;filter:none!important;-webkit-backdrop-filter:none!important;isolation:isolate!important;will-change:auto!important;background-color:#fef3c7d9!important;border-left:none!important;width:100%!important;margin:24px 0!important;padding:20px 24px!important;transition:none!important}.article-body blockquote .highlight,.article-body ul .highlight,.article-body ol .highlight,.article-body li .highlight{width:calc(100% + 24px)!important;margin-left:-24px!important;padding-left:48px!important}.highlight,.highlight *{text-shadow:0 0 1px #0000001a;color:#000!important;opacity:1!important;filter:none!important;-webkit-backdrop-filter:none!important;transition:none!important}[data-theme=dark] .highlight{box-shadow:0 4px 20px #fef3c733;background-color:#fef3c7f2!important}[data-theme=dark] .highlight,[data-theme=dark] .highlight *{color:#000!important}.highlight:has(+.highlight){box-shadow:0 4px 20px #00000008;border-bottom-right-radius:0!important;border-bottom-left-radius:0!important;margin-bottom:0!important;padding-bottom:15px!important}.highlight+.highlight{border-top:1px solid #00000008;box-shadow:0 4px 20px #00000008;border-top-left-radius:0!important;border-top-right-radius:0!important;margin-top:0!important;padding-top:15px!important}.article-body blockquote .highlight:has(+.highlight),.article-body blockquote .highlight+.highlight,.article-body ul .highlight:has(+.highlight),.article-body ul .highlight+.highlight,.article-body ol .highlight:has(+.highlight),.article-body ol .highlight+.highlight,.article-body li .highlight:has(+.highlight),.article-body li .highlight+.highlight{width:calc(100% + 24px)!important;margin-left:-24px!important;padding-left:48px!important}h1.highlight+p.highlight,h2.highlight+p.highlight,h3.highlight+p.highlight{background-color:#fef3c766!important;padding-top:20px!important}[data-theme=dark] h1.highlight+p.highlight,[data-theme=dark] h2.highlight+p.highlight,[data-theme=dark] h3.highlight+p.highlight{background-color:#fef3c7d9!important}.highlight{border-left:none!important}.highlight+.highlight .current-indicator{display:none!important}.highlight-container{opacity:1!important;filter:none!important;-webkit-backdrop-filter:none!important}.highlight-container .highlight{opacity:1!important;filter:none!important;-webkit-backdrop-filter:none!important;background-color:#fef3c7d9!important}.highlight-container>:not(.highlight){transition:all .5s;opacity:1!important;color:var(--text-primary)!important}[data-theme=dark] .highlight-container>:not(.highlight){opacity:1!important;color:var(--text-primary)!important}.article-body:has(.highlight)>:not(.highlight):not(.highlight-container):not(:has(.highlight)){opacity:1;filter:none;transition:all .5s}.highlight-container>:not(.highlight){opacity:1;transition:all .5s}[data-theme=dark] .article-body:has(.highlight)>:not(.highlight):not(.highlight-container):not(:has(.highlight)),[data-theme=dark] .highlight-container>:not(.highlight){transition:all .5s;opacity:1!important;filter:none!important;color:var(--text-primary)!important}.article-body:has(.highlight):hover>:not(.highlight):not(.highlight-container):not(:has(.highlight)),.highlight-container:hover>:not(.highlight){opacity:1}[data-theme=dark] .article-body:has(.highlight):hover>:not(.highlight):not(.highlight-container):not(:has(.highlight)),[data-theme=dark] .highlight-container:hover>:not(.highlight){opacity:1!important}.bottom-player{width:90%;max-width:800px;height:var(--player-height);background:var(--paper-color);background:rgba(var(--paper-color-rgb,255,255,255),.85);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:1000;box-sizing:border-box;border-radius:24px;padding:0 30px;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -4px 20px #0000001a,0 0 0 1px #0000000d}.player-content{box-sizing:border-box;justify-content:center;align-items:center;gap:20px;width:100%;max-width:100%;height:100%;display:flex}.track-info{flex:1;align-items:center;gap:15px;min-width:180px;display:flex}.track-icon{color:#fff;background:#1a1a1a;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}[data-theme=dark] .track-icon{color:#1a1a1a;background:#f9fafb}.track-text{flex-direction:column;display:flex}.track-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-size:14px;font-weight:600;overflow:hidden}.track-status{color:var(--accent-color);font-size:11px;font-weight:500}.player-controls-wrapper{flex-direction:column;flex:none;justify-content:center;align-items:center;gap:8px;display:flex}.controls-main{align-items:center;gap:24px;display:flex}.icon-btn{cursor:pointer;color:var(--text-secondary);opacity:.7;background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.icon-btn:hover{opacity:1;color:var(--text-primary);transform:scale(1.1)}.bottom-player .play-btn{cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s cubic-bezier(.175,.885,.32,1.275);display:flex;box-shadow:0 4px 12px #0003;color:#fff!important;background:#1a1a1a!important}[data-theme=dark] .bottom-player .play-btn{color:#1a1a1a!important;background:#f9fafb!important}.bottom-player .play-btn:hover{transform:scale(1.05);background:#000!important}[data-theme=dark] .bottom-player .play-btn:hover{color:#1a1a1a!important;background:#fff!important}.bottom-player .play-btn svg{fill:currentColor;stroke:currentColor;width:20px;height:20px}.progress-wrapper{width:100%;color:var(--text-secondary);align-items:center;gap:12px;font-family:Inter,monospace;font-size:11px;display:flex}.progress-bar-container{background:rgba(var(--text-primary-rgb,0,0,0),.05);cursor:pointer;border-radius:2px;flex:1;height:4px;position:relative;overflow:hidden}.progress-bar-container:hover{height:6px}#progressSlider{opacity:0;cursor:pointer;z-index:2;width:100%;height:100%;position:absolute;top:0;left:0}.progress-fill{background:var(--accent-color);pointer-events:none;border-radius:2px;width:0%;height:100%;transition:width .1s linear;position:absolute;top:0;left:0}.player-extra{flex:none;justify-content:flex-end;min-width:40px;display:flex}@media(min-width:769px){.bottom-player{border-radius:24px;bottom:30px;box-shadow:0 15px 40px #0000001a,0 0 0 1px #0000000d}.player-extra,.track-info{flex:1}}.article-footer{text-align:center;color:var(--text-secondary);margin-top:80px;font-family:Noto Serif SC,serif;font-style:italic}.divider{letter-spacing:5px;opacity:.3;margin-top:20px}.current-indicator{color:var(--accent-color);margin-right:8px;font-size:14px;font-weight:700;display:inline-block}@media(max-width:768px){.bottom-player{border-radius:24px 24px 0 0;width:100%;max-width:100%;margin:0;padding:0 15px;bottom:0;left:0;right:0;transform:none}.player-content{justify-content:center;gap:12px;padding:0}.track-info{display:none}.player-controls-wrapper{flex-direction:column;flex:1;justify-content:center;align-items:center;max-width:100%;display:flex}.controls-main{gap:16px}.player-extra{display:none}.article-body h1{font-size:28px}.top-nav{flex-wrap:wrap;padding:10px 16px}.nav-right{gap:8px}.nav-info{display:none}.user-menu{gap:8px}.floating-level-badge{top:80px;right:16px;transform:scale(.85)}.floating-level-badge:hover{transform:scale(.95)rotate(5deg)}body{padding-bottom:100px}}@media(max-width:480px){.floating-level-badge{top:70px;right:12px;transform:scale(.75)}.floating-level-badge:hover{transform:scale(.85)rotate(5deg)}.bottom-player{height:80px;padding:0 12px}.bottom-player .play-btn{width:40px;height:40px;color:#fff!important;background:#1a1a1a!important}[data-theme=dark] .bottom-player .play-btn{color:#1a1a1a!important;background:#f9fafb!important}.icon-btn{width:28px;height:28px}.progress-wrapper{gap:8px;font-size:10px}body{padding-bottom:90px}}.mini-player{z-index:1001;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1);position:fixed;bottom:30px;right:30px;transform:translateY(20px)scale(.9)}.mini-player.visible{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.mini-player-content{flex-direction:column;align-items:center;gap:8px;display:flex}.mini-progress-ring{filter:drop-shadow(0 4px 12px #00000026);width:56px;height:56px;position:relative}.mini-progress-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.mini-progress-ring .ring-bg{fill:none;stroke:#0000001a;stroke-width:3px}.mini-progress-ring .ring-progress{fill:none;stroke:var(--accent-color);stroke-width:3px;stroke-linecap:round;transition:stroke-dashoffset .3s}[data-theme=dark] .mini-progress-ring .ring-bg{stroke:#ffffff26}.mini-play-btn{background:var(--paper-color);width:44px;height:44px;color:var(--text-primary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #0000001a}.mini-play-btn:hover{transform:translate(-50%,-50%)scale(1.08);box-shadow:0 4px 16px #00000026}.mini-play-btn svg{width:18px;height:18px}.mini-expand-btn{background:rgba(var(--paper-color-rgb,255,255,255),.9);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;-webkit-backdrop-filter:blur(8px);border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000001a}.mini-expand-btn:hover{background:var(--paper-color);color:var(--accent-color);transform:scale(1.1)}.mini-expand-btn svg{width:16px;height:16px}[data-theme=dark] .mini-expand-btn{background:#111827e6}.bottom-player.minimized{opacity:0;pointer-events:none;transform:translate(-50%)translateY(100%)}.minimize-btn{opacity:.6;transition:all .2s}.minimize-btn:hover{opacity:1;color:var(--accent-color)}@media(max-width:768px){.mini-player{bottom:20px;right:20px}.mini-progress-ring{width:52px;height:52px}.mini-play-btn{width:40px;height:40px}.mini-play-btn svg{width:16px;height:16px}}@media(max-width:480px){.mini-player{bottom:16px;right:16px}.mini-progress-ring{width:48px;height:48px}.mini-play-btn{width:36px;height:36px}.mini-expand-btn{width:24px;height:24px}.mini-expand-btn svg{width:14px;height:14px}}@supports (-webkit-appearance:none){html,body{background-color:var(--bg-color)!important}.top-nav{background:var(--bg-color)!important}.bottom-player{background:rgba(var(--paper-color-rgb,255,255,255),.95)!important}[data-theme=dark] .bottom-player{background:#111827f2!important}}@media screen and (-webkit-min-device-pixel-ratio:0){html,body{background-color:var(--bg-color)}.top-nav{background:var(--bg-color)}}.sidebar-toggle-button{z-index:998;background:rgba(var(--paper-color-rgb,255,255,255),.35);width:56px;height:100px;color:var(--text-primary);border:1px solid rgba(var(--border-color-rgb,229,231,235),.25);cursor:pointer;-webkit-backdrop-filter:blur(16px);border-left:none;border-radius:0 12px 12px 0;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:12px 8px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:50%;left:0;transform:translateY(-50%);box-shadow:2px 0 12px #0000000a}.sidebar-toggle-button:hover{width:64px;color:var(--accent-color);background:#eff6ffa6;box-shadow:4px 0 16px #0000001f}.sidebar-toggle-button:active{transform:translateY(-50%)translate(2px)}.sidebar-toggle-button .sidebar-button-text{writing-mode:vertical-rl;letter-spacing:2px;font-size:12px;font-weight:600}[data-theme=dark] .sidebar-toggle-button{color:var(--text-primary);background:#11182759;border-color:#4b556340}[data-theme=dark] .sidebar-toggle-button:hover{color:var(--accent-color);background:#1e3a8aa6}.sidebar-overlay{z-index:999;-webkit-backdrop-filter:blur(4px);background:#0006;animation:.3s fadeIn;position:fixed;inset:0}body:has(.dictation-page-overlay)::-webkit-scrollbar{width:0!important;height:0!important;display:none!important}html:has(.dictation-page-overlay)::-webkit-scrollbar{width:0!important;height:0!important;display:none!important}#root:has(.dictation-page-overlay)::-webkit-scrollbar{width:0!important;height:0!important;display:none!important}body:has(.dictation-page-overlay),html:has(.dictation-page-overlay),#root:has(.dictation-page-overlay){scrollbar-width:none!important;-ms-overflow-style:none!important}.scroll-to-current-btn{z-index:900;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(10px);background:#a0a0a0cc;border:none;border-radius:50px;align-items:center;gap:8px;padding:14px 20px;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);animation:.4s ease-out slideInFromRight;display:flex;position:fixed;top:50%;right:32px;transform:translateY(-50%);box-shadow:0 4px 20px #00000026}.scroll-to-current-btn:hover{color:#1a1a1a;background:#fef3c7f2;transform:translateY(calc(-50% - 2px));box-shadow:0 6px 24px #0003}.scroll-to-current-btn:active{transform:translateY(-50%);box-shadow:0 2px 12px #0003}[data-theme=dark] .scroll-to-current-btn{color:#fff;background:#a0a0a0b3}[data-theme=dark] .scroll-to-current-btn:hover{color:#1a1a1a;background:#fef3c7e6}.scroll-to-current-btn svg{flex-shrink:0;width:20px;height:20px}@keyframes slideInFromRight{0%{opacity:0;transform:translateY(-50%)translate(100px)}to{opacity:1;transform:translateY(-50%)translate(0)}}@media(max-width:768px){.scroll-to-current-btn{border-radius:50%;justify-content:center;width:48px;height:48px;padding:0;right:16px}.scroll-to-current-btn span{display:none}.scroll-to-current-btn:hover{transform:translateY(calc(-50% - 2px))}.sidebar-toggle-button{width:48px;height:80px;top:auto;bottom:120px;left:0;transform:none}.sidebar-toggle-button:hover{width:52px}.sidebar-toggle-button .sidebar-button-text{font-size:11px}.sidebar-toggle-button:hover{transform:scale(1.1)}.sidebar-toggle-button:active{transform:scale(.95)}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}.add-vocabulary-overlay{position:fixed;inset:0;background-color:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.add-vocabulary-popup{position:relative;z-index:1000001;width:340px;max-height:85vh;display:flex;flex-direction:column;background:var(--paper-color, #ffffff);border-radius:16px;box-shadow:0 20px 60px #0003,0 0 0 1px #0000000d;animation:popupFadeIn .25s ease;overflow:hidden}[data-theme=dark] .add-vocabulary-popup{background:#1f2937;box-shadow:0 10px 40px #0006,0 0 0 1px #ffffff1a}@keyframes popupFadeIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.add-vocabulary-popup.success{padding:40px 60px;display:flex;align-items:center;justify-content:center;position:relative;overflow:visible}.confetti-burst{position:absolute;top:50%;left:50%;width:0;height:0;z-index:100}.confetti-piece{position:absolute;width:12px;height:12px;border-radius:3px;animation:confetti-explode .8s cubic-bezier(.25,.46,.45,.94) forwards;animation-delay:var(--delay)}.confetti-0{background:#6366f1;transform:rotate(45deg)}.confetti-1{background:#22c55e;border-radius:50%}.confetti-2{background:#f59e0b;transform:rotate(30deg)}.confetti-3{background:#ec4899;border-radius:50%}.confetti-4{background:#8b5cf6;transform:rotate(60deg)}@keyframes confetti-explode{0%{transform:rotate(0) translate(0) scale(.5);opacity:1}50%{opacity:1}to{transform:rotate(var(--angle)) translate(var(--distance)) scale(1);opacity:0}}.success-content{display:flex;flex-direction:column;align-items:center;gap:16px;position:relative;z-index:1}.success-icon-wrapper{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;animation:successPop .4s cubic-bezier(.68,-.55,.265,1.55);box-shadow:0 8px 25px #22c55e66}.success-icon{color:#fff;font-size:32px;font-weight:700}.success-text{color:#22c55e;font-weight:600;font-size:18px;animation:fadeInUp .3s ease .2s both}@keyframes successPop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.popup-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border-color, #e5e7eb);flex-shrink:0}.popup-title{font-size:15px;font-weight:600;color:var(--text-primary, #1a1a1a)}.close-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent!important;border:none;color:#6b7280!important;cursor:pointer;transition:all .2s ease;flex-shrink:0}[data-theme=dark] .close-btn{color:#9ca3af!important}.close-btn:hover{background:#0000000d!important;color:#1f2937!important;border-radius:50%}[data-theme=dark] .close-btn:hover{background:#ffffff1a!important;color:#f3f4f6!important}.popup-content{padding:16px;overflow-y:auto;flex:1;min-height:0;overscroll-behavior:contain}.popup-content::-webkit-scrollbar{width:6px}.popup-content::-webkit-scrollbar-track{background:transparent}.popup-content::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.popup-content::-webkit-scrollbar-thumb:hover{background:#00000040}[data-theme=dark] .popup-content::-webkit-scrollbar-thumb{background:#ffffff26}[data-theme=dark] .popup-content::-webkit-scrollbar-thumb:hover{background:#ffffff40}.selected-text{margin-bottom:14px}.text-label{font-size:12px;color:var(--text-secondary, #888);margin-bottom:6px;display:block}.text-content-row{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-secondary, #f9fafb);border-radius:10px}[data-theme=dark] .text-content-row{background:#ffffff0d}.text-content{font-size:16px;font-weight:600;color:var(--text-primary, #1a1a1a);word-break:break-word;flex:1}.play-audio-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.play-audio-btn .icon-img{width:24px;height:24px}.play-audio-btn:hover{transform:scale(1.1);background:#8b5cf61a}.play-audio-btn:active{transform:scale(.95)}.looking-up{font-size:12px;color:var(--accent-color, #3b82f6);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.type-selector{display:flex;gap:8px;margin-bottom:14px}.type-btn{flex:1;padding:8px 12px;border:1px solid var(--border-color, #e5e7eb);background:transparent;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-secondary, #666);cursor:pointer;transition:all .15s ease}.type-btn:hover{background:var(--bg-hover, #f3f4f6);border-color:var(--accent-color, #3b82f6)}.type-btn.active{background:var(--accent-color, #3b82f6);border-color:var(--accent-color, #3b82f6);color:#fff}.input-group{margin-bottom:10px;position:relative}.phonetic-group,.meaning-group{position:relative}.auto-filled{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:11px;color:#22c55e;background:#22c55e1a;padding:2px 6px;border-radius:4px}.more-meanings{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:10px;padding:8px;background:var(--bg-secondary, #f3f4f6);border-radius:8px}[data-theme=dark] .more-meanings{background:#ffffff0d}.more-meanings-label{font-size:11px;color:var(--text-secondary, #888)}.meaning-tag{font-size:11px;padding:3px 8px;background:var(--accent-color, #3b82f6);color:#fff;border-radius:4px;cursor:pointer;transition:all .15s ease}.meaning-tag:hover{opacity:.8;transform:scale(1.05)}.translation-display{margin-bottom:12px;padding:12px;background:linear-gradient(135deg,#3b82f614,#8b5cf614);border-radius:10px;border:1px solid rgba(59,130,246,.15)}[data-theme=dark] .translation-display{background:linear-gradient(135deg,#3b82f626,#8b5cf626);border-color:#3b82f640}.translation-label{display:block;font-size:11px;color:var(--accent-color, #3b82f6);font-weight:600;margin-bottom:6px}.translation-text{font-size:15px;color:var(--text-primary, #1a1a1a);line-height:1.5;font-weight:500}.example-display{margin-bottom:12px;padding:12px;background:linear-gradient(135deg,#22c55e14,#10b98114);border-radius:10px;border:1px solid rgba(34,197,94,.15)}[data-theme=dark] .example-display{background:linear-gradient(135deg,#22c55e26,#10b98126);border-color:#22c55e40}.example-label{display:block;font-size:11px;color:#22c55e;font-weight:600;margin-bottom:6px}.example-text{font-size:14px;color:var(--text-primary, #1a1a1a);line-height:1.5;font-style:italic}.example-translation{font-size:13px;color:var(--text-secondary, #666);margin-top:6px;padding-top:6px;border-top:1px dashed rgba(34,197,94,.2)}.morpheme-display{margin-bottom:12px;padding:12px;background:linear-gradient(135deg,#f9731614,#ea580c14);border-radius:10px;border:1px solid rgba(249,115,22,.15)}[data-theme=dark] .morpheme-display{background:linear-gradient(135deg,#f9731626,#ea580c26);border-color:#f9731640}.morpheme-label{display:block;font-size:11px;color:#ea580c;font-weight:600;margin-bottom:8px}.morpheme-list{display:flex;flex-direction:column;gap:6px}.add-vocabulary-popup .morpheme-item{display:flex;align-items:center;gap:8px;font-size:13px;flex-wrap:wrap;padding:10px 14px;border-radius:8px;background:#ffffffe6!important;border-left:none!important}.add-vocabulary-popup .morpheme-item.prefix{background:#3b82f61a!important;border-left:3px solid #3b82f6!important}.add-vocabulary-popup .morpheme-item.root{background:#8b5cf61a!important;border-left:3px solid #8b5cf6!important}.add-vocabulary-popup .morpheme-item.suffix{background:#22c55e1a!important;border-left:3px solid #22c55e!important}.add-vocabulary-popup .morpheme-type{font-size:10px;padding:2px 6px;border-radius:4px;font-weight:600;flex-shrink:0}.add-vocabulary-popup .morpheme-item.prefix .morpheme-type{background:#3b82f633;color:#2563eb}.add-vocabulary-popup .morpheme-item.root .morpheme-type{background:#8b5cf633;color:#7c3aed}.add-vocabulary-popup .morpheme-item.suffix .morpheme-type{background:#22c55e33;color:#16a34a}.add-vocabulary-popup .morpheme-text{font-weight:600;color:#1f2937!important}.add-vocabulary-popup .morpheme-meaning{color:#374151!important;font-size:13px;font-weight:500}.add-vocabulary-popup .morpheme-origin{font-size:12px;color:#6b7280!important;margin-left:4px}.collocation-display{margin-bottom:12px;padding:12px;background:linear-gradient(135deg,#3b82f614,#6366f114);border-radius:10px;border:1px solid rgba(59,130,246,.15)}.collocation-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#3b82f6;margin-bottom:4px}.collocation-hint{font-size:11px;color:var(--text-secondary, #888);margin-bottom:8px}.collocation-list{display:flex;flex-direction:column;gap:6px}.collocation-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fffc;border-radius:8px;cursor:pointer;transition:all .2s ease;border:2px solid transparent}[data-theme=dark] .collocation-item{background:#0003}.collocation-item:hover{background:#3b82f61a;border-color:#3b82f64d}.collocation-item.selected{background:#3b82f626;border-color:#3b82f6}.collocation-phrase{font-weight:600;color:#3b82f6;font-size:13px}.collocation-meaning{font-size:12px;color:var(--text-secondary, #666);flex:1}.collocation-selected-badge{font-size:11px;color:#22c55e;font-weight:600;background:#22c55e1a;padding:2px 6px;border-radius:4px}.collocation-selected-info{margin-top:8px;padding:8px 10px;background:#22c55e1a;border-radius:6px;font-size:12px;color:#16a34a}.collocation-selected-info strong{color:#15803d}.input-group input{width:100%;padding:10px 12px;border:1px solid var(--border-color, #e5e7eb);border-radius:10px;font-size:14px;background:var(--paper-color, #ffffff);color:var(--text-primary, #1a1a1a);transition:all .15s ease}.input-group input:focus{outline:none;border-color:var(--accent-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.input-group input::-moz-placeholder{color:var(--text-secondary, #999)}.input-group input::placeholder{color:var(--text-secondary, #999)}[data-theme=dark] .input-group input{background:#ffffff0d;border-color:#ffffff1a}.error-message{padding:8px 12px;background:#fef2f2;color:#dc2626;border-radius:8px;font-size:13px;margin-top:10px}[data-theme=dark] .error-message{background:#dc262626}.already-exists-notice{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#fef2f2,#fee2e2);border-bottom:1px solid #fecaca;color:#dc2626;font-size:14px;font-weight:600;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notice-icon{font-size:16px}.add-btn.already-exists{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;border:1px solid #fca5a5;cursor:pointer}.add-btn.already-exists:hover{background:linear-gradient(135deg,#fecaca,#fca5a5)}.popup-actions{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--bg-secondary, #f9fafb);border-top:1px solid var(--border-color, #e5e7eb);flex-shrink:0}[data-theme=dark] .popup-actions{background:#00000026}.add-btn.primary-action{width:100%;padding:14px 24px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 14px #3b82f659;transition:all .2s ease}.add-btn.primary-action:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #3b82f673}.add-btn.primary-action:active:not(:disabled){transform:translateY(0)}.add-btn.primary-action:disabled{opacity:.7;cursor:not-allowed;transform:none}.icon-img{width:20px;height:20px;-o-object-fit:contain;object-fit:contain}.label-icon{width:16px;height:16px;-o-object-fit:contain;object-fit:contain;vertical-align:middle;margin-right:4px}.btn-icon{width:18px;height:18px;-o-object-fit:contain;object-fit:contain}.loading-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.shortcut-hints{display:flex;justify-content:center;gap:16px}.shortcut-hints .hint{font-size:12px;color:var(--text-secondary, #888);display:flex;align-items:center;gap:4px}.shortcut-hints kbd{display:inline-block;padding:2px 6px;font-size:11px;font-family:inherit;background:var(--paper-color, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:4px;box-shadow:0 1px 2px #0000000d}[data-theme=dark] .shortcut-hints kbd{background:#ffffff1a;border-color:#ffffff26}@media(max-width:480px){.add-vocabulary-popup{width:calc(100vw - 32px);max-width:320px}}.article-sidebar{position:fixed;top:0;left:-420px;width:420px;max-width:90vw;height:100vh;background:linear-gradient(180deg,var(--paper-color) 0%,var(--bg-color) 100%);box-shadow:8px 0 40px #0003;z-index:1000;display:flex;flex-direction:column;transition:left .4s cubic-bezier(.4,0,.2,1);overflow:hidden}.article-sidebar.open{left:0}[data-theme=dark] .article-sidebar{background:linear-gradient(180deg,#1e1e23fa,#141419fa);box-shadow:8px 0 40px #00000080}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(var(--text-primary-rgb, 0, 0, 0),.06);background:var(--paper-color);position:relative}.sidebar-header:after{display:none}.sidebar-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:.5px}.sidebar-close-button{width:36px;height:36px;border-radius:10px;border:none;background:rgba(var(--text-primary-rgb, 0, 0, 0),.04);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s ease}.sidebar-close-button:hover{background:#ef44441a;color:#ef4444;transform:rotate(90deg)}.sidebar-content{flex:1;overflow-y:auto;padding:20px;-webkit-overflow-scrolling:touch}.sidebar-content::-webkit-scrollbar{width:6px}.sidebar-content::-webkit-scrollbar-track{background:transparent}.sidebar-content::-webkit-scrollbar-thumb{background:rgba(var(--text-primary-rgb, 0, 0, 0),.15);border-radius:3px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:rgba(var(--text-primary-rgb, 0, 0, 0),.25)}.article-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}.article-item{position:relative;padding:0;border-radius:16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);background:var(--paper-color);border:1px solid rgba(var(--text-primary-rgb, 0, 0, 0),.06);overflow:hidden;display:flex;flex-direction:row;min-height:110px}.article-item-cover{width:90px;flex-shrink:0;aspect-ratio:9 / 16;overflow:hidden;position:relative;background:linear-gradient(135deg,rgba(var(--accent-color-rgb, 37, 99, 235),.05),rgba(var(--accent-color-rgb, 37, 99, 235),.02))}.article-item-cover img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;transition:all .5s cubic-bezier(.4,0,.2,1)}.article-item:hover .article-item-cover img{transform:scale(1.08)}.article-item-cover:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmerCover 2s ease-in-out infinite}@keyframes shimmerCover{0%{left:-100%}to{left:100%}}.article-item:not(:has(.article-item-cover)) .article-item-number{top:12px;left:12px}.article-item:not(:has(.article-item-cover)) .article-item-content{padding:18px 20px}.article-item:not(:has(.article-item-cover)):before{top:50%;transform:translateY(-50%)}.article-item:not(:has(.article-item-cover)):hover:before{height:50%}.article-item.active:not(:has(.article-item-cover)):before{height:85%;transform:translateY(-50%)}.article-item-number{position:absolute;top:8px;left:8px;width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,rgba(var(--accent-color-rgb, 37, 99, 235),.9),rgba(var(--accent-color-rgb, 37, 99, 235),.8));color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:Inter,sans-serif;z-index:10;box-shadow:0 2px 8px #0003}.article-item:before{content:"";position:absolute;left:0;top:0;height:0;width:4px;border-radius:0 4px 4px 0;background:linear-gradient(180deg,var(--accent-color) 0%,#60a5fa 100%);transition:height .3s cubic-bezier(.4,0,.2,1);z-index:10}.article-item:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(var(--accent-color-rgb, 37, 99, 235),.15);border-color:rgba(var(--accent-color-rgb, 37, 99, 235),.2)}.article-item:hover:before{height:calc(100% - 40px)}.article-item.active{background:linear-gradient(135deg,#3b82f62e,#6366f124,#8b5cf61a);border:2px solid;-o-border-image:linear-gradient(135deg,#3b82f6,#8b5cf6) 1;border-image:linear-gradient(135deg,#3b82f6,#8b5cf6) 1;box-shadow:0 8px 32px #3b82f640,0 4px 16px #6366f126,inset 0 0 20px #3b82f614;position:relative}.article-item.active{border:none;position:relative}.article-item.active:after{content:"";position:absolute;inset:0;border-radius:16px;padding:2px;background:linear-gradient(135deg,#3b82f6,#8b5cf6,#6366f1);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.article-item.active:before{height:calc(100% - 40px);background:linear-gradient(180deg,#3b82f6,#8b5cf6,#6366f1);width:5px;border-radius:0 3px 3px 0}.article-item.active .article-item-number{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;box-shadow:0 3px 12px #6366f180;transform:scale(1.05)}.article-item.active .article-item-title{background:linear-gradient(135deg,#2563eb,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}.article-item.active .article-item-category{background:linear-gradient(135deg,#3b82f633,#8b5cf626);color:#6366f1}.article-item-content{flex:1;min-width:0;padding:14px 16px 44px;position:relative;display:flex;flex-direction:column;justify-content:center}.article-item-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;transition:color .2s ease}.article-item:hover .article-item-title,.article-item.active .article-item-title{color:var(--accent-color)}.article-item-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}.article-meta-item{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--text-tertiary, #9ca3af);font-weight:500}.article-meta-item svg{width:12px;height:12px;opacity:.7}.article-item-category{display:inline-flex;align-items:center;font-size:11px;font-weight:600;color:var(--accent-color);background:linear-gradient(135deg,rgba(var(--accent-color-rgb, 37, 99, 235),.12),rgba(var(--accent-color-rgb, 37, 99, 235),.06));padding:5px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}.article-item.active .article-item-category{background:linear-gradient(135deg,rgba(var(--accent-color-rgb, 37, 99, 235),.2),rgba(var(--accent-color-rgb, 37, 99, 235),.1))}.article-progress-container{margin-top:8px}.article-progress-bar{height:4px;background:rgba(var(--text-primary-rgb, 0, 0, 0),.08);border-radius:2px;overflow:hidden;position:relative}.article-progress-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--accent-color) 0%,#60a5fa 100%);transition:width .5s cubic-bezier(.4,0,.2,1);position:relative}.article-progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.article-progress-text{font-size:11px;color:var(--text-tertiary, #9ca3af);margin-top:6px;font-weight:500;display:flex;align-items:center;gap:4px}.article-progress-text.completed{color:#10b981}.article-status-icon{position:absolute;bottom:12px;right:12px;display:flex;align-items:center;justify-content:center;animation:iconIn .3s cubic-bezier(.4,0,.2,1);z-index:2}.article-status-icon img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.article-status-icon.reading{width:28px;height:28px}.article-status-icon.new{width:42px;height:42px}.article-status-icon.new img{filter:brightness(0) saturate(100%) invert(55%) sepia(98%) saturate(1500%) hue-rotate(360deg) brightness(103%) contrast(105%);animation:newPulse 2s ease-in-out infinite}.article-status-icon.new:before{content:"";position:absolute;inset:-4px;background:radial-gradient(circle,rgba(255,140,0,.4) 0%,transparent 70%);border-radius:50%;animation:glowPulse 2s ease-in-out infinite;z-index:-1}.article-status-icon.new:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shine 3s ease-in-out infinite}@keyframes iconIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@keyframes newPulse{0%,to{transform:scale(1);filter:brightness(0) saturate(100%) invert(55%) sepia(98%) saturate(1500%) hue-rotate(360deg) brightness(103%) contrast(105%)}50%{transform:scale(1.08);filter:brightness(0) saturate(100%) invert(45%) sepia(98%) saturate(2000%) hue-rotate(10deg) brightness(110%) contrast(110%)}}@keyframes glowPulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}@keyframes shine{0%{left:-100%}20%{left:100%}to{left:100%}}.sidebar-empty{text-align:center;padding:60px 24px;color:var(--text-secondary)}.sidebar-empty-icon{width:64px;height:64px;margin:0 auto 16px;opacity:.3}.sidebar-empty p{font-size:15px;font-weight:500}.sidebar-footer{padding:20px 24px;border-top:1px solid rgba(var(--text-primary-rgb, 0, 0, 0),.08);background:linear-gradient(180deg,var(--bg-color) 0%,var(--paper-color) 100%)}.sidebar-footer-text{font-size:13px;color:var(--text-secondary);text-align:center;margin:0;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px}.sidebar-footer-text:before,.sidebar-footer-text:after{content:"";width:20px;height:1px;background:linear-gradient(90deg,transparent,var(--text-secondary),transparent);opacity:.3}.sidebar-dictation-entry{padding:16px 24px 24px}.dictation-sidebar-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;background:linear-gradient(135deg,var(--accent-color) 0%,#60a5fa 100%);color:#fff;border:none;border-radius:14px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px rgba(var(--accent-color-rgb, 37, 99, 235),.3)}.dictation-sidebar-btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px rgba(var(--accent-color-rgb, 37, 99, 235),.4)}.dictation-sidebar-btn:active{transform:translateY(0)}.dictation-sidebar-btn svg{width:20px;height:20px}@media(max-width:768px){.article-sidebar{width:90vw;left:-90vw}.article-item{flex-direction:row}.article-item-cover{width:75px}.article-item-number{top:10px;width:24px;height:24px;font-size:11px}.article-item:before{top:0}.article-item-title{font-size:14px}}@media(max-width:480px){.article-sidebar{width:95vw;left:-95vw}.sidebar-header{padding:20px}.sidebar-title{font-size:18px}.sidebar-content{padding:14px}.article-list{gap:10px}.article-item-cover{width:70px}.article-item-number{top:10px}.article-item:before{top:0}.article-item-content{padding:14px}}[data-theme=dark] .article-item{background:#ffffff08;border-color:#ffffff0f}[data-theme=dark] .article-item-cover{background:#3b82f60d}[data-theme=dark] .article-item-cover img{opacity:.9}[data-theme=dark] .article-item:hover .article-item-cover img{opacity:1}[data-theme=dark] .article-item:hover{background:#ffffff0f;border-color:rgba(var(--accent-color-rgb, 37, 99, 235),.3)}[data-theme=dark] .article-item.active{background:linear-gradient(135deg,#3b82f638,#6366f129,#8b5cf61f);box-shadow:0 8px 32px #6366f159,0 4px 16px #3b82f633,inset 0 0 30px #6366f11a}[data-theme=dark] .article-progress-bar{background:#ffffff1a}[data-theme=dark] .sidebar-footer{background:linear-gradient(180deg,#1e1e23cc,#141419e6)}.login-page{height:100vh;width:100vw;background:linear-gradient(135deg,#f9f8f6,#f5f4f2);display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box;overflow:hidden;position:fixed;inset:0}.login-wrapper{width:100%;max-width:420px}.login-container{background:#fff;border-radius:20px;box-shadow:0 8px 32px #00000014;width:100%;padding:40px 36px;transition:all .3s ease;max-height:calc(100vh - 40px);overflow:hidden;display:flex;flex-direction:column;position:relative}.login-back-btn{position:absolute;top:20px;left:20px;width:40px;height:40px;border-radius:50%;border:none;background:#0000000d;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.login-back-btn:hover{background:#0000001a;transform:scale(1.05)}.login-back-btn:active{transform:scale(.95)}.login-back-btn svg{width:20px;height:20px}.login-header{text-align:center;margin-bottom:32px;flex-shrink:0}.login-logo{font-family:"Noto Serif SC",serif;font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 8px;letter-spacing:-.5px}.login-logo .dot{color:var(--accent-color)}.login-subtitle{color:var(--text-secondary);font-size:14px;margin:0;font-weight:400}.auth-toggle{display:flex;background:#f3f4f6;border-radius:12px;padding:4px;margin-bottom:24px;gap:4px;flex-shrink:0}.toggle-btn{flex:1;padding:8px 16px;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.toggle-btn:hover{color:var(--text-primary)}.toggle-btn.active{background:#fff;color:var(--text-primary);box-shadow:0 2px 4px #0000000d;font-weight:600}.login-method-toggle{display:flex;gap:10px;margin-bottom:24px;flex-shrink:0}.method-btn{flex:1;padding:10px 16px;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.method-btn:hover{border-color:var(--accent-color);color:var(--accent-color)}.method-btn.active{border-color:var(--accent-color);background:#2563eb0d;color:var(--accent-color);font-weight:600}.login-content{flex:1;overflow-y:auto;min-height:0}.auth-form{display:flex;flex-direction:column;gap:20px}.form-section{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:14px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.label-row{display:flex;justify-content:space-between;align-items:center;width:100%}.forgot-password-link{background:none;border:none;color:var(--accent-color);font-size:12px;font-weight:500;cursor:pointer;padding:0;transition:all .2s ease}.forgot-password-link:hover{color:#1d4ed8;text-decoration:underline}.optional-badge{font-size:12px;font-weight:400;color:var(--text-secondary);background:#f3f4f6;padding:2px 8px;border-radius:4px}.form-group input{padding:13px 16px;border:1.5px solid #e5e7eb;border-radius:10px;font-size:15px;transition:all .2s ease;background:#fff;color:var(--text-primary)}.form-group input::-moz-placeholder{color:#9ca3af}.form-group input::placeholder{color:#9ca3af}.form-group input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 4px #2563eb14}.form-group input:disabled{background:#f9fafb;cursor:not-allowed;opacity:.6}.field-hint{font-size:12px;color:var(--text-secondary);margin-top:-4px}.supported-emails{display:flex;align-items:center;gap:10px;margin-top:10px;flex-wrap:wrap}.supported-label{font-size:12px;color:var(--text-secondary);font-weight:500;white-space:nowrap;flex-shrink:0}.email-providers{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-height:32px}.email-logo{height:32px;width:auto;min-width:32px;max-width:40px;-o-object-fit:contain;object-fit:contain;transition:all .2s ease;cursor:pointer;filter:brightness(1);display:inline-block;opacity:.85;vertical-align:middle}.email-logo:hover{transform:translateY(-2px) scale(1.1);filter:brightness(1.1);opacity:1}.email-logo[src=""],.email-logo:not([src]),.email-logo[src=undefined]{display:none}.email-logo:before{content:"";display:none}.code-input-group{display:flex;gap:12px}.code-input-group input{flex:1}.send-code-btn{padding:11px 16px;background:var(--accent-color);color:#fff;border:none;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s ease;min-width:100px}.send-code-btn:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.send-code-btn:disabled{background:#d1d5db;cursor:not-allowed;transform:none}.invite-code-group{display:flex;flex-direction:column;gap:6px}.invite-code-message{font-size:12px;padding:6px 10px;border-radius:6px;font-weight:500}.invite-code-message.valid{color:#059669;background:#d1fae5}.invite-code-message.invalid{color:#dc2626;background:#fee2e2}.auth-btn{padding:14px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:4px;flex-shrink:0}.auth-btn.primary{background:var(--text-primary);color:#fff}.auth-btn.primary:hover:not(:disabled){background:#000;transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.auth-btn:disabled{background:#d1d5db;cursor:not-allowed;transform:none;opacity:.6}.divider{display:flex;align-items:center;text-align:center;margin:0;flex-shrink:0}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid #e5e7eb}.divider span{padding:0 10px;color:var(--text-secondary);font-size:11px;background:#fff}.oauth-section{display:flex;flex-direction:row;gap:8px;flex-shrink:0}.oauth-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border:1.5px solid #e5e7eb;border-radius:10px;background:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;color:var(--text-primary)}.oauth-btn:hover:not(:disabled){border-color:var(--accent-color);background:#2563eb05;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.oauth-btn:disabled{opacity:.5;cursor:not-allowed}.oauth-btn svg{flex-shrink:0;width:18px;height:18px}.oauth-btn span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.error-message{padding:8px 12px;background:#fee2e2;border:1px solid #fecaca;border-radius:10px;color:#dc2626;font-size:12px;text-align:center;font-weight:500;flex-shrink:0}.success-message{padding:8px 12px;background:#d1fae5;border:1px solid #a7f3d0;border-radius:10px;color:#059669;font-size:12px;text-align:center;font-weight:500;flex-shrink:0}.login-footer{text-align:center;padding-top:12px;margin-top:12px;border-top:1px solid #e5e7eb;flex-shrink:0}.login-footer p{color:var(--text-secondary);font-size:10px;margin:0;line-height:1.3}.link-btn{background:none;border:none;color:var(--accent-color);font-size:12px;cursor:pointer;text-decoration:underline;padding:0;margin:0 2px}.link-btn:hover{color:#1d4ed8}@media(max-width:640px){.login-container{padding:28px 20px;border-radius:16px}.login-logo{font-size:28px}.login-subtitle{font-size:12px}.auth-toggle{margin-bottom:18px}.toggle-btn{padding:8px 14px;font-size:13px}.code-input-group{flex-direction:column}.send-code-btn{width:100%;min-width:auto}.login-method-toggle{flex-direction:column}.method-btn{width:100%}.oauth-section{flex-direction:column}}[data-theme=dark] .login-container{background:#2d3748;box-shadow:0 8px 32px #00000080}[data-theme=dark] .login-page{background:#1a202c}[data-theme=dark] .auth-toggle{background:#ffffff14}[data-theme=dark] .toggle-btn.active{background:#4299e126}[data-theme=dark] .method-btn{background:#1a202c;border-color:#fff3;color:var(--text-primary)}[data-theme=dark] .method-btn.active{background:#2563eb26;border-color:#2563eb66}[data-theme=dark] .form-group input{background:#1a202c;border-color:#fff3;color:var(--text-primary)}[data-theme=dark] .form-group input:focus{border-color:var(--accent-color);background:#1a202c}[data-theme=dark] .field-hint,[data-theme=dark] .supported-label{color:#a0aec0}[data-theme=dark] .oauth-btn{background:#1a202c;border-color:#fff3}[data-theme=dark] .divider:before,[data-theme=dark] .divider:after{border-color:#ffffff26}[data-theme=dark] .login-footer{border-color:#ffffff26}[data-theme=dark] .form-group label{color:#e2e8f0}.landing-page{position:fixed;inset:0;width:100vw;height:100vh;overflow:hidden;display:flex;flex-direction:column;z-index:1}.landing-background{position:absolute;inset:0;z-index:0;overflow:hidden}.bg-gradient{position:absolute;inset:0;background:linear-gradient(135deg,#f9f8f6,#f5f4f2,#f9f8f6);z-index:1}.bg-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 30%,rgba(156,163,175,.03) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(156,163,175,.02) 0%,transparent 50%);z-index:2;animation:patternMove 20s ease-in-out infinite}@keyframes patternMove{0%,to{transform:translate(0)}50%{transform:translate(-10px,-10px)}}.landing-nav{position:relative;z-index:10;padding:20px 40px;display:flex;justify-content:space-between;align-items:center;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:none}.landing-nav-content{width:100%;display:flex;justify-content:space-between;align-items:center}.landing-logo{font-family:"Noto Serif SC",serif;font-size:28px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.landing-logo-btn{background:none;border:none;cursor:pointer;padding:0;transition:all .2s ease;display:inline-block}.landing-logo-btn:hover{opacity:.8;transform:scale(1.05)}.landing-logo-btn:active{transform:scale(.98)}.landing-logo .dot{color:var(--accent-color);transition:color .3s ease}.landing-nav-buttons{display:flex;gap:20px;align-items:center;background:transparent;padding:0;border:none;backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:none}.nav-btn{padding:10px 24px!important;border-radius:6px;font-size:15px!important;font-weight:500;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);border:none;background:transparent;white-space:nowrap;line-height:1;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;min-height:40px!important;height:auto!important;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;letter-spacing:.02em}.login-btn{color:var(--text-primary)!important;background:transparent!important}.login-btn:hover{background:#00000008!important}.register-btn{background:#3f3f46!important;color:#fff!important;border:none!important;box-shadow:0 2px 4px #0000001a!important}.register-btn:hover{background:#18181b!important;box-shadow:0 4px 8px #00000026!important;transform:translateY(-1px)}.login-btn:active,.register-btn:active{transform:translateY(0)}.landing-content{position:relative;z-index:5;flex:1;display:flex;align-items:center;justify-content:center;padding:0 40px;min-height:0}.landing-hero{text-align:center;max-width:900px;animation:fadeInUp 1s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.landing-slogan-cn{font-family:"Noto Serif SC",serif;font-size:72px;font-weight:700;color:var(--text-primary);margin:0 0 28px;line-height:1.2;letter-spacing:-1px;background:linear-gradient(135deg,#1a1a1a,#4a4a4a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-divider{width:100px;height:2px;background:linear-gradient(90deg,transparent,var(--accent-color),transparent);margin:36px auto;animation:expandDivider 1.5s ease-out .5s both}@keyframes expandDivider{0%{width:0;opacity:0}to{width:80px;opacity:1}}.landing-slogan-en{font-family:Inter,sans-serif;font-size:48px;font-weight:600;color:var(--text-primary);margin:0 0 24px;letter-spacing:-.5px;opacity:.9}.landing-subtitle{font-family:Inter,sans-serif;font-size:20px;color:var(--text-secondary);margin:0;font-weight:400;letter-spacing:.5px}.landing-decoration{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}.landing-decoration .decoration-circle{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(156,163,175,.08) 0%,transparent 70%);animation:float 15s ease-in-out infinite;display:none}.circle-1{width:300px;height:300px;top:10%;left:10%;animation-delay:0s}.circle-2{width:200px;height:200px;top:60%;right:15%;animation-delay:5s}.circle-3{width:150px;height:150px;bottom:20%;left:20%;animation-delay:10s}@keyframes float{0%,to{transform:translate(0) scale(1);opacity:.5}50%{transform:translate(30px,-30px) scale(1.1);opacity:.8}}.landing-footer{position:relative;z-index:10;padding:24px 60px;text-align:center;background:#ffffff4d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid rgba(0,0,0,.05)}.landing-footer p{font-size:14px;color:var(--text-secondary);margin:0;font-style:italic;letter-spacing:.5px}[data-theme=dark] .landing-page,[data-theme=dark] .bg-gradient{background:linear-gradient(135deg,#1f2937,#111827,#1f2937)}[data-theme=dark] .landing-nav{background:transparent;border-bottom:none}[data-theme=dark] .landing-slogan-cn{background:linear-gradient(135deg,#f9fafb,#d1d5db);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=dark] .landing-nav-buttons{background:#ffffff0d;border-color:#ffffff1a}[data-theme=dark] .login-btn:hover{background:#ffffff0d!important}[data-theme=dark] .cta-btn.secondary{background:var(--paper-color);border-color:#fff3;color:var(--text-primary)}[data-theme=dark] .landing-footer{background:transparent;border-top:none}@media(max-width:768px){.landing-nav{padding:20px 32px}.landing-nav-content{flex-direction:column;gap:16px}.landing-nav-buttons{width:100%;justify-content:center}.landing-nav-buttons .nav-btn{flex:1;max-width:140px;padding:10px 16px!important;font-size:14px!important;min-height:40px!important}.landing-content{padding:0 24px}.landing-slogan-cn{font-size:48px}.landing-slogan-en{font-size:32px}.landing-subtitle{font-size:16px}.landing-footer{padding:20px 32px}}@media(max-width:480px){.landing-nav{padding:20px 24px}.landing-slogan-cn{font-size:40px}.landing-slogan-en{font-size:26px}.landing-subtitle{font-size:14px}.landing-footer{padding:20px 24px}}.loading-page{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg-color);z-index:9999;overflow:hidden}.loading-background{position:absolute;inset:0;overflow:hidden}.loading-gradient{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 50%,rgba(37,99,235,.08) 0%,transparent 50%);animation:gradientRotate 20s ease-in-out infinite}.loading-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(37,99,235,.03) 1px,transparent 0);background-size:40px 40px;opacity:.5}@keyframes gradientRotate{0%,to{transform:rotate(0)}50%{transform:rotate(180deg)}}.loading-content{position:relative;z-index:1;text-align:center;max-width:600px;padding:2rem}.loading-logo{margin-bottom:3rem;animation:fadeInDown .8s ease-out}.loading-logo-text{font-family:"Noto Serif SC",serif;font-size:42px;font-weight:700;color:var(--text-primary);letter-spacing:-1px}.loading-logo-dot{color:var(--accent-color);font-size:42px;font-weight:700}.loading-animation{margin-bottom:3rem;animation:fadeIn 1s ease-out .2s both}.loading-spinner{position:relative;width:80px;height:80px;margin:0 auto}.spinner-ring{position:absolute;width:100%;height:100%;border:3px solid transparent;border-top-color:var(--accent-color);border-radius:50%;animation:spin 1.2s cubic-bezier(.5,0,.5,1) infinite}.spinner-ring:nth-child(1){animation-delay:0s;opacity:1}.spinner-ring:nth-child(2){animation-delay:-.4s;opacity:.7;width:70%;height:70%;top:15%;left:15%}.spinner-ring:nth-child(3){animation-delay:-.8s;opacity:.5;width:50%;height:50%;top:25%;left:25%}.loading-slogan{margin-bottom:2.5rem;animation:fadeInUp 1s ease-out .4s both}.loading-slogan-cn{font-family:"Noto Serif SC",serif;font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 1rem;letter-spacing:2px;line-height:1.4}.loading-divider{width:60px;height:2px;background:var(--accent-color);margin:1rem auto;opacity:.6}.loading-slogan-en{font-family:Inter,sans-serif;font-size:18px;font-weight:500;color:var(--text-secondary);margin:0;letter-spacing:3px;text-transform:uppercase}.loading-message{animation:fadeIn 1s ease-out .6s both}.loading-text{font-family:Inter,sans-serif;font-size:15px;color:var(--text-secondary);margin:0 0 1rem;font-weight:500}.loading-dots{display:flex;justify-content:center;gap:8px;margin-top:1rem}.loading-dots span{width:8px;height:8px;border-radius:50%;background:var(--accent-color);animation:dotBounce 1.4s ease-in-out infinite}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-12px);opacity:1}}.loading-decoration{position:absolute;inset:0;pointer-events:none;z-index:0}.decoration-circle{position:absolute;border-radius:50%;background:var(--accent-color);opacity:.1;animation:float 6s ease-in-out infinite}.circle-1{width:200px;height:200px;top:10%;left:10%;animation-delay:0s}.circle-2{width:150px;height:150px;top:60%;right:15%;animation-delay:2s}.circle-3{width:100px;height:100px;bottom:15%;left:20%;animation-delay:4s}@keyframes float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,-30px) scale(1.1)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.loading-page.dark .loading-gradient{background:radial-gradient(circle at 30% 50%,rgba(59,130,246,.12) 0%,transparent 50%)}.loading-page.dark .loading-pattern{background-image:radial-gradient(circle at 1px 1px,rgba(59,130,246,.05) 1px,transparent 0)}@media(max-width:768px){.loading-logo-text,.loading-logo-dot{font-size:36px}.loading-slogan-cn{font-size:26px;letter-spacing:1px}.loading-slogan-en{font-size:16px;letter-spacing:2px}.loading-spinner{width:60px;height:60px}.circle-1{width:150px;height:150px}.circle-2{width:120px;height:120px}.circle-3{width:80px;height:80px}}@media(max-width:480px){.loading-content{padding:1.5rem}.loading-logo-text,.loading-logo-dot{font-size:32px}.loading-slogan-cn{font-size:22px}.loading-slogan-en{font-size:14px;letter-spacing:1px}.loading-text{font-size:14px}}.theme-toggle{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:10px;cursor:pointer;color:#6b7280;transition:all .2s ease;box-shadow:0 1px 2px #0000000d;padding:0;margin:0}.theme-toggle:hover{background:#fff;border-color:#00000026;color:#111827;transform:scale(1.05);box-shadow:0 2px 4px #0000001a}.theme-toggle:active{transform:scale(.95)}.theme-toggle svg{width:18px;height:18px;transition:transform .3s ease}.theme-toggle:hover svg{transform:rotate(15deg)}[data-theme=dark] .theme-toggle{background:#1f2937e6;border-color:#ffffff1a;color:#9ca3af}[data-theme=dark] .theme-toggle:hover{background:#1f2937;border-color:#fff3;color:#fff}.ranking-display{width:100%}.ranking-display.loading,.ranking-display.error{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-secondary, #666);font-size:16px}.ranking-card{background:var(--paper-color, #fff);border:1px solid var(--border-color, #e5e5e5);border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000000f}.ranking-header{display:flex;align-items:center;gap:20px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border-color, #e5e5e5)}.ranking-badge{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:100px}.ranking-icon{width:48px;height:48px;-o-object-fit:contain;object-fit:contain}.ranking-number{font-size:28px;font-weight:700;color:#d946ef;background:linear-gradient(135deg,#d946ef,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ranking-main{flex:1}.ranking-info{display:flex;flex-direction:column;gap:4px}.ranking-label{font-size:12px;font-weight:600;color:var(--text-secondary, #666);text-transform:uppercase;letter-spacing:.5px}.ranking-percentage{font-size:16px;font-weight:500;color:var(--text-primary, #1a1a1a)}.ranking-metrics{display:flex;justify-content:space-around;align-items:center;gap:12px;margin-bottom:24px;padding:20px;background:var(--bg-color, #f5f5f5);border-radius:8px}.metric-item{flex:1;text-align:center}.metric-label{font-size:12px;color:var(--text-secondary, #666);margin-bottom:8px;font-weight:500}.metric-value{display:flex;align-items:baseline;justify-content:center;gap:4px}.metric-number{font-size:24px;font-weight:700;color:var(--text-primary, #1a1a1a)}.metric-unit{font-size:12px;color:var(--text-secondary, #666)}.metric-divider{width:1px;height:40px;background:var(--border-color, #e5e5e5)}.ranking-formula{margin-bottom:24px;padding:16px;background:var(--info-bg, #f8f9ff);border-left:4px solid #d946ef;border-radius:8px}.formula-title{font-size:12px;font-weight:600;color:var(--text-secondary, #666);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.formula-content{font-size:14px;color:var(--text-primary, #1a1a1a);font-weight:500;font-family:Monaco,Courier,monospace}.nearby-rankings{margin-bottom:24px}.nearby-title{font-size:14px;font-weight:600;color:var(--text-primary, #1a1a1a);margin-bottom:12px}.nearby-list{display:flex;flex-direction:column;gap:8px}.nearby-item{display:flex;align-items:center;gap:16px;padding:12px;background:var(--bg-color, #f5f5f5);border-radius:8px;transition:all .2s ease}.nearby-item:hover{background:var(--info-bg, #f8f9ff)}.nearby-item.current-user{background:linear-gradient(135deg,#fef3ff,#f8f9ff);border:1px solid #d946ef;font-weight:600}.nearby-rank{font-size:14px;font-weight:700;color:#d946ef;min-width:50px}.user-avatar-mini{width:32px;height:32px;flex-shrink:0}.user-avatar-mini img{width:100%;height:100%;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:1.5px solid #fff;box-shadow:0 2px 4px #0000000d}.nearby-item.current-user .user-avatar-mini img{border-color:#d946ef}.rank-medal{width:40px;height:40px;-o-object-fit:contain;object-fit:contain;min-width:50px;display:flex;align-items:center;justify-content:center}.nearby-name{flex:1;font-size:14px;color:var(--text-primary, #1a1a1a)}.nearby-score{font-size:14px;font-weight:600;color:var(--text-secondary, #666)}.ranking-refresh-btn{width:100%;padding:12px 16px;background:transparent;border:1px solid var(--border-color, #e5e5e5);border-radius:8px;color:var(--text-secondary, #666);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease}.ranking-refresh-btn:hover{background:var(--accent-light, #fae8ff);border-color:#d946ef;color:#d946ef}.ranking-refresh-btn:active{transform:scale(.98)}[data-theme=dark] .ranking-card{background:var(--paper-color);border-color:var(--border-color)}[data-theme=dark] .ranking-header{border-bottom-color:var(--border-color)}[data-theme=dark] .ranking-metrics{background:var(--bg-color)}[data-theme=dark] .metric-divider{background:var(--border-color)}[data-theme=dark] .ranking-formula{background:var(--info-bg);border-left-color:#d946ef}[data-theme=dark] .nearby-item{background:var(--bg-color)}[data-theme=dark] .nearby-item:hover{background:var(--info-bg)}[data-theme=dark] .nearby-item.current-user{background:linear-gradient(135deg,var(--accent-light) 0%,var(--info-bg) 100%);border-color:#d946ef}[data-theme=dark] .ranking-refresh-btn{border-color:var(--border-color);color:var(--text-secondary)}[data-theme=dark] .ranking-refresh-btn:hover{background:var(--accent-light);border-color:#d946ef;color:#d946ef}.points-display{width:100%;max-width:100%;margin:0 auto}.points-display.loading{text-align:center;padding:40px;color:var(--text-secondary, #999);font-size:14px}.points-card{background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);border-radius:20px;padding:28px;color:#fff;box-shadow:0 10px 40px #6366f14d,0 2px 10px #0000001a;position:relative;overflow:hidden}.points-card:before{content:"";position:absolute;top:-100px;right:-100px;width:250px;height:250px;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);border-radius:50%}.points-card:after{content:"";position:absolute;bottom:-80px;left:-80px;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.points-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;position:relative;z-index:1}.level-badge{display:flex;flex-direction:column;gap:4px}.level-number{font-size:36px;font-weight:800;line-height:1;letter-spacing:-1px}.level-name{font-size:14px;font-weight:600;opacity:.9;letter-spacing:.5px}.points-main{text-align:right}.points-value{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.points-number{font-size:56px;font-weight:900;line-height:1;letter-spacing:-2px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.points-label{font-size:14px;opacity:.9;letter-spacing:1px;font-weight:600}.level-progress-bar{height:8px;background:#fff3;border-radius:10px;overflow:hidden;margin-bottom:10px;position:relative;z-index:1}.progress-fill{height:100%;background:linear-gradient(90deg,#ffffffe6,#fbbf24);border-radius:10px;transition:width .8s ease;position:relative}.level-progress-text{font-size:12px;opacity:.9;text-align:center;margin-bottom:20px;font-weight:500;position:relative;z-index:1}.points-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;position:relative;z-index:1}.stat-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;background:#ffffff1f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:14px;border:1px solid rgba(255,255,255,.15);transition:all .2s ease}.stat-item:hover{background:#ffffff2e;transform:translateY(-2px)}.stat-icon{font-size:24px}.stat-value{font-size:22px;font-weight:800;line-height:1}.stat-label{font-size:11px;opacity:.9;font-weight:600;letter-spacing:.5px}@media(max-width:480px){.points-card{padding:24px 20px;border-radius:16px}.level-number{font-size:28px}.points-number{font-size:38px}.points-stats{gap:8px}.stat-item{padding:12px 8px}.stat-icon{font-size:20px}.stat-value{font-size:18px}.stat-label{font-size:10px}}[data-theme=dark] .points-card{background:linear-gradient(135deg,#4f46e5,#7c3aed,#9333ea);box-shadow:0 10px 40px #4f46e566,0 2px 10px #0003}.check-in-success-modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99999;display:flex;align-items:flex-start;justify-content:center;animation:fadeIn .2s ease;padding:80px 20px 20px;box-sizing:border-box;overflow-y:auto}.check-in-success-modal{background:#fff;border-radius:16px;padding:16px;max-width:480px;width:90%;height:auto;max-height:calc(100vh - 160px);overflow:visible;display:flex;flex-direction:column;position:relative;box-shadow:0 25px 50px #00000080,0 0 0 1px #d946ef33 inset;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);border:2px solid rgba(217,70,239,.3);margin:0 auto;z-index:100001}.modal-content-scrollable{flex:1;overflow-y:auto;min-height:0;overflow-x:hidden}[data-theme=dark] .check-in-success-modal{background:#1f2937}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{text-align:center;padding:0 0 10px;position:relative;flex-shrink:0;border-bottom:1px solid #e5e5e5;margin-bottom:10px}.modal-close-x{position:absolute;top:12px;right:12px;width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);font-size:24px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;z-index:100003;line-height:1}.modal-close-x:hover{color:var(--text-primary);background:var(--hover-bg);border-radius:6px}.modal-close-x:active{transform:scale(.95)}.success-icon-large{position:relative;width:60px;height:60px;margin:0 auto 10px;display:flex;align-items:center;justify-content:center}.success-icon-ring-large{position:absolute;width:60px;height:60px;border:3px solid #d946ef;border-radius:50%;animation:ringPulse 1.5s ease-out infinite}.success-icon-ring-large.ring-2{animation-delay:.5s;border-color:#a855f7}@keyframes ringPulse{0%{transform:scale(.8);opacity:1}to{transform:scale(1.5);opacity:0}}.success-check{font-size:36px;color:#d946ef;font-weight:700;z-index:1;animation:checkBounce .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes checkBounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.modal-title{font-size:15px;font-weight:700;color:#1a1a1a;margin:0 0 6px}.points-display-large{display:flex;align-items:baseline;justify-content:center;gap:8px}.points-plus-large{font-size:24px;color:#d946ef;font-weight:700;animation:fadeInUp .6s ease .2s both}.points-number-large{font-size:24px;color:#d946ef;font-weight:800;animation:fadeInUp .6s ease .3s both}.points-unit-large{font-size:13px;color:#888;animation:fadeInUp .6s ease .4s both}.user-stats-section{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:0 0 24px;flex-shrink:0;align-items:start}.stat-card-large{background:#f5f5f5;border-radius:12px;padding:16px 4px;text-align:center;transition:all .2s ease;border:1px solid transparent;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100px;box-sizing:border-box;margin:0}.stat-card-large:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.stat-card-large.stat-highlight{background:#f5f5f5!important;border:1px solid transparent!important;padding:16px 4px!important}[data-theme=dark] .stat-card-large.stat-highlight{background:#333!important}.stat-icon-img-large{width:32px;height:32px;-o-object-fit:contain;object-fit:contain}.rank-medal-img{width:28px;height:28px;-o-object-fit:contain;object-fit:contain}.stat-icon-large{font-size:24px;margin-bottom:6px;line-height:1;display:flex;align-items:center;justify-content:center;height:32px;width:100%}.stat-value-large{font-size:20px;font-weight:800;color:#d946ef;margin-bottom:2px;line-height:1.2;display:block}.stat-card-large.stat-highlight .stat-value-large{color:#d946ef!important;font-size:20px!important;font-weight:800!important}.stat-label-large{font-size:11px;color:#666;font-weight:500;line-height:1;margin-top:0;display:block}.ranking-section{padding:0;display:flex;flex-direction:column;min-height:0;flex:1;overflow:hidden;gap:6px}.ranking-header{display:flex;justify-content:space-between;align-items:center;flex-shrink:0;margin-bottom:4px}.ranking-title{font-size:16px;font-weight:700;color:#1a1a1a;margin:0;display:flex;align-items:center;gap:6px}.ranking-title-rank{font-size:14px;font-weight:600;color:#d946ef}.ranking-tabs{display:flex;gap:8px;background:transparent;border-radius:0;padding:0}[data-theme=dark] .ranking-tabs{background:transparent}.tab-btn{padding:6px 16px;border:1px solid #e5e5e5;background:transparent;color:#666;border-radius:20px;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s ease}.tab-btn:hover{color:#d946ef;border-color:#d946ef}[data-theme=dark] .tab-btn{border-color:#444;color:#aaa}[data-theme=dark] .tab-btn:hover{color:#d946ef;border-color:#d946ef}.tab-btn.active{background:#d946ef;color:#fff;border-color:#d946ef}.ranking-loading{text-align:center;padding:40px;color:var(--text-secondary)}.ranking-list{display:flex;flex-direction:column;gap:6px;flex:1;overflow-y:auto;min-height:0;overflow-x:hidden}.ranking-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#f5f5f5;border-radius:6px;transition:all .2s ease;flex-shrink:0}.ranking-item:hover{background:linear-gradient(135deg,#d946ef14,#d946ef0a);transform:translate(4px)}.ranking-item.is-me{background:linear-gradient(135deg,#d946ef26,#d946ef14);border:2px solid rgba(217,70,239,.3)}.user-avatar-container{width:36px;height:36px;flex-shrink:0}.user-ranking-avatar{width:100%;height:100%;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:1.5px solid #fff;box-shadow:0 2px 4px #0000000d}.ranking-item.is-me .user-ranking-avatar{border-color:#d946ef}.ranking-position{min-width:40px;display:flex;align-items:center;justify-content:center}.rank-number-large{display:flex;align-items:center;justify-content:center;font-weight:700;color:#d946ef;font-size:16px}.rank-medal{font-size:20px;display:flex;align-items:center;justify-content:center}.user-name{font-size:14px;font-weight:600;color:#1a1a1a;display:flex;align-items:center;gap:6px}.user-score-small{font-size:12px;color:#888}.user-score-large{font-size:16px;font-weight:700;color:#d946ef;min-width:70px;text-align:right}.me-badge{background:#d946ef;color:#fff;font-size:11px;padding:2px 6px;border-radius:10px;font-weight:600}.user-rank-info{text-align:center;padding:8px;background:#f5f5f5;border-radius:6px;color:#888;font-size:12px;flex-shrink:0;margin-top:4px}.user-rank-info strong{color:#d946ef;font-size:14px;font-weight:700}[data-theme=dark] .check-in-success-modal{background:#2a2a2a}[data-theme=dark] .modal-header{border-bottom-color:#444}[data-theme=dark] .modal-title{color:#fff}[data-theme=dark] .stat-card-large{background:#333}[data-theme=dark] .stat-value-large,[data-theme=dark] .stat-card-large.stat-highlight .stat-value-large{color:#d946ef}[data-theme=dark] .ranking-item{background:#333}[data-theme=dark] .ranking-item.is-me{background:linear-gradient(135deg,#d946ef26,#d946ef14)}[data-theme=dark] .ranking-title,[data-theme=dark] .user-name{color:#fff}[data-theme=dark] .ranking-tabs,[data-theme=dark] .user-rank-info{background:#333}.ranking-list::-webkit-scrollbar{width:6px}.ranking-list::-webkit-scrollbar-track{background:transparent}.ranking-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.ranking-list::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.check-in-container{position:relative;width:100%}.check-in-button{width:100%;padding:18px 32px;border:none;border-radius:14px;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .25s ease;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 4px 16px #6366f159;position:relative;overflow:hidden}.check-in-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #6366f173}.check-in-button:active:not(:disabled){transform:translateY(0)}.check-in-button:disabled{cursor:not-allowed}.check-in-button.checked{background:linear-gradient(135deg,#10b981,#34d399);box-shadow:0 4px 16px #10b98159}.check-in-button.checked:hover:not(:disabled){box-shadow:0 8px 24px #10b98173}.check-icon,.calendar-icon{font-size:18px}.check-in-info{margin-top:20px}.streak-display{display:flex;align-items:center;gap:16px;padding:20px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:16px;margin-bottom:16px;border:1px solid rgba(251,191,36,.3)}[data-theme=dark] .streak-display{background:linear-gradient(135deg,#fbbf2426,#f59e0b26);border-color:#fbbf2433}.fire-icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:64px;height:64px;flex-shrink:0}.fire-icon{font-size:48px;filter:drop-shadow(0 2px 4px rgba(245,158,11,.4))}.streak-count{position:absolute;bottom:2px;right:-4px;font-size:18px;font-weight:900;color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #f59e0b80;border:2px solid white}[data-theme=dark] .streak-count{border-color:#1f2937}.streak-text{flex:1;display:flex;flex-direction:column;gap:4px}.streak-label{font-size:12px;font-weight:600;color:#92400e;letter-spacing:.5px}[data-theme=dark] .streak-label{color:#fbbf24}.streak-days{font-size:26px;font-weight:800;color:#d97706;line-height:1}[data-theme=dark] .streak-days{color:#fbbf24}.milestone-progress{padding:16px 20px;background:var(--paper-color, #ffffff);border-radius:14px;border:1px solid var(--border-color, #e5e7eb);box-shadow:0 1px 3px #0000000d}[data-theme=dark] .milestone-progress{background:#3741514d;border-color:#4b556380}.milestone-text{font-size:13px;color:var(--text-secondary, #6b7280);margin-bottom:8px;font-weight:500}.milestone-reward{font-size:15px;font-weight:700;color:#8b5cf6;margin-bottom:12px}[data-theme=dark] .milestone-reward{color:#a78bfa}.milestone-bar{height:8px;background:#8b5cf626;border-radius:10px;overflow:hidden}.milestone-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#a855f7);border-radius:10px;transition:width .5s ease}.check-in-result{position:fixed;inset:0;background:#000000bf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:modalFadeIn .4s ease;cursor:pointer}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.fireworks-container{position:absolute;inset:0;pointer-events:none;overflow:hidden}.firework{position:absolute;width:8px;height:8px;border-radius:50%;animation:fireworkBurst 1.5s ease-out forwards}.firework-0{background:#ff6b6b}.firework-1{background:#ffd93d}.firework-2{background:#6bcb77}.firework-3{background:#4d96ff}.firework-4{background:#c36bff}@keyframes fireworkBurst{0%{transform:translateY(50vh) scale(0);opacity:1}50%{opacity:1}to{transform:translateY(-20vh) scale(1.5);opacity:0}}.result-card-premium{position:relative;background:linear-gradient(145deg,#fff,#f8fafc);border-radius:28px;padding:48px 40px 36px;text-align:center;max-width:420px;width:92%;box-shadow:0 25px 80px #6366f14d,0 10px 40px #0003,inset 0 1px #fffc;animation:cardEntrance .6s cubic-bezier(.34,1.56,.64,1);overflow:hidden;cursor:default}[data-theme=dark] .result-card-premium{background:linear-gradient(145deg,#1f2937,#111827);box-shadow:0 25px 80px #6366f140,0 10px 40px #0006,inset 0 1px #ffffff1a}@keyframes cardEntrance{0%{transform:translateY(60px) scale(.8);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.glow-bg{position:absolute;inset:-50%;background:radial-gradient(circle at 50% 30%,rgba(99,102,241,.15) 0%,transparent 50%);animation:glowRotate 10s linear infinite;pointer-events:none}@keyframes glowRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success-icon-wrapper{position:relative;width:100px;height:100px;margin:0 auto 24px}.success-icon-ring{position:absolute;inset:0;border:3px solid;border-color:#10b981 transparent #10b981 transparent;border-radius:50%;animation:ringRotate 2s linear infinite}.success-icon-ring.ring-2{border-color:transparent #34d399 transparent #34d399;animation:ringRotate 2s linear infinite reverse;animation-delay:.5s}@keyframes ringRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70px;height:70px;background:linear-gradient(135deg,#10b981,#34d399);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:900;color:#fff;box-shadow:0 8px 32px #10b98166;animation:iconPop .5s cubic-bezier(.34,1.56,.64,1) .2s both}@keyframes iconPop{0%{transform:translate(-50%,-50%) scale(0)}to{transform:translate(-50%,-50%) scale(1)}}.result-title-premium{font-size:28px;font-weight:800;color:var(--text-primary, #1f2937);margin-bottom:20px;letter-spacing:2px}.points-showcase{display:flex;align-items:baseline;justify-content:center;gap:4px;margin-bottom:20px;animation:pointsCountUp .8s ease-out .3s both}@keyframes pointsCountUp{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.points-plus{font-size:36px;font-weight:900;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.points-number{font-size:72px;font-weight:900;background:linear-gradient(135deg,#6366f1,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;text-shadow:0 4px 30px rgba(99,102,241,.3)}.points-unit{font-size:20px;font-weight:700;color:var(--text-secondary, #6b7280);margin-left:4px}.bonus-badges{margin:16px 0 24px;display:flex;flex-direction:column;gap:8px;animation:bonusFadeIn .5s ease .5s both}@keyframes bonusFadeIn{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.bonus-badge{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;border-radius:30px;font-size:15px;font-weight:700;box-shadow:0 6px 20px #f59e0b66;animation:badgePulse 2s ease-in-out infinite}.bonus-star{font-size:16px;animation:starSpin 1s ease-in-out infinite}@keyframes starSpin{0%,to{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.2)}}@keyframes badgePulse{0%,to{box-shadow:0 6px 20px #f59e0b66}50%{box-shadow:0 8px 30px #f59e0b99}}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:24px 0;animation:statsSlideIn .6s ease .4s both}@keyframes statsSlideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.stat-card{background:var(--bg-secondary, #f3f4f6);border-radius:16px;padding:16px 12px;transition:all .3s ease}[data-theme=dark] .stat-card{background:#37415180}.stat-card.highlight{background:linear-gradient(135deg,#6366f126,#a855f726);border:1px solid rgba(99,102,241,.3)}[data-theme=dark] .stat-card.highlight{background:linear-gradient(135deg,#6366f140,#a855f740)}.stat-icon{font-size:28px;margin-bottom:8px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.stat-value{font-size:28px;font-weight:900;color:var(--text-primary, #1f2937);line-height:1;margin-bottom:4px}.stat-card.highlight .stat-value{background:linear-gradient(135deg,#6366f1,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:12px;font-weight:600;color:var(--text-secondary, #6b7280);letter-spacing:.5px}.level-showcase{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 24px;background:linear-gradient(135deg,#6366f11a,#a855f71a);border-radius:30px;margin-bottom:16px}.level-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-radius:20px;font-size:14px;font-weight:800;box-shadow:0 4px 12px #6366f159}.level-name{font-size:15px;font-weight:700;color:var(--text-primary, #1f2937)}.level-points{font-size:14px;font-weight:600;color:var(--text-secondary, #6b7280)}.close-hint{font-size:13px;color:var(--text-muted, #9ca3af);opacity:.7;animation:hintBlink 2s ease-in-out infinite}@keyframes hintBlink{0%,to{opacity:.5}50%{opacity:.8}}@media(max-width:480px){.check-in-button{padding:16px 24px;font-size:15px}.streak-display{padding:16px;gap:12px}.fire-icon-wrapper{width:56px;height:56px}.fire-icon{font-size:40px}.streak-count{width:24px;height:24px;font-size:14px}.streak-days{font-size:22px}.result-card{padding:32px 24px}.result-icon{font-size:56px}.result-title{font-size:20px}.result-points{font-size:36px}}.achievement-icon{display:inline-flex;align-items:center;justify-content:center}.icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center;transition:transform .3s ease;background:transparent}.icon-wrapper:hover{transform:scale(1.1) rotate(5deg)}.achievement-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;position:relative;z-index:2;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.icon-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;border-radius:50%;z-index:1;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}}.icon-wrapper.locked{opacity:.3;filter:grayscale(100%)}.lock-icon{font-size:100%;opacity:.5}.achievement-icon-small .icon-wrapper{width:48px;height:48px}.achievement-icon-medium .icon-wrapper{width:64px;height:64px}.achievement-icon-large .icon-wrapper{width:80px;height:80px}.icon-common-teal .achievement-image{filter:sepia(20%) hue-rotate(130deg) saturate(2) brightness(1.1) drop-shadow(0 4px 10px rgba(32,178,170,.8))}.icon-common-teal .icon-glow{background:radial-gradient(circle,rgba(32,178,170,.5) 0%,transparent 70%)}.icon-common-coral .achievement-image{filter:sepia(30%) hue-rotate(-20deg) saturate(2.5) brightness(1.1) drop-shadow(0 4px 10px rgba(255,107,107,.8))}.icon-common-coral .icon-glow{background:radial-gradient(circle,rgba(255,107,107,.5) 0%,transparent 70%)}.icon-common-mint .achievement-image{filter:sepia(20%) hue-rotate(140deg) saturate(2) brightness(1.15) drop-shadow(0 4px 10px rgba(78,205,196,.8))}.icon-common-mint .icon-glow{background:radial-gradient(circle,rgba(78,205,196,.5) 0%,transparent 70%)}.icon-common-brown .achievement-image{filter:sepia(50%) hue-rotate(10deg) saturate(1.5) brightness(1.05) drop-shadow(0 4px 10px rgba(139,115,85,.8))}.icon-common-brown .icon-glow{background:radial-gradient(circle,rgba(139,115,85,.5) 0%,transparent 70%)}.icon-common-olive .achievement-image{filter:sepia(30%) hue-rotate(50deg) saturate(2) brightness(1.1) drop-shadow(0 4px 10px rgba(124,179,66,.8))}.icon-common-olive .icon-glow{background:radial-gradient(circle,rgba(124,179,66,.5) 0%,transparent 70%)}.icon-common-cyan .achievement-image{filter:sepia(20%) hue-rotate(100deg) saturate(2.5) brightness(1.2) drop-shadow(0 4px 10px rgba(67,233,123,.8))}.icon-common-cyan .icon-glow{background:radial-gradient(circle,rgba(67,233,123,.5) 0%,transparent 70%)}.icon-common .achievement-image{filter:grayscale(40%) brightness(.95) drop-shadow(0 4px 10px rgba(128,128,128,.8))}.icon-common .icon-glow{background:radial-gradient(circle,rgba(128,128,128,.4) 0%,transparent 70%)}.icon-rare .achievement-image{filter:sepia(30%) hue-rotate(180deg) saturate(3) brightness(1.15) drop-shadow(0 4px 15px rgba(0,140,255,1))}.icon-rare .icon-glow{background:radial-gradient(circle,rgba(0,112,221,.5) 0%,transparent 70%)}.icon-epic .achievement-image{filter:sepia(60%) hue-rotate(260deg) saturate(3) brightness(1.25) drop-shadow(0 4px 18px rgba(163,53,238,1))}.icon-epic .icon-glow{background:radial-gradient(circle,rgba(163,53,238,.5) 0%,transparent 70%)}.icon-legendary .achievement-image{animation:rainbow 3s linear infinite;filter:brightness(1.4) contrast(1.3) saturate(2) drop-shadow(0 4px 20px rgba(255,180,0,1))}.icon-legendary .icon-glow{background:radial-gradient(circle,rgba(255,180,0,.6) 0%,transparent 70%);animation:legendaryPulse 1.5s ease-in-out infinite}@keyframes legendaryPulse{0%,to{opacity:.7;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}}@keyframes rainbow{0%{filter:hue-rotate(0deg) brightness(1.3) contrast(1.3) saturate(2) drop-shadow(0 4px 16px rgba(255,0,0,.8))}16.6%{filter:hue-rotate(60deg) brightness(1.3) contrast(1.3) saturate(2) drop-shadow(0 4px 16px rgba(255,255,0,.8))}33.3%{filter:hue-rotate(120deg) brightness(1.3) contrast(1.3) saturate(2) drop-shadow(0 4px 16px rgba(0,255,0,.8))}50%{filter:hue-rotate(180deg) brightness(1.3) contrast(1.3) saturate(2) drop-shadow(0 4px 16px rgba(0,255,255,.8))}66.6%{filter:hue-rotate(240deg) brightness(1.3) contrast(1.3) saturate(2) drop-shadow(0 4px 16px rgba(0,0,255,.8))}83.3%{filter:hue-rotate(300deg) brightness(1.3) contrast(1.3) saturate(2) drop-shadow(0 4px 16px rgba(255,0,255,.8))}to{filter:hue-rotate(360deg) brightness(1.3) contrast(1.3) saturate(2) drop-shadow(0 4px 16px rgba(255,0,0,.8))}}[data-theme=dark] .achievement-image{filter:brightness(1.2) drop-shadow(0 4px 8px rgba(255,255,255,.3))}[data-theme=dark] .icon-common .achievement-image{filter:grayscale(40%) brightness(1.2) drop-shadow(0 4px 12px rgba(180,180,180,.8))}[data-theme=dark] .icon-rare .achievement-image{filter:sepia(30%) hue-rotate(180deg) saturate(3) brightness(1.4) drop-shadow(0 4px 18px rgba(100,180,255,1))}[data-theme=dark] .icon-epic .achievement-image{filter:sepia(60%) hue-rotate(260deg) saturate(3) brightness(1.5) drop-shadow(0 4px 20px rgba(200,100,255,1))}[data-theme=dark] .icon-legendary .achievement-image{filter:brightness(1.6) contrast(1.4) saturate(2.5) drop-shadow(0 4px 24px rgba(255,200,0,1))}@media(max-width:768px){.achievement-icon-small .icon-wrapper{width:40px;height:40px}.achievement-icon-medium .icon-wrapper{width:56px;height:56px}.achievement-icon-large .icon-wrapper{width:72px;height:72px}}.title-badges{width:100%;max-width:100%;margin:0 auto;padding:0}.title-badges.loading{text-align:center;padding:60px;color:#999;font-size:16px}.title-header{text-align:center;margin-bottom:40px;padding:24px;background:linear-gradient(135deg,#667eea0d,#764ba20d);border-radius:20px;border:2px solid rgba(102,126,234,.1)}.title-header h2{font-size:32px;font-weight:900;margin-bottom:12px;color:var(--text-primary, #333);text-shadow:0 2px 4px rgba(0,0,0,.05);display:flex;align-items:center;justify-content:center;gap:8px}.title-header-icon{width:36px;height:36px;-o-object-fit:contain;object-fit:contain}.subtitle{color:var(--text-secondary, #666);font-size:16px;font-weight:600}.category-tabs{display:flex;gap:8px;margin-bottom:24px;overflow-x:auto;padding-bottom:8px}.category-tab{padding:8px 16px;border:2px solid #e5e7eb;border-radius:20px;background:#fff;cursor:pointer;font-size:14px;font-weight:500;white-space:nowrap;transition:all .3s ease;display:flex;align-items:center;gap:6px}.category-icon{width:18px;height:18px;-o-object-fit:contain;object-fit:contain}.category-tab:hover{border-color:#667eea;color:#667eea}.category-tab.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-color:#6366f1;color:#fff;box-shadow:0 4px 12px #6366f159}.titles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.title-card{background:#fff;border:3px solid;border-radius:20px;padding:24px;display:flex;gap:20px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.title-card:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.8) 0%,transparent 70%);opacity:0;transition:opacity .4s ease}.title-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 40px #00000026}.title-card:hover:before{opacity:.3}.title-card.locked{opacity:.5;filter:grayscale(80%);background:#f5f5f5}.title-card.locked:hover{transform:translateY(-4px)}.title-card.owned{box-shadow:0 4px 20px #667eea33}.title-card.owned.common-teal{background:linear-gradient(135deg,#20b2aa1a,#40e0d026);box-shadow:0 4px 20px #20b2aa40,0 0 30px #40e0d026;animation:tealGlow 3s ease-in-out infinite}.title-card.owned.common-coral{background:linear-gradient(135deg,#ff6b6b1a,#ff8f8f26);box-shadow:0 4px 20px #ff6b6b40,0 0 30px #ff8f8f26;animation:coralGlow 3s ease-in-out infinite}.title-card.owned.common-mint{background:linear-gradient(135deg,#4ecdc41a,#81ecec26);box-shadow:0 4px 20px #4ecdc440,0 0 30px #81ecec26;animation:mintGlow 3s ease-in-out infinite}.title-card.owned.common-brown{background:linear-gradient(135deg,#8b73551a,#b4966e26);box-shadow:0 4px 20px #8b735540,0 0 30px #b4966e26;animation:brownGlow 3s ease-in-out infinite}.title-card.owned.common-olive{background:linear-gradient(135deg,#7cb3421a,#9ccc6526);box-shadow:0 4px 20px #7cb34240,0 0 30px #9ccc6526;animation:oliveGlow 3s ease-in-out infinite}.title-card.owned.common-cyan{background:linear-gradient(135deg,#43e97b1a,#38f9d726);box-shadow:0 4px 20px #43e97b40,0 0 30px #38f9d726;animation:cyanGlow 3s ease-in-out infinite}@keyframes tealGlow{0%,to{box-shadow:0 4px 20px #20b2aa40,0 0 30px #40e0d026}50%{box-shadow:0 4px 25px #20b2aa59,0 0 40px #40e0d040}}@keyframes coralGlow{0%,to{box-shadow:0 4px 20px #ff6b6b40,0 0 30px #ff8f8f26}50%{box-shadow:0 4px 25px #ff6b6b59,0 0 40px #ff8f8f40}}@keyframes mintGlow{0%,to{box-shadow:0 4px 20px #4ecdc440,0 0 30px #81ecec26}50%{box-shadow:0 4px 25px #4ecdc459,0 0 40px #81ecec40}}@keyframes brownGlow{0%,to{box-shadow:0 4px 20px #8b735540,0 0 30px #b4966e26}50%{box-shadow:0 4px 25px #8b735559,0 0 40px #b4966e40}}@keyframes oliveGlow{0%,to{box-shadow:0 4px 20px #7cb34240,0 0 30px #9ccc6526}50%{box-shadow:0 4px 25px #7cb34259,0 0 40px #9ccc6540}}@keyframes cyanGlow{0%,to{box-shadow:0 4px 20px #43e97b40,0 0 30px #38f9d726}50%{box-shadow:0 4px 25px #43e97b59,0 0 40px #38f9d740}}.title-card.owned.rarity-common:not(.common-teal):not(.common-coral):not(.common-mint):not(.common-brown):not(.common-olive){background:linear-gradient(135deg,#20b2aa1a,#40e0d026);box-shadow:0 4px 20px #20b2aa40}.title-card.owned.rarity-rare{background:linear-gradient(135deg,#0070dd1a,#64b4ff26);box-shadow:0 4px 20px #0070dd40}.title-card.owned.rarity-epic{background:linear-gradient(135deg,#a335ee1a,#c864ff26);box-shadow:0 4px 20px #a335ee40}.title-card.owned.rarity-legendary{background:linear-gradient(135deg,#ffb40026,#ffd70033);box-shadow:0 4px 20px #ffb4004d}.title-card.owned:after{content:"✓";position:absolute;top:12px;right:12px;width:32px;height:32px;background:linear-gradient(135deg,#56ab2f,#a8e063);color:#fff;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:50%;box-shadow:0 4px 12px #56ab2f66}.title-icon{flex-shrink:0;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:16px;transition:transform .3s ease}.title-card:hover .title-icon{transform:scale(1.05)}.title-info{flex:1;display:flex;flex-direction:column;gap:8px}.title-name{font-size:18px;font-weight:700;color:var(--text-primary, #333);display:flex;align-items:center;gap:8px}.rarity-badge{font-size:11px;font-weight:600;color:#fff;padding:2px 8px;border-radius:10px;text-transform:uppercase}.title-description{font-size:14px;color:var(--text-secondary, #666)}.title-condition{font-size:12px;color:var(--text-tertiary, #999);margin-top:4px}.title-progress{margin-top:12px}.progress-bar{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden;margin-bottom:4px}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.progress-text{font-size:11px;color:var(--text-tertiary, #999)}.equip-button{margin-top:16px;padding:12px 24px;border:none;border-radius:12px;background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #6b728059;position:relative;overflow:hidden}.equip-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.equip-button:hover:before{width:300px;height:300px}.equip-button:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 20px #6b728080;background:linear-gradient(135deg,#4b5563,#374151)}.equip-button:active{transform:translateY(-2px) scale(1)}.title-card.equipped{background:linear-gradient(135deg,#ffc10726,#ff980026);border-color:#ffc107!important;box-shadow:0 4px 20px #ffc1074d,inset 0 0 20px #ffc1071a}.title-card.equipped:after{content:"👑";background:linear-gradient(135deg,#ffc107,#ff9800);box-shadow:0 4px 12px #ffc10780}.equipped-badge{display:flex;align-items:center;gap:6px;margin-top:16px;padding:12px 24px;background:linear-gradient(135deg,#ffc107,#ff9800);color:#fff;font-size:14px;font-weight:700;border-radius:12px;box-shadow:0 4px 12px #ffc10766}.equipped-badge .equipped-icon{font-size:16px;font-weight:700}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary, #666)}[data-theme=dark] .title-header h2{color:var(--text-primary, #e5e5e5)}[data-theme=dark] .subtitle{color:var(--text-secondary, #999)}[data-theme=dark] .category-tab{background:#2a2a2a;border-color:#404040;color:#e5e5e5}[data-theme=dark] .title-card{background:#2a2a2a}[data-theme=dark] .title-card.owned{background:linear-gradient(135deg,#667eea26,#764ba226)}[data-theme=dark] .title-name{color:var(--text-primary, #e5e5e5)}[data-theme=dark] .title-description{color:var(--text-secondary, #999)}[data-theme=dark] .title-condition{color:var(--text-tertiary, #666)}[data-theme=dark] .progress-bar{background:#404040}[data-theme=dark] .empty-state{color:var(--text-secondary, #999)}[data-theme=dark] .title-card.equipped{background:linear-gradient(135deg,#ffc10733,#ff980033)}.level-badge{display:inline-flex;flex-direction:column;align-items:center;gap:8px;padding:0;background:transparent;border-radius:20px;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;border:none;transition:all .3s ease}.badge-icon{position:relative;display:flex;align-items:center;justify-content:center;transition:all .3s ease;background:transparent!important;border:none!important;box-shadow:none!important;padding:0!important}.badge-icon:hover{transform:scale(1.08)}.badge-glow-layer{position:absolute;top:60%;left:50%;transform:translate(-50%,-50%);width:140%;height:120%;border-radius:50%;z-index:0;opacity:.7;filter:blur(25px);animation:pulse-glow 2.5s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(.95);filter:blur(20px)}50%{opacity:.8;transform:translate(-50%,-50%) scale(1.1);filter:blur(30px)}}.badge-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;position:relative;z-index:2;background:transparent!important;transition:all .3s ease}.level-badge-small{background:transparent;border:none;box-shadow:none;padding:0}.level-badge-small .badge-icon{width:32px;height:32px}.level-badge-medium{background:transparent;border:none;box-shadow:none;padding:0}.level-badge-medium .badge-icon{width:48px;height:48px}.level-badge-large{background:transparent;border:none;box-shadow:none;padding:0;-webkit-backdrop-filter:none;backdrop-filter:none}.level-badge-large .badge-icon{width:80px;height:80px}.level-badge-large .badge-label{margin-top:8px;text-shadow:0 2px 4px rgba(0,0,0,.3),0 0 8px rgba(255,255,255,.8)}.glow-light .badge-glow-layer{opacity:.4;filter:blur(20px)}.glow-medium .badge-glow-layer{opacity:.6;filter:blur(25px)}.glow-strong .badge-glow-layer{opacity:.8;filter:blur(30px)}.badge-legendary .badge-glow-layer{animation:rainbow-pulse 3s linear infinite}.badge-legendary .badge-image{animation:rainbow-filter 3s linear infinite}@keyframes rainbow-pulse{0%{box-shadow:0 0 20px red,0 0 40px red,0 0 60px red,0 0 80px red}16.6%{box-shadow:0 0 20px #ff0,0 0 40px #ff0,0 0 60px #ff0,0 0 80px #ff0}33.3%{box-shadow:0 0 20px #0f0,0 0 40px #0f0,0 0 60px #0f0,0 0 80px #0f0}50%{box-shadow:0 0 20px #0ff,0 0 40px #0ff,0 0 60px #0ff,0 0 80px #0ff}66.6%{box-shadow:0 0 20px #00f,0 0 40px #00f,0 0 60px #00f,0 0 80px #00f}83.3%{box-shadow:0 0 20px #f0f,0 0 40px #f0f,0 0 60px #f0f,0 0 80px #f0f}to{box-shadow:0 0 20px red,0 0 40px red,0 0 60px red,0 0 80px red}}@keyframes rainbow-filter{0%{filter:drop-shadow(0 0 15px #ff0000)}16.6%{filter:drop-shadow(0 0 15px #ffff00)}33.3%{filter:drop-shadow(0 0 15px #00ff00)}50%{filter:drop-shadow(0 0 15px #00ffff)}66.6%{filter:drop-shadow(0 0 15px #0000ff)}83.3%{filter:drop-shadow(0 0 15px #ff00ff)}to{filter:drop-shadow(0 0 15px #ff0000)}}[data-theme=dark] .badge-glow-layer{opacity:1}[data-theme=dark] .badge-image{filter:brightness(1.1)}.badge-label{display:flex;flex-direction:column;gap:4px;align-items:center;text-align:center}.badge-level{font-size:18px;font-weight:900;color:#667eea;text-shadow:0 2px 4px rgba(0,0,0,.3),0 0 8px rgba(255,255,255,.8),0 0 2px rgba(255,255,255,1)}.badge-name{font-size:14px;font-weight:700;color:#333;letter-spacing:1px;text-shadow:0 2px 4px rgba(0,0,0,.3),0 0 8px rgba(255,255,255,.8),0 0 2px rgba(255,255,255,1)}[data-theme=dark] .badge-level{color:#8b9cff;text-shadow:0 2px 4px rgba(0,0,0,.5),0 0 8px rgba(139,156,255,.5)}[data-theme=dark] .badge-name{color:#e5e5e5;text-shadow:0 2px 4px rgba(0,0,0,.5),0 0 8px rgba(229,229,229,.3)}[data-theme=dark] .badge-level{color:var(--text-primary, #e5e5e5)}[data-theme=dark] .badge-name{color:var(--text-secondary, #999)}@media(max-width:768px){.level-badge-small .badge-icon{width:28px;height:28px}.level-badge-medium .badge-icon{width:40px;height:40px}.level-badge-large{padding:0;background:transparent!important}.level-badge-large .badge-icon{width:60px;height:60px}.badge-level{font-size:16px}.badge-name{font-size:12px}}@-webkit-keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size: 12px;--rc-drag-handle-mobile-size: 24px;--rc-drag-handle-bg-colour: rgba(0, 0, 0, .2);--rc-drag-bar-size: 6px;--rc-border-color: rgba(255, 255, 255, .7);--rc-focus-color: #0088ff}.ReactCrop{position:relative;display:inline-block;cursor:crosshair;max-width:100%}.ReactCrop *,.ReactCrop *:before,.ReactCrop *:after{-webkit-box-sizing:border-box;box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{overflow:hidden;max-height:inherit}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-width:100%;max-height:inherit}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video{-ms-touch-action:none;touch-action:none}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{-ms-touch-action:none;touch-action:none}.ReactCrop__crop-mask{position:absolute;inset:0;pointer-events:none;width:calc(100% + .5px);height:calc(100% + .5px)}.ReactCrop__crop-selection{position:absolute;top:0;left:0;-webkit-transform:translateZ(0);transform:translateZ(0);cursor:move}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{pointer-events:none;content:"";position:absolute;inset:-1px;border:1px solid var(--rc-border-color);opacity:.3}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed white}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){-webkit-animation:marching-ants 1s;animation:marching-ants 1s;background-image:-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444));background-image:linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%);background-size:10px 1px,10px 1px,1px 10px,1px 10px;background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;color:#fff;-webkit-animation-play-state:running;animation-play-state:running;-webkit-animation-timing-function:linear;animation-timing-function:linear;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite}.ReactCrop__crop-selection:focus{outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{content:"";display:block;position:absolute;background-color:#fff6}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after{width:1px;height:100%}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{width:100%;height:1px}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{position:absolute;width:var(--rc-drag-handle-size);height:var(--rc-drag-handle-size);background-color:var(--rc-drag-handle-bg-colour);border:1px solid var(--rc-border-color)}.ReactCrop__drag-handle:focus{background:var(--rc-focus-color)}.ReactCrop .ord-nw{top:0;left:0;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);cursor:nw-resize}.ReactCrop .ord-n{top:0;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);cursor:n-resize}.ReactCrop .ord-ne{top:0;right:0;-webkit-transform:translate(50%,-50%);transform:translate(50%,-50%);cursor:ne-resize}.ReactCrop .ord-e{top:50%;right:0;-webkit-transform:translate(50%,-50%);transform:translate(50%,-50%);cursor:e-resize}.ReactCrop .ord-se{bottom:0;right:0;-webkit-transform:translate(50%,50%);transform:translate(50%,50%);cursor:se-resize}.ReactCrop .ord-s{bottom:0;left:50%;-webkit-transform:translate(-50%,50%);transform:translate(-50%,50%);cursor:s-resize}.ReactCrop .ord-sw{bottom:0;left:0;-webkit-transform:translate(-50%,50%);transform:translate(-50%,50%);cursor:sw-resize}.ReactCrop .ord-w{top:50%;left:0;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);cursor:w-resize}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{top:0;left:0;width:100%;height:var(--rc-drag-bar-size);-webkit-transform:translateY(-50%);transform:translateY(-50%)}.ReactCrop__drag-bar.ord-e{right:0;top:0;width:var(--rc-drag-bar-size);height:100%;-webkit-transform:translate(50%);transform:translate(50%)}.ReactCrop__drag-bar.ord-s{bottom:0;left:0;width:100%;height:var(--rc-drag-bar-size);-webkit-transform:translateY(50%);transform:translateY(50%)}.ReactCrop__drag-bar.ord-w{top:0;left:0;width:var(--rc-drag-bar-size);height:100%;-webkit-transform:translate(-50%);transform:translate(-50%)}.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle,.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w{display:none}@media(pointer:coarse){.ReactCrop .ord-n,.ReactCrop .ord-e,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{width:var(--rc-drag-handle-mobile-size);height:var(--rc-drag-handle-mobile-size)}}.user-profile{max-width:900px;margin:0 auto;padding:2rem 2rem 4rem;background:transparent;position:relative;min-height:calc(100vh - 200px)}.profile-back-btn{position:absolute;top:0;left:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--paper-color);border:1px solid var(--border-color);border-radius:10px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;box-shadow:0 1px 2px #0000000d;z-index:10}.profile-back-btn:hover{background:var(--bg-color);border-color:var(--border-color);color:var(--text-primary);transform:translate(-2px);box-shadow:0 2px 4px #0000001a}[data-theme=dark] .profile-back-btn:hover{background:#37415180}.profile-back-btn:active{transform:translate(0);box-shadow:0 1px 2px #0000000d}.profile-back-btn svg{width:18px;height:18px}.profile-header-card{background:var(--paper-color);border-radius:16px;padding:2.5rem;margin-bottom:1.5rem;margin-top:3rem;box-shadow:0 1px 3px #0000000d,0 1px 2px #0000001a;border:1px solid var(--border-color);transition:background-color .3s ease,border-color .3s ease}.profile-header{display:flex;gap:2rem;align-items:flex-start}.profile-avatar-container{position:relative;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:12px}.avatar-badge-container{display:flex;justify-content:center;animation:fadeInUp .5s ease}.avatar-wrapper{position:relative;width:100px;height:100px;border-radius:50%;overflow:hidden;border:3px solid #f3f4f6;transition:all .2s ease}.avatar-wrapper.editable{cursor:pointer}.avatar-wrapper.editable:hover{border-color:#3b82f6;transform:scale(1.02)}.profile-avatar{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.avatar-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;border-radius:50%}.avatar-wrapper.editable:hover .avatar-overlay{opacity:1}.upload-hint,.uploading-indicator{color:#fff;font-size:.75rem;font-weight:500;text-align:center}.uploading-indicator{opacity:1;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.avatar-edit-hint{margin-top:.75rem;font-size:.8125rem;color:#6b7280;text-align:center}.avatar-url-input{width:100%;padding:.5rem .75rem;margin-top:.5rem;border:1px solid #d1d5db;border-radius:8px;font-size:.8125rem;background:#fff;color:#111827;transition:all .2s}.avatar-url-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}[data-theme=dark] .avatar-url-input{background:#374151;border-color:#4b5563;color:#f3f4f6}[data-theme=dark] .avatar-url-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.profile-info{flex:1;min-width:0}.profile-name{font-size:1.75rem;font-weight:600;color:#111827;margin:0 0 .5rem;letter-spacing:-.01em}[data-theme=dark] .profile-name{color:#f3f4f6}.profile-bio{color:#6b7280;margin:0;line-height:1.6;font-size:.9375rem}[data-theme=dark] .profile-bio{color:#9ca3af}.profile-invite-code{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid #f3f4f6}[data-theme=dark] .profile-invite-code{border-top-color:#374151}.invite-code-label{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.8125rem;font-weight:500;color:#6b7280}[data-theme=dark] .invite-code-label{color:#9ca3af}.invite-code-label svg{flex-shrink:0;color:var(--accent-color)}.invite-code-compact{display:flex;align-items:center;gap:.75rem;background:transparent;border:none;border-radius:8px;padding:0;transition:all .2s ease}.invite-code-text{flex:1;font-family:Monaco,Menlo,Courier New,monospace;font-size:.875rem;font-weight:600;color:#374151;letter-spacing:.05em;background:transparent;border:none;padding:0;margin:0;-webkit-user-select:all;-moz-user-select:all;user-select:all;cursor:text;word-break:break-all;min-width:0}[data-theme=dark] .invite-code-text{color:#e5e7eb}.invite-code-copy-compact{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#6b7280;border:none;border-radius:6px;color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.invite-code-copy-compact:hover{background:#4b5563;transform:scale(1.05)}.invite-code-copy-compact:active{transform:scale(.95)}[data-theme=dark] .invite-code-copy-compact{background:#6b7280}[data-theme=dark] .invite-code-copy-compact:hover{background:#4b5563}.invite-code-copy-compact svg{width:14px;height:14px}.nickname-input{width:100%;padding:.75rem 1rem;margin-bottom:1rem;border:1.5px solid #d1d5db;border-radius:8px;font-size:1rem;transition:all .2s;background:#fff;color:#111827;font-weight:500}.nickname-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}[data-theme=dark] .nickname-input{background:#374151;border-color:#4b5563;color:#f3f4f6}[data-theme=dark] .nickname-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.bio-input{width:100%;padding:.75rem 1rem;border:1.5px solid #d1d5db;border-radius:8px;font-size:.9375rem;resize:vertical;font-family:inherit;transition:all .2s;background:#fff;color:#111827;line-height:1.6}.bio-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}[data-theme=dark] .bio-input{background:#374151;border-color:#4b5563;color:#f3f4f6}[data-theme=dark] .bio-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.profile-content{background:var(--paper-color);border-radius:16px;padding:2rem;box-shadow:0 1px 3px #0000000d,0 1px 2px #0000001a;border:1px solid var(--border-color);transition:background-color .3s ease,border-color .3s ease}.profile-details{margin-bottom:2rem}.detail-item{display:flex;align-items:center;gap:1rem;padding:1rem 0;border-bottom:1px solid #f3f4f6;transition:background-color .15s}[data-theme=dark] .detail-item{border-bottom-color:#374151}.detail-item:last-child{border-bottom:none}.detail-item:hover{background-color:#f9fafb;margin:0 -1rem;padding-left:1rem;padding-right:1rem;border-radius:8px}[data-theme=dark] .detail-item:hover{background-color:#37415180}.detail-icon{width:20px;height:20px;flex-shrink:0;color:#9ca3af;stroke-width:2}[data-theme=dark] .detail-icon{color:#6b7280}.detail-label{font-weight:500;color:#6b7280;font-size:.9375rem;min-width:90px}[data-theme=dark] .detail-label{color:#d1d5db}.detail-value{color:#111827;font-weight:500;flex:1;text-align:right;font-size:.9375rem}[data-theme=dark] .detail-value{color:#f3f4f6}.error-message{padding:1rem 1.25rem;margin-bottom:1.5rem;background:#fef2f2;color:#dc2626;border-radius:10px;font-size:.875rem;border:1px solid #fecaca;display:flex;align-items:center;gap:.5rem}.success-message{padding:1rem 1.25rem;margin-bottom:1.5rem;background:#f0fdf4;color:#16a34a;border-radius:10px;font-size:.875rem;border:1px solid #bbf7d0;display:flex;align-items:center;gap:.5rem}.profile-actions{display:flex;gap:.75rem;flex-wrap:wrap;padding-top:1.5rem;border-top:1px solid #f3f4f6}[data-theme=dark] .profile-actions{border-top-color:#374151}.btn{padding:.625rem 1.5rem;border:none;border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:40px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#3b82f6;color:#fff;box-shadow:0 1px 2px #0000000d}.btn-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0000000d}.btn-secondary{background:#fff;color:#374151;border:1.5px solid #d1d5db;box-shadow:0 1px 2px #0000000d}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.btn-secondary:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0000000d}[data-theme=dark] .btn-secondary{background:#374151;color:#e5e7eb;border-color:#4b5563}[data-theme=dark] .btn-secondary:hover:not(:disabled){background:#4b5563;border-color:#6b7280}.btn-danger{background:#fff;color:#dc2626;border:1.5px solid #fecaca;box-shadow:0 1px 2px #0000000d}.btn-danger:hover{background:#fef2f2;border-color:#fca5a5;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.btn-danger:active{transform:translateY(0);box-shadow:0 1px 2px #0000000d}[data-theme=dark] .btn-danger{background:transparent;color:#f87171;border-color:#7f1d1d}[data-theme=dark] .btn-danger:hover{background:#7f1d1d4d;border-color:#dc2626}.crop-modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.crop-modal{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.crop-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.crop-modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.crop-modal-close{background:none;border:none;font-size:1.5rem;line-height:1;color:#6b7280;cursor:pointer;padding:.5rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.crop-modal-close:hover:not(:disabled){background:#f3f4f6;color:#111827}.crop-modal-close:disabled{opacity:.5;cursor:not-allowed}.crop-modal-content{padding:1.5rem;overflow:auto;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.crop-modal-content .ReactCrop{max-width:100%}.crop-modal-content img{display:block;max-width:100%;max-height:70vh}.crop-modal-actions{display:flex;gap:.75rem;padding:1.5rem;border-top:1px solid #e5e7eb;justify-content:flex-end}.crop-modal-actions .btn{min-width:100px}@media(max-width:768px){.user-profile{padding:1rem}.profile-back-btn{position:absolute;top:0;left:0;width:36px;height:36px}.profile-header-card{margin-top:2.5rem}.profile-back-btn svg{width:16px;height:16px}.profile-header-card{padding:1.5rem}.profile-header{flex-direction:column;align-items:center;text-align:center;gap:1.5rem}.avatar-wrapper{width:90px;height:90px}.profile-name{font-size:1.5rem}.profile-content{padding:1.5rem}.detail-item{flex-direction:column;align-items:flex-start;gap:.5rem;padding:1rem 0}.detail-item:hover{margin:0;padding:1rem}.detail-value{text-align:left;width:100%}.profile-actions{flex-direction:column}.btn{width:100%}.crop-modal{max-width:100%;max-height:100vh;border-radius:0}.crop-modal-content{padding:1rem}.crop-modal-actions{flex-direction:column}.crop-modal-actions .btn{width:100%}}.profile-tabs{display:flex;gap:8px;margin:24px 0 0;padding:8px;background:var(--bg-secondary, #f5f5f5);border-radius:16px;overflow-x:auto;box-shadow:inset 0 2px 4px #0000000d}[data-theme=dark] .profile-tabs{background:#3741514d}.profile-tab{padding:12px 24px;border:none;background:transparent;cursor:pointer;font-size:15px;font-weight:600;color:var(--text-secondary, #666);border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;position:relative;display:flex;align-items:center;gap:8px}.tab-icon{width:20px;height:20px;-o-object-fit:contain;object-fit:contain}.profile-tab:hover{color:var(--text-primary, #333);background:#ffffff80}[data-theme=dark] .profile-tab:hover{color:var(--text-primary, #e5e5e5);background:#4b556380}.profile-tab.active{color:#667eea;background:#fff;box-shadow:0 4px 12px #667eea26,0 2px 4px #00000014;transform:translateY(-2px)}[data-theme=dark] .profile-tab.active{background:#667eea33;box-shadow:0 4px 12px #667eea4d}.profile-tab-content{padding:24px 0 0;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.points-section,.titles-section{max-width:100%;margin:0 auto}.floating-back-button{position:fixed!important;left:24px!important;top:50%!important;transform:translateY(-50%)!important;width:auto!important;height:auto!important;border-radius:0!important;background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;border:none!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;transition:all .3s ease!important;z-index:9999!important;box-shadow:none!important;padding:0!important}.floating-back-button:hover{background:transparent!important;box-shadow:none!important;transform:translateY(-50%) scale(1.15)}.floating-back-button:active{transform:translateY(-50%) scale(.92)}.floating-back-button .back-icon{width:50px;height:50px;-o-object-fit:contain;object-fit:contain;opacity:.75;animation:backButtonGlowGolden 2s ease-in-out infinite;transition:opacity .3s ease,animation-duration .3s ease}.floating-back-button:hover .back-icon{opacity:1;animation-duration:1.2s}@keyframes backButtonGlowGolden{0%,to{filter:drop-shadow(0 0 8px rgba(255,200,0,.6)) drop-shadow(0 0 16px rgba(255,180,0,.5)) drop-shadow(0 0 24px rgba(255,150,0,.4))}50%{filter:drop-shadow(0 0 16px rgba(255,215,0,.9)) drop-shadow(0 0 28px rgba(255,190,0,.8)) drop-shadow(0 0 40px rgba(255,165,0,.6))}}@media(hover:hover){.floating-back-button:hover .back-icon{filter:drop-shadow(0 0 20px rgba(255,230,0,1)) drop-shadow(0 0 32px rgba(255,200,0,1)) drop-shadow(0 0 48px rgba(255,165,0,.9))!important}}[data-theme=dark] .floating-back-button{background:transparent!important;border-color:transparent!important}[data-theme=dark] .floating-back-button:hover{background:transparent!important;box-shadow:none!important}@media(max-width:768px){.floating-back-button{left:12px}.floating-back-button .back-icon{width:42px;height:42px}}body:has(.dictation-page-overlay){margin:0!important;padding:0!important;overflow:hidden!important}html:has(.dictation-page-overlay){margin:0!important;padding:0!important;overflow:hidden!important}#root:has(.dictation-page-overlay){margin:0!important;padding:0!important;width:100vw!important;max-width:100vw!important;height:100vh!important}.dictation-page-overlay{--bg-color: #FFFFFF;--paper-color: #FFFFFF;--text-primary: #1f2937;--text-secondary: #6b7280;--accent-color: #10b981;--accent-light: #d1fae5;--accent-secondary: #3b82f6;--border-color: #e5e7eb;--success-color: #10b981;--error-color: #ef4444;position:fixed!important;inset:0!important;width:100vw!important;height:100vh!important;background:#fff!important;display:flex!important;align-items:center!important;justify-content:center!important;margin:0!important;padding:0!important;border:none!important;overflow-y:auto!important;overflow-x:hidden!important;z-index:999999!important}.dictation-page-overlay.dark{--bg-color: #0f172a;--paper-color: #1e293b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--accent-color: #d946ef;--accent-light: #581c87;--border-color: #334155;background:#0f172a!important}.dictation-page{position:relative!important;width:100%!important;max-width:1200px!important;min-height:100vh!important;background:transparent!important;display:flex!important;flex-direction:column!important;margin:0!important;padding:0!important;border:none!important;box-sizing:border-box!important}.dictation-page-overlay::-webkit-scrollbar{display:none!important;width:0!important;height:0!important}.dictation-page-overlay{-ms-overflow-style:none!important;scrollbar-width:none!important}.dictation-page::-webkit-scrollbar{display:none!important;width:0!important;height:0!important}.dictation-page{-ms-overflow-style:none!important;scrollbar-width:none!important}.dictation-page~.article-sidebar,.dictation-page~.sidebar-toggle-button,.dictation-page~.sidebar-overlay,body:has(.dictation-page) .article-sidebar,body:has(.dictation-page) .sidebar-toggle-button,body:has(.dictation-page) .sidebar-overlay,body:has(.dictation-page) .bottom-player{display:none!important;visibility:hidden!important}.dictation-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:transparent;border-bottom:none;width:100%;flex-shrink:0}.dictation-page-overlay.dark .dictation-header{background:transparent;border-bottom:none}.header-left{display:flex;align-items:center;gap:8px}.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0;pointer-events:auto}.dictation-back-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:14px;outline:none!important}.dictation-back-btn.icon-only{padding:8px;min-width:36px}.dictation-back-btn.icon-only span{display:none}.dictation-back-btn.with-text{padding:8px 16px}.dictation-back-btn:hover,.dictation-back-btn:focus,.dictation-back-btn:focus-visible{background:var(--bg-color);border-color:var(--text-primary);color:var(--text-primary);outline:none!important;box-shadow:none!important}.dictation-back-btn svg{width:20px;height:20px;flex-shrink:0}.dictation-title{flex:1;text-align:center}.dictation-title-text{text-align:center}.dictation-title h1{font-family:"Noto Serif SC",serif;font-size:24px;font-weight:700;margin:0 0 4px;color:var(--text-primary)}.dictation-title p{font-size:14px;color:var(--text-secondary);margin:0}.article-title-subtitle{font-size:13px!important;color:var(--text-secondary)!important;max-width:600px;margin:0 auto!important;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.8;font-weight:400}.dictation-mode-toggle{display:flex;gap:8px;background:var(--bg-color);padding:4px;border-radius:8px}.mode-btn{padding:8px 20px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500;outline:none!important}.mode-btn:focus,.mode-btn:focus-visible{outline:none!important;box-shadow:none!important}.mode-btn.active{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.fullscreen-btn{width:36px;height:36px;padding:6px;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:101;pointer-events:auto}.fullscreen-btn:hover{background:#d1fae5;border-color:#10b981;color:#10b981}.fullscreen-btn svg{width:20px;height:20px}.theme-toggle-btn{width:36px;height:36px;padding:6px;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:101;pointer-events:auto}.theme-toggle-btn:hover{background:#d1fae5;border-color:#10b981;color:#10b981}.theme-toggle-btn svg{width:20px;height:20px}[data-theme=dark] .theme-toggle-btn{border-color:#fbbf244d;color:#fbbf24}[data-theme=dark] .theme-toggle-btn:hover{background:#fbbf2426;border-color:#fbbf24}.dictation-progress{padding:12px 20px;background:var(--bg-color);border-bottom:1px solid var(--border-color);width:100%;flex-shrink:0;box-sizing:border-box}.progress-bar{width:100%!important;max-width:100%!important;height:4px!important;background:#0000001a;border-radius:2px;overflow:hidden;margin-bottom:8px;position:relative;display:block}.progress-fill{height:100%!important;background:linear-gradient(90deg,#10b981,#3b82f6);border-radius:2px;transition:width .4s cubic-bezier(.4,0,.2,1);box-shadow:none;display:block;position:relative}.progress-text{text-align:center;font-size:13px;color:var(--text-secondary);font-weight:600;letter-spacing:.5px}.dictation-page-overlay.dark .progress-bar{background:#ffffff1a}.dictation-page-overlay.dark .progress-fill{background:#fff}.dictation-content{flex:1;display:flex;align-items:center;justify-content:center;padding:20px 20px 10px;width:100%;background:transparent;min-height:0;overflow:visible!important}.dictation-content::-webkit-scrollbar{display:none!important;width:0!important}.dictation-practice{width:100%;max-width:900px;margin:0 auto;position:relative}.add-to-vocabulary-btn{position:absolute;top:0;right:0;display:flex;align-items:center;gap:6px;padding:8px 14px;background:#fffffff2;border:1px solid #e5e7eb;border-radius:20px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000000f;z-index:10;font-size:13px;color:#374151;pointer-events:auto}.add-to-vocabulary-btn:hover{background:#f0fdf4;border-color:#10b981;box-shadow:0 4px 12px #10b98133;transform:translateY(-1px)}.add-to-vocabulary-btn:active{transform:translateY(0)}.add-to-vocabulary-btn img{width:18px;height:18px;-o-object-fit:contain;object-fit:contain}.add-to-vocabulary-btn span{font-weight:500}.dictation-page-overlay.dark .add-to-vocabulary-btn{background:#1f2937f2;border-color:#374151;color:#e5e7eb}.dictation-page-overlay.dark .add-to-vocabulary-btn:hover{background:#374151;border-color:#10b981}.practice-item{background:var(--paper-color);border-radius:24px;padding:60px 40px;box-shadow:0 8px 32px #0000000f;text-align:center;transition:box-shadow .3s ease}.practice-item:hover{box-shadow:0 12px 40px #0000001a}.dictation-page-overlay.dark .practice-item{box-shadow:0 8px 32px #0000004d}.dictation-page-overlay.dark .practice-item:hover{box-shadow:0 12px 40px #0006}.practice-item-no-card{background:transparent;padding:20px;text-align:center}.item-prompt{display:flex;flex-direction:column;align-items:center;gap:32px;padding:20px 0}.item-prompt p{font-size:20px;font-weight:500;color:var(--text-secondary);margin:0;letter-spacing:.5px}.dictation-page .play-btn{width:96px;height:96px;border-radius:50%;background:var(--text-primary);color:var(--paper-color);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 24px #00000026,0 4px 8px #0000001a;outline:none!important}.dictation-page .play-btn:hover{transform:scale(1.08);box-shadow:0 12px 32px #0003,0 6px 12px #00000026;outline:none!important}.dictation-page .play-btn:active{transform:scale(.98)}.dictation-page .play-btn svg{width:36px;height:36px;margin-left:4px}.item-listening{display:flex;flex-direction:column;align-items:center;gap:24px;padding:60px 0;min-height:200px;justify-content:center}.listening-animation{display:flex;align-items:center;gap:8px;height:60px}.sound-wave{width:4px;height:40px;background:var(--text-primary);border-radius:2px;animation:wave 1.2s ease-in-out infinite}.sound-wave:nth-child(1){animation-delay:0s}.sound-wave:nth-child(2){animation-delay:.2s}.sound-wave:nth-child(3){animation-delay:.4s}@keyframes wave{0%,to{transform:scaleY(.5);opacity:.7}50%{transform:scaleY(1);opacity:1}}.item-listening p.listening-status{font-size:16px;color:var(--text-secondary);margin:0}.listening-content{display:flex;flex-direction:column;gap:16px;width:100%;max-width:800px;padding:24px;background:var(--surface-color);border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-top:8px}.listening-sentence{font-size:20px;font-weight:500;color:var(--text-color);line-height:1.6;text-align:center}.listening-translation{font-size:16px;color:var(--text-secondary);line-height:1.6;text-align:center;padding-top:12px;border-top:1px solid var(--border-color)}.listening-phonetic{font-size:18px;color:#3b82f6;text-align:center;font-family:Arial,sans-serif}.listening-meaning{font-size:16px;color:var(--text-secondary);text-align:center;line-height:1.6}.item-typing{display:flex;flex-direction:column;gap:16px}.word-hint{text-align:center;margin-bottom:12px}.input-display-container{position:relative;width:100%;display:flex;flex-direction:column;align-items:center;cursor:text}.overlay-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:text;z-index:10;font-size:3rem;border:none!important;outline:none!important;background:transparent!important;padding:0;margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.overlay-input:focus{outline:none!important;border:none!important;box-shadow:none!important}.word-phonetic{font-size:20px;color:var(--text-secondary);margin-top:0;margin-bottom:8px;font-weight:500;font-family:Courier New,monospace;letter-spacing:1px}.word-meaning{font-size:24px;color:var(--text-primary);font-weight:400;text-align:center;max-width:500px;margin:0 auto 8px}.sentence-translation-hint{font-size:18px;color:var(--text-primary);margin-bottom:16px;font-weight:500;text-align:center;line-height:1.6;padding:8px 20px;border-radius:8px;max-width:90%;margin-left:auto;margin-right:auto}.input-display-wrapper{position:relative;cursor:text}.transparent-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:text;font-size:3rem;border:none;outline:none;background:transparent;z-index:10}.transparent-input:disabled{cursor:not-allowed}.hint-label{font-size:14px;color:var(--text-secondary);margin-bottom:20px;font-weight:500}.word-blur-hint{font-size:2.5rem;font-weight:600;letter-spacing:3px;color:var(--text-secondary);opacity:.3;filter:blur(8px);margin:12px 0;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all .3s ease;font-family:Inter,Courier New,monospace}.word-blur-hint:hover{filter:blur(6px);opacity:.4}.underscore-display{display:inline-flex;gap:12px;font-family:Inter,Courier New,monospace;font-size:2.5rem;font-weight:600;letter-spacing:2px;color:var(--text-primary);line-height:1.2;min-height:3rem;padding:12px 0;align-items:flex-end}.sentence-words-display{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding:12px 0;max-width:90%;margin:0 auto;align-items:flex-end}.sentence-word-box{min-width:4ch;height:auto;font-size:inherit;font-weight:600;font-family:Inter,Courier New,monospace;color:var(--text-primary);border-bottom:2px solid #cccccc;padding:0 8px 4px;text-align:center;line-height:1.4;letter-spacing:1px;transition:all .2s ease}.sentence-word-box.active{color:#10b981;border-bottom:3px solid #10b981;font-weight:700}.sentence-word-box.completed{color:var(--text-primary);border-bottom-color:var(--text-primary)}.sentence-word-box.empty{color:#0003;border-bottom-color:#e5e5e5}@media(prefers-color-scheme:dark){.sentence-word-box.empty{color:#ffffff4d;border-bottom-color:#fff3}}.sentence-word-box.error{color:#ef4444!important;border-bottom-color:#ef4444!important;border-bottom-width:3px!important;background:#ef44440d}.sentence-word-box.error.shake{animation:shake .5s cubic-bezier(.36,.07,.19,.97)}.sentence-punctuation{font-size:inherit;font-weight:600;color:var(--text-primary);height:auto;line-height:1.4;display:flex;align-items:flex-end;padding-bottom:4px}.underscore-char{display:inline-block;min-width:1.2ch;text-align:center;padding-bottom:4px;transition:all .2s ease;color:#999}.underscore-char:not(:empty){color:var(--text-primary)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}50%{transform:translate(10px)}75%{transform:translate(-10px)}}.animate-shake{animation:shake .5s cubic-bezier(.36,.07,.19,.97)}.input-wrapper{position:relative}.practice-input{width:100%;padding:24px 32px;font-size:2rem;font-weight:500;border:none!important;border-radius:0!important;background:transparent!important;color:var(--text-primary);transition:all .3s cubic-bezier(.4,0,.2,1);font-family:Inter,sans-serif;text-align:center;letter-spacing:1px;outline:none!important;box-shadow:none!important;-webkit-appearance:none;-moz-appearance:none;appearance:none}.practice-input::-moz-placeholder{color:var(--text-secondary);opacity:.4;font-weight:400}.practice-input::placeholder{color:var(--text-secondary);opacity:.4;font-weight:400}.practice-input:focus,.practice-input:focus-visible{outline:none!important;border:none!important;box-shadow:none!important}.practice-input.correct{color:var(--success-color)!important;background:transparent!important;box-shadow:none!important;border:none!important}.practice-input.incorrect{color:var(--error-color)!important;background:transparent!important;box-shadow:none!important;border:none!important;animation:shake .5s cubic-bezier(.36,.07,.19,.97)}.hint-display{margin-top:20px;margin-bottom:20px;padding:16px 20px;background:transparent;border-radius:12px;border:2px dashed rgba(100,116,139,.4);animation:slideDown .4s cubic-bezier(.4,0,.2,1);text-align:left;box-shadow:0 4px 16px #64748b1f;position:relative;overflow:hidden}.hint-display:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#64748b99,#47556999)}.hint-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;font-size:17px;font-weight:700;color:#64748b}.hint-icon{font-size:24px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.hint-title{font-weight:700;letter-spacing:.5px}.hint-word{font-size:20px;color:var(--text-primary);margin-bottom:16px;line-height:1.7;padding:12px 16px;background:#64748b1a;border-radius:10px;font-weight:600;letter-spacing:1px}.hint-word strong{color:#64748b;margin-right:10px;font-weight:700}.hint-word-phonetic{color:var(--text-secondary);font-weight:400;font-family:Courier New,monospace;margin-left:8px;font-size:18px}.hint-meaning{font-size:16px;color:var(--text-primary);margin-bottom:14px;line-height:1.7}.hint-meaning strong{color:#64748b;margin-right:8px;font-weight:700}.hint-example{font-size:15px;color:var(--text-secondary);font-style:italic;padding:14px 16px;background:#64748b0f;border-radius:10px;border-left:4px solid #64748b;line-height:1.7;display:flex;align-items:center;gap:12px}.hint-example strong{color:#64748b;margin-right:8px;font-style:normal;font-weight:700}.play-example-btn{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:#64748b;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;outline:none;margin-left:auto}.play-example-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px #64748b4d}.play-example-btn:active{transform:scale(.95)}.play-example-btn svg{width:14px;height:14px;margin-left:2px}.hint-translation{font-size:14px;color:var(--text-secondary);padding:12px 16px;background:#64748b0a;border-radius:8px;line-height:1.7;margin-top:8px;font-style:normal}.hint-translation strong{color:#64748b;margin-right:8px;font-weight:700}.dictation-page-overlay.dark .hint-display{background:transparent;box-shadow:0 4px 16px #64748b33}.dictation-page-overlay.dark .hint-example{background:#64748b1f}.shortcut-hint{display:flex;justify-content:center;gap:12px;margin-top:12px;padding-bottom:16px;flex-wrap:wrap}.hint-item{font-size:12px;color:var(--text-secondary);padding:4px 12px;background:var(--bg-color);border-radius:12px;border:1px solid var(--border-color);transition:all .2s ease}.hint-item:hover{border-color:#10b981;color:#10b981}.answer-display{margin-top:32px;padding:28px 32px;background:linear-gradient(135deg,#10b98108,#3b82f608);border-radius:16px;border:2px solid var(--border-color);animation:slideDown .4s cubic-bezier(.4,0,.2,1);text-align:center;box-shadow:0 4px 16px #0000000a}.answer-tips{margin-top:16px;padding:16px 20px;background:#64748b0a;border-radius:12px;text-align:center;animation:slideDown .4s cubic-bezier(.4,0,.2,1)}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.answer-text{font-size:20px;font-weight:700;margin-bottom:20px;display:flex;align-items:center;justify-content:center;gap:10px;letter-spacing:.5px}.answer-text.correct{color:#10b981;text-shadow:0 2px 8px rgba(16,185,129,.2)}.answer-text.incorrect{color:#ef4444;text-shadow:0 2px 8px rgba(239,68,68,.2)}.correct-answer{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:16px;font-family:Inter,sans-serif;letter-spacing:2px}.correct-answer-highlighted{font-size:32px;font-weight:700;margin-bottom:16px;font-family:Inter,sans-serif;letter-spacing:2px;line-height:1.6}.correct-answer-highlighted .error-word{color:#ef4444;background:#ef44441a;padding:4px 8px;border-radius:0;margin:0 4px;display:inline-block}.correct-answer-highlighted .correct-word{color:var(--text-primary);margin:0 4px;display:inline-block}.word-meaning{font-size:17px;color:var(--text-secondary);font-style:italic;margin-bottom:12px;line-height:1.6}.word-example{font-size:15px;color:var(--text-secondary);margin-top:16px;padding:16px;background:#10b9810a;border-radius:12px;border-left:4px solid var(--accent-color);text-align:left;font-style:italic;line-height:1.6}.word-example-translation{font-size:14px;color:var(--text-secondary);margin-top:8px;padding:12px 16px;background:#10b98105;border-radius:10px;text-align:left;font-style:normal;line-height:1.6}.input-actions{display:flex;justify-content:center;gap:10px;margin-top:16px}.action-btn{padding:10px 20px;border-radius:12px;border:1.5px solid #e5e7eb;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;outline:none!important;letter-spacing:0px;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;line-height:1.5;min-height:40px;background:#fff;color:#374151;box-sizing:border-box;text-align:center}.action-btn:focus,.action-btn:focus-visible{outline:none!important}.action-btn.primary{background:#10b981;color:#fff;border:1.5px solid #10b981;font-weight:600}.action-btn.primary:hover:not(:disabled){background:#059669;border-color:#10b981}.action-btn.primary:active:not(:disabled){background:#047857;border-color:#059669}.action-btn.primary:disabled{background:#d1fae5;color:#6ee7b7;border-color:#d1fae5;cursor:not-allowed;opacity:.6}.action-btn.secondary{background:#fff;color:#374151;border:1.5px solid #e5e7eb}.action-btn.secondary:hover:not(:disabled){background:#f0fdf4;border-color:#10b981;color:#1f2937}.action-btn.secondary:active:not(:disabled){background:#dcfce7;border-color:#059669}.action-btn.secondary svg{width:18px;height:18px}.dictation-result{text-align:center;max-width:700px;padding:40px 20px}.result-icon{width:140px;height:140px;margin:0 auto 40px;animation:scaleIn .6s cubic-bezier(.34,1.56,.64,1)}@keyframes scaleIn{0%{transform:scale(0) rotate(-180deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.result-icon svg{width:100%;height:100%;filter:drop-shadow(0 4px 12px rgba(16,185,129,.3))}.dictation-result h2{font-family:"Noto Serif SC",serif;font-size:36px;font-weight:700;margin:0 0 48px;color:var(--text-primary);letter-spacing:1px}.result-stats{display:flex;justify-content:center;gap:60px;margin-bottom:48px}.stat-item{text-align:center;position:relative;padding:20px}.stat-item:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#10b9810d,#3b82f60d);border-radius:16px;opacity:0;transition:opacity .3s ease}.stat-item:hover:before{opacity:1}.stat-value{font-size:48px;font-weight:800;background:linear-gradient(135deg,#10b981,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px;position:relative}.stat-label{font-size:15px;color:var(--text-secondary);font-weight:600;letter-spacing:.5px;position:relative}.result-actions{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}.dictation-empty{text-align:center;color:var(--text-secondary);font-size:16px}@keyframes vibrate-success{0%,to{transform:scale(1);filter:brightness(1)}25%{transform:scale(1.05);filter:brightness(1.1)}50%{transform:scale(.98);filter:brightness(1)}75%{transform:scale(1.03);filter:brightness(1.08)}}.vibrate-success{animation:vibrate-success .6s cubic-bezier(.36,.07,.19,.97);box-shadow:0 0 50px #10b98180!important;transition:box-shadow .3s ease-out}@keyframes vibrate-error{0%,to{transform:translate(0) rotate(0)}10%,30%,50%,70%,90%{transform:translate(-15px) rotate(-2deg)}20%,40%,60%,80%{transform:translate(15px) rotate(2deg)}}@keyframes flash-error{0%,to{filter:brightness(1);background:transparent}50%{filter:brightness(.9);background:#ef44440d}}.vibrate-error{animation:vibrate-error .6s cubic-bezier(.36,.07,.19,.97),flash-error .6s ease-out;box-shadow:0 0 50px #ef444499!important;transition:box-shadow .3s ease-out}@media(max-width:768px){.dictation-header{padding:16px 20px;flex-wrap:wrap;gap:12px}.dictation-title{order:3;width:100%}.dictation-progress{padding:16px 20px}.dictation-content{padding:20px}.practice-item{padding:40px 24px}.result-stats{gap:24px}}.dictation-page-overlay.dark .action-btn{background:#1f2937;color:#e5e7eb;border-color:#374151}.dictation-page-overlay.dark .action-btn.secondary{background:#1f2937;border-color:#374151}.dictation-page-overlay.dark .action-btn.secondary:hover:not(:disabled){background:#374151;border-color:#4b5563;color:#f3f4f6}.dictation-page-overlay.dark .action-btn.primary{background:#10b981;color:#fff;border-color:#10b981}.dictation-page-overlay.dark .action-btn.primary:hover:not(:disabled){background:#059669;border-color:#059669}.keyboard-shortcuts-hint{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px 20px;margin-top:16px;padding:10px 20px;background:transparent;font-size:12px;max-width:100%}.keyboard-shortcuts-hint .shortcut-item{display:inline-flex;align-items:center;gap:5px;color:#9ca3af;white-space:nowrap;font-size:12px;flex-shrink:0}.keyboard-shortcuts-hint kbd{display:inline-flex;align-items:center;justify-content:center;padding:3px 7px;font-size:11px;font-family:SF Mono,Consolas,Monaco,Courier New,monospace;font-weight:600;color:#6b7280;background:#0000000a;border:1px solid rgba(0,0,0,.08);border-radius:4px;min-width:24px;min-height:20px;text-align:center;letter-spacing:.3px}.dictation-page-overlay.dark .keyboard-shortcuts-hint{background:transparent}.dictation-page-overlay.dark .keyboard-shortcuts-hint .shortcut-item{color:#6b7280}.dictation-page-overlay.dark .keyboard-shortcuts-hint kbd{color:#9ca3af;background:#ffffff0f;border-color:#ffffff1a}@media(max-width:640px){.listening-content{padding:16px;max-width:100%}.listening-sentence{font-size:18px}.listening-translation{font-size:15px}.listening-phonetic{font-size:16px}.listening-meaning{font-size:15px}.keyboard-shortcuts-hint{gap:10px;padding:8px 12px;font-size:10px;margin-top:12px;flex-wrap:wrap}.keyboard-shortcuts-hint .shortcut-item{gap:4px;font-size:10px}.keyboard-shortcuts-hint kbd{padding:2px 6px;font-size:9px;min-width:22px;min-height:18px}}.category-selection{min-height:100vh;background-color:#f8fafc;padding:40px;width:100%;box-sizing:border-box}.category-selection-header{text-align:center;margin-bottom:48px}.category-selection-title{font-size:32px;font-weight:800;color:#1e293b;margin-bottom:12px;letter-spacing:1px;background:linear-gradient(135deg,#6366f1,#8b5cf6,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.category-selection-subtitle{font-size:15px;color:#64748b;font-weight:500;line-height:1.6;letter-spacing:.5px;margin:0}[data-theme=dark] .category-selection-title{color:#f8fafc}[data-theme=dark] .category-selection-subtitle{color:#94a3b8}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;max-width:1200px;margin:0 auto;padding-bottom:60px}.category-card{background:#fff;border-radius:16px;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);border:1px solid rgba(226,232,240,.6);display:flex;flex-direction:column;position:relative;height:100%;box-shadow:0 2px 4px #00000005;cursor:pointer}.category-card:hover{transform:translateY(-6px);box-shadow:0 12px 20px -5px #00000014;border-color:#6366f133}.category-card-visual{width:100%;aspect-ratio:16 / 10;background:#f1f5f9;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.visual-gradient-1{background:linear-gradient(135deg,#e0e7ff,#a5b4fc)}.visual-gradient-2{background:linear-gradient(135deg,#fce7f3,#f9a8d4)}.visual-gradient-3{background:linear-gradient(135deg,#d1fae5,#6ee7b7)}.visual-gradient-4{background:linear-gradient(135deg,#ffedd5,#fdba74)}.category-card-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .5s ease}.category-card:hover .category-card-image{transform:scale(1.05)}.category-icon-wrapper{font-size:56px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.1))}.category-card-content{padding:24px;flex:1;display:flex;flex-direction:column}.category-tags{display:flex;gap:6px;margin-bottom:10px}.category-tag{font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;background:#000;color:#fff;text-transform:uppercase;letter-spacing:.5px}.category-name{font-size:18px;font-weight:700;color:#1e293b;margin:0 0 6px;line-height:1.4}.category-description{font-size:13px;color:#64748b;line-height:1.5;margin:0 0 16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.category-footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;padding-bottom:4px;border-top:1px solid #F1F5F9;margin-top:auto;width:100%}.category-stats{display:flex;flex-direction:row;gap:12px;align-items:center}.stat-item{display:flex;align-items:center;gap:4px;font-size:11px;color:#000;font-weight:700;line-height:1;white-space:nowrap}.stat-item svg{width:12px;height:12px;stroke:#000;stroke-width:3;flex-shrink:0}.category-card .action-btn{width:auto!important;min-width:100px!important;max-width:120px!important;height:36px!important;min-height:36px!important;max-height:36px!important;padding:8px 16px!important;border-radius:10px!important;background:#9ca3af!important;display:inline-flex!important;align-items:center;justify-content:center;gap:8px!important;color:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #00000014;flex-shrink:0!important;flex-grow:0!important;border:none!important;cursor:pointer;white-space:nowrap!important;font-size:14px!important;font-weight:500!important;letter-spacing:0!important;line-height:1!important}.category-card .action-btn:hover,.category-card:hover .action-btn{transform:translateY(-2px);background:linear-gradient(135deg,#f59e0b,#d97706)!important;box-shadow:0 4px 14px #f59e0b59}.category-card .action-btn svg{width:16px!important;height:16px!important;stroke-width:2.5;flex-shrink:0}[data-theme=dark] .category-selection{background-color:#0f172a}[data-theme=dark] .category-card{background:#1e293b;border-color:#334155}[data-theme=dark] .stat-item{color:#fff}[data-theme=dark] .stat-item svg{stroke:#fff}[data-theme=dark] .category-tag{background:#fff;color:#000}[data-theme=dark] .category-card .action-btn{background:#6b7280!important}[data-theme=dark] .category-card .action-btn:hover,[data-theme=dark] .category-card:hover .action-btn{background:linear-gradient(135deg,#fbbf24,#f59e0b)!important;box-shadow:0 4px 12px #fbbf2466}@media(max-width:640px){.categories-grid{grid-template-columns:1fr}}.category-article-list{min-height:100vh;background:#f8f9fa;padding-top:80px}.list-header{position:fixed;top:0;left:0;right:0;height:70px;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;z-index:100;border-bottom:1px solid rgba(0,0,0,.05);transition:all .3s ease}[data-theme=dark] .list-header{background:#1f2937d9;border-bottom:1px solid rgba(255,255,255,.05)}.back-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid rgba(0,0,0,.1);border-radius:12px;cursor:pointer;color:var(--text-primary);transition:all .2s cubic-bezier(.4,0,.2,1)}.back-btn:hover{background:var(--text-primary);border-color:var(--text-primary);color:var(--bg-primary);transform:translate(-2px)}.list-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em}.header-placeholder{width:40px}.list-container{max-width:1200px;margin:0 auto;padding:2rem}.articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:2rem}.article-card{display:flex;flex-direction:column;background:#fff;border-radius:16px;border:1px solid rgba(0,0,0,.04);cursor:pointer;transition:all .4s cubic-bezier(.25,.8,.25,1);overflow:hidden;height:100%;position:relative;box-shadow:0 4px 6px -1px #00000005,0 2px 4px -1px #00000005}.article-card:hover{transform:translateY(-8px);box-shadow:0 20px 25px -5px #0000000d,0 10px 10px -5px #00000003;border-color:#00000014}.article-cover{width:100%;aspect-ratio:2 / 3;position:relative;overflow:hidden;background-color:var(--bg-secondary)}.article-cover img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .6s cubic-bezier(.25,.8,.25,1)}.article-card:hover .article-cover img{transform:scale(1.08)}.article-card-number{position:absolute;top:12px;left:12px;background:#ffffffe6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--text-primary);font-size:.75rem;font-weight:700;font-family:var(--font-mono);padding:4px 8px;border-radius:6px;z-index:2;box-shadow:0 2px 4px #0000000d}.article-card-content{flex:1;padding:1.25rem;display:flex;flex-direction:column;justify-content:space-between}.article-title{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem;line-height:1.4;letter-spacing:-.01em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-meta{display:flex;align-items:center;justify-content:space-between;width:100%;padding-top:.75rem;border-top:1px solid rgba(0,0,0,.04)}.meta-item{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--text-secondary);font-weight:500}.meta-item svg{width:14px;height:14px;opacity:.6}.meta-tag{font-size:.7rem;padding:3px 8px;background:var(--bg-secondary);color:var(--text-secondary);border-radius:100px;font-weight:600;transition:all .2s}.meta-tag.today{background:linear-gradient(135deg,#fbbf24,#d97706);color:#fff;box-shadow:0 2px 4px #f59e0b33}.article-card-action{position:absolute;top:50%;left:50%;transform:translate(-50%,-40%) scale(.8);opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);z-index:3}.article-card:hover .article-card-action{opacity:1;transform:translate(-50%,-50%) scale(1)}.start-btn{width:56px;height:56px;border-radius:50%;border:none;background:#fffffff2;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #0003;transition:all .2s}.start-btn svg{width:28px;height:28px;fill:var(--text-primary);stroke:none;margin-left:4px}.start-btn:hover{transform:scale(1.1);background:#fff}.article-list-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-secondary);background:#f8f9fa}.list-empty{text-align:center;padding:6rem 0;color:var(--text-third)}.empty-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.5}@media(max-width:640px){.category-article-list{background:#fff}.list-header{padding:0 1rem;height:60px}.list-container{padding:1rem}.articles-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.article-card{border-radius:12px;box-shadow:0 2px 8px #0000000a}.article-card-content{padding:.875rem}.article-title{font-size:.9rem;margin-bottom:.5rem;line-height:1.35}.article-meta{padding-top:.5rem}.meta-item{font-size:.7rem}.meta-tag{font-size:.65rem;padding:2px 6px}.article-card-number{font-size:.65rem;padding:2px 6px;top:8px;left:8px}.article-card-action{display:block;position:absolute;top:auto;left:auto;bottom:.75rem;right:.75rem;transform:none;opacity:1}.start-btn{width:32px;height:32px;background:#ffffffe6;box-shadow:0 4px 12px #00000026}.start-btn svg{width:14px;height:14px;margin-left:2px}}.feedback-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease;padding:20px}.feedback-modal{background:var(--bg-color);border-radius:16px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}.feedback-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid var(--border-color, #e5e7eb)}.feedback-header-content{display:flex;align-items:center;gap:12px}.feedback-header-content svg{color:#667eea}.feedback-header h2{margin:0;font-size:20px;font-weight:700;color:var(--text-color)}.feedback-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:8px;cursor:pointer;color:var(--text-color-secondary, #6b7280);transition:all .2s ease}.feedback-close:hover{background:var(--hover-bg, #f3f4f6);color:var(--text-color)}.feedback-form{padding:24px;display:flex;flex-direction:column;gap:24px}.feedback-field{display:flex;flex-direction:column;gap:8px}.feedback-label{font-size:14px;font-weight:600;color:var(--text-color)}.feedback-required{color:#ef4444}.feedback-optional{font-weight:400;color:var(--text-color-secondary, #6b7280)}.feedback-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.feedback-type-item{padding:16px;background:var(--card-bg, #f9fafb);border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left}.feedback-type-item:hover{background:var(--hover-bg, #f3f4f6);border-color:#667eea}.feedback-type-item.active{background:#667eea1a;border-color:#667eea}.feedback-type-label{font-size:14px;font-weight:600;color:var(--text-color);margin-bottom:4px;display:flex;align-items:center;gap:8px}.feedback-type-icon{width:20px;height:20px;-o-object-fit:contain;object-fit:contain}.feedback-type-emoji{font-size:18px;line-height:1}.feedback-type-desc{font-size:12px;color:var(--text-color-secondary, #6b7280)}.feedback-textarea,.feedback-input{width:100%;padding:12px;background:var(--input-bg, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:14px;color:var(--text-color);transition:all .2s ease;font-family:inherit;resize:vertical}.feedback-textarea:focus,.feedback-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.feedback-textarea::-moz-placeholder,.feedback-input::-moz-placeholder{color:var(--text-color-secondary, #9ca3af)}.feedback-textarea::placeholder,.feedback-input::placeholder{color:var(--text-color-secondary, #9ca3af)}.feedback-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.feedback-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.feedback-btn:disabled{opacity:.6;cursor:not-allowed}.feedback-btn-cancel{background:var(--cancel-bg, #f3f4f6);color:var(--text-color-secondary, #6b7280)}.feedback-btn-cancel:hover:not(:disabled){background:var(--cancel-hover-bg, #e5e7eb)}.feedback-btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea4d}.feedback-btn-submit:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.feedback-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.feedback-success{padding:48px 24px;text-align:center}.feedback-success-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;margin-bottom:24px;animation:scaleIn .4s ease}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.feedback-success h3{margin:0 0 12px;font-size:20px;font-weight:700;color:var(--text-color)}.feedback-success p{margin:0;font-size:14px;color:var(--text-color-secondary, #6b7280)}:root[data-theme=dark]{--bg-color: #1f2937;--card-bg: #111827;--input-bg: #111827;--border-color: #374151;--hover-bg: #374151;--text-color: #f9fafb;--text-color-secondary: #9ca3af;--cancel-bg: #374151;--cancel-hover-bg: #4b5563}@media(max-width:640px){.feedback-trigger{right:16px;bottom:80px;padding:10px 16px;font-size:13px}.feedback-modal{max-height:95vh;border-radius:16px 16px 0 0;margin-top:auto}.feedback-type-grid{grid-template-columns:1fr}.feedback-actions{flex-direction:column-reverse}.feedback-btn{width:100%;justify-content:center}}.floating-action-badge{position:fixed;top:50%;right:60px;transform:translateY(-50%);z-index:800;display:flex;align-items:center;justify-content:center;cursor:pointer;width:160px;height:160px}@media(max-width:768px){.floating-action-badge{right:16px;width:120px;height:120px}}.fab-badge-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:transparent!important;border:none!important;box-shadow:none!important;z-index:10;cursor:pointer;padding:0;transition:transform .2s ease}.fab-badge-center:hover{transform:translate(-50%,-50%) scale(1.1)}.fab-badge-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 0 10px rgba(255,255,255,.5))}.fab-glow-layer{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:140%;height:140%;border-radius:50%;z-index:-1;opacity:.6;filter:blur(20px);pointer-events:none}.fab-menu-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.fab-sector-item{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;-webkit-mask:radial-gradient(transparent 35px,black 36px,black 75px,transparent 76px);mask:radial-gradient(transparent 35px,black 36px,black 75px,transparent 76px);background:#a0a0a033;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);opacity:0;transform:scale(.9)}.floating-action-badge:hover .fab-sector-item{opacity:1;transform:scale(1)}.fab-sector-item:hover{background:#fbbf24e6;box-shadow:0 0 20px #fbbf2480}.fab-sector-feedback{clip-path:polygon(0 0,50% 0,50% 50%,0 50%)}.fab-sector-icon{position:absolute;top:26%;left:26%;transform:translate(-50%,-50%);width:24px;height:24px;display:flex;align-items:center;justify-content:center;z-index:20;pointer-events:none;opacity:.6;transition:opacity .2s}.fab-sector-item:hover .fab-sector-icon{opacity:1}.fab-sector-icon img{width:20px;height:20px;-o-object-fit:contain;object-fit:contain;filter:brightness(.3)}.fab-sector-item:hover .fab-sector-icon img{filter:brightness(0) invert(1)}.fab-badge-label{position:absolute;top:115px;left:50%;transform:translate(-50%);display:flex!important;flex-direction:row;align-items:center;gap:6px;pointer-events:none;z-index:20;text-align:center;text-shadow:0 1px 3px rgba(255,255,255,.9),0 0 2px rgba(255,255,255,1);white-space:nowrap}.fab-badge-level{font-size:11px;font-weight:800;color:#6366f1;font-family:SF Mono,monospace;line-height:1}.fab-badge-name{font-size:11px;font-weight:700;color:#1f2937;line-height:1}.quick-points-card{display:flex;align-items:center;gap:8px;cursor:pointer;position:relative}.quick-points-info{display:flex;align-items:center;gap:6px;padding:6px 14px 6px 12px;background:#3b82f614;border-radius:20px;transition:all .2s ease;flex-shrink:0;overflow:visible;min-width:-moz-fit-content;min-width:fit-content}.quick-points-info:hover{background:#3b82f61f}.quick-points-value{display:flex;align-items:center;gap:5px;flex-shrink:0;overflow:visible}.points-icon{font-size:14px;line-height:1;flex-shrink:0}.points-icon-img{width:16px;height:16px;-o-object-fit:contain;object-fit:contain;flex-shrink:0}.points-number{font-size:15px;font-weight:700;color:#3b82f6;line-height:1;white-space:nowrap;min-width:-moz-max-content;min-width:max-content;display:inline-block;letter-spacing:.5px}[data-theme=dark] .points-number{color:#60a5fa}.quick-points-label{display:none}.quick-checkin-btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:6px 14px;background:linear-gradient(135deg,#f97316,#ea580c);border:none;border-radius:20px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #f973164d;min-width:auto;white-space:nowrap}.quick-checkin-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #f9731666;background:linear-gradient(135deg,#ea580c,#c2410c)}.quick-checkin-btn:active:not(:disabled){transform:translateY(0)}.quick-checkin-btn:disabled{cursor:default}.quick-checkin-btn.checked{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 2px 8px #22c55e4d}.quick-checkin-btn.checked:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 4px 12px #22c55e66;transform:translateY(-1px)}.quick-checkin-btn.loading{background:linear-gradient(135deg,#9ca3af,#6b7280);box-shadow:0 2px 6px #9ca3af40}.checkin-icon{font-size:14px;line-height:1}.checkin-icon-img{width:16px;height:16px;-o-object-fit:contain;object-fit:contain}.checkin-text{font-size:12px;font-weight:600}.checkin-days{font-size:13px;font-weight:700}.checkin-loading{font-size:14px;animation:spin 1s linear infinite}.quick-checkin-success{position:absolute;top:-32px;right:0;padding:6px 10px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:13px;font-weight:700;border-radius:16px;box-shadow:0 3px 10px #f59e0b59;animation:bounceIn .4s ease,fadeOut .4s ease 1.5s forwards;z-index:10}@keyframes bounceIn{0%{transform:scale(0) translateY(10px);opacity:0}60%{transform:scale(1.1) translateY(0)}to{transform:scale(1);opacity:1}}@keyframes fadeOut{to{opacity:0;transform:translateY(-8px)}}@media(max-width:768px){.quick-points-card{gap:6px}.quick-points-info{padding:5px 10px;gap:4px}.points-icon{font-size:12px}.points-icon-img{width:14px;height:14px}.points-number{font-size:14px}.quick-checkin-btn{padding:5px 12px;font-size:12px}.checkin-icon{font-size:12px}.checkin-icon-img{width:14px;height:14px}.checkin-text{display:none}.checkin-days{font-size:12px}}[data-theme=dark] .quick-points-info{background:#60a5fa26}[data-theme=dark] .quick-points-info:hover{background:#60a5fa33}[data-theme=dark] .quick-checkin-btn{background:linear-gradient(135deg,#f97316,#ea580c)}[data-theme=dark] .quick-checkin-btn.checked{background:linear-gradient(135deg,#22c55e,#16a34a)}.checkin-wrapper{position:relative}.checkin-calendar-popup{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:var(--paper-color, #ffffff);border-radius:16px;box-shadow:0 10px 40px #00000026;padding:16px;z-index:1000;animation:slideDown .2s ease}[data-theme=dark] .checkin-calendar-popup{background:#1f2937;box-shadow:0 10px 40px #0006}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border-color, #e5e7eb)}.calendar-title{font-size:15px;font-weight:700;color:var(--text-primary, #1a1a1a)}.calendar-stats{font-size:12px;color:var(--text-secondary, #666)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:8px}.calendar-weekdays span{text-align:center;font-size:11px;font-weight:600;color:var(--text-secondary, #999);padding:4px 0}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-loading{grid-column:span 7;text-align:center;padding:20px;color:var(--text-secondary, #999);font-size:13px}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;color:var(--text-primary, #333);border-radius:8px;position:relative;transition:all .15s ease}.calendar-day.empty{visibility:hidden}.calendar-day.future{color:var(--text-secondary, #ccc)}.calendar-day.today{background:#3b82f61a;color:#3b82f6;font-weight:700}.calendar-day.checked{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-weight:600}.calendar-day .check-mark{position:absolute;bottom:1px;right:2px;font-size:8px;opacity:.9}.calendar-footer{margin-top:12px;padding-top:10px;border-top:1px solid var(--border-color, #e5e7eb);text-align:center}.streak-info{font-size:13px;font-weight:600;color:#f59e0b}.checkin-calendar-popup:before{content:"";position:absolute;top:-6px;right:20px;width:12px;height:12px;background:var(--paper-color, #ffffff);transform:rotate(45deg);border-radius:2px}[data-theme=dark] .checkin-calendar-popup:before{background:#1f2937}.calendar-day.can-makeup{background:#f59e0b26;border:1px dashed #f59e0b;color:#d97706}.calendar-day.can-makeup:hover{background:#f59e0b40;transform:scale(1.05)}.makeup-icon{position:absolute;bottom:-4px;right:-4px;width:28px;height:28px;-o-object-fit:contain;object-fit:contain;transform:rotate(-15deg);filter:drop-shadow(0 1px 3px rgba(0,0,0,.25));z-index:1}.calendar-footer{display:flex;justify-content:space-between;align-items:center}.makeup-card-info{font-size:12px;color:#f59e0b;font-weight:500}.makeup-card-info:hover{color:#d97706}.buy-modal{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;border-radius:16px;z-index:10}.buy-modal-content{background:var(--paper-color, #ffffff);padding:20px;border-radius:12px;text-align:center;min-width:200px}[data-theme=dark] .buy-modal-content{background:#374151}.buy-modal-content h3{margin:0 0 12px;font-size:16px;font-weight:700;color:var(--text-primary, #1a1a1a)}.buy-modal-content p{margin:6px 0;font-size:13px;color:var(--text-secondary, #666)}.buy-modal-actions{display:flex;gap:10px;margin-top:16px;justify-content:center}.buy-modal-actions .cancel-btn{padding:8px 16px;border:1px solid var(--border-color, #e5e7eb);background:transparent;border-radius:8px;font-size:13px;cursor:pointer;color:var(--text-secondary, #666)}.buy-modal-actions .buy-btn{padding:8px 16px;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:8px;color:#fff;font-size:13px;font-weight:600;cursor:pointer}.buy-modal-actions .buy-btn:disabled{opacity:.6;cursor:not-allowed}.buy-modal-actions .buy-btn:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309)}.ranking-button{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;border-radius:8px;background:transparent;color:var(--text-primary);cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;white-space:nowrap}.ranking-button:hover{background:var(--hover-bg)}.ranking-button.ranking-loading{opacity:.6;cursor:not-allowed}.ranking-btn-icon{width:18px;height:18px;-o-object-fit:contain;object-fit:contain}.ranking-label{color:var(--text-secondary);font-size:12px;font-weight:500}.ranking-number{font-weight:700;color:#d946ef;font-size:14px;letter-spacing:.5px}.ranking-modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;z-index:99999;animation:fadeIn .2s ease;padding:80px 20px 20px;box-sizing:border-box;overflow-y:auto}.ranking-modal-content{background:#fff;border-radius:16px;padding:20px;max-width:540px;width:90%;height:auto;max-height:calc(100vh - 160px);overflow:visible;display:flex;flex-direction:column;position:relative;box-shadow:0 25px 50px #00000080,0 0 0 1px #d946ef33 inset;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);border:2px solid rgba(217,70,239,.3);margin:0 auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close-btn{position:absolute;top:12px;right:12px;width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);font-size:24px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{color:var(--text-primary);background:var(--hover-bg);border-radius:6px}.modal-loading,.modal-error{text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:14px}.modal-error{color:#dc2626}.ranking-modal-body{display:flex;flex-direction:column;gap:12px;overflow:visible}.modal-title-section{text-align:center;padding-bottom:12px;border-bottom:1px solid #e5e5e5;flex-shrink:0}.modal-title{font-size:16px;font-weight:700;color:#1a1a1a;margin:0}.top-rankings-section{display:flex;flex-direction:column;gap:6px;overflow:visible;flex-shrink:0}.top-rankings-list{display:flex;flex-direction:column;gap:6px;overflow:visible}.top-ranking-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#f5f5f5;border-radius:6px;transition:all .2s ease;flex-shrink:0}.top-ranking-item:hover{background:linear-gradient(135deg,#d946ef14,#d946ef0a);transform:translate(4px)}.top-ranking-item.current-user{background:linear-gradient(135deg,#d946ef26,#d946ef14);border:2px solid rgba(217,70,239,.3)}.ranking-position{min-width:50px;display:flex;align-items:center;justify-content:center}.user-avatar-container{width:40px;height:40px;flex-shrink:0}.user-ranking-avatar{width:100%;height:100%;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #fff;box-shadow:0 2px 4px #0000000d}.top-ranking-item.current-user .user-ranking-avatar{border-color:#d946ef}.rank-medal-large,.rank-number-large{display:flex;align-items:center;justify-content:center;font-weight:700;color:#d946ef;font-size:16px}.rank-medal-large{width:50px;height:50px;-o-object-fit:contain;object-fit:contain}.user-info{flex:1;display:flex;flex-direction:column;gap:2px}.user-name{font-size:14px;font-weight:600;color:#1a1a1a}.user-score-small{font-size:12px;color:var(--text-secondary)}.user-score-large{font-size:20px!important;font-weight:600!important;color:#d946ef!important;min-width:70px;text-align:right}.your-ranking-section{display:none;flex-direction:column;gap:8px}.divider{font-size:12px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:1px;padding:8px 0}.your-ranking-item{display:flex;align-items:center;gap:12px;padding:12px;background:linear-gradient(135deg,#d946ef1a,#d946ef0d);border-left:3px solid #d946ef;border-radius:6px}.your-rank{font-weight:700;color:#d946ef;font-size:16px;min-width:50px}.your-name{flex:1;font-size:14px;font-weight:600;color:#1a1a1a}.your-score{font-size:16px;font-weight:700;color:#d946ef;min-width:70px;text-align:right}.your-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding-top:8px;border-top:1px solid #e5e5e5;flex-shrink:0}.stat-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;background:#f5f5f5;border-radius:6px;text-align:center}.stat-label{font-size:12px;color:#888;font-weight:500}.stat-value{font-size:32px!important;font-weight:700!important;color:#d946ef!important;line-height:1.2;display:flex;align-items:baseline;gap:4px;justify-content:center}.stat-value .stat-unit{font-size:20px!important;font-weight:500!important;color:#d946ef!important;opacity:.8}[data-theme=dark] .ranking-modal-content{background:#2a2a2a}[data-theme=dark] .top-ranking-item,[data-theme=dark] .stat-item{background:#333}[data-theme=dark] .your-ranking-item{background:linear-gradient(135deg,#d946ef26,#d946ef14)}@media(max-width:600px){.ranking-modal-content{max-width:95%;padding:16px}.modal-title{font-size:18px}.top-ranking-item{padding:12px}.user-score-large{font-size:18px!important;min-width:60px}.your-stats{grid-template-columns:1fr}}.review-session-desktop{--bg-color: #FFFFFF;--paper-color: #FFFFFF;--text-primary: #1A1A1A;--text-secondary: #565656;--accent-color: #d946ef;--accent-light: #fef3ff;--border-color: #E8E8E8;--success-color: #059669;--error-color: #dc2626;--info-bg: #f8f9ff;--info-border: #d4d7ff;position:fixed;inset:0;background:var(--bg-color);z-index:1000;display:flex;flex-direction:column;overflow:hidden;color:var(--text-primary)}.review-session-desktop.dark{--bg-color: #0f172a;--paper-color: #1a2542;--text-primary: #e5e7eb;--text-secondary: #9ca3af;--accent-color: #ec4899;--accent-light: #3b1b5c;--border-color: #334155;--success-color: #10b981;--error-color: #f87171;--info-bg: #1a2e4d;--info-border: #2a4a7d;background:var(--bg-color)}.desktop-header{display:flex;align-items:center;justify-content:space-between;padding:16px 40px;background:var(--paper-color);border-bottom:1px solid var(--border-color);flex-shrink:0;transition:all .3s ease}.theme-btn svg circle,.theme-btn svg line{stroke:currentColor}.review-session-desktop.immersive .desktop-main{padding-top:20px}.desktop-footer.compact{padding:16px 40px;background:transparent;border-top:none}.desktop-footer.compact .footer-hint{display:none}.desktop-footer.compact .action-buttons{justify-content:center}.close-btn{display:flex;align-items:center;justify-content:center;padding:8px;min-width:36px;height:36px;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .2s ease;outline:none!important}.close-btn:hover,.close-btn:focus,.close-btn:focus-visible{background:var(--bg-color);border-color:var(--text-primary);color:var(--text-primary);outline:none!important;box-shadow:none!important}.close-btn svg{width:20px;height:20px;stroke-linecap:round;stroke-linejoin:round}.close-text{font-weight:500;display:inline}.progress-container{display:flex;align-items:center;gap:20px;flex:1;max-width:1200px;margin-right:48px}.header-label{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#6366f1,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.header-label:before{content:"";display:inline-block;width:6px;height:6px;background:#6366f1;border-radius:50%;box-shadow:0 0 8px #6366f180}.progress-bar-desktop{flex:1;height:6px;background:var(--border-color);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--accent-color);border-radius:3px;transition:width .4s ease}.progress-text{color:var(--text-secondary);font-size:14px;font-weight:500;white-space:nowrap}.points-animation{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;gap:8px;z-index:9999;animation:points-float-up 2s ease-out forwards;pointer-events:none}@keyframes points-float-up{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}30%{transform:translate(-50%,-50%) scale(1)}70%{opacity:1;transform:translate(-50%,-80%) scale(1)}to{opacity:0;transform:translate(-50%,-120%) scale(.8)}}.points-badge{font-size:48px;font-weight:700;color:#f59e0b;text-shadow:0 2px 10px rgba(245,158,11,.5),0 4px 20px rgba(245,158,11,.3);font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,sans-serif}.points-icon{font-size:40px;animation:points-icon-bounce .5s ease-out}@keyframes points-icon-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.mode-switch{display:flex;gap:8px;background:var(--border-color);padding:4px;border-radius:12px}.mode-btn{padding:10px 20px;background:transparent;border:none;border-radius:10px;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.mode-btn.active{background:var(--accent-color);color:#fff;box-shadow:0 4px 12px #00000026}.mode-btn:hover:not(.active){color:var(--text-primary);background:var(--accent-light)}.desktop-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 48px;overflow:visible;gap:32px}.card-layout{display:flex;gap:32px;width:100%;max-height:70vh}.card-left{flex:1.2;background:var(--paper-color);border:1px solid var(--border-color);border-radius:16px;padding:40px;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;box-shadow:0 4px 12px #00000014;max-height:100%}.card-left::-webkit-scrollbar{width:6px}.card-left::-webkit-scrollbar-track{background:transparent}.card-left::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.card-left::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.card-right{flex:.8;display:flex;flex-direction:column;gap:16px;overflow-y:auto;overflow-x:hidden;max-height:100%;padding-right:4px}.card-right::-webkit-scrollbar{width:6px}.card-right::-webkit-scrollbar-track{background:transparent}.card-right::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.card-right::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.word-section{text-align:center;padding-bottom:24px;border-bottom:1px solid var(--border-color);margin-bottom:24px;flex-shrink:0}.word-row{display:flex;align-items:center;justify-content:center;gap:24px;margin-bottom:16px}.word-text{font-size:48px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.audio-btn{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--accent-color);border:none;border-radius:50%;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000001a}.audio-btn:hover{transform:scale(1.08);box-shadow:0 6px 16px #00000026}.audio-icon{width:28px;height:28px;filter:brightness(0) invert(1)}.phonetic{font-size:16px;color:var(--text-secondary);font-family:Segoe UI,sans-serif;letter-spacing:.5px}.section-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.section-header span{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.section-icon{width:20px;height:20px;opacity:.6}.context-icon{font-size:18px;opacity:.6}.meaning-section{margin-bottom:32px}.meaning-content{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1.5}.example-section{margin-bottom:0;padding:16px;background:var(--info-bg);border-radius:12px;border-left:4px solid var(--accent-color);flex-shrink:0;overflow:hidden}.example-en{font-size:16px;color:var(--text-primary);line-height:1.6;margin-bottom:8px;font-style:italic;font-weight:500}.example-zh{font-size:14px;color:var(--text-secondary);line-height:1.5}.example-empty{font-size:14px;color:var(--text-secondary);font-style:italic}.morpheme-section{background:var(--info-bg);border:1px solid var(--info-border);border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000000f;flex-shrink:0;overflow:hidden}.morpheme-list{display:flex;flex-direction:column;gap:8px}.morpheme-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;transition:all .2s ease;background:var(--bg-color)}.morpheme-item.prefix{background:var(--bg-color);border-left:3px solid #3b82f6}.morpheme-item.root{background:var(--bg-color);border-left:3px solid #8b5cf6}.morpheme-item.suffix{background:var(--bg-color);border-left:3px solid #10b981}.morpheme-name{font-size:16px;font-weight:600;color:var(--text-primary)}.morpheme-meaning{font-size:14px;color:var(--text-secondary)}.morpheme-empty{font-size:14px;color:var(--text-secondary);font-style:italic;padding:12px 0}.context-section{background:var(--info-bg);border:1px solid var(--info-border);border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000f;flex:1}.context-content{font-size:14px;color:var(--text-primary);line-height:1.6;padding-left:16px;border-left:3px solid var(--accent-color)}.spell-layout-split{display:flex;gap:40px;width:100%;max-height:70vh;padding:20px;animation:fadeIn .3s ease}.spell-layout-split.center-mode{justify-content:center;gap:0;transition:gap .3s ease}.spell-layout-split.center-mode .spell-left{max-width:600px}.spell-layout-split.center-mode .spell-right{display:none}.spell-left{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:24px;max-width:500px;margin:0 auto;transition:max-width .3s ease}.spell-hint-section{text-align:center;width:100%}.prompt-meaning-large{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:16px;line-height:1.4}.audio-row{display:flex;align-items:center;justify-content:center;gap:12px}.phonetic-text{font-size:18px;color:var(--text-secondary);font-family:Courier New,monospace}.audio-btn-small{width:36px;height:36px;border-radius:50%;background:var(--accent-light);border:1px solid var(--accent-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--accent-color)}.audio-btn-small:hover{background:var(--accent-color);border-color:var(--accent-color);color:#fff;transform:scale(1.1)}.audio-icon-small{width:20px;height:20px}.spell-input-section{display:flex;gap:12px;width:100%}.spell-input-new{flex:1;padding:16px 24px;font-size:20px;text-align:center;background:var(--paper-color);border:2px solid var(--border-color);border-radius:14px;color:var(--text-primary);outline:none;transition:all .2s ease;font-weight:500}.spell-input-new:focus{border-color:var(--accent-color);background:var(--info-bg);box-shadow:0 0 0 3px var(--accent-light)}.spell-input-new.correct{border-color:#059669;background:#f0fdf4;color:#065f46}.spell-input-new.incorrect{border-color:#dc2626;background:#fef2f2;color:#7f1d1d}.check-btn-new{padding:16px 28px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:14px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.check-btn-new:hover{transform:scale(1.05)}.underscore-input-container{position:relative;display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;cursor:text}.underscore-hidden-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:text;font-size:2rem;z-index:10}.underscore-display-review{display:inline-flex;flex-wrap:wrap;justify-content:center;gap:8px;font-family:SF Mono,Consolas,Monaco,monospace;font-size:2.5rem;font-weight:600;letter-spacing:2px;padding:20px;min-height:80px;transition:all .3s ease}.underscore-display-review.correct{animation:correct-flash .5s ease}.underscore-display-review.incorrect{animation:incorrect-shake .5s ease}@keyframes correct-flash{0%,to{background:transparent}50%{background:#10b9811a}}@keyframes incorrect-shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}50%{transform:translate(8px)}75%{transform:translate(-8px)}}.underscore-char-review{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:56px;border-bottom:3px solid var(--border-color);color:var(--text-primary);transition:all .15s ease}.underscore-char-review.empty{color:transparent}.underscore-char-review.filled{color:var(--text-primary);border-bottom-color:var(--accent-color)}.underscore-char-review.cursor{border-bottom-color:var(--accent-color);animation:cursor-blink 1s infinite}@keyframes cursor-blink{0%,50%{border-bottom-color:var(--accent-color)}51%,to{border-bottom-color:transparent}}.underscore-char-review.correct{color:#059669;border-bottom-color:#059669;background:#10b9811a;border-radius:4px 4px 0 0}.underscore-char-review.incorrect{color:#dc2626;border-bottom-color:#dc2626;background:#dc26261a;border-radius:4px 4px 0 0}.result-actions-container{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:16px;width:100%}.result-badge-review{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;border-radius:20px;font-size:16px;font-weight:600}.retry-btn-review{display:flex;align-items:center;gap:8px;padding:10px 24px;background:transparent;border:1px solid var(--border-color);border-radius:20px;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;width:auto}.retry-btn-review:hover{background:var(--bg-color);border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-1px);box-shadow:0 2px 8px #0000000d}.retry-btn-review svg{width:16px;height:16px}.result-badge-inline{padding:16px 20px;border-radius:14px;font-size:16px;font-weight:600;white-space:nowrap}.result-badge-inline.correct{background:#10b98133;color:#10b981;border:1px solid rgba(16,185,129,.3)}.result-badge-inline.incorrect{background:#f59e0b33;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.answer-section{display:flex;align-items:center;gap:16px}.answer-word{font-size:28px;font-weight:700;color:#fff}.retry-btn-small{padding:10px 20px;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-btn-small:hover{transform:translateY(-2px)}.tab-hint-section{margin-top:8px}.hint-revealed{display:flex;align-items:center;gap:12px;padding:12px 24px;background:var(--info-bg);border:1px solid var(--info-border);border-radius:12px}.hint-label-small{font-size:14px;color:#fbbf24}.hint-word-small{font-size:22px;font-weight:700;color:var(--accent-color)}.hint-prompt{font-size:13px;color:var(--text-secondary)}.spell-right{flex:1;display:flex;flex-direction:column;gap:20px;max-width:450px;overflow-y:auto;opacity:0;transform:translate(20px);transition:all .3s ease}.spell-right.visible{opacity:1;transform:translate(0)}.spell-right.hidden{opacity:0;pointer-events:none}.spell-right-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px}.placeholder-icon{font-size:48px;opacity:.3}.placeholder-text{font-size:14px;color:var(--text-secondary)}.info-section{background:var(--info-bg);border:1px solid var(--info-border);border-radius:12px;padding:16px;flex-shrink:0;overflow:hidden}.info-section .section-header{display:flex;align-items:center;gap:6px;margin-bottom:10px;font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.info-section .section-icon{width:16px;height:16px;opacity:.8}.info-content{font-size:14px;color:var(--text-primary);line-height:1.5}.info-content.example-text{font-style:italic}.info-content.example-zh{margin-top:6px;color:var(--text-secondary);font-size:13px}.info-content.context-text{padding-left:12px;border-left:3px solid rgba(99,102,241,.5)}.morpheme-tags{display:flex;flex-wrap:wrap;gap:8px}.morpheme-tag-spell{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--accent-light);border:1px solid var(--accent-color);border-radius:10px}.morpheme-tag-spell .tag-name{font-weight:600;color:var(--accent-color)}.morpheme-tag-spell .tag-meaning{font-size:12px;color:var(--text-secondary)}.spell-layout{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;gap:48px}.spell-prompt{text-align:center}.prompt-meaning{font-size:36px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.audio-section-spell{display:flex;flex-direction:column;align-items:center;gap:16px;margin-bottom:24px;padding:20px 32px;background:var(--info-bg);border-radius:16px;border:1px solid var(--info-border)}.prompt-phonetic{font-size:18px;color:var(--text-secondary);font-family:Courier New,monospace;letter-spacing:1px}.audio-btn-spell{display:flex;align-items:center;gap:10px;padding:12px 28px;background:var(--accent-light);border:1px solid var(--accent-color);border-radius:25px;color:var(--accent-color);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease}.audio-btn-spell:hover{background:var(--accent-color);border-color:var(--accent-color);color:#fff;transform:scale(1.05);box-shadow:0 4px 12px #0000001a}.audio-btn-spell .audio-icon{width:22px;height:22px;filter:none;opacity:.9}.hint-box{margin-top:20px;padding:16px 28px;background:var(--accent-light);border:1px solid var(--accent-color);border-radius:12px;display:flex;align-items:center;gap:12px;animation:fadeInUp .3s ease}.hint-label{font-size:15px;color:var(--accent-color);font-weight:500}.hint-word{font-size:28px;font-weight:700;color:var(--accent-color);letter-spacing:2px}.hint-toggle{margin-top:20px;font-size:13px;color:var(--text-secondary);padding:8px 16px;background:var(--border-color);border-radius:20px;cursor:pointer;transition:all .2s ease}.hint-toggle:hover{background:var(--accent-light);color:var(--accent-color)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.spell-input-area{display:flex;gap:16px;width:100%;max-width:600px}.spell-input{flex:1;padding:20px 28px;font-size:24px;text-align:center;border:2px solid var(--border-color);border-radius:16px;background:var(--paper-color);color:var(--text-primary);outline:none;transition:all .2s ease;font-weight:500}.spell-input::-moz-placeholder{color:var(--text-secondary)}.spell-input::placeholder{color:var(--text-secondary)}.spell-input:focus{border-color:var(--accent-color);background:var(--info-bg);box-shadow:0 0 0 3px var(--accent-light)}.spell-input.correct{border-color:#059669;background:#f0fdf4;color:#065f46}.spell-input.incorrect{border-color:#dc2626;background:#fef2f2;color:#7f1d1d}.check-btn{padding:16px 48px;background:var(--accent-color);border:none;border-radius:12px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #0000001a}.check-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #d946ef4d}.spell-result{text-align:center}.result-badge{display:inline-block;padding:14px 36px;border-radius:30px;font-size:22px;font-weight:700;margin-bottom:20px}.result-badge.correct{background:#f0fdf4;color:#059669;border:2px solid #059669;font-weight:600}.result-badge.incorrect{background:#fffbeb;color:#b45309;border:2px solid #f59e0b;font-weight:600}.correct-answer{font-size:16px;color:var(--text-secondary)}.correct-answer strong{font-size:24px;color:var(--text-primary);margin-left:12px;font-weight:700}.spell-full-info{margin-top:24px;padding:20px 24px;background:var(--info-bg);border-radius:16px;text-align:left;max-width:500px;margin-left:auto;margin-right:auto;border:1px solid var(--info-border)}.spell-full-info .info-row{display:flex;margin-bottom:12px;font-size:14px;line-height:1.6}.spell-full-info .info-row:last-of-type{margin-bottom:16px}.spell-full-info .info-label{color:var(--text-secondary);min-width:70px;flex-shrink:0;font-weight:600}.spell-full-info .info-value{color:var(--text-primary)}.spell-full-info .morphemes-row{flex-wrap:wrap}.spell-full-info .morphemes-inline{display:flex;flex-wrap:wrap;gap:6px}.spell-full-info .morpheme-tag{background:var(--accent-light);color:var(--accent-color);padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.retry-btn{display:block;width:100%;padding:12px 20px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b66}.desktop-footer{position:fixed;bottom:0;left:0;right:0;background:transparent;border-top:none;padding:20px;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:100;pointer-events:none}.desktop-footer>*{pointer-events:auto}.footer-hint{text-align:center;font-size:13px;color:var(--text-secondary);margin-bottom:20px}.card-shortcut-container{position:absolute;top:32px;right:48px;z-index:10}.spell-shortcut-container{position:absolute;top:20px;right:20px;z-index:10}.spell-left{position:relative}.shortcut-icon-btn{width:32px;height:32px;border-radius:50%;background:transparent;border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text-secondary)}.icon-text{font-size:16px;font-weight:700;font-family:Times New Roman,serif;font-style:italic;line-height:1}.shortcut-popup-card,.shortcut-popup-spell{position:absolute;top:100%;right:0;margin-top:12px;background:var(--paper-color);border:1px solid var(--border-color);border-radius:12px;padding:16px;width:200px;box-shadow:0 10px 30px #0000001f;opacity:0;pointer-events:none;transition:all .2s ease;transform-origin:top right;transform:scale(.95);z-index:100}.shortcut-popup-card.visible,.shortcut-popup-spell.visible{opacity:1;pointer-events:auto;transform:scale(1)}.popup-title{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.shortcut-list{display:flex;flex-direction:column;gap:8px}.key-label{font-family:SF Mono,Consolas,monospace;font-size:11px;font-weight:600;color:var(--accent-color);background:var(--accent-light);padding:2px 6px;border-radius:4px}.key-desc{font-size:12px;color:var(--text-secondary)}@media(max-width:768px){.card-shortcut-container{top:20px;right:20px}}.action-buttons{display:flex;gap:48px;justify-content:center}.action-item{display:flex;flex-direction:column;align-items:center;gap:12px}.action-btn{display:flex;align-items:center;justify-content:center;padding:18px 48px;border:none;border-radius:14px;cursor:pointer;transition:all .25s ease;min-width:160px;position:relative;outline:none}.action-btn:disabled{opacity:.4;cursor:not-allowed}.action-btn.forget{background:#fef2f2;border:2px solid #dc2626;color:#991b1b;font-weight:600}.action-btn.fuzzy{background:#fff;border:2px solid #f59e0b;color:#92400e;font-weight:600}.action-btn.know{background:#f0fdf4;border:2px solid #059669;color:#065f46;font-weight:600}.action-btn:hover:not(:disabled){transform:translateY(-4px)}.action-btn.forget:hover:not(:disabled){box-shadow:0 8px 16px #dc262633;background:#fee2e2;border-color:#991b1b}.action-btn.fuzzy:hover:not(:disabled){box-shadow:0 8px 16px #f59e0b33;background:#fef3c7;border-color:#92400e}.action-btn.know:hover:not(:disabled){box-shadow:0 8px 16px #05966933;background:#dcfce7;border-color:#065f46}@keyframes button-vibrate{0%,to{transform:scale(1)}10%{transform:scale(1.1) rotate(-2deg)}20%{transform:scale(1.15) rotate(2deg)}30%{transform:scale(1.1) rotate(-1deg)}40%{transform:scale(1.12) rotate(1deg)}50%{transform:scale(1.08)}60%{transform:scale(1.1)}70%{transform:scale(1.05)}80%{transform:scale(1.08)}90%{transform:scale(1.02)}}.action-btn.vibrating{animation:button-vibrate .5s ease-out}.action-btn.forget.vibrating{box-shadow:0 0 30px #dc262699;background:#fee2e2;border-color:#dc2626}.action-btn.fuzzy.vibrating{box-shadow:0 0 30px #f59e0b99;background:#fef3c7;border-color:#f59e0b}.action-btn.know.vibrating{box-shadow:0 0 30px #05966999;background:#dcfce7;border-color:#059669}.btn-label{font-size:18px;font-weight:600}.action-item>.btn-desc{font-size:12px;color:var(--text-secondary);font-weight:500;margin-top:8px}.action-btn:after{content:attr(data-key);position:absolute;top:50%;right:16px;transform:translateY(-50%);font-size:20px;font-weight:400;opacity:.7;color:inherit;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:none!important;border:none!important;outline:none!important;box-shadow:none!important;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-variant-emoji:text}.review-loading,.review-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-primary);text-align:center;padding:40px}.loading-spinner-large{width:60px;height:60px;border:3px solid var(--border-color);border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:24px}.empty-icon{font-size:80px;margin-bottom:24px}.review-empty h2{font-size:32px;font-weight:600;margin-bottom:12px;color:var(--text-primary);background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.review-empty p{font-size:16px;color:var(--text-secondary);margin-bottom:32px}.empty-actions{display:flex;gap:16px}.empty-back-btn{padding:14px 32px;background:var(--info-bg);border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease}.empty-back-btn:hover{background:var(--accent-light);border-color:var(--accent-color);color:var(--accent-color)}.empty-restart-btn{padding:14px 32px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #6366f14d}.empty-restart-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.review-empty .back-btn{padding:16px 48px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:30px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 8px 25px #6366f14d}.back-btn:hover{transform:scale(1.05);box-shadow:0 12px 35px #6366f166}.confetti-container{position:absolute;inset:0;overflow:hidden;pointer-events:none}.confetti{position:absolute;top:-20px;width:10px;height:10px;border-radius:2px;animation:confetti-fall linear forwards}.confetti-0{background:#6366f1}.confetti-1{background:#8b5cf6}.confetti-2{background:#a855f7}.confetti-3{background:#10b981}.confetti-4{background:#f59e0b}.confetti-5{background:#ec4899}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.complete-page{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 40px 80px;position:relative;z-index:1;overflow-y:auto;min-height:0}.trophy-section{position:relative;margin-bottom:32px}.trophy-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:200px;background:radial-gradient(circle,rgba(251,191,36,.3) 0%,transparent 70%);border-radius:50%;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.2);opacity:.8}}.trophy-icon{width:120px;height:120px;position:relative;z-index:1;animation:trophy-bounce 1s ease-out;filter:drop-shadow(0 10px 30px rgba(251,191,36,.4))}@keyframes trophy-bounce{0%{transform:scale(0) rotate(-20deg)}50%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0)}}.complete-title{font-size:48px;font-weight:700;background:linear-gradient(135deg,#6366f1,#f59e0b,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px;animation:title-appear .6s ease-out .3s both}.review-session-desktop.dark .complete-title{background:linear-gradient(135deg,#fff,#fbbf24,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@keyframes title-appear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.complete-message{font-size:18px;margin-bottom:48px;animation:title-appear .6s ease-out .5s both}.complete-message.excellent{color:#059669}.complete-message.good{color:#d97706}.complete-message.normal{color:#6b7280}.review-session-desktop.dark .complete-message.excellent{color:#34d399}.review-session-desktop.dark .complete-message.good{color:#fbbf24}.review-session-desktop.dark .complete-message.normal{color:#fff9}.stats-grid{display:flex;gap:24px;margin-bottom:32px;animation:title-appear .6s ease-out .7s both}.complete-page .stat-card{background:#374151!important;border:1px solid #4b5563!important;border-radius:20px;padding:28px 48px;text-align:center;box-shadow:0 8px 25px #00000026}.complete-page .stat-card .stat-number{font-size:56px;font-weight:700;color:#fff!important;line-height:1;margin-bottom:8px}.complete-page .stat-card .stat-unit{font-size:32px;opacity:.7;color:#fff}.complete-page .stat-card .stat-label{font-size:14px;color:#fffc!important;text-transform:uppercase;letter-spacing:2px}.review-session-desktop.dark .complete-page .stat-card{background:#1e1e32cc!important;border:1px solid rgba(255,255,255,.15)!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.complete-page .accuracy-stat{min-width:200px}.accuracy-bar{margin-top:16px;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.accuracy-fill{height:100%;background:linear-gradient(90deg,#10b981,#34d399);border-radius:3px;transition:width 1s ease-out}.breakdown-cards{display:flex;gap:20px;margin-bottom:48px;animation:title-appear .6s ease-out .9s both}.breakdown-card{position:relative;padding:24px 40px;border-radius:16px;text-align:center;min-width:120px;overflow:hidden}.breakdown-card:before{content:"";position:absolute;inset:0;opacity:.15;border-radius:16px}.breakdown-card.know{background:#10b9811a;border:1px solid rgba(16,185,129,.3)}.breakdown-card.fuzzy{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3)}.breakdown-card.forget{background:#ef44441a;border:1px solid rgba(239,68,68,.3)}.breakdown-number{font-size:32px;font-weight:700;margin-bottom:4px}.breakdown-text{font-size:14px;opacity:.8;font-weight:500}.breakdown-icon{position:absolute;bottom:-10px;right:-10px;font-size:60px;opacity:.1;transform:rotate(-15deg)}.breakdown-card.know .breakdown-number{color:#059669}.breakdown-card.know .breakdown-text{color:#065f46}.breakdown-card.fuzzy .breakdown-number{color:#d97706}.breakdown-card.fuzzy .breakdown-text{color:#92400e}.breakdown-card.forget .breakdown-number{color:#dc2626}.breakdown-card.forget .breakdown-text{color:#991b1b}.review-session-desktop.dark .breakdown-card.know .breakdown-number{color:#34d399}.review-session-desktop.dark .breakdown-card.know .breakdown-text{color:#a7f3d0}.review-session-desktop.dark .breakdown-card.fuzzy .breakdown-number{color:#fbbf24}.review-session-desktop.dark .breakdown-card.fuzzy .breakdown-text{color:#fde68a}.review-session-desktop.dark .breakdown-card.forget .breakdown-number{color:#f87171}.review-session-desktop.dark .breakdown-card.forget .breakdown-text{color:#fecaca}.complete-actions{display:flex;gap:24px;animation:title-appear .6s ease-out 1.1s both}.action-btn-primary{padding:16px 48px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:14px;font-size:18px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 8px 20px #6366f14d}.action-btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 25px #6366f166}.action-btn-secondary{padding:16px 48px;background:transparent;border:2px solid var(--border-color);color:var(--text-secondary);border-radius:14px;font-size:18px;font-weight:600;cursor:pointer;transition:all .2s ease}.action-btn-secondary:hover{background:var(--info-bg);border-color:var(--accent-color);color:var(--accent-color)}@media(max-width:768px){.complete-page{padding:20px}.complete-title{font-size:32px}.stats-grid{flex-direction:column;width:100%}.complete-page .stat-card{padding:20px}.complete-page .stat-card .stat-number{font-size:40px}.breakdown-cards{flex-wrap:wrap;justify-content:center}.breakdown-card{flex:1;min-width:100px;padding:16px}.complete-actions{flex-direction:column;width:100%;gap:12px}.action-btn-primary,.action-btn-secondary{width:100%}}.review-card-wrapper{width:100%;height:100%;display:flex;justify-content:center;align-items:center;padding:20px}.word-card-commercial{width:100%;max-width:1200px;height:100%;max-height:72vh;background:var(--paper-color);border-radius:24px;box-shadow:0 20px 50px #00000014;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--border-color);position:relative}.word-card-commercial .word-header{padding:32px 48px;background:linear-gradient(180deg,var(--bg-color) 0%,var(--paper-color) 100%);border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:8px;flex-shrink:0}.word-card-commercial .word-title-row{display:flex;align-items:center;gap:16px}.word-card-commercial .word-text{font-size:48px;font-weight:800;color:var(--text-primary);letter-spacing:-1px;margin:0;line-height:1.1}.word-card-commercial .audio-btn{width:44px;height:44px;background:var(--accent-light);color:var(--accent-color);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:none}.word-card-commercial .audio-btn:hover{background:var(--accent-color);color:#fff;transform:scale(1.1);box-shadow:0 4px 12px #00000026}.word-card-commercial .phonetic-row{font-size:18px;color:var(--text-secondary);font-family:Segoe UI,sans-serif;opacity:.8}.card-scroll-content{flex:1;overflow-y:auto;padding:32px 48px}.info-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px}.info-left,.info-right{display:flex;flex-direction:column;gap:32px}.section-title{font-size:12px;font-weight:700;color:var(--accent-color);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:16px;opacity:.8}.meaning-text{font-size:24px;font-weight:700;color:var(--text-primary);line-height:1.5}.morpheme-list{display:flex;flex-direction:column;gap:10px}.morpheme-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-color);border-radius:10px;border:1px solid var(--border-color)}.morpheme-name{font-weight:600;color:var(--text-primary);font-size:15px}.morpheme-meaning{color:var(--text-secondary);font-size:14px}.example-item{padding:20px;background:var(--info-bg);border-radius:16px;border-left:4px solid var(--accent-color)}.example-item .en{font-size:18px;font-weight:500;color:var(--text-primary);margin-bottom:8px;line-height:1.5}.example-item .cn{font-size:15px;color:var(--text-secondary)}.empty-text{color:var(--text-secondary);font-style:italic;opacity:.6}.context-card{position:relative;padding:24px 32px;background:linear-gradient(135deg,var(--info-bg) 0%,var(--bg-color) 100%);border-radius:16px;border:1px solid var(--info-border)}.context-icon{position:absolute;top:16px;left:16px;font-size:48px;line-height:1;color:var(--accent-color);opacity:.1;font-family:serif}.context-text{font-size:16px;line-height:1.8;color:var(--text-primary);position:relative;z-index:1;font-family:Georgia,serif}@media(max-width:1024px){.info-grid{grid-template-columns:1fr;gap:32px}.word-card-commercial{max-height:none;height:auto}.review-card-wrapper{align-items:flex-start;overflow-y:auto}}.review-session-desktop.dark .desktop-header{background:var(--paper-color);border-bottom-color:var(--border-color)}.review-session-desktop.dark .mode-switch .mode-btn{background:transparent;border-color:var(--border-color);color:var(--text-secondary)}.review-session-desktop.dark .mode-switch .mode-btn:hover:not(.active){background:var(--accent-light);color:var(--accent-color)}.review-session-desktop.dark .mode-switch .mode-btn.active{background:var(--paper-color);border-color:var(--accent-color);color:var(--text-primary)}.review-session-desktop.dark .progress-container{background:transparent}.review-session-desktop.dark .progress-text{color:var(--text-secondary)}.review-session-desktop.dark .progress-bar-desktop{background:var(--border-color)}.review-session-desktop.dark .progress-fill{background:var(--accent-color)}.review-session-desktop.dark .desktop-main,.review-session-desktop.dark .card-left,.review-session-desktop.dark .card-right{background:var(--bg-color)}.review-session-desktop.dark .word-section{background:var(--paper-color);border-color:var(--border-color)}.review-session-desktop.dark .word-row,.review-session-desktop.dark .word-text{color:var(--text-primary)}.review-session-desktop.dark .example-section{background:var(--paper-color);border-color:var(--border-color)}.review-session-desktop.dark .example-text{color:var(--text-secondary)}.review-session-desktop.dark .translation-text{color:var(--text-primary)}.review-session-desktop.dark .spell-section{background:var(--paper-color);border-color:var(--border-color)}.review-session-desktop.dark .spell-input{background:var(--bg-color);border-color:var(--border-color);color:var(--text-primary)}.review-session-desktop.dark .spell-input:focus{border-color:var(--accent-color)}.review-session-desktop.dark .result-feedback{background:var(--paper-color);border-color:var(--border-color)}.review-session-desktop.dark .result-feedback.correct{border-color:var(--success-color);color:var(--success-color)}.review-session-desktop.dark .result-feedback.incorrect{border-color:var(--error-color);color:var(--error-color)}.review-session-desktop.dark .correct-answer{color:var(--success-color)}.review-session-desktop.dark .hint-box{background:var(--paper-color);border-color:var(--border-color);color:var(--text-secondary)}.review-session-desktop.dark .hint-label{color:var(--text-primary)}.review-session-desktop.dark .desktop-footer{background:var(--paper-color);border-top-color:var(--border-color)}.review-session-desktop.dark .footer-hint{color:var(--text-secondary)}.review-session-desktop.dark .action-btn{background:var(--paper-color);border-color:var(--border-color);color:var(--text-primary);font-weight:600}.review-session-desktop.dark .action-btn:hover:not(:disabled){box-shadow:0 8px 16px #0000004d;transform:translateY(-2px)}.review-session-desktop.dark .action-btn.forget{background:#3d1f1f;border-color:#f87171;color:#fecaca}.review-session-desktop.dark .action-btn.forget:hover:not(:disabled){background:#4a2626;border-color:#f87171;color:#fecaca;box-shadow:0 8px 16px #f8717133}.review-session-desktop.dark .action-btn.fuzzy{background:#3d3320;border-color:#fbbf24;color:#fef08a}.review-session-desktop.dark .action-btn.fuzzy:hover:not(:disabled){background:#4a4028;border-color:#fbbf24;color:#fef08a;box-shadow:0 8px 16px #fbbf2433}.review-session-desktop.dark .action-btn.know{background:#1f3a1f;border-color:#6ee7b7;color:#a7f3d0}.review-session-desktop.dark .action-btn.know:hover:not(:disabled){background:#274d27;border-color:#6ee7b7;color:#a7f3d0;box-shadow:0 8px 16px #6ee7b733}.review-session-desktop.dark .immersive-controls{background:var(--paper-color);border-color:var(--border-color)}.review-session-desktop.dark .mini-control{background:transparent;border-color:var(--border-color);color:var(--text-secondary)}.review-session-desktop.dark .mini-control:hover{background:var(--accent-light);border-color:var(--accent-color);color:var(--accent-color)}.review-session-desktop.dark .mini-progress{color:var(--text-secondary)}.review-session-desktop.dark .completion-message{color:var(--text-primary)}.review-session-desktop.dark .completion-stats{background:var(--paper-color);border-color:var(--border-color)}.review-session-desktop.dark .stat-item{color:var(--text-secondary)}.review-session-desktop.dark .stat-value{color:var(--text-primary)}.review-session-desktop.dark .action-buttons{background:transparent}.review-session-desktop.dark .card-left{background:var(--paper-color);border-color:var(--border-color)}.review-session-desktop.dark .word-section{border-bottom-color:var(--border-color)}.review-session-desktop.dark .example-section{background:var(--info-bg);border-left-color:var(--accent-color)}.review-session-desktop.dark .example-en{color:var(--text-primary)}.review-session-desktop.dark .example-zh{color:var(--text-secondary)}.review-session-desktop.dark .morpheme-section{background:var(--info-bg);border-color:var(--info-border)}.review-session-desktop.dark .morpheme-item{background:var(--bg-color)}.review-session-desktop.dark .morpheme-name{color:var(--text-primary)}.review-session-desktop.dark .info-section{background:var(--info-bg);border-color:var(--info-border)}.review-session-desktop.dark .info-content{color:var(--text-primary)}.review-session-desktop.dark .spell-input{background:var(--paper-color);border-color:var(--border-color);color:var(--text-primary)}.review-session-desktop.dark .spell-input::-moz-placeholder{color:var(--text-secondary)}.review-session-desktop.dark .spell-input::placeholder{color:var(--text-secondary)}.review-session-desktop.dark .spell-input:focus{border-color:var(--accent-color);background:var(--info-bg);box-shadow:0 0 0 3px var(--accent-light)}.review-session-desktop.dark .spell-input.correct{border-color:#10b981;background:var(--bg-color);color:#86efac}.review-session-desktop.dark .spell-input.incorrect{border-color:#f87171;background:var(--bg-color);color:#fecaca}.review-session-desktop.dark .check-btn{background:var(--accent-color);color:#fff}.review-session-desktop.dark .check-btn:hover{box-shadow:0 8px 20px #ec48994d}.review-session-desktop.dark .hint-word-small{color:var(--accent-color)}.review-session-desktop.dark .hint-prompt,.review-session-desktop.dark .placeholder-text{color:var(--text-secondary)}.review-session-desktop.dark .audio-section-spell{background:var(--info-bg);border-color:var(--info-border)}.review-session-desktop.dark .prompt-phonetic{color:var(--text-secondary)}.review-session-desktop.dark .audio-btn-spell{background:var(--accent-light);border-color:var(--accent-color);color:var(--accent-color)}.review-session-desktop.dark .audio-btn-spell:hover{background:var(--accent-color);color:#fff}.review-session-desktop.dark .hint-box{background:var(--accent-light);border-color:var(--accent-color)}.review-session-desktop.dark .hint-label,.review-session-desktop.dark .hint-word{color:var(--accent-color)}.review-session-desktop.dark .hint-toggle{background:var(--border-color);color:var(--text-secondary)}.review-session-desktop.dark .hint-toggle:hover{background:var(--accent-light);color:var(--accent-color)}.review-session-desktop.dark .result-badge{font-weight:600}.review-session-desktop.dark .result-badge.correct{background:var(--bg-color);color:#10b981;border-color:#10b981}.review-session-desktop.dark .result-badge.incorrect{background:var(--bg-color);color:#f59e0b;border-color:#f59e0b}.review-session-desktop.dark .correct-answer{color:var(--text-secondary)}.review-session-desktop.dark .correct-answer strong{color:var(--text-primary)}.review-session-desktop.dark .spell-full-info{background:var(--info-bg);border-color:var(--info-border)}.review-session-desktop.dark .spell-full-info .info-label{color:var(--text-secondary)}.review-session-desktop.dark .spell-full-info .info-value{color:var(--text-primary)}.review-session-desktop.dark .spell-full-info .morpheme-tag{background:var(--accent-light);color:var(--accent-color)}.review-session-desktop.dark .section-header span{color:var(--text-secondary)}.review-session-desktop.dark .meaning-content{color:var(--text-primary)}.review-session-desktop.dark .morpheme-meaning,.review-session-desktop.dark .morpheme-empty{color:var(--text-secondary)}.review-session-desktop.dark .prompt-meaning-large{color:var(--text-primary)}.review-session-desktop.dark .phonetic-text{color:var(--text-secondary)}.review-session-desktop.dark .audio-btn-small{background:var(--accent-light);border-color:var(--accent-color);color:var(--accent-color)}.review-session-desktop.dark .audio-btn-small:hover{background:var(--accent-color);color:#fff}.review-session-desktop.dark .spell-input-new{background:var(--paper-color);border-color:var(--border-color);color:var(--text-primary)}.review-session-desktop.dark .spell-input-new:focus{border-color:var(--accent-color);background:var(--info-bg);box-shadow:0 0 0 3px var(--accent-light)}.review-session-desktop.dark .spell-input-new.correct{border-color:#10b981;background:var(--bg-color);color:#86efac}.review-session-desktop.dark .spell-input-new.incorrect{border-color:#f87171;background:var(--bg-color);color:#fecaca}.review-session-desktop.dark .action-item>.btn-desc{color:var(--text-secondary)}.review-session-desktop.dark .btn-key{opacity:.8;color:var(--text-secondary)}.review-session-desktop.dark .close-btn{background:transparent;border-color:var(--border-color);color:var(--text-primary)}.review-session-desktop.dark .close-btn:hover,.review-session-desktop.dark .close-btn:focus,.review-session-desktop.dark .close-btn:focus-visible{background:var(--bg-color);border-color:var(--text-primary);color:var(--text-primary)}.vocabulary-page{width:100%;height:100%;background:var(--bg-color, #f9f8f6);overflow-y:auto;animation:fadeIn .3s ease}[data-theme=dark] .vocabulary-page{background:var(--bg-color, #111827)}.vocabulary-header{display:none}[data-theme=dark] .vocabulary-header{background:#1f2937}.vocabulary-header h1{flex:1;font-size:20px;font-weight:700;color:var(--text-primary, #1a1a1a);margin:0;display:flex;align-items:center;gap:8px}.page-title-icon{width:24px;height:24px;-o-object-fit:contain;object-fit:contain}.back-btn{width:36px;height:36px;min-width:36px;max-width:36px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .15s ease;flex-shrink:0}.back-btn:hover{background:#e5e7eb;border-color:#d1d5db}.back-btn svg{width:18px;height:18px;flex-shrink:0}.back-btn svg path{stroke:#6b7280;stroke-width:2.5}.start-review-btn{padding:10px 20px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #f59e0b4d;transition:all .2s ease}.start-review-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b66}.stats-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:32px}.stat-card{background:var(--paper-color, #ffffff);border-radius:16px;padding:16px;text-align:center;box-shadow:0 2px 8px #0000000d}[data-theme=dark] .stat-card{background:#1f2937}.stat-value{font-size:36px!important;font-weight:700!important;margin-bottom:4px;line-height:1.2}.stat-label{font-size:13px;color:#4b5563;font-weight:500;margin-top:4px}[data-theme=dark] .stat-label{color:#9ca3af}.stat-card.total .stat-value{color:#3b82f6}.stat-card.review .stat-value{color:#f59e0b}.stat-card.learning .stat-value{color:#8b5cf6}.stat-card.mastered .stat-value{color:#22c55e}.vocabulary-tabs{display:flex;justify-content:space-between;align-items:center;padding:0 32px;margin-bottom:16px}.tabs-left{display:flex;gap:8px}.tab-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;background:transparent;border:1px solid var(--border-color, #e5e7eb);border-radius:20px;font-size:14px;font-weight:500;color:var(--text-secondary, #666);cursor:pointer;transition:all .15s ease}.tab-icon{width:16px;height:16px}.tab-btn.active .tab-icon{filter:brightness(0) invert(1)}.tab-btn:hover{background:var(--bg-hover, #f3f4f6)}.tab-btn.active{background:var(--accent-color, #3b82f6);border-color:var(--accent-color, #3b82f6);color:#fff}.start-review-btn{padding:10px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #3b82f64d;transition:all .2s ease;display:flex;align-items:center;gap:6px}.start-review-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.start-review-btn:before{content:"▶";font-size:12px}.search-box{position:relative;padding:0 32px;margin-bottom:16px}.search-box input{width:100%;padding:12px 16px 12px 44px;border:1px solid var(--border-color, #e5e7eb);border-radius:12px;font-size:14px;background:var(--paper-color, #ffffff);color:var(--text-primary, #1a1a1a);transition:all .15s ease}.search-box input:focus{outline:none;border-color:var(--accent-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.search-icon{position:absolute;left:46px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--text-secondary, #999)}[data-theme=dark] .search-box input{background:#1f2937;border-color:#ffffff1a}.vocabulary-list{padding:0 32px 100px}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:20px;padding:24px 0;margin-top:12px;border-top:1px solid var(--border-color)}.page-btn{padding:8px 20px;background:var(--paper-color);border:1px solid var(--border-color);border-radius:10px;font-size:14px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.page-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent-color);color:var(--accent-color)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-info{font-size:14px;color:var(--text-secondary);font-weight:500}.vocabulary-item{display:flex;align-items:center;gap:16px;padding:16px;background:var(--paper-color, #ffffff);border-radius:16px;margin-bottom:12px;box-shadow:0 2px 8px #0000000d;transition:all .15s ease}.vocabulary-item:hover{box-shadow:0 4px 12px #0000001a}[data-theme=dark] .vocabulary-item{background:#1f2937}.vocab-main{flex:1;min-width:0}.vocab-content{display:flex;align-items:baseline;gap:10px;margin-bottom:6px}.vocab-text{font-size:18px;font-weight:600;color:var(--text-primary, #1a1a1a)}.vocab-phonetic{font-size:14px;color:var(--text-secondary, #888);font-family:monospace}.vocab-meaning{font-size:14px;color:var(--text-secondary, #666);margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vocab-meta{display:flex;align-items:center;gap:12px}.vocab-type{font-size:12px;padding:3px 8px;border-radius:6px;font-weight:500}.vocab-type.type-word{background:#3b82f61a;color:#3b82f6}.vocab-type.type-phrase{background:#8b5cf61a;color:#8b5cf6}.vocab-type.type-sentence{background:#22c55e1a;color:#22c55e}.vocab-mastery{display:flex;align-items:center;gap:8px}.mastery-bar{width:50px;height:5px;background:var(--bg-secondary, #e5e7eb);border-radius:3px;overflow:hidden}.mastery-fill{height:100%;border-radius:3px;transition:width .3s ease}.mastery-bar.level-0 .mastery-fill{background:#d1d5db}.mastery-bar.level-1 .mastery-fill{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.mastery-bar.level-2 .mastery-fill{background:linear-gradient(90deg,#34d399,#10b981)}.mastery-bar.level-3 .mastery-fill{background:linear-gradient(90deg,#60a5fa,#3b82f6)}.mastery-bar.level-4 .mastery-fill{background:linear-gradient(90deg,#a78bfa,#8b5cf6)}.mastery-text{font-size:11px;color:var(--text-secondary, #888);white-space:nowrap}.vocab-actions{display:flex;gap:8px}.star-btn,.delete-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:10px;cursor:pointer;transition:all .15s ease}.action-icon{width:20px;height:20px;transition:all .15s ease}.star-btn .action-icon{opacity:.5;transition:all .15s ease}.star-btn:hover{background:#f59e0b1a}.star-btn:hover .action-icon{opacity:.8}.star-btn.starred .action-icon{opacity:1}.star-btn.starred:hover{background:#f59e0b26}.delete-btn .action-icon{opacity:.5}.delete-btn:hover{background:#ef44441a}.delete-btn:hover .action-icon{opacity:1}.empty-state,.loading-state{text-align:center;padding:60px 20px;color:var(--text-secondary, #888)}.empty-icon{font-size:48px;margin-bottom:16px}.empty-text{font-size:18px;font-weight:600;color:var(--text-primary, #1a1a1a);margin-bottom:8px}.empty-hint{font-size:14px;color:var(--text-secondary, #888)}.review-card-container{display:flex;flex-direction:column;align-items:center;padding:40px 24px;min-height:60vh}.review-card{width:100%;max-width:500px;min-height:300px;background:var(--paper-color, #ffffff);border-radius:24px;box-shadow:0 10px 40px #0000001a;padding:40px 32px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}[data-theme=dark] .review-card{background:#1f2937}.card-front,.card-back{width:100%}.card-type{font-size:12px;padding:4px 12px;background:#3b82f61a;color:#3b82f6;border-radius:20px;display:inline-block;margin-bottom:20px}.card-content{font-size:32px;font-weight:700;color:var(--text-primary, #1a1a1a);margin-bottom:12px;word-break:break-word}.card-phonetic{font-size:18px;color:var(--text-secondary, #888);font-family:monospace;margin-bottom:24px}.show-answer-btn{padding:14px 32px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #3b82f64d;transition:all .2s ease}.show-answer-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.card-meaning{font-size:24px;font-weight:600;color:#22c55e;margin-bottom:20px}.card-example,.card-context{font-size:14px;color:var(--text-secondary, #666);padding:12px 16px;background:var(--bg-secondary, #f9fafb);border-radius:12px;margin-top:12px;text-align:left}.example-label,.context-label{font-weight:600;color:var(--text-primary, #1a1a1a)}[data-theme=dark] .card-example,[data-theme=dark] .card-context{background:#ffffff0d}.review-actions{display:flex;gap:10px;margin-top:32px;flex-wrap:wrap;justify-content:center}.review-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px;min-width:64px;border:none;border-radius:14px;cursor:pointer;transition:all .15s ease}.review-btn:disabled{opacity:.6;cursor:not-allowed}.btn-emoji{font-size:24px}.btn-text{font-size:12px;font-weight:600}.review-btn.forget{background:#fef2f2;color:#dc2626}.review-btn.hard{background:#fff7ed;color:#ea580c}.review-btn.normal{background:#fffbeb;color:#d97706}.review-btn.easy{background:#f0fdf4;color:#16a34a}.review-btn.perfect{background:#ecfdf5;color:#059669}.review-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 4px 12px #00000026}[data-theme=dark] .review-btn.forget{background:#dc262626}[data-theme=dark] .review-btn.hard{background:#ea580c26}[data-theme=dark] .review-btn.normal{background:#d9770626}[data-theme=dark] .review-btn.easy{background:#16a34a26}[data-theme=dark] .review-btn.perfect{background:#05966926}.review-progress-bar{position:fixed;bottom:0;left:0;right:0;height:6px;background:var(--bg-secondary, #e5e7eb)}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#22c55e);transition:width .3s ease}.review-progress-text{font-size:14px;font-weight:600;color:var(--text-secondary, #666)}@media(max-width:768px){.stats-cards{grid-template-columns:repeat(2,1fr)}.vocabulary-tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.tab-btn{flex-shrink:0}.review-actions{gap:8px}.review-btn{padding:10px 12px;min-width:56px}.btn-emoji{font-size:20px}.card-content{font-size:24px}}.wordbook-reader{--bg-color: #F5F5F5;--paper-color: #FFFFFF;--text-primary: #1A1A1A;--text-secondary: #565656;--accent-color: #d946ef;--accent-light: #fef3ff;--border-color: #E8E8E8;--success-color: #059669;--error-color: #dc2626;--info-bg: #f8f9ff;--info-border: #d4d7ff;position:fixed;inset:0;width:100%;height:100vh;background:var(--bg-color);display:flex;flex-direction:column;z-index:200;color:var(--text-primary)}.wordbook-reader.dark{--bg-color: #0f172a;--paper-color: #1a2542;--text-primary: #e5e7eb;--text-secondary: #9ca3af;--accent-color: #ec4899;--accent-light: #3b1b5c;--border-color: #334155;--success-color: #10b981;--error-color: #f87171;--info-bg: #1a2e4d;--info-border: #2a4a7d;background:var(--bg-color)}.desktop-header{display:flex;align-items:center;justify-content:space-between;padding:16px 40px;background:var(--paper-color);border-bottom:1px solid var(--border-color);flex-shrink:0;transition:all .3s ease;gap:20px}.desktop-header.hidden{transform:translateY(-100%);opacity:0;pointer-events:none;position:absolute}.header-left{flex:1;display:flex;align-items:center}.header-center{flex:2;display:flex;justify-content:center}.header-right{flex:1;display:flex;justify-content:flex-end}.book-name{font-size:18px;font-weight:700;color:var(--text-primary);white-space:nowrap}.progress-container-header{display:flex;align-items:center;gap:16px;width:100%;max-width:600px}.progress-bar-desktop{flex:1;height:8px;background:var(--border-color);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#d946ef);border-radius:4px;transition:width .4s ease;box-shadow:0 0 8px #d946ef66}.progress-text{color:var(--text-secondary);font-size:14px;font-weight:600;font-family:SF Mono,Consolas,monospace;min-width:30px;text-align:right}.progress-text.total{text-align:left;color:var(--text-secondary);opacity:.7}.header-controls{display:flex;align-items:center;gap:12px}.control-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-color);border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.control-btn:hover,.control-btn.active{background:var(--accent-light);border-color:var(--accent-color);color:var(--accent-color)}.wordbook-reader.immersive .reader-content{padding-top:20px}.immersive-controls{position:fixed;top:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--paper-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:20px;z-index:101;opacity:.8;transition:opacity .2s ease;box-shadow:0 4px 12px #00000026}.immersive-controls:hover{opacity:1}.mini-control{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.mini-control:hover{background:var(--accent-light);border-color:var(--accent-color);color:var(--accent-color)}.mini-progress{font-size:13px;color:var(--text-secondary);font-weight:500}.reader-header,.progress-info-inline{display:none}.reader-content{flex:0 0 auto;padding:10px 32px 0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;background:var(--bg-color);min-height:0;width:100%}.word-card{width:100%;max-width:1200px;height:76vh;background-color:var(--paper-color);background:#fff;border-radius:24px;padding:0;box-shadow:0 15px 45px #00000014;display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(0,0,0,.06);position:relative;z-index:1}[data-theme=dark] .word-card{background:var(--paper-color)}.card-scroll-area{flex:1;overflow-y:auto;padding:24px 40px;display:flex;flex-direction:column;gap:24px}.word-header{display:flex;flex-direction:column;align-items:flex-start;padding:20px 40px;background:linear-gradient(135deg,#ffffff 0%,var(--bg-color) 100%);border-bottom:1px solid var(--border-color);position:relative}.card-shortcut-container{position:absolute;top:20px;right:40px;z-index:10}.shortcut-icon-btn{width:28px;height:28px;border-radius:50%;background:transparent;border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text-secondary)}.shortcut-icon-btn:hover{background:var(--bg-color);border-color:var(--accent-color);color:var(--accent-color);transform:scale(1.1)}.shortcut-icon-btn.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.icon-text{font-size:14px;font-weight:700;font-family:Times New Roman,serif;font-style:italic;line-height:1}.shortcut-popup-card{position:absolute;top:100%;right:0;margin-top:8px;background:var(--paper-color);border:1px solid var(--border-color);border-radius:12px;padding:14px;width:180px;box-shadow:0 10px 30px #0000001f;opacity:0;pointer-events:none;transition:all .2s ease;transform-origin:top right;transform:scale(.95);z-index:100}[data-theme=dark] .shortcut-popup-card{background:var(--paper-color)}.shortcut-popup-card.visible{opacity:1;pointer-events:auto;transform:scale(1)}.popup-title{font-size:12px;font-weight:700;color:var(--text-primary);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border-color)}.shortcut-list{display:flex;flex-direction:column;gap:6px}.shortcut-row{display:flex;align-items:center;justify-content:space-between}.key-label{font-family:SF Mono,Consolas,monospace;font-size:10px;font-weight:600;color:var(--accent-color);background:var(--accent-light);padding:2px 5px;border-radius:4px}.key-desc{font-size:11px;color:var(--text-secondary)}[data-theme=dark] .word-header{background:linear-gradient(135deg,var(--paper-color) 0%,var(--bg-color) 100%)}.word-title-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}.word-text{font-size:36px;font-weight:800;margin:0;color:var(--text-primary);letter-spacing:-1px}.audio-btn{background:transparent!important;border:none!important;cursor:pointer;padding:4px!important;margin:0!important;display:flex;align-items:center;justify-content:center;border-radius:50%!important;transition:all .2s ease;color:var(--accent-color);width:32px;height:32px}.audio-btn:hover{background:rgba(var(--accent-color-rgb, 37, 99, 235),.1)!important;transform:scale(1.1)}.audio-btn svg{width:20px;height:20px}.phonetic-row{display:flex;align-items:center;gap:8px;font-size:16px;color:var(--text-secondary);opacity:.8}.main-content-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:32px}.section-title{font-size:11px;font-weight:700;color:var(--accent-color);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px;display:flex;align-items:center;gap:10px;opacity:.7}.meaning-text{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:12px;line-height:1.4}.analysis-box{font-size:14px;color:var(--text-secondary);line-height:1.6;background:#00000005;padding:16px;border-radius:12px;border:1px solid rgba(0,0,0,.02)}.example-list{display:flex;flex-direction:column;gap:16px}.example-item{padding:12px 16px;background:#2563eb05;border-left:3px solid var(--accent-color);border-radius:4px 12px 12px 4px;transition:all .2s ease}.example-item:hover{background:#2563eb0a}.example-item .en{font-size:15px;font-weight:500;margin-bottom:4px;line-height:1.4}.example-item .cn{font-size:13px;color:var(--text-secondary)}.phrases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;background:transparent;padding:0}.phrase-item{background:rgba(var(--accent-color-rgb, 37, 99, 235),.04);padding:8px 12px;border-radius:8px;border:1px solid rgba(var(--accent-color-rgb, 37, 99, 235),.05);transition:all .2s ease}.phrase-item:hover{background:rgba(var(--accent-color-rgb, 37, 99, 235),.08);transform:translateY(-1px)}.p-en{font-size:13px;font-weight:700;display:block;margin-bottom:1px;color:var(--text-primary)}.p-cn{font-size:11px;color:var(--text-secondary);opacity:.8}.reader-footer{flex:1;padding:0 32px;background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0}.action-buttons-wordbook{display:flex;gap:20px;justify-content:center;width:100%;max-width:640px}.action-btn-wordbook{flex:1;max-width:150px;padding:10px 18px;border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 12px #0000001a;position:relative}.action-btn-wordbook:hover:not(:disabled){transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.btn-label{font-weight:700;font-size:15px;letter-spacing:.5px}.action-btn-wordbook:after{content:attr(data-key);font-size:20px;font-weight:400;opacity:.8;color:inherit;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;margin-left:8px;line-height:1;font-variant-emoji:text}.action-btn-wordbook:active:not(:disabled){transform:translateY(-2px)}.action-btn-wordbook:disabled{opacity:.6;cursor:not-allowed}.action-btn-wordbook.vibrating{animation:vibrate .4s ease-out}@keyframes vibrate{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.action-btn-wordbook.forget{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.action-btn-wordbook.forget:hover:not(:disabled){box-shadow:0 12px 24px #ef44444d}.action-btn-wordbook.fuzzy{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.action-btn-wordbook.fuzzy:hover:not(:disabled){box-shadow:0 12px 24px #f59e0b4d}.action-btn-wordbook.know{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.action-btn-wordbook.know:hover:not(:disabled){box-shadow:0 12px 24px #10b9814d}.btn-desc,.keyboard-shortcuts-wordbook{display:none}@media(max-width:768px){.reader-header{padding:12px 20px}.reader-content{padding:20px}.word-card{padding:24px}.grid-sections{grid-template-columns:1fr}.word-text{font-size:36px}.reader-footer{padding:16px 20px}.action-buttons-wordbook{gap:12px}.action-btn-wordbook{padding:10px 20px;font-size:13px;min-width:100px}.keyboard-shortcuts-wordbook{font-size:11px;gap:8px}}.memory-tips-list{display:flex;flex-direction:column;gap:12px}.memory-tip-item{font-size:15px;line-height:1.6;color:var(--text-primary);background:#00000005;padding:12px;border-radius:8px;border-left:3px solid var(--accent-color)}.memory-tip-title{font-weight:700;color:var(--accent-color);margin-right:8px;display:inline-block}.memory-tip-content{color:var(--text-secondary)}.order-btn{position:relative}.order-btn.random{background:linear-gradient(135deg,#8b5cf626,#ec489926);border-color:#8b5cf6;color:#8b5cf6}.order-btn.random:hover{background:linear-gradient(135deg,#8b5cf640,#ec489940)}.order-btn:disabled{opacity:.6;cursor:not-allowed}.order-btn .spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.points-animation-wordbook{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;gap:8px;z-index:9999;animation:points-float-up-wordbook 2s ease-out forwards;pointer-events:none}@keyframes points-float-up-wordbook{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}30%{transform:translate(-50%,-50%) scale(1)}70%{opacity:1;transform:translate(-50%,-80%) scale(1)}to{opacity:0;transform:translate(-50%,-120%) scale(.8)}}.points-animation-wordbook .points-badge{font-size:48px;font-weight:700;color:#f59e0b;text-shadow:0 2px 10px rgba(245,158,11,.5),0 4px 20px rgba(245,158,11,.3);font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,sans-serif}.points-animation-wordbook .points-icon{font-size:40px;animation:points-icon-bounce-wordbook .5s ease-out}@keyframes points-icon-bounce-wordbook{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.main-content-grid.single-col{grid-template-columns:1fr;display:flex;flex-direction:column}.main-content-grid.single-col .left-col{width:100%}.main-content-grid.single-col .meaning-text{font-size:24px;margin-bottom:20px}.analysis-tags{display:flex;flex-direction:column;gap:8px;margin-top:16px;background:#00000005;padding:16px;border-radius:12px}.analysis-tag-item{display:flex;align-items:flex-start;line-height:1.5}.pos-tag{font-size:12px;font-weight:700;color:var(--accent-color);background:rgba(var(--accent-color-rgb, 217, 70, 239),.1);padding:2px 6px;border-radius:4px;margin-right:10px;font-family:SF Mono,Consolas,monospace;min-width:32px;text-align:center;margin-top:2px}.cn-text{font-size:15px;color:var(--text-secondary);flex:1}.wordbook-page{width:100%;height:100%;background:var(--bg-color);display:flex;flex-direction:column;animation:fadeIn .3s ease-out;overflow-y:auto}.wordbook-header{padding:16px 32px;background:transparent;border-bottom:none;display:flex;justify-content:flex-start;box-shadow:none}.header-container{width:100%;max-width:1200px;display:flex;flex-direction:row;align-items:center;gap:20px;margin:0;padding-left:0}.header-left-section{display:flex;align-items:center;gap:16px;flex:1}.header-title-group{display:flex;flex-direction:row;align-items:baseline;gap:16px;flex:1}.back-btn{padding:10px;margin:0;background:transparent;border:none;cursor:pointer;color:var(--text-primary);display:flex;align-items:center;justify-content:center;border-radius:10px;transition:all .2s ease;flex-shrink:0}.back-btn:hover{background:var(--hover-bg);color:var(--accent-color);transform:translate(-2px)}.back-btn svg{width:22px;height:22px}.wordbook-header h1{font-size:28px;font-weight:800;margin:0;color:var(--text-primary);letter-spacing:-.5px;white-space:nowrap;line-height:1.2;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;position:relative;display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#1a1a2e,#2d2d44,#1a1a2e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 8px rgba(139,92,246,.1)}.wordbook-header h1:before{content:"📚";font-size:22px;opacity:.9;filter:drop-shadow(0 2px 4px rgba(139,92,246,.2));-webkit-background-clip:initial;-webkit-text-fill-color:initial;background:none;display:inline-block;transform:translateY(-1px)}.wordbook-header h1:after{content:"";position:absolute;left:0;bottom:-6px;width:60px;height:3px;background:linear-gradient(90deg,#8b5cf6 0%,#a855f7 50%,transparent 100%);border-radius:2px;opacity:.6}.header-subtitle{color:var(--text-secondary);margin:0;font-size:15px;opacity:.85;white-space:nowrap;display:flex;align-items:center;gap:8px;font-weight:500;letter-spacing:.3px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;position:relative;padding-left:4px}.header-subtitle:before{content:"✨";font-size:16px;opacity:.7;filter:drop-shadow(0 1px 2px rgba(139,92,246,.2))}.header-subtitle:after{content:"";position:absolute;left:28px;bottom:-2px;width:120px;height:2px;background:linear-gradient(90deg,rgba(139,92,246,.4) 0%,rgba(168,85,247,.2) 50%,transparent 100%);border-radius:1px;opacity:.5}.category-tabs{display:flex;gap:8px}.cat-tab{padding:6px 16px;border-radius:10px;background:var(--bg-color);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;border:1px solid var(--border-color)}.cat-tab:hover{color:var(--accent-color);background:var(--accent-light)}.cat-tab.active{background:var(--accent-color);color:#fff}.wordbook-content{flex:1;padding:32px;background:transparent;display:flex;flex-direction:column;align-items:flex-start}.category-section{max-width:1200px;margin:0 0 40px;padding:0}.category-tabs-horizontal{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.cat-tab-h{padding:10px 22px;border-radius:24px;background:var(--paper-color);color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);border:1px solid var(--border-color);white-space:nowrap;box-shadow:0 1px 2px #00000008;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;letter-spacing:.2px}.cat-tab-h:hover{color:var(--accent-color);border-color:var(--accent-color);background:#2563eb0d;transform:translateY(-1px)}.cat-tab-h.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 2px 8px #2563eb33}.cat-tab-h.active:hover{background:var(--accent-color);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}[data-theme=dark] .cat-tab-h{border-color:#ffffff1a;color:var(--text-secondary)}[data-theme=dark] .cat-tab-h:hover{border-color:var(--accent-color);background:#2563eb1a}[data-theme=dark] .cat-tab-h.active{background:var(--accent-color);border-color:var(--accent-color)}.wordbook-grid-modern{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;width:100%;max-width:1600px;margin:0 auto;padding:0}@media(max-width:768px){.wordbook-grid-modern{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}}.wordbook-card-modern{background:var(--paper-color);border-radius:20px;overflow:hidden;box-shadow:0 1px 8px #0000000f,0 0 0 .5px #00000005;transition:all .35s cubic-bezier(.4,0,.2,1);cursor:pointer;border:.5px solid rgba(0,0,0,.06);display:flex;flex-direction:column;position:relative;animation:fadeInUp .6s ease-out calc(var(--card-index, 0) * .08s) both;height:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.wordbook-card-modern:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 12px 32px #2563eb26,0 0 0 .5px #2563eb14;border-color:#2563eb33}.card-bg-gradient{position:absolute;top:0;left:0;right:0;height:120px;background:linear-gradient(135deg,#2563eb1a,#8b5cf61a);opacity:0;transition:opacity .3s ease}.wordbook-card-modern:hover .card-bg-gradient{opacity:1}.card-badges{position:absolute;top:16px;left:16px;right:16px;display:flex;gap:8px;z-index:2}.badge{padding:5px 12px;border-radius:12px;font-size:11px;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-flex;align-items:center;gap:4px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;letter-spacing:.2px}.badge-hot{background:#ef4444e6;color:#fff}.badge-words{background:#ffffffe6;color:var(--text-primary);border:1px solid rgba(0,0,0,.1)}.book-cover-modern{position:relative;aspect-ratio:310 / 420;background:linear-gradient(135deg,#f0f4ff,#e0e7ff);overflow:hidden;margin:20px;border-radius:16px;box-shadow:0 4px 12px #00000014}.cover-image-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.cover-image-wrapper img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1)}.wordbook-card-modern:hover .cover-image-wrapper img{transform:scale(1.05)}.card-info-modern{padding:0 24px 24px;display:flex;flex-direction:column;gap:16px;position:relative;z-index:1;flex:1}.book-title-modern{margin:0;font-size:20px;font-weight:700;color:var(--text-primary);line-height:1.5;min-height:60px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;letter-spacing:-.3px}.stats-modern{display:flex;gap:20px;align-items:center;flex-wrap:wrap}.stat-modern{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);font-weight:500;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;letter-spacing:.1px}.stat-icon-img{width:16px;height:16px;-o-object-fit:contain;object-fit:contain;opacity:.85}.stat-text{font-weight:500;opacity:.9}.cta-button{width:100%;padding:13px 24px;background:linear-gradient(135deg,var(--accent-color) 0%,#2563eb 100%);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .25s cubic-bezier(.4,0,.2,1);margin-top:8px;box-shadow:0 2px 8px #2563eb33;letter-spacing:.5px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}.cta-button:hover{background:linear-gradient(135deg,#2563eb 0%,var(--accent-color) 100%);transform:translateY(-2px);box-shadow:0 6px 20px #2563eb59}.cta-button:active{transform:translateY(0);box-shadow:0 2px 8px #2563eb40}.cta-button svg{width:18px;height:18px;transition:transform .25s ease}.cta-button:hover svg{transform:translate(2px)}.wordbook-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:32px;max-width:1200px;margin:0 auto}.wordbook-card-vertical{background:var(--paper-color);border-radius:16px;overflow:hidden;box-shadow:0 4px 15px #0000000d;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;border:1px solid var(--border-color);display:flex;flex-direction:column;position:relative}.wordbook-card-vertical:hover{transform:translateY(-10px);box-shadow:0 20px 40px #0000001f;border-color:var(--accent-color)}.book-cover-vertical{position:relative;aspect-ratio:3/4.2;background:#fff;overflow:hidden}.book-cover-vertical>img{width:100%;height:100%;-o-object-fit:fill;object-fit:fill;transition:transform .6s cubic-bezier(.4,0,.2,1);display:block}.wordbook-card-vertical:hover .book-cover-vertical>img{transform:scale(1.08)}.book-hotness{position:absolute;top:12px;right:12px;background:#00000080;color:#fff;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;gap:4px;z-index:2}.hot-icon{width:14px!important;height:14px!important}.book-info-vertical{padding:20px;display:flex;flex-direction:column;gap:12px;background:var(--paper-color)}.book-name{margin:0;font-size:18px;font-weight:800;color:var(--text-primary);line-height:1.3}.book-stats-row{display:flex;align-items:center;gap:16px}.stat-item{display:flex;flex-direction:column;gap:2px}.stat-value{font-size:15px;font-weight:800;color:var(--accent-color)}.stat-label{font-size:11px;color:var(--text-secondary);font-weight:600;opacity:.7}.stat-divider{width:1px;height:24px;background:var(--border-color)}@media(max-width:768px){.wordbook-header{padding:20px 16px}.wordbook-header h1{font-size:24px}.header-subtitle{font-size:13px}.wordbook-content{padding:24px 16px}.category-section{margin-bottom:24px;padding:0 16px}.category-tabs-horizontal{gap:8px}.cat-tab-h{padding:8px 16px;font-size:13px}.wordbook-grid-modern{gap:16px;padding:0 16px}.book-title-modern{font-size:18px;min-height:auto}.stats-modern{gap:12px}.stat-modern{font-size:12px}.cta-button{padding:12px 20px;font-size:14px}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:var(--text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.wordbook-header,.wordbook-content{padding:20px}.wordbook-grid{gap:20px}}.year-report-overlay{position:fixed;inset:0;background-color:#000000eb;display:flex;justify-content:center;align-items:center;z-index:2000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:fadeIn .5s ease-out;padding:20px}.year-report-wrapper{display:flex;flex-direction:column;align-items:center;gap:20px;max-width:100%}.year-report-container{position:relative;width:90vw;max-width:440px;background:transparent;border-radius:20px;overflow:hidden;box-shadow:0 0 50px #00c8ff26;animation:slideUp .6s cubic-bezier(.2,.8,.2,1);transform:translateZ(0)}.year-report-close{display:none}.year-report-content{position:relative;width:100%;line-height:0}.year-report-bg{width:100%;height:auto;display:block}.year-report-loading{padding:80px;text-align:center;color:#0ff;font-size:1.2rem;letter-spacing:2px;text-shadow:0 0 10px rgba(0,255,255,.5)}.report-grid-area{position:absolute;top:20%;left:6%;right:6%;height:45%}.report-item{position:absolute;display:flex;flex-direction:column;justify-content:center;padding:10px 14px;border-radius:12px;background:linear-gradient(135deg,#ffffff0d,#0003);border:1px solid rgba(0,255,255,.15);box-shadow:0 4px 15px #0000004d,inset 0 0 20px #00ffff0d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:transform .3s ease}.report-label{font-size:.8rem;color:#fff9;margin-bottom:10px;text-transform:uppercase;letter-spacing:1px}.report-value{font-family:DIN Alternate,Roboto Mono,monospace;font-size:1.5rem;font-weight:700;line-height:1;filter:drop-shadow(0 0 8px rgba(0,0,0,.5))}.unit{font-size:.75rem;margin-left:3px;opacity:.7;font-weight:400}.item-articles{top:0;left:50%;transform:translate(-50%);width:160px;height:90px;align-items:center;text-align:center;background:linear-gradient(180deg,#00ffff1a,#0064c833);border-color:#00ffff4d;box-shadow:0 0 30px #00ffff26 inset;z-index:2}.text-cyan{color:#fff;font-size:2.8rem;text-shadow:0 0 10px rgba(0,255,255,.8),0 0 20px rgba(0,255,255,.4)}.item-checkin{top:36%;left:0;width:46%;height:80px;align-items:flex-start}.text-purple{color:#e0aaff;text-shadow:0 0 12px rgba(224,170,255,.6)}.item-words{top:36%;right:0;width:46%;height:80px;align-items:flex-end;text-align:right}.text-green{color:#afffc6;text-shadow:0 0 12px rgba(175,255,198,.6)}.item-duration{top:66%;left:0;width:46%;height:80px;align-items:flex-start}.text-orange{color:#ffdab9;text-shadow:0 0 12px rgba(255,218,185,.6)}.item-points{top:66%;right:0;width:46%;height:80px;align-items:flex-end;text-align:right}.text-yellow{color:#fffacd;text-shadow:0 0 12px rgba(255,250,205,.6)}.report-rank-area{position:absolute;bottom:20%;left:50%;transform:translate(-50%);text-align:center;width:100%;z-index:5;display:flex;flex-direction:column;align-items:center}.rank-title{font-size:.9rem;color:#ffd700e6;letter-spacing:6px;margin-bottom:0;text-transform:uppercase;text-shadow:0 2px 4px rgba(0,0,0,.8);font-weight:700;background:linear-gradient(90deg,transparent,rgba(0,0,0,.5),transparent);padding:4px 20px;border-radius:20px;border:none}.rank-value{font-family:Impact,Arial Black,sans-serif;font-size:4.8rem;line-height:1;margin-top:-5px;background:linear-gradient(180deg,#fff 10%,gold 45%,#b8860b 70%,#8b4500);-webkit-background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 20px rgba(255,215,0,.4));position:relative}.rank-hash{font-size:1.8rem;margin-right:6px;vertical-align:top;position:relative;top:15px;-webkit-text-fill-color:#ffd700}.user-info-tag{position:absolute;bottom:12%;left:50%;transform:translate(-50%);width:auto;min-width:200px;text-align:center;background:#00000080;border:1px solid rgba(255,255,255,.15);padding:6px 20px;border-radius:25px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fffc;font-size:.85rem;letter-spacing:1.5px;z-index:10;box-shadow:0 4px 15px #0006}.user-nickname{color:#0ff;font-weight:700;margin-right:4px}.report-actions{display:flex;gap:15px;z-index:100}.action-btn{padding:10px 24px;border-radius:30px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;justify-content:center}.download-btn{background:#0ff;color:#000;box-shadow:0 0 20px #0ff6}.download-btn:hover{background:#fff;box-shadow:0 0 30px #0ff9;transform:translateY(-2px)}.download-btn:disabled{opacity:.7;cursor:wait}.report-close-btn{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.report-close-btn:hover{background:#fff3;border-radius:30px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(60px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
