.login-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:1rem;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="25" cy="25" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="75" cy="75" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="50" cy="10" r="0.5" fill="rgba(255,255,255,0.05)"/><circle cx="10" cy="60" r="0.5" fill="rgba(255,255,255,0.05)"/><circle cx="90" cy="40" r="0.5" fill="rgba(255,255,255,0.05)"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');opacity:.3}.login-container{background:#fffffff2;border-radius:20px;box-shadow:0 20px 40px #0000001a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);width:100%;max-width:450px;position:relative;z-index:1;animation:slideInUp .6s cubic-bezier(.4,0,.2,1)}.login-header{text-align:center;padding:2rem 2rem 1rem;border-bottom:1px solid #e2e8f0}.logo{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1rem}.logo-icon{font-size:2.5rem;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.logo h1{margin:0;color:#2d3748;font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{margin:0;color:#718096;font-size:1rem;line-height:1.5}.login-form-container{padding:2rem}.form-tabs{display:flex;background:#f7fafc;border-radius:8px;padding:4px;margin-bottom:2rem}.tab-btn{flex:1;padding:.75rem 1rem;border:none;background:transparent;color:#718096;font-size:1rem;font-weight:600;cursor:pointer;border-radius:6px;transition:all .2s}.tab-btn.active{background:#fff;color:#3182ce;box-shadow:0 2px 4px #0000001a}.tab-btn:hover:not(.active){color:#4a5568}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#4a5568;font-weight:600;font-size:.9rem}.form-group input{padding:.875rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s;background:#fff}.form-group input.error{border-color:#e53e3e;box-shadow:0 0 0 3px #e53e3e1a}.error-text{color:#e53e3e;font-size:.8rem;margin-top:.25rem}.required-mark{color:#e53e3e;font-weight:700;margin-left:.2rem}.general-error{background:#fed7d7;color:#c53030;padding:.75rem;border-radius:6px;border:1px solid #feb2b2;margin-bottom:1rem}.success-message{background:#c6f6d5;color:#276749;padding:.75rem;border-radius:6px;border:1px solid #9ae6b4;margin-bottom:1rem;animation:slideInDown .3s ease-out}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.success-content{display:flex;align-items:center;gap:.75rem}.success-icon{font-size:1rem;flex-shrink:0}.success-text{flex:1;font-weight:500}.error-content{display:flex;align-items:center;gap:.5rem}.error-icon{font-size:1rem;flex-shrink:0}.error-text{flex:1;font-weight:500}.error-close{background:none;border:none;color:#c53030;cursor:pointer;font-size:1rem;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;flex-shrink:0}.error-close:hover{background:#c530301a;transform:scale(1.1)}.submit-btn{background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;border:none;padding:1rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #3182ce4d}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{padding:1.5rem 2rem 2rem;border-top:1px solid #e2e8f0}.features h3{margin:0 0 1rem;color:#2d3748;font-size:1.1rem;font-weight:600;text-align:center}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.feature-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;background:#f8fafc;border-radius:8px;transition:all .2s}.feature-item:hover{background:#e2e8f0;transform:translateY(-2px)}.feature-icon{font-size:1.5rem}.feature-item span:last-child{font-size:.8rem;color:#4a5568;font-weight:500;text-align:center}@media screen and (orientation: landscape) and (max-height: 600px){.login-page{padding:.5rem}.login-container{max-width:800px;display:grid;grid-template-columns:1fr 1fr;gap:2rem}.login-header{padding:1.5rem 1.5rem 1rem;border-bottom:none;border-right:1px solid #e2e8f0}.logo h1{font-size:1.5rem}.subtitle{font-size:.9rem}.login-form-container{padding:1.5rem}.form-group{gap:.4rem}.form-group input{padding:.75rem;font-size:.9rem}.submit-btn{padding:.875rem;font-size:.9rem}.login-footer{padding:1rem 1.5rem 1.5rem;border-top:none;border-left:1px solid #e2e8f0}.feature-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.feature-item{padding:.5rem}.feature-icon{font-size:1.25rem}.feature-item span:last-child{font-size:.75rem}}@media screen and (orientation: portrait) and (max-width: 480px){.login-page{padding:.75rem}.login-container{max-width:100%}.login-header{padding:1.5rem 1.5rem 1rem}.logo h1{font-size:1.5rem}.login-form-container{padding:1.5rem}.login-footer{padding:1rem 1.5rem 1.5rem}.feature-grid{grid-template-columns:repeat(2,1fr)}}@media screen and (min-width: 768px) and (max-width: 1024px){.login-container{max-width:600px}.feature-grid{grid-template-columns:repeat(3,1fr)}}@media screen and (min-width: 1024px){.login-container{max-width:500px}}.login-type-selector{display:flex;gap:.5rem;background:#f7fafc;border-radius:8px;padding:4px}.type-btn{flex:1;padding:.75rem 1rem;border:none;background:transparent;color:#146cef;font-size:.9rem;font-weight:600;cursor:pointer;border-radius:6px;transition:all .2s}.type-btn.active{background:#fff;color:#0c85f7;box-shadow:0 2px 4px #0000001a}.type-btn:hover:not(.active){color:#4a5568}.guest-login{margin-top:1.5rem;text-align:center}.divider{position:relative;margin:1rem 0}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e2e8f0}.divider span{background:#fff;padding:0 1rem;color:#718096;font-size:.9rem;position:relative;z-index:1}.dev-login-btn{width:100%;padding:.9rem 1.5rem;background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-bottom:.5rem}.dev-login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #3182ce4d}.dev-login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.dev-note{color:#4299e1;font-size:.8rem;margin:0 0 1rem;line-height:1.4;text-align:center;font-weight:500}.guest-btn{width:100%;padding:.9rem 1.5rem;background:linear-gradient(135deg,#38a169,#68d391);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-bottom:.75rem}.guest-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #38a1694d}.guest-note{color:#718096;font-size:.8rem;margin:0;line-height:1.4}.admin-setup-btn{width:100%;padding:.75rem 1rem;background:linear-gradient(135deg,#ed8936,#f6ad55);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:1rem;box-shadow:0 4px 12px #ed89364d}.admin-setup-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ed893666}.register-link{text-align:center;margin-top:1rem;font-size:.9rem;color:#718096}.register-link-btn{background:none;border:none;color:#3182ce;font-size:.9rem;font-weight:600;cursor:pointer;text-decoration:underline;padding:0;margin-left:.25rem;transition:color .2s}.register-link-btn:hover{color:#2c5aa0;text-decoration:none}.word-search-chat-style{width:100%;max-width:900px;margin:0 auto;padding:0;display:flex;flex-direction:column;position:relative}.language-selector-simple{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fff;border-bottom:1px solid #e0e0e0;gap:16px}.lang-option{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;font-size:25px;font-weight:500;color:#333;cursor:pointer;padding:8px 12px;border-radius:6px;transition:background .2s}.lang-option:hover{background:#f5f5f5}.dropdown-icon{font-size:10px;color:#666;transition:transform .2s}.lang-option:hover .dropdown-icon{transform:translateY(2px)}.swap-btn-simple{background:transparent;border:none;color:#1976d2;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:24px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.swap-btn-simple:hover{background:#1976d21a;transform:rotate(180deg)}.swap-btn-simple:active{transform:rotate(180deg) scale(.9)}.bottom-input-bar{display:flex;align-items:center;gap:12px;padding:20px;background:#fff;border-top:1px solid #e0e0e0;position:fixed;bottom:0;left:0;right:0;z-index:9999;box-shadow:0 -2px 10px #00000014;width:100%;max-width:100vw}.input-wrapper{flex:1;display:flex;align-items:center;background:#f5f5f5;border-radius:24px;padding:0 16px;transition:all .2s}.input-wrapper:focus-within{background:#eee;box-shadow:0 0 0 2px #1976d21a}.chat-input{flex:1;border:none;background:transparent;padding:12px 8px;font-size:15px;line-height:1.5;color:#333;outline:none}.chat-input::placeholder{color:#999;font-size:14px}.voice-icon-btn{background:transparent;border:none;color:#666;font-size:20px;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.voice-icon-btn:hover{color:#1976d2;transform:scale(1.1)}.voice-icon-btn:active{transform:scale(.95)}.send-btn{background:#1976d2;color:#fff;border:none;padding:11px 28px;border-radius:24px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;box-shadow:0 2px 8px #1976d24d}.send-btn:hover:not(:disabled){background:#1565c0;box-shadow:0 4px 12px #1976d266;transform:translateY(-1px)}.send-btn:active:not(:disabled){transform:translateY(0)}.send-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}@media (max-width: 768px){.language-selector-simple{padding:12px 16px}.lang-option{font-size:14px;padding:6px 8px}.swap-btn-simple{width:36px;height:36px;font-size:20px}.bottom-input-bar{padding:12px 16px;gap:10px}.chat-input{font-size:14px;padding:10px 6px}.send-btn{padding:10px 24px;font-size:14px}}@media (max-width: 480px){.language-selector-simple{padding:10px 12px;gap:12px}.lang-option{font-size:13px}.bottom-input-bar{padding:10px 12px}.input-wrapper{padding:0 12px}.send-btn{padding:9px 20px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.word-search-chat-style{animation:fadeIn .3s ease-out}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.confirm-modal{background:#fff;border-radius:16px;padding:0;max-width:420px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out;overflow:hidden}.modal-header{padding:20px 24px;border-bottom:1px solid #e2e8f0;background:linear-gradient(135deg,#ebf8ff,#bee3f8)}.modal-header.confirm{background:linear-gradient(135deg,#ebf8ff,#bee3f8)}.modal-header.alert{background:linear-gradient(135deg,#fff5f5,#fed7d7)}.modal-header.warning{background:linear-gradient(135deg,#fffaf0,#feebc8)}.modal-header.error{background:linear-gradient(135deg,#fff5f5,#fed7d7)}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#2d3748;text-align:center}.modal-header.alert h3,.modal-header.error h3{color:#c53030}.modal-header.warning h3{color:#c05621}.modal-body p{margin:0;font-size:1rem;color:#2d3748;line-height:1.6}.modal-footer:has(.modal-btn-cancel){justify-content:space-between}.modal-footer:not(:has(.modal-btn-cancel)){justify-content:center}.modal-btn{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:100px}.modal-btn-confirm{background:linear-gradient(135deg,#3182ce,#2c5282);color:#fff}.modal-btn-confirm:hover{background:linear-gradient(135deg,#2c5282,#2a4a73);transform:translateY(-1px);box-shadow:0 4px 12px #3182ce4d}.modal-btn-confirm.alert{background:linear-gradient(135deg,#e53e3e,#c53030)}.modal-btn-confirm.alert:hover{background:linear-gradient(135deg,#c53030,#9b2c2c);box-shadow:0 4px 12px #c530304d}.modal-btn-confirm.warning{background:linear-gradient(135deg,#d69e2e,#b7791f)}.modal-btn-confirm.warning:hover{background:linear-gradient(135deg,#b7791f,#975a16);box-shadow:0 4px 12px #b7791f4d}.modal-btn-confirm.error{background:linear-gradient(135deg,#e53e3e,#c53030)}.modal-btn-confirm.error:hover{background:linear-gradient(135deg,#c53030,#9b2c2c);box-shadow:0 4px 12px #c530304d}@media (max-width: 480px){.confirm-modal{max-width:95%;margin:0 10px}.modal-header h3{font-size:1.1rem}.modal-body{padding:20px}.modal-body p{font-size:.95rem}.modal-footer{padding:12px 20px}.modal-btn{padding:10px 20px;font-size:.95rem}}.translation-result-chat-style{width:100%;max-width:900px;margin:20px auto;padding:0 20px;animation:bubbleSlideUp .4s ease-out}@keyframes bubbleSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.translation-bubble{background:linear-gradient(135deg,#e3f2fd,#e8eaf6);border-radius:16px;padding:20px;position:relative;box-shadow:0 2px 12px #00000014;transition:all .3s ease}.translation-bubble:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.original-text{font-size:17px;line-height:1.6;color:#212121;font-weight:500;margin-bottom:16px;word-wrap:break-word;word-break:break-word}.translated-text{font-size:18px;line-height:1.7;color:#1565c0;font-weight:500;margin-bottom:40px;word-wrap:break-word;word-break:break-word}.translated-text div:not(:last-child){margin-bottom:8px}.no-data{color:#9e9e9e;font-style:italic;font-size:15px}.bubble-actions{position:absolute;bottom:16px;right:20px;display:flex;gap:16px;align-items:center}.icon-btn{background:transparent;border:none;color:#1976d2;font-size:18px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:.7}.icon-btn:hover:not(:disabled){opacity:1;transform:scale(1.15)}.icon-btn:active:not(:disabled){transform:scale(.95)}.icon-btn.active{opacity:1;animation:iconPulse 1.5s ease-in-out infinite;color:#1565c0}.icon-btn.success{opacity:1;color:#4caf50;animation:iconSuccess .5s ease-out}@keyframes iconPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}@keyframes iconSuccess{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.detail-section{background:#fff;border-radius:12px;padding:16px;margin-top:12px;box-shadow:0 2px 8px #0000000f}.detail-section summary{cursor:pointer;font-size:14px;font-weight:600;color:#1976d2;padding:8px;border-radius:6px;transition:all .2s;list-style:none;display:flex;align-items:center;gap:6px}.detail-section summary::-webkit-details-marker{display:none}.detail-section summary:before{content:"▶";font-size:10px;transition:transform .3s}.detail-section[open] summary:before{transform:rotate(90deg)}.detail-section summary:hover{background:#1976d20d}.detail-content{margin-top:12px;padding-top:12px;border-top:1px solid #e0e0e0}.basic-info{margin-bottom:16px}.basic-info h4{font-size:15px;font-weight:600;color:#424242;margin-bottom:10px;display:flex;align-items:center;gap:6px}.phonetics{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:10px;padding:10px 12px;background:#f5f5f5;border-radius:6px}.phonetic-item{display:flex;align-items:center;gap:4px;font-size:13px}.phonetic-label{color:#757575;font-weight:500}.phonetic-text{color:#424242;font-family:monospace;font-weight:600}.explains{display:flex;flex-direction:column;gap:6px}.explain-item{padding:6px 10px;background:#f5f5f5;border-left:3px solid #1976d2;border-radius:3px;font-size:14px;line-height:1.4;color:#424242}.web-translations{margin-top:16px}.web-translations h4{font-size:15px;font-weight:600;color:#424242;margin-bottom:10px;display:flex;align-items:center;gap:6px}.web-list{display:flex;flex-direction:column;gap:8px}.web-item{padding:10px 12px;background:#f5f5f5;border-radius:6px;transition:all .2s}.web-item:hover{background:#e3f2fd;transform:translate(4px)}.web-key{font-weight:600;color:#1976d2;font-size:14px;margin-bottom:4px}.web-value{color:#616161;font-size:13px;line-height:1.4}@media (max-width: 768px){.translation-result-chat-style{padding:0 16px;margin:16px auto}.translation-bubble{padding:16px}.original-text{font-size:16px;margin-bottom:14px}.translated-text{font-size:17px;margin-bottom:36px}.bubble-actions{gap:14px;bottom:14px;right:16px}.icon-btn{font-size:16px;width:22px;height:22px}.detail-section{padding:14px}}@media (max-width: 480px){.translation-result-chat-style{padding:0 12px}.translation-bubble{padding:14px;border-radius:12px}.original-text{font-size:15px;margin-bottom:12px}.translated-text{font-size:16px;margin-bottom:32px}.bubble-actions{gap:12px;bottom:12px;right:14px}.icon-btn{font-size:15px;width:20px;height:20px}.phonetics{flex-direction:column;gap:6px}}@media print{.bubble-actions,.detail-section summary{display:none}.detail-section[open]{page-break-inside:avoid}.translation-bubble{box-shadow:none;border:1px solid #e0e0e0}}.ecdict-result{background:#fff;border-radius:0;padding:0;box-shadow:none;animation:fadeInUp .6s cubic-bezier(.4,0,.2,1);overflow:hidden}.result-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem;color:#fff;display:flex;justify-content:space-between;align-items:flex-start;position:relative;gap:1rem;min-height:120px}.word-info{flex:1;text-align:center;padding-right:140px}.word-text{font-size:3rem;font-weight:800;color:#fff;margin:0 0 .5rem;text-shadow:0 4px 8px rgba(0,0,0,.2);letter-spacing:-.02em}.source-tag{background:#fff3;color:#fff;padding:.5rem 1.25rem;border-radius:20px;font-size:.85rem;font-weight:600;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-block}.result-content{padding:2rem;background:#fff}.phonetic-section,.pos-section,.translation-section,.definition-section,.detail-section,.exchange-section,.frequency-section,.tag-section,.audio-section{background:#f8fafc;border-radius:16px;padding:1.5rem;border:1px solid #e2e8f0;margin-bottom:1.5rem;transition:all .2s ease}.phonetic-section:hover,.pos-section:hover,.translation-section:hover,.definition-section:hover,.detail-section:hover,.exchange-section:hover,.frequency-section:hover,.tag-section:hover,.audio-section:hover{border-color:#cbd5e0;box-shadow:0 4px 12px #0000000d}.phonetic-section h4,.pos-section h4,.translation-section h4,.definition-section h4,.detail-section h4,.exchange-section h4,.frequency-section h4,.tag-section h4,.audio-section h4{color:#2d3748;font-size:1.1rem;font-weight:700;margin:0 0 1rem;padding-bottom:.75rem;border-bottom:2px solid #3182ce;display:flex;align-items:center;gap:.5rem}.phonetic-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.audio-controls{display:flex;gap:.5rem}.audio-btn{background:linear-gradient(135deg,#4299e1,#3182ce);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.25rem;box-shadow:0 2px 4px #3182ce4d}.audio-btn:hover{background:linear-gradient(135deg,#3182ce,#2c5282);transform:translateY(-1px);box-shadow:0 4px 8px #3182ce66}.audio-btn:active{transform:translateY(0);box-shadow:0 2px 4px #3182ce4d}.audio-btn:disabled{background:#a0aec0;cursor:not-allowed;transform:none;box-shadow:none}.audio-btn.playing{background:linear-gradient(135deg,#48bb78,#38a169);animation:pulse 1.5s infinite}.phonetic-text{color:#e53e3e;font-weight:600;font-size:1.3rem;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;background:#fed7d7;padding:.5rem 1rem;border-radius:8px;display:inline-block}.pos-text{color:#3182ce;font-weight:600;font-size:1.1rem;background:#bee3f8;padding:.4rem .8rem;border-radius:20px;display:inline-block}.translation-text{color:#2d3748;font-size:1.1rem;line-height:1.6;font-weight:500}.definition-text{color:#4a5568;font-size:1rem;line-height:1.6;font-style:italic}.detail-text{color:#4a5568;font-size:1rem;line-height:1.6}.exchange-text{display:flex;flex-direction:column;gap:.75rem}.exchange-item{display:flex;align-items:center;padding:.75rem 1rem;background:#edf2f7;border-radius:12px;border-left:4px solid #3182ce;transition:all .2s ease}.exchange-item:hover{background:#e2e8f0;transform:translate(2px)}.exchange-type{color:#3182ce;font-weight:700;min-width:120px;font-size:.9rem}.exchange-form{color:#2d3748;font-weight:600;margin-left:1rem;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;background:#fff;padding:.25rem .75rem;border-radius:6px;border:1px solid #e2e8f0}.frequency-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.frequency-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border-radius:12px;border:2px solid #e2e8f0;transition:all .2s ease}.frequency-item:hover{border-color:#3182ce;box-shadow:0 4px 12px #3182ce26}.frequency-label{color:#718096;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.frequency-value{color:#3182ce;font-weight:800;font-size:1.2rem}.tag-list{display:flex;flex-wrap:wrap;gap:.5rem}.tag-item{background:#fff;color:#4a5568;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;border:2px solid #e2e8f0;font-weight:600;transition:all .2s ease;cursor:default}.tag-item[title*=zk]{background:#dbeafe;border-color:#3b82f6;color:#1e40af}.tag-item[title*=gk]{background:#f3e8ff;border-color:#8b5cf6;color:#6b21a8}.tag-item[title*=ky]{background:#fed7aa;border-color:#f97316;color:#c2410c}.tag-item[title*=cet4]{background:#dcfce7;border-color:#22c55e;color:#15803d}.tag-item[title*=cet6]{background:#ecfdf5;border-color:#10b981;color:#047857}.tag-item[title*=toefl]{background:#fee2e2;border-color:#ef4444;color:#dc2626}.tag-item[title*=ielts]{background:#e0e7ff;border-color:#6366f1;color:#4338ca}.tag-item[title*=gre]{background:#f3f4f6;border-color:#6b7280;color:#374151}.audio-text{color:#fffc;font-size:1rem}.debug-info{margin-top:1.5rem;padding:1rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.debug-info summary{color:#fff;cursor:pointer;font-size:.9rem;margin-bottom:.5rem}.debug-info pre{background:#0000004d;padding:1rem;border-radius:8px;color:#fff;font-size:.8rem;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;max-height:300px;overflow-y:auto}@media (max-width: 768px){.result-header{padding:2rem 1.5rem 1.5rem;flex-direction:column;align-items:center;text-align:center;min-height:auto}.word-info{padding-right:0;width:100%}.result-actions{position:absolute;bottom:1rem;right:1rem;min-width:auto;z-index:1001}.favorite-btn{padding:.6rem 1rem;font-size:.9rem;min-width:85px;font-weight:700}.word-text{font-size:2.5rem}.source-tag{font-size:.75rem;padding:.4rem 1rem}.result-content{padding:1.5rem}.phonetic-section,.pos-section,.translation-section,.definition-section,.detail-section,.exchange-section,.frequency-section,.tag-section,.audio-section{padding:1.25rem;margin-bottom:1rem}.phonetic-section h4,.pos-section h4,.translation-section h4,.definition-section h4,.detail-section h4,.exchange-section h4,.frequency-section h4,.tag-section h4,.audio-section h4{font-size:1rem}.phonetic-header{flex-direction:column;align-items:flex-start;gap:1rem}.audio-controls{width:100%;justify-content:flex-start;flex-wrap:wrap}.audio-btn{padding:.4rem .8rem;font-size:.8rem;flex:1;min-width:80px}.phonetic-text{font-size:1rem}.pos-text,.translation-text,.definition-text,.detail-text,.exchange-text,.audio-text{font-size:.9rem}.exchange-item{flex-direction:column;align-items:flex-start;padding:.75rem}.exchange-type{min-width:auto;margin-bottom:.25rem;font-size:.8rem}.exchange-form{margin-left:0;font-size:.85rem}.frequency-grid{grid-template-columns:1fr;gap:.5rem}.frequency-item{padding:.4rem}.frequency-label{font-size:.8rem}.frequency-value{font-size:.9rem}.tag-item{padding:.2rem .6rem;font-size:.7rem}.debug-info{padding:.8rem}.debug-info summary{font-size:.8rem}.debug-info pre{font-size:.7rem;padding:.8rem}}.result-actions{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;flex-shrink:0;min-width:120px;position:absolute;bottom:1rem;right:1rem;z-index:1001}.favorite-btn{display:flex!important;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:2px solid rgba(255,255,255,.95);border-radius:10px;background:#ffffff59;color:#2d3748;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap;min-width:100px;justify-content:center;box-shadow:0 3px 12px #00000040;text-shadow:none}.favorite-btn:hover:not(:disabled){border-color:#fff;background:#ffffff80;transform:translateY(-1px);box-shadow:0 4px 16px #00000059}.favorite-btn.favorited{border-color:#ff6b6b;background:#ff6b6b;color:#fff;text-shadow:none}.favorite-btn.favorited:hover:not(:disabled){border-color:#ff5252;background:#ff5252;box-shadow:0 4px 16px #ff525280}.favorite-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.favorite-message{background:#38a169;color:#fff;padding:.4rem .8rem;border-radius:6px;font-size:.8rem;font-weight:500;animation:slideIn .3s ease-out;position:relative;z-index:1000;box-shadow:0 4px 12px #00000026;border:1px solid rgba(255,255,255,.2)}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.ecdict-query{background:#fff;border-radius:0;padding:1rem;margin-bottom:0;box-shadow:none}.query-header{text-align:center;margin-bottom:1rem}.query-header h3{color:#000;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.query-header p{color:#000;font-size:.9rem;margin:0}.loading-status{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem 1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;color:#000}.status-indicator{font-size:1rem}.status-indicator.loaded{color:#4caf50}.status-indicator.loading{color:#ffc107;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{color:#000000e6;font-size:.8rem}.query-form{width:100%}.query-container{display:flex;flex-direction:column;gap:1.5rem}.input-group{display:flex;gap:.5rem;align-items:center}.query-input{flex:1;padding:1rem 1.5rem;border:2px solid #e2e8f0;border-radius:12px;background:#fff;color:#2d3748;font-size:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000001a}.query-input::placeholder{color:#a0aec0}.query-input:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a}.query-btn{padding:1rem 1.5rem;border:2px solid #3182ce;border-radius:12px;background:#3182ce;color:#fff;font-size:1.2rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:60px;font-weight:600}.query-btn:hover:not(:disabled){background:#2c5aa0;border-color:#2c5aa0;transform:translateY(-2px);box-shadow:0 8px 25px #3182ce4d}.query-btn:disabled{opacity:.6;cursor:not-allowed}.clear-btn{padding:.5rem 1rem;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fffc;font-size:.9rem;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.clear-btn:hover{background:#fff3;color:#fff}.quick-tests{margin-top:1.5rem;padding:1rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.quick-tests p{color:#ffffffe6;margin-bottom:.5rem;font-size:.9rem}.word-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.word-btn{padding:.4rem .8rem;border:1px solid rgba(255,255,255,.3);border-radius:6px;background:#ffffff1a;color:#ffffffe6;font-size:.8rem;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.word-btn:hover{background:#fff3;color:#fff;transform:translateY(-1px)}.loading-container{text-align:center;margin:2rem 0;color:#2d3748;background:#ffffffe6;border-radius:12px;padding:2rem;border:1px solid #e2e8f0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.loading-detail{margin:.5rem 0;font-size:.9rem;color:#4a5568}.error-container{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:1.5rem;margin:1rem 0;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.error-message{color:#ff6b6b;font-size:1rem;margin:0 0 1rem}.suggestions{margin-top:1rem}.suggestions p{color:#fffc;margin-bottom:.5rem;font-size:.9rem}.suggestion-list{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.suggestion-btn{padding:.3rem .6rem;border:1px solid rgba(255,255,255,.3);border-radius:4px;background:#ffffff1a;color:#ffffffe6;font-size:.8rem;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.suggestion-btn:hover{background:#fff3;color:#fff}.query-tips{margin-top:1.5rem;padding:1rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(3,3,3,.1)}.query-tips h4{color:#000;margin:0 0 .5rem;font-size:1rem}.query-tips ul{color:#030303cc;margin:.5rem 0 0 1.5rem;font-size:.9rem}.query-tips li{margin:.25rem 0}@media (max-width: 768px){.ecdict-query{padding:1.5rem 1rem}.query-header{margin-bottom:1.5rem}.query-header h3{font-size:1.3rem}.query-container{gap:1rem}.input-group{flex-direction:column;gap:.75rem}.query-input{padding:.8rem 1rem;font-size:16px}.query-btn{padding:.8rem 1.5rem;font-size:1rem;width:100%}.clear-btn{padding:.4rem .8rem;font-size:.8rem}.word-buttons{gap:.3rem}.word-btn{padding:.3rem .6rem;font-size:.7rem}.loading-spinner{width:30px;height:30px}.suggestion-list{gap:.3rem}.suggestion-btn{padding:.2rem .5rem;font-size:.7rem}.query-tips{padding:.8rem}.query-tips h4{font-size:.9rem}.query-tips ul,.query-tips li{font-size:.8rem}}.ocr-scanner-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000;z-index:1000;display:flex;flex-direction:column;overflow:hidden}.scanner-header{position:absolute;top:0;left:0;right:0;height:60px;display:flex;justify-content:space-between;align-items:center;padding:0 20px;background:linear-gradient(to bottom,rgba(0,0,0,.7),transparent);z-index:1001}.close-btn{background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:50%;transition:background-color .2s}.close-btn:hover{background:#fff3}.scanner-controls{display:flex;gap:12px;align-items:center}.control-btn{background:#00000080;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.control-btn:hover{background:#fff3}.control-btn.active{background:#ffffff4d}.scanner-preview{flex:1;position:relative;overflow:hidden}.camera-video{width:100%;height:100%;object-fit:cover}.camera-placeholder{width:100%;height:100%;background:#1a1a1a;display:flex;align-items:center;justify-content:center}.error-message{text-align:center;color:#fff}.error-message p{margin-bottom:16px;font-size:16px}.retry-btn{background:#007aff;color:#fff;border:none;padding:10px 20px;border-radius:20px;cursor:pointer;font-size:14px}.retry-btn:hover{background:#0056cc}.scanner-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center}.scanner-frame{position:relative;width:280px;height:200px;border:2px solid transparent}.corner{position:absolute;width:30px;height:30px;border:3px solid #00FF00}.corner.top-left{top:-3px;left:-3px;border-right:none;border-bottom:none}.corner.top-right{top:-3px;right:-3px;border-left:none;border-bottom:none}.corner.bottom-left{bottom:-3px;left:-3px;border-right:none;border-top:none}.corner.bottom-right{bottom:-3px;right:-3px;border-left:none;border-top:none}.scan-line{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#00FF00,transparent);animation:scan 2s linear infinite}@keyframes scan{0%{transform:translateY(0);opacity:1}to{transform:translateY(200px);opacity:0}}.scan-hint{position:absolute;bottom:-60px;left:50%;transform:translate(-50%);text-align:center;color:#fff;background:#000000b3;padding:8px 16px;border-radius:20px;font-size:14px}.scan-hint p{margin:0}.scanner-footer{position:absolute;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);z-index:1001}.scanner-actions{display:flex;justify-content:center;margin-bottom:16px}.capture-btn{width:80px;height:80px;border-radius:50%;border:4px solid white;background:#fff3;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;position:relative}.capture-btn:hover{background:#ffffff4d;transform:scale(1.05)}.capture-btn:active{transform:scale(.95)}.capture-btn-inner{width:60px;height:60px;border-radius:50%;background:#fff;transition:all .2s}.capture-btn:hover .capture-btn-inner{background:#f0f0f0}.scanner-tips{text-align:center;color:#fff}.scanner-tips p{margin:0;font-size:14px;opacity:.8}.error-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1002}.error-content{text-align:center;color:#fff;padding:20px;background:#ffffff1a;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.error-content p{margin-bottom:16px;font-size:16px}@media (max-width: 768px){.scanner-header{height:50px;padding:0 16px}.scanner-frame{width:240px;height:160px}.corner{width:25px;height:25px;border-width:2px}.capture-btn{width:70px;height:70px;border-width:3px}.capture-btn-inner{width:50px;height:50px}.scanner-footer{padding:16px}.scan-hint{bottom:-50px;font-size:12px;padding:6px 12px}}@media (max-width: 480px){.scanner-frame{width:200px;height:140px}.corner{width:20px;height:20px;border-width:2px}.capture-btn{width:60px;height:60px}.capture-btn-inner{width:40px;height:40px}.scan-hint{bottom:-40px;font-size:11px}}.camera-controls{display:flex;gap:16px;justify-content:center;align-items:center;padding:20px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;margin:20px auto;max-width:400px}.camera-btn{padding:16px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;min-width:140px;justify-content:center;position:relative;overflow:hidden}.camera-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.camera-btn:hover:before{left:100%}.camera-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.camera-btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea99}.camera-btn.secondary{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;box-shadow:0 4px 15px #f093fb66}.camera-btn.secondary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #f093fb99}.camera-btn:active{transform:translateY(0);transition:transform .1s}@media (max-width: 768px){.camera-controls{flex-direction:column;gap:12px;padding:16px;margin:16px}.camera-btn{width:100%;min-width:auto;padding:14px 20px;font-size:15px}}.scanner-frame{animation:pulse 2s ease-in-out infinite}.scanner-frame.success{border-color:#0f0;animation:success-pulse .5s ease-in-out}@keyframes success-pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.scanner-overlay.loading .scan-line{animation:none;background:gold}.scanner-overlay.loading .corner{border-color:gold}.result-section{width:100%;max-width:100%;margin:0 auto;padding:16px;box-sizing:border-box}.image-preview{width:100%;max-width:100%;margin:0 auto 20px;text-align:center;position:relative;background:#f8f9fa;border-radius:12px;padding:16px;box-shadow:0 4px 12px #0000001a;box-sizing:border-box}.captured-image{max-width:100%;max-height:60vh;height:auto;width:auto;border-radius:8px;box-shadow:0 2px 8px #00000026;object-fit:contain;display:block;margin:0 auto}.image-controls{margin-top:16px;display:flex;flex-direction:column;gap:12px;align-items:center}.rotation-controls{display:flex;gap:12px;justify-content:center}.rotate-btn{padding:10px 16px;background:#fff;color:#667eea;border:2px solid #667eea;border-radius:8px;font-size:20px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 6px #667eea33;display:flex;align-items:center;justify-content:center;min-width:48px;height:48px}.rotate-btn:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.rotate-btn:active{transform:translateY(0)}.image-action-buttons{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.rescan-btn{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d}.rescan-btn.secondary{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d}.rescan-btn.recognize-btn{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 8px #f59e0b4d}.rescan-btn:hover{transform:translateY(-2px);box-shadow:0 4px 16px #667eea66}.rescan-btn.secondary:hover{box-shadow:0 4px 16px #10b98166}.rescan-btn.recognize-btn:hover{box-shadow:0 4px 16px #f59e0b66}.rescan-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.rescan-btn:active:not(:disabled){transform:translateY(0)}.text-result{width:100%;max-width:100%;margin:0 auto;background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 12px #0000001a;box-sizing:border-box}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.result-title{display:flex;align-items:center;gap:12px;flex:1;min-width:200px}.result-title h4{margin:0;color:#1a1a1a;font-size:18px;font-weight:600}.engine-badge{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.copy-btn,.save-btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px;white-space:nowrap}.copy-btn{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.copy-btn:hover{background:#e5e7eb;transform:translateY(-1px)}.copy-btn.success{background:#10b981;color:#fff;border-color:#10b981}.save-btn{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.save-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.save-btn.success{background:#10b981}.save-btn.loading{background:#9ca3af;cursor:not-allowed}.recognized-text{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:16px;font-size:16px;line-height:1.6;color:#1a1a1a;white-space:pre-wrap;word-wrap:break-word;max-height:400px;overflow-y:auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.no-text{text-align:center;color:#6b7280;font-style:italic;padding:40px 20px;background:#f9fafb;border-radius:8px;border:2px dashed #d1d5db}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:16px}.title-input-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;box-sizing:border-box}.title-input-content{background:#fff;border-radius:12px;padding:24px;width:100%;max-width:400px;box-shadow:0 20px 25px -5px #0000001a}.title-input-content h3{margin:0 0 8px;color:#1a1a1a;font-size:18px;font-weight:600}.title-input-desc{margin:0 0 16px;color:#6b7280;font-size:14px;line-height:1.5}.title-input{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:16px;margin-bottom:20px;box-sizing:border-box;transition:border-color .2s}.title-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.title-input-actions{display:flex;gap:12px;justify-content:flex-end}.cancel-btn,.confirm-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.cancel-btn{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.cancel-btn:hover{background:#e5e7eb}.confirm-btn{background:#3b82f6;color:#fff}.confirm-btn:hover:not(:disabled){background:#2563eb}.confirm-btn:disabled{background:#9ca3af;cursor:not-allowed}.processing{text-align:center;padding:40px 20px;background:#f8f9fa;border-radius:12px;margin:20px 0}.processing-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.processing p{margin:0;color:#374151;font-size:16px;font-weight:500}@media (max-width: 768px){.result-section{padding:12px}.image-preview{padding:12px;margin-bottom:16px}.captured-image{max-height:50vh}.text-result{padding:16px}.result-header{flex-direction:column;align-items:stretch;gap:12px}.result-title{min-width:auto;justify-content:center}.action-buttons{justify-content:center}.copy-btn,.save-btn{flex:1;min-width:120px;justify-content:center}.title-input-content{padding:20px;margin:0 16px}.title-input-actions{flex-direction:column}.cancel-btn,.confirm-btn{width:100%}}@media (max-width: 480px){.result-section{padding:8px}.image-preview{padding:8px;margin-bottom:12px}.captured-image{max-height:40vh}.text-result{padding:12px}.result-title h4{font-size:16px}.engine-badge{font-size:11px;padding:3px 8px}.copy-btn,.save-btn{padding:6px 12px;font-size:13px}.recognized-text{font-size:14px;padding:12px;max-height:300px}.title-input-content{padding:16px;margin:0 12px}.title-input{font-size:14px;padding:10px 12px}}.ocr-history{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 4px 6px #0000001a;animation:fadeInUp .6s cubic-bezier(.4,0,.2,1);min-height:100vh;display:flex;flex-direction:column}@media screen and (orientation: landscape) and (max-height: 600px){.ocr-history{padding:.5rem;border-radius:8px}.history-header{margin-bottom:.5rem;padding-bottom:.5rem}.history-header h3{font-size:1.2rem}.history-header p{font-size:.9rem}.search-section{margin-bottom:.5rem}.search-controls,.records-list{gap:.5rem}.record-item{padding:.5rem;gap:.5rem}.record-image{width:80px;height:80px}.record-content{flex:1;min-width:0}.record-text p,.record-text-content{font-size:.9rem;line-height:1.4}.edit-textarea{min-height:60px;font-size:.9rem}.read-btn,.edit-btn{font-size:.75rem;padding:.4rem .6rem}.save-btn,.cancel-btn{padding:.4rem .8rem;font-size:.8rem}.record-actions{gap:.25rem}.action-btn{padding:.3rem .5rem;font-size:.75rem;min-width:60px}.phonetics-text{margin-top:.5rem;padding:.5rem}.phonetics-title{font-size:.9rem;margin-bottom:.5rem}.phonetics-content{padding:.5rem}.word-phonetic-pair{margin:.03rem .05rem .03rem 0;padding:.1rem .2rem;min-width:35px}.english-word{font-size:.8rem}.phonetic{font-size:.65rem;padding:.05rem .1rem}}@media screen and (orientation: landscape) and (min-width: 768px) and (max-height: 500px){.ocr-history{padding:.75rem}.records-list{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.record-item{flex-direction:column;text-align:center}.record-image{width:100px;height:100px;align-self:center}.record-content{text-align:center}.record-actions{justify-content:center;flex-wrap:wrap}}@media screen and (orientation: landscape) and (min-width: 1024px){.records-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1rem}.record-item{flex-direction:row;text-align:left}.record-image{width:120px;height:120px}.record-content{text-align:left}.record-actions{justify-content:flex-start}}@media screen and (orientation: portrait) and (max-width: 480px){.ocr-history{padding:.75rem;border-radius:8px}.history-header h3{font-size:1.3rem}.search-controls{flex-direction:column;align-items:stretch;gap:.75rem}.search-input{width:100%}.record-item{flex-direction:column;text-align:center}.record-image{width:100%;height:200px;align-self:center}.record-content{text-align:center}.record-actions{justify-content:center;flex-wrap:wrap}.phonetics-content{padding:.5rem .25rem}}.history-header{text-align:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #e2e8f0}.history-header h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.history-header p{color:#718096;font-size:1rem;margin:0}.search-section{margin-bottom:1rem}.search-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.search-input{flex:1;min-width:200px;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s}.engine-select:focus{outline:none;border-color:#3182ce}.search-btn,.reset-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.search-btn{background:#3182ce;color:#fff}.search-btn:hover{background:#2c5aa0;transform:translateY(-1px)}.loading-section{text-align:center;padding:2rem 1rem}.error-section{text-align:center;padding:2rem;background:#fed7d7;border:1px solid #feb2b2;border-radius:8px;color:#c53030}.error-section button{margin-top:1rem;padding:.5rem 1rem;background:#c53030;color:#fff;border:none;border-radius:6px;cursor:pointer}.empty-state{text-align:center;padding:2rem 1rem;color:#718096}.empty-state p{margin:.5rem 0;font-size:1.1rem}.records-section{margin-top:1rem}.records-list{display:flex;flex-direction:column;gap:1rem}.record-item{display:flex;gap:1rem;padding:1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;transition:all .2s}.record-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.record-image{flex-shrink:0;width:120px;height:120px;border-radius:8px;overflow:hidden;background:#e2e8f0}.record-image img{width:100%;height:100%;object-fit:cover}.record-content{flex:1;display:flex;flex-direction:column;gap:.75rem}.record-text{flex:1}.record-text p{margin:0;color:#2d3748;font-size:1rem;line-height:1.6;word-break:break-word;text-align:left}.record-text-content{margin:0;color:#2d3748;font-size:1rem;line-height:1.6;word-break:break-word;white-space:pre-wrap;text-align:left}.edit-mode{width:100%;position:relative;background:#f8fafc;border:2px solid #3182ce;border-radius:12px;padding:1rem;margin:.5rem 0;box-shadow:0 4px 8px #3182ce1a}.edit-mode:before{content:"✏️ 编辑模式";position:absolute;top:-10px;left:10px;background:#3182ce;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.edit-textarea{width:100%;min-height:80px;padding:.75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;line-height:1.5;font-family:inherit;color:#2d3748;background:#fff;resize:vertical;transition:all .2s;box-shadow:0 1px 3px #0000001a;margin-top:.5rem}.edit-actions{display:flex;gap:.5rem;margin-top:.75rem;justify-content:flex-end}.save-btn,.cancel-btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:80px}.save-btn{background:#38a169;color:#fff}.save-btn:hover:not(:disabled){background:#2f855a;transform:translateY(-1px)}.save-btn:disabled{background:#a0aec0;cursor:not-allowed;transform:none}.cancel-btn{background:#e2e8f0;color:#4a5568}.cancel-btn:hover:not(:disabled){background:#cbd5e0;transform:translateY(-1px)}.cancel-btn:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed;transform:none}.display-mode{position:relative;width:100%}.text-actions{position:absolute;top:0;right:0;display:flex;gap:.25rem;opacity:0;transform:translateY(-2px);transition:all .2s}.display-mode:hover .text-actions{opacity:1;transform:translateY(0)}.read-btn,.edit-btn{padding:.25rem .5rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:4px;font-size:.75rem;color:#4a5568;cursor:pointer;transition:all .2s}.read-btn:hover{background:#e6fffa;border-color:#38a169;color:#2f855a}.edit-btn:hover{background:#edf2f7;border-color:#cbd5e0;color:#2d3748}.read-btn.reading{background:#feb2b2;border-color:#e53e3e;color:#c53030;animation:pulse 1s infinite}.phonetic{position:relative;transition:all .2s ease}.phonetic:hover{background:#3182ce1a;border-radius:4px;padding:.1rem .2rem}.phonetic.playing{background:#38a16933;border-radius:4px;padding:.1rem .2rem;animation:pulse 1s infinite}.phonetics-text{margin-top:1rem;margin-left:-1rem;margin-right:-1rem;padding:1rem;background:#f7fafc;border-radius:0}.phonetics-title{margin:0 0 1rem;color:#2d3748;font-size:1rem;font-weight:600}.phonetics-content{line-height:1.8;font-size:1rem;color:#2d3748;text-align:left;padding:.8rem 1rem;background:#f8fafc;border-radius:0;border:1px solid #e2e8f0;word-wrap:break-word;margin:0;width:100%;box-sizing:border-box;overflow:visible;max-height:none;white-space:normal}.word-phonetic-pair{display:inline-block;margin:.05rem .1rem .05rem 0;padding:.15rem .3rem;background:#fff;border-radius:4px;border:1px solid #e2e8f0;box-shadow:0 1px 2px #0000000d;vertical-align:top;min-width:45px;text-align:center}.english-word{color:#2d3748;font-weight:600;font-size:.9rem;margin:0;display:block;line-height:1.1}.phonetic{color:#e53e3e;font-weight:500;font-family:Courier New,monospace;font-size:.7rem;background:#fed7d7;padding:.1rem .2rem;border-radius:2px;margin-top:.1rem;display:block;line-height:1;transition:all .2s ease}.phonetic:hover{background:#feb2b2;transform:translateY(-1px);box-shadow:0 2px 4px #e53e3e33}.punctuation{color:#718096;font-size:1rem;margin:.2rem .1rem;display:inline;font-weight:400;vertical-align:middle}.phonetics-paragraph{margin-bottom:1.5rem;line-height:1.8}.word-phonetic-pair.compact{margin:.05rem .08rem .05rem 0;padding:.1rem .25rem;min-width:35px}.word-phonetic-pair.compact .english-word{font-size:.75rem}.word-phonetic-pair.compact .phonetic{font-size:.65rem;padding:.08rem .15rem}.word-space{display:inline;margin:0;padding:0;font-size:inherit;line-height:inherit}.word-phonetic-pair.hover{display:inline;margin:0;padding:0;background:none;border:none;box-shadow:none;min-width:auto;position:relative;cursor:help}.word-phonetic-pair.hover .english-word{color:#3182ce;text-decoration:none;font-size:1rem;display:inline;cursor:help;position:relative}.word-phonetic-pair.hover .english-word:hover{color:#2c5aa0}.word-phonetic-pair.hover .phonetic{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#2d3748;color:#fff;padding:.6rem 1rem;border-radius:8px;font-size:.8rem;white-space:normal;z-index:1000;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;margin-bottom:.3rem;max-width:400px;min-width:200px;text-align:left;line-height:1.5;word-wrap:break-word;box-shadow:0 4px 12px #0000004d}.word-phonetic-pair.hover .phonetic:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#2d3748}.word-phonetic-pair.hover:hover .phonetic{opacity:1;visibility:visible}.word-phonetic-pair.hover .translation{display:block;font-size:.85rem;color:#fbbf24;margin-top:.4rem;font-weight:500;line-height:1.4;word-wrap:break-word;max-width:100%;padding:.2rem 0;border-top:1px solid rgba(255,255,255,.2)}.pronunciation-btn{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);border:none;color:#fff;font-size:.8rem;cursor:pointer;padding:.2rem;border-radius:50%;transition:all .3s ease;margin-right:.3rem;display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;box-shadow:0 2px 4px #ff6b6b4d}.pronunciation-btn:hover{background:linear-gradient(135deg,#ff5252,#ff7979);transform:scale(1.1);box-shadow:0 4px 8px #ff6b6b66}.favorite-star{background:none;border:none;font-size:.9rem;cursor:pointer;padding:.15rem;border-radius:4px;transition:all .2s;margin-left:.3rem;display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px}.favorite-star:hover:not(:disabled){background:#ffc1071a;transform:scale(1.1)}.favorite-star.favorited{color:#ffc107}.favorite-star:not(.favorited){color:#cbd5e0}.favorite-star:disabled{opacity:.6;cursor:not-allowed;transform:none}.hover-actions{display:flex;gap:.25rem;margin-top:.25rem;align-items:center}.pronunciation-btn{background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #3182ce4d}.pronunciation-btn:hover{transform:scale(1.1);box-shadow:0 4px 8px #3182ce66}.phonetics-loading{display:flex;align-items:center;gap:.5rem;color:#4a5568;font-size:.9rem;padding:1rem;justify-content:center}.phonetics-error{color:#e53e3e;font-size:.9rem;padding:1rem;text-align:center;background:#fed7d7;border-radius:6px}.record-meta{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;font-size:.9rem;color:#718096}.record-meta span{padding:.25rem .5rem;background:#e2e8f0;border-radius:4px;font-weight:500}.record-meta .engine{background:#bee3f8;color:#2b6cb0}.record-meta .time{background:#c6f6d5;color:#2f855a}.record-meta .size{background:#fbb6ce;color:#b83280}.record-meta .processing-time{background:#faf089;color:#744210}.record-actions{display:flex;gap:.5rem;flex-wrap:wrap}.action-btn{padding:.5rem .75rem;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:70px;text-align:center}.copy-btn{background:#3182ce;color:#fff}.copy-btn:hover{background:#2c5aa0;transform:translateY(-1px)}.delete-btn{background:#e53e3e!important;color:#fff!important;border:none!important}.delete-btn:hover{background:#c53030!important;color:#fff!important;transform:translateY(-1px);box-shadow:0 2px 4px #e53e3e4d}.delete-btn:active{background:#b91c1c!important;transform:translateY(0)}.phonetics-btn{background:#38a169;color:#fff}.phonetics-btn:hover{background:#2f855a;transform:translateY(-1px)}.phonetics-btn.active{background:#ed8936}.phonetics-btn.active:hover{background:#dd6b20}.display-mode-btn{background:#805ad5;color:#fff;font-size:.8rem;padding:.4rem .6rem;min-width:60px}.display-mode-btn:hover{background:#6b46c1}.pagination{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-top:1rem;padding:1rem;background:#f8fafc;border-radius:8px}.page-btn{padding:.75rem 1.5rem;border:2px solid #e2e8f0;background:#fff;color:#4a5568;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.page-info{text-align:center;color:#718096;font-size:.9rem;line-height:1.4}@media (max-width: 768px){.ocr-history{padding:1rem}.search-controls{flex-direction:column;align-items:stretch}.search-input,.engine-select,.search-btn,.reset-btn{width:100%}.record-item{flex-direction:column;gap:1rem}.record-image{width:100%;height:200px}.record-meta{flex-direction:column;align-items:flex-start;gap:.5rem}.record-actions{justify-content:center}.pagination{flex-direction:column;gap:1rem}}.user-profile{padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;animation:fadeInUp .6s cubic-bezier(.4,0,.2,1)}.profile-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #e2e8f0}.profile-avatar img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid #e2e8f0}.avatar-placeholder{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:700;border:3px solid #e2e8f0}.profile-details h2{margin:0 0 .5rem;color:#2d3748;font-size:1.5rem;font-weight:700}.user-email{margin:0 0 1rem;color:#718096;font-size:1rem}.edit-btn{background:#3182ce;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.edit-btn:hover{background:#2c5aa0;transform:translateY(-1px)}.edit-input{padding:.5rem;border:2px solid #e2e8f0;border-radius:6px;font-size:.9rem;transition:border-color .2s}.edit-input:focus{outline:none;border-color:#3182ce}.save-btn{background:#48bb78;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.save-btn:hover{background:#38a169}.cancel-btn{background:#e2e8f0;color:#4a5568;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#cbd5e0}.profile-stats{margin-bottom:2rem}.profile-stats h3{margin:0 0 1rem;color:#2d3748;font-size:1.25rem;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;display:flex;align-items:center;gap:.75rem;transition:all .2s}.stat-icon{font-size:1.5rem;flex-shrink:0}.stat-value{font-size:1.5rem;font-weight:700;color:#2d3748;margin:0}.stat-label{font-size:.8rem;color:#718096;margin:0}.profile-actions{display:flex;flex-direction:column;gap:.75rem}.action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:left}@media screen and (orientation: landscape) and (max-height: 600px){.user-profile{padding:1rem}.profile-header{gap:1rem;margin-bottom:1rem;padding-bottom:1rem}.profile-avatar img,.avatar-placeholder{width:60px;height:60px}.avatar-placeholder{font-size:1.5rem}.profile-details h2{font-size:1.2rem}.user-email{font-size:.9rem}.stats-grid{grid-template-columns:repeat(4,1fr);gap:.75rem}.stat-card{padding:.75rem;flex-direction:column;text-align:center;gap:.5rem}.stat-icon,.stat-value{font-size:1.25rem}.stat-label{font-size:.75rem}.action-btn{padding:.6rem .8rem;font-size:.85rem}}@media screen and (orientation: landscape) and (min-width: 768px) and (max-height: 500px){.stats-grid{grid-template-columns:repeat(4,1fr)}.profile-actions{flex-direction:row;gap:1rem}.action-btn{flex:1;justify-content:center}}.profile-settings{margin-bottom:2rem;padding:1.5rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.profile-settings h3{color:#2d3748;margin-top:0;margin-bottom:1.5rem;font-size:1.2rem;display:flex;align-items:center;gap:.5rem}.setting-range{display:flex;justify-content:space-between;font-size:.8rem;color:#718096;margin-top:.25rem}.setting-actions{display:flex;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.test-btn,.reset-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.9rem}@media screen and (orientation: landscape) and (max-height: 600px){.profile-settings{padding:1rem;margin-bottom:1rem}.profile-settings h3{margin-bottom:1rem;font-size:1.1rem}.settings-content{gap:1rem}.setting-actions{flex-direction:column;gap:.5rem}.test-btn,.reset-btn{padding:.5rem 1rem;font-size:.85rem}}@media screen and (orientation: portrait) and (max-width: 480px){.user-profile{padding:1rem}.profile-header{flex-direction:column;text-align:center;gap:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-card{flex-direction:column;text-align:center;gap:.5rem}}.user-favorites{padding:1rem;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a}.favorites-header{text-align:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e2e8f0}.favorites-header h2{color:#2d3748;font-size:2rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.favorites-subtitle{color:#718096;font-size:1rem;margin:0}.favorites-controls{margin-bottom:2rem;display:flex;flex-direction:column;gap:1rem}.search-form{display:flex;gap:.75rem;align-items:center}.search-input{flex:1;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s}.search-btn,.clear-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.search-btn{background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff}.search-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3182ce4d}.clear-btn{background:#e2e8f0;color:#4a5568}.clear-btn:hover{background:#cbd5e0;transform:translateY(-1px)}.category-filters{display:flex;gap:.5rem}.category-btn{padding:.5rem 1rem;border:2px solid #e2e8f0;border-radius:20px;background:#fff;color:#4a5568;font-weight:600;cursor:pointer;transition:all .2s}.category-btn:hover{border-color:#3182ce;color:#3182ce}.loading-container{text-align:center;padding:3rem}.error-container{text-align:center;padding:2rem;background:#fed7d7;border:1px solid #feb2b2;border-radius:8px;color:#c53030}.retry-btn{margin-top:1rem;padding:.5rem 1rem;background:#e53e3e;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.local-dev-help{margin-top:1rem;padding:1rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px}.local-dev-help h4{color:#2d3748;margin-bottom:.75rem;font-size:1rem}.local-dev-help ol{color:#4a5568;margin-bottom:1rem;padding-left:1.5rem}.local-dev-help li{margin:.5rem 0;line-height:1.5}.setup-btn{background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #3182ce4d}.setup-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3182ce66}.favorites-stats{margin-bottom:1rem;padding:1rem;background:#f7fafc;border-radius:8px;text-align:center;color:#4a5568;font-weight:600}.favorites-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.favorite-item{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;transition:all .2s;box-shadow:0 2px 8px #0000000d}.favorite-item:hover{border-color:#3182ce;box-shadow:0 4px 16px #3182ce1a;transform:translateY(-2px)}.favorite-content{flex:1}.favorite-word{display:flex;align-items:baseline;gap:1rem;margin-bottom:.75rem}.favorite-word h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0}.favorite-phonetic{color:#718096;font-size:1rem;font-style:italic}.favorite-translation{margin-bottom:.75rem}.favorite-translation p{color:#4a5568;margin:.25rem 0;line-height:1.5}.favorite-definition{margin-bottom:.75rem}.favorite-definition p{color:#2d3748;font-style:italic;margin:0;line-height:1.4}.favorite-notes{margin-bottom:.75rem;padding:.75rem;background:#f0f8ff;border-left:4px solid #3182ce;border-radius:0 6px 6px 0;color:#2d3748;font-size:.9rem}.favorite-meta{display:flex;gap:1rem;font-size:.8rem;color:#718096}.favorite-category{background:#e2e8f0;padding:.25rem .5rem;border-radius:12px;font-weight:600}.difficulty-level{background:#fff3cd;color:#856404;padding:.25rem .5rem;border-radius:12px;font-weight:600;font-size:.75rem}.favorite-actions{display:flex;flex-direction:column;gap:.5rem}.delete-btn{width:40px;height:40px;border:2px solid #e53e3e;border-radius:8px;background:#fff;color:#e53e3e;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all .2s ease;position:relative;overflow:hidden}.delete-btn:hover:not(:disabled){background:#e53e3e;color:#fff;transform:scale(1.05);box-shadow:0 4px 8px #e53e3e4d}.delete-btn:active:not(:disabled){background:#c53030;transform:scale(.95)}.delete-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;background:#f5f5f5;color:#999;border-color:#ddd}.empty-state{text-align:center;padding:4rem 2rem;color:#718096}.empty-state h3{color:#4a5568;font-size:1.5rem;margin-bottom:.5rem}.empty-state p{font-size:1rem;margin:0}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding:1rem;background:#f7fafc;border-radius:8px}.page-btn{padding:.75rem 1.5rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-weight:600;cursor:pointer;transition:all .2s}.page-btn:hover:not(:disabled){border-color:#3182ce;color:#3182ce;transform:translateY(-1px)}.page-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.page-info{color:#4a5568;font-weight:600;font-size:.9rem}@media screen and (orientation: landscape) and (max-height: 600px){.user-favorites{padding:.75rem}.favorites-header h2{font-size:1.5rem}.favorites-controls{margin-bottom:1rem}.search-form{flex-direction:column;align-items:stretch}.category-filters{justify-content:center}.favorite-item{padding:1rem}.favorite-word h3{font-size:1.25rem}.empty-state{padding:2rem 1rem}}@media screen and (orientation: portrait) and (max-width: 480px){.favorites-header h2{font-size:1.5rem}.search-form,.favorite-item{flex-direction:column;align-items:stretch}.favorite-actions{flex-direction:row;justify-content:flex-end}.delete-btn{width:35px;height:35px}.pagination{flex-direction:column;gap:.75rem}.page-btn{padding:.6rem 1.2rem;font-size:.9rem}}@media screen and (min-width: 768px) and (max-width: 1024px){.favorites-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}}@media screen and (min-width: 1024px){.favorites-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:1.5rem}}.word-importer{padding:1rem;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:800px;margin:0 auto}.importer-container{display:flex;flex-direction:column;gap:2rem}.importer-header{text-align:center;padding-bottom:1rem;border-bottom:2px solid #e2e8f0}.importer-header h2{color:#2d3748;font-size:2rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.importer-header p{color:#718096;font-size:1rem;margin:0}.importer-content{display:flex;flex-direction:column;gap:2rem}.import-type-section{background:#f7fafc;padding:1.5rem;border-radius:8px;border:1px solid #e2e8f0}.import-type-section h3{color:#2d3748;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.import-type-buttons{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.type-btn{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease}.type-btn:hover{border-color:#3182ce;transform:translateY(-2px);box-shadow:0 4px 12px #3182ce33}.type-btn.active{border-color:#3182ce;background:linear-gradient(135deg,#ebf8ff,#e6fffa);box-shadow:0 4px 12px #3182ce4d}.type-icon{font-size:2rem;line-height:1}.type-info{flex:1;text-align:left}.type-info strong{display:block;color:#2d3748;font-size:1.1rem;margin-bottom:.25rem}.type-info p{margin:0;color:#718096;font-size:.9rem}.file-section{background:#f7fafc;padding:1.5rem;border-radius:8px;border:1px solid #e2e8f0}.file-section h3{color:#2d3748;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.file-input-container{position:relative;margin-bottom:.5rem}.file-input{display:none}.file-label{display:inline-block;padding:1rem 2rem;background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #3182ce4d;text-align:center;min-width:200px}.file-label:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3182ce66}.file-help{color:#718096;font-size:.9rem;margin:0;font-style:italic}.file-help.csv-help{background:#e6fffa;padding:1rem;border-radius:8px;border:1px solid #81e6d9;font-style:normal}.file-help.csv-help p{margin:0 0 .5rem;font-weight:600;color:#234e52}.file-help.csv-help ul{margin:.5rem 0 0;padding-left:1.5rem;list-style-type:disc}.file-help.csv-help li{margin:.3rem 0;color:#2c7a7b}.file-help.csv-help code{background:#c6f6d5;padding:.2rem .4rem;border-radius:4px;font-family:Courier New,monospace;font-size:.85rem;color:#22543d}.preview-section{background:#fff5f5;padding:1.5rem;border-radius:8px;border:1px solid #fed7d7}.preview-section h3{color:#2d3748;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.preview-stats{display:flex;gap:1rem;margin-bottom:1rem;font-size:.9rem;color:#4a5568}.preview-words{display:flex;flex-wrap:wrap;gap:.5rem;max-height:200px;overflow-y:auto;padding:1rem;background:#fff;border-radius:6px;border:1px solid #e2e8f0}.preview-word{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:4px;font-size:.9rem}.word-text{color:#2d3748;font-weight:500}.pronunciation-btn-small{background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.pronunciation-btn-small:hover{transform:scale(1.1)}.preview-more{color:#718096;font-style:italic;padding:.5rem;text-align:center;width:100%}.csv-preview-list{display:flex;flex-direction:column;gap:1rem;max-height:400px;overflow-y:auto;padding:1rem;background:#fff;border-radius:6px;border:1px solid #e2e8f0}.csv-preview-item{padding:1rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;transition:all .2s ease}.csv-preview-item:hover{border-color:#3182ce;box-shadow:0 2px 8px #3182ce1a}.csv-word-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #e2e8f0}.csv-word-text{color:#2d3748;font-size:1.2rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.csv-word-details{display:flex;flex-direction:column;gap:.5rem}.csv-phonetic,.csv-translation{display:flex;align-items:flex-start;gap:.5rem;font-size:.95rem}.detail-label{color:#718096;font-weight:600;min-width:50px;flex-shrink:0}.detail-value{color:#2d3748;flex:1}.csv-phonetic .detail-value{font-family:Courier New,monospace;color:#e53e3e;font-weight:500}.csv-translation .detail-value{color:#2c7a7b}.category-section{background:#f0fff4;padding:1.5rem;border-radius:8px;border:1px solid #9ae6b4}.category-section h3{color:#2d3748;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.existing-categories,.new-category{margin-bottom:1rem}.existing-categories label,.new-category label{display:block;color:#2d3748;font-weight:600;margin-bottom:.5rem}.category-select{width:100%;padding:.75rem;border:2px solid #e2e8f0;border-radius:6px;font-size:1rem;background:#fff}.category-select:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a}.category-form{margin-top:.5rem}.form-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.category-name-input{flex:1;min-width:150px;padding:.75rem;border:2px solid #e2e8f0;border-radius:6px;font-size:1rem}.color-select,.icon-select{padding:.75rem;border:2px solid #e2e8f0;border-radius:6px;font-size:1rem;background:#fff;min-width:100px}.create-category-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#38a169,#68d391);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #38a1694d}.create-category-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #38a16966}.create-category-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.import-section{text-align:center}.import-btn{padding:1rem 2rem;background:linear-gradient(135deg,#ed8936,#f6ad55);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #ed89364d}.import-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ed893666}.import-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.import-result{padding:1.5rem;border-radius:8px;margin-top:1rem}.import-result.success{background:#f0fff4;border:1px solid #9ae6b4;color:#2f855a}.import-result.error{background:#fed7d7;border:1px solid #feb2b2;color:#c53030}.import-result h4{margin:0 0 1rem;font-size:1.2rem}.result-stats{margin-bottom:1rem}.result-stats p{margin:.5rem 0;font-weight:500}.error-details{margin-top:1rem;padding:1rem;background:#ffffff80;border-radius:6px}.error-details ul{margin:.5rem 0 0;padding-left:1.5rem}.error-details li{margin:.25rem 0;font-size:.9rem}@media screen and (orientation: landscape) and (max-height: 600px){.word-importer{padding:.75rem}.importer-content{gap:1rem}.importer-header h2{font-size:1.5rem}}@media screen and (orientation: portrait) and (max-width: 480px){.word-importer{padding:.5rem}.importer-content{gap:1rem}.importer-header h2{font-size:1.5rem}.form-row{flex-direction:column;align-items:stretch}.category-name-input,.color-select,.icon-select{min-width:auto}.preview-words{max-height:150px}}@media screen and (min-width: 768px) and (max-width: 1024px){.form-row{flex-wrap:wrap}}@media screen and (min-width: 1024px){.form-row{flex-wrap:nowrap}}.library-selection{width:100%;margin:0;padding:0;background:transparent;border-radius:0;box-shadow:none}.selection-content,.category-section,.subcategory-section{margin-bottom:30px}.category-section h3,.subcategory-section h3{color:#2d3748;margin-bottom:16px;font-size:1.2rem}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.category-card{display:flex;align-items:center;padding:16px;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#fff}.category-card:hover{border-color:#4299e1;transform:translateY(-2px);box-shadow:0 4px 12px #4299e126}.category-card.selected{border-color:#4299e1;background:#ebf8ff}.category-icon{font-size:2rem;margin-right:16px}.category-info h4{color:#2d3748;margin:0 0 4px;font-size:1.1rem}.category-info p{color:#718096;margin:0;font-size:.9rem}.subcategory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.subcategory-card{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border:2px solid #e2e8f0;border-radius:6px;cursor:pointer;transition:all .2s ease;background:#fff}.subcategory-card:hover{border-color:#4299e1;background:#f7fafc}.subcategory-card.selected{border-color:#4299e1;background:#ebf8ff}.subcategory-name{color:#2d3748;font-weight:500}.checkmark{color:#4299e1;font-weight:700;font-size:1.2rem}.selection-summary{background:#f7fafc;padding:20px;border-radius:8px;border:1px solid #e2e8f0}.selection-summary h3{color:#2d3748;margin:0 0 16px;font-size:1.1rem}.summary-content{display:flex;flex-direction:column;gap:8px}.summary-item{display:flex;align-items:center}.summary-item .label{color:#718096;font-weight:500;min-width:80px}.summary-item .value{color:#2d3748;font-weight:600}.selection-actions{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid #e2e8f0}.back-btn,.confirm-btn{padding:12px 24px;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:120px}.back-btn{background:#e2e8f0;color:#4a5568}.back-btn:hover{background:#cbd5e0}.confirm-btn{background:#4299e1;color:#fff}.confirm-btn:hover:not(:disabled){background:#3182ce}.confirm-btn:disabled{background:#a0aec0;cursor:not-allowed}@media (min-width: 1200px){.category-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 900px) and (max-width: 1199px){.category-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.category-grid,.subcategory-grid{grid-template-columns:1fr}.selection-actions{flex-direction:column;gap:12px}.back-btn,.confirm-btn{width:100%}}.mode-selection{max-width:900px;margin:0 auto;padding:20px;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a}.selection-header{text-align:center;margin-bottom:30px}.selection-header h2{color:#2d3748;margin-bottom:8px;font-size:1.8rem}.selection-header p{color:#718096;font-size:1rem}.error-message{background:#fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;margin-bottom:20px;text-align:center}.loading-container{text-align:center;padding:40px 20px}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #4299e1;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.mode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:30px}.mode-card{display:flex;align-items:center;padding:6px 8px;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .3s ease;background:#fff;position:relative;overflow:hidden}.mode-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--mode-color);transform:scaleX(0);transition:transform .3s ease}.mode-card:hover{border-color:var(--mode-color);transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.mode-card:hover:before{transform:scaleX(1)}.mode-icon{font-size:1.5rem;margin-right:6px;transition:transform .3s ease}.mode-card:hover .mode-icon{transform:scale(1.1)}.mode-content{flex:1}.mode-name{color:#2d3748;margin:0;font-size:.9rem;font-weight:600}.mode-description{color:#718096;margin:0 0 12px;font-size:.95rem;line-height:1.4}.mode-meta{display:flex;align-items:center;gap:8px}.difficulty-badge{color:#fff;padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.mode-arrow{color:#a0aec0;font-size:.9rem;font-weight:700;transition:all .3s ease}.mode-card:hover .mode-arrow{color:var(--mode-color);transform:translate(4px)}.mode-actions{display:flex;justify-content:center;padding-top:20px;border-top:1px solid #e2e8f0;margin-bottom:30px}.back-btn{padding:12px 24px;border:2px solid #e2e8f0;border-radius:6px;background:#fff;color:#4a5568;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.back-btn:hover{border-color:#4299e1;color:#4299e1;background:#ebf8ff}.learning-tips{background:#f7fafc;padding:20px;border-radius:8px;border:1px solid #e2e8f0}.learning-tips h3{color:#2d3748;margin:0 0 16px;font-size:1.1rem}.learning-tips ul{margin:0;padding-left:20px;color:#4a5568}.learning-tips li{margin-bottom:8px;line-height:1.5}.learning-tips li:last-child{margin-bottom:0}@media (max-width: 768px){.mode-selection{padding:16px;margin:0 10px}.mode-grid{grid-template-columns:repeat(3,1fr);gap:12px}.mode-card{padding:4px 6px}.mode-icon{font-size:1.2rem;margin-right:6px}.mode-name,.mode-description{font-size:.85rem}}@media (max-width: 480px){.mode-grid{grid-template-columns:1fr;gap:8px}.mode-card{flex-direction:row;text-align:left;padding:6px 8px}.mode-icon{margin-right:6px;margin-bottom:0}.mode-arrow{display:block}}.word-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin-bottom:8px;overflow:hidden}.word-card-content{padding:16px 20px;text-align:center}.word-loading{display:flex;flex-direction:column;align-items:center;padding:40px 24px;color:#718096}.loading-spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top:3px solid #4299e1;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.word-display-container{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:12px}.word-content{flex:1;max-width:400px}.word-text{color:#2d3748;font-size:2.5rem;font-weight:700;margin:0 0 8px;line-height:1.2}.word-phonetic{color:#4299e1;font-size:1.2rem;font-weight:500;margin:0;font-family:Courier New,monospace}.word-phonetic-secondary{color:#718096;font-size:1rem;font-weight:400;margin:0;font-family:Courier New,monospace}.pronunciation-btn{width:60px;height:60px;border:none;border-radius:50%;background:linear-gradient(135deg,#4299e1,#3182ce);color:#fff;font-size:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #4299e14d}.pronunciation-btn:hover{transform:scale(1.05);box-shadow:0 6px 20px #4299e166}.pronunciation-btn:active{transform:scale(.95)}.pronunciation-btn.playing{background:linear-gradient(135deg,#ff6b6b,#ee5a24);box-shadow:0 4px 12px #ff6b6b66;animation:pulse 1.5s ease-in-out infinite}.pronunciation-btn.playing:hover{transform:scale(1.05);box-shadow:0 6px 20px #ff6b6b99}.phonetic-instruction{background:#f7fafc;padding:16px 20px;border-radius:8px;border:1px solid #e2e8f0;margin-bottom:20px}.phonetic-instruction p{color:#4a5568;margin:0;font-size:.95rem;line-height:1.4}.word-answer{background:#fff;border:2px solid #38a169;border-radius:8px;padding:12px 16px;margin-top:8px;box-shadow:0 2px 8px #38a16926}.translation{color:#1a202c;font-size:1.8rem;font-weight:700;margin:0 0 12px}.translation-secondary{color:#38a169;font-size:1.2rem;font-weight:500;margin:0 0 12px}.definition{color:#4a5568;font-size:1rem;line-height:1.5;margin:0;font-style:italic}.word-info{display:flex;flex-wrap:wrap;gap:8px;padding:16px 24px;background:#f7fafc;border-top:1px solid #e2e8f0}.word-category,.word-subcategory{background:#e2e8f0;color:#4a5568;padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:500}.word-difficulty{padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600}.difficulty-easy{background:#c6f6d5;color:#22543d}.difficulty-medium{background:#faf089;color:#744210}.difficulty-hard{background:#fed7d7;color:#742a2a}@media (max-width: 768px){.word-card-content{padding:24px 16px}.word-text{font-size:2rem}.word-phonetic{font-size:1rem}.pronunciation-btn{width:50px;height:50px;font-size:1.2rem}.word-display-container{flex-direction:column;gap:12px}.word-content{max-width:none}.translation{font-size:1.5rem}.word-info{padding:12px 16px;gap:6px}}@media (max-width: 480px){.word-text{font-size:1.8rem}.word-phonetic{font-size:.9rem}.pronunciation-btn{width:45px;height:45px;font-size:1.1rem}.translation{font-size:1.3rem}.definition{font-size:.9rem}}.choice-section{margin-bottom:8px}.choice-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:8px;margin-bottom:12px}.choice-option{display:flex;align-items:center;padding:16px 20px;border:2px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;transition:all .3s ease;text-align:left;font-size:1rem;position:relative;overflow:hidden}.choice-option:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:#4299e1;transform:scaleX(0);transition:transform .3s ease}.choice-option:hover{border-color:#4299e1;transform:translateY(-2px);box-shadow:0 4px 12px #4299e126}.choice-option:hover:before{transform:scaleX(1)}.choice-option.selected{border-color:#4299e1;background:#ebf8ff;transform:translateY(-2px);box-shadow:0 4px 12px #4299e133}.choice-option.selected:before{transform:scaleX(1)}.choice-option.correct-answer{border-color:#38a169;background:#f0fff4;color:#22543d}.choice-option.correct-answer:before{background:#38a169;transform:scaleX(1)}.choice-option.wrong-answer{border-color:#e53e3e;background:#fed7d7;color:#742a2a}.choice-option.wrong-answer:before{background:#e53e3e;transform:scaleX(1)}.choice-option:disabled{cursor:not-allowed}.choice-letter{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#f7fafc;color:#4a5568;border-radius:50%;font-weight:600;font-size:.9rem;margin-right:12px;flex-shrink:0}.choice-option.selected .choice-letter{background:#4299e1;color:#fff}.choice-option.correct-answer .choice-letter{background:#38a169;color:#fff}.choice-option.wrong-answer .choice-letter{background:#e53e3e;color:#fff}.choice-text{flex:1;font-weight:500;line-height:1.4}.choice-checkmark{color:#4299e1;font-weight:700;font-size:1.2rem;margin-left:8px}.choice-actions{display:flex;justify-content:center;gap:16px}@media (max-width: 768px){.choice-options{grid-template-columns:1fr;gap:10px}.choice-option{padding:14px 16px}.choice-letter{width:28px;height:28px;font-size:.8rem;margin-right:10px}.choice-text{font-size:.95rem}.choice-actions{flex-direction:column;align-items:center}.check-btn,.next-btn{width:100%;max-width:300px}}@media (max-width: 480px){.choice-option{padding:12px 14px}.choice-letter{width:24px;height:24px;font-size:.75rem;margin-right:8px}.choice-text{font-size:.9rem}}.input-section{margin-bottom:8px}.input-instruction{text-align:center;margin-bottom:12px}.input-instruction p{color:#4a5568;font-size:1rem;margin:0;line-height:1.4}.input-container{margin-bottom:12px}.answer-input{width:100%;max-width:400px;margin:0 auto;display:block;padding:16px 20px;border:2px solid #e2e8f0;border-radius:8px;font-size:1.1rem;font-weight:500;text-align:center;transition:all .3s ease;background:#fff;color:#2d3748}.answer-input:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a;transform:translateY(-1px)}.answer-input:disabled{background:#f7fafc;color:#718096;cursor:not-allowed}.answer-input::placeholder{color:#a0aec0;font-weight:400}.answer-feedback{margin-top:16px;padding:16px 20px;border-radius:8px;text-align:center}.feedback-result{margin-bottom:8px}.feedback-result.correct{background:#f0fff4;border:2px solid #38a169;color:#22543d}.feedback-result.incorrect{background:#fed7d7;border:2px solid #e53e3e;color:#742a2a}.correct-answer-display{color:#2d3748;font-size:1rem;margin-top:8px}.correct-answer-display strong{color:#4299e1;font-weight:600}.input-actions{display:flex;justify-content:center;gap:16px}.check-btn,.next-btn{padding:12px 32px;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:120px}.check-btn{background:#4299e1;color:#fff}.check-btn:hover:not(:disabled){background:#3182ce;transform:translateY(-1px);box-shadow:0 4px 12px #4299e14d}.check-btn:disabled{background:#a0aec0;cursor:not-allowed;transform:none;box-shadow:none}.next-btn{background:#38a169;color:#fff}.next-btn:hover{background:#2f855a;transform:translateY(-1px);box-shadow:0 4px 12px #38a1694d}@media (max-width: 768px){.answer-input{padding:14px 16px;font-size:1rem}.input-actions{flex-direction:column;align-items:center}.check-btn,.next-btn{width:100%;max-width:300px}.answer-feedback{padding:14px 16px}.feedback-text{font-size:1rem}.correct-answer-display{font-size:.95rem}}@media (max-width: 480px){.answer-input{padding:12px 14px;font-size:.95rem}.input-instruction p{font-size:.9rem}.answer-feedback{padding:12px 14px}.feedback-text{font-size:.95rem}.correct-answer-display{font-size:.9rem}}.study-progress{background:#fff;border-radius:12px;padding:12px 16px;margin-bottom:0;box-shadow:0 2px 4px #0000001a}.progress-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px;margin-bottom:20px}.progress-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px 8px;background:#f7fafc;border-radius:8px;border:1px solid #e2e8f0}.progress-label{color:#718096;font-size:.8rem;font-weight:500;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.progress-value{color:#2d3748;font-size:1rem;font-weight:600;line-height:1.2}.progress-bar{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-bottom:20px}.progress-fill{height:100%;background:linear-gradient(90deg,#4299e1,#38a169);border-radius:4px;transition:width .3s ease;position:relative}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.round-progress{border-top:1px solid #e2e8f0;padding-top:20px}.round-info h4{color:#2d3748;margin:0 0 16px;font-size:1.1rem;font-weight:600;text-align:center}.round-badges{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.round-badge{display:flex;align-items:center;gap:8px;padding:8px 16px;border:2px solid #e2e8f0;border-radius:20px;background:#fff;color:#718096;font-size:.9rem;font-weight:500;transition:all .3s ease;position:relative;overflow:hidden}.round-badge:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#4299e1;opacity:0;transition:opacity .3s ease}.round-badge.active{border-color:#4299e1;background:#ebf8ff;color:#2d3748;transform:scale(1.05);box-shadow:0 4px 12px #4299e133}.round-badge.active:before{opacity:.1}.round-badge.completed{border-color:#38a169;background:#f0fff4;color:#22543d}.round-badge.completed:before{background:#38a169;opacity:.1}.round-number{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#e2e8f0;border-radius:50%;font-weight:600;font-size:.8rem;color:#4a5568}.round-badge.active .round-number{background:#4299e1;color:#fff}.round-badge.completed .round-number{background:#38a169;color:#fff}.round-badge.completed .round-number:after{content:"✓";font-size:.7rem}.round-name{font-weight:500}@media (max-width: 768px){.study-progress{padding:16px}.progress-info{grid-template-columns:repeat(2,1fr);gap:12px}.progress-item{padding:10px 6px}.progress-label{font-size:.75rem}.progress-value{font-size:.9rem}.round-badges{gap:8px}.round-badge{padding:6px 12px;font-size:.8rem}.round-number{width:20px;height:20px;font-size:.7rem}}@media (max-width: 480px){.progress-info{grid-template-columns:1fr;gap:10px}.progress-item{flex-direction:row;justify-content:space-between;align-items:center;text-align:left;padding:10px 12px}.progress-label{margin-bottom:0;font-size:.8rem}.progress-value{font-size:.9rem}.round-badges{flex-direction:column;align-items:center;gap:6px}.round-badge{width:100%;max-width:200px;justify-content:center}}.practice-container{max-width:800px;margin:0 auto;padding:8px 12px}.no-word-message{text-align:center;padding:40px 20px;color:#718096;font-size:1.1rem}.practice-content{margin-bottom:8px}.game-mode-toggle{text-align:center;margin-top:20px}.game-mode-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;padding:12px 24px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d}.game-mode-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.game-mode-btn:active{transform:translateY(0)}@media (max-width: 768px){.practice-container{padding:16px}.game-mode-btn{padding:10px 20px;font-size:.95rem}}@media (max-width: 480px){.practice-container{padding:12px}.game-mode-btn{width:100%;padding:12px}}.word-study{padding:2rem;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:1400px;margin:0 auto;width:100%}.study-container{display:flex;flex-direction:column;gap:1rem}.study-mode-selector{text-align:center;padding-bottom:1rem;border-bottom:2px solid #e2e8f0}.library-selection-page{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.library-selection-content{max-width:1200px;width:100%;text-align:center}.library-selection-content h2{font-size:2.5rem;color:#2d3748;margin-bottom:.5rem;font-weight:700}.library-selection-desc{font-size:1.2rem;color:#4a5568;margin-bottom:3rem}.category-selection,.subcategory-selection{margin-bottom:2rem;text-align:left}.category-selection h3,.subcategory-selection h3{font-size:1.5rem;color:#2d3748;margin-bottom:1rem;text-align:center}.category-options,.subcategory-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;margin-bottom:1rem}.category-option,.subcategory-option{padding:1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;gap:.5rem}.category-option:hover,.subcategory-option:hover{border-color:#3182ce;transform:translateY(-2px);box-shadow:0 4px 12px #3182ce33}.category-option.selected,.subcategory-option.selected{border-color:#3182ce;background:linear-gradient(135deg,#ebf8ff,#e6fffa);box-shadow:0 4px 12px #3182ce4d}.category-name,.subcategory-name{font-size:1.2rem;font-weight:600;color:#2d3748}.category-count{font-size:.9rem;color:#718096}.subcategory-option{padding:1rem;text-align:center}.subcategory-option.selected{background:linear-gradient(135deg,#f0fff4,#e6fffa)}.library-selection-footer{margin-top:3rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.confirm-library-btn{padding:1rem 2rem;background:linear-gradient(135deg,#38a169,#48bb78);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #38a1694d}.confirm-library-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #38a16966}.confirm-library-btn:disabled{opacity:.6;cursor:not-allowed}.back-to-library-btn{padding:.75rem 1.5rem;background:#718096;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.back-to-library-btn:hover{background:#4a5568;transform:translateY(-1px)}.error-message{margin-top:1rem;padding:1rem;background:#fed7d7;color:#c53030;border-radius:8px;border:1px solid #feb2b2;font-weight:500}.mode-selection-page{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.mode-selection-content{max-width:1200px;width:100%;text-align:center}.mode-selection-content h2{font-size:2.5rem;color:#2d3748;margin-bottom:.5rem;font-weight:700}.mode-selection-desc{font-size:1.2rem;color:#4a5568;margin-bottom:3rem}.mode-selection-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-bottom:2rem}.mode-card{background:#fff;border-radius:16px;padding:2rem;border:2px solid #e2e8f0;cursor:pointer;transition:all .3s ease;text-align:left;box-shadow:0 4px 12px #0000000d}.mode-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#3182ce}.mode-icon{font-size:3rem;text-align:center;margin-bottom:1rem}.mode-card h3{font-size:1.5rem;color:#2d3748;margin-bottom:.5rem;text-align:center;font-weight:600}.mode-card p{color:#4a5568;margin-bottom:1.5rem;text-align:center;font-size:1rem}.mode-details{border-top:1px solid #e2e8f0;padding-top:1rem}.mode-type{display:inline-block;background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;margin-bottom:1rem}.mode-details ul{list-style:none;padding:0;margin:0}.mode-details li{color:#4a5568;font-size:.9rem;margin-bottom:.5rem;padding-left:1rem;position:relative}.mode-details li:before{content:"✓";position:absolute;left:0;color:#48bb78;font-weight:700}.mode-selection-footer{margin-top:2rem;padding-top:2rem;border-top:1px solid #e2e8f0}.mode-selection-footer p{color:#718096;font-style:italic;margin:0}.practice-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;padding:.5rem 1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.back-to-mode-btn{padding:.5rem 1rem;background:#4a5568;color:#fff;border:none;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.back-to-mode-btn:hover{background:#2d3748;transform:translateY(-1px)}.current-mode-info{flex:1;text-align:center}.mode-indicator{font-size:1.2rem;font-weight:600;color:#2d3748;background:#fff;padding:.5rem 1rem;border-radius:8px;border:1px solid #e2e8f0}.study-mode-selector h2{color:#2d3748;font-size:1.8rem;font-weight:700;margin-bottom:1rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mode-buttons{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;justify-content:center}.mode-btn{padding:.75rem 1.5rem;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;color:#4a5568}.mode-btn:hover{background:#edf2f7;border-color:#cbd5e0}.mode-btn.active{background:linear-gradient(135deg,#3182ce,#63b3ed);border-color:#3182ce;color:#fff;box-shadow:0 4px 12px #3182ce4d}.study-progress{background:#f7fafc;padding:1rem;border-radius:8px;border:1px solid #e2e8f0}.progress-info{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.9rem;color:#4a5568;flex-wrap:wrap;gap:.5rem}.progress-bar{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(135deg,#38a169,#68d391);transition:width .3s ease;border-radius:4px}.word-card{background:linear-gradient(135deg,#fff,#f8fafc);padding:2.5rem;border-radius:20px;border:1px solid #e2e8f0;box-shadow:0 8px 32px #00000014;position:relative;overflow:hidden;transition:all .3s ease}.word-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,#667eea,#764ba2)}.word-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0000001f}.word-header{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.word-display-container{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1rem}.word-content{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem}.word-text{color:#2d3748;font-size:3rem;font-weight:800;margin:0;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em;-webkit-text-stroke:.5px transparent}@supports not (-webkit-background-clip: text){.word-text{color:#667eea!important;background:none!important;-webkit-text-fill-color:initial!important}}.pronunciation-btn{background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;border:none;border-radius:50%;width:50px;height:50px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 4px 12px #3182ce4d;flex-shrink:0;align-self:flex-start;margin-top:.5rem}.pronunciation-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #3182ce66}.word-phonetic{color:#e53e3e;font-size:1.4rem;font-weight:600;font-family:Courier New,monospace;text-align:center;margin:0;padding:.75rem 1.5rem;background:#e53e3e1a;border-radius:12px;border:1px solid rgba(229,62,62,.2);display:inline-block}.word-answer{background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:2rem;border-radius:16px;border:1px solid #cbd5e0;margin-bottom:2rem;box-shadow:0 4px 16px #00000014;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.translation{color:#2d3748;font-size:1.3rem;font-weight:600;margin-bottom:.5rem;text-align:center}.translation-secondary{color:#4a5568;font-size:1.1rem;font-weight:500;margin-bottom:.5rem;text-align:center;font-style:italic}.phonetic-answer{color:#e53e3e;font-size:1.2rem;font-weight:600;font-family:Courier New,monospace;text-align:center;margin:.5rem 0;padding:.5rem 1rem;background:#e53e3e1a;border-radius:8px;display:inline-block}.definition{color:#4a5568;font-size:1rem;line-height:1.6;text-align:center}.validation-feedback{margin:1rem 0;padding:1rem;border-radius:12px;text-align:center;animation:slideIn .3s ease-out}.validation-feedback.correct{background:linear-gradient(135deg,#48bb78,#68d391);color:#fff;border:2px solid #38a169}.validation-feedback.incorrect{background:linear-gradient(135deg,#f56565,#fc8181);color:#fff;border:2px solid #e53e3e}.feedback-content{display:flex;align-items:center;justify-content:center;gap:.5rem}.feedback-icon{font-size:1.5rem}.feedback-text{font-size:1.1rem;font-weight:600}.feedback-actions{margin-top:1rem;display:flex;justify-content:center}.next-word-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #3182ce4d}.next-word-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3182ce66}.next-word-btn:active{transform:translateY(0);box-shadow:0 2px 8px #3182ce4d}.phonetic-instruction{text-align:center;margin:1rem 0;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;border:2px solid #5a67d8}.phonetic-instruction p{margin:0;font-size:1rem;font-weight:500;line-height:1.4}.study-report-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2)}.study-report-content{max-width:800px;width:100%;background:#fff;border-radius:20px;padding:2rem;box-shadow:0 20px 40px #0000001a;text-align:center}.report-header h2{font-size:2.5rem;color:#2d3748;margin-bottom:.5rem;font-weight:700}.report-subtitle{font-size:1.2rem;color:#4a5568;margin-bottom:2rem}.report-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#f7fafc;border-radius:12px;padding:1.5rem 1rem;border:2px solid transparent;transition:all .3s ease}.stat-card.primary{border-color:#3182ce;background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff}.stat-card.success{border-color:#38a169;background:linear-gradient(135deg,#38a169,#68d391);color:#fff}.stat-card.warning{border-color:#ed8936;background:linear-gradient(135deg,#ed8936,#f6ad55);color:#fff}.stat-card.info{border-color:#805ad5;background:linear-gradient(135deg,#805ad5,#b794f6);color:#fff}.stat-icon{font-size:2rem;margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;margin-bottom:.25rem}.stat-label{font-size:.9rem;opacity:.9}.report-details{background:#f8fafc;border-radius:12px;padding:1.5rem;margin-bottom:2rem;text-align:left}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #e2e8f0}.detail-item:last-child{border-bottom:none}.detail-label{font-weight:600;color:#4a5568}.detail-value{color:#2d3748;font-weight:500}.report-performance{margin-bottom:2rem}.report-performance h3{font-size:1.5rem;color:#2d3748;margin-bottom:1rem}.performance-excellent,.performance-good,.performance-average,.performance-needs-improvement{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border-radius:12px;font-size:1.1rem;font-weight:600}.performance-excellent{background:linear-gradient(135deg,#f6e05e,#fbb6ce);color:#744210}.performance-good{background:linear-gradient(135deg,#68d391,#81e6d9);color:#065f46}.performance-average{background:linear-gradient(135deg,#f6ad55,#fbb6ce);color:#7c2d12}.performance-needs-improvement{background:linear-gradient(135deg,#feb2b2,#fbd38d);color:#742a2a}.performance-icon{font-size:1.5rem}.report-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.action-btn{padding:1rem 2rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:150px}.restart-btn{background:linear-gradient(135deg,#38a169,#48bb78);color:#fff}.restart-btn:hover{background:linear-gradient(135deg,#2f855a,#38a169);transform:translateY(-2px);box-shadow:0 8px 20px #38a1694d}.back-btn{background:linear-gradient(135deg,#4a5568,#718096);color:#fff}.back-btn:hover{background:linear-gradient(135deg,#2d3748,#4a5568);transform:translateY(-2px);box-shadow:0 8px 20px #4a55684d}.study-mode{margin-bottom:1.5rem}.input-section{display:flex;gap:1rem;align-items:center}.choice-section{margin-bottom:1.5rem}.choice-options{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}.choice-option{padding:.875rem 1rem;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;font-weight:500;color:#4a5568;cursor:pointer;transition:all .2s ease;text-align:center;min-height:50px;display:flex;align-items:center;justify-content:center}.choice-option:hover{background:#edf2f7;border-color:#cbd5e0;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.choice-option.selected{background:linear-gradient(135deg,#3182ce,#63b3ed);border-color:#3182ce;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #3182ce4d}.choice-option:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.choice-option.correct-answer{background:linear-gradient(135deg,#38a169,#68d391);border-color:#2f855a;color:#fff;box-shadow:0 4px 12px #38a1694d;animation:correctPulse .6s ease-out}.choice-option.wrong-answer{background:linear-gradient(135deg,#e53e3e,#fc8181);border-color:#c53030;color:#fff;box-shadow:0 4px 12px #e53e3e4d;animation:wrongShake .6s ease-out}@keyframes correctPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes wrongShake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.answer-input{flex:1;padding:1.25rem 1.5rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1.1rem;transition:all .3s ease;background:#fff;color:#2d3748;box-shadow:0 2px 8px #0000000d}.answer-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;transform:translateY(-1px);color:#2d3748}.check-btn{padding:1.25rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #667eea4d;letter-spacing:.5px}.check-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.check-btn:active{transform:translateY(0)}.game-mode{margin-bottom:1.5rem}.game-mode h4{color:#2d3748;font-size:1.1rem;margin-bottom:1rem;text-align:center}.game-options{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.game-option{padding:1rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s;font-size:1rem;font-weight:500;color:#2d3748}.game-option:hover:not(:disabled){border-color:#3182ce;background:#f7fafc;transform:translateY(-2px)}.game-option.selected{border-color:#3182ce;background:#ebf8ff;color:#3182ce}.game-option:disabled{opacity:.7;cursor:not-allowed}.game-option.correct-answer{background:linear-gradient(135deg,#38a169,#68d391);border-color:#2f855a;color:#fff;box-shadow:0 4px 12px #38a1694d;animation:correctPulse .6s ease-out}.game-option.wrong-answer{background:linear-gradient(135deg,#e53e3e,#fc8181);border-color:#c53030;color:#fff;box-shadow:0 4px 12px #e53e3e4d;animation:wrongShake .6s ease-out}.game-feedback{text-align:center;padding:1rem;border-radius:8px;font-weight:600;font-size:1.1rem}.game-feedback.correct{background:linear-gradient(135deg,#38a169,#68d391);color:#fff;border:2px solid #2f855a;box-shadow:0 4px 12px #38a1694d}.game-feedback.incorrect{background:#fed7d7;color:#c53030;border:1px solid #feb2b2}.skip-btn:hover{background:linear-gradient(135deg,#4a5568,#718096);box-shadow:0 4px 12px #7180964d}.loading-container,.error-container,.empty-state{text-align:center;padding:3rem 2rem}.retry-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #3182ce4d;margin-top:1rem}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3182ce66}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{color:#2d3748;font-size:1.5rem;margin-bottom:.5rem}.empty-state p{color:#718096;margin-bottom:1rem}@media screen and (orientation: landscape) and (max-height: 600px){.word-study{padding:.75rem}.study-container{gap:1rem}.word-card{padding:1rem}.word-text{font-size:2rem}.mode-buttons{gap:.5rem}.mode-btn{padding:.5rem 1rem;font-size:.9rem}}@media screen and (orientation: portrait) and (max-width: 480px){.word-study{padding:.5rem}.study-container{gap:1rem}.word-card{padding:1rem}.word-text{font-size:2rem}.word-header{flex-direction:column;gap:.5rem}.pronunciation-btn{width:40px;height:40px;font-size:1rem}.mode-buttons{flex-direction:column;align-items:center}.mode-buttons{grid-template-columns:1fr;gap:.5rem}.mode-btn{width:100%;padding:.875rem 1rem;font-size:.9rem}.mode-selection-content h2{font-size:2rem}.mode-selection-desc{font-size:1rem}.mode-selection-grid{grid-template-columns:1fr;gap:1.5rem}.mode-card{padding:1.5rem}.mode-icon{font-size:2.5rem}.mode-card h3{font-size:1.3rem}.practice-header{flex-direction:column;gap:1rem;text-align:center}.back-to-mode-btn{width:100%;max-width:200px}.input-section{flex-direction:column}.answer-input,.check-btn{width:100%}.choice-options{grid-template-columns:1fr}.choice-option{min-height:60px;font-size:1.1rem}.game-options{grid-template-columns:1fr}}@media screen and (min-width: 768px) and (max-width: 1024px){.game-options{grid-template-columns:1fr 1fr}.study-actions{justify-content:center}}@media screen and (min-width: 1024px){.game-options{grid-template-columns:1fr 1fr}.input-section{max-width:600px;margin:0 auto}}.phonetics-learning{padding:20px;max-width:1200px;margin:0 auto;background:#f8fafc;min-height:100vh}.phonetics-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #3182ce;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.phonetics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;flex-wrap:wrap;gap:15px}.phonetics-header h2{margin:0;color:#2d3748;font-size:28px;font-weight:700}.header-info{flex:1;display:flex;justify-content:center;align-items:center}.audio-status{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}.audio-status.loading{background:#ebf8ff;color:#2c5282;border:1px solid #90cdf4}.audio-status.success{background:#f0fff4;color:#22543d;border:1px solid #9ae6b4}.header-actions{display:flex;gap:12px;flex-wrap:wrap}.progress-btn,.practice-btn,.preload-btn,.test-btn,.stop-audio-btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.progress-btn{background:#ed8936;color:#fff}.progress-btn:hover{background:#dd6b20;transform:translateY(-1px)}.practice-btn{background:#38a169;color:#fff}.practice-btn:hover:not(:disabled){background:#2f855a;transform:translateY(-1px)}.practice-btn:disabled{background:#a0aec0;cursor:not-allowed;transform:none}.preload-btn{background:#3182ce;color:#fff}.preload-btn:hover{background:#2c5282;transform:translateY(-1px)}.test-btn{background:#3182ce;color:#fff}.test-btn:hover{background:#2c5282;transform:translateY(-1px)}.stop-audio-btn{background:#e53e3e;color:#fff}.stop-audio-btn:hover:not(:disabled){background:#c53030;transform:translateY(-1px)}.stop-audio-btn:disabled{background:#a0aec0;cursor:not-allowed;opacity:.6;transform:none}.error-message{background:#fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;margin-bottom:20px;border:1px solid #feb2b2}.progress-panel{background:#fff;border-radius:12px;padding:24px;margin-bottom:30px;box-shadow:0 2px 10px #0000001a}.progress-panel h3{margin:0 0 20px;color:#2d3748;font-size:20px}.progress-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px}.stat-item{text-align:center;padding:4px 16px;background:#f7fafc;border-radius:8px;border:1px solid #e2e8f0}.stat-value{display:block;font-size:24px;font-weight:700;color:#3182ce;margin-bottom:4px}.stat-label{font-size:14px;color:#718096}.practice-mode{background:#fff;border-radius:12px;padding:30px;margin-bottom:30px;box-shadow:0 2px 10px #0000001a}.practice-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e2e8f0}.practice-header h3{margin:0;color:#2d3748;font-size:24px}.practice-progress{background:#3182ce;color:#fff;padding:8px 16px;border-radius:20px;font-weight:600;font-size:14px}.practice-content{text-align:center}.practice-phoneme{max-width:500px;margin:0 auto}.phoneme-modal .phoneme-symbol-large{font-size:72px;font-weight:700;color:#3182ce;margin-bottom:16px;font-family:Times New Roman,serif}.phoneme-modal .phoneme-name-large{font-size:24px;color:#4a5568;margin-bottom:12px;font-weight:600}.phoneme-modal .phoneme-description-large{font-size:18px;color:#2d3748;line-height:1.6;margin-bottom:24px}.phoneme-modal .example-words-section{margin-top:24px}.phoneme-description{font-size:16px;color:#718096;margin-bottom:24px;line-height:1.5}.practice-actions{margin-bottom:30px}.play-phoneme-btn{background:#3182ce;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.play-phoneme-btn:hover:not(:disabled){background:#2c5282;transform:translateY(-1px)}.play-phoneme-btn:disabled{background:#a0aec0;cursor:not-allowed}.practice-buttons{display:flex;gap:20px;justify-content:center}.correct-btn,.incorrect-btn{padding:16px 32px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:140px}.correct-btn{background:#38a169;color:#fff}.correct-btn:hover{background:#2f855a;transform:translateY(-2px);box-shadow:0 4px 12px #38a1694d}.incorrect-btn{background:#e53e3e;color:#fff}.incorrect-btn:hover{background:#c53030;transform:translateY(-2px);box-shadow:0 4px 12px #e53e3e4d}.phoneme-filters{display:flex;gap:12px;margin-bottom:30px;flex-wrap:wrap}.filter-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border:2px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;font-weight:600;color:#4a5568}.filter-btn:hover{border-color:#3182ce;transform:translateY(-1px)}.filter-btn.active{background:#3182ce;color:#fff;border-color:#3182ce}.filter-icon{font-size:16px}.filter-label{font-size:14px}.phonemes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.phoneme-card{background:#fff;border-radius:12px;padding:20px;cursor:pointer;transition:all .2s ease;border:2px solid transparent;position:relative;box-shadow:0 2px 8px #0000001a}.phoneme-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026;border-color:#3182ce}.phoneme-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.phoneme-type{font-size:18px}.phoneme-symbol{font-size:24px;font-weight:700;color:#3182ce;font-family:Times New Roman,serif}.phoneme-name{font-size:16px;font-weight:600;color:#2d3748;margin-bottom:8px}.phoneme-description{font-size:14px;color:#718096;margin-bottom:16px;line-height:1.4}.phoneme-examples{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.example-word{background:#f7fafc;color:#4a5568;padding:4px 8px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s ease;border:1px solid #e2e8f0;-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;gap:4px}.example-word:hover{background:#edf2f7;color:#2d3748;transform:translateY(-1px);border-color:#cbd5e0}.example-word:active{transform:translateY(0);background:#e2e8f0}.example-word .word-icon{font-size:10px;opacity:.7;transition:opacity .2s ease}.example-word:hover .word-icon{opacity:1}.play-btn{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;border-radius:50%;background:#3182ce;color:#fff;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-size:14px}.play-btn:hover{background:#2c5282;transform:scale(1.1)}.play-btn:disabled{background:#a0aec0;cursor:not-allowed}.phoneme-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;overflow-y:auto}.phoneme-modal .modal-content{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;margin:auto;position:relative}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.phoneme-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0}.phoneme-modal .modal-header h3{margin:0;color:#2d3748;font-size:20px}.phoneme-modal .close-btn{width:32px;height:32px;border:none;border-radius:50%;background:#e2e8f0;color:#4a5568;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s ease}.phoneme-modal .close-btn:hover{background:#cbd5e0;color:#2d3748}.phoneme-modal .modal-body{padding:24px}.phoneme-modal .phoneme-info-large{text-align:center;margin-bottom:30px}.phoneme-modal .phoneme-type-large{margin-bottom:16px;font-size:16px;font-weight:600}.phoneme-modal .example-words-section h4{margin:0 0 16px;color:#2d3748;font-size:18px}.phoneme-modal .example-words-grid{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}.phoneme-modal .example-word-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:6px;box-shadow:0 2px 8px #667eea4d}.phoneme-modal .example-word-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.phoneme-modal .example-word-btn:active{transform:translateY(0);box-shadow:0 2px 6px #667eea4d}.phoneme-modal .modal-actions{text-align:center}.phoneme-modal .play-phoneme-btn-large{background:#3182ce;color:#fff;border:none;padding:14px 28px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.phoneme-modal .play-phoneme-btn-large:hover:not(:disabled){background:#2c5282;transform:translateY(-1px);box-shadow:0 4px 12px #3182ce4d}.phoneme-modal .play-phoneme-btn-large:disabled{background:#a0aec0;cursor:not-allowed}@media screen and (max-width: 768px){.phonetics-learning{padding:16px}.phonetics-header{flex-direction:column;gap:16px;text-align:center}.header-actions{flex-direction:column;width:100%}.progress-btn,.practice-btn{width:100%;justify-content:center}.phonemes-grid{grid-template-columns:1fr}.practice-buttons{flex-direction:column;gap:12px}.correct-btn,.incorrect-btn{width:100%}.phoneme-symbol-large{font-size:48px}.phoneme-name-large{font-size:20px}.phoneme-modal .modal-content{margin:10px;max-height:90vh}}@media screen and (max-width: 480px){.phoneme-filters{flex-direction:column}.filter-btn{width:100%;justify-content:center}.progress-stats{grid-template-columns:repeat(2,1fr)}.phoneme-modal .example-words-grid{flex-direction:column}.phoneme-modal .example-word-btn{width:100%;text-align:center}}.article-analysis{max-width:1200px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.analysis-header{text-align:center;margin-bottom:30px;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;box-shadow:0 4px 15px #0000001a}.analysis-header h2{margin:0 0 10px;font-size:2rem;font-weight:600}.analysis-header p{margin:0;font-size:1.1rem;opacity:.9}.input-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px}.input-controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:25px;padding:20px;background:#f8f9fa;border-radius:8px}.control-group{display:flex;flex-direction:column;gap:8px}.control-group label{font-weight:600;color:#333;font-size:.95rem}.control-select{padding:10px 12px;border:2px solid #e1e5e9;border-radius:6px;font-size:.95rem;background:#fff;transition:border-color .2s ease}.control-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.checkbox-group{display:flex;flex-wrap:wrap;gap:15px;margin-top:5px}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:.9rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:#667eea}.text-input-container{margin-bottom:25px}.text-input-container label{display:block;font-weight:600;color:#333;margin-bottom:10px;font-size:1rem}.article-textarea{width:100%;min-height:200px;padding:15px;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;line-height:1.6;font-family:Courier New,monospace;resize:vertical;transition:border-color .2s ease;background:#fafbfc}.article-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fff}.article-textarea::placeholder{color:#6c757d;font-style:italic}.text-stats{display:flex;gap:20px;margin-top:8px;font-size:.85rem;color:#6c757d;flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#f8f9fa;border-radius:4px;border:1px solid #e1e5e9}.stat-label{color:#6c757d;font-weight:500}.stat-value{color:#333;font-weight:600}.action-buttons{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.btn{padding:12px 24px;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;gap:6px;min-width:120px;justify-content:center}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea4d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-secondary{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;box-shadow:0 2px 8px #f093fb4d}.btn-secondary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #f093fb66}.btn-outline{background:transparent;color:#667eea;border:2px solid #667eea}.btn-outline:hover:not(:disabled){background:#667eea;color:#fff}.error-message{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fee;color:#c53030;border:1px solid #feb2b2;border-radius:6px;margin-top:15px;font-size:.9rem}.error-icon{font-size:1.1rem}.result-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.result-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;background:#f8f9fa;border-bottom:1px solid #e1e5e9}.result-header h3{margin:0;color:#333;font-size:1.5rem}.result-actions{display:flex;gap:10px}.result-content{padding:30px}.summary-result,.questions-result,.analysis-result{margin-bottom:30px}.summary-result h4,.questions-result h4,.analysis-result h4{color:#333;margin-bottom:15px;font-size:1.3rem;display:flex;align-items:center;gap:8px}.summary-text{background:#f8f9fa;padding:20px;border-radius:8px;border-left:4px solid #667eea;line-height:1.6;font-size:1rem}.questions-list{display:flex;flex-direction:column;gap:20px}.question-item{background:#f8f9fa;padding:20px;border-radius:8px;border-left:4px solid #f093fb}.question{margin-bottom:12px;font-size:1rem;line-height:1.5}.answer{color:#666;font-size:.95rem;line-height:1.5;padding-left:20px;border-left:2px solid #e1e5e9}.analysis-sections{display:flex;flex-direction:column;gap:25px}.section{background:#f8f9fa;padding:20px;border-radius:8px;border-left:4px solid #667eea}.section h5{color:#333;margin:0 0 15px;font-size:1.1rem;display:flex;align-items:center;gap:8px}.section-content{line-height:1.6;color:#555;white-space:pre-wrap}.raw-response{background:#f8f9fa;padding:20px;border-radius:8px;border-left:4px solid #667eea;line-height:1.6;white-space:pre-wrap;font-size:.95rem}.result-meta{margin-top:20px;padding-top:15px;border-top:1px solid #e1e5e9;color:#6c757d}.meta-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;text-align:center}.meta-item{display:flex;flex-direction:column;align-items:center;padding:10px;background:#f8f9fa;border-radius:8px;border:1px solid #e1e5e9;transition:all .2s ease}.meta-item:hover{background:#e9ecef;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.meta-label{font-size:.85rem;color:#6c757d;margin-bottom:4px;font-weight:500}.meta-value{font-size:1rem;color:#333;font-weight:600}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.chinese-meaning-item{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px;border-left:4px solid #007bff}.chinese-meaning-original{font-weight:600;color:#333;margin-bottom:8px;font-size:1rem}.chinese-meaning-chinese{color:#007bff;font-weight:500;margin-bottom:8px;font-size:1rem;padding-left:20px;position:relative}.chinese-meaning-meta{font-size:.85rem;color:#6c757d;margin-top:8px}.chinese-meaning-meta span{margin-right:15px}.chinese-meaning-difficulty{background:#e3f2fd;color:#1976d2;padding:2px 8px;border-radius:12px;font-size:.75rem}.paragraph-translation{margin-bottom:25px;padding:20px;background:#fff;border:1px solid #e1e5e9;border-radius:8px}.paragraph-translation h4{color:#007bff;margin-bottom:15px;font-size:1.1rem}.phrase-translation{margin-bottom:15px;padding:12px;background:#f8f9fa;border-radius:6px;border-left:3px solid #28a745}.phrase-original{font-weight:600;color:#333;margin-bottom:5px}.phrase-chinese{color:#28a745;font-weight:500;margin-bottom:5px}.difficult-sentence{margin-bottom:20px;padding:15px;background:#fff5f5;border-radius:8px;border-left:4px solid #dc3545}.difficult-sentence-original{font-weight:600;color:#333;margin-bottom:8px}.difficult-sentence-chinese{color:#dc3545;font-weight:500;margin-bottom:8px}.difficult-sentence-explanation{color:#6c757d;font-style:italic;margin-bottom:5px}.difficult-sentence-grammar{color:#dc3545;font-weight:500;font-size:.9rem}@media (max-width: 768px){.article-analysis{padding:15px}.analysis-header{padding:15px;margin-bottom:20px}.analysis-header h2{font-size:1.5rem}.input-section{padding:20px}.input-controls{grid-template-columns:1fr;gap:15px;padding:15px}.action-buttons{flex-direction:column}.btn{width:100%}.result-header{flex-direction:column;gap:15px;align-items:stretch}.result-actions{justify-content:center}.result-content{padding:20px}.checkbox-group{flex-direction:column;gap:10px}.meta-info{grid-template-columns:repeat(2,1fr);gap:10px}.meta-item{padding:8px}.meta-label{font-size:.75rem}.meta-value{font-size:.85rem}}@media (max-width: 480px){.analysis-header h2{font-size:1.3rem}.analysis-header p{font-size:1rem}.input-section,.result-content,.section,.question-item{padding:15px}.meta-info{grid-template-columns:1fr;gap:8px}.meta-item{padding:6px}.meta-label{font-size:.7rem}.meta-value{font-size:.8rem}}.analysis-table-container{margin:12px 0;background:#fff;border-radius:10px;box-shadow:0 2px 6px #00000014;overflow:hidden}.table-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 16px;border-bottom:1px solid #e0e0e0}.table-header h4{margin:0;font-size:15px;font-weight:600;display:flex;align-items:center;gap:6px}.table-wrapper{overflow-x:auto;background:#fff}.analysis-table{width:100%;border-collapse:collapse;font-size:16px;min-width:600px}.analysis-table th{background:#f8f9fa;color:#495057;font-weight:600;padding:14px 12px;text-align:left;border-bottom:2px solid #dee2e6;position:sticky;top:0;z-index:10;font-size:15px}.analysis-table td{padding:10px 12px;border-bottom:1px solid #e9ecef;vertical-align:top;line-height:1.4;font-size:15px}.table-row:hover{background-color:#f8f9fa}.table-row.highlighted-sentence{background-color:#fff3cd!important;border:2px solid #ffc107;animation:highlightPulse 2s ease-out}@keyframes highlightPulse{0%{background-color:#ffeb3b;transform:scale(1.02)}to{background-color:#fff3cd;transform:scale(1)}}.overview-table{display:flex;flex-direction:column;gap:1px;border-radius:8px;overflow:hidden}.overview-table .table-row{display:grid;gap:1px}.overview-table .table-row:first-child{grid-template-columns:200px 1fr}.overview-table .table-row:last-child{grid-template-columns:200px 1fr 1fr 1fr}.overview-table .label-cell{background:#e3f2fd;font-weight:600;color:#1976d2;padding:12px 16px;font-size:15px;display:flex;align-items:center}.overview-table .value-cell{background:#fff;color:#424242;word-break:break-word;padding:12px 16px;font-size:15px;display:flex;align-items:center}.vocabulary-table{margin-bottom:12px}.vocabulary-tables .analysis-table-container,.grammar-tables .analysis-table-container,.structure-tables .analysis-table-container,.chinese-meaning-tables .analysis-table-container{margin-bottom:8px}.vocabulary-table .word-cell{font-weight:600;color:#2c3e50;background:#ecf0f1;width:100px;min-width:100px;font-size:16px}.vocabulary-table .phonetic-cell{color:#e74c3c;font-family:Courier New,monospace;font-style:italic;width:120px;min-width:120px;font-size:14px}.vocabulary-table .meaning-cell{color:#27ae60;font-weight:500;font-size:15px;line-height:1.4}.vocabulary-table .meaning-cell:before{content:"";display:inline-block;color:#8e44ad;font-weight:600;font-size:13px;margin-right:4px}.vocabulary-table .example-cell{color:#7f8c8d;font-style:italic;font-size:14px}.vocabulary-table.suggested .word-cell{background:#fff3cd;color:#856404}.memory-tips-table .type-cell{background:#f0f8ff;font-weight:600;color:#06c;width:100px;min-width:100px}.memory-tips-table .content-cell{color:#333;line-height:1.6}.grammar-table .tense-cell{background:#fff5f5;color:#c53030;font-weight:600;width:100px;min-width:100px;font-size:15px}.grammar-table .examples-cell{color:#2d3748;font-family:Georgia,serif;font-style:italic;font-size:14px}.grammar-table .usage-cell{color:#4a5568;line-height:1.4;font-size:14px}.grammar-table .tips-cell{color:#38a169;font-size:14px;background:#f0fff4}.structure-table .type-cell{background:#e6fffa;color:#234e52;font-weight:600;width:120px;min-width:120px}.structure-table .count-cell{text-align:center;color:#d69e2e;font-weight:600;width:80px;min-width:80px}.structure-table .difficulty-cell{color:#805ad5;font-weight:500;width:80px;min-width:80px}.structure-table .tips-cell{color:#2f855a;font-size:13px}.grammar-points-table .point-cell{background:#fef5e7;color:#744210;font-weight:600;width:120px;min-width:120px}.grammar-points-table .usage-cell{color:#2d3748;line-height:1.5}.grammar-points-table .examples-cell{color:#4a5568;font-style:italic;font-size:13px}.grammar-points-table .mistakes-cell{color:#e53e3e;font-size:13px;background:#fed7d7}.paragraph-table .paragraph-cell{background:#ebf8ff;color:#2b6cb0;font-weight:600;width:80px;min-width:80px;text-align:center}.paragraph-table .main-idea-cell{color:#2d3748;line-height:1.6}.connectors-table .type-cell{background:#f0fff4;color:#276749;font-weight:600;width:100px;min-width:100px}.connectors-table .words-cell{color:#2d3748;font-family:Georgia,serif}.writing-techniques-table .type-cell{background:#fefcbf;color:#744210;font-weight:600;width:100px;min-width:100px}.writing-techniques-table .content-cell{color:#2d3748;line-height:1.6}.sentence-translation-table .original-cell{background:#f7fafc;color:#2d3748;font-family:Georgia,serif;font-style:italic;width:50%;font-size:15px}.sentence-translation-table .chinese-cell{background:#fff5f5;color:#c53030;font-weight:500;width:50%;font-size:15px}.paragraph-translation-table .paragraph-cell{background:#ebf8ff;color:#2b6cb0;font-weight:600;width:80px;min-width:80px;text-align:center}.paragraph-translation-table .original-cell{color:#2d3748;font-family:Georgia,serif;font-style:italic;width:45%}.paragraph-translation-table .chinese-cell{color:#c53030;font-weight:500;width:45%}.key-phrases-table .phrase-cell{background:#fef5e7;color:#744210;font-weight:600;width:120px;min-width:120px}.key-phrases-table .chinese-cell{color:#c53030;font-weight:500}.key-phrases-table .usage-cell{color:#4a5568;font-size:13px}.key-phrases-table .example-cell{color:#7f8c8d;font-style:italic;font-size:13px}.difficult-sentences-table .original-cell{background:#fff5f5;color:#2d3748;font-family:Georgia,serif;font-style:italic;width:30%}.difficult-sentences-table .chinese-cell{color:#c53030;font-weight:500;width:30%}.difficult-sentences-table .explanation-cell{color:#4a5568;font-size:13px;width:25%}.difficult-sentences-table .grammar-cell{color:#805ad5;font-weight:500;font-size:13px;background:#faf5ff;width:15%}@media (max-width: 768px){.analysis-table{font-size:14px;min-width:400px}.analysis-table th,.analysis-table td{padding:10px;font-size:14px}.table-header{padding:10px 14px}.table-header h4{font-size:14px}.overview-table .table-row:first-child{grid-template-columns:1fr}.overview-table .table-row:last-child{grid-template-columns:1fr}.overview-table .label-cell,.overview-table .value-cell{padding:10px 12px;font-size:14px}.structure-table .count-cell,.difficult-sentences-table .grammar-cell{display:none}}@media (max-width: 480px){.analysis-table{font-size:13px;min-width:300px}.analysis-table th,.analysis-table td{padding:8px;font-size:13px}.vocabulary-table .phonetic-cell,.grammar-table .tips-cell,.key-phrases-table .usage-cell{display:none}}@media print{.analysis-table-container{box-shadow:none;border:1px solid #ccc;page-break-inside:avoid}.table-header{background:#f8f9fa!important;color:#000!important;border-bottom:2px solid #000}.analysis-table th{background:#f0f0f0!important;color:#000!important}.analysis-table td{border-bottom:1px solid #ccc}.table-row:hover{background-color:transparent!important}}.analysis-table-container{animation:fadeInUp .3s ease-out}.table-wrapper::-webkit-scrollbar{height:8px}.table-wrapper::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.table-wrapper::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.table-wrapper::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.translation-table .sentence-cell{background:#f7fafc;color:#2d3748;font-family:Georgia,serif;font-style:italic;line-height:1.6;transition:background-color .3s ease}.translation-table .sentence-cell.reading-highlight{background-color:#3b82f633}.translation-table .chinese-cell{background:#fff5f5;color:#c53030;font-weight:500;line-height:1.6;position:relative;transition:background-color .2s ease}.translation-table .chinese-cell:hover{background-color:#ffe0e0}.jump-to-analysis-icon{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:.9rem;opacity:.6;transition:all .2s ease;pointer-events:none}.translation-table .chinese-cell:hover .jump-to-analysis-icon{opacity:1;transform:translateY(-50%) scale(1.2)}.translation-row-clickable{cursor:pointer;transition:background-color .2s ease}.translation-row-clickable:hover{background-color:#f8f9fa}.translation-row-clickable.highlight-scroll{background-color:#fff9e6!important;animation:highlightRowPulse 2s ease-out}@keyframes highlightRowPulse{0%{background-color:#fff9e6;box-shadow:0 0 10px #ffc1074d}50%{background-color:#fffde7;box-shadow:0 0 15px #ffc10766}to{background-color:transparent;box-shadow:none}}.translation-table .favorite-cell{text-align:center;background:#fff}.sentence-favorite-btn{background:none;border:none;cursor:pointer;padding:.25rem;font-size:1.2rem;transition:transform .2s,opacity .2s;opacity:.6;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.sentence-favorite-btn:hover{opacity:1;transform:scale(1.1)}.sentence-favorite-btn.favorited{opacity:1;color:#f59e0b}.sentence-favorite-btn.favorited:hover{transform:scale(1.15)}@media (max-width: 768px){.translation-table .sentence-cell,.translation-table .chinese-cell{font-size:14px;padding:10px 8px}.sentence-favorite-btn{font-size:1rem;width:28px;height:28px}}.database-manager{padding:1rem;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:1200px;margin:0 auto}.access-denied{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;border:2px solid #e2e8f0}.access-denied-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.7}.access-denied h2{color:#2d3748;font-size:2rem;font-weight:700;margin-bottom:1rem}.access-denied p{color:#718096;font-size:1.1rem;margin-bottom:2rem}.admin-info{background:#fff;padding:2rem;border-radius:8px;border:1px solid #e2e8f0;margin-top:2rem;text-align:left;max-width:500px;margin-left:auto;margin-right:auto}.admin-info h3{color:#2d3748;font-size:1.3rem;font-weight:600;margin-bottom:1rem;text-align:center}.admin-info ul{list-style:none;padding:0;margin:0}.admin-info li{padding:.75rem 0;color:#4a5568;font-size:1rem;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;gap:.75rem}.admin-info li:last-child{border-bottom:none}.manager-header{text-align:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e2e8f0}.manager-header h2{color:#2d3748;font-size:2rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.manager-subtitle{color:#718096;font-size:1rem;margin:0}.manager-content{display:flex;flex-direction:column;gap:2rem}.action-section{background:#f7fafc;padding:2rem;border-radius:12px;border:1px solid #e2e8f0}.action-section h3{color:#2d3748;font-size:1.5rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.action-section p{color:#4a5568;margin-bottom:1.5rem;line-height:1.6}.init-btn{padding:1rem 2rem;background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #3182ce4d}.init-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #3182ce66}.init-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.result-box{margin-top:1.5rem;padding:1.5rem;border-radius:8px;border:2px solid}.result-box.success{background:#f0fff4;border-color:#38a169;color:#2f855a}.result-box.error{background:#fed7d7;border-color:#e53e3e;color:#c53030}.result-box h4{margin:0 0 1rem;font-size:1.2rem;font-weight:700}.result-box p{margin:0 0 1rem;font-weight:600}.tables-info h5{margin:1rem 0 .5rem;font-size:1rem;font-weight:600}.tables-info ul{margin:0 0 1rem 1rem;padding:0}.tables-info li{margin:.25rem 0;font-family:Courier New,monospace;font-size:.9rem}.info-section{background:#fff;padding:2rem;border-radius:12px;border:1px solid #e2e8f0}.info-section h3{color:#2d3748;font-size:1.5rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.tables-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.table-info{background:#f8fafc;padding:1.5rem;border-radius:8px;border:1px solid #e2e8f0;transition:all .2s}.table-info:hover{border-color:#3182ce;box-shadow:0 4px 12px #3182ce1a;transform:translateY(-2px)}.table-info h4{color:#2d3748;font-size:1.1rem;margin:0 0 .5rem;font-weight:700}.table-info p{color:#718096;margin:0 0 1rem;font-size:.9rem;font-style:italic}.table-info ul{margin:0;padding-left:1.2rem;color:#4a5568;font-size:.9rem;line-height:1.5}.table-info li{margin:.25rem 0}.usage-section{background:#f7fafc;padding:2rem;border-radius:12px;border:1px solid #e2e8f0}.usage-section h3{color:#2d3748;font-size:1.5rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.usage-content{display:flex;flex-direction:column;gap:1.5rem}.usage-item{background:#fff;padding:1.5rem;border-radius:8px;border:1px solid #e2e8f0}.usage-item h4{color:#3182ce;font-size:1.1rem;margin:0 0 .75rem;font-weight:700}.usage-item p{color:#4a5568;margin:0 0 1rem;line-height:1.6}.usage-item ul{margin:0;padding-left:0;list-style:none}.usage-item li{color:#4a5568;margin:.75rem 0;line-height:1.6;padding-left:1rem;position:relative}.usage-item li:before{content:"•";color:#3182ce;font-weight:700;position:absolute;left:0}.usage-item strong{color:#2d3748;font-weight:600}@media screen and (orientation: landscape) and (max-height: 600px){.database-manager{padding:.75rem}.manager-header h2{font-size:1.5rem}.action-section,.info-section,.usage-section{padding:1rem}.tables-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.table-info,.usage-item{padding:1rem}}@media screen and (orientation: portrait) and (max-width: 480px){.manager-header h2{font-size:1.5rem}.action-section,.info-section,.usage-section{padding:1rem}.tables-grid{grid-template-columns:1fr;gap:1rem}.init-btn{padding:.75rem 1.5rem;font-size:1rem}.result-box,.table-info,.usage-item{padding:1rem}}@media screen and (min-width: 768px) and (max-width: 1024px){.tables-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media screen and (min-width: 1024px){.tables-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.usage-content{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}}.database-fix{padding:20px;max-width:800px;margin:0 auto;background:#f8fafc;min-height:100vh}.database-fix-header{text-align:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a}.database-fix-header h2{margin:0 0 10px;color:#2d3748;font-size:28px;font-weight:700}.database-fix-header p{margin:0;color:#718096;font-size:16px}.message{margin-bottom:20px;padding:12px 16px;border-radius:8px;font-weight:700;text-align:center}.message.info{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.message.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.message.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.message.warning{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.database-fix-sections{display:flex;flex-direction:column;gap:20px}.fix-section{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 10px #0000001a}.fix-section h3{margin:0 0 12px;color:#2d3748;font-size:20px;font-weight:700}.fix-section p{margin:0 0 20px;color:#718096;line-height:1.5}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:600;color:#4a5568}.form-group input{width:100%;padding:10px 12px;border:2px solid #e2e8f0;border-radius:6px;font-size:14px;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a}.fix-btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;background:#3182ce;color:#fff}.fix-btn:hover:not(:disabled){background:#2c5282;transform:translateY(-1px);box-shadow:0 4px 12px #3182ce4d}.fix-btn:disabled{background:#a0aec0;cursor:not-allowed;transform:none;box-shadow:none}.create-admin-btn{background:#38a169}.create-admin-btn:hover:not(:disabled){background:#2f855a;box-shadow:0 4px 12px #38a1694d}.test-btn{background:#ed8936}.test-btn:hover:not(:disabled){background:#dd6b20;box-shadow:0 4px 12px #ed89364d}.result-section{background:#fff;border-radius:12px;padding:24px;margin-top:20px;box-shadow:0 2px 10px #0000001a}.result-section h3{margin:0 0 16px;color:#2d3748;font-size:18px;font-weight:700}.result-content{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;padding:16px;overflow-x:auto;font-size:12px;line-height:1.4;color:#4a5568;max-height:400px;overflow-y:auto}.instructions{background:#fff;border-radius:12px;padding:24px;margin-top:20px;box-shadow:0 2px 10px #0000001a}.instructions h3{margin:0 0 16px;color:#2d3748;font-size:18px;font-weight:700}.instructions ol{margin:0;padding-left:20px;color:#4a5568;line-height:1.6}.instructions li{margin-bottom:8px}@media screen and (max-width: 768px){.database-fix{padding:16px}.database-fix-header h2{font-size:24px}.fix-section{padding:20px}.fix-section h3{font-size:18px}.form-group input{font-size:16px}.fix-btn{width:100%;padding:14px 24px}}@media screen and (max-width: 480px){.database-fix{padding:12px}.database-fix-header,.fix-section{padding:16px}.result-content{font-size:11px;padding:12px}}.header{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2);padding:1rem 0;position:relative;z-index:1000;min-height:60px}.header-content{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.header-left{text-align:left}.header-right{display:flex;align-items:center;position:relative}.user-menu-container{position:relative}.header-title{font-size:2rem;font-weight:700;color:#fff;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.header-subtitle{font-size:1rem;color:#ffffffe6;margin:0;font-weight:300}.user-info{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;padding:.375rem .75rem;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:all .2s;cursor:pointer}.user-info:hover,.user-info.active{background:#fff3;transform:translateY(-1px)}.dropdown-arrow{color:#ffffffe6;font-size:.8rem;transition:all .2s;margin-left:.5rem;font-weight:700}.user-info.active .dropdown-arrow{transform:rotate(180deg)}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem;flex-shrink:0}.user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.user-details{display:flex;flex-direction:column;gap:.1rem;min-width:0}.user-name{color:#fff;font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px;display:flex;align-items:center;gap:.5rem}.user-level{color:#fffc;font-size:.75rem;font-weight:400;margin-left:.25rem}.user-info.guest-user{border:1px solid rgba(56,161,105,.3);background:#38a1691a}.user-info.guest-user:hover{background:#38a16933}.guest-badge{background:#38a169;color:#fff;font-size:.6rem;padding:.1rem .4rem;border-radius:10px;margin-left:.5rem;font-weight:500}.user-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026,0 2px 8px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid #e2e8f0;min-width:200px;z-index:10000;overflow:hidden;animation:slideDown .2s ease-out;opacity:1}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.menu-item{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;color:#2d3748;cursor:pointer;transition:all .2s;border-bottom:1px solid #e2e8f0;font-size:.9rem;font-weight:500}.menu-item:last-child{border-bottom:none}.menu-item:hover{background:#f7fafc;color:#3182ce;transform:translate(2px)}.menu-icon{font-size:1.2rem;width:24px;text-align:center;display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.header{padding:1rem 0}.header-title{font-size:1.5rem}.header-subtitle{font-size:.9rem}}.footer{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.1);padding:1rem 0;text-align:center}.footer-content{max-width:600px;margin:0 auto;padding:0 1rem}.footer-text{font-size:.9rem;color:#fffc;margin-bottom:.5rem}.footer-link{color:#ffffffe6;text-decoration:none;margin-left:.5rem;transition:color .3s ease}.footer-link:hover{color:#fff;text-decoration:underline}.footer-copyright{font-size:.8rem;color:#fff9;margin:0}@media (max-width: 768px){.footer{padding:.8rem 0}.footer-text{font-size:.8rem}.footer-copyright{font-size:.7rem}}.tab-navigation{width:100%;margin:0}.tab-header{display:flex;background:#f7fafc;border-bottom:1px solid #e2e8f0;overflow:hidden}.tab-button{flex:1;padding:1.25rem 2rem;background:transparent;border:none;color:#718096;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;display:flex;align-items:center;justify-content:center;gap:.75rem}.tab-icon{font-size:1.1rem}.tab-label{font-size:.9rem}@media screen and (orientation: landscape) and (max-height: 600px){.tab-button{padding:.75rem 1rem;font-size:.9rem;gap:.5rem}.tab-button .tab-icon{font-size:1rem}}@media screen and (orientation: landscape) and (min-width: 768px) and (max-height: 500px){.tab-button{padding:1rem 1.5rem;font-size:.95rem}}@media screen and (orientation: portrait) and (max-width: 480px){.tab-button{padding:1rem .75rem;font-size:.9rem;gap:.5rem}.tab-button .tab-icon{font-size:1.1rem}}.tab-button:hover{color:#4a5568;background:#4299e10d}.tab-button.active{color:#3182ce;background:#fff;box-shadow:0 -2px 8px #0000000d}.tab-button.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3182ce,#63b3ed)}.tab-content{background:#fff;min-height:500px;padding:0}@media (max-width: 768px){.tab-button{padding:.8rem 1rem;font-size:.9rem;flex-direction:column;gap:.3rem}.tab-content{padding:1.5rem 1rem;min-height:300px}}@media (max-width: 480px){.tab-button{padding:.7rem .5rem;font-size:.8rem}.tab-content{padding:1rem .8rem}}.image-preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-preview-modal{background:#1a1a1a;border-radius:12px;width:95%;height:95%;max-width:1200px;max-height:800px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 40px #00000080;animation:slideInUp .3s ease-out}.image-preview-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#2a2a2a;border-bottom:1px solid #404040;flex-shrink:0}.image-preview-title{color:#fff;font-size:1.125rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.image-preview-controls{display:flex;align-items:center;gap:.5rem}.control-btn{background:#404040;border:none;color:#fff;padding:.5rem;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:.875rem;min-width:36px;height:36px;display:flex;align-items:center;justify-content:center}.control-btn:hover:not(:disabled){background:#505050;transform:scale(1.05)}.control-btn.delete-btn{background:#dc2626;color:#fff}.control-btn.delete-btn:hover:not(:disabled){background:#ef4444;transform:scale(1.05)}.control-btn:disabled{opacity:.5;cursor:not-allowed}.close-btn{background:#dc2626}.close-btn:hover:not(:disabled){background:#ef4444}.zoom-level{color:#fff;font-size:.875rem;font-weight:600;min-width:40px;text-align:center}.image-preview-content{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#1a1a1a;position:relative}.image-container{display:flex;align-items:center;justify-content:center;transition:transform .1s ease-out;transform-origin:center center}.preview-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 4px 20px #0000004d;transition:opacity .3s ease}.preview-image.loading{opacity:0}.preview-image.loaded{opacity:1}.image-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:1rem}.loading-spinner{width:32px;height:32px;border:3px solid #404040;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.image-error{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:1rem;text-align:center}.error-icon{font-size:3rem;opacity:.7}.retry-btn{background:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s ease}.retry-btn:hover{background:#2563eb;transform:translateY(-2px)}.image-preview-footer{padding:.75rem 1.5rem;background:#2a2a2a;border-top:1px solid #404040;flex-shrink:0}.shortcuts-hint{color:#a0a0a0;font-size:.875rem;text-align:center;display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}@media screen and (max-width: 768px){.image-preview-modal{width:100%;height:100%;border-radius:0;max-width:none;max-height:none}.image-preview-header{padding:.75rem 1rem;flex-wrap:wrap;gap:.5rem}.image-preview-title{font-size:1rem;flex:1;min-width:120px}.image-preview-controls{flex-wrap:wrap;gap:.25rem}.control-btn{min-width:32px;height:32px;font-size:.8rem;padding:.4rem}.zoom-level{font-size:.8rem;min-width:36px}.image-preview-content{min-height:0;flex:1}.preview-image{max-width:100%;max-height:100%;width:auto;height:auto}.image-preview-footer{padding:.5rem 1rem}.shortcuts-hint{font-size:.8rem;flex-direction:column;gap:.25rem;text-align:center}}@media screen and (max-width: 480px){.image-preview-header{padding:.5rem;flex-direction:column;align-items:stretch;gap:.5rem}.image-preview-title{text-align:center;font-size:.9rem;min-width:auto}.image-preview-controls{gap:.25rem;justify-content:center;flex-wrap:wrap}.control-btn{min-width:28px;height:28px;font-size:.75rem;padding:.3rem}.zoom-level{font-size:.75rem;min-width:32px}.image-preview-footer{padding:.4rem .5rem}.shortcuts-hint{font-size:.75rem;line-height:1.3}}@media screen and (max-width: 360px){.image-preview-header{padding:.4rem}.image-preview-title{font-size:.85rem}.control-btn{min-width:26px;height:26px;font-size:.7rem}.zoom-level{font-size:.7rem;min-width:30px}.shortcuts-hint{font-size:.7rem}}.mobile-ocr-history{padding:1rem;background:#f8fafc;min-height:100vh;overflow:visible;position:relative;z-index:1}.empty-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;text-align:center;color:#718096}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-container h3{font-size:1.25rem;color:#2d3748;margin:0 0 .5rem}.empty-container p{margin:0;line-height:1.5}.history-stats{display:flex;background:#fff;border-radius:1rem;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a;gap:2rem}.stat-number{font-size:1.5rem;font-weight:700;color:#3182ce;margin-bottom:.25rem}.stat-label{font-size:.875rem;color:#718096;font-weight:500}.records-list{display:flex;flex-direction:column;gap:1rem;overflow:visible;position:relative;z-index:2}.record-card{background:#fff;border-radius:1rem;box-shadow:0 2px 8px #0000001a;overflow:visible;transition:transform .2s ease,box-shadow .2s ease;position:relative;z-index:3;-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.record-card:hover{transform:none;box-shadow:0 4px 16px #00000026}.record-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1rem .5rem}.record-meta{display:flex;gap:.5rem;align-items:center}.record-time{font-size:.875rem;color:#4a5568;font-weight:500}.record-engine{background:#edf2f7;color:#4a5568;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.record-actions{display:flex;gap:.5rem}.record-image-container{padding:0 1rem;margin-bottom:1rem;position:relative;cursor:pointer;overflow:hidden;border-radius:.5rem;background:#f1f5f9}.record-actions-row{display:flex;gap:.5rem;margin:0 1rem 1rem;padding:.75rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;flex-wrap:wrap;justify-content:center}.record-image{width:100%;max-width:100%;height:auto;border-radius:.5rem;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.record-image.thumbnail{max-height:200px;object-fit:cover;cursor:pointer}.record-image.thumbnail:hover{transform:scale(1.02);box-shadow:0 4px 12px #00000026}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;border-radius:.5rem}.record-image-container:hover .image-overlay{opacity:1}.preview-hint{color:#fff;font-size:.875rem;font-weight:600;background:#fff3;padding:.5rem 1rem;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.record-content{padding:0 1rem 1rem}.record-text-preview{font-size:.875rem;line-height:1.6;color:#2d3748;margin:0 0 1rem;background:#f8fafc;padding:1rem;border-radius:.5rem;border-left:4px solid #3182ce;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;text-align:left}.text-actions{display:flex;gap:.5rem;flex-wrap:wrap}.action-btn{background:#f7fafc;border:1px solid #e2e8f0;color:#4a5568;padding:.5rem .75rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:all .2s;display:flex;align-items:center;gap:.25rem}.action-btn:hover{background:#edf2f7;border-color:#cbd5e0}.action-btn.delete-btn{background:#fed7d7;border-color:#feb2b2;color:#c53030}.action-btn.delete-btn:hover{background:#feb2b2;border-color:#fc8181}.action-btn.read-btn{background:#bee3f8;border-color:#90cdf4;color:#2b6cb0}.action-btn.read-btn:hover{background:#90cdf4;border-color:#63b3ed}.action-btn.edit-btn{background:#c6f6d5;border-color:#9ae6b4;color:#276749}.action-btn.edit-btn:hover{background:#9ae6b4;border-color:#68d391}.action-btn.phonetics-btn{background:#e9d8fd;border-color:#d6bcfa;color:#553c9a}.action-btn.phonetics-btn:hover{background:#d6bcfa;border-color:#b794f6}.edit-mode{margin-top:1rem}.edit-textarea{width:100%;min-height:150px;padding:.75rem;border:2px solid #e2e8f0;border-radius:.5rem;font-size:.875rem;line-height:1.6;resize:vertical;font-family:inherit;background:#f8fafc}.edit-textarea:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a}.edit-actions{display:flex;gap:.5rem;margin-top:.75rem}.fullscreen-edit-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;z-index:10000;display:flex;align-items:center;justify-content:center;padding:1rem}.fullscreen-edit-container{background:#fff;border-radius:1rem;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 40px #0000004d}.fullscreen-edit-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0;background:#f8fafc;border-radius:1rem 1rem 0 0}.fullscreen-edit-header h3{margin:0;color:#2d3748;font-size:1.1rem}.close-fullscreen-btn{background:#f56565;color:#fff;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background-color .2s}.close-fullscreen-btn:hover{background:#e53e3e}.fullscreen-edit-textarea{flex:1;width:100%;min-height:400px;padding:1.5rem;border:none;font-size:1rem;line-height:1.6;resize:none;font-family:inherit;background:#fff;outline:none}.fullscreen-edit-actions{display:flex;gap:1rem;padding:1rem 1.5rem;border-top:1px solid #e2e8f0;background:#f8fafc;border-radius:0 0 1rem 1rem;justify-content:flex-end}.action-btn.fullscreen-edit-btn{background:#e9d8fd;border-color:#d6bcfa;color:#553c9a}.action-btn.fullscreen-edit-btn:hover{background:#d6bcfa;border-color:#b794f6}.fullscreen-btn{background:#4299e1;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s}.fullscreen-btn:hover:not(:disabled){background:#3182ce}.fullscreen-btn:disabled{background:#a0aec0;cursor:not-allowed}.save-btn{background:#48bb78;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s}.save-btn:disabled{background:#a0aec0;cursor:not-allowed}.cancel-btn{background:#f56565;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s}.cancel-btn:hover:not(:disabled){background:#e53e3e}.cancel-btn:disabled{background:#a0aec0;cursor:not-allowed}.phonetics-section{margin-top:1rem;padding:1rem;background:#f8fafc;border-top:1px solid #e2e8f0;transition:none}.phonetics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.phonetics-title{font-size:.875rem;font-weight:600;color:#4a5568}.phonetics-mode-selector{display:flex;gap:.25rem}.mode-btn{background:#fff;border:1px solid #e2e8f0;color:#718096;padding:.25rem .5rem;border-radius:.25rem;cursor:pointer;font-size:.75rem;transition:all .2s}.mode-btn.active{background:#3182ce;border-color:#3182ce;color:#fff}.mode-btn:hover:not(.active){background:#f7fafc;border-color:#cbd5e0}.phonetics-loading{display:flex;align-items:center;gap:.5rem;color:#718096;font-size:.875rem}.loading-spinner-small{width:16px;height:16px;border:2px solid #e2e8f0;border-top:2px solid #3182ce;border-radius:50%;animation:spin 1s linear infinite}.phonetics-content{background:#fff;padding:1rem;border-radius:.5rem;border:1px solid #e2e8f0;transition:none;overflow:visible;position:relative;width:100%;max-width:100%;box-sizing:border-box;-webkit-overflow-scrolling:touch;overflow-x:visible;overflow-y:visible}.phonetics-paragraph{margin-bottom:.75rem;line-height:1.8;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;overflow:visible;width:100%;max-width:100%;box-sizing:border-box;-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto;-webkit-word-break:break-word;-ms-word-break:break-word;min-width:0;flex-shrink:1}.phonetics-paragraph:last-child{margin-bottom:0}.word-phonetic-pair{display:inline-block;position:relative;margin-right:.5rem;white-space:normal;vertical-align:top;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.word-phonetic-pair.hover{position:relative;display:inline;cursor:pointer}.word-phonetic-pair.hover .english-word{color:#3182ce;text-decoration:underline;text-decoration-style:dotted}.word-phonetic-pair.hover.active .english-word{color:#2c5282;font-weight:500}.hover-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);background:#000000f2;color:#fff;padding:.75rem;border-radius:.5rem;font-size:.8rem;white-space:normal;word-wrap:break-word;overflow-wrap:break-word;z-index:10000;box-shadow:0 4px 12px #0000004d;border:1px solid rgba(255,255,255,.1);min-width:200px;max-width:280px;text-align:center;pointer-events:auto;-webkit-transform:translateX(-50%) translateY(-8px) translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.hover-popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#000000f2}.hover-phonetic-display{font-family:Courier New,monospace;color:#fc8181;font-weight:500;margin-bottom:.5rem;font-size:.85rem}.hover-translation-display{color:#cbd5e0;font-size:.75rem;margin-bottom:.5rem;font-style:italic;line-height:1.4}.hover-actions{display:flex;gap:.5rem;margin-top:.75rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.2);justify-content:center}.hover-action-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.3rem .6rem;border-radius:.3rem;font-size:.7rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.25rem;min-width:65px;justify-content:center;white-space:nowrap}.hover-action-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.hover-action-btn:active{transform:translateY(0);background:#ffffff40}.hover-action-btn.playing{background:#60a5fa4d;border-color:#60a5fa80}.hover-action-btn.favorited{background:#fc81814d;border-color:#fc818180}.word-phonetic-pair.compact{display:inline-block;margin:.05rem .08rem .05rem 0;padding:.1rem .25rem;min-width:35px;vertical-align:top}.word-phonetic-pair.compact .english-word{display:block;font-size:.75rem;font-weight:500;color:#3182ce;line-height:1.2;margin-bottom:.1rem}.word-phonetic-pair.compact .phonetic{display:block;font-size:.65rem;color:#4a5568;padding:.08rem .15rem;background:#f8fafc;border-radius:.2rem;border:1px solid #e2e8f0;line-height:1.2;text-align:center;position:static;opacity:1;pointer-events:auto;transform:none;margin:0;box-shadow:none}.word-phonetic-pair.compact .phonetic:after{display:none}.word-phonetic-pair.compact .translation{display:block;margin-top:.1rem;font-size:.55rem;color:#718096;line-height:1.2;text-align:center}.word-phonetic-pair.compact .phonetic-actions{display:none}.word-phonetic-pair.compact.active .phonetic{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#000000f2;color:#fff;padding:.75rem;border-radius:.5rem;font-size:.75rem;white-space:normal;word-wrap:break-word;overflow-wrap:break-word;z-index:1000;max-width:280px;min-width:200px;text-align:center;box-shadow:0 4px 12px #0000004d;border:1px solid rgba(255,255,255,.1);margin-top:0}.word-phonetic-pair.compact.active .phonetic:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#000000f2}.word-phonetic-pair.compact.active .phonetic-actions{margin-top:.75rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.2)}.word-phonetic-pair.compact.active .phonetic-action-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:.65rem;padding:.25rem .5rem}.word-phonetic-pair.compact.active .phonetic-action-btn:hover{background:#ffffff4d;border-color:#ffffff80}.word-phonetic-pair.compact.active .phonetic-action-btn.pronounce-btn{background:#3182cecc;border-color:#3182ce}.word-phonetic-pair.compact.active .phonetic-action-btn.favorite-btn{background:#48bb78cc;border-color:#48bb78}.word-phonetic-pair.compact.active .phonetic-action-btn.favorite-btn.favorited{background:#f56565cc;border-color:#f56565}.compact-text-container{margin-top:1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;padding:1rem;width:100%;max-width:100%;overflow:visible;box-sizing:border-box}.paragraph-break{height:1.5rem;width:100%;display:block;clear:both}.compact-text-line{font-size:1rem;line-height:1.6;color:#2d3748;margin-bottom:.75rem;word-wrap:break-word;overflow-wrap:break-word;white-space:pre-wrap;word-break:break-word;overflow:visible;max-width:100%}.compact-space{white-space:pre}.compact-punctuation{color:inherit}.compact-word-block{position:relative;display:inline-block;cursor:pointer;transition:all .2s ease;margin:0 .1rem;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;white-space:normal;max-width:100%}.word-phonetic-vertical{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:0}.compact-word-text{font-size:1rem;font-weight:500;color:#2d3748;line-height:1.2;cursor:pointer;transition:all .2s ease;padding:.1rem .2rem;border-radius:.25rem}.compact-word-text:hover{background:#3182ce1a;color:#3182ce}.compact-phonetic-text{font-size:.85rem;font-weight:400;color:#e53e3e;line-height:1;cursor:pointer;transition:all .2s ease;padding:.1rem .2rem;border-radius:.25rem;margin-top:.1rem;font-family:Courier New,monospace;background:#e53e3e1a;border:1px solid rgba(229,62,62,.2);font-style:normal}.compact-phonetic-text:hover{background:#e53e3e33;border-color:#e53e3e66;transform:translateY(-1px)}.compact-word-inline:hover{background:#3182ce1a}.compact-word-inline.active{background:#3182ce33}.compact-word-text{font-weight:500;color:#2d3748}.compact-word-popup{position:absolute;top:-.5rem;left:50%;transform:translate(-50%) translateY(-100%);background:#000000f2;color:#fff;padding:.75rem;border-radius:.5rem;font-size:.8rem;white-space:normal;word-wrap:break-word;overflow-wrap:break-word;z-index:1000;box-shadow:0 4px 12px #0000004d;border:1px solid rgba(255,255,255,.1);min-width:200px;max-width:280px;text-align:center;display:none}.compact-word-block.active .compact-word-popup{display:block!important}.compact-word-popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#000000f2}.compact-phonetic-display{font-family:Courier New,monospace;color:#e53e3e;font-weight:500;margin-bottom:.5rem}.compact-translation-display{color:#cbd5e0;font-size:.75rem;margin-bottom:.5rem;font-style:italic}.compact-actions-inline{display:flex;gap:.5rem;justify-content:center;margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.2)}.compact-action-btn-inline{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all .2s ease;box-shadow:0 2px 4px #0000001a;flex-shrink:0}.compact-action-btn-inline.pronounce-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.compact-action-btn-inline.pronounce-btn:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1);transform:translateY(-1px);box-shadow:0 4px 8px #0003}.compact-action-btn-inline.pronounce-btn.playing{background:linear-gradient(135deg,#48bb78,#38a169);animation:pulse 1.5s infinite}.compact-action-btn-inline.favorite-btn{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none}.compact-action-btn-inline.favorite-btn:hover{background:linear-gradient(135deg,#e879f9,#ef4444);transform:translateY(-1px);box-shadow:0 4px 8px #0003}.compact-action-btn-inline.favorite-btn.favorited{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.word-card{background:#fff;border:2px solid #e2e8f0;border-radius:.75rem;padding:.75rem;cursor:pointer;transition:all .2s ease;position:relative;box-shadow:0 2px 4px #0000001a}.word-card:hover{border-color:#3182ce;box-shadow:0 4px 8px #3182ce33;transform:translateY(-2px)}.word-card.active{border-color:#3182ce;box-shadow:0 4px 12px #3182ce4d;transform:translateY(-2px)}.word-card-content{text-align:center}.word-text{font-size:1rem;font-weight:600;color:#2d3748;margin-bottom:.5rem;word-break:break-word}.word-phonetic{font-size:.8rem;color:#e53e3e;font-weight:500;margin-bottom:.25rem;font-family:Courier New,monospace}.word-translation{font-size:.7rem;color:#718096;line-height:1.3;margin-top:.25rem}.word-card-actions{position:absolute;top:.5rem;right:.5rem;display:flex;gap:.25rem;opacity:.7;transition:opacity .2s ease}.word-card:hover .word-card-actions,.word-card.active .word-card-actions{opacity:1}.word-action-btn{width:28px;height:28px;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:all .2s ease;box-shadow:0 2px 4px #0003}.word-action-btn.pronounce-btn{background:#3182ce;color:#fff}.word-action-btn.pronounce-btn:hover{background:#2c5aa0;transform:scale(1.1)}.word-action-btn.pronounce-btn.playing{background:#48bb78;animation:pulse 1.5s infinite}.word-action-btn.favorite-btn{background:#f7fafc;color:#4a5568;border:1px solid #e2e8f0}.word-action-btn.favorite-btn:hover{background:#edf2f7;transform:scale(1.1)}.word-action-btn.favorite-btn.favorited{background:#fed7d7;color:#c53030;border-color:#feb2b2}.word-phonetic-pair.compact .phonetic-actions{display:none;margin-top:.3rem;padding-top:.3rem;border-top:1px solid #e2e8f0;gap:.2rem}.word-phonetic-pair.compact.active .phonetic-actions{display:flex}.word-phonetic-pair.compact .phonetic-action-btn{background:#f7fafc;border:1px solid #e2e8f0;color:#4a5568;font-size:.5rem;padding:.15rem .3rem;border-radius:.2rem;min-width:40px}.word-phonetic-pair.compact .phonetic-action-btn:hover{background:#edf2f7;border-color:#cbd5e0}.word-phonetic-pair.compact .phonetic-action-btn.pronounce-btn{background:#bee3f8;border-color:#90cdf4;color:#2b6cb0}.word-phonetic-pair.compact .phonetic-action-btn.favorite-btn{background:#c6f6d5;border-color:#9ae6b4;color:#276749}.word-phonetic-pair.compact .phonetic-action-btn.favorite-btn.favorited{background:#fed7d7;border-color:#feb2b2;color:#c53030}.english-word{color:#3182ce;font-weight:500;cursor:help;white-space:normal;display:inline-block;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.phonetic{position:absolute;top:-10px;left:50%;transform:translate(-50%) translateY(-100%) translateZ(0);background:#000000f2;color:#fff;padding:.75rem;border-radius:.5rem;font-size:.75rem;white-space:normal;word-wrap:break-word;overflow-wrap:break-word;opacity:0;pointer-events:none;z-index:9999;max-width:280px;min-width:200px;text-align:center;box-shadow:0 4px 12px #0000004d;border:1px solid rgba(255,255,255,.1);-webkit-transform:translateX(-50%) translateY(-100%) translateZ(0);-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto;-webkit-word-break:break-word;-ms-word-break:break-word;min-width:0;max-width:calc(100vw - 2rem);box-sizing:border-box;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}.word-phonetic-pair.phonetic-left .phonetic{left:0;transform:translate(0) translateY(-100%) translateZ(0);-webkit-transform:translateX(0) translateY(-100%) translateZ(0)}.word-phonetic-pair.phonetic-right .phonetic{left:auto;right:0;transform:translate(0) translateY(-100%) translateZ(0);-webkit-transform:translateX(0) translateY(-100%) translateZ(0)}.word-phonetic-pair.phonetic-bottom .phonetic{top:100%;transform:translate(-50%) translateY(10px) translateZ(0);-webkit-transform:translateX(-50%) translateY(10px) translateZ(0)}.phonetic:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#000000e6}.word-phonetic-pair:hover .phonetic{opacity:1;transition:none}.phonetic-text{display:block;font-family:Courier New,monospace;color:#e53e3e;font-weight:500;margin-bottom:.5rem;font-size:.75rem}.phonetic-translation{display:block;margin-top:.25rem;margin-bottom:.5rem;font-size:.7rem;color:#cbd5e0;line-height:1.3;font-style:italic}.translation{display:block;margin-top:.25rem;font-size:.7rem;color:#cbd5e0;line-height:1.3}.phonetic-actions{display:flex;gap:.5rem;margin-top:.75rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.2);justify-content:center;pointer-events:auto}.phonetic-action-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.25rem .5rem;border-radius:.25rem;font-size:.65rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.25rem;min-width:60px;justify-content:center;pointer-events:auto;position:relative;z-index:1}.phonetic-action-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.phonetic-action-btn:active{transform:none}.phonetic-action-btn.pronounce-btn{background:#3182cecc;border-color:#3182ce}.phonetic-action-btn.pronounce-btn:hover{background:#3182ce}.phonetic-action-btn.favorite-btn{background:#48bb78cc;border-color:#48bb78}.phonetic-action-btn.favorite-btn:hover{background:#48bb78}.phonetic-action-btn.favorite-btn.favorited{background:#f56565cc;border-color:#f56565}.phonetic-action-btn.favorite-btn.favorited:hover{background:#f56565}.space-token{white-space:pre;display:inline}.punctuation-token{display:inline;color:inherit}.phonetics-error{text-align:center;color:#e53e3e;font-size:.875rem;padding:1rem}@media screen and (max-width: 480px){.mobile-ocr-history{padding:.75rem}.history-stats{padding:1rem;gap:1rem}.record-header{padding:.75rem .75rem .5rem}.record-image-container{padding:0 .75rem}.record-actions-row{margin:0 .75rem .75rem;padding:.5rem;gap:.25rem}.record-content{padding:0 .75rem .75rem}.text-actions{gap:.25rem}.action-btn{padding:.375rem .5rem;font-size:.8rem}.phonetics-section{padding:.75rem}.fullscreen-edit-overlay{padding:.5rem}.fullscreen-edit-container{max-height:95vh}.fullscreen-edit-header{padding:.75rem 1rem}.fullscreen-edit-header h3{font-size:1rem}.fullscreen-edit-textarea{min-height:300px;padding:1rem;font-size:.9rem}.fullscreen-edit-actions{padding:.75rem 1rem;gap:.5rem}.fullscreen-edit-actions button{flex:1;min-width:80px}.text-actions{flex-wrap:wrap}.action-btn{flex:1;min-width:80px}.word-cards-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.word-card{padding:.5rem}.word-text{font-size:.9rem}.word-phonetic{font-size:.7rem}.word-translation{font-size:.65rem}.word-card-actions{top:.25rem;right:.25rem}.word-action-btn{width:24px;height:24px;font-size:.6rem}.phonetic{max-width:250px;min-width:180px;font-size:.7rem;padding:.6rem}.phonetic-actions{gap:.4rem;margin-top:.5rem}.phonetic-action-btn{font-size:.6rem;padding:.2rem .4rem}.compact-text-container{padding:.75rem;width:100%;max-width:100%;overflow:visible}.compact-text-line{font-size:.9rem;line-height:1.5;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;white-space:pre-wrap;width:100%;max-width:100%}.compact-word-block{margin:0 .05rem;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;white-space:normal}.compact-word-text{font-size:.9rem;padding:.05rem .15rem}.compact-phonetic-text{font-size:.75rem;padding:.05rem .15rem;margin-top:.05rem}.compact-word-popup,.hover-popup{font-size:.75rem;padding:.6rem;min-width:180px;max-width:260px}.hover-phonetic-display{font-size:.8rem}.hover-translation-display{font-size:.7rem}.hover-actions{gap:.4rem}.hover-action-btn{font-size:.65rem;padding:.25rem .5rem;min-width:60px}.compact-phonetic-display{font-size:.8rem}.compact-translation-display{font-size:.7rem}.compact-actions-inline{gap:.4rem}.compact-action-btn-inline{width:24px;height:24px;font-size:.6rem}.phonetics-content{padding:.75rem;width:85vw;max-width:85vw;overflow:visible;margin:0 auto}.phonetics-paragraph{width:100%;max-width:100%;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;white-space:pre-wrap}}@supports (-webkit-touch-callout: none){.phonetics-content{-webkit-overflow-scrolling:touch;overflow-x:visible;overflow-y:visible;-webkit-transform:translateZ(0);transform:translateZ(0);width:85vw;max-width:85vw}.phonetics-paragraph{-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto;-webkit-word-break:break-word;-ms-word-break:break-word;word-break:break-word;-webkit-transform:translateZ(0);transform:translateZ(0)}.phonetic{-webkit-transform:translateX(-50%) translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}.word-phonetic-pair.phonetic-left .phonetic,.word-phonetic-pair.phonetic-right .phonetic{-webkit-transform:translateX(0) translateZ(0)}.word-phonetic-pair.phonetic-bottom .phonetic{-webkit-transform:translateX(-50%) translateZ(0)}.compact-text-container,.compact-word-block,.word-phonetic-vertical{-webkit-transform:translateZ(0);transform:translateZ(0)}}@media (hover: none) and (pointer: coarse){.record-card:hover{transform:none;box-shadow:0 2px 8px #0000001a}.action-btn:hover{background:#f7fafc;border-color:#e2e8f0}.record-card:active{transform:none;transition:none}.compact-word-item:hover{transform:none;box-shadow:0 2px 4px #3182ce1a}.compact-phonetic:hover{transform:none;background:#e53e3e33}.compact-action-btn:hover{transform:none}.compact-action-btn:active{transform:scale(.95)}.compact-word-inline:hover{background:#3182ce1a}.compact-phonetic-item:hover{transform:none;background:#e53e3e33}.compact-action-btn-inline:hover{transform:none}.compact-action-btn-inline:active{transform:scale(.9)}}.analyze-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.analyze-btn:hover{background:linear-gradient(135deg,#5a6fd8,#6d4190);transform:translateY(-1px)}.analysis-btn-group{display:flex;gap:.25rem;flex-wrap:wrap}.analysis-btn-group .analyze-btn{flex:1;min-width:80px;font-size:.75rem;padding:.4rem .6rem}.analysis-btn-group .analyze-btn.basic{background:#48bb78;border-color:#38a169}.analysis-btn-group .analyze-btn.basic:hover{background:#38a169}.analysis-btn-group .analyze-btn.advanced{background:#9f7aea;border-color:#805ad5}.analysis-btn-group .analyze-btn.advanced:hover{background:#805ad5}.analysis-mode-tag{display:inline-block;padding:.2rem .5rem;border-radius:12px;font-size:.7rem;font-weight:600;margin-left:.5rem;vertical-align:middle}.analysis-mode-tag.basic{background:#e6fffa;color:#234e52;border:1px solid #38a169}.analysis-mode-tag.advanced{background:#f3e8ff;color:#553c9a;border:1px solid #805ad5}.grammar-analysis-section{margin-top:16px;border:1px solid #e0e7ff;border-radius:12px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);overflow:hidden}.grammar-analysis-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff}.grammar-analysis-title{font-size:16px;font-weight:600}.analysis-summary{display:flex;gap:12px;font-size:12px}.summary-item{background:#fff3;padding:4px 8px;border-radius:6px;white-space:nowrap}.grammar-analysis-content{padding:0}.analysis-section{padding:20px;border-bottom:1px solid #e2e8f0}.analysis-section:last-child{border-bottom:none}.section-title{font-size:16px;font-weight:600;color:#374151;margin-bottom:16px;display:flex;align-items:center;gap:8px}.sentences-analysis{display:flex;flex-direction:column;gap:12px}.sentence-analysis-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.sentence-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sentence-number{font-weight:600;color:#4f46e5;font-size:14px}.sentence-type{font-size:12px;background:#f3f4f6;padding:2px 8px;border-radius:4px;color:#6b7280}.sentence-text{font-style:italic;color:#374151;margin-bottom:12px;padding:8px;background:#f9fafb;border-radius:4px;line-height:1.5}.sentence-structure{display:flex;flex-direction:column;gap:6px}.structure-component{display:flex;align-items:center;gap:8px}.component-label{font-weight:500;color:#6b7280;min-width:40px;font-size:14px}.component-value{color:#374151;font-weight:500;font-size:14px}.grammar-points{display:flex;flex-direction:column;gap:12px}.grammar-point-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.point-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.point-type{background:#dbeafe;color:#1e40af;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:500}.point-name{font-weight:600;color:#374151;font-size:14px}.point-description{color:#6b7280;margin-bottom:8px;font-size:14px;line-height:1.5}.point-examples{margin-top:8px}.examples-label{font-size:12px;color:#6b7280;margin-right:8px;font-weight:500}.example-item{background:#f3f4f6;padding:4px 8px;border-radius:4px;margin:4px 0;font-size:13px;color:#374151;line-height:1.4}.phrases-analysis{display:flex;flex-direction:column;gap:12px}.phrase-group{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.phrase-type{font-weight:600;color:#374151;margin-bottom:8px;font-size:14px}.phrase-list{display:flex;flex-wrap:wrap;gap:6px}.phrase-item{background:#fef3c7;color:#92400e;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:500}.word-types-chart{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.word-type-item{display:flex;align-items:center;gap:12px;margin-bottom:8px}.word-type-item:last-child{margin-bottom:0}.type-label{font-weight:500;color:#374151;min-width:80px;font-size:14px}.type-bar{flex:1;height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden}.type-fill{height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed);transition:width .3s ease}.type-count{font-weight:600;color:#6b7280;min-width:30px;text-align:right;font-size:14px}.sentence-analysis-block{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:16px;overflow:hidden}.original-sentence{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:16px;border-bottom:1px solid #e5e7eb}.sentence-structure-analysis{padding:16px;border-bottom:1px solid #e5e7eb}.analysis-subtitle{font-size:14px;font-weight:600;color:#374151;margin:0 0 12px;display:flex;align-items:center;gap:6px}.structure-components{display:flex;flex-direction:column;gap:8px}.sentence-grammar-points{padding:16px;border-bottom:1px solid #e5e7eb;background:#fef3c7}.grammar-points-compact{display:flex;flex-direction:column;gap:8px}.grammar-point-compact{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#fff;border-radius:6px;border:1px solid #f59e0b}.grammar-point-compact .point-type{background:#fbbf24;color:#92400e;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:500;min-width:40px;text-align:center}.grammar-point-compact .point-name{font-weight:600;color:#374151;font-size:13px;min-width:60px}.grammar-point-compact .point-description{color:#6b7280;font-size:12px;flex:1}.sentence-phrases{padding:16px;border-bottom:1px solid #e5e7eb;background:#ecfdf5}.phrases-compact{display:flex;flex-direction:column;gap:8px}.phrase-group-compact{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#fff;border-radius:6px;border:1px solid #10b981}.phrase-type-label{background:#34d399;color:#065f46;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:500;min-width:50px;text-align:center}.phrase-examples{color:#374151;font-size:12px;flex:1}.overall-word-stats{padding:16px;background:#f0f9ff}.word-types-compact{display:flex;flex-wrap:wrap;gap:8px}.word-type-compact{background:#0ea5e9;color:#fff;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:500}@media (max-width: 768px){.grammar-analysis-section{margin-top:12px;border-radius:8px}.grammar-analysis-header{padding:12px;flex-direction:column;gap:8px;align-items:flex-start}.grammar-analysis-title{font-size:14px}.analysis-summary{gap:8px;flex-wrap:wrap}.summary-item{font-size:11px;padding:3px 6px}.original-sentence{padding:12px}.sentence-header{flex-direction:column;gap:4px;align-items:flex-start}.sentence-number{font-size:13px}.sentence-type{font-size:11px}.sentence-text{font-size:13px;line-height:1.5}.sentence-structure-analysis,.sentence-grammar-points,.sentence-phrases,.overall-word-stats{padding:12px}.analysis-subtitle{font-size:13px;margin-bottom:8px}.component-label{font-size:12px;min-width:35px}.component-value{font-size:12px}.grammar-point-compact{padding:4px 8px;gap:6px}.grammar-point-compact .point-type{font-size:10px;min-width:35px}.grammar-point-compact .point-name{font-size:12px;min-width:50px}.grammar-point-compact .point-description{font-size:11px}.phrase-group-compact{padding:4px 8px;gap:6px}.phrase-type-label{font-size:10px;min-width:45px}.phrase-examples{font-size:11px}.word-type-compact{font-size:11px;padding:3px 6px}}.history-toolbar{background:#fff;border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 8px #00000014}.search-box{position:relative;margin-bottom:1rem}.search-input{width:100%;padding:.875rem 3rem .875rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:16px;transition:all .3s ease;box-sizing:border-box}.search-input:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}.clear-search{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:#e2e8f0;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#4a5568;font-size:14px;transition:all .2s ease}.clear-search:hover{background:#cbd5e0}.quick-access{margin-bottom:1rem}.quick-btn{padding:.625rem 1rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.25rem}.quick-btn:hover{border-color:#cbd5e0;background:#f7fafc}.quick-btn.active{border-color:#f59e0b;background:#fffbeb;color:#f59e0b}.time-filters{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.filter-btn{flex:1;min-width:60px;padding:.625rem .75rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease}.filter-btn:hover{border-color:#cbd5e0;background:#f7fafc}.filter-btn.active{border-color:#4299e1;background:#ebf8ff;color:#4299e1}.sort-section{display:flex;align-items:center;gap:.5rem}.sort-label{font-size:.875rem;font-weight:600;color:#4a5568;white-space:nowrap}.sort-select{flex:1;padding:.625rem .75rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#2d3748;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease}.sort-select:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}.time-group{margin-bottom:1.5rem}.time-group-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;margin-bottom:.75rem;box-shadow:0 2px 8px #667eea4d}.time-group-title{font-size:1rem;font-weight:700;color:#fff}.time-group-count{font-size:.875rem;color:#ffffffe6;font-weight:600}.time-group-records{display:flex;flex-direction:column;gap:1rem}.record-title-section{flex:1;min-width:0}.record-title{font-size:1.125rem;font-weight:700;color:#2d3748;margin:0 0 .5rem;line-height:1.4;word-break:break-word}.record-title mark{background:#fef08a;color:#854d0e;padding:0 2px;border-radius:2px}.record-meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.8125rem;color:#718096}.record-time,.record-engine,.record-word-count{display:inline-flex;align-items:center;gap:.25rem}.favorite-btn{font-size:1.5rem;padding:.375rem;transition:transform .2s ease}.favorite-btn:hover{transform:scale(1.1)}.favorite-btn.favorited{color:#f59e0b}.no-records{text-align:center;padding:4rem 1rem;color:#a0aec0}.no-records p{font-size:1.125rem;margin:0}@media (max-width: 768px){.history-toolbar{padding:.875rem}.search-input{padding:.75rem 2.5rem .75rem .875rem;font-size:16px}.time-filters{gap:.375rem}.filter-btn{padding:.5rem .625rem;font-size:.8125rem;min-width:50px}.sort-section{flex-direction:column;align-items:stretch;gap:.5rem}.sort-label{font-size:.8125rem}.sort-select{width:100%;padding:.5rem .625rem;font-size:.8125rem}.record-title{font-size:1rem}.record-meta{font-size:.75rem;gap:.5rem}.time-group-header{padding:.625rem .875rem}.time-group-title{font-size:.9375rem}.time-group-count{font-size:.8125rem}}.mobile-user-favorites{padding:1rem;background:#fff;min-height:100vh}.favorites-search{margin-bottom:1rem}.search-form{display:flex;gap:.5rem}.search-input{flex:1;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;background:#f8fafc;transition:all .2s ease}.search-input:focus{outline:none;border-color:#3182ce;background:#fff;box-shadow:0 0 0 3px #3182ce1a}.search-btn{padding:.75rem 1rem;background:linear-gradient(135deg,#3182ce,#2c5282);color:#fff;border:none;border-radius:12px;font-size:1.2rem;cursor:pointer;transition:all .2s ease;min-width:50px}.search-btn:hover{background:linear-gradient(135deg,#2c5282,#2a4a73);transform:translateY(-1px)}.learning-status-filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;padding:.75rem;background:linear-gradient(135deg,#667eea0d,#764ba20d);border-radius:12px;border:1px solid rgba(102,126,234,.1)}.learning-status-btn{padding:.5rem 1rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:20px;color:#4a5568;font-size:.9rem;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0;font-weight:500}.learning-status-btn:hover{background:#edf2f7;border-color:#cbd5e0}.learning-status-btn.active{background:linear-gradient(135deg,#3182ce,#2c5282);border-color:#3182ce;color:#fff;font-weight:600;box-shadow:0 2px 4px #3182ce4d}.category-filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.category-btn{padding:.5rem 1rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:20px;color:#4a5568;font-size:.9rem;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.category-btn:hover{background:#edf2f7;border-color:#cbd5e0}.category-btn.active{background:#3182ce;border-color:#3182ce;color:#fff}.subcategory-filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;padding-left:.5rem;border-left:3px solid #3182ce}.subcategory-btn{padding:.4rem .9rem;background:#fff5f5;border:1px solid #feb2b2;border-radius:16px;color:#c53030;font-size:.85rem;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.subcategory-btn:hover{background:#ffe5e5;border-color:#fc8181}.subcategory-btn.active{background:#e53e3e;border-color:#e53e3e;color:#fff}.favorites-stats{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.5rem 0;color:#718096;font-size:.9rem}.category-info{background:#e6fffa;color:#2f855a;padding:.25rem .75rem;border-radius:12px;font-size:.8rem}.favorites-list{display:flex;flex-direction:column;gap:1rem}.favorite-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:1rem;transition:all .2s ease;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.favorite-item:hover{border-color:#cbd5e0;box-shadow:0 4px 12px #0000000d;transform:translateY(-1px)}.favorite-content{flex:1;min-width:0}.favorite-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:1rem}.favorite-word{font-size:1.25rem;font-weight:700;color:#2d3748;margin:0;word-break:break-all}.favorite-category{background:#e6fffa;color:#2f855a;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;white-space:nowrap;flex-shrink:0}.favorite-phonetic{color:#e53e3e;font-weight:600;font-size:1rem;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;background:#fed7d7;padding:.25rem .5rem;border-radius:6px;display:inline-block;margin-bottom:.5rem}.favorite-translation{color:#4a5568;font-size:.95rem;line-height:1.5;margin-bottom:.5rem;word-break:break-word}.favorite-meta{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:#a0aec0}.favorite-actions{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.pronounce-btn{padding:.5rem;background:#ebf8ff;border:1px solid #90cdf4;border-radius:8px;color:#2b6cb0;font-size:1rem;cursor:pointer;transition:all .2s ease;min-width:40px;height:40px;display:flex;align-items:center;justify-content:center}.pronounce-btn:hover:not(:disabled){background:#bee3f8;border-color:#63b3ed;transform:translateY(-1px)}.pronounce-btn.playing{background:#c6f6d5;border-color:#9ae6b4;color:#276749;animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 2px 4px #48bb784d}50%{box-shadow:0 4px 12px #48bb7899}to{box-shadow:0 2px 4px #48bb784d}}.delete-btn{padding:.5rem;background:#fed7d7;border:1px solid #feb2b2;border-radius:8px;color:#e53e3e;font-size:1rem;cursor:pointer;transition:all .2s ease;min-width:40px;height:40px;display:flex;align-items:center;justify-content:center}.delete-btn:hover:not(:disabled){background:#feb2b2;border-color:#fc8181;transform:translateY(-1px)}.delete-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-container{text-align:center;padding:3rem 1rem;color:#718096}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #3182ce;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.error-container{text-align:center;padding:3rem 1rem;color:#e53e3e}.error-message{margin-bottom:1rem;font-size:1rem}.retry-btn{padding:.75rem 1.5rem;background:#3182ce;color:#fff;border:none;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.retry-btn:hover{background:#2c5282;transform:translateY(-1px)}.empty-container{text-align:center;padding:3rem 1rem;color:#718096}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-message{font-size:1.1rem;font-weight:600;margin-bottom:.5rem;color:#4a5568}.empty-hint{font-size:.9rem;color:#a0aec0}.load-more-container{text-align:center;margin-top:2rem}.load-more-btn{padding:.75rem 2rem;background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;color:#4a5568;font-size:.9rem;cursor:pointer;transition:all .2s ease}.load-more-btn:hover:not(:disabled){background:#edf2f7;border-color:#cbd5e0;transform:translateY(-1px)}.load-more-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 480px){.mobile-user-favorites{padding:.75rem}.favorite-item{padding:.75rem;flex-direction:column;gap:.75rem}.favorite-actions{flex-direction:row;justify-content:flex-end;gap:.375rem}.pronounce-btn,.delete-btn{min-width:36px;height:36px;font-size:.9rem}.favorite-header{flex-direction:column;align-items:flex-start;gap:.5rem}.category-filter{margin-bottom:.75rem}.category-btn{padding:.4rem .8rem;font-size:.85rem}.subcategory-filter{margin-bottom:.75rem;padding-left:.25rem}.subcategory-btn{padding:.35rem .7rem;font-size:.8rem}}.delete-confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.delete-confirm-modal{background:#fff;border-radius:16px;padding:0;max-width:400px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out;overflow:hidden}.modal-header{padding:20px 24px;border-bottom:1px solid #e2e8f0;background:linear-gradient(135deg,#fff5f5,#fed7d7)}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#c53030;text-align:center}.modal-body{padding:24px;text-align:center}.modal-body p{margin:0 0 12px;font-size:1rem;color:#2d3748;line-height:1.6}.modal-body strong{color:#c53030;font-weight:600}.modal-warning{font-size:.875rem;color:#e53e3e;font-weight:500;margin-top:8px}.modal-footer{display:flex;gap:12px;padding:16px 24px;border-top:1px solid #e2e8f0;background:#f7fafc}.modal-btn{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.modal-btn-cancel{background:#fff;color:#4a5568;border:2px solid #e2e8f0}.modal-btn-cancel:hover{background:#f7fafc;border-color:#cbd5e0;transform:translateY(-1px)}.modal-btn-confirm{background:linear-gradient(135deg,#e53e3e,#c53030);color:#fff}.modal-btn-confirm:hover{background:linear-gradient(135deg,#c53030,#9b2c2c);transform:translateY(-1px);box-shadow:0 4px 12px #c530304d}.modal-btn:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.mobile-phonetics-learning{padding:1rem;background:#f8fafc;min-height:100vh}.audio-status-banner{padding:.75rem 1rem;margin:0;text-align:center;font-size:.875rem;font-weight:500}.status-warning{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff;padding:.5rem 1rem;border-radius:8px;margin:0 1rem;box-shadow:0 2px 8px #ff6b6b4d}.status-info{background:linear-gradient(135deg,#feca57,#ff9ff3);color:#2c2c54;padding:.5rem 1rem;border-radius:8px;margin:0 1rem;box-shadow:0 2px 8px #feca574d}.status-success{background:linear-gradient(135deg,#48dbfb,#0abde3);color:#fff;padding:.5rem 1rem;border-radius:8px;margin:0 1rem;box-shadow:0 2px 8px #48dbfb4d}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:#718096}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;text-align:center}.error-message{color:#e53e3e;margin-bottom:1rem}.retry-btn{background:#3182ce;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:background-color .2s}.retry-btn:hover{background:#2c5aa0}.controls-section,.search-container{margin-bottom:1rem}.search-input{width:100%;padding:.75rem;border:2px solid #e2e8f0;border-radius:.5rem;font-size:1rem;background:#fff;transition:border-color .2s}.search-input:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a}.search-input::placeholder{color:#a0aec0}.filter-tabs{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem}.filter-tab{background:#fff;border:2px solid #e2e8f0;color:#4a5568;padding:.5rem 1rem;border-radius:1.5rem;cursor:pointer;font-size:.875rem;font-weight:500;white-space:nowrap;transition:all .2s;flex-shrink:0}.filter-tab.active{background:#3182ce;border-color:#3182ce;color:#fff}.filter-tab:hover:not(.active){background:#f7fafc;border-color:#cbd5e0}.stats-section{display:flex;background:#fff;border-radius:1rem;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a;align-items:center;justify-content:space-between}.stat-item{display:flex;flex-direction:column;align-items:center;flex:1}.stat-number{font-size:1.25rem;font-weight:700;color:#3182ce;margin-bottom:.25rem}.stat-label{font-size:.75rem;color:#718096;font-weight:500}.practice-start-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:1.5rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d}.practice-start-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 16px #667eea66}.practice-start-btn:disabled{background:#a0aec0;cursor:not-allowed;transform:none;box-shadow:none}.phonemes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.phoneme-card{background:#fff;border-radius:1rem;padding:1rem;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .3s ease;position:relative;border:2px solid transparent}.phoneme-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026;border-color:#3182ce}.phoneme-card:active{transform:translateY(-2px)}.phoneme-symbol{font-size:2rem;font-weight:700;color:#2d3748;text-align:center;margin-bottom:.5rem}.phoneme-type{font-size:.75rem;color:#718096;text-align:center;margin-bottom:.5rem;background:#f7fafc;padding:.25rem .5rem;border-radius:.25rem;font-weight:500}.phoneme-description-short{font-size:.8rem;color:#4a5568;text-align:center;line-height:1.4;margin-bottom:.75rem}.play-btn{position:absolute;top:.5rem;right:.5rem;background:linear-gradient(135deg,#ff6b6b,#ff8e8e);border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 4px #ff6b6b4d}.play-btn:hover{transform:scale(1.1);box-shadow:0 4px 8px #ff6b6b66}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:#718096;text-align:center}.empty-icon{font-size:2rem;margin-bottom:1rem}.practice-mode{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;min-height:100vh}.practice-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-btn{background:#fff3;color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem;transition:background-color .2s}.back-btn:hover{background:#ffffff4d}.practice-progress{display:flex;flex-direction:column;align-items:center;gap:.5rem}.progress-bar{width:100px;height:4px;background:#ffffff4d;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:#fff;transition:width .3s ease}.practice-content{padding:2rem 1rem;text-align:center}.practice-card{background:#fffffff2;border-radius:1.5rem;padding:2rem;margin-bottom:2rem;box-shadow:0 8px 32px #0000001a}.phoneme-symbol-large{font-size:4rem;font-weight:700;color:#2d3748;margin-bottom:1rem}.phoneme-description{font-size:1.125rem;color:#4a5568;margin-bottom:1rem;line-height:1.6}.phoneme-examples{display:flex;justify-content:center;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.example-word{background:#f7fafc;color:#2d3748;padding:.5rem 1rem;border-radius:1rem;font-size:.875rem;font-weight:500}.example-word.clickable{cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.example-word.clickable:hover{background:#e2e8f0;transform:translateY(-2px)}.example-word.clickable:active{background:#cbd5e0;transform:translateY(0)}.example-word-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.25rem;border-radius:1rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 2px 8px #667eea4d}.example-word-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.example-word-btn:active{transform:translateY(0);box-shadow:0 2px 6px #667eea4d}.play-sound-btn{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff;border:none;padding:1rem 2rem;border-radius:1rem;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 16px #ff6b6b4d}.play-sound-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b66}.practice-actions{display:flex;gap:1rem;justify-content:center}.practice-btn{border:none;padding:1rem 2rem;border-radius:1rem;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;min-width:120px}.wrong-btn{background:#fed7d7;color:#c53030;box-shadow:0 4px 16px #f565654d}.wrong-btn:hover{background:#feb2b2;transform:translateY(-2px);box-shadow:0 6px 20px #f5656566}.correct-btn{background:#c6f6d5;color:#276749;box-shadow:0 4px 16px #48bb784d}.correct-btn:hover{background:#9ae6b4;transform:translateY(-2px);box-shadow:0 6px 20px #48bb7866}.practice-score{text-align:center;padding:1rem;background:#ffffff1a;border-radius:1rem;margin:1rem}.score-text{font-size:1.125rem;font-weight:600}.phoneme-detail-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{position:relative;background:#fff;border-radius:1rem;width:100%;max-width:400px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0}.modal-title{font-size:1.125rem;font-weight:600;color:#2d3748;margin:0}.close-btn{background:none;border:none;color:#718096;font-size:1.25rem;padding:.25rem;border-radius:.25rem;cursor:pointer;transition:background-color .2s}.close-btn:hover{background:#f7fafc}.modal-body{padding:1.5rem}.phoneme-info{text-align:center;margin-bottom:1.5rem}.phoneme-type{background:#f7fafc;color:#4a5568;padding:.25rem .75rem;border-radius:1rem;font-size:.875rem;font-weight:500;display:inline-block;margin-bottom:1rem}.examples-list{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.play-detail-btn{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:1rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 16px #ff6b6b4d;width:100%}.play-detail-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b66}@media screen and (max-width: 480px){.mobile-phonetics-learning{padding:.75rem}.phonemes-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.phoneme-card{padding:.75rem}.phoneme-symbol{font-size:1.5rem}.stats-section{padding:1rem;flex-direction:column;gap:1rem}.practice-content{padding:1rem .75rem}.phoneme-symbol-large{font-size:3rem}.practice-actions{flex-direction:column;gap:.75rem}.practice-btn{min-width:auto}}@media (hover: none) and (pointer: coarse){.phoneme-card:hover{transform:none;box-shadow:0 2px 8px #0000001a;border-color:transparent}.phoneme-card:active{transform:scale(.98);transition:transform .1s ease}.play-btn:hover{transform:none}.play-btn:active{transform:scale(.95)}}.mobile-word-search{padding:1rem;background:#f8fafc;min-height:100vh}.search-container{margin-bottom:1rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:120px;color:#718096}@media screen and (max-width: 480px){.mobile-word-search{padding:.75rem}}.mobile-ecdict-query{padding:1rem;background:#f8fafc;min-height:100vh;width:100%;max-width:100vw}.search-form-container{margin-bottom:1.5rem;width:100%}.search-form{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 2px 8px #0000001a;width:100%;max-width:100%}.input-group{position:relative;margin-bottom:1rem;width:100%}.search-input{width:100%;padding:1rem 3rem 1rem 1rem;border:2px solid #e2e8f0;border-radius:.75rem;font-size:1rem;background:#f8fafc;transition:all .2s}.search-input:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a;background:#fff}.clear-btn{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#a0aec0;cursor:pointer;padding:.25rem;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all .2s}.clear-btn:hover:not(:disabled){background:#e2e8f0;color:#4a5568}.clear-btn:disabled{opacity:.5;cursor:not-allowed}.search-btn{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem;border-radius:.75rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #667eea4d;height:45.6px;display:flex;align-items:center;justify-content:center}.search-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.search-btn:disabled{background:#a0aec0;cursor:not-allowed;transform:none;box-shadow:none}.quick-words-section{margin-bottom:1.5rem}.section-title{font-size:1rem;font-weight:600;color:#2d3748;margin:0 0 1rem}.quick-words{display:flex;flex-wrap:wrap;gap:.5rem}.quick-word-btn{background:#fff;border:2px solid #e2e8f0;color:#4a5568;padding:.5rem .75rem;border-radius:1rem;font-size:.875rem;cursor:pointer;transition:all .2s;font-weight:500}.quick-word-btn:hover{background:#3182ce;border-color:#3182ce;color:#fff;transform:translateY(-1px)}.loading-status{background:#fff;border-radius:.75rem;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a}.loading-progress{text-align:center}.progress-bar{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.progress-text{font-size:.875rem;color:#718096}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:120px;color:#718096;background:#fff;border-radius:.75rem;margin-bottom:1rem}.loading-spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top:3px solid #3182ce;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;background:#fed7d7;border-radius:.75rem;margin-bottom:1rem}.error-icon{font-size:2rem;margin-bottom:1rem}.error-message{color:#c53030;margin:0;font-size:.875rem}.suggestions-container{background:#fff;border-radius:.75rem;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a}.suggestions-list{display:flex;flex-wrap:wrap;gap:.5rem}.suggestion-btn{background:#f7fafc;border:1px solid #e2e8f0;color:#4a5568;padding:.5rem .75rem;border-radius:.5rem;font-size:.875rem;cursor:pointer;transition:all .2s}.suggestion-btn:hover{background:#3182ce;border-color:#3182ce;color:#fff}.result-container{background:#fff;border-radius:.75rem;box-shadow:0 2px 8px #0000001a;overflow:hidden}@media screen and (max-width: 480px){.mobile-ecdict-query{padding:.75rem}.search-form{padding:1rem}.quick-words{gap:.375rem}.quick-word-btn{padding:.375rem .5rem;font-size:.8rem}}.mobile-word-study{padding:1rem;background:#f8fafc;min-height:100vh}.study-container{background:#fff;border-radius:1rem;box-shadow:0 2px 8px #0000001a;overflow:hidden}@media screen and (max-width: 480px){.mobile-word-study{padding:.75rem}}.special-word-study{display:flex;flex-direction:column;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.study-header{display:flex;align-items:center;justify-content:space-between;padding:20px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2)}.back-btn{background:#fff3;border:none;color:#fff;padding:10px 15px;border-radius:8px;font-size:16px;cursor:pointer;transition:all .3s ease}.back-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.header-info h2{margin:0;font-size:24px;font-weight:600}.mode-description{margin:5px 0 0;font-size:14px;opacity:.8}.progress-info{font-size:16px;font-weight:500;background:#fff3;padding:8px 12px;border-radius:20px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:20px;text-align:center;padding:20px}.error-icon{font-size:48px}.error-message{font-size:18px;margin:0}.retry-btn{background:#ff6b6b;border:none;color:#fff;padding:12px 24px;border-radius:8px;font-size:16px;cursor:pointer;transition:all .3s ease}.retry-btn:hover{background:#ff5252;transform:translateY(-1px)}.study-complete{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:30px;text-align:center;padding:20px}.complete-icon{font-size:64px}.study-complete h3{margin:0;font-size:28px;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;width:100%;max-width:400px}.stat-item{background:#ffffff1a;padding:20px;border-radius:12px;text-align:center}.stat-value{font-size:24px;font-weight:700;margin-bottom:5px}.stat-label{font-size:14px;opacity:.8}.complete-actions{display:flex;gap:15px}.restart-btn,.back-to-home-btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;cursor:pointer;transition:all .3s ease}.restart-btn{background:#4ecdc4;color:#fff}.restart-btn:hover{background:#45b7b8;transform:translateY(-1px)}.back-to-home-btn{background:#fff3;color:#fff}.back-to-home-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.study-content{flex:1;display:flex;flex-direction:column;padding:30px 20px;gap:30px}.word-display{display:flex;flex-direction:column;align-items:center;gap:15px;background:#ffffff1a;padding:40px 20px;border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.word-text{font-size:36px;font-weight:700;text-align:center;letter-spacing:1px}.word-phonetic{font-size:18px;opacity:.8;font-style:italic}.speaker-btn{background:#fff3;border:none;color:#fff;padding:12px;border-radius:50%;font-size:20px;cursor:pointer;transition:all .3s ease;width:50px;height:50px;display:flex;align-items:center;justify-content:center}.speaker-btn:hover{background:#ffffff4d;transform:scale(1.1)}.answer-section{display:flex;flex-direction:column;gap:20px}.answer-input{width:100%;padding:20px;border:2px solid rgba(255,255,255,.3);border-radius:12px;background:#ffffff1a;color:#fff;font-size:18px;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.answer-input:focus{outline:none;border-color:#4ecdc4;background:#ffffff26}.answer-input::placeholder{color:#fff9}.answer-input:disabled{opacity:.6;cursor:not-allowed}.answer-feedback{display:flex;flex-direction:column;gap:10px;padding:20px;background:#ffffff1a;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.correct-answer{font-size:16px;font-weight:600;color:#4ecdc4}.user-answer{font-size:16px;padding:10px;border-radius:8px}.user-answer.correct{background:#4ccdc433;color:#4ecdc4}.user-answer.incorrect{background:#ff6b6b33;color:#ff6b6b}.action-buttons{display:flex;justify-content:center}.check-btn,.next-btn{padding:15px 30px;border:none;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:120px}.check-btn{background:#4ecdc4;color:#fff}.check-btn:hover:not(:disabled){background:#45b7b8;transform:translateY(-2px)}.check-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.next-btn{background:#ff6b6b;color:#fff}.next-btn:hover{background:#ff5252;transform:translateY(-2px)}.study-progress{display:flex;flex-direction:column;gap:10px}.progress-bar{width:100%;height:8px;background:#fff3;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4ecdc4,#44a08d);transition:width .3s ease}.progress-text{text-align:center;font-size:14px;opacity:.8}@media (max-width: 768px){.study-header{padding:15px}.header-info h2{font-size:20px}.progress-info{font-size:14px;padding:6px 10px}.study-content{padding:20px 15px;gap:25px}.word-display{padding:30px 15px}.word-text{font-size:28px}.word-phonetic{font-size:16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:15px}.stat-item{padding:15px}.stat-value{font-size:20px}.complete-actions{flex-direction:column;width:100%}.restart-btn,.back-to-home-btn{width:100%}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.word-text{font-size:24px}.answer-input{padding:15px;font-size:16px}.check-btn,.next-btn{padding:12px 24px;font-size:16px}}.mobile-word-importer{padding:1rem;background:#f8fafc;min-height:100vh}.importer-container{background:#fff;border-radius:1rem;box-shadow:0 2px 8px #0000001a;overflow:hidden}@media screen and (max-width: 480px){.mobile-word-importer{padding:.75rem}}.mobile-user-profile{padding:1rem;background:#f8fafc;min-height:100vh;animation:fadeInUp .6s cubic-bezier(.4,0,.2,1)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.profile-header-card{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:1rem}.profile-avatar{flex-shrink:0}.profile-avatar img{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid #e2e8f0}.avatar-placeholder{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;border:3px solid #e2e8f0}.profile-info{flex:1;min-width:0}.profile-details h2{margin:0 0 .25rem;color:#2d3748;font-size:1.25rem;font-weight:700}.user-email{margin:0 0 .75rem;color:#718096;font-size:.9rem}.edit-btn{background:#3182ce;color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.edit-btn:hover:not(:disabled){background:#2c5aa0;transform:translateY(-1px)}.edit-btn:disabled{opacity:.6;cursor:not-allowed}.edit-form{display:flex;flex-direction:column;gap:.75rem}.edit-input{padding:.75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;transition:border-color .2s;background:#fff}.edit-input:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a}.edit-actions{display:flex;gap:.5rem}.save-btn{background:#48bb78;color:#fff;border:none;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;flex:1}.save-btn:hover:not(:disabled){background:#38a169}.save-btn:disabled{opacity:.6;cursor:not-allowed}.cancel-btn{background:#e2e8f0;color:#4a5568;border:none;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;flex:1}.cancel-btn:hover:not(:disabled){background:#cbd5e0}.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;font-weight:500}.error-message{background:#fed7d7;color:#c53030;border:1px solid #feb2b2}.success-message{background:#c6f6d5;color:#2f855a;border:1px solid #9ae6b4}.message-icon{font-size:1rem}.stats-section{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a}.section-title{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;color:#2d3748;font-size:1.1rem;font-weight:600}.title-icon{font-size:1.2rem}.loading-stats{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:#718096}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.stat-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1rem;display:flex;align-items:center;gap:.75rem;transition:all .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-icon{font-size:1.25rem;flex-shrink:0}.stat-content{flex:1;min-width:0}.stat-value{font-size:1.25rem;font-weight:700;color:#2d3748;margin:0}.stat-label{font-size:.75rem;color:#718096;margin:0}.settings-section{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a}.settings-content{display:flex;flex-direction:column;gap:1.5rem}.setting-group{display:flex;flex-direction:column;gap:.5rem}.setting-label{font-weight:600;color:#4a5568;font-size:.9rem}.setting-slider{width:100%;height:6px;border-radius:3px;background:#e2e8f0;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.setting-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#3182ce;cursor:pointer;box-shadow:0 2px 4px #0003;transition:all .2s}.setting-slider::-webkit-slider-thumb:hover{background:#2c5aa0;transform:scale(1.1)}.setting-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#3182ce;cursor:pointer;border:none;box-shadow:0 2px 4px #0003;transition:all .2s}.setting-slider::-moz-range-thumb:hover{background:#2c5aa0;transform:scale(1.1)}.setting-range{display:flex;justify-content:space-between;font-size:.75rem;color:#718096;margin-top:.25rem}.setting-actions{display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.test-btn,.reset-btn{padding:.75rem 1rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.85rem;flex:1}.test-btn{background:#38a169;color:#fff}.test-btn:hover{background:#2f855a;transform:translateY(-1px)}.reset-btn:hover{background:#cbd5e0;transform:translateY(-1px)}.other-settings-section{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a}.settings-list{display:flex;flex-direction:column;gap:.75rem}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #f1f5f9}.setting-item:last-child{border-bottom:none}.setting-info{display:flex;align-items:center;gap:.75rem}.setting-icon{font-size:1.1rem;width:20px;text-align:center}.setting-name{font-size:.9rem;color:#4a5568;font-weight:500}.setting-control{flex-shrink:0}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e0;transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background-color:#3182ce}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.features-section{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a}.section-title{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#2d3748}.title-icon{font-size:1.3rem}.features-grid{display:grid;gap:.75rem}.feature-card{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:12px;background:#f8fafc;border:2px solid #e2e8f0;cursor:pointer;transition:all .3s ease}.feature-card:hover{background:linear-gradient(135deg,#667eea1a,#764ba20d);border-color:#667eea4d;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.feature-card.import-card:hover{background:linear-gradient(135deg,#3182ce1a,#2c52820d);border-color:#3182ce4d;box-shadow:0 4px 12px #3182ce33}.feature-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;flex-shrink:0}.feature-card.import-card .feature-icon{background:linear-gradient(135deg,#3182ce,#2c5282)}.feature-content{flex:1;min-width:0}.feature-content h4{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:#2d3748}.feature-content p{margin:0;font-size:.85rem;color:#718096}.feature-arrow{font-size:1.2rem;color:#718096;transition:all .3s ease}.feature-card:hover .feature-arrow{transform:translate(4px);color:#667eea}.profile-actions{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.action-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border:none;border-radius:12px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}.action-btn.primary{background:#3182ce;color:#fff}.action-btn.primary:hover{background:#2c5aa0;transform:translateY(-1px)}.action-btn.secondary{background:#e2e8f0;color:#4a5568}.action-btn.secondary:hover{background:#cbd5e0}.action-btn.danger{background:#fed7d7;color:#c53030}.action-btn.danger:hover{background:#feb2b2}.btn-icon{font-size:1rem}@media screen and (max-width: 480px){.mobile-user-profile{padding:.75rem}.profile-header-card{padding:1rem;flex-direction:column;text-align:center;gap:1rem}.profile-avatar img,.avatar-placeholder{width:80px;height:80px}.avatar-placeholder{font-size:2rem}.profile-details h2{font-size:1.5rem}.stats-grid{grid-template-columns:1fr;gap:.75rem}.stat-card{padding:.75rem;flex-direction:column;text-align:center;gap:.5rem}.stat-icon,.stat-value{font-size:1.5rem}.setting-actions{flex-direction:column;gap:.5rem}.test-btn,.reset-btn{padding:.75rem}}@media screen and (orientation: landscape) and (max-height: 600px){.mobile-user-profile{padding:.5rem}.profile-header-card,.stats-section,.settings-section,.other-settings-section{padding:1rem;margin-bottom:.75rem}.stats-grid{grid-template-columns:repeat(4,1fr);gap:.75rem}.stat-card{padding:.75rem;flex-direction:column;text-align:center;gap:.5rem}.stat-icon,.stat-value{font-size:1.25rem}.stat-label{font-size:.7rem}.settings-content{gap:1rem}.setting-actions{flex-direction:row;gap:.5rem}.test-btn,.reset-btn{padding:.5rem .75rem;font-size:.8rem}.profile-actions{flex-direction:row;gap:.5rem;margin-bottom:1rem}.action-btn{padding:.75rem;font-size:.8rem;flex:1}}.mobile-article-analysis{padding:15px;background:#f8f9fa;min-height:100vh}.mobile-analysis-header{text-align:center;margin-bottom:20px;padding:20px 15px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;box-shadow:0 4px 15px #0000001a}.mobile-analysis-header h2{margin:0 0 8px;font-size:1.5rem;font-weight:600}.mobile-analysis-header p{margin:0;font-size:.95rem;opacity:.9}.mobile-input-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000001a;margin-bottom:15px}.options-toggle{margin-bottom:15px;text-align:center}.toggle-btn{padding:10px 20px;background:#f8f9fa;border:2px solid #e1e5e9;border-radius:25px;font-size:.9rem;font-weight:600;color:#333;cursor:pointer;transition:all .2s ease}.toggle-btn.active{background:#667eea;color:#fff;border-color:#667eea}.mobile-options-panel{background:#f8f9fa;border-radius:8px;padding:15px;margin-bottom:20px;border:1px solid #e1e5e9}.option-group{margin-bottom:20px}.option-group:last-child{margin-bottom:0}.option-group label{display:block;font-weight:600;color:#333;margin-bottom:10px;font-size:.9rem}.option-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.option-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:#fff;border:2px solid #e1e5e9;border-radius:8px;font-size:.8rem;cursor:pointer;transition:all .2s ease;text-align:center}.option-btn.active{background:#667eea;color:#fff;border-color:#667eea}.option-icon{font-size:1.2rem}.option-label{font-weight:600}.mobile-text-input{margin-bottom:20px}.mobile-text-input label{display:block;font-weight:600;color:#333;margin-bottom:10px;font-size:.95rem}.mobile-textarea{width:100%;min-height:150px;padding:12px;border:2px solid #e1e5e9;border-radius:8px;font-size:.95rem;line-height:1.5;font-family:Courier New,monospace;resize:vertical;background:#fafbfc;transition:border-color .2s ease}.mobile-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fff}.mobile-textarea::placeholder{color:#6c757d;font-style:italic}.text-stats{display:flex;gap:10px;margin-top:8px;font-size:.8rem;color:#6c757d;flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:3px;padding:3px 6px;background:#f8f9fa;border-radius:3px;border:1px solid #e1e5e9;flex:1;min-width:0}.stat-label{color:#6c757d;font-weight:500;font-size:.75rem}.stat-value{color:#333;font-weight:600;font-size:.75rem}.mobile-action-buttons{display:flex;flex-direction:column;gap:12px}.mobile-btn{padding:14px 20px;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-align:center;display:flex;align-items:center;justify-content:center;gap:6px}.mobile-btn:disabled{opacity:.6;cursor:not-allowed}.mobile-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea4d}.mobile-btn.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.mobile-btn.secondary{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;box-shadow:0 2px 8px #f093fb4d}.mobile-btn.secondary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #f093fb66}.mobile-btn.outline{background:transparent;color:#667eea;border:2px solid #667eea}.mobile-btn.outline:hover:not(:disabled){background:#667eea;color:#fff}.mobile-btn.small{padding:8px 16px;font-size:.85rem}.secondary-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.mobile-error{display:flex;align-items:center;gap:8px;padding:12px;background:#fee;color:#c53030;border:1px solid #feb2b2;border-radius:6px;margin-top:15px;font-size:.85rem}.error-icon{font-size:1rem}.mobile-result-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.mobile-result-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f8f9fa;border-bottom:1px solid #e1e5e9;position:relative;flex-wrap:nowrap;gap:15px}.mobile-result-header h3{margin:0;color:#333;font-size:1.2rem;flex:1;min-width:0;white-space:nowrap}.result-actions{display:flex;gap:8px;flex-shrink:0;align-items:center;flex-direction:row}.mobile-result-content{padding:20px}.mobile-summary,.mobile-questions,.mobile-analysis{margin-bottom:25px}.mobile-summary h4,.mobile-questions h4,.mobile-analysis h4{color:#333;margin-bottom:15px;font-size:1.1rem;display:flex;align-items:center;gap:6px}.summary-text{background:#f8f9fa;padding:15px;border-radius:8px;border-left:4px solid #667eea;line-height:1.6;font-size:.9rem}.questions-list{display:flex;flex-direction:column;gap:15px}.question-card{background:#f8f9fa;padding:15px;border-radius:8px;border-left:4px solid #f093fb}.question{margin-bottom:10px;font-size:.9rem;line-height:1.5}.answer{color:#666;font-size:.85rem;line-height:1.5;padding-left:15px;border-left:2px solid #e1e5e9}.section-card{background:#f8f9fa;padding:15px;border-radius:8px;border-left:4px solid #667eea}.section-card h5{color:#333;margin:0 0 12px;font-size:1rem;display:flex;align-items:center;gap:6px}.section-content{line-height:1.6;color:#555;white-space:pre-wrap;font-size:.9rem}.raw-response{background:#f8f9fa;padding:15px;border-radius:8px;border-left:4px solid #667eea;line-height:1.6;white-space:pre-wrap;font-size:.9rem}.result-meta{margin-top:15px;padding-top:12px;border-top:1px solid #e1e5e9;color:#6c757d;font-size:.8rem}.meta-info{display:flex;gap:8px;text-align:center;justify-content:space-between;flex-wrap:nowrap}.meta-item{display:flex;flex-direction:column;align-items:center;padding:6px 4px;background:#f8f9fa;border-radius:6px;border:1px solid #e1e5e9;transition:all .2s ease;flex:1;min-width:0;font-size:.75rem}.meta-item:hover{background:#e9ecef;transform:translateY(-1px);box-shadow:0 2px 6px #0000001a}.meta-label{font-size:.7rem;color:#6c757d;margin-bottom:2px;font-weight:500;line-height:1.2}.meta-value{font-size:.75rem;color:#333;font-weight:600;line-height:1.2}.mobile-loading{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}.mobile-loading p{color:#fff;font-size:1rem;margin:0 0 20px}.progress-container{width:80%;max-width:300px;margin-top:20px}.progress-bar{width:100%;height:8px;background:#ffffff4d;border-radius:4px;overflow:hidden;margin-bottom:10px}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease;position:relative}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:progress-shine 2s infinite}@keyframes progress-shine{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{color:#fff;font-size:.9rem;font-weight:600;text-align:center}.chinese-meaning-content{line-height:1.8}.chinese-meaning-item{margin-bottom:15px;padding:12px;background:#f8f9fa;border-radius:8px;border-left:4px solid #007bff}.chinese-meaning-original{font-weight:600;color:#333;margin-bottom:6px;font-size:.95rem}.chinese-meaning-chinese{color:#007bff;font-weight:500;margin-bottom:6px;font-size:.95rem;padding-left:20px;position:relative}.chinese-meaning-chinese:before{content:"🈯";position:absolute;left:0;top:0}.chinese-meaning-meta{font-size:.8rem;color:#6c757d;margin-top:6px}.chinese-meaning-meta span{margin-right:10px}.chinese-meaning-difficulty{background:#e3f2fd;color:#1976d2;padding:2px 6px;border-radius:10px;font-size:.7rem}.chinese-meaning-keywords{color:#28a745;font-weight:500}.chinese-meaning-grammar{color:#dc3545;font-weight:500}.paragraph-translation{margin-bottom:20px;padding:15px;background:#fff;border:1px solid #e1e5e9;border-radius:8px}.paragraph-translation h4{color:#007bff;margin-bottom:12px;font-size:1rem}.phrase-translation{margin-bottom:12px;padding:10px;background:#f8f9fa;border-radius:6px;border-left:3px solid #28a745}.phrase-original{font-weight:600;color:#333;margin-bottom:4px;font-size:.9rem}.phrase-chinese{color:#28a745;font-weight:500;margin-bottom:4px;font-size:.9rem}.difficult-sentence{margin-bottom:15px;padding:12px;background:#fff5f5;border-radius:8px;border-left:4px solid #dc3545}.difficult-sentence-original{font-weight:600;color:#333;margin-bottom:6px;font-size:.9rem}.difficult-sentence-chinese{color:#dc3545;font-weight:500;margin-bottom:6px;font-size:.9rem}.difficult-sentence-explanation{color:#6c757d;font-style:italic;margin-bottom:4px;font-size:.85rem}.difficult-sentence-grammar{color:#dc3545;font-weight:500;font-size:.8rem}@media (max-width: 480px){.mobile-article-analysis{padding:10px}.mobile-result-header{flex-wrap:wrap;gap:10px}.result-actions{flex-direction:column;gap:6px}.mobile-analysis-header{padding:15px 10px}.mobile-analysis-header h2{font-size:1.3rem}.mobile-input-section{padding:15px}.mobile-options-panel{padding:12px}.option-grid{grid-template-columns:1fr;gap:6px}.option-btn{padding:10px 6px;font-size:.75rem}.secondary-buttons{grid-template-columns:1fr;gap:6px}.mobile-result-content{padding:15px}.section-card,.question-card{padding:12px}.meta-info{gap:4px}.meta-item{padding:4px 2px;font-size:.7rem}.meta-label{font-size:.65rem;margin-bottom:1px}.meta-value{font-size:.7rem}}@media (max-width: 768px) and (orientation: landscape){.mobile-textarea{min-height:120px}.option-grid{grid-template-columns:repeat(4,1fr)}}.word-phonetic-pair{display:inline;margin:0;padding:0;background:none;border:none;box-shadow:none;min-width:auto;position:relative;cursor:help}.word-phonetic-pair .english-word{color:#3182ce;text-decoration:none;font-size:1rem;display:inline;cursor:help;position:relative}.word-phonetic-pair .english-word:hover{color:#2c5aa0}.word-phonetic-pair .phonetic-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#2d3748;color:#fff;padding:.6rem 1rem;border-radius:8px;font-size:.8rem;white-space:normal;z-index:1000;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;margin-bottom:.3rem;max-width:400px;min-width:200px;text-align:left;line-height:1.5;word-wrap:break-word;box-shadow:0 4px 12px #0000004d}.word-phonetic-pair .phonetic-popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#2d3748}.word-phonetic-pair:hover .phonetic-popup{opacity:1;visibility:visible}.word-phonetic-pair .phonetic{color:#fff;font-weight:600;margin-bottom:.4rem;font-family:Courier New,monospace;font-size:.8rem;display:block;line-height:1.4}.word-phonetic-pair .word-meaning{display:inline-block;font-size:.85rem;color:#fbbf24;margin-top:.4rem;margin-right:.5rem;font-weight:500;line-height:1.4;word-wrap:break-word;border-top:none;padding:0;vertical-align:middle}.word-phonetic-pair .phonetic-actions{display:inline-flex;gap:.25rem;margin-top:.4rem;align-items:center;vertical-align:middle;flex-shrink:0}.word-phonetic-pair .phonetic-action-btn.pronounce-btn{background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #3182ce4d}.word-phonetic-pair .phonetic-action-btn.pronounce-btn:hover{transform:scale(1.1);box-shadow:0 4px 8px #3182ce66}.word-phonetic-pair .phonetic-action-btn.pronounce-btn:active{transform:scale(.95)}.word-phonetic-pair .phonetic-action-btn.favorite-btn{background:none;border:none;font-size:.9rem;cursor:pointer;padding:.15rem;border-radius:4px;transition:all .2s;margin-left:.3rem;display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px}.word-phonetic-pair .phonetic-action-btn.favorite-btn:hover:not(:disabled){background:#ffc1071a;transform:scale(1.1)}.word-phonetic-pair .phonetic-action-btn.favorite-btn.favorited{color:#ffc107}.word-phonetic-pair .phonetic-action-btn.favorite-btn:not(.favorited){color:#cbd5e0}.word-phonetic-pair .phonetic-action-btn.favorite-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.word-phonetic-pair .phonetic-action-btn.favorite-btn:before{content:"☆";font-size:12px;line-height:1}.word-phonetic-pair .phonetic-action-btn.favorite-btn.favorited:before{content:"★";font-size:12px;line-height:1}.word-phonetic-pair.phonetic-left .phonetic-popup{left:0;transform:translate(0)}.word-phonetic-pair.phonetic-right .phonetic-popup{left:auto;right:0;transform:translate(0)}.word-phonetic-pair.phonetic-bottom .phonetic-popup{top:100%;bottom:auto;transform:translate(-50%);margin-top:.3rem;margin-bottom:0}.word-phonetic-pair.phonetic-bottom .phonetic-popup:after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:#2d3748}.word-phonetic-pair.phonetic-left.phonetic-bottom .phonetic-popup{left:0;transform:translate(0)}.word-phonetic-pair.phonetic-right.phonetic-bottom .phonetic-popup{left:auto;right:0;transform:translate(0)}.analysis-table .word-phonetic-pair .phonetic-popup{font-size:.75rem;padding:6px 10px}@media (max-width: 768px){.word-phonetic-pair .phonetic-popup{font-size:.8rem;padding:.6rem 1rem;max-width:300px;white-space:normal;text-align:left;min-width:200px}.word-phonetic-pair .phonetic-action-btn.pronounce-btn{width:18px;height:18px;font-size:9px}.word-phonetic-pair .phonetic-action-btn.favorite-btn{min-width:18px;height:18px;font-size:.8rem}.word-phonetic-pair .phonetic{font-size:.75rem}.word-phonetic-pair .word-meaning{font-size:.8rem}}.word-phonetic-pair .phonetic.playing{background:#38a16933;border-radius:4px;padding:.1rem .2rem;animation:pulse 1s infinite}.playing-indicator{margin-left:.25rem;font-size:.8em;animation:bounce .5s infinite alternate}.audio-error{margin-left:.25rem;font-size:.8em;color:#e53e3e;animation:shake .5s ease-in-out}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-2px)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}.sentence-analysis-container{margin:20px 0}.sentence-analysis-item{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 2px 10px #0000001a;border:1px solid #e1e5e9;transition:all .3s ease;scroll-margin-top:80px}.sentence-analysis-item.highlight-scroll{background:#fff9e6;border-color:#ffc107;box-shadow:0 4px 20px #ffc1074d;animation:highlightPulse 2s ease-out}@keyframes highlightPulse{0%{background:#fff9e6;border-color:#ffc107;box-shadow:0 4px 20px #ffc10780}50%{background:#fffde7;border-color:#ffc107;box-shadow:0 6px 25px #ffc10766}to{background:#fff;border-color:#e1e5e9;box-shadow:0 2px 10px #0000001a}}.sentence-header{margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f0f0f0}.sentence-header h4{margin:0 0 10px;color:#667eea;font-size:1.2rem;font-weight:600;display:flex;align-items:center;gap:8px}.jump-to-translation{color:#667eea;text-decoration:none;font-size:.9rem;opacity:.7;transition:all .2s ease;margin-left:8px}.jump-to-translation:hover{opacity:1;transform:scale(1.2);color:#764ba2}.sentence-text{font-size:1.1rem;line-height:1.6;color:#333;background:#f8f9fa;padding:15px;border-radius:8px}.analysis-sections{display:flex;flex-direction:column;gap:20px}.analysis-section{background:#f8f9fa;border-radius:8px;padding:15px;border:1px solid #e1e5e9}.analysis-section h5{margin:0 0 15px;color:#333;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:8px}.structure-analysis{display:grid;grid-template-columns:1fr 1fr;gap:10px}.structure-item{display:flex;flex-direction:row;align-items:center;background:#fff;padding:10px;border-radius:6px;border:1px solid #e1e5e9;gap:8px}.structure-label{font-weight:600;color:#667eea;font-size:.9rem;white-space:nowrap;min-width:60px}.structure-value{color:#333;font-size:.95rem;line-height:1.4;flex:1}.fixed-collocations{display:flex;flex-direction:column;gap:12px}.collocation-item{background:#fff;padding:15px;border-radius:8px;border:1px solid #e1e5e9;transition:all .2s ease}.collocation-item:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.collocation-name{font-weight:600;color:#667eea;font-size:1rem;margin-bottom:8px}.collocation-meaning{color:#333;font-size:.95rem;line-height:1.5;margin-bottom:6px}.collocation-usage{color:#666;font-size:.9rem;line-height:1.4;margin-bottom:8px}.collocation-example{color:#666;font-size:.9rem;font-style:italic;background:#f8f9fa;padding:8px;border-radius:4px;margin-top:8px}.phrase-analysis{display:flex;flex-direction:column;gap:12px}.phrase-item{background:#fff;padding:15px;border-radius:8px;border:1px solid #e1e5e9;transition:all .2s ease}.phrase-item:hover{border-color:#10b981;box-shadow:0 2px 8px #10b9811a}.phrase-name{font-weight:600;color:#10b981;font-size:1rem;margin-bottom:10px}.phrase-details{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.phrase-type,.phrase-meaning,.phrase-function{color:#333;font-size:.9rem;line-height:1.4}.phrase-type{color:#f59e0b;font-weight:500}.phrase-meaning{color:#333}.phrase-function{color:#6366f1}.phrase-example{color:#666;font-size:.9rem;font-style:italic;background:#f8f9fa;padding:8px;border-radius:4px;margin-top:8px}.grammar-rules{display:flex;flex-direction:column;gap:12px}.grammar-rule-item{background:#fff;padding:15px;border-radius:8px;border:1px solid #e1e5e9}.rule-name{font-weight:600;color:#28a745;font-size:1rem;margin-bottom:8px}.rule-explanation{color:#333;font-size:.95rem;line-height:1.5;margin-bottom:10px}.rule-example{color:#666;font-size:.9rem;font-style:italic;background:#f8f9fa;padding:8px;border-radius:4px}.semantic-logic{display:flex;flex-direction:column;gap:12px}.semantic-item{display:flex;flex-direction:column;background:#fff;padding:12px;border-radius:6px;border:1px solid #e1e5e9}.semantic-label{font-weight:600;color:#dc3545;font-size:.9rem;margin-bottom:5px}.semantic-value{color:#333;font-size:.95rem;line-height:1.4}.semantic-value .word-phonetic-pair{display:inline;margin:0;padding:0;background:none;border:none;box-shadow:none;min-width:auto;position:relative;cursor:help}.semantic-value .word-phonetic-pair .english-word{color:#3182ce;text-decoration:none;font-size:.95rem;display:inline;cursor:help;position:relative;border-bottom:1px dotted #3182ce}.semantic-value .word-phonetic-pair .english-word:hover{color:#2c5aa0;border-bottom-color:#2c5aa0}.semantic-value .word-phonetic-pair .phonetic-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#2d3748;color:#fff;padding:.6rem 1rem;border-radius:8px;font-size:.8rem;white-space:normal;z-index:1000;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;margin-bottom:.3rem;max-width:300px;min-width:180px;text-align:left;line-height:1.5;word-wrap:break-word;box-shadow:0 4px 12px #0000004d}.semantic-value .word-phonetic-pair .phonetic-popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#2d3748}.semantic-value .word-phonetic-pair:hover .phonetic-popup{opacity:1;visibility:visible}.semantic-value .word-phonetic-pair .phonetic{color:#fff;font-weight:600;margin-bottom:.4rem;font-family:Courier New,monospace;font-size:.8rem;display:block;line-height:1.4}.semantic-value .word-phonetic-pair .word-meaning{display:inline-block;color:#fbbf24;margin-top:.4rem;margin-right:.5rem;font-weight:500;line-height:1.4;padding:0;border-top:none;vertical-align:middle}.semantic-value .word-phonetic-pair .phonetic-actions{display:inline-flex;gap:.25rem;margin-top:.4rem;align-items:center;vertical-align:middle;flex-shrink:0}.semantic-value .word-phonetic-pair .phonetic-action-btn{background:none;border:none;color:#cbd5e0;cursor:pointer;font-size:.9rem;padding:.15rem;border-radius:3px;transition:all .2s ease;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center}.semantic-value .word-phonetic-pair .phonetic-action-btn.pronounce-btn{background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;width:20px;height:20px;font-size:10px;box-shadow:0 2px 4px #3182ce4d}.semantic-value .word-phonetic-pair .phonetic-action-btn.pronounce-btn:hover{background:linear-gradient(135deg,#2c5aa0,#4299e1);transform:translateY(-1px);box-shadow:0 4px 8px #3182ce66}.semantic-value .word-phonetic-pair .phonetic-action-btn.pronounce-btn:active{transform:translateY(0);box-shadow:0 2px 4px #3182ce4d}.semantic-value .word-phonetic-pair .phonetic-action-btn.favorite-btn{background:none;border:none;font-size:.9rem;padding:.15rem;margin-left:.3rem;min-width:20px;height:20px}.semantic-value .word-phonetic-pair .phonetic-action-btn.favorite-btn:hover:not(:disabled){background:#ffc1071a;transform:scale(1.1)}.semantic-value .word-phonetic-pair .phonetic-action-btn.favorite-btn.favorited{color:#ffc107}.semantic-value .word-phonetic-pair .phonetic-action-btn.favorite-btn:not(.favorited){color:#cbd5e0}.semantic-value .word-phonetic-pair .phonetic-action-btn.favorite-btn:before{content:"☆"}.semantic-value .word-phonetic-pair .phonetic-action-btn.favorite-btn.favorited:before{content:"★"}.semantic-value .word-phonetic-pair.phonetic-left .phonetic-popup{left:0;transform:translate(0)}.semantic-value .word-phonetic-pair.phonetic-right .phonetic-popup{left:auto;right:0;transform:translate(0)}.semantic-value .word-phonetic-pair.phonetic-bottom .phonetic-popup{top:100%;bottom:auto;transform:translate(-50%);margin-top:.3rem;margin-bottom:0}.semantic-value .word-phonetic-pair.phonetic-bottom .phonetic-popup:after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:#2d3748}.semantic-value .word-phonetic-pair.phonetic-left.phonetic-bottom .phonetic-popup{left:0;transform:translate(0)}.semantic-value .word-phonetic-pair.phonetic-right.phonetic-bottom .phonetic-popup{left:auto;right:0;transform:translate(0)}.sentence-type-display{display:inline-flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s ease}.sentence-type-display:hover{background-color:#f0f8ff}.explanation-btn{background:linear-gradient(135deg,gold,#ffed4e);border:none;border-radius:50%;width:20px;height:20px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #ffd7004d}.explanation-btn:hover{background:linear-gradient(135deg,#ffed4e,gold);transform:scale(1.1);box-shadow:0 4px 8px #ffd70066}.explanation-btn:active{transform:scale(.95)}.sentence-type-explanation{margin-top:8px;padding:12px;background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:1px solid #ffd700;border-radius:8px;box-shadow:0 2px 8px #ffd70033}.explanation-content{color:#856404;font-size:.9rem;line-height:1.5;font-style:italic}.explanation-content.loading{color:#6c757d;font-style:normal}.explanation-content.error{color:#dc3545;font-style:normal}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-wrap:wrap;gap:10px}.floating-speech-controls{position:fixed;top:20px;right:20px;width:280px;background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026;border:1px solid #e1e5e9;z-index:1000;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:slideInFromRight .3s ease-out}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.speech-controls-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px 12px 0 0}.speech-title{font-weight:600;font-size:.9rem}.close-speech-btn{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:4px;border-radius:4px;transition:background .2s ease}.close-speech-btn:hover{background:#fff3}.speech-controls-content{padding:16px}.speech-buttons{display:flex;gap:8px;margin-bottom:12px}.speech-btn{flex:1;padding:8px 12px;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:4px}.speech-btn.pause-btn{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;box-shadow:0 2px 8px #f093fb4d}.speech-btn.pause-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f093fb66}.speech-btn.stop-btn{background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff;box-shadow:0 2px 8px #ff6b6b4d}.speech-btn.stop-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff6b6b66}.speech-rate-control{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:.85rem;color:#666}.speech-rate-control label{font-weight:500;color:#333;min-width:40px}.speech-rate-slider{flex:1;height:4px;background:#e1e5e9;border-radius:2px;outline:none;-webkit-appearance:none}.speech-rate-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:#667eea;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0003}.speech-rate-slider::-moz-range-thumb{width:16px;height:16px;background:#667eea;border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.rate-value{font-weight:600;color:#667eea;min-width:30px;text-align:right}.speech-progress{font-size:.8rem;color:#667eea;font-weight:500;background:#667eea1a;padding:8px 12px;border-radius:6px;border:1px solid rgba(102,126,234,.2);text-align:center}@media (max-width: 768px){.sentence-analysis-item{padding:15px;margin-bottom:15px}.sentence-header h4{font-size:1.1rem}.sentence-text{font-size:1rem;padding:12px}.analysis-section{padding:12px}.analysis-section h5{font-size:.95rem}.structure-analysis{grid-template-columns:1fr;gap:8px}.structure-item{padding:8px}.structure-label{font-size:.85rem}.structure-value{font-size:.9rem}.grammar-rule-item{padding:12px}.rule-name{font-size:.95rem}.rule-explanation{font-size:.9rem}.rule-example{font-size:.85rem;padding:6px}.semantic-item{padding:10px}.semantic-label{font-size:.85rem}.semantic-value{font-size:.9rem}.collocation-item{padding:12px}.collocation-name{font-size:.95rem}.collocation-meaning{font-size:.9rem}.collocation-usage{font-size:.85rem}.collocation-example{font-size:.85rem;padding:6px}.phrase-item{padding:12px}.phrase-name{font-size:.95rem}.phrase-type,.phrase-meaning,.phrase-function{font-size:.85rem}.phrase-example{font-size:.85rem;padding:6px}.semantic-value .word-phonetic-pair .phonetic-popup{max-width:280px;min-width:160px;padding:.5rem .8rem;font-size:.75rem}.semantic-value .word-phonetic-pair .phonetic-action-btn.pronounce-btn{width:18px;height:18px;font-size:9px}.semantic-value .word-phonetic-pair .phonetic-action-btn.favorite-btn{min-width:18px;height:18px;font-size:.8rem}.sentence-type-display{gap:6px;padding:3px 6px}.explanation-btn{width:18px;height:18px;font-size:10px}.sentence-type-explanation{padding:10px;margin-top:6px}.explanation-content{font-size:.85rem}.section-header{flex-direction:column;align-items:flex-start;gap:8px}.section-header:has(button){flex-direction:row;align-items:center;justify-content:space-between}.speech-rate-slider{width:50px}.reading-progress{font-size:.75rem;padding:3px 6px}.floating-speech-controls{top:10px;right:10px;left:10px;width:auto;max-width:none}.speech-controls-header{padding:10px 12px}.speech-controls-content{padding:12px}.speech-btn{padding:6px 10px;font-size:.8rem}.speech-rate-control{font-size:.8rem}.speech-progress{font-size:.75rem;padding:6px 10px}}.today-study-modal{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0003;width:90%;max-width:800px;max-height:90vh;overflow:hidden;animation:slideInUp .3s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e2e8f0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.close-btn{background:#fff3;border:none;color:#fff;font-size:1.25rem;padding:.5rem;border-radius:50%;cursor:pointer;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.modal-content{padding:1.5rem;max-height:calc(90vh - 80px);overflow-y:auto}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#718096}.loading-spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.error-icon{font-size:3rem;margin-bottom:1rem}.error-message{color:#e53e3e;margin:0 0 1rem;font-size:1rem}.empty-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.6}.empty-message{color:#4a5568;margin:0 0 .5rem;font-size:1.125rem;font-weight:600}.empty-hint{color:#718096;margin:0;font-size:.875rem}.words-list{width:100%}.list-header{margin-bottom:1.5rem;padding:1rem;background:#f8fafc;border-radius:8px;text-align:center;font-weight:600;color:#4a5568}.words-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.word-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem;transition:all .3s ease;box-shadow:0 2px 4px #0000001a}.word-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:#cbd5e0}.word-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #f1f5f9}.word-text{font-size:1.125rem;font-weight:700;color:#2d3748}.accuracy-badge{color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600;min-width:40px;text-align:center}.word-stats{display:flex;flex-direction:column;gap:.5rem}.stat-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.stat-label{color:#718096;font-weight:500}.stat-value{color:#2d3748;font-weight:600}@media screen and (max-width: 768px){.today-study-modal{width:95%;margin:.5rem;max-height:95vh}.modal-header{padding:1rem .75rem}.modal-header h2{font-size:1.125rem}.close-btn{width:28px;height:28px;font-size:1rem}.modal-content{padding:1rem .75rem;max-height:calc(95vh - 70px)}.words-grid{grid-template-columns:1fr;gap:.75rem}.word-card{padding:.75rem}.word-text{font-size:1rem}.stat-item{font-size:.8rem}.list-header{padding:.75rem;font-size:.9rem}}@media screen and (max-width: 480px){.today-study-modal{width:100%;height:100%;max-height:100vh;border-radius:0;margin:0}.modal-header{padding:.75rem}.modal-header h2{font-size:1rem}.close-btn{width:24px;height:24px;font-size:.9rem}.modal-content{padding:.75rem .5rem;max-height:calc(100vh - 60px)}.word-card{padding:.5rem;margin-bottom:.5rem}.word-header{flex-direction:row;align-items:center;justify-content:space-between;margin-bottom:.5rem;padding-bottom:.25rem}.word-text{font-size:.95rem;font-weight:600}.accuracy-badge{font-size:.7rem;padding:.2rem .4rem;min-width:35px}.word-stats{gap:.25rem}.stat-item{font-size:.75rem;flex-direction:column;align-items:flex-start;gap:.1rem}.stat-label{font-size:.7rem;color:#a0aec0}.stat-value{font-size:.75rem;font-weight:600;color:#2d3748}.list-header{padding:.5rem;font-size:.85rem;margin-bottom:1rem}.empty-container,.error-container,.loading-container{padding:2rem 1rem}.empty-icon{font-size:3rem}.empty-message{font-size:1rem}.empty-hint{font-size:.8rem}}@media screen and (max-width: 360px){.modal-header h2,.word-text{font-size:.9rem}.stat-item{font-size:.7rem}.stat-label{font-size:.65rem}.stat-value{font-size:.7rem}.accuracy-badge{font-size:.65rem;padding:.15rem .3rem;min-width:30px}}.review-reminder{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:1.5rem;margin:1rem 0;color:#fff;box-shadow:0 8px 32px #667eea4d;position:relative;overflow:hidden}.review-reminder:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.review-reminder.loading{display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:120px}.review-reminder.error{background:linear-gradient(135deg,#e53e3e,#fc8181);display:flex;align-items:center;justify-content:center;gap:.5rem;flex-direction:column;min-height:120px}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.retry-btn{padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease;margin-top:.5rem}.retry-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.review-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;position:relative;z-index:1}.review-header h3{margin:0;font-size:1.3rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.2)}.refresh-btn{padding:.25rem!important;background:#fff3!important;border-radius:50%!important;cursor:pointer!important;transition:all .2s ease!important;font-size:.9rem!important;width:28px!important;height:28px!important;min-width:28px!important;min-height:28px!important;max-width:28px!important;max-height:28px!important;display:flex!important;align-items:center!important;justify-content:center!important;box-sizing:border-box!important}.refresh-btn:hover{background:#ffffff4d;transform:rotate(180deg)}.review-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.5rem;position:relative;z-index:1;width:100%;min-width:0}.stat-item{background:#ffffff26;border-radius:12px;padding:.75rem;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:all .3s ease;min-width:0;overflow:hidden}.stat-item:hover{background:#ffffff40;transform:translateY(-2px)}.stat-item.clickable{cursor:pointer;transition:all .3s ease}.stat-item.clickable:hover{background:#ffffff4d;transform:translateY(-3px);box-shadow:0 8px 25px #0003}.click-hint{position:absolute;top:.5rem;right:.5rem;font-size:.8rem;opacity:.8;transition:all .2s ease}.stat-item.clickable:hover .click-hint{opacity:1;transform:scale(1.1)}.stat-item.primary{border-left:4px solid #68d391}.stat-item.success{border-left:4px solid #48bb78}.stat-item.warning{border-left:4px solid #fbb6ce}.stat-item.info{border-left:4px solid #90cdf4}.stat-item.error{border-left:4px solid #e53e3e;background:linear-gradient(135deg,#fed7d7,#feb2b2)}.stat-item.error:hover{transform:translateY(-2px);box-shadow:0 8px 25px #e53e3e4d}.stat-icon{font-size:1.5rem;margin-bottom:.5rem}.stat-content{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.8rem;font-weight:800;line-height:1;margin-bottom:.25rem;text-shadow:0 2px 4px rgba(0,0,0,.2)}.stat-label,.stat-label-1{font-size:.85rem;opacity:1;font-weight:600;color:#000}.review-alert,.study-suggestion{background:#ffffff26;border-radius:12px;padding:1rem;display:flex;align-items:center;gap:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);position:relative;z-index:1;animation:slideInUp .5s ease-out}.review-alert.clickable,.study-suggestion.clickable{cursor:pointer;transition:all .3s ease}.review-alert.clickable:hover,.study-suggestion.clickable:hover{background:#ffffff40;transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.review-alert .click-hint,.study-suggestion .click-hint{position:absolute;top:.5rem;right:.5rem;font-size:.75rem;opacity:.7;transition:all .2s ease}.review-alert.clickable:hover .click-hint,.study-suggestion.clickable:hover .click-hint{opacity:1;transform:scale(1.05)}.review-alert{border-left:4px solid #fbb6ce}.study-suggestion{border-left:4px solid #68d391}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.alert-icon,.suggestion-icon{font-size:1.5rem;flex-shrink:0}.alert-content,.suggestion-content{flex:1}.alert-title,.suggestion-title{font-weight:700;font-size:1rem;margin-bottom:.25rem}.alert-message,.suggestion-message{font-size:.9rem;opacity:.9;line-height:1.4}.alert-message strong{font-weight:800;color:#fbb6ce}@media screen and (max-width: 480px){.review-reminder{padding:.75rem;margin:.5rem 0}.review-header{margin-bottom:1rem}.review-header h3{font-size:1rem}.review-stats{grid-template-columns:repeat(4,1fr);gap:.4rem;margin-bottom:1rem;width:100%;min-width:0}.stat-item{padding:.5rem .2rem;min-width:0;overflow:hidden}.stat-icon{font-size:1.1rem;margin-bottom:.2rem}.stat-value{font-size:1.2rem}.stat-label-1{font-size:.7rem}.click-hint{display:none}.review-alert,.study-suggestion{padding:.5rem;gap:.5rem}.alert-title,.suggestion-title{font-size:.8rem}.alert-message,.suggestion-message{font-size:.75rem}.alert-icon,.suggestion-icon{font-size:1.2rem}}@media screen and (min-width: 481px) and (max-width: 768px){.review-stats{grid-template-columns:repeat(3,1fr);gap:.75rem}.stat-item{padding:.75rem .5rem}.stat-value{font-size:1.6rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.category-stats-modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:2px solid #e2e8f0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700}.close-btn{background:#fff3;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:1.2rem;font-weight:700;transition:all .3s ease}.close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.modal-content{flex:1;overflow-y:auto;padding:0}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.error-container p{color:#e53e3e;font-size:1.1rem;margin-bottom:1rem}.retry-btn{background:linear-gradient(135deg,#e53e3e,#fc8181);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e53e3e4d}.table-container{width:100%;overflow-x:auto}.stats-table{width:100%;border-collapse:collapse;font-size:.9rem;background:#fff;box-shadow:0 2px 8px #0000001a}.stats-table thead th{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:1px solid #cbd5e0;padding:1rem .75rem;text-align:center;font-weight:700;color:#2d3748;position:sticky;top:0;z-index:10}.stats-table thead th:first-child{text-align:left}.col-category{width:25%;min-width:150px}.col-total,.col-studied{width:15%;min-width:80px}.col-percentage{width:20%;min-width:100px}.col-action{width:15%;min-width:80px}.stats-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .2s ease}.stats-table tbody tr:hover{background-color:#f8fafc}.even-row{background-color:#fff}.odd-row{background-color:#f9f9f9}.stats-table td{padding:.75rem;border:1px solid #e2e8f0;vertical-align:middle}.stats-table td:first-child{text-align:left}.stats-table td:not(:first-child){text-align:center}.category-name{display:flex;align-items:center;gap:.5rem}.category-icon{font-size:1.2rem;width:24px;text-align:center}.studied-count{font-weight:600;color:#38a169}.percentage-cell{display:flex;flex-direction:column;align-items:center;gap:.25rem}.percentage-text{font-weight:600;color:#667eea}.progress-bar-mini{width:60px;height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden}.progress-fill-mini{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px;transition:width .3s ease}.study-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;padding:.4rem .8rem;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .3s ease}.study-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.no-data{color:#a0aec0;font-style:italic}.total-row{background:linear-gradient(135deg,#f7fafc,#edf2f7)!important;border-top:2px solid #cbd5e0!important;font-weight:700}.total-row td{border-color:#cbd5e0!important;padding:1rem .75rem!important}.total-label{color:#2d3748}@media screen and (max-width: 768px){.modal-overlay{padding:.5rem}.category-stats-modal{max-height:95vh}.modal-header{padding:1rem}.modal-header h2{font-size:1.25rem}.close-btn{width:32px;height:32px;font-size:1rem}.stats-table{font-size:.8rem}.stats-table thead th{padding:.75rem .5rem}.stats-table td{padding:.5rem}.col-category{min-width:120px}.col-total,.col-studied,.col-percentage,.col-action{min-width:60px}.category-name{gap:.25rem}.category-icon{font-size:1rem;width:20px}.study-btn{padding:.3rem .6rem;font-size:.7rem}.progress-bar-mini{width:40px}}@media screen and (max-width: 480px){.modal-overlay{padding:.25rem}.category-stats-modal{max-height:98vh}.modal-header{padding:.75rem}.modal-header h2{font-size:1.1rem}.stats-table{font-size:.75rem}.stats-table thead th{padding:.5rem .25rem}.stats-table td{padding:.4rem .25rem}.col-category{min-width:100px}.col-total,.col-studied,.col-percentage,.col-action{min-width:50px}.category-name{flex-direction:column;gap:.1rem;align-items:flex-start}.category-icon{font-size:.9rem}.study-btn{padding:.25rem .5rem;font-size:.65rem}.progress-bar-mini{width:30px}}.learning-stats{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:16px;padding:1.5rem;margin:1rem 0;box-shadow:0 4px 20px #0000001a;border:1px solid #e2e8f0;width:100%;max-width:100%;box-sizing:border-box}.learning-stats.loading{display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:120px}.learning-stats.error{background:linear-gradient(135deg,#fed7d7,#feb2b2);display:flex;align-items:center;justify-content:center;gap:.5rem;flex-direction:column;min-height:120px;color:#c53030}.loading-spinner{width:20px;height:20px;border:2px solid #e2e8f0;border-top:2px solid #3182ce;border-radius:50%;animation:spin 1s linear infinite}.error-icon{font-size:2rem;margin-bottom:.5rem}.retry-btn{padding:.5rem 1rem;background:#c53030;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease;margin-top:.5rem}.retry-btn:hover{background:#9c2626;transform:translateY(-1px)}.stats-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.stats-header h3{margin:0;font-size:1.3rem;font-weight:700;color:#2d3748}.refresh-btn{padding:.25rem!important;background:#e2e8f0!important;border-radius:50%!important;cursor:pointer!important;transition:all .2s ease!important;font-size:.9rem!important;width:28px!important;height:28px!important;min-width:28px!important;min-height:28px!important;max-width:28px!important;max-height:28px!important;display:flex!important;align-items:center!important;justify-content:center!important;box-sizing:border-box!important}.refresh-btn:hover{background:#cbd5e0;transform:rotate(180deg)}.stats-tabs{display:flex;background:#fff;border-radius:12px;padding:.25rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000001a}.tab-btn{flex:1;padding:.75rem 1rem;background:transparent;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;color:#4a5568;transition:all .2s ease}.tab-btn.active{background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;box-shadow:0 2px 8px #3182ce4d}.tab-btn:hover:not(.active){background:#f7fafc;color:#2d3748}.overview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:12px;padding:1rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;border-left:4px solid}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.stat-card.clickable{cursor:pointer;transition:all .3s ease}.stat-card.clickable:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0003}.stat-card .click-hint{position:absolute;top:.5rem;right:.5rem;font-size:.8rem;opacity:.6;transition:all .2s ease}.stat-card.clickable:hover .click-hint{opacity:1;transform:scale(1.1)}.stat-card.primary{border-left-color:#3182ce}.stat-card.success{border-left-color:#38a169}.stat-card.info{border-left-color:#805ad5}.stat-card.warning{border-left-color:#ed8936}.stat-icon{font-size:2rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#f7fafc;border-radius:50%}.stat-info{flex:1}.stat-value{font-size:1.8rem;font-weight:800;color:#2d3748;line-height:1;margin-bottom:.25rem}.stat-label,.stat-label1{font-size:.85rem;color:#000;font-weight:600}.progress-summary{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.progress-summary h4{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#2d3748}.progress-bar-large{width:100%;height:12px;background:#e2e8f0;border-radius:6px;overflow:hidden;margin-bottom:.5rem}.progress-fill-large{height:100%;background:linear-gradient(90deg,#38a169,#68d391);border-radius:6px;transition:width .6s ease;box-shadow:0 2px 8px #38a1694d}.progress-text{font-size:.9rem;color:#4a5568;text-align:center;font-weight:500}.weekly-chart{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.weekly-chart h4{margin:0 0 1.5rem;font-size:1.1rem;font-weight:600;color:#2d3748;text-align:center}.chart-container{display:flex;align-items:end;justify-content:space-between;gap:.5rem;height:120px;padding:0 .5rem}.chart-bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem}.bar-fill{width:100%;background:linear-gradient(180deg,#3182ce,#63b3ed);border-radius:4px 4px 0 0;min-height:4px;transition:height .6s ease;box-shadow:0 2px 8px #3182ce4d}.bar-label{font-size:.75rem;color:#718096;font-weight:500}.bar-value{font-size:.8rem;color:#2d3748;font-weight:600}.achievements-grid{display:grid;grid-template-columns:1fr;gap:1rem}.achievement-card{background:#fff;border-radius:12px;padding:1rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;border-left:4px solid #fbb6ce}.achievement-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.achievement-icon{font-size:2rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#fef5e7;border-radius:50%}.achievement-info{flex:1}.achievement-title{font-size:1rem;font-weight:700;color:#2d3748;margin-bottom:.25rem}.achievement-desc{font-size:.85rem;color:#718096;line-height:1.4}.achievement-status{font-size:1.2rem}@media screen and (max-width: 480px){.learning-stats{padding:.75rem;margin:.5rem 0}.stats-header{margin-bottom:1rem}.stats-header h3{font-size:1rem}.stats-tabs{margin-bottom:1rem;padding:.2rem}.tab-btn{padding:.5rem .75rem;font-size:.8rem}.overview-grid{grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:1rem}.stat-card{padding:.5rem;gap:.5rem;flex-direction:column;text-align:center}.stat-card .click-hint{display:none}.stat-icon{width:35px;height:35px;font-size:1.2rem}.stat-value{font-size:1.3rem}.stat-label{font-size:.75rem}.progress-summary{padding:.75rem}.progress-summary h4{font-size:.9rem;margin-bottom:.75rem}.progress-bar-large{height:8px;margin-bottom:.5rem}.progress-text{font-size:.8rem}.weekly-chart{padding:.75rem}.weekly-chart h4{font-size:.9rem;margin-bottom:1rem}.chart-container{height:80px}.bar-label{font-size:.7rem}.bar-value{font-size:.75rem}.achievement-card{padding:.5rem;gap:.5rem}.achievement-icon{width:35px;height:35px;font-size:1.2rem}.achievement-title{font-size:.85rem}.achievement-desc{font-size:.75rem}}@media screen and (min-width: 481px) and (max-width: 768px){.overview-grid{grid-template-columns:repeat(2,1fr)}}@media screen and (min-width: 769px){.overview-grid{grid-template-columns:repeat(4,1fr)}.achievements-grid{grid-template-columns:repeat(2,1fr)}}.modes-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:1rem}.mode-stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0;transition:transform .2s ease,box-shadow .2s ease}.mode-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.mode-stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.mode-stat-header h4{margin:0;color:#2d3748;font-size:1.125rem;font-weight:600}.mode-stat-icon{font-size:1.5rem}.mode-stat-numbers{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.mode-stat-item{text-align:center;padding:.75rem;background:#f7fafc;border-radius:8px}.mode-stat-item.accuracy{grid-column:span 2;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.mode-stat-value{display:block;font-size:1.5rem;font-weight:700;color:#2d3748;margin-bottom:.25rem}.mode-stat-item.accuracy .mode-stat-value{color:#fff}.mode-stat-label{font-size:.875rem;color:#718096;font-weight:500}.mode-stat-item.accuracy .mode-stat-label{color:#ffffffe6}.mode-error-summary{text-align:center}.error-words-btn{background:linear-gradient(135deg,#f56565,#e53e3e);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.error-words-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f5656566}.errors-analysis h4{margin:0 0 1.5rem;color:#2d3748;font-size:1.25rem;font-weight:600}.no-errors{text-align:center;padding:3rem 1rem;color:#718096}.no-errors-icon{font-size:3rem;margin-bottom:1rem}.error-mode-section{margin-bottom:2rem}.error-mode-section h5{margin:0 0 1rem;color:#4a5568;font-size:1rem;font-weight:600;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.error-words-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.error-word-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem;box-shadow:0 2px 4px #0000000d;transition:transform .2s ease,box-shadow .2s ease}.error-word-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.error-word-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #f1f5f9}.error-word-text{font-size:1.125rem;font-weight:700;color:#2d3748}.error-word-translation{font-size:.875rem;color:#718096;background:#f7fafc;padding:.25rem .5rem;border-radius:4px}.error-word-details{margin-bottom:1rem}.error-user-answer{font-size:.875rem;color:#4a5568;margin-bottom:.5rem}.user-answer{color:#e53e3e;font-weight:600;background:#fed7d7;padding:.125rem .375rem;border-radius:4px}.error-timestamp{font-size:.75rem;color:#a0aec0}.error-word-actions{display:flex;gap:.5rem;margin-top:.5rem}.review-error-btn{flex:1;background:linear-gradient(135deg,#4299e1,#3182ce);color:#fff;border:none;padding:.75rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.review-error-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4299e166}.mark-mastered-btn{flex:1;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;padding:.75rem;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.mark-mastered-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #48bb7866}@media (max-width: 768px){.modes-stats-grid{grid-template-columns:1fr;gap:.75rem}.mode-stat-card{padding:1rem}.mode-stat-numbers{grid-template-columns:repeat(2,1fr);gap:.75rem}.error-words-grid{grid-template-columns:1fr;gap:.75rem}.error-word-card{padding:.75rem}.stats-tabs{gap:.5rem;flex-wrap:wrap}.tab-btn{padding:.5rem .75rem;font-size:.8rem}}.shortcuts-toggle-btn{position:fixed;bottom:20px;right:20px;width:50px;height:50px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50%;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 16px #667eea4d;transition:all .3s ease;z-index:1000;display:flex;align-items:center;justify-content:center}.shortcuts-toggle-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #667eea66}.shortcuts-help-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.shortcuts-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.shortcuts-help-modal{position:relative;background:#fff;border-radius:16px;max-width:500px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 40px #00000026;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.5rem 0;border-bottom:1px solid #e2e8f0;margin-bottom:1.5rem}.shortcuts-header h3{margin:0;font-size:1.3rem;font-weight:700;color:#2d3748}.shortcuts-close-btn{width:32px;height:32px;background:#e2e8f0;border:none;border-radius:50%;cursor:pointer;font-size:1rem;color:#4a5568;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.shortcuts-close-btn:hover{background:#cbd5e0;color:#2d3748}.shortcuts-content{padding:0 1.5rem 1.5rem}.shortcuts-section{margin-bottom:2rem}.shortcuts-section:last-child{margin-bottom:0}.shortcuts-section h4{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#2d3748}.shortcuts-list{display:flex;flex-direction:column;gap:.75rem}.shortcut-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;transition:all .2s ease}.shortcut-item:hover{background:#f1f5f9;border-color:#cbd5e0}.shortcut-key{background:linear-gradient(135deg,#3182ce,#63b3ed);color:#fff;padding:.25rem .75rem;border-radius:6px;font-size:.8rem;font-weight:600;font-family:Courier New,monospace;min-width:60px;text-align:center;box-shadow:0 2px 4px #3182ce4d}.shortcut-desc{flex:1;font-size:.9rem;color:#4a5568;font-weight:500}.shortcuts-tips{margin:0;padding-left:1.5rem;color:#4a5568}.shortcuts-tips li{margin-bottom:.5rem;line-height:1.5}.shortcuts-tips li:last-child{margin-bottom:0}@media screen and (max-width: 480px){.shortcuts-toggle-btn{width:45px;height:45px;bottom:15px;right:15px;font-size:1.3rem}.shortcuts-help-modal{margin:10px;max-height:85vh}.shortcuts-header{padding:1rem 1rem 0;margin-bottom:1rem}.shortcuts-header h3{font-size:1.1rem}.shortcuts-content{padding:0 1rem 1rem}.shortcut-item{padding:.5rem;gap:.75rem}.shortcut-key{font-size:.75rem;padding:.2rem .5rem;min-width:50px}.shortcut-desc,.shortcuts-tips{font-size:.85rem}}@media screen and (max-width: 320px){.shortcuts-help-overlay{padding:10px}.shortcuts-help-modal{margin:5px}}.new-home-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2px;margin-bottom:2px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.new-home-page *{box-sizing:border-box}.welcome-section{display:flex;justify-content:flex-end;align-items:center;gap:16px;margin-bottom:10px;padding:2px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:10px;border:1px solid rgba(255,255,255,.2);flex-direction:row-reverse}.welcome-content{flex:none}.welcome-title{font-size:24px;font-weight:700;color:#fff;margin:0 0 8px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.welcome-subtitle{font-size:16px;color:#fffc;margin:0}.user-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{font-size:18px;color:#fff}.stats-section{margin-bottom:10px}.stats-card{display:flex;flex-direction:row;background:#fffffff2;border-radius:16px;padding:20px;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stat-item{flex:1;text-align:center;padding:0;display:flex;flex-direction:column;justify-content:center;align-items:center}.stat-item:not(:last-child){border-right:1px solid rgba(0,0,0,.1)}.stat-number{font-size:28px;font-weight:700;color:#667eea;margin-bottom:0;line-height:1}.stat-number.total-stat{font-size:36px;font-weight:800;line-height:1}.stat-number.success{color:#48bb78}.stat-number.warning{color:#ed8936}.stat-number.info{color:#4299e1}.stat-label{font-size:14px;color:#666;font-weight:500;margin-bottom:0;line-height:1}.favorite-stats-section,.carousel-section{margin-bottom:10px}.carousel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.carousel-header h2{font-size:20px;font-weight:600;color:#fff;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.1)}.carousel-indicators{display:flex;gap:8px}.indicator{padding:6px 12px;border:none;border-radius:20px;background:#fff3;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease}.indicator.active{background:#ffffffe6;color:#091a63;transform:scale(1.05)}.indicator:hover:not(.disabled){background:#ffffff4d;transform:scale(1.02)}.indicator.disabled{opacity:.5;cursor:not-allowed;background:#ffffff1a}.word-carousel{position:relative;min-height:120px}.word-card{background:#fffffff2;border-radius:20px;padding:30px;box-shadow:0 12px 40px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);animation:slideIn .5s ease-out;display:flex;flex-direction:column;align-items:center;position:relative}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.word-content{text-align:center;margin-bottom:20px;display:flex;flex-direction:column;align-items:center;position:relative}.word-index-indicator{position:absolute;top:10px;right:10px;font-size:12px;color:#999;font-weight:500;z-index:5}.swipe-hint{text-align:center;margin-top:16px;font-size:12px;color:#999;font-weight:500}.word-text{font-size:32px;font-weight:700;color:#333;margin:0 0 8px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.word-phonetic{font-size:18px;color:#667eea;margin:0 0 12px;font-style:italic}.word-translation{font-size:20px;color:#666;margin:0 0 16px;font-weight:500}.difficulty-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.difficulty-badge.easy{background:#e8f5e8;color:#4caf50}.difficulty-badge.medium{background:#fff3e0;color:#ff9800}.difficulty-badge.hard{background:#ffebee;color:#f44336}.word-actions{display:flex;gap:12px;justify-content:center}.play-btn,.study-btn{padding:12px 24px;border:none;border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px}.play-btn{position:absolute;top:10px;left:10px;padding:8px 16px;border-radius:20px;font-size:13px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66;z-index:10}.play-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.play-btn.playing{background:linear-gradient(135deg,#ff6b6b,#ee5a24);box-shadow:0 4px 15px #ff6b6b66;animation:pulse 1.5s ease-in-out infinite}.play-btn.playing:hover{box-shadow:0 6px 20px #ff6b6b99;transform:translateY(-2px) scale(1.05)}.study-btn{background:#ffffffe6;color:#667eea;border:2px solid #667eea}.study-btn:hover{background:#667eea;color:#fff;transform:translateY(-2px)}.loading-card,.empty-card{background:#fffffff2;border-radius:20px;padding:40px;text-align:center;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid rgba(102,126,234,.2);border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.function-section{margin-bottom:10px}.function-section h2{font-size:18px;font-weight:600;color:#fff;margin:0 0 12px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.function-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}.function-card{background:#fffffff2;border-radius:14px;padding:16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.function-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.function-card.translation-card:hover{background:linear-gradient(135deg,#667eea1a,#764ba21a)}.function-card.dictionary-card:hover{background:linear-gradient(135deg,#ff6b6b1a,#ee5a241a)}.function-card.ocr-card:hover{background:linear-gradient(135deg,#2ecc711a,#27ae601a)}.function-card.study-card:hover{background:linear-gradient(135deg,#667eea1a,#764ba21a)}.card-icon{font-size:28px;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-shrink:0}.function-card.dictionary-card .card-icon{background:linear-gradient(135deg,#ff6b6b,#ee5a24)}.function-card.ocr-card .card-icon{background:linear-gradient(135deg,#2ecc71,#27ae60)}.card-content h3{font-size:16px;font-weight:600;color:#333;margin:0 0 4px}.card-content p{font-size:13px;color:#666;margin:0;line-height:1.3}.card-arrow{font-size:18px;color:#667eea;font-weight:700;transition:transform .3s ease}.function-card:hover .card-arrow{transform:translate(4px)}.quick-actions{display:flex;gap:12px;justify-content:center}.quick-action-btn{padding:14px 24px;border:none;border-radius:20px;background:#ffffffe6;color:#667eea;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex:1}.quick-action-btn:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@media (max-width: 768px){.new-home-page{padding:6px}.welcome-section{flex-direction:row-reverse;text-align:right;gap:8px}.welcome-title{font-size:10px}.stats-card{flex-direction:row;gap:8px}.stat-item:not(:last-child){border-right:1px solid rgba(0,0,0,.1);border-bottom:none;padding-bottom:0}.carousel-header{flex-direction:column;gap:16px;align-items:flex-start}.carousel-indicators{flex-wrap:wrap}.function-grid{grid-template-columns:1fr;gap:10px}.function-section h2{font-size:16px;margin-bottom:10px}.quick-actions{gap:10px}.word-text{font-size:28px}.word-phonetic{font-size:16px}.word-translation{font-size:18px}.word-card{padding:20px}}@media (max-width: 480px){.welcome-title{font-size:18px}.word-text{font-size:24px}.word-phonetic{font-size:14px}.word-translation{font-size:16px}.word-card{padding:16px}.function-card{padding:14px;gap:10px}.card-icon{font-size:24px;width:45px;height:45px}.card-content h3{font-size:15px}.card-content p{font-size:12px}.quick-action-btn{padding:12px 20px;font-size:14px}}.favorite-sentences-section{margin-bottom:10px}.sentences-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.sentences-header h2{font-size:20px;font-weight:600;color:#fff;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.1)}.sentence-tabs{display:flex;gap:4px;background:#fff3;border-radius:20px;padding:2px}.sentence-tab{padding:6px 16px;border:none;border-radius:18px;background:transparent;color:#ffffffb3;font-size:13px;font-weight:500;cursor:pointer;transition:all .3s ease}.sentence-tab.active{background:#ffffffe6;color:#091a63;font-weight:600}.sentence-tab:hover{color:#fff}.sentence-carousel{position:relative;min-height:140px}.sentence-card{background:#fffffff2;border-radius:20px;padding:30px;box-shadow:0 12px 40px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);animation:slideIn .5s ease-out;position:relative}.sentence-index-indicator{position:absolute;top:10px;right:10px;font-size:12px;color:#999;font-weight:500}.sentence-content{margin:20px 0;display:flex;flex-direction:column;align-items:center}.sentence-text{font-size:18px;line-height:1.6;color:#333;text-align:center;word-wrap:break-word;word-break:break-word;font-weight:500;margin:0}.sentence-read-btn{position:absolute;top:10px;left:10px;padding:8px 16px;border:none;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66;z-index:10}.sentence-read-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.sentence-read-btn:active{transform:translateY(0)}.sentence-read-btn.reading{background:linear-gradient(135deg,#ff6b6b,#ee5a24);box-shadow:0 4px 15px #ff6b6b66;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.sentence-read-btn.reading:hover{box-shadow:0 6px 20px #ff6b6b99;transform:translateY(-2px) scale(1.05)}.sentence-text.chinese{font-size:16px;color:#c53030;font-weight:600}.sentence-hint{text-align:center;margin-top:16px;font-size:12px;color:#999;font-weight:500}.sentence-controls{display:flex;gap:8px;margin-top:12px;justify-content:center}.sentence-control-btn{flex:1;padding:10px 16px;border:none;border-radius:12px;background:#fff3;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.sentence-control-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.sentence-control-btn:active{transform:translateY(0)}.history-display{max-width:1200px;margin:0 auto;padding:1rem;background:#f8fafc;min-height:100vh}@media (max-width: 768px){.history-display{max-width:100%;padding:.5rem;margin:0}}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;box-shadow:0 4px 12px #0000001a}@media (max-width: 768px){.history-header{padding:.25rem .5rem;margin-bottom:.25rem;border-radius:6px}}.history-header h2{margin:0;font-size:1.8rem;font-weight:700}@media (max-width: 768px){.history-header h2{font-size:1rem}.total-count{font-size:.7rem;padding:.2rem .6rem}}.header-stats{display:flex;align-items:center;gap:1rem}.total-count{background:#fff3;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.search-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;width:100%}@media (max-width: 768px){.search-section{padding:.25rem;margin-bottom:.25rem;border-radius:4px}}.search-form{width:100%}.search-input-group{display:flex;gap:.5rem;align-items:center;flex-wrap:nowrap;width:100%}.search-input-wrapper{position:relative;flex:1}.clear-input-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:#94a3b8;font-size:1.2rem;cursor:pointer;padding:.25rem;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all .2s}.clear-input-btn:hover{background:#f1f5f9;color:#64748b}.search-input{flex:1;min-width:0;width:100%;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s;box-sizing:border-box}@media (max-width: 768px){.search-input{padding:.4rem .6rem;font-size:.9rem;border-radius:4px}}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.engine-select{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;transition:border-color .2s}.engine-select:focus{outline:none;border-color:#667eea}.search-btn,.reset-btn{padding:.5rem;border:none;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0;width:auto;min-width:auto}.search-btn{background:#667eea;color:#fff}.search-btn:hover{background:#5a67d8;transform:translateY(-1px)}.reset-btn{background:#e2e8f0;color:#4a5568}.reset-btn:hover{background:#cbd5e0}.view-controls{display:flex;flex-direction:row;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem 1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}@media (max-width: 768px){.view-controls{padding:.4rem .5rem;margin-bottom:.5rem;border-radius:6px}}.view-modes{display:flex;gap:.5rem}.view-btn{padding:.5rem 1rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-size:.9rem;cursor:pointer;transition:all .2s}.view-btn.active{background:#667eea;color:#fff;border-color:#667eea}.view-btn:hover:not(.active){border-color:#667eea;color:#667eea}.sort-controls{display:flex;align-items:center;gap:.5rem}.sort-controls label{font-weight:500;color:#4a5568}.sort-select{padding:.5rem 1rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer}.favorite-filter{display:flex;align-items:center}.favorite-filter-btn{padding:.5rem 1rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.25rem}.favorite-filter-btn:hover{border-color:#f59e0b;color:#f59e0b}.favorite-filter-btn.active{background:#f59e0b;color:#fff;border-color:#f59e0b}.favorite-filter-btn.active:hover{background:#d97706;border-color:#d97706}.records-container{display:grid;gap:1.5rem;margin-bottom:2rem}.records-container.grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.records-container.list{grid-template-columns:1fr}.records-container.list .record-image-thumbnail{width:70px;height:70px;flex-shrink:0;margin-left:auto;order:2}.records-container.list .record-image-thumbnail img{width:100%;height:100%;object-fit:cover;border-radius:8px}.record-meta-info{font-size:.85rem;color:#64748b}.records-container.timeline{grid-template-columns:1fr;position:relative}.records-container.timeline:before{content:"";position:absolute;left:2rem;top:0;bottom:0;width:2px;background:#e2e8f0}.record-item{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:all .3s;position:relative}.record-item:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.records-container.timeline .record-item{margin-left:4rem;position:relative}.records-container.timeline .record-item:before{content:"";position:absolute;left:-2.5rem;top:1.5rem;width:12px;height:12px;background:#667eea;border-radius:50%;border:3px solid white;box-shadow:0 0 0 3px #e2e8f0}.record-header{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #f1f5f9}.record-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.record-time{font-size:.85rem;color:#64748b;font-weight:500}.record-engine{font-size:.85rem;color:#667eea;font-weight:500;background:#f0f4ff;padding:.25rem .75rem;border-radius:12px}.record-title{font-size:1.1rem;font-weight:600;color:#1e293b;margin-top:.5rem}.record-content{padding:1rem 1.5rem}.record-image{margin-bottom:1rem;border-radius:8px;overflow:hidden}.record-image img{width:100%;height:auto;max-height:200px;object-fit:cover}.record-text{margin-bottom:1rem}.record-text-content{font-size:1rem;line-height:1.6;color:#374151;white-space:pre-wrap;word-break:break-word;text-align:left}.record-actions{padding:1rem 1.5rem;border-top:1px solid #f1f5f9;display:flex;gap:.75rem;justify-content:flex-end}.action-btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.view-btn{background:#f0f4ff;color:#667eea}.view-btn:hover{background:#e0e7ff}.copy-btn{background:#f0fdf4;color:#16a34a}.copy-btn:hover{background:#dcfce7}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.page-btn{padding:.75rem 1.5rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-size:1rem;cursor:pointer;transition:all .2s}.page-btn:hover:not(:disabled){border-color:#667eea;color:#667eea}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-info{font-size:1rem;color:#64748b;font-weight:500}.loading-section,.error-section,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.error-icon,.empty-icon{font-size:3rem;margin-bottom:1rem}.error-section h3,.empty-state h3{margin:0 0 .5rem;color:#1e293b;font-size:1.5rem}.error-section p,.empty-state p{margin:0 0 1.5rem;color:#64748b;font-size:1rem}.retry-btn{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .2s}.retry-btn:hover{background:#5a67d8}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000}.loading-overlay .loading-spinner{margin-bottom:1rem}.loading-overlay p{color:#fff;font-size:1.1rem;margin:0}@media (max-width: 768px){.history-display{padding:.5rem}.history-header{flex-direction:column;gap:1rem;text-align:center}.search-input-group{flex-direction:row;align-items:center;gap:.2rem}.search-input{flex:1;min-width:0}.search-btn{flex-shrink:0;padding:.3rem;font-size:.7rem;width:auto;min-width:auto}.view-controls{flex-direction:column;gap:1rem;align-items:stretch}.view-modes,.sort-controls{justify-content:center}.records-container.grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.records-container.timeline .record-item{margin-left:2rem}.records-container.timeline:before{left:1rem}.records-container.timeline .record-item:before{left:-1.5rem}.pagination{flex-direction:column;gap:1rem}.page-btn{width:100%}}@media (max-width: 480px){.records-container.grid{grid-template-columns:1fr}.record-header,.record-content,.record-actions{padding:1rem}.record-actions{flex-direction:column}.action-btn{width:100%}}.record-item{background:#fff;border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;border:1px solid #e2e8f0;cursor:pointer}.record-item.grid{display:flex;align-items:center;gap:1rem;padding:1rem}.record-item:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026;border-color:#667eea}.record-date-title{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem;padding:.5rem 0;border-bottom:1px solid #f1f5f9}.records-container.list .record-date-title{flex-direction:row;align-items:center;gap:1rem;margin-bottom:0;padding:.5rem 0;justify-content:space-between}.record-text-content{display:flex;flex-direction:column;gap:.5rem;flex:1;order:1}.records-container.list .record-text-content{flex-direction:row;align-items:center;gap:1rem;order:1}.record-item.grid .record-date-title{flex:1;margin-bottom:0;padding:0;border-bottom:none;flex-direction:row;align-items:center;justify-content:space-between}.record-item.grid .record-text-content{order:1}.record-date{font-size:1rem;font-weight:600;color:#1e293b}.record-engine-badge{font-size:.85rem;color:#64748b;background:#f1f5f9;padding:.25rem .75rem;border-radius:12px}.record-image-thumbnail{width:100%;height:120px;border-radius:8px;overflow:hidden;background:#f8fafc;display:flex;align-items:center;justify-content:center;border:2px solid #e2e8f0;transition:border-color .2s}.record-item.grid .record-image-thumbnail{width:120px;height:80px;flex-shrink:0;margin-left:auto;order:2}.record-image-thumbnail:hover{border-color:#667eea}.record-image-thumbnail img{width:100%;height:100%;object-fit:cover}.no-image-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#94a3b8;font-size:.9rem;width:100%;height:100%}.no-image-placeholder span:first-child{font-size:2rem;margin-bottom:.5rem}.records-container.list .no-image-placeholder{font-size:.7rem}.records-container.list .no-image-placeholder span:first-child{font-size:1.5rem;margin-bottom:0}.record-favorite-btn{background:none;border:none;cursor:pointer;padding:.25rem;font-size:1.2rem;opacity:.6;transition:opacity .2s,transform .2s;z-index:10;order:2;flex-shrink:0}.record-favorite-btn:hover{opacity:1;transform:scale(1.1)}.record-item:hover .record-favorite-btn{opacity:.8}.record-favorite-btn.favorited{opacity:1;color:#f59e0b}.record-favorite-btn.favorited:hover{transform:scale(1.15)}.record-item.grid .record-favorite-btn,.records-container.list .record-favorite-btn{margin-left:.5rem}.record-delete-btn{background:none;border:none;cursor:pointer;padding:.25rem;font-size:1.2rem;opacity:.6;transition:opacity .2s,transform .2s;z-index:10;order:3;flex-shrink:0}.record-delete-btn:hover{opacity:1;transform:scale(1.1)}.record-item:hover .record-delete-btn{opacity:.8}.record-item.grid .record-delete-btn,.records-container.list .record-delete-btn{margin-left:.5rem}@media (max-width: 768px){.record-item{padding:.4rem;margin-bottom:.4rem}.record-item.grid{padding:.6rem;gap:.5rem}.record-image-thumbnail{height:60px}.record-item.grid .record-image-thumbnail{width:80px;height:60px}.record-date{font-size:.75rem}.record-engine-badge{font-size:.7rem;padding:.1rem .4rem}.record-date-title{margin-bottom:.3rem;padding:.15rem 0}}.history-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.history-menu{background:#fff;border-radius:16px;box-shadow:0 10px 30px #0000004d;max-width:400px;width:100%;max-height:80vh;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.history-menu-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #f1f5f9}.history-menu-header h3{margin:0;font-size:1.2rem;font-weight:600;color:#1e293b}.close-btn{background:none;border:none;font-size:1.5rem;color:#64748b;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .2s}.close-btn:hover{background-color:#f1f5f9}.history-menu-options{padding:1rem 0}.history-option{display:flex;align-items:center;padding:1rem 1.5rem;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #f8fafc}.history-option:last-child{border-bottom:none}.history-option:hover{background-color:#f8fafc}.option-icon{font-size:2rem;margin-right:1rem;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;box-shadow:0 2px 8px #667eea4d}.option-content{flex:1;margin-right:1rem}.option-content h4{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:#1e293b}.option-content p{margin:0;font-size:.85rem;color:#64748b;line-height:1.4}.option-arrow{font-size:1.2rem;color:#cbd5e0;transition:color .2s}.history-option:hover .option-arrow{color:#667eea}.history-menu-footer{padding:1rem 1.5rem;border-top:1px solid #f1f5f9;text-align:center}.cancel-btn{background:#f1f5f9;color:#64748b;border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#e2e8f0;color:#4a5568}@media (max-width: 480px){.history-menu{margin:.5rem;max-height:85vh}.history-menu-header{padding:1rem 1rem .75rem}.history-menu-header h3{font-size:1.1rem}.history-option{padding:.75rem 1rem}.option-icon{font-size:1.5rem;width:2.5rem;height:2.5rem;margin-right:.75rem}.option-content h4{font-size:.95rem}.option-content p{font-size:.8rem}.history-menu-footer{padding:.75rem 1rem}.cancel-btn{padding:.625rem 1.5rem;font-size:.9rem}}.history-option{animation:fadeInUp .3s ease-out}.history-option:nth-child(1){animation-delay:.1s}.history-option:nth-child(2){animation-delay:.2s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mobile-main-app{display:flex;flex-direction:column;height:100vh;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;width:100%;max-width:100vw}.mobile-device{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;z-index:100;position:sticky;top:0}.header-left,.header-right{width:60px}.header-center{flex:1;text-align:center}.title-user-container{position:relative;display:flex;align-items:center;justify-content:center;width:100%}.page-title{font-size:1.125rem;font-weight:600;color:#2d3748;margin:0;text-align:center}.user-info-display{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;z-index:1}.user-name{font-size:.7rem;color:#4a5568;font-weight:500;white-space:nowrap}.guest-badge{font-size:.55rem;background:#fef5e7;color:#d69e2e;padding:.1rem .3rem;border-radius:.5rem;font-weight:600;border:1px solid #f6e05e;white-space:nowrap}.admin-badge{font-size:.55rem;background:#e6fffa;color:#38a169;padding:.1rem .3rem;border-radius:.5rem;font-weight:600;border:1px solid #68d391;white-space:nowrap}.back-btn{background:none;border:none;color:#3182ce;font-size:1rem;padding:.5rem .75rem;border-radius:.375rem;cursor:pointer;transition:background-color .2s;white-space:nowrap;font-weight:500;position:relative;z-index:2}.back-btn:hover{background:#f7fafc}.menu-btn{background:none;border:none;color:#4a5568;font-size:1.25rem;padding:.5rem;border-radius:.375rem;cursor:pointer;transition:background-color .2s}.menu-btn:hover{background:#f7fafc}.mobile-main-content{flex:1;overflow-y:auto;padding-bottom:80px;-webkit-overflow-scrolling:touch;width:100%;max-width:100vw}.mobile-bottom-nav{display:flex;background:#fff;border-top:1px solid #e2e8f0;box-shadow:0 -1px 3px #0000001a;position:fixed;bottom:0;left:0;right:0;z-index:100;padding:.5rem 0}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;background:none;border:none;padding:.5rem .25rem;cursor:pointer;transition:all .2s;color:#718096}.nav-item.active{color:#3182ce}.nav-item:hover{background:#f7fafc}.nav-icon{font-size:1.25rem;margin-bottom:.25rem;display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem}.nav-label{font-size:.75rem;font-weight:500}.user-avatar{font-size:1.25rem;line-height:1}.user-avatar img{width:1.25rem;height:1.25rem;border-radius:50%;object-fit:cover}.mobile-home-page{padding:1rem}.home-header{text-align:center;margin-bottom:2rem}.app-title{font-size:1.5rem;font-weight:700;color:#2d3748;margin:0 0 .5rem}.welcome-text{color:#718096;margin:0 0 1rem}.stats-toggle{display:flex;justify-content:center;margin-top:.5rem}.toggle-btn{padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:20px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d}.toggle-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.toggle-btn.active{background:linear-gradient(135deg,#48bb78,#38a169);box-shadow:0 2px 8px #48bb784d}.toggle-btn.active:hover{box-shadow:0 4px 12px #48bb7866}.feature-cards{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.feature-card{display:flex;align-items:center;background:#fff;border-radius:1rem;padding:1.25rem;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .3s ease;border:2px solid transparent}.feature-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.feature-card:active{transform:translateY(0)}.card-icon{font-size:2rem;margin-right:1rem;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;border-radius:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.translation-card .card-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.dictionary-card .card-icon{background:linear-gradient(135deg,#f093fb,#f5576c)}.ocr-card .card-icon{background:linear-gradient(135deg,#4facfe,#00f2fe)}.history-card .card-icon{background:linear-gradient(135deg,#43e97b,#38f9d7)}.favorites-card .card-icon{background:linear-gradient(135deg,#fa709a,#fee140)}.phonetics-card .card-icon{background:linear-gradient(135deg,#ffecd2,#fcb69f);color:#8b4513}.study-card .card-icon{background:linear-gradient(135deg,#a8edea,#fed6e3);color:#4a5568}.import-card .card-icon{background:linear-gradient(135deg,#ff9a9e,#fecfef);color:#8b4513}.profile-card .card-icon{background:linear-gradient(135deg,#e0c3fc,#9bb5ff);color:#4a5568}.card-content{flex:1}.card-content h3{font-size:1.125rem;font-weight:600;color:#2d3748;margin:0 0 .25rem}.card-content p{font-size:.875rem;color:#718096;margin:0;line-height:1.4}.card-arrow{font-size:1.25rem;color:#cbd5e0;margin-left:.5rem}.quick-stats{display:flex;justify-content:space-around;background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.stat-item{text-align:center}.stat-number{font-size:1.5rem;margin-bottom:.5rem}.stat-label{font-size:.75rem;color:#000;font-weight:500}.admin-side-menu{position:fixed;top:0;right:-300px;width:280px;height:100vh;background:#fff;box-shadow:-2px 0 8px #00000026;transition:right .3s ease;z-index:200;display:flex;flex-direction:column}.admin-side-menu.open{right:0}.menu-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid #e2e8f0;background:#f8fafc}.menu-header h3{font-size:1.125rem;font-weight:600;color:#2d3748;margin:0}.close-menu-btn{background:none;border:none;color:#718096;font-size:1.25rem;padding:.25rem;border-radius:.25rem;cursor:pointer;transition:background-color .2s}.close-menu-btn:hover{background:#e2e8f0}.menu-items{flex:1;padding:1rem 0}.menu-item{display:flex;align-items:center;width:100%;background:none;border:none;padding:1rem;cursor:pointer;transition:background-color .2s;color:#4a5568}.menu-item:hover{background:#f7fafc}.menu-icon{font-size:1.25rem;margin-right:.75rem;width:1.5rem;text-align:center}.menu-label{font-size:1rem;font-weight:500}.menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:150}@media screen and (min-width: 769px){.mobile-main-app{width:100%;max-width:100%;margin:0;border-left:none;border-right:none}.mobile-header,.mobile-bottom-nav{border-radius:0}}@media screen and (max-width: 480px){.mobile-home-page{padding:.75rem}.feature-card{padding:1rem}.card-icon{font-size:1.75rem;width:2.5rem;height:2.5rem}.quick-stats{padding:1rem}.user-info-display{gap:.25rem}.user-name{font-size:.65rem}.guest-badge,.admin-badge{font-size:.5rem;padding:.08rem .25rem}}@media (hover: none) and (pointer: coarse){.feature-card:hover{transform:none;box-shadow:0 2px 8px #0000001a}.nav-item:hover{background:none}.feature-card:active{transform:scale(.98);transition:transform .1s ease}.toggle-btn{padding:.4rem .8rem;font-size:.8rem}}.app{min-height:100vh;display:flex;flex-direction:column;background:transparent;overflow-x:hidden}body{overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}body::-webkit-scrollbar{display:none}.main-content{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem 1rem;margin-top:0;overflow-x:hidden}.main-content::-webkit-scrollbar{display:none}.container{width:100%;max-width:800px;margin:0 auto;background:#fffffff2;border-radius:24px;box-shadow:0 20px 40px #0000001a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);overflow:hidden;scrollbar-width:none;-ms-overflow-style:none}.container::-webkit-scrollbar{display:none}@media screen and (orientation: landscape) and (max-height: 600px){.main-content{padding:.5rem}.container{max-width:100%;border-radius:12px;box-shadow:0 10px 20px #0000001a}}@media screen and (orientation: landscape) and (min-width: 768px) and (max-height: 500px){.main-content{padding:.75rem}.container{max-width:100%;border-radius:16px}}@media screen and (orientation: landscape) and (min-width: 1024px){.main-content{padding:1rem}.container{max-width:1200px}}@media screen and (orientation: portrait) and (max-width: 480px){.main-content{padding:.5rem}.container{max-width:100%;border-radius:16px;box-shadow:0 10px 20px #0000001a}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{position:relative;background:#fff;border-radius:16px;box-shadow:0 20px 40px #0003;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;animation:slideInUp .3s ease-out}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;color:#718096;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s;z-index:1001}.modal-close:hover{background:#f7fafc;color:#4a5568}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.loading-container{text-align:center;padding:1.5rem 1rem;color:#4a5568}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top:4px solid #3182ce;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-container{background:#fed7d7;border:1px solid #feb2b2;border-radius:12px;padding:1rem;margin:.5rem 1rem;text-align:center}.error-message{color:#c53030;font-size:1rem;margin:0;font-weight:500}.translation-chat-layout{display:flex;flex-direction:column;height:calc(100vh - 200px);min-height:500px;max-height:700px;background:#fafafa}.translation-messages-area{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px 0 100px;background:#fafafa;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}.translation-messages-area::-webkit-scrollbar{display:none}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#9e9e9e;padding:40px 20px}.empty-icon{font-size:64px;margin-bottom:16px;opacity:.5}.empty-state p{font-size:16px;margin:0}@media (max-width: 768px){.main-content{padding:2rem .5rem 1rem}.container{max-width:100%;border-radius:16px;margin:0 .5rem}.loading-container{padding:2rem 1rem}.loading-spinner{width:36px;height:36px}.error-container{margin:1rem;padding:1.5rem}.translation-chat-layout{height:calc(100vh - 180px);min-height:400px}.translation-messages-area{padding:16px 0}.empty-icon{font-size:48px}.empty-state p{font-size:14px}}@media (max-width: 480px){.translation-chat-layout{height:calc(100vh - 160px);min-height:350px}.translation-messages-area{padding:12px 0}}*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}input,textarea,[contenteditable]{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.scroll-container{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.touch-button{position:relative;overflow:hidden}.touch-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.touch-button:active:before{width:300px;height:300px}.touch-card{transition:transform .1s ease}.touch-card:active{transform:scale(.98)}.swipe-indicator{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:flex;gap:4px;z-index:10}.swipe-dot{width:8px;height:8px;border-radius:50%;background:#ffffff80;transition:background-color .3s ease}.swipe-dot.active{background:#fff}.pull-to-refresh{position:relative;overflow:hidden}.pull-to-refresh-indicator{position:absolute;top:-50px;left:0;right:0;height:50px;display:flex;align-items:center;justify-content:center;background:#f8fafc;transition:transform .3s ease;z-index:100}.pull-to-refresh-indicator.refreshing{transform:translateY(50px)}.long-press-menu{position:fixed;background:#000c;color:#fff;border-radius:8px;padding:8px 0;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0000004d}.long-press-menu-item{padding:12px 16px;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;gap:8px}.long-press-menu-item:hover{background:#ffffff1a}.long-press-menu-item:active{background:#fff3}.swipe-navigation{position:relative;overflow:hidden}.swipe-navigation-content{display:flex;transition:transform .3s ease;width:100%}.swipe-navigation-item{min-width:100%;flex-shrink:0}.gesture-hint{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeInOut 3s ease}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%) translateY(20px)}20%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-20px)}}.haptic-feedback{animation:haptic .1s ease}@keyframes haptic{0%{transform:scale(1)}50%{transform:scale(.98)}to{transform:scale(1)}}.skeleton-loader{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:4px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.responsive-text{font-size:clamp(14px,4vw,18px)}.responsive-title{font-size:clamp(18px,5vw,24px)}.responsive-subtitle{font-size:clamp(16px,4.5vw,20px)}.safe-area-top{padding-top:env(safe-area-inset-top)}.safe-area-bottom{padding-bottom:env(safe-area-inset-bottom)}.safe-area-left{padding-left:env(safe-area-inset-left)}.safe-area-right{padding-right:env(safe-area-inset-right)}@media (prefers-color-scheme: dark){.dark-mode-support{background:#1a202c;color:#e2e8f0}.dark-mode-support .card{background:#2d3748;border-color:#4a5568}.dark-mode-support .text-muted{color:#a0aec0}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){.high-contrast-support,.high-contrast-support button{border:2px solid currentColor}}@media (hover: none) and (pointer: coarse){.touch-target{min-height:44px;min-width:44px}.no-hover:hover{background:initial;transform:initial;box-shadow:initial}.mobile-input,.mobile-select{font-size:16px;padding:12px;border-radius:8px}}@media (min-width: 768px) and (max-width: 1024px){.tablet-optimized{max-width:600px;margin:0 auto}}@media (min-width: 414px) and (max-width: 768px){.large-phone-optimized{padding:0 20px}}@media (max-width: 320px){.small-screen-optimized{font-size:14px}.small-screen-optimized .button{padding:8px 12px;font-size:14px}}*{margin:0;padding:0;box-sizing:border-box}*{scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{display:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#1e3c72,#2a5298);min-height:100vh;color:#2d3748;line-height:1.6;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}@media (max-width: 768px){body{font-size:14px}}@media screen and (max-width: 768px){input[type=text],input[type=email],input[type=password],textarea,select{font-size:16px!important}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}
