:root{--bg-primary:#f5f1e8;--bg-secondary:#ede6d3;--bg-tertiary:#e5dcc4;--text-primary:#2c3e2d;--text-secondary:#4a5d4c;--text-muted:#6b7b6d;--accent-gold:#b8860b;--accent-gold-light:#d4a84b;--accent-copper:#b87333;--accent-copper-light:peru;--border:#c9b896;--border-light:#ddd4be;--shadow:#2c3e2d14;--shadow-deep:#2c3e2d26;--font-display:"Cormorant Garamond", Georgia, serif;--font-mono:"JetBrains Mono", "Courier New", monospace;--space-xs:.5rem;--space-sm:.75rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.65, 0, .35, 1)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-mono);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;position:relative;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:-2;background:radial-gradient(ellipse at 20% 30%, #b8860b08 0%, transparent 50%), radial-gradient(ellipse at 80% 70%, #b8733308 0%, transparent 50%), linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);width:100%;height:100%;position:fixed;top:0;left:0}body:after{content:"";pointer-events:none;z-index:-1;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");width:100%;height:100%;position:fixed;top:0;left:0}#root{flex-direction:column;min-height:100vh;display:flex}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes developImage{0%{opacity:0;filter:sepia(80%)contrast(1.2)brightness(1.3);transform:scale(.98)}50%{filter:sepia(40%)contrast(1.1)brightness(1.1)}to{opacity:1;filter:sepia(15%)contrast(1.05)brightness();transform:scale(1)}}@keyframes loupeScan{0%,to{transform:translate(-30px)rotate(-5deg)}50%{transform:translate(30px)rotate(5deg)}}@keyframes scanSweep{0%,to{opacity:0;transform:translate(-100%)}50%{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}@keyframes cardAppear{to{opacity:1;transform:translateY(0)rotate(0)}}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.archive-header{text-align:center;padding:var(--space-3xl) var(--space-lg);position:relative}.header-top{position:absolute;top:1rem;right:1rem}.header-actions{align-items:center;gap:var(--space-md);display:flex}.user-menu{align-items:center;gap:var(--space-sm);display:flex}.user-email{font-family:var(--font-mono);color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:150px;font-size:.75rem;overflow:hidden}.header-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);font-family:var(--font-mono);cursor:pointer;border-radius:6px;align-items:center;gap:.5rem;padding:.5rem .875rem;font-size:.75rem;transition:all .2s;display:flex}.header-btn:hover{background:var(--bg-primary);border-color:var(--accent-gold);color:var(--accent-gold)}.header-btn.logout{background:var(--bg-secondary);border-color:var(--border);color:var(--text-muted)}.header-btn.logout:hover{background:var(--bg-primary);color:#ef4444;border-color:#ef4444}.header-decoration{justify-content:center;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);display:flex}.decoration-line{background:linear-gradient(90deg, transparent, var(--border), transparent);width:80px;height:1px}.decoration-ornament{color:var(--accent-gold);opacity:.6;font-size:1.2rem}.typewriter-title{align-items:center;gap:var(--space-xs);flex-direction:column;display:flex}.title-main{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.15em;animation:fadeInUp 1s var(--ease-out) forwards;font-size:clamp(2.5rem,6vw,4rem);font-weight:700}.title-sub{font-family:var(--font-display);color:var(--text-secondary);letter-spacing:.3em;text-transform:uppercase;animation:fadeInUp 1s var(--ease-out) .2s forwards;opacity:0;font-size:clamp(.9rem,2vw,1.1rem);font-style:italic;font-weight:400}.archive-subtitle{font-family:var(--font-mono);letter-spacing:.4em;color:var(--text-muted);margin-top:var(--space-md);text-transform:uppercase;animation:fadeInUp 1s var(--ease-out) .4s forwards;opacity:0;font-size:.75rem;font-weight:300}@media (width<=640px){.archive-header{padding:var(--space-2xl) var(--space-md)}.decoration-line{width:50px}}.settings-btn{top:var(--space-lg);left:var(--space-lg);z-index:100;background:var(--bg-secondary);border:1px solid var(--border);width:44px;height:44px;color:var(--text-secondary);cursor:pointer;transition:all .3s var(--ease-out);box-shadow:0 2px 8px var(--shadow);border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed}.settings-btn:hover{background:var(--bg-primary);border-color:var(--accent-gold);color:var(--accent-gold);box-shadow:0 4px 12px var(--shadow-deep);transform:rotate(30deg)}.settings-indicator{background:var(--accent-gold);border:2px solid var(--bg-secondary);border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.settings-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:overlayFadeIn .3s var(--ease-out);background:#2c3e2d66;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.settings-modal{width:100%;max-width:480px;margin:var(--space-lg);background:var(--bg-primary);border:1px solid var(--border);animation:modalSlideIn .3s var(--ease-out);border-radius:8px;overflow:hidden;box-shadow:0 20px 60px #0003}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.settings-header{padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.settings-title{align-items:center;gap:var(--space-sm);font-family:var(--font-display);color:var(--text-primary);margin:0;font-size:1.3rem;font-weight:600;display:flex}.settings-icon{font-size:1.1rem}.settings-close{width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.settings-close:hover{background:var(--bg-primary);border-color:var(--border);color:var(--text-primary)}.settings-content{padding:var(--space-lg);gap:var(--space-md);flex-direction:column;max-height:60vh;display:flex;overflow-y:auto}.settings-section{gap:var(--space-sm);flex-direction:column;display:flex}.settings-label{align-items:center;gap:var(--space-xs);font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.1em;text-transform:uppercase;font-size:.8rem;font-weight:500;display:flex}.settings-input-wrapper{align-items:center;display:flex;position:relative}.settings-input{width:100%;padding:var(--space-sm) var(--space-md);font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border);transition:all .3s var(--ease-out);border-radius:4px;padding-right:3rem;font-size:.9rem}.settings-input:focus{border-color:var(--accent-gold);outline:none;box-shadow:0 0 0 3px #b8860b1a}.settings-input::placeholder{color:var(--text-muted);opacity:.6}.settings-toggle{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.settings-toggle:hover{color:var(--accent-gold);background:var(--bg-primary)}.settings-hint{font-family:var(--font-mono);color:var(--text-muted);opacity:.8;margin:0;font-size:.75rem}.settings-footer{justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-top:1px solid var(--border);display:flex}.settings-btn-secondary,.settings-btn-primary{padding:var(--space-sm) var(--space-md);font-family:var(--font-mono);cursor:pointer;transition:all .3s var(--ease-out);border-radius:4px;font-size:.85rem;font-weight:500}.settings-btn-secondary{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.settings-btn-secondary:hover{background:var(--bg-primary);border-color:var(--text-muted);color:var(--text-primary)}.settings-btn-primary{background:linear-gradient(135deg, var(--accent-gold), var(--accent-copper));color:var(--bg-primary);border:none}.settings-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #b8860b4d}@media (width<=640px){.settings-btn{top:var(--space-sm);left:var(--space-sm);width:40px;height:40px}.settings-modal{margin:var(--space-sm);max-height:calc(100vh - var(--space-lg));overflow-y:auto}.settings-title{font-size:1.1rem}}.error-overlay{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:errorOverlayFadeIn .3s var(--ease-out);background:#2c3e2d80;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes errorOverlayFadeIn{0%{opacity:0}to{opacity:1}}.error-modal{width:100%;max-width:420px;margin:var(--space-lg);background:var(--bg-primary);border:2px solid var(--accent-copper);animation:errorModalSlideIn .3s var(--ease-out);border-radius:8px;overflow:hidden;box-shadow:0 20px 60px #00000040}@keyframes errorModalSlideIn{0%{opacity:0;transform:translateY(-20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.error-header{align-items:center;gap:var(--space-md);padding:var(--space-xl) var(--space-lg) var(--space-md);background:linear-gradient(#b8733314 0%,#0000 100%);flex-direction:column;display:flex}.error-icon-wrapper{width:60px;height:60px;color:var(--accent-copper);background:#b8733326;border-radius:50%;justify-content:center;align-items:center;animation:1.5s ease-in-out infinite errorIconPulse;display:flex}@keyframes errorIconPulse{0%,to{transform:scale(1);box-shadow:0 0 #b8733366}50%{transform:scale(1.05);box-shadow:0 0 0 8px #b8733300}}.error-icon{color:var(--accent-copper)}.error-title{font-family:var(--font-display);color:var(--accent-copper);text-align:center;margin:0;font-size:1.5rem;font-weight:700}.error-content{padding:var(--space-md) var(--space-lg) var(--space-xl);text-align:center}.error-message{font-family:var(--font-mono);color:var(--text-primary);word-break:break-word;margin:0;font-size:.95rem;line-height:1.6}.error-footer{padding:var(--space-md) var(--space-lg) var(--space-lg);border-top:1px solid var(--border);justify-content:center;display:flex}.error-btn{min-width:120px;padding:var(--space-sm) var(--space-xl);font-family:var(--font-display);color:var(--bg-primary);background:linear-gradient(135deg, var(--accent-copper), var(--accent-copper-light));cursor:pointer;transition:all .3s var(--ease-out);border:none;border-radius:4px;font-size:1rem;font-weight:600}.error-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #b8733359}.error-btn:active{transform:translateY(0)}@media (width<=640px){.error-modal{margin:var(--space-md)}.error-title{font-size:1.3rem}.error-message{font-size:.9rem}}.auth-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:overlayFadeIn .3s var(--ease-out);background:#2c3e2d66;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-dialog{width:100%;max-width:420px;margin:var(--space-lg);background:var(--bg-primary);border:1px solid var(--border);animation:modalSlideIn .3s var(--ease-out);border-radius:8px;position:relative;overflow:hidden;box-shadow:0 20px 60px #0003}.auth-dialog:before{content:"";background:linear-gradient(90deg, var(--accent-gold), var(--accent-copper), var(--accent-gold));height:3px;position:absolute;top:0;left:0;right:0}.auth-header{padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.auth-title{align-items:center;gap:var(--space-sm);font-family:var(--font-display);color:var(--text-primary);margin:0;font-size:1.3rem;font-weight:600;display:flex}.auth-title-icon{color:var(--accent-gold);font-size:1.1rem}.auth-close{width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;line-height:1;transition:all .2s;display:flex}.auth-close:hover{background:var(--bg-primary);border-color:var(--border);color:var(--text-primary)}.auth-content{padding:var(--space-lg)}.auth-form{gap:var(--space-md);flex-direction:column;display:flex}.auth-field{gap:var(--space-xs);flex-direction:column;display:flex}.auth-field label{align-items:center;gap:var(--space-xs);font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.1em;text-transform:uppercase;font-size:.8rem;font-weight:500;display:flex}.label-icon{color:var(--accent-gold);font-size:.9rem}.auth-field input{padding:var(--space-sm) var(--space-md);font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border);transition:all .3s var(--ease-out);border-radius:4px;font-size:.95rem}.auth-field input:focus{border-color:var(--accent-gold);outline:none;box-shadow:0 0 0 3px #b8860b1a}.auth-field input::placeholder{color:var(--text-muted);opacity:.6}.auth-error{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);color:#c44;font-family:var(--font-mono);background:#ef444414;border:1px solid #ef44444d;border-radius:4px;font-size:.8rem;display:flex}.error-icon{flex-shrink:0;font-size:1rem}.auth-submit{margin-top:var(--space-sm);padding:var(--space-sm) var(--space-md);font-family:var(--font-mono);background:linear-gradient(135deg, var(--accent-gold), var(--accent-copper));color:var(--bg-primary);cursor:pointer;transition:all .3s var(--ease-out);border:none;border-radius:4px;font-size:.9rem;font-weight:500}.auth-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #b8860b4d}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-divider{align-items:center;gap:var(--space-md);margin:var(--space-md) 0;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border-light);flex:1;height:1px}.auth-divider span{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;font-size:.7rem}.auth-switch{text-align:center;color:var(--text-secondary);font-family:var(--font-mono);font-size:.85rem}.auth-switch-btn{color:var(--accent-gold);font-family:var(--font-mono);cursor:pointer;background:0 0;border:none;margin-left:.25rem;padding:0;font-size:.85rem;font-weight:500;-webkit-text-decoration:underline #0000;text-decoration:underline #0000;transition:all .2s}.auth-switch-btn:hover{-webkit-text-decoration-color:var(--accent-gold);text-decoration-color:var(--accent-gold)}.auth-footer-decoration{justify-content:center;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-top:1px solid var(--border);display:flex}.decoration-dot{background:var(--border);border-radius:50%;width:4px;height:4px}.decoration-line-short{background:linear-gradient(90deg, transparent, var(--border), transparent);width:40px;height:1px}@media (width<=640px){.auth-dialog{margin:var(--space-sm);max-height:calc(100vh - var(--space-lg));overflow-y:auto}.auth-title{font-size:1.1rem}.auth-content{padding:var(--space-md)}}.vocab-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:overlayFadeIn .3s var(--ease-out);background:#2c3e2d66;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.vocab-dialog{width:100%;max-width:520px;margin:var(--space-lg);max-height:calc(100vh - var(--space-xl));background:var(--bg-primary);border:1px solid var(--border);animation:modalSlideIn .3s var(--ease-out);border-radius:8px;flex-direction:column;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 60px #0003}.vocab-dialog:before{content:"";background:linear-gradient(90deg, var(--accent-gold), var(--accent-copper), var(--accent-gold));z-index:1;height:3px;position:absolute;top:0;left:0;right:0}.vocab-header{padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.vocab-title{align-items:center;gap:var(--space-sm);font-family:var(--font-display);color:var(--text-primary);margin:0;font-size:1.3rem;font-weight:600;display:flex}.vocab-title-icon{font-size:1.1rem}.vocab-close{width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:50%;justify-content:center;align-items:center;font-size:1.75rem;line-height:1;transition:all .2s;display:flex}.vocab-close:hover{background:var(--bg-primary);border-color:var(--border);color:var(--text-primary)}.vocab-search{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border);background:var(--bg-primary);flex-shrink:0}.vocab-search-input{width:100%;padding:var(--space-sm) var(--space-md);font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border);transition:all .3s var(--ease-out);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%236B7B6D' stroke-width='1.5'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-position:.75rem;background-repeat:no-repeat;border-radius:4px;padding-left:2.5rem;font-size:.9rem}.vocab-search-input:focus{border-color:var(--accent-gold);outline:none;box-shadow:0 0 0 3px #b8860b1a}.vocab-search-input::placeholder{color:var(--text-muted);opacity:.6}.vocab-list{padding:var(--space-sm);background:var(--bg-primary);flex:1;overflow-y:auto}.vocab-item{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-xs);background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;transition:all .2s;display:flex}.vocab-item:hover{background:var(--bg-tertiary);border-color:var(--border-light);transform:translate(2px)}.vocab-item-clickable{cursor:pointer;border-color:var(--accent-gold);border-style:dashed}.vocab-item-clickable:hover{border-color:var(--accent-gold);background:#b8860b0d;border-style:solid}.vocab-restore-hint{font-family:var(--font-mono);color:var(--accent-gold);opacity:.8;margin-top:.25rem;font-size:.7rem}.vocab-image{object-fit:cover;border:1px solid var(--border);background:var(--bg-primary);border-radius:4px;width:48px;height:48px}.vocab-content{flex:1;min-width:0}.vocab-word{font-family:var(--font-mono);color:var(--text-primary);margin-bottom:.125rem;font-size:.95rem;font-weight:600}.vocab-chinese{font-family:var(--font-mono);color:var(--text-muted);font-size:.8rem}.vocab-remove{background:var(--bg-primary);border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex}.vocab-remove:hover{color:#ef4444;background:#ef44441a;border-color:#ef44444d}.vocab-loading,.vocab-error,.vocab-empty{padding:var(--space-2xl) var(--space-lg);text-align:center;font-family:var(--font-mono);flex:1}.vocab-loading{color:var(--text-muted)}.vocab-loading:before{content:"◌";margin-bottom:var(--space-sm);font-size:2rem;animation:1s linear infinite spin;display:block}.vocab-error{color:#c44}.vocab-empty{color:var(--text-muted);line-height:1.6}.vocab-empty:before{content:"📝";margin-bottom:var(--space-md);opacity:.5;font-size:2.5rem;display:block}.vocab-footer{justify-content:center;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-top:1px solid var(--border);font-family:var(--font-mono);color:var(--text-muted);flex-shrink:0;font-size:.8rem;display:flex}.vocab-footer:before,.vocab-footer:after{content:"";background:var(--border-light);flex:1;height:1px}.vocab-list::-webkit-scrollbar{width:6px}.vocab-list::-webkit-scrollbar-track{background:0 0}.vocab-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.vocab-list::-webkit-scrollbar-thumb:hover{background:var(--accent-gold)}@media (width<=640px){.vocab-dialog{margin:var(--space-sm);max-height:calc(100vh - var(--space-lg))}.vocab-title{font-size:1.1rem}.vocab-header,.vocab-search{padding:var(--space-sm) var(--space-md)}}.upload-section,.upload-zone{position:relative}.upload-frame{padding:var(--space-xl);background:var(--bg-secondary);border-radius:4px;flex-direction:column;justify-content:center;align-items:center;min-height:280px;display:flex;position:relative}.frame-corner{border:2px solid var(--accent-gold);opacity:.4;width:24px;height:24px;transition:all .4s var(--ease-out);position:absolute}.frame-tl{border-bottom:none;border-right:none;top:12px;left:12px}.frame-tr{border-bottom:none;border-left:none;top:12px;right:12px}.frame-bl{border-top:none;border-right:none;bottom:12px;left:12px}.frame-br{border-top:none;border-left:none;bottom:12px;right:12px}.upload-zone:hover .frame-corner,.upload-zone.drag-over .frame-corner{opacity:.8;width:32px;height:32px}.upload-zone.login-required .upload-frame{background:var(--bg-tertiary);border:2px dashed var(--border)}.upload-zone.login-required .frame-corner{opacity:.2}.login-prompt{opacity:.7}.login-prompt:hover{opacity:1}.login-prompt .upload-icon{color:var(--text-secondary);opacity:.8}.upload-zone.login-required:hover .upload-icon{color:var(--accent-gold);transform:translateY(-4px)}.upload-content{text-align:center;cursor:pointer;transition:all .4s var(--ease-out);padding:var(--space-xl)}.upload-zone:hover .upload-content{transform:scale(1.02)}.upload-icon{color:var(--text-muted);margin-bottom:var(--space-md);opacity:.6;transition:all .4s var(--ease-out)}.upload-zone:hover .upload-icon{color:var(--accent-gold);opacity:1;transform:translateY(-4px)}.upload-text{gap:var(--space-xs);margin-bottom:var(--space-sm);flex-direction:column;display:flex}.upload-primary{font-family:var(--font-display);color:var(--text-primary);font-size:1.3rem;font-weight:600}.upload-secondary{font-family:var(--font-mono);color:var(--text-muted);font-size:.8rem}.upload-formats{font-family:var(--font-mono);color:var(--text-muted);opacity:.6;letter-spacing:.1em;font-size:.7rem}.image-preview{width:100%;max-width:400px;margin:0 auto;display:none;position:relative}.image-preview.active{animation:developImage 1s var(--ease-out) forwards;display:block}.image-preview img{width:100%;height:auto;box-shadow:0 4px 20px var(--shadow), 0 0 0 1px var(--border);filter:sepia(15%)contrast(1.05);border-radius:3px}.preview-overlay{top:var(--space-sm);right:var(--space-sm);position:absolute}.remove-image{background:var(--bg-primary);border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);transition:all .3s var(--ease-out);border-radius:50%;justify-content:center;align-items:center;display:flex}.remove-image:hover{border-color:var(--accent-copper);color:var(--accent-copper);background:#fff;transform:rotate(90deg)}.scanning-overlay{justify-content:center;align-items:center;gap:var(--space-lg);background:#f5f1e8f2;border-radius:4px;flex-direction:column;display:none;position:absolute;inset:0}.scanning-overlay.active{display:flex}.loupe{width:80px;height:80px;animation:2s ease-in-out infinite loupeScan;position:relative}.loupe-ring{border:3px solid var(--accent-gold);opacity:.6;border-radius:50%;position:absolute;inset:0}.loupe-handle{background:var(--accent-copper);transform-origin:0;border-radius:4px;width:30px;height:8px;position:absolute;bottom:-15px;right:-15px;transform:rotate(45deg)}.loupe-glass{background:radial-gradient(circle at 30% 30%,#ffffff4d,#0000 60%);border-radius:50%;position:absolute;inset:8px}.scan-line{background:linear-gradient(90deg, transparent, var(--accent-gold), transparent);height:2px;animation:2s ease-in-out infinite scanSweep;position:absolute;top:50%;left:10%;right:10%}.scan-text{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.15em;font-size:.8rem;animation:1.5s ease-in-out infinite pulse}.upload-zone.drag-over .upload-frame{background:var(--bg-tertiary);border:2px dashed var(--accent-gold)}.upload-zone.drag-over .upload-icon{color:var(--accent-gold);transform:scale(1.1)}.error-message{margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);border:1px solid var(--accent-copper);color:var(--accent-copper);font-family:var(--font-mono);text-align:center;animation:shake .5s var(--ease-out);background:#b873331a;border-radius:4px;font-size:.8rem}.analyze-btn{justify-content:center;align-items:center;gap:var(--space-sm);width:100%;margin-top:var(--space-lg);padding:var(--space-md) var(--space-xl);font-family:var(--font-display);color:var(--bg-primary);background:linear-gradient(135deg, var(--text-primary), var(--text-secondary));cursor:pointer;transition:all .4s var(--ease-out);box-shadow:0 4px 15px var(--shadow);border:none;border-radius:4px;font-size:1.1rem;font-weight:600;display:flex;position:relative;overflow:hidden}.analyze-btn:hover:not(:disabled){box-shadow:0 6px 20px var(--shadow-deep);transform:translateY(-2px)}.analyze-btn:active:not(:disabled){transform:translateY(0)}.analyze-btn:disabled{opacity:.5;cursor:not-allowed;background:var(--text-muted)}.btn-icon{font-size:1.2rem}.btn-shine{background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .6s;position:absolute;top:0;left:-100%}.analyze-btn:hover:not(:disabled) .btn-shine{left:100%}.apikey-hint{justify-content:center;align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);border:1px dashed var(--accent-gold);color:var(--accent-gold);font-family:var(--font-mono);text-align:center;animation:fadeInUp .4s var(--ease-out);background:#b8860b14;border-radius:4px;font-size:.8rem;display:flex}.hint-icon{font-size:1rem}.hint-text{letter-spacing:.02em}.markers-section{animation:fadeInUp .6s var(--ease-out) forwards;position:relative}.markers-instruction{justify-content:center;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border);font-family:var(--font-mono);color:var(--text-secondary);border-radius:4px;font-size:.8rem;display:flex}.instruction-icon{font-size:1rem}.instruction-text{letter-spacing:.05em}.image-marker-container{width:100%;box-shadow:0 8px 30px var(--shadow-deep);cursor:crosshair;border-radius:4px;display:block;position:relative;overflow:visible}.marker-image{filter:sepia(10%)contrast(1.02);width:100%;height:auto;display:block}.point-marker{cursor:pointer;z-index:10;position:absolute;transform:translate(-50%,-50%)}.point-marker:hover{z-index:20}.point-pulse{border:2px solid var(--accent-gold);opacity:0;pointer-events:none;border-radius:50%;width:32px;height:32px;animation:2s ease-out infinite pointPulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.point-marker:nth-child(2) .point-pulse{animation-delay:.2s}.point-marker:nth-child(3) .point-pulse{animation-delay:.4s}.point-marker:nth-child(4) .point-pulse{animation-delay:.6s}.point-marker:nth-child(5) .point-pulse{animation-delay:.8s}@keyframes pointPulse{0%{opacity:.8;transform:translate(-50%,-50%)scale(.5)}to{opacity:0;transform:translate(-50%,-50%)scale(1.5)}}.point-dot{background:var(--accent-gold);width:28px;height:28px;transition:all .3s var(--ease-out);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative;box-shadow:0 2px 8px #b8860b66}.point-marker:hover .point-dot,.point-marker.selected .point-dot{background:var(--accent-copper);transform:scale(1.2);box-shadow:0 4px 15px #b8733380}.point-inner{font-family:var(--font-mono);color:var(--bg-primary);font-size:.7rem;font-weight:600}.point-marker.selected:before{content:"";border:2px solid var(--accent-copper);border-radius:50%;width:40px;height:40px;animation:1.5s ease-in-out infinite selectionRing;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes selectionRing{0%,to{opacity:.6;transform:translate(-50%,-50%)scale(1)}50%{opacity:.3;transform:translate(-50%,-50%)scale(1.2)}}.point-tooltip{z-index:100;padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border:2px solid var(--accent-gold);box-shadow:0 4px 20px var(--shadow-deep);animation:tooltipAppear .3s var(--ease-out) forwards;pointer-events:auto;white-space:nowrap;border-radius:4px;flex-direction:column;align-items:center;min-width:160px;display:flex;position:absolute;bottom:100%;left:50%;transform:translate(-50%)translateY(-12px)}.point-tooltip.tooltip-bottom{animation:tooltipAppearBottom .3s var(--ease-out) forwards;top:100%;bottom:auto;transform:translate(-50%)translateY(12px)}.point-tooltip.tooltip-bottom .tooltip-arrow{border-top:none;border-bottom:8px solid var(--accent-gold);top:-8px;bottom:auto}.tooltip-content{flex-direction:column;align-items:center;gap:2px;display:flex}.tooltip-name{font-family:var(--font-display);color:var(--text-primary);font-size:1.1rem;font-weight:600}.tooltip-english{font-family:var(--font-mono);color:var(--text-secondary);font-size:.75rem;font-style:italic}.tooltip-arrow{border-left:8px solid #0000;border-right:8px solid #0000;border-top:8px solid var(--accent-gold);width:0;height:0;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}.tooltip-favorite-btn{margin-top:var(--space-sm);border:1px solid var(--accent-gold);font-family:var(--font-mono);color:var(--accent-gold);cursor:pointer;transition:all .2s var(--ease-out);pointer-events:auto;touch-action:manipulation;background:0 0;border-radius:4px;justify-content:center;align-items:center;gap:4px;padding:4px 10px;font-size:16px;display:flex}.tooltip-favorite-btn:hover:not(:disabled){background:var(--accent-gold);color:var(--bg-primary)}.tooltip-favorite-btn:disabled{cursor:not-allowed;opacity:.6}.tooltip-favorite-btn.favorited{background:var(--accent-gold);color:var(--bg-primary);border-color:var(--accent-gold)}.tooltip-favorite-btn.adding .favorite-spinner{animation:1s linear infinite spin;display:inline-block}@keyframes tooltipAppear{0%{opacity:0;transform:translate(-50%)translateY(-6px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(-12px)scale(1)}}@keyframes tooltipAppearBottom{0%{opacity:0;transform:translate(-50%)translateY(6px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(12px)scale(1)}}@media (width<=640px){.point-dot{width:24px;height:24px}.point-inner{font-size:.6rem}.point-pulse{width:28px;height:28px}.point-tooltip{min-width:140px;padding:var(--space-xs) var(--space-sm)}.tooltip-name{font-size:.95rem}.tooltip-english{font-size:.7rem}}.results-section{position:relative}.results-container{gap:var(--space-md);display:grid}.results-empty{text-align:center;padding:var(--space-2xl);color:var(--text-muted);border:2px dashed var(--border-light);border-radius:4px;font-style:italic}.empty-text{font-family:var(--font-mono);letter-spacing:.05em;font-size:.85rem}.error-result{padding:var(--space-md) var(--space-lg);border:1px solid var(--accent-copper);color:var(--accent-copper);font-family:var(--font-mono);text-align:center;animation:shake .5s var(--ease-out);background:#b873331a;border-radius:4px;font-size:.85rem}.specimen-card{align-items:flex-start;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border:1px solid var(--border);animation:cardAppear .5s var(--ease-out) forwards;opacity:0;box-shadow:0 2px 8px var(--shadow), inset 0 1px 0 #ffffff80;cursor:pointer;transition:all .3s var(--ease-out);border-radius:3px;display:flex;position:relative;transform:translateY(20px)rotate(-.5deg)}.specimen-card:nth-child(2n){transform:translateY(20px)rotate(.5deg)}.specimen-card:hover{border-color:var(--accent-gold);box-shadow:0 4px 12px var(--shadow-deep);transform:translateY(-2px)rotate(0)}.specimen-card.selected{border-color:var(--accent-gold);background:#b8860b14;border-width:2px;transform:translateY(-2px)rotate(0);box-shadow:0 4px 15px #b8860b26}.specimen-number{min-width:36px;height:36px;font-family:var(--font-mono);color:var(--accent-gold);background:var(--bg-primary);border:1px solid var(--border);transition:all .3s var(--ease-out);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:500;display:flex;box-shadow:inset 0 1px 2px #0000000d}.specimen-card:hover .specimen-number,.specimen-card.selected .specimen-number{background:var(--accent-gold);color:var(--bg-primary);border-color:var(--accent-gold)}.specimen-content{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.specimen-name{font-family:var(--font-display);color:var(--text-primary);word-break:break-word;font-size:1.2rem;font-weight:600}.specimen-english{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.02em;font-size:.85rem;font-style:italic;font-weight:400}.specimen-divider{background:linear-gradient(90deg, transparent, var(--border-light), transparent);height:1px;position:absolute;bottom:0;left:5%;right:5%}.specimen-indicator{background:var(--accent-gold);border-radius:0 2px 2px 0;width:4px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.favorite-btn{border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex}.favorite-btn:hover:not(:disabled){color:#4a90e2;background:#4a90e21a;border-color:#4a90e2;transform:scale(1.1)}.favorite-btn.favorited{color:#4a90e2;cursor:default;background:#4a90e226;border-color:#4a90e2}.favorite-btn.adding{cursor:wait}.favorite-spinner{animation:1s linear infinite spin;display:inline-block}@media (width<=640px){.specimen-card{gap:var(--space-sm);flex-direction:column}.specimen-card:hover,.specimen-card.selected{transform:translateY(-1px)rotate(0)}.specimen-number{align-self:flex-start}}.archive-footer{text-align:center;padding:var(--space-2xl) var(--space-lg);margin-top:auto}.footer-line{background:linear-gradient(90deg, transparent, var(--border), transparent);width:120px;height:1px;margin:0 auto var(--space-md)}.footer-text{font-family:var(--font-mono);color:var(--text-muted);justify-content:center;align-items:center;gap:var(--space-sm);flex-wrap:wrap;font-size:.7rem;display:flex}.footer-archive{letter-spacing:.1em}.footer-divider{opacity:.4}.footer-powered{opacity:.7}.archive-app{flex-direction:column;min-height:100vh;display:flex}.archive-container{width:100%;max-width:720px;padding:0 var(--space-lg) var(--space-3xl);gap:var(--space-2xl);flex-direction:column;margin:0 auto;display:flex}@media (width<=640px){.archive-container{padding:0 var(--space-md) var(--space-2xl);gap:var(--space-xl)}}
