:root{--parchment: #f5f4ed;--parchment-deep: #eeede3;--ivory: #faf9f5;--white: #ffffff;--sand: #e8e6dc;--dark-surface: #30302e;--deep-dark: #141413;--ink: #141413;--charcoal: #4d4c48;--olive: #5e5d59;--stone: #87867f;--silver: #b0aea5;--dark-warm: #3d3d3a;--border-cream: #f0eee6;--border-warm: #e8e6dc;--border-dark: #30302e;--ring-warm: #d1cfc5;--ring-deep: #c2c0b6;--terracotta: #c96442;--terracotta-ink: #a8532f;--coral: #d97757;--error: #b53333;--focus: #3898ec;--success-soft: #6b8c61;--fam-unknown: #c5c3b9;--fam-vague: #e8a882;--fam-familiar: #c96442;--fam-mastered: #4a7c59;--fam-vague-ink: #8a4e25;--fam-mastered-ink: #2d5e3e;--serif: "Fraunces", "Noto Serif SC", Georgia, "Songti SC", serif;--sans: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Helvetica Neue", Arial, sans-serif;--mono: ui-monospace, "SF Mono", "IBM Plex Mono", Menlo, Consolas, monospace;--opsz-display: "opsz" 144;--opsz-heading: "opsz" 36;--opsz-body: "opsz" 12;--t-hero: 64px;--t-h1: 44px;--t-h2: 32px;--t-h3: 24px;--t-h4: 20px;--t-body-lg: 18px;--t-body: 16px;--t-body-sm: 14px;--t-caption: 13px;--t-micro: 11px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--r-2xl: 28px;--shadow-card: 0 1px 0 rgba(20,20,19,.02), 0 8px 32px rgba(20,20,19,.04), 0 0 0 1px var(--border-cream);--shadow-raise: 0 10px 40px rgba(20,20,19,.08);--ring-btn: 0 0 0 1px var(--ring-warm)}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--parchment);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:var(--sans);min-height:100vh}.display,.hero-title,.card-word,.detail-word,h1,h2,h3{font-variation-settings:var(--opsz-display)}.section-title,.card-zh,.side-card h4,h4,h5{font-variation-settings:var(--opsz-heading)}.lede,.body-serif,.card-def,.card-quote{font-variation-settings:var(--opsz-body)}.stat .val,.val,.rc-val,.legend-item .num,.streak-foot .big{font-variant-numeric:tabular-nums}:lang(zh){line-height:1.75}:root{--near-black: var(--ink);--pure-white: var(--white);--warm-sand: var(--sand);--charcoal-warm: var(--charcoal);--olive-gray: var(--olive);--stone-gray: var(--stone);--warm-silver: var(--silver);--error-crimson: var(--error);--focus-blue: var(--focus);--success: #2a7d6f;--success-bg: #f0f5f4;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-sm: var(--r-sm);--radius-md: 8px;--radius-lg: var(--r-lg);--radius-xl: var(--r-xl);--radius-2xl: 24px;--radius-3xl: 32px;--shadow-ring: var(--ring-btn);--shadow-whisper: 0 4px 24px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.06);--shadow-lg: 0 8px 32px rgba(0,0,0,.06);--shadow-xl: 0 16px 48px rgba(0,0,0,.08);--font-serif: var(--serif);--font-sans: var(--sans);--font-display: var(--serif);--font-body: var(--sans);--ink-soft: var(--charcoal);--ink-muted: var(--olive);--ink-faint: var(--stone);--cream: var(--ivory);--parchment-warm: var(--border-warm);--accent: var(--terracotta);--accent-hover: var(--terracotta-ink);--accent-light: var(--coral);--accent-bg: #fdf3ef;--teal: var(--terracotta);--teal-hover: var(--terracotta-ink);--teal-light: #fdf3ef;--danger: var(--error);--danger-hover: #9a2b2b;--danger-bg: #fdf0ee;--warning-bg: #fdf3ef;--highlight: #fce8df;--border: var(--border-cream);--border-strong: var(--border-warm);--color-primary: var(--terracotta);--color-primary-hover: var(--terracotta-ink);--color-success: var(--success);--color-danger: var(--error);--color-text-primary: var(--ink);--color-text-secondary: var(--charcoal);--color-text-tertiary: var(--olive);--color-text-muted: var(--stone);--color-bg-page: var(--parchment);--color-bg-card: var(--ivory);--color-bg-code: var(--sand);--color-border: var(--border-cream);--color-border-input: var(--border-warm);--color-highlight: var(--highlight)}body{line-height:1.6;-moz-osx-font-smoothing:grayscale}a{color:var(--terracotta);text-decoration:none}a:hover{color:var(--coral);text-decoration:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-family:var(--font-sans);font-size:15px;font-weight:500;border-radius:var(--radius-md);padding:10px 24px;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;letter-spacing:.1px}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--terracotta);color:var(--ivory);box-shadow:#c96442 0 0,#c96442 0 0 0 1px}.btn-primary:hover:not(:disabled){background:#b55838;box-shadow:#b55838 0 0,#b55838 0 0 0 1px,0 4px 12px #c9644233}.btn-secondary{background:var(--warm-sand);color:var(--charcoal-warm);box-shadow:#e8e6dc 0 0,#d1cfc5 0 0 0 1px}.btn-secondary:hover:not(:disabled){background:#dfddd3;box-shadow:#dfddd3 0 0,#c2c0b6 0 0 0 1px}.btn-danger{background:var(--ivory);color:var(--error-crimson);box-shadow:0 0 0 1px var(--border-warm)}.btn-danger:hover:not(:disabled){background:#fdf0ee;box-shadow:0 0 0 1px var(--error-crimson)}.btn-success{background:var(--ivory);color:var(--terracotta);box-shadow:0 0 0 1px var(--border-warm)}.btn-success:hover:not(:disabled){background:#fdf3ef;box-shadow:0 0 0 1px var(--terracotta)}.btn-ghost{background:transparent;color:var(--olive-gray);box-shadow:0 0 0 1px var(--border-warm);padding:8px 20px;font-size:14px;font-weight:500}.btn-ghost:hover:not(:disabled){background:var(--ivory);color:var(--near-black);box-shadow:0 0 0 1px var(--ring-warm)}.input{width:100%;border:none;box-shadow:0 0 0 1px var(--border-warm);border-radius:var(--radius-lg);padding:10px 16px;font-size:15px;font-family:var(--font-sans);color:var(--near-black);background:var(--ivory);outline:none;transition:all .2s ease;line-height:1.5}.input:focus{box-shadow:0 0 0 2px var(--focus-blue)}.input::placeholder{color:var(--stone-gray)}mark{background:var(--highlight);padding:1px 4px;border-radius:3px;font-weight:500;color:var(--terracotta)}html{--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}body{padding-top:var(--safe-top);padding-bottom:var(--safe-bottom);padding-left:var(--safe-left);padding-right:var(--safe-right)}.app-header{padding-top:var(--safe-top)}@media(max-width:767px){.btn{min-height:44px;min-width:44px}.input{min-height:44px;font-size:16px}.vocab-card-delete-btn{min-height:44px;min-width:44px;padding:10px 16px}.app-header-nav-link{min-height:44px;display:inline-flex;align-items:center}}@media(max-width:767px){.vocabulary-page{padding:calc(60px + var(--safe-top)) 16px calc(32px + var(--safe-bottom))}.vocabulary-search-bar{top:calc(52px + var(--safe-top))}.vocab-card{border-radius:8px}}@media(min-width:768px)and (max-width:1024px){.vocabulary-list{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}}@media(max-width:767px){.review-page{padding:calc(24px + var(--safe-top)) 16px calc(24px + var(--safe-bottom))}.review-card-front-content{height:auto;min-height:360px;padding:40px 24px}.review-card-back-content{max-height:none}.review-card-word-display{font-size:36px}.review-actions{width:100%;gap:12px}.review-action-btn{flex:1;min-width:0}.review-keyboard-hint{display:none}}@media(max-width:480px){.auth-page{padding:calc(32px + var(--safe-top)) 16px calc(32px + var(--safe-bottom));justify-content:flex-start;padding-top:calc(80px + var(--safe-top))}.auth-card{max-width:100%;box-shadow:none;background:transparent;border:none}.auth-card:before{display:none}.auth-submit-btn{min-height:48px;font-size:16px}}@media(max-width:480px){.home-page{padding:calc(24px + var(--safe-top)) 16px calc(24px + var(--safe-bottom))}.home-title{font-size:26px}.home-card{max-width:100%;padding:24px 20px}}@keyframes streak-cell-in{0%{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}@keyframes streak-heatmap-fade-in{0%{opacity:0}to{opacity:1}}@keyframes streak-skeleton-breathe{0%,to{opacity:.55}50%{opacity:.85}}.streak-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:14px}.streak-heatmap-90 .streak-grid{gap:4px;animation:streak-heatmap-fade-in .4s ease both}.streak-cell{aspect-ratio:1;border-radius:4px;background:var(--sand);position:relative;cursor:default;opacity:0;animation:streak-cell-in .35s ease-out both}.streak-heatmap-90 .streak-cell{opacity:1;animation:none;border-radius:2px}.streak-cell-l0{background:var(--sand)}.streak-cell-l1{background:#c964422e}.streak-cell-l2{background:#c964426b}.streak-cell-l3{background:#c96442ad}.streak-cell-l4{background:var(--terracotta)}.streak-cell-today{outline:2px solid var(--ink);outline-offset:1px}.streak-cell:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.streak-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--ink);color:var(--ivory);padding:6px 10px;border-radius:6px;font-family:var(--sans);font-size:12px;white-space:nowrap;pointer-events:none;z-index:5}.streak-foot{display:flex;align-items:baseline;gap:8px}.streak-foot-big{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:36px;letter-spacing:-.015em;line-height:1;font-variant-numeric:tabular-nums;color:var(--ink)}.streak-foot-unit{font-family:var(--serif);color:var(--olive);font-size:14px}.streak-foot-note{font-family:var(--sans);font-size:12px;color:var(--stone);margin-left:auto}.streak-legend{display:flex;align-items:center;gap:4px;margin-top:14px;font-family:var(--sans);font-size:11px;color:var(--stone)}.streak-legend-cell{width:8px;height:8px;border-radius:2px;animation:none;opacity:1}.streak-legend-label{margin:0 4px}.heatmap-skeleton{height:280px;background:var(--sand);animation:streak-skeleton-breathe 1.4s ease-in-out infinite;border:none;box-shadow:none;padding:0}@media(max-width:768px){.streak-heatmap-90 .streak-grid{gap:3px}}@media(prefers-reduced-motion:reduce){.streak-cell,.streak-heatmap-90 .streak-grid{animation:none!important;transition:none!important;opacity:1!important;transform:none!important}.heatmap-skeleton{animation:none;opacity:.7}}@keyframes home-page-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes home-skeleton-breathe{0%,to{opacity:.55}50%{opacity:.85}}.home-page{background:var(--parchment);color:var(--ink);font-family:var(--sans);min-height:100vh;animation:home-page-enter .4s ease both}.home-main{max-width:1280px;margin:0 auto;padding:48px 40px 80px;width:100%;display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:40px}.feed{display:flex;flex-direction:column;gap:36px;min-width:0}.sidebar{display:flex;flex-direction:column;gap:22px;min-width:0}.topnav{padding:18px 40px;padding-top:calc(18px + env(safe-area-inset-top,0px));display:flex;align-items:center;justify-content:space-between;gap:16px;border-bottom:1px solid var(--border-cream);background:var(--parchment);position:sticky;top:0;z-index:10}.topnav-wordmark{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:500;font-size:18px;font-variation-settings:var(--opsz-heading);letter-spacing:-.005em;color:var(--ink);text-decoration:none}.topnav-wordmark-static{cursor:default}.topnav-mark{width:22px;height:22px;border-radius:6px;background:var(--ink);position:relative;flex-shrink:0}.topnav-mark:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:3px;background:var(--terracotta)}.topnav-brand{white-space:nowrap}.topnav-links{display:flex;gap:6px}.topnav-link{padding:8px 14px;border-radius:8px;font-family:var(--sans);font-size:14px;color:var(--olive);text-decoration:none;transition:background .15s ease,color .15s ease}.topnav-link:hover,.topnav-link.is-active{background:var(--sand);color:var(--ink)}.topnav-user{display:flex;align-items:center;gap:12px}.topnav-streak-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:var(--ivory);border:1px solid var(--border-cream);border-radius:100px;font-family:var(--sans);font-size:12px;color:var(--charcoal);text-decoration:none;transition:border-color .15s ease,background .15s ease}.topnav-streak-pill:hover{border-color:var(--ring-warm);cursor:pointer}.topnav-flame{width:6px;height:6px;border-radius:50%;background:var(--terracotta);flex-shrink:0}.topnav-avatar{width:30px;height:30px;border-radius:50%;background:var(--sand);color:var(--terracotta);display:grid;place-items:center;font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:14px;text-decoration:none;transition:background .15s ease}.topnav-avatar:hover{background:var(--parchment-deep)}.hero-head{margin-bottom:0}.kicker{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:14px;display:flex;align-items:center;gap:10px}.kicker:after{content:"";flex:0 0 36px;height:1px;background:var(--terracotta);opacity:.5}.hero-title{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:44px;line-height:1.08;letter-spacing:-.015em;color:var(--ink);margin-bottom:10px;text-wrap:pretty}.hero-title em{font-style:italic;color:var(--terracotta)}.hero-title-skeleton{height:50px;width:60%;background:var(--sand);border-radius:var(--r-md);animation:home-skeleton-breathe 1.4s ease-in-out infinite}.hero-sub{font-family:var(--serif);font-variation-settings:var(--opsz-body);font-weight:400;font-size:18px;line-height:1.65;color:var(--charcoal);max-width:56ch}.today-card{background:var(--ivory);border:1px solid var(--border-cream);border-radius:var(--r-xl);padding:32px 34px;box-shadow:var(--shadow-card);display:grid;grid-template-columns:1fr auto;gap:28px;align-items:end;position:relative;overflow:hidden}.today-card:before{content:"";position:absolute;left:34px;right:34px;top:0;height:2px;border-radius:0 0 3px 3px;background:linear-gradient(90deg,var(--terracotta),var(--coral))}.today-card-skeleton{height:196px;background:var(--sand);border-radius:var(--r-xl);animation:home-skeleton-breathe 1.4s ease-in-out infinite;display:block}.today-card-skeleton:before{display:none}.today-eyebrow{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:10px}.today-h2{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:28px;color:var(--ink);margin-bottom:6px;letter-spacing:-.01em}.today-count{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:56px;line-height:1;color:var(--ink);margin:16px 0 6px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.today-sub{font-family:var(--sans);font-size:14px;color:var(--olive);line-height:1.6;max-width:46ch}.today-meta{display:flex;gap:18px;font-family:var(--sans);font-size:13px;color:var(--olive);margin-top:14px}.today-meta b{color:var(--ink);font-weight:500;font-family:var(--serif);font-variation-settings:var(--opsz-body)}.today-right{display:flex;flex-direction:column;gap:10px;min-width:180px}.btn-primary{height:46px;padding:0 22px;background:var(--terracotta);color:var(--ivory);border-radius:var(--r-md);font-family:var(--sans);font-size:14.5px;font-weight:500;box-shadow:0 0 0 1px var(--terracotta);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none;transition:background .15s ease,transform .05s ease}.btn-primary:hover{background:var(--terracotta-ink)}.btn-primary:active{transform:translateY(1px)}.btn-ghost{height:40px;padding:0 18px;background:var(--white);color:var(--ink);border:1px solid var(--border-warm);border-radius:var(--r-md);font-family:var(--sans);font-size:13.5px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.btn-ghost:hover{background:var(--parchment);border-color:var(--ring-warm)}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.stat{background:var(--ivory);border:1px solid var(--border-cream);border-radius:var(--r-lg);padding:20px 20px 18px;box-shadow:var(--shadow-card)}.stat-skeleton{height:92px;background:var(--sand);border-radius:var(--r-lg);animation:home-skeleton-breathe 1.4s ease-in-out infinite;border:none;box-shadow:none}.stat-label{font-family:var(--sans);font-size:11.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);margin-bottom:10px}.stat-val{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:32px;line-height:1;letter-spacing:-.015em;color:var(--ink);font-variant-numeric:tabular-nums}.stat-val em{color:var(--terracotta);font-style:italic;font-size:20px;margin-left:4px;font-weight:400}.stat-delta{display:inline-flex;align-items:center;gap:4px;font-family:var(--sans);font-size:12px;margin-top:10px;color:var(--olive)}.distribution{background:var(--ivory);border:1px solid var(--border-cream);border-radius:var(--r-xl);padding:28px 32px;box-shadow:var(--shadow-card)}.distribution-skeleton{height:180px;background:var(--sand);animation:home-skeleton-breathe 1.4s ease-in-out infinite;border:none;box-shadow:none;padding:0}.distribution-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px;gap:12px}.distribution-title{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:22px;color:var(--ink);letter-spacing:-.01em}.distribution-link{font-family:var(--sans);font-size:13px;color:var(--terracotta);text-decoration:none}.distribution-link:hover{text-decoration:underline}.bar{height:14px;border-radius:100px;overflow:hidden;display:flex;background:var(--sand);margin-bottom:14px}.bar-seg{display:block;height:100%;transition:width .4s ease}.bar-seg-mastered{background:var(--fam-mastered)}.bar-seg-familiar{background:var(--fam-familiar)}.bar-seg-vague{background:var(--fam-vague)}.bar-seg-unknown{background:var(--fam-unknown)}.legend{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.legend-item{display:flex;flex-direction:column;gap:4px}.legend-row{display:flex;align-items:center;gap:8px}.legend-sq{width:10px;height:10px;border-radius:3px}.legend-sq-mastered{background:var(--fam-mastered)}.legend-sq-familiar{background:var(--fam-familiar)}.legend-sq-vague{background:var(--fam-vague)}.legend-sq-unknown{background:var(--fam-unknown)}.legend-name{font-family:var(--sans);font-size:12.5px;color:var(--olive)}.legend-num{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:22px;letter-spacing:-.01em;color:var(--ink);font-variant-numeric:tabular-nums}.legend-num em{color:var(--terracotta);font-style:italic;font-weight:400;font-size:14px;margin-left:4px}.side-card{background:var(--ivory);border:1px solid var(--border-cream);border-radius:var(--r-xl);padding:24px 26px;box-shadow:var(--shadow-card)}.side-card-title{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:18px;letter-spacing:-.005em;color:var(--ink);margin-bottom:14px}.side-card-sub{font-family:var(--sans);font-size:12.5px;color:var(--olive);margin-bottom:16px;line-height:1.55}.tip{background:var(--ink);color:var(--ivory);border-radius:var(--r-xl);padding:26px 28px;position:relative;overflow:hidden}.tip:before{content:"“";position:absolute;top:-16px;right:14px;font-family:var(--serif);font-variation-settings:var(--opsz-display);font-size:120px;color:var(--terracotta);opacity:.6;line-height:1;font-style:italic;pointer-events:none}.tip-skeleton{height:160px;background:var(--sand);animation:home-skeleton-breathe 1.4s ease-in-out infinite;padding:0}.tip-skeleton:before{display:none}.tip-tag{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--coral);margin-bottom:10px}.tip-main{font-family:var(--serif);font-variation-settings:var(--opsz-body);font-size:17px;line-height:1.55;margin-bottom:12px;position:relative;text-wrap:pretty;color:var(--ivory)}.tip-main em{color:var(--coral);font-style:italic}.tip-example{font-family:var(--serif);font-variation-settings:var(--opsz-body);font-size:14px;color:var(--silver);font-style:italic;margin-bottom:10px;line-height:1.55}.tip-src{font-family:var(--serif);font-style:italic;font-size:12px;color:var(--silver)}.ext-hint{border:1px dashed var(--ring-warm);border-radius:var(--r-lg);padding:18px 20px;background:transparent}.ext-hint-title{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:15px;color:var(--ink);margin-bottom:6px}.ext-hint-desc{font-family:var(--sans);font-size:12.5px;color:var(--olive);line-height:1.55;margin-bottom:12px}.ext-hint-link{font-family:var(--sans);font-size:13px;color:var(--terracotta);font-weight:500;display:inline-flex;align-items:center;gap:4px;text-decoration:none}.ext-hint-link:hover{text-decoration:underline}.error-banner{background:#b5333314;color:var(--error);padding:12px 16px;border-radius:var(--r-md);font-family:var(--sans);font-size:14px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.error-banner-retry{background:transparent;border:1px solid currentColor;color:inherit;padding:4px 12px;border-radius:var(--r-sm);cursor:pointer;font-family:var(--sans);font-size:13px;margin-left:auto}.error-banner-retry:hover{background:#b5333314}@media(max-width:960px){.home-main{grid-template-columns:1fr;gap:32px;padding:28px 24px 64px}.feed{order:1}.sidebar{order:2}}@media(max-width:700px){.home-main{padding:24px 20px 60px;gap:28px}.topnav{padding:14px 20px;padding-top:calc(14px + env(safe-area-inset-top,0px))}.hero-title{font-size:34px}.stats,.legend{grid-template-columns:repeat(2,1fr)}.today-card{grid-template-columns:1fr;padding:28px 24px}.today-count{font-size:48px}.distribution{padding:24px}.today-right{min-width:0}}@media(max-width:600px){.topnav-links{display:none}.topnav{padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0px))}.hero-title{font-size:clamp(28px,8vw,34px)}.home-main{padding:20px 16px 56px}}@media(prefers-reduced-motion:reduce){.home-page{animation:none}.hero-title-skeleton,.today-card-skeleton,.stat-skeleton,.distribution-skeleton,.tip-skeleton{animation:none;opacity:.7}.bar-seg{transition:none}}.vp-page{max-width:1280px;margin:0 auto;padding:40px 40px 80px;width:100%}.vp-pagehead{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:16px}.vp-pagehead-left{display:flex;flex-direction:column;align-items:flex-start;gap:6px}.vp-kicker{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:8px;display:flex;align-items:center;gap:10px}.vp-kicker:after{content:"";flex:0 0 32px;height:1px;background:var(--terracotta);opacity:.5}.vp-h1{font-family:var(--serif);font-weight:500;font-size:44px;letter-spacing:-.015em;line-height:1.08;color:var(--ink);font-variation-settings:var(--opsz-display)}.vp-meta{font-family:var(--sans);font-size:14px;color:var(--stone);margin-top:6px}.vp-meta b{color:var(--ink);font-weight:500;font-variant-numeric:tabular-nums}.vp-cta-link{font-family:var(--sans);font-size:13.5px;font-weight:500;color:var(--terracotta);text-decoration:none;transition:color .15s ease,text-decoration .15s ease}.vp-cta-link:hover{color:var(--terracotta-ink);text-decoration:underline}.vp-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}.vp-search{flex:1 1 auto;min-width:200px;max-width:340px;display:flex;align-items:center;gap:10px;background:var(--ivory);border:1px solid var(--border-warm);border-radius:10px;padding:0 14px;height:40px;transition:border-color .15s ease,box-shadow .15s ease}.vp-search:focus-within{border-color:var(--focus);box-shadow:0 0 0 3px #3898ec26}.vp-search-icon{width:15px;height:15px;color:var(--stone);flex-shrink:0}.vp-search-input{flex:1;background:transparent;border:none;outline:none;font-family:var(--sans);font-size:14px;color:var(--ink)}.vp-search-input::placeholder{color:var(--stone)}.vp-filters{display:flex;gap:8px;flex-wrap:wrap}.vp-filter-btn{height:36px;padding:0 14px;background:var(--ivory);border:1px solid var(--border-warm);border-radius:100px;font-family:var(--sans);font-size:13px;color:var(--olive);cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.vp-filter-btn:hover{border-color:var(--ring-warm);color:var(--ink)}.vp-filter-btn:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.vp-filter-btn.is-on{background:var(--ink);color:var(--ivory);border-color:var(--ink)}.vp-filter-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.vp-filter-dot[data-key=unknown]{background:var(--fam-unknown)}.vp-filter-dot[data-key=vague]{background:var(--fam-vague)}.vp-filter-dot[data-key=familiar]{background:var(--fam-familiar)}.vp-filter-dot[data-key=mastered]{background:var(--fam-mastered)}.vp-sort{margin-left:auto;height:36px;padding:0 14px;background:var(--ivory);border:1px solid var(--border-warm);border-radius:8px;font-family:var(--sans);font-size:13px;color:var(--olive);display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:background-color .15s ease}.vp-sort:hover{background:var(--sand)}.vp-sort:focus-within{border-color:var(--focus);box-shadow:0 0 0 3px #3898ec26}.vp-sort-icon{width:14px;height:14px;color:var(--stone);flex-shrink:0}.vp-sort-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:transparent;border:none;outline:none;font:inherit;color:inherit;padding-right:16px;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none' stroke='%2387867f' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 1l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0 center;background-size:10px 6px}.vp-table{display:flex;flex-direction:column;background:var(--ivory);border:1px solid var(--border-cream);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-card)}.vp-thead{display:grid;grid-template-columns:1fr 180px 140px 120px 80px;gap:16px;padding:12px 24px;background:var(--parchment-deep);border-bottom:1px solid var(--border-cream);font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--stone)}.vp-tbody{display:flex;flex-direction:column}.vp-row{display:grid;grid-template-columns:1fr 180px 140px 120px 80px;gap:16px;padding:16px 24px;border-bottom:1px solid var(--border-cream);align-items:center;cursor:pointer;transition:background-color .12s ease;background:var(--ivory)}.vp-row:last-child{border-bottom:none}.vp-row:hover{background:var(--parchment)}.vp-row:focus-visible{outline:2px solid var(--focus);outline-offset:-2px}.vp-cell{min-width:0}.vp-cell-word{font-family:var(--serif);font-weight:500;font-size:18px;color:var(--ink);font-variation-settings:var(--opsz-body);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vp-cell-zh{font-family:var(--serif);font-size:14px;color:var(--charcoal);font-variation-settings:var(--opsz-body);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vp-cell-src{font-family:var(--sans);font-size:12px;color:var(--stone);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vp-cell-fam{display:flex;align-items:center}.vp-cell-date{font-family:var(--sans);font-size:12.5px;color:var(--stone);font-variant-numeric:tabular-nums;white-space:nowrap}.vp-muted{color:var(--stone);font-style:italic}.vp-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:100px;font-family:var(--sans);font-size:11.5px;font-weight:500;position:relative;cursor:default}.vp-badge-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.vp-badge--unknown{background:#c5c3b933;color:var(--olive)}.vp-badge--unknown .vp-badge-dot{background:var(--fam-unknown)}.vp-badge--vague{background:#e8a88233;color:var(--fam-vague-ink)}.vp-badge--vague .vp-badge-dot{background:var(--fam-vague)}.vp-badge--familiar{background:#c964421f;color:var(--terracotta-ink)}.vp-badge--familiar .vp-badge-dot{background:var(--fam-familiar)}.vp-badge--mastered{background:#4a7c591f;color:var(--fam-mastered-ink)}.vp-badge--mastered .vp-badge-dot{background:var(--fam-mastered)}.vp-badge-tip{position:absolute;bottom:calc(100% + 6px);right:0;background:var(--ink);color:var(--ivory);padding:8px 12px;border-radius:8px;font-family:var(--sans);font-size:11.5px;line-height:1.5;white-space:nowrap;min-width:160px;max-width:calc(100vw - 40px);z-index:10;pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .15s ease,transform .15s ease}.vp-badge-tip:after{content:"";position:absolute;right:14px;bottom:-6px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--ink)}.vp-badge:hover .vp-badge-tip,.vp-badge:focus-within .vp-badge-tip{opacity:1;transform:none}.vp-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1414134d;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:40;opacity:0;pointer-events:none;transition:opacity .3s cubic-bezier(.4,0,.2,1)}.vp-drawer-overlay.is-on{opacity:1;pointer-events:auto}.vp-drawer{position:fixed;top:0;right:0;bottom:0;width:min(480px,90vw);background:var(--ivory);border-left:1px solid var(--border-cream);box-shadow:-20px 0 60px #14141314;z-index:50;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);padding-right:env(safe-area-inset-right)}.vp-drawer.is-on{transform:translate(0)}.vp-drawer-head{padding:24px 28px 20px;border-bottom:1px solid var(--border-cream);display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.vp-drawer-head-left{min-width:0;display:flex;flex-direction:column;gap:6px}.vp-drawer-word{font-family:var(--serif);font-weight:500;font-size:40px;line-height:1;letter-spacing:-.015em;color:var(--ink);font-variation-settings:var(--opsz-display);word-break:break-word}.vp-close-btn{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:var(--stone);background:transparent;border:none;cursor:pointer;flex-shrink:0;transition:background-color .15s ease,color .15s ease}.vp-close-btn:hover{background:var(--sand);color:var(--ink)}.vp-close-btn:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.vp-drawer-body{flex:1;overflow-y:auto;padding:24px 28px;display:flex;flex-direction:column;gap:20px}.vp-drawer-section{display:flex;flex-direction:column;gap:6px}.vp-drawer-zh{font-family:var(--serif);font-size:22px;color:var(--ink);line-height:1.3;font-variation-settings:var(--opsz-heading)}.vp-drawer-muted{font-family:var(--sans);font-size:13px;font-style:italic;color:var(--stone)}.vp-drawer-h4{font-family:var(--serif);font-weight:500;font-size:14px;color:var(--ink);margin-bottom:8px;font-variation-settings:var(--opsz-body)}.vp-drawer-quote{background:var(--parchment);border-radius:10px;border-left:2px solid var(--terracotta);padding:12px 16px;font-family:var(--serif);font-style:italic;font-size:15px;line-height:1.65;color:var(--charcoal);font-variation-settings:var(--opsz-body)}.vp-drawer-quote .vp-hl{color:var(--terracotta);background:#c9644214;padding:0 2px;border-radius:2px}.vp-drawer-quote-translation{font-family:var(--sans);font-size:13.5px;color:var(--olive);margin-top:8px;line-height:1.6}.vp-drawer-source{font-family:var(--sans);font-size:12.5px;color:var(--stone);margin-top:8px;display:inline-block;text-decoration:none;transition:color .15s ease}.vp-drawer-source:hover{color:var(--terracotta);text-decoration:underline}.vp-drawer-meta{display:grid;grid-template-columns:1fr 1fr;gap:12px}.vp-meta-cell{background:var(--parchment);border-radius:10px;padding:12px 14px}.vp-meta-cell-label{font-family:var(--sans);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--stone);margin-bottom:4px}.vp-meta-cell-value{font-family:var(--serif);font-weight:500;font-size:18px;color:var(--ink);font-variation-settings:var(--opsz-body);font-variant-numeric:tabular-nums;word-break:break-word}.vp-drawer-foot{padding:16px 28px;border-top:1px solid var(--border-cream);display:flex;gap:10px}.vp-btn-primary{flex:1;height:44px;padding:0 18px;background:var(--terracotta);color:var(--ivory);border:none;border-radius:10px;font-family:var(--sans);font-size:14px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:background-color .15s ease}.vp-btn-primary:hover{background:var(--terracotta-ink)}.vp-btn-primary:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.vp-btn-danger{height:44px;padding:0 18px;background:transparent;color:var(--error);border:1px solid rgba(181,51,51,.3);border-radius:10px;font-family:var(--sans);font-size:13.5px;font-weight:500;cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.vp-btn-danger:hover{background:#b533330d}.vp-btn-danger:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.vp-btn-danger.is-prompted{background:var(--error);color:var(--ivory);border-color:var(--error)}.vp-btn-ghost{height:40px;padding:0 18px;background:var(--white);color:var(--ink);border:1px solid var(--border-warm);border-radius:10px;font-family:var(--sans);font-size:13.5px;font-weight:500;cursor:pointer;transition:background-color .15s ease}.vp-btn-ghost:hover{background:var(--parchment)}.vp-btn-ghost:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.vp-empty{padding:60px 20px;display:flex;justify-content:center}.vp-empty-card{background:var(--ivory);border-radius:20px;border:1px dashed var(--ring-warm);padding:60px 40px;text-align:center;max-width:480px;box-shadow:var(--shadow-card)}.vp-empty-title{font-family:var(--serif);font-weight:500;font-size:22px;color:var(--ink);margin-bottom:12px;font-variation-settings:var(--opsz-heading)}.vp-empty-desc{font-family:var(--sans);font-size:14px;color:var(--olive);line-height:1.6;margin-bottom:24px}.vp-empty-desc a{color:var(--terracotta);text-decoration:none}.vp-empty-desc a:hover{text-decoration:underline}.vp-skeleton{background:var(--ivory);border:1px solid var(--border-cream);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-card)}.vp-skeleton-head{height:44px;background:var(--parchment-deep);border-bottom:1px solid var(--border-cream)}.vp-skeleton-row{height:56px;border-bottom:1px solid var(--border-cream);background:linear-gradient(90deg,var(--parchment) 0%,var(--sand) 50%,var(--parchment) 100%);background-size:200px 100%;animation:vp-shimmer 1.5s infinite linear}.vp-skeleton-row:last-child{border-bottom:none}.vp-error{padding:20px 0;display:flex;flex-direction:column;gap:12px;align-items:flex-start}.vp-error-banner{background:#b5333314;color:var(--error);border:1px solid rgba(181,51,51,.3);border-radius:10px;padding:12px 16px;font-family:var(--sans);font-size:14px;width:100%}.vp-no-match{text-align:center;padding:40px 20px;font-family:var(--sans);font-size:14px;color:var(--olive)}@keyframes vp-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes vp-shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.vp-pagehead,.vp-toolbar,.vp-table{animation:vp-rise .4s ease both}.vp-toolbar{animation-delay:.05s}.vp-table{animation-delay:.1s}@media(max-width:1024px){.vp-page{padding:32px 24px 80px}}@media(max-width:768px){.vp-page{padding:24px 16px 80px}.vp-h1{font-size:32px}.vp-pagehead{gap:12px}.vp-thead,.vp-row{grid-template-columns:1fr 100px 80px;gap:12px;padding:14px 16px}.vp-thead>:nth-child(3),.vp-thead>:nth-child(5),.vp-row .vp-cell-src,.vp-row .vp-cell-date{display:none}.vp-drawer{width:100vw}.vp-drawer-head{padding:20px 20px 16px}.vp-drawer-body{padding:20px}.vp-drawer-foot{padding:14px 20px}.vp-drawer-word{font-size:32px}.vp-search{max-width:100%;min-width:0;flex:1 1 100%}.vp-toolbar{gap:10px}.vp-sort{margin-left:0}}@media(max-width:480px){.vp-meta{display:block;line-height:1.7}.vp-meta b{display:inline}.vp-drawer-meta{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){.vp-pagehead,.vp-toolbar,.vp-table{animation:none}.vp-drawer{transition:none}.vp-drawer-overlay{transition:opacity .01s}.vp-row,.vp-filter-btn{transition:none}.vp-skeleton-row{animation:none;background:var(--sand)}.vp-badge-tip{transition:opacity .01s;transform:none}}.review-page{background:var(--parchment);min-height:100vh;display:flex;flex-direction:column;color:var(--ink)}.rv-topbar{padding:16px 40px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-cream);flex-shrink:0}.rv-wordmark{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:17px;display:flex;align-items:center;gap:10px;color:var(--ink)}.rv-wordmark-mark{width:20px;height:20px;border-radius:5px;background:var(--ink);position:relative;flex-shrink:0}.rv-wordmark-mark:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:2px;background:var(--terracotta)}.rv-progress-wrap{flex:1;margin:0 40px;display:flex;align-items:center;gap:14px}.rv-progress-track{flex:1;height:4px;background:var(--sand);border-radius:100px;overflow:hidden}.rv-progress-fill{height:100%;background:linear-gradient(90deg,var(--terracotta),var(--coral));border-radius:100px;transition:width .3s ease}.rv-exit-btn{font:inherit;font-size:13.5px;color:var(--olive);padding:8px 14px;border-radius:8px;border:1px solid var(--border-warm);background:transparent;cursor:pointer;transition:background .15s ease,color .15s ease}.rv-exit-btn:hover{background:var(--sand);color:var(--ink)}.rv-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px 100px;position:relative}.rv-card-scene{width:min(640px,100%);margin-bottom:36px;min-height:440px;animation:rv-rise .4s ease both}.rv-card-inner{position:relative;width:100%;height:440px}.rv-card-face{background:var(--ivory);border:1px solid var(--border-cream);border-radius:var(--r-xl);box-shadow:var(--shadow-card),0 20px 60px #1414130f;padding:56px 48px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden;cursor:pointer;-webkit-user-select:none;user-select:none;position:absolute;top:0;right:0;bottom:0;left:0;opacity:1;transition:opacity .2s ease,transform .2s ease}.rv-card-face.hidden{opacity:0;pointer-events:none;transform:scale(.97);display:none}.rv-card-face:not(.hidden){animation:rv-card-flip-in .25s cubic-bezier(.34,1.56,.64,1) both}.rv-card-back{padding:32px 40px;overflow-y:auto;overscroll-behavior:contain;justify-content:flex-start;gap:16px}.rv-card-front:before{content:"";position:absolute;top:0;left:48px;right:48px;height:2px;background:linear-gradient(90deg,transparent,var(--terracotta),transparent);border-radius:0 0 2px 2px}.rv-card-eyebrow{font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:20px}.rv-card-word{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:clamp(64px,10vw,96px);line-height:1;letter-spacing:-.02em;color:var(--ink);margin-bottom:18px}.rv-card-hint{font-size:13px;color:var(--stone);display:flex;align-items:center;gap:6px}.rv-tap-icon{width:20px;height:20px;border:1.5px solid var(--ring-warm);border-radius:5px;display:inline-flex;align-items:center;justify-content:center;font-size:10px}.rv-card-pos{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--terracotta);margin-bottom:12px}.rv-card-zh{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:clamp(24px,3.5vw,36px);line-height:1.1;color:var(--ink);margin-bottom:12px}.rv-card-def{font-family:var(--serif);font-variation-settings:var(--opsz-body);font-size:15px;line-height:1.6;color:var(--charcoal);max-width:40ch;margin-bottom:14px}.rv-card-quote{background:var(--parchment);border-radius:10px;border-left:2px solid var(--terracotta);padding:12px 16px;font-family:var(--serif);font-variation-settings:var(--opsz-body);font-style:italic;font-size:15px;line-height:1.65;color:var(--charcoal);text-align:left;width:100%;max-width:46ch}.rv-hl{color:var(--terracotta);background:#c9644214;padding:0 2px;border-radius:2px}.rv-card-out{animation:rv-card-out .25s ease-in both}.rv-card-in{animation:rv-card-in .25s cubic-bezier(.34,1.56,.64,1) both}.rv-answer-row{display:flex;gap:14px;justify-content:center;margin-bottom:36px;animation:rv-rise .4s ease .08s both}.rv-answer-row.hidden{opacity:0;pointer-events:none}.rv-btn-forget{font:inherit;height:52px;padding:0 28px;background:var(--white);color:var(--charcoal);border:1px solid var(--border-warm);border-radius:var(--r-md);font-size:15px;font-weight:500;display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .08s ease}.rv-btn-forget:hover{background:var(--sand);border-color:var(--ring-warm)}.rv-btn-forget:active{transform:translateY(1px)}.rv-btn-remember{font:inherit;height:52px;padding:0 28px;background:var(--terracotta);color:var(--ivory);border:none;border-radius:var(--r-md);font-size:15px;font-weight:500;display:inline-flex;align-items:center;gap:8px;box-shadow:0 0 0 1px var(--terracotta);cursor:pointer;transition:background .15s ease,transform .08s ease}.rv-btn-remember:hover{background:var(--terracotta-ink)}.rv-btn-remember:active{transform:translateY(1px)}.rv-btn-key{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:5px;border:1.5px solid rgba(255,255,255,.3);font-size:11px;font-family:var(--mono);flex-shrink:0}.rv-btn-forget .rv-btn-key{border-color:var(--ring-warm);color:var(--stone)}.rv-btn-forget.pressed,.rv-btn-remember.pressed{transform:scale(.96);transition:transform .08s ease}.rv-btn-forget:disabled,.rv-btn-remember:disabled{cursor:not-allowed}.rv-kb-hints{display:flex;align-items:center;gap:10px;justify-content:center;animation:rv-rise .4s ease .16s both}.rv-kb-pill{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;background:var(--ivory);border:1px solid var(--border-cream);border-radius:100px;font-size:13px;color:var(--olive);box-shadow:0 1px #14141308}.rv-kb-key{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:22px;padding:0 5px;background:var(--parchment);border:1px solid var(--border-warm);border-bottom:2px solid var(--ring-warm);border-radius:5px;font-size:11px;font-family:var(--mono);color:var(--charcoal);font-weight:500}.rv-complete{display:flex;flex-direction:column;align-items:center;text-align:center;padding:40px 20px 80px;flex:1;animation:rv-rise .4s ease both}.rv-complete-icon{width:72px;height:72px;border-radius:50%;background:var(--terracotta);display:grid;place-items:center;margin-bottom:28px;box-shadow:0 0 0 8px #c964421f,0 0 0 16px #c964420d;color:var(--ivory)}.rv-complete-icon svg{width:32px;height:32px}.rv-complete-h1{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:44px;letter-spacing:-.015em;margin-bottom:8px;color:var(--ink)}.rv-complete-h1 em{color:var(--terracotta);font-style:italic}.rv-complete-tagline{font-family:var(--serif);font-variation-settings:var(--opsz-body);font-size:17px;color:var(--olive);margin-bottom:40px;line-height:1.55}.rv-complete-tagline b{font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}.rv-result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;width:min(580px,100%);margin-bottom:40px}.rv-result-card{background:var(--ivory);border:1px solid var(--border-cream);border-radius:var(--r-lg);padding:22px 18px 20px;box-shadow:var(--shadow-card);text-align:left}.rv-rc-label{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--stone);margin-bottom:10px}.rv-rc-val{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:36px;line-height:1;letter-spacing:-.015em;color:var(--ink);font-variant-numeric:tabular-nums}.rv-rc-val em{color:var(--terracotta);font-style:italic;font-weight:400;font-size:20px;margin-left:3px}.rv-rc-val.success{color:var(--fam-mastered)}.rv-rc-val.terracotta{color:var(--terracotta)}.rv-rc-sub{font-size:12px;color:var(--olive);margin-top:8px;line-height:1.45}.rv-hardest{width:min(580px,100%);margin-bottom:40px;text-align:left}.rv-hardest h3{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:20px;margin-bottom:14px;letter-spacing:-.005em;color:var(--ink)}.rv-hardest-list{display:flex;flex-direction:column;gap:10px;list-style:none;padding:0}.rv-hardest-item{background:var(--ivory);border:1px solid var(--border-cream);border-radius:var(--r-lg);padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;box-shadow:var(--shadow-card)}.rv-hardest-item .rv-en{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:18px;color:var(--ink)}.rv-hardest-item .rv-zh{font-family:var(--serif);font-variation-settings:var(--opsz-body);color:var(--olive);font-size:13.5px;flex:1;margin-left:12px}.rv-hardest-item .rv-tries{font-size:12px;color:var(--stone);white-space:nowrap}.rv-next-review{width:min(580px,100%);background:var(--parchment-deep);border:1px solid var(--border-cream);border-radius:var(--r-lg);padding:18px 22px;margin-bottom:24px;display:flex;align-items:center;gap:16px;text-align:left}.rv-nr-icon{width:38px;height:38px;border-radius:10px;background:var(--ivory);border:1px solid var(--border-cream);display:grid;place-items:center;flex-shrink:0;font-size:18px}.rv-nr-label{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);margin-bottom:3px}.rv-nr-val{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:17px;color:var(--ink)}.rv-nr-sub{font-size:12.5px;color:var(--olive);margin-top:2px}.rv-continue-notice{font-size:13px;color:var(--olive);margin-bottom:16px;font-style:italic}.rv-complete-btns{display:flex;gap:12px}.rv-btn-primary{font:inherit;height:48px;padding:0 24px;background:var(--terracotta);color:var(--ivory);border:none;border-radius:var(--r-md);font-size:14.5px;font-weight:500;box-shadow:0 0 0 1px var(--terracotta);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background .15s ease}.rv-btn-primary:hover{background:var(--terracotta-ink)}.rv-btn-ghost{font:inherit;height:48px;padding:0 20px;background:var(--white);color:var(--ink);border:1px solid var(--border-warm);border-radius:var(--r-md);font-size:14px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s ease}.rv-btn-ghost:hover{background:var(--parchment)}.rv-empty,.rv-error{display:flex;flex-direction:column;align-items:center;text-align:center;padding:80px 20px;flex:1;animation:rv-rise .4s ease both}.rv-empty-icon{width:56px;height:56px;color:var(--terracotta);margin-bottom:24px}.rv-empty-icon svg{width:100%;height:100%}.rv-empty-h1,.rv-error-h1{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:32px;margin-bottom:12px;color:var(--ink)}.rv-empty-sub,.rv-error-detail{font-size:15px;color:var(--olive);margin-bottom:28px;max-width:40ch;line-height:1.55}.rv-empty-btns,.rv-error-btns{display:flex;gap:12px}.rv-loading-wrap{padding-top:80px}.rv-skeleton{background:linear-gradient(90deg,var(--ivory) 0%,var(--parchment-deep) 50%,var(--ivory) 100%);background-size:200% 100%;animation:rv-skeleton-shimmer 1.4s ease-in-out infinite;border-radius:var(--r-xl);width:min(640px,100%);height:440px}@keyframes rv-rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@keyframes rv-card-flip-in{0%{opacity:0;transform:scale(.96) translateY(6px)}to{opacity:1;transform:none}}@keyframes rv-card-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-12px)}}@keyframes rv-card-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}@keyframes rv-skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media(max-width:768px){.rv-topbar{padding:14px 24px}.rv-progress-wrap{margin:0 20px;gap:10px}.rv-card-face{padding:40px 32px}.rv-card-back{padding:28px}}@media(max-width:600px){.rv-card-scene{min-height:0}.rv-card-inner{height:clamp(360px,75vh,440px)}.rv-answer-row{flex-direction:column;width:100%}.rv-btn-forget,.rv-btn-remember{width:100%;justify-content:center}.rv-kb-hints{flex-wrap:wrap}.rv-main{padding:24px 16px 80px}.rv-complete-btns{flex-direction:column;width:100%;max-width:320px}.rv-complete-btns .rv-btn-primary,.rv-complete-btns .rv-btn-ghost{width:100%}}@media(max-width:500px){.rv-result-grid{grid-template-columns:1fr 1fr}.rv-complete-h1{font-size:32px}.rv-hardest-item .rv-zh{font-size:12px}}@media(prefers-reduced-motion:reduce){.rv-card-scene,.rv-answer-row,.rv-kb-hints,.rv-complete,.rv-empty,.rv-error,.rv-card-face,.rv-skeleton,.rv-card-out,.rv-card-in{animation-duration:.01ms!important;animation-delay:0ms!important;animation-iteration-count:1!important}.rv-progress-fill{transition:none!important}.rv-btn-forget.pressed,.rv-btn-remember.pressed{transform:none}.rv-card-face{transition:none!important}.rv-complete-icon{box-shadow:0 0 0 1px var(--terracotta)}}.auth-page-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--parchment);color:var(--ink);font-family:var(--sans)}.auth-loading{font-family:var(--serif);font-variation-settings:var(--opsz-body);color:var(--olive);text-align:center;margin-top:40vh;font-size:16px}.auth-topbar{padding:20px 40px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-cream);background:var(--parchment)}.auth-wordmark{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:18px;letter-spacing:-.005em;display:flex;align-items:center;gap:10px;color:var(--ink);text-decoration:none}.auth-wordmark:hover{color:var(--ink);text-decoration:none}.auth-wordmark-mark{width:22px;height:22px;border-radius:6px;background:var(--ink);position:relative;display:inline-block}.auth-wordmark-mark:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:3px;background:var(--terracotta)}.auth-topbar-cta{font-size:13px;color:var(--olive)}.auth-topbar-link{color:var(--terracotta);font-weight:500;text-decoration:none}.auth-topbar-link:hover{color:var(--coral);text-decoration:underline}main.auth-main{flex:1;display:grid;grid-template-columns:1fr 1fr;min-height:0}.essay{padding:64px 72px 56px;display:flex;flex-direction:column;justify-content:space-between;background:radial-gradient(ellipse 60% 40% at 8% 100%,rgba(201,100,66,.06),transparent 70%),radial-gradient(ellipse 40% 30% at 100% 8%,rgba(201,100,66,.04),transparent 70%),var(--parchment);border-right:1px solid var(--border-cream);position:relative;overflow:hidden}.kicker{font-family:var(--sans);font-size:var(--t-micro);font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);margin-bottom:36px;display:flex;align-items:center;gap:10px}.kicker:after{content:"";flex:0 0 40px;height:1px;background:var(--terracotta);opacity:.5}.display{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:clamp(40px,4.5vw,64px);line-height:1.08;letter-spacing:-.015em;color:var(--ink);margin-bottom:28px;text-wrap:pretty}.display em{font-style:italic;color:var(--terracotta);font-weight:500}.lede{font-family:var(--serif);font-variation-settings:var(--opsz-body);font-size:19px;line-height:1.65;color:var(--charcoal);max-width:46ch;margin-bottom:36px}.bullets{list-style:none;display:flex;flex-direction:column;gap:16px;max-width:44ch;padding:0;margin:0}.bullets li{display:grid;grid-template-columns:28px 1fr;gap:14px;align-items:baseline;font-size:15px;color:var(--olive);line-height:1.55}.bullets .num{font-family:var(--serif);font-variation-settings:var(--opsz-body);font-style:italic;color:var(--terracotta);font-size:16px;border-top:1px solid var(--terracotta);padding-top:6px}.bullets b{color:var(--ink);font-weight:500;font-family:var(--serif);font-variation-settings:var(--opsz-body);font-size:16px}.essay-foot{display:flex;align-items:center;gap:16px;color:var(--stone);font-size:12px;margin-top:48px;padding-top:24px;border-top:1px solid var(--border-cream)}.essay-foot-dot{width:4px;height:4px;border-radius:50%;background:var(--stone)}.form-col{padding:56px 72px;display:flex;flex-direction:column;justify-content:center;background:var(--parchment)}.card{width:100%;max-width:440px;margin:0 auto;background:var(--ivory);border:1px solid var(--border-cream);border-radius:16px;padding:36px 36px 32px;box-shadow:var(--shadow-card)}.card-h1{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:26px;text-align:left;margin-bottom:6px;letter-spacing:-.01em;color:var(--ink)}.card-sub{font-size:13.5px;color:var(--olive);margin-bottom:24px;line-height:1.5}.tabs{display:grid;grid-template-columns:1fr 1fr;background:var(--sand);border-radius:10px;padding:4px;margin-bottom:28px;position:relative}.tab-indicator{position:absolute;top:4px;bottom:4px;width:calc(50% - 4px);left:4px;background:var(--ivory);border-radius:7px;box-shadow:0 1px 2px #1414130f,0 0 0 1px var(--ring-warm);transition:transform .28s cubic-bezier(.4,0,.2,1);z-index:0;pointer-events:none}.tab-indicator[data-active=register]{transform:translate(100%)}.tab{padding:9px 0;text-align:center;font-size:var(--t-body-sm);font-weight:500;color:var(--olive);border-radius:7px;transition:color .2s ease;position:relative;z-index:1;background:transparent;border:none;cursor:pointer;font-family:var(--sans)}.tab.on{color:var(--ink)}.tab:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.pane-wrapper{position:relative}.pane{position:relative;transition:opacity .18s ease}.pane.is-active{opacity:1;pointer-events:auto;position:relative}.pane.is-inactive{opacity:0;pointer-events:none;position:absolute;top:0;left:0;right:0}.field{margin-bottom:14px;position:relative}.field label{display:block;font-size:12px;font-weight:500;color:var(--charcoal);margin-bottom:6px;letter-spacing:.01em;font-family:var(--sans)}.field input{width:100%;height:42px;padding:0 14px;background:var(--white);border:1px solid var(--border-warm);border-radius:10px;font-size:var(--t-body-sm);color:var(--ink);font-family:var(--sans);transition:border-color .15s ease,box-shadow .15s ease}.field input:focus{outline:none;border-color:var(--focus);box-shadow:0 0 0 3px #3898ec26}.field input::placeholder{color:var(--stone)}.auth-error{color:var(--error);font-size:13px;margin:-4px 0 12px;line-height:1.4}.auth-submit-btn{width:100%;height:44px;background:var(--terracotta);color:var(--ivory);border:none;border-radius:10px;font-size:14.5px;font-weight:500;letter-spacing:.01em;cursor:pointer;font-family:var(--sans);box-shadow:0 0 0 1px var(--terracotta),0 1px #1414130a;transition:background .15s ease,transform .05s ease}.auth-submit-btn:hover:not(:disabled){background:var(--terracotta-ink)}.auth-submit-btn:active:not(:disabled){transform:translateY(1px)}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed}.divider{display:flex;align-items:center;gap:12px;margin:20px 0 16px;color:var(--stone);font-size:11.5px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border-warm)}.auth-btn-ghost{width:100%;height:44px;background:var(--white);border:1px solid var(--border-warm);border-radius:10px;display:flex;align-items:center;justify-content:center;gap:10px;font-size:var(--t-body-sm);color:var(--ink);cursor:pointer;font-family:var(--sans);font-weight:500;transition:background .15s ease,border-color .15s ease}.auth-btn-ghost:hover:not(:disabled){background:var(--parchment);border-color:var(--ring-warm)}.auth-btn-ghost:disabled{opacity:.5;cursor:not-allowed}.auth-btn-ghost svg{width:16px;height:16px;flex-shrink:0}.fine{margin-top:18px;text-align:center;font-size:12.5px;color:var(--olive)}.fine-link{color:var(--terracotta);background:none;border:none;padding:0;cursor:pointer;font:inherit;font-weight:500;text-decoration:none}.fine-link:hover{text-decoration:underline;color:var(--terracotta-ink)}.advanced{margin-top:16px;max-width:440px;margin-left:auto;margin-right:auto;width:100%}.advanced-head{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-size:13px;color:var(--olive);background:transparent;border:1px dashed var(--ring-warm);border-radius:10px;cursor:pointer;font-family:var(--sans);transition:background .15s ease}.advanced-head:hover{background:#14141305}.advanced-head-label{display:flex;align-items:center;gap:8px}.advanced-head .chev{transition:transform .25s ease;flex-shrink:0}.advanced[data-open=true] .advanced-head .chev{transform:rotate(180deg)}.advanced-body{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1),margin .25s ease}.advanced[data-open=true] .advanced-body{max-height:320px;margin-top:12px}.advanced-card{background:var(--ivory);border:1px solid var(--border-cream);border-radius:12px;padding:18px 18px 16px}.advanced-card h3{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-size:15px;font-weight:500;margin-bottom:4px;color:var(--ink)}.advanced-card p{font-size:12.5px;color:var(--olive);line-height:1.55;margin-bottom:12px}.dot-s{width:6px;height:6px;border-radius:50%;background:var(--coral);display:inline-block}.ext-input-row{display:flex;gap:8px}.ext-input-row input{flex:1;height:38px;padding:0 12px;background:var(--white);border:1px solid var(--border-warm);border-radius:8px;font-size:13px;color:var(--ink);font-family:var(--sans);transition:border-color .15s ease,box-shadow .15s ease}.ext-input-row input:focus{outline:none;border-color:var(--focus);box-shadow:0 0 0 3px #3898ec26}.ext-input-row button{height:38px;padding:0 16px;background:var(--ink);color:var(--ivory);border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--sans);transition:background .15s ease}.ext-input-row button:hover{background:var(--deep-dark)}@keyframes auth-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.card,.essay>div>*{animation:auth-rise .5s ease both}.essay>div>*:nth-child(2){animation-delay:.05s}.essay>div>*:nth-child(3){animation-delay:.1s}.essay>div>*:nth-child(4){animation-delay:.15s}@media(max-width:900px){.auth-topbar{padding:16px 20px}main.auth-main{grid-template-columns:1fr}.essay{padding:32px 22px 28px;border-right:none;border-bottom:1px solid var(--border-cream)}.display{font-size:34px}.lede{font-size:16px}.bullets li{font-size:14px}.essay-foot{margin-top:24px;padding-top:16px}.form-col{padding:28px 18px 40px}.card{padding:26px 22px 24px;border-radius:14px}.card-h1{font-size:22px}}@media(max-width:600px){.essay{display:none}.form-col{padding:24px 16px 40px;background:var(--parchment)}.card{max-width:100%;padding:24px 18px 22px;border-radius:12px}.auth-topbar{padding:12px 16px}.auth-topbar-cta{display:none}.advanced{max-width:100%}}@media(prefers-reduced-motion:reduce){.auth-page-shell *,.auth-page-shell *:before,.auth-page-shell *:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}@keyframes stats-page-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes bar-grow{0%{transform:scaleY(0)}to{transform:scaleY(1)}}@keyframes stats-skeleton-breathe{0%,to{opacity:.55}50%{opacity:.85}}.stats-page{background:var(--parchment);color:var(--ink);font-family:var(--sans);min-height:100vh;animation:stats-page-enter .4s ease both}.stats-main{max-width:1280px;margin:0 auto;padding:40px 40px 80px;width:100%}.stats-head{margin-bottom:32px}.stats-head .kicker{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:8px;display:flex;align-items:center;gap:10px}.stats-head .kicker:after{content:"";flex:0 0 32px;height:1px;background:var(--terracotta);opacity:.5}.stats-h1{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:44px;letter-spacing:-.015em;line-height:1.06;color:var(--ink);margin-bottom:6px}.stats-meta{font-family:var(--sans);font-size:14px;color:var(--stone)}.period-tabs{position:relative;display:inline-flex;background:var(--sand);border-radius:10px;padding:4px;gap:0;margin-bottom:32px}.period-tab{position:relative;z-index:2;padding:8px 18px;border-radius:7px;font-family:var(--sans);font-size:13.5px;color:var(--olive);background:transparent;border:none;cursor:pointer;transition:color .15s ease;flex:1 1 0;min-width:88px;text-align:center}.period-tab:hover:not(.period-tab-active){color:var(--ink)}.period-tab-active{color:var(--ink)}.period-tab:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.period-indicator{position:absolute;top:4px;left:4px;height:calc(100% - 8px);width:calc((100% - 8px) / 3);background:var(--ivory);border-radius:7px;box-shadow:0 1px 2px #0000000f,var(--ring-btn);transition:transform .25s cubic-bezier(.4,0,.2,1);z-index:1;pointer-events:none}.stats-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:32px}.stats-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.stat-tile{background:var(--ivory);border-radius:var(--r-lg);padding:22px 22px 18px;box-shadow:var(--shadow-card)}.stat-kicker{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);margin-bottom:10px}.stat-val{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:36px;line-height:1;letter-spacing:-.015em;color:var(--ink);font-variant-numeric:tabular-nums}.stat-val em{color:var(--terracotta);font-style:italic;font-weight:400;font-size:20px;margin-left:3px}.stat-delta{font-family:var(--sans);font-size:12px;margin-top:10px;display:flex;align-items:center;gap:4px;font-variant-numeric:tabular-nums}.stat-delta-up{color:var(--success-soft)}.stat-delta-down{color:var(--error)}.stat-delta-flat{color:var(--olive)}.chart-card{background:var(--ivory);border-radius:var(--r-xl);padding:28px 32px;box-shadow:var(--shadow-card)}.chart-card-title{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:20px;letter-spacing:-.01em;color:var(--ink);margin-bottom:20px}.bar-chart{display:flex;align-items:flex-end;gap:6px;height:120px;padding-bottom:24px;position:relative;border-bottom:1px solid var(--border-cream)}.bar-chart-90d{gap:2px}.bar-chart:before{content:"";position:absolute;left:0;right:0;top:0;bottom:24px;background:repeating-linear-gradient(to top,var(--border-cream) 0 1px,transparent 1px 30px);pointer-events:none}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;cursor:pointer;min-width:2px}.bar-col:focus{outline:none}.bar-fill{width:100%;background:linear-gradient(to top,rgba(201,100,66,.55),var(--terracotta));border-radius:4px 4px 0 0;min-height:4px;opacity:.9;transform-origin:bottom;animation:bar-grow .6s cubic-bezier(.34,1.56,.64,1) both;transition:opacity .15s ease,background .15s ease}.bar-fill-empty{background:var(--sand);opacity:.6}.bar-col:hover .bar-fill,.bar-col:focus-visible .bar-fill{opacity:1;background:var(--terracotta-ink)}.bar-col:focus-visible .bar-fill{outline:2px solid var(--focus);outline-offset:2px}.bar-tip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--ink);color:var(--ivory);font-family:var(--sans);font-size:12px;padding:6px 10px;border-radius:8px;white-space:nowrap;pointer-events:none;z-index:5;font-variant-numeric:tabular-nums}.bar-tip-left{left:0;transform:translate(0)}.bar-tip-right{left:auto;right:0;transform:translate(0)}.bar-label{position:absolute;bottom:-20px;font-family:var(--sans);font-size:11px;color:var(--stone);white-space:nowrap;font-variant-numeric:tabular-nums}.acc-chart{display:flex;align-items:center;gap:24px}.donut{position:relative;width:120px;height:120px;flex-shrink:0}.donut-progress{transition:stroke-dashoffset .6s ease}.donut-center{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;text-align:center}.donut-big{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:28px;line-height:1;color:var(--ink);font-variant-numeric:tabular-nums}.donut-unit{font-family:var(--sans);font-size:12px;color:var(--olive);margin-top:4px}.acc-legend{display:flex;flex-direction:column;gap:10px;flex:1;min-width:0}.acc-row{display:flex;align-items:center;gap:10px;font-family:var(--sans);font-size:14px;color:var(--charcoal)}.acc-sq{width:10px;height:10px;border-radius:3px;flex-shrink:0}.acc-sq-mastered{background:var(--fam-mastered)}.acc-sq-familiar{background:var(--fam-familiar)}.acc-sq-vague{background:var(--fam-vague)}.acc-sq-unknown{background:var(--fam-unknown)}.acc-name{flex:1}.acc-num{font-family:var(--serif);font-weight:500;font-size:18px;margin-left:auto;color:var(--ink);font-variant-numeric:tabular-nums}.hard-card{background:var(--ivory);border-radius:var(--r-xl);padding:28px 32px;box-shadow:var(--shadow-card)}.hard-list{display:flex;flex-direction:column;gap:10px;list-style:none;padding:0;margin:0}.hard-item{display:flex;align-items:center;border-bottom:1px solid var(--border-cream)}.hard-item:last-child{border-bottom:none}.hard-link{display:flex;align-items:center;gap:16px;padding:12px 0;width:100%;color:inherit;text-decoration:none;border-radius:6px;transition:background .15s ease}.hard-link:hover{background:var(--parchment-deep)}.hard-link:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.hard-rank{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--terracotta);font-size:16px;width:24px;flex-shrink:0;text-align:center;font-variant-numeric:tabular-nums}.hard-text{flex:1;min-width:0}.hard-en{font-family:var(--serif);font-variation-settings:var(--opsz-body);font-weight:500;font-size:17px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hard-zh{font-family:var(--sans);font-size:13px;color:var(--olive);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hard-acc{font-family:var(--serif);font-size:16px;font-weight:500;color:var(--error);font-variant-numeric:tabular-nums;flex-shrink:0;padding-right:4px}.hard-empty{font-family:var(--sans);font-size:14px;color:var(--stone);padding:24px 0;text-align:center}.stats-empty{display:flex;flex-direction:column;align-items:center;gap:16px;padding:80px 32px;background:var(--ivory);border-radius:var(--r-xl);box-shadow:var(--shadow-card);text-align:center}.stats-empty-icon{font-size:56px;opacity:.8;line-height:1}.stats-empty-title{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-size:24px;font-weight:500;color:var(--ink)}.stats-empty-desc{font-family:var(--sans);font-size:14px;color:var(--olive)}.stats-empty-actions{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap;justify-content:center}.stats-empty-actions .btn-primary,.stats-empty-actions .btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--r-md);font-family:var(--sans);font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:background .15s ease,color .15s ease,border-color .15s ease}.stats-empty-actions .btn-primary{background:var(--ink);color:var(--ivory)}.stats-empty-actions .btn-primary:hover{background:var(--dark-warm)}.stats-empty-actions .btn-ghost{background:transparent;color:var(--ink);border-color:var(--ring-warm)}.stats-empty-actions .btn-ghost:hover{background:var(--sand)}.error-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:var(--ivory);border:1px solid var(--error);border-radius:var(--r-md);font-family:var(--sans);font-size:14px;color:var(--error);margin-bottom:24px}.error-banner-retry{background:transparent;border:1px solid var(--error);color:var(--error);padding:6px 12px;border-radius:var(--r-sm);font-family:var(--sans);font-size:13px;cursor:pointer;transition:background .15s ease,color .15s ease}.error-banner-retry:hover{background:var(--error);color:var(--ivory)}.stats-skeleton-area{pointer-events:none}.stat-tile-skel{height:110px;background:var(--sand);animation:stats-skeleton-breathe 1.4s ease-in-out infinite}.chart-card-skel{height:240px;background:var(--sand);animation:stats-skeleton-breathe 1.4s ease-in-out infinite;padding:0}@media(max-width:1024px){.stats-main{padding:32px 24px 64px}.stats-grid-2{grid-template-columns:1fr}.chart-card,.hard-card{padding:22px 24px}}@media(max-width:768px){.stats-main{padding:24px 16px 80px}.stats-grid-4{grid-template-columns:repeat(2,1fr);gap:12px}.stats-h1{font-size:34px}.stat-val{font-size:30px}.acc-chart{flex-direction:column;gap:18px;align-items:stretch}.acc-legend{width:100%}.bar-label{font-size:10px}.period-tabs{width:100%}}@media(max-width:480px){.stats-grid-4{grid-template-columns:1fr}.period-tab{padding:6px 12px;font-size:12px;min-width:0}.hard-zh{display:none}.donut{width:100px;height:100px}.donut svg{width:100px;height:100px}.donut-big{font-size:24px}.stats-h1{font-size:28px}}@media(prefers-reduced-motion:reduce){.stats-page,.bar-fill,.donut-progress,.stat-tile-skel,.chart-card-skel{animation:none!important;transition:none!important}.bar-fill{transform:scaleY(1)}.stat-tile-skel,.chart-card-skel{opacity:.7}.period-indicator{transition:none!important}}.settings-page{max-width:640px;margin:0 auto;padding:72px var(--space-6) var(--space-12);min-height:100vh;background:var(--parchment)}.settings-header{margin-bottom:var(--space-8)}.settings-title{font-family:var(--font-serif);font-size:28px;font-weight:500;color:var(--near-black);line-height:1.2}.settings-subtitle{font-size:14px;color:var(--stone-gray);margin-top:var(--space-1)}.settings-section{background:var(--ivory);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:var(--space-6);margin-bottom:var(--space-6);position:relative;overflow:hidden}.settings-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--terracotta)}.settings-section-title{font-family:var(--font-serif);font-size:18px;font-weight:500;color:var(--near-black);margin-bottom:var(--space-5);line-height:1.3}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) 0}.settings-row+.settings-row{border-top:1px solid var(--border-cream)}.settings-row-label{font-size:15px;color:var(--near-black);font-weight:400}.settings-row-sublabel{font-size:13px;color:var(--stone-gray);margin-top:2px}.settings-toggle{position:relative;width:48px;height:28px;flex-shrink:0}.settings-toggle input{opacity:0;width:0;height:0;position:absolute}.settings-toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--warm-sand);border-radius:14px;cursor:pointer;transition:background .2s ease;box-shadow:inset 0 1px 3px #0000000f}.settings-toggle input:checked+.settings-toggle-track{background:var(--terracotta)}.settings-toggle input:disabled+.settings-toggle-track{opacity:.4;cursor:not-allowed}.settings-toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;background:var(--pure-white);border-radius:50%;box-shadow:0 1px 4px #0000001f;transition:transform .2s ease}.settings-toggle input:checked+.settings-toggle-track:after{transform:translate(20px)}.settings-time-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--ivory);border:none;box-shadow:0 0 0 1px var(--border-warm);border-radius:var(--radius-md);padding:8px 32px 8px 12px;font-size:15px;font-family:var(--font-sans);color:var(--near-black);cursor:pointer;outline:none;transition:box-shadow .2s ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%234d4c48' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.settings-time-select:focus{box-shadow:0 0 0 2px var(--focus-blue)}.settings-time-select:disabled{opacity:.4;cursor:not-allowed}.settings-preview{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--parchment);border-radius:var(--radius-md);font-size:14px;color:var(--olive-gray);line-height:1.5}.settings-preview-icon{margin-right:var(--space-2)}.settings-permission-banner{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:13px;line-height:1.5}.settings-permission-banner--granted{background:var(--success-bg);color:var(--success)}.settings-permission-banner--denied{background:var(--danger-bg);color:var(--error-crimson)}.settings-permission-banner--prompt{background:var(--warning-bg);color:var(--charcoal-warm)}.settings-back{display:inline-flex;align-items:center;gap:var(--space-2);font-size:14px;color:var(--olive-gray);text-decoration:none;margin-bottom:var(--space-4);transition:color .15s}.settings-back:hover{color:var(--near-black);text-decoration:none}@media(max-width:480px){.settings-page{padding:64px var(--space-4) var(--space-8)}.settings-title{font-size:24px}.settings-section{padding:var(--space-4)}}.landing{background:var(--parchment);color:var(--ink);overflow-x:hidden;min-height:100vh;display:flex;flex-direction:column;animation:landing-rise .4s ease both}@keyframes landing-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.reveal-on-scroll{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1)}.reveal-on-scroll.revealed{opacity:1;transform:translateY(0)}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:18px 40px;background:#f5f4edd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-cream)}.landing-nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink)}.landing-nav-mark{width:22px;height:22px;border-radius:6px;background:var(--ink);position:relative;flex:0 0 auto}.landing-nav-mark:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:3px;background:var(--terracotta)}.landing-nav-wordmark{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:16px;color:var(--ink);letter-spacing:.01em}.landing-nav-links{display:flex;align-items:center;gap:18px}.landing-nav-link{font:500 14px var(--sans);color:var(--charcoal);text-decoration:none;padding:8px 12px;border-radius:8px;transition:color .15s ease,background .15s ease}.landing-nav-link:hover{color:var(--ink);background:var(--sand)}.landing-nav-btn{height:36px;display:inline-flex;align-items:center;padding:0 18px;background:var(--ink);color:var(--ivory);border-radius:100px;font:500 14px var(--sans);text-decoration:none;transition:background .15s ease}.landing-nav-btn:hover{background:var(--dark-warm);color:var(--ivory);text-decoration:none}.landing-main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:96px 40px 100px}.landing-hero{display:grid;grid-template-columns:1fr 420px;gap:64px;align-items:center;margin:24px 0 72px}.landing-hero-text{min-width:0}.landing-hero-kicker{font:500 11px var(--sans);letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:14px;display:flex;align-items:center;gap:10px}.landing-hero-kicker:after{content:"";flex:0 0 32px;height:1px;background:var(--terracotta);opacity:.5}.landing-hero-title{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:clamp(40px,6vw,64px);line-height:1.06;letter-spacing:-.015em;color:var(--ink);margin-bottom:16px;text-wrap:pretty}.landing-hero-title em{font-style:italic;color:var(--terracotta)}.landing-hero-lede{font-family:var(--serif);font-variation-settings:var(--opsz-body);font-size:18px;line-height:1.65;color:var(--charcoal);margin-bottom:28px;max-width:52ch}.landing-hero-cta{display:flex;gap:12px;flex-wrap:wrap}.landing-hero-foot{margin-top:18px;font:400 13px var(--sans);color:var(--olive)}.landing-hero-foot-link{color:var(--terracotta);text-decoration:none;transition:color .15s ease}.landing-hero-foot-link:hover{text-decoration:underline}.landing-btn-primary{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;cursor:pointer;height:50px;padding:0 24px;background:var(--terracotta);color:var(--ivory);border-radius:12px;font:500 15px var(--sans);display:inline-flex;align-items:center;gap:10px;text-decoration:none;box-shadow:0 0 0 1px var(--terracotta),0 4px 16px #c9644233;transition:background .15s ease,transform .15s ease,box-shadow .15s ease}.landing-btn-primary:hover{background:var(--terracotta-ink);color:var(--ivory);text-decoration:none}.landing-btn-primary:active{transform:translateY(1px)}.landing-btn-primary:focus-visible{outline:2px solid var(--terracotta);outline-offset:3px}.landing-btn-large{height:54px;padding:0 32px;font-size:16px;min-width:220px;justify-content:center}.landing-btn-ghost{height:50px;padding:0 22px;background:var(--white);color:var(--ink);border:1px solid var(--border-warm);border-radius:12px;font:500 15px var(--sans);display:inline-flex;align-items:center;gap:8px;text-decoration:none;transition:background .15s ease,border-color .15s ease}.landing-btn-ghost:hover{background:var(--parchment);border-color:var(--ring-warm);color:var(--ink);text-decoration:none}.landing-btn-ghost:focus-visible{outline:2px solid var(--ink);outline-offset:3px}.ext-mock{position:relative;background:var(--ivory);border:1px solid var(--border-cream);border-radius:20px;box-shadow:var(--shadow-raise);padding:20px;overflow:hidden}.ext-mock:before{content:"";position:absolute;top:0;left:20px;right:20px;height:2px;background:linear-gradient(90deg,transparent,var(--terracotta),transparent)}.ext-mock-bar{display:flex;align-items:center;gap:6px;background:var(--sand);height:28px;padding:0 12px;border-radius:10px;margin-bottom:14px}.ext-mock-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}.ext-mock-dot--red{background:#c964428c}.ext-mock-dot--amber{background:#e8a882d9}.ext-mock-dot--green{background:#4a7c598c}.ext-mock-bar-url{margin-left:8px;font:500 11px var(--sans);color:var(--stone);letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ext-mock-head{display:flex;align-items:center;gap:8px;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--border-cream)}.ext-mock-logo{width:24px;height:24px;border-radius:6px;background:var(--ink);position:relative;flex:0 0 auto}.ext-mock-logo:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:2px;background:var(--terracotta)}.ext-mock-title{font-family:var(--serif);font-weight:500;font-size:14px;color:var(--ink)}.ext-mock-status{margin-left:auto;display:inline-flex;align-items:center;gap:5px;background:#4a7c591a;padding:3px 10px;border-radius:100px;font:500 11px var(--sans);color:var(--fam-mastered-ink);white-space:nowrap}.ext-mock-status-dot{width:6px;height:6px;border-radius:50%;background:var(--fam-mastered);animation:ext-pulse 2.4s ease-in-out infinite}@keyframes ext-pulse{0%,to{opacity:1}50%{opacity:.4}}.ext-mock-passage{background:var(--parchment);border-radius:12px;padding:14px 16px;margin-bottom:12px}.ext-mock-passage p{font:400 13px var(--sans);color:var(--charcoal);line-height:1.6;word-break:break-word}.ext-mock-selected{background:#c9644226;border-bottom:2px solid var(--terracotta);font-family:var(--serif);font-weight:500;font-size:14px;color:var(--ink);padding:0 2px}.ext-mock-popup{background:var(--white);border:1px solid var(--border-warm);border-radius:12px;padding:14px 16px;box-shadow:0 8px 24px #1414131a}.ext-mock-popup-word{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:20px;color:var(--ink);margin-bottom:2px}.ext-mock-popup-pos{font:500 10.5px var(--sans);letter-spacing:.14em;text-transform:uppercase;color:var(--terracotta)}.ext-mock-popup-zh{font-family:var(--serif);font-variation-settings:var(--opsz-body);font-size:14px;color:var(--charcoal);margin:8px 0}.ext-mock-popup-sent{font:italic 12.5px var(--serif);font-variation-settings:var(--opsz-body);color:var(--olive);line-height:1.5}.ext-mock-popup-actions{display:flex;gap:8px;margin-top:12px}.ext-mock-popup-btn{flex:1;height:32px;display:inline-flex;align-items:center;justify-content:center;font:500 12.5px var(--sans);border-radius:8px;-webkit-user-select:none;user-select:none}.ext-mock-popup-btn--add{background:var(--terracotta);color:var(--ivory)}.ext-mock-popup-btn--skip{background:var(--sand);color:var(--charcoal)}.landing-steps{margin-bottom:72px}.landing-steps-head{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:28px;letter-spacing:-.01em;margin-bottom:32px;color:var(--ink)}.landing-steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.landing-step{background:var(--ivory);border:1px solid var(--border-cream);border-radius:var(--r-xl);padding:28px 26px;box-shadow:var(--shadow-card);transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s ease}.landing-step:hover{transform:translateY(-3px);box-shadow:var(--shadow-raise)}.landing-step-num{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-style:italic;font-weight:500;font-size:56px;color:var(--terracotta);line-height:1;margin-bottom:14px}.landing-step-title{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:22px;color:var(--ink);margin-bottom:8px;line-height:1.3}.landing-step-desc{font:400 14px var(--sans);line-height:1.65;color:var(--olive)}.landing-features{margin-bottom:72px}.landing-features-head{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:28px;letter-spacing:-.01em;margin-bottom:24px;color:var(--ink)}.landing-features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.landing-feature{background:var(--ivory);border:1px solid var(--border-cream);border-radius:var(--r-lg);padding:22px;box-shadow:var(--shadow-card);display:grid;grid-template-columns:40px 1fr;gap:16px;align-items:start;transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s ease}.landing-feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-raise)}.landing-feature-icon{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;font-size:20px}.landing-feature-body{min-width:0}.landing-feature-title{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:17px;color:var(--ink);margin-bottom:6px;line-height:1.35}.landing-feature-desc{font:400 13.5px var(--sans);line-height:1.6;color:var(--olive)}.landing-vp{margin-bottom:72px}.landing-vp-head-wrap{text-align:center;margin-bottom:32px}.landing-vp-kicker{font:500 11px var(--sans);letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:8px}.landing-vp-head{font-family:var(--serif);font-variation-settings:var(--opsz-heading);font-weight:500;font-size:28px;letter-spacing:-.01em;color:var(--ink)}.landing-vp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.landing-vp-card{background:var(--ivory);border:1px solid var(--border-cream);border-radius:var(--r-xl);padding:32px 28px;box-shadow:var(--shadow-card);text-align:center;transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s ease}.landing-vp-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-raise)}.landing-vp-big{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-style:italic;font-weight:500;font-size:36px;letter-spacing:-.015em;color:var(--terracotta);margin-bottom:8px;line-height:1.1}.landing-vp-kicker-sm{font:500 11px var(--sans);letter-spacing:.18em;text-transform:uppercase;color:var(--stone);margin-bottom:14px}.landing-vp-body{font:400 14px var(--sans);line-height:1.65;color:var(--olive);max-width:28ch;margin:0 auto}.landing-cta{background:var(--ink);color:var(--ivory);border-radius:var(--r-2xl);padding:56px 40px;text-align:center;position:relative;overflow:hidden}.landing-cta:before{content:"";position:absolute;top:0;left:40px;right:40px;height:2px;background:linear-gradient(90deg,transparent,var(--terracotta),transparent)}.landing-cta-title{font-family:var(--serif);font-variation-settings:var(--opsz-display);font-weight:500;font-size:clamp(28px,4vw,36px);line-height:1.15;margin-bottom:12px;color:var(--ivory)}.landing-cta-title em{font-style:italic;color:var(--terracotta)}.landing-cta-sub{font:400 14px var(--sans);color:var(--silver);margin-bottom:28px}.landing-footer{padding:32px 40px;background:var(--parchment-deep);border-top:1px solid var(--border-cream)}.landing-footer-content{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font:400 13px var(--sans);color:var(--olive)}.landing-footer-brand{font-weight:500;color:var(--ink)}.landing-footer-powered{font-size:12.5px;color:var(--olive)}.landing-footer-link{color:var(--olive);text-decoration:none;transition:color .15s ease}.landing-footer-link:hover{color:var(--terracotta)}@media(max-width:1024px){.landing-main{padding:88px 24px 80px}.landing-hero{grid-template-columns:1fr 360px;gap:40px}}@media(max-width:768px){.landing-nav{padding:14px 20px}.landing-nav-link{min-height:44px;display:inline-flex;align-items:center}.landing-nav-btn{min-height:44px}.landing-main{padding:80px 20px 64px}.landing-hero{grid-template-columns:1fr;gap:32px;margin-bottom:56px}.landing-steps{margin-bottom:56px}.landing-steps-grid{grid-template-columns:1fr;gap:16px}.landing-features{margin-bottom:56px}.landing-features-grid{grid-template-columns:1fr;gap:14px}.landing-vp{margin-bottom:56px}.landing-vp-grid{grid-template-columns:1fr;gap:16px}.landing-cta{padding:40px 24px}.landing-footer{padding:24px 20px}.landing-footer-content{flex-direction:column;text-align:center;align-items:center}.landing-footer-link{min-height:44px;display:inline-flex;align-items:center}}@media(max-width:480px){.landing-nav{padding:12px 16px}.landing-nav-wordmark{font-size:14px}.landing-nav-links{gap:8px}.landing-nav-link{padding:8px}.landing-nav-btn{padding:0 14px;font-size:13px}.landing-main{padding:76px 18px 56px}.landing-hero-title{font-size:clamp(32px,8vw,40px)}.landing-hero-cta{flex-direction:column}.landing-btn-primary,.landing-btn-ghost,.landing-btn-large{width:100%;justify-content:center;min-width:0}.landing-steps-head,.landing-features-head,.landing-vp-head{font-size:24px}.ext-mock{padding:16px}.ext-mock-passage p{font-size:12px}.ext-mock-popup-word{font-size:18px}.landing-step-num{font-size:48px}.landing-cta{padding:36px 20px}}@media(prefers-reduced-motion:reduce){.landing,.reveal-on-scroll,.ext-mock-status-dot,.landing-step,.landing-feature,.landing-vp-card{animation:none!important;transition-duration:.01ms!important;transform:none!important}.reveal-on-scroll{opacity:1!important}}.app-header{position:fixed;top:0;left:0;right:0;z-index:100;background:#f5f4edeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-cream)}.app-header-inner{max-width:960px;margin:0 auto;padding:0 var(--space-6);height:52px;display:flex;align-items:center;justify-content:space-between}.app-header-left{display:flex;align-items:center;gap:var(--space-6)}.app-header-brand{font-family:var(--font-serif);font-size:17px;font-weight:500;color:var(--near-black);text-decoration:none;letter-spacing:normal;line-height:1.2}.app-header-brand:hover{color:var(--charcoal-warm);text-decoration:none}.app-header-nav{display:flex;align-items:center;gap:var(--space-1)}.app-header-nav-link{font-size:14px;font-weight:400;color:var(--olive-gray);text-decoration:none;padding:4px 12px;border-radius:var(--radius-sm);transition:all .15s}.app-header-nav-link:hover{color:var(--near-black);background:#0000000a;text-decoration:none}.app-header-nav-link--active{color:var(--terracotta);font-weight:500}.app-header-nav-link--active:hover{color:var(--terracotta)}.app-header-right{display:flex;align-items:center;gap:var(--space-3)}.app-header-email{font-size:13px;color:var(--olive-gray);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-header-logout{font-size:13px;padding:6px 14px}.app-header-login{font-size:13px;padding:6px 14px;text-decoration:none}
