@import "https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700&family=Noto+Sans+SC:wght@300;400;500;600&display=swap";@import "https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700&family=Noto+Sans+SC:wght@300;400;500&display=swap";@import "https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600&family=Noto+Sans+SC:wght@300;400;500&display=swap";@import "https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700&family=Noto+Sans+SC:wght@300;400;500;600&display=swap";html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f5f0e8}::-webkit-scrollbar-thumb{background:#c9a962;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8893f}::selection{color:#c53d43;background:#c53d4326}.image-uploader{border:2px dashed var(--border-light);border-radius:var(--radius-md);background:var(--paper-warm);cursor:pointer;justify-content:center;align-items:center;width:100%;min-height:220px;transition:all .3s;display:flex;position:relative;overflow:hidden}.image-uploader:hover{border-color:var(--gold);background:linear-gradient(180deg,var(--paper)0%,var(--paper-warm)100%)}.image-uploader.dragging{border-color:var(--vermillion);background:#c53d4308;transform:scale(1.01)}.image-uploader.disabled{opacity:.6;cursor:not-allowed}.file-input{opacity:0;cursor:pointer;position:absolute;inset:0}.image-uploader.disabled .file-input{cursor:not-allowed}.upload-placeholder{text-align:center;padding:2rem}.upload-icon{width:56px;height:56px;color:var(--gold);opacity:.8;margin:0 auto 1rem}.upload-icon svg{width:100%;height:100%}.upload-text{color:var(--text-primary);margin-bottom:.5rem;font-family:Noto Serif SC,serif;font-size:1.1rem}.upload-hint{color:var(--text-muted);font-size:.875rem}.preview-container{width:100%;height:100%;position:relative}.preview-image{object-fit:contain;width:100%;height:100%;max-height:280px}.preview-overlay{opacity:0;background:#1a1a1ab3;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.preview-container:hover .preview-overlay{opacity:1}.preview-overlay span{color:#fff;background:var(--vermillion);border-radius:var(--radius-sm);padding:.6rem 1.2rem;font-size:.9rem}.dictation-page{color:#1a1a1a;background-color:#fffef9;border:1px solid #c9a96233;border-radius:8px;margin:0;padding:2.5rem;font-family:Noto Serif SC,KaiTi,楷体,serif;font-size:22px;line-height:3.2;position:relative;box-shadow:0 8px 32px #1a1a1a1a}.dictation-page:before{content:"";background:linear-gradient(90deg,#0000,#c53d43,#0000);border-radius:0 0 4px 4px;width:80px;height:4px;position:absolute;top:0;left:50%;transform:translate(-50%)}.sheet-title{text-align:center;color:#1a1a1a;letter-spacing:.15em;margin-bottom:2rem;padding-bottom:1rem;font-size:1.75rem;font-weight:700;position:relative}.sheet-title:after{content:"";background:linear-gradient(90deg,#0000,#c9a962,#0000);width:120px;height:2px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.content{text-align:justify;text-justify:inter-character}.paragraph{margin:0;display:block}.char-unit{vertical-align:middle;flex-direction:column;align-items:center;margin:0 3px;display:inline-flex;transform:translateY(-8px)}.pinyin{color:#c53d43;white-space:nowrap;margin-bottom:2px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;font-size:13px;font-weight:500;line-height:1.4}.tzg{box-sizing:border-box;background-color:#fffef9;border:1.5px solid #1a1a1a;width:44px;height:44px;position:relative}.tzg:before{content:"";border-top:1px dashed #c9a962;width:100%;height:1px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.tzg:after{content:"";border-left:1px dashed #c9a962;width:1px;height:100%;position:absolute;top:0;left:50%;transform:translate(-50%)}.btn-print{color:#fff;cursor:pointer;background:#c53d43;border:none;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;margin:2.5rem auto 0;padding:.875rem 2.5rem;font-family:Noto Sans SC,sans-serif;font-size:1rem;font-weight:500;transition:all .3s;display:flex}.btn-print:hover{background:#a32e33;transform:translateY(-2px);box-shadow:0 4px 12px #c53d434d}.btn-print svg{width:18px;height:18px}@media print{.btn-print{display:none!important}.dictation-page{box-shadow:none;border:none;border-radius:0;padding:0 30px}.dictation-page:before{display:none}.tzg{-webkit-print-color-adjust:exact;print-color-adjust:exact;border-color:#000}.tzg:before,.tzg:after{-webkit-print-color-adjust:exact;print-color-adjust:exact}@page{size:A4;margin:1.5cm}}.loading-container{flex-direction:column;justify-content:center;align-items:center;padding:3rem;display:flex}.loading-spinner{width:64px;height:64px;position:relative}.spinner-taiji{width:100%;height:100%;animation:2s linear infinite rotate}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-taiji svg{width:100%;height:100%}.loading-message{color:var(--text-secondary);letter-spacing:.1em;margin-top:1.5rem;font-family:Noto Serif SC,serif;font-size:1rem}.ink-dots{gap:8px;margin-top:1rem;display:flex}.ink-dot{background:var(--vermillion);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite inkPulse}.ink-dot:nth-child(2){background:var(--gold);animation-delay:.2s}.ink-dot:nth-child(3){background:var(--ink);animation-delay:.4s}@keyframes inkPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.5)}}.history-panel{z-index:1000;background:#faf8f5;flex-direction:column;width:380px;max-width:100%;height:100vh;animation:.3s slideIn;display:flex;position:fixed;top:0;right:0;box-shadow:-8px 0 32px #1a1a1a26}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.history-header{color:#faf8f5;background:#1a1a1a;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.history-header h2{letter-spacing:.1em;margin:0;font-family:Noto Serif SC,serif;font-size:1.25rem;font-weight:600}.history-actions{align-items:center;gap:10px;display:flex}.clear-btn{color:#c9a962;cursor:pointer;background:0 0;border:1px solid #c9a962;border-radius:4px;padding:6px 12px;font-family:Noto Sans SC,sans-serif;font-size:.8rem;transition:all .2s}.clear-btn:hover{color:#1a1a1a;background:#c9a962}.close-btn{color:#faf8f5;cursor:pointer;background:0 0;border:1px solid #faf8f54d;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;transition:all .2s;display:flex}.close-btn:hover{background:#faf8f51a;border-color:#faf8f580}.history-list{flex:1;padding:1rem;overflow-y:auto}.empty-state{color:#8c8c8c;flex-direction:column;justify-content:center;align-items:center;height:200px;display:flex}.empty-icon{color:#c9a962;opacity:.5;width:48px;height:48px;margin-bottom:1rem}.empty-icon svg{width:100%;height:100%}.empty-state p{font-family:Noto Sans SC,sans-serif;font-size:.9rem}.history-item{cursor:pointer;background:#fff;border:1px solid #c9a96226;border-radius:8px;align-items:center;gap:12px;margin-bottom:10px;padding:12px;transition:all .2s;display:flex}.history-item:hover{border-color:#c9a962;box-shadow:0 4px 12px #c9a9621a}.history-thumb{object-fit:cover;border:1px solid #1a1a1a1a;border-radius:4px;width:56px;height:56px}.history-info{flex:1;min-width:0}.history-title{color:#1a1a1a;white-space:nowrap;text-overflow:ellipsis;margin:0 0 6px;font-family:Noto Serif SC,serif;font-size:.95rem;font-weight:500;overflow:hidden}.history-meta{color:#8c8c8c;gap:12px;font-family:Noto Sans SC,sans-serif;font-size:.75rem;display:flex}.history-tokens{color:#c53d43;font-weight:500}.delete-btn{color:#8c8c8c;cursor:pointer;opacity:.5;background:0 0;border:none;border-radius:4px;padding:6px;transition:all .2s}.delete-btn:hover{opacity:1;color:#c53d43;background:#c53d431a}.delete-btn svg{width:18px;height:18px}@media (max-width:480px){.history-panel{width:100%}}.api-key-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;background:#1a1a1ad9;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.api-key-modal{text-align:center;background:#faf8f5;border-radius:12px;width:100%;max-width:420px;padding:2.5rem;animation:.3s modalIn;box-shadow:0 20px 60px #0000004d}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-icon{color:#c9a962;width:56px;height:56px;margin:0 auto 1.5rem}.modal-icon svg{width:100%;height:100%}.modal-title{color:#1a1a1a;letter-spacing:.05em;margin-bottom:.5rem;font-family:Noto Serif SC,serif;font-size:1.5rem;font-weight:600}.modal-desc{color:#5c5c5c;margin-bottom:2rem;font-size:.95rem;line-height:1.6}.key-form{flex-direction:column;gap:1rem;display:flex}.input-wrapper{position:relative}.key-input{color:#1a1a1a;background:#fff;border:1.5px solid #c9a9624d;border-radius:6px;outline:none;width:100%;padding:.875rem 1rem;font-family:monospace;font-size:1rem;transition:all .2s}.key-input:focus{border-color:#c9a962;box-shadow:0 0 0 3px #c9a96226}.key-input.has-error{border-color:#c53d43}.key-input:disabled{cursor:not-allowed;background:#f5f0e8}.error-text{color:#c53d43;text-align:left;margin:0;font-size:.875rem}.submit-btn{color:#fff;cursor:pointer;background:#c53d43;border:none;border-radius:6px;padding:.875rem 1.5rem;font-family:Noto Sans SC,sans-serif;font-size:1rem;font-weight:500;transition:all .2s}.submit-btn:hover:not(:disabled){background:#a32e33}.submit-btn:disabled{cursor:not-allowed;background:#8c8c8c}.modal-footer{border-top:1px solid #c9a96233;margin-top:1.5rem;padding-top:1.5rem}.get-key-link{color:#c9a962;font-size:.875rem;text-decoration:none;transition:color .2s}.get-key-link:hover{color:#a8893f;text-decoration:underline}:root{--vermillion:#c53d43;--vermillion-dark:#a32e33;--gold:#c9a962;--gold-light:#e6d5a8;--ink:#1a1a1a;--ink-light:#2d2d2d;--paper:#faf8f5;--paper-warm:#f5f0e8;--bamboo:#5b7553;--text-primary:#1a1a1a;--text-secondary:#5c5c5c;--text-muted:#8c8c8c;--border-light:#c9a96233;--shadow-soft:0 4px 20px #1a1a1a14;--shadow-float:0 8px 32px #1a1a1a1f;--radius-sm:4px;--radius-md:8px;--radius-lg:12px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{background:var(--paper);color:var(--text-primary);min-height:100vh;font-family:Noto Sans SC,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.8}.app{background:var(--paper);flex-direction:column;min-height:100vh;display:flex;position:relative}.app:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle at 20% 80%,#c9a96208 0%,#0000 50%),radial-gradient(circle at 80% 20%,#c53d4305 0%,#0000 50%);position:fixed;inset:0}.app-header{background:linear-gradient(180deg,var(--ink)0%,var(--ink-light)100%);text-align:center;color:var(--paper);z-index:1;padding:3rem 2rem;position:relative;overflow:hidden}.app-header:before{content:"";pointer-events:none;background:radial-gradient(100px 100px at 15% 30%,#c9a9621a 0%,#0000 70%),radial-gradient(80px 80px at 85% 70%,#c9a96214 0%,#0000 70%),radial-gradient(60px 60px at 60% 20%,#c53d430d 0%,#0000 70%);width:120%;height:160%;position:absolute;top:-30%;left:-10%}.header-content{z-index:1;position:relative}.app-title{letter-spacing:.1em;text-shadow:0 2px 8px #0000004d;justify-content:center;align-items:center;gap:1rem;font-family:Noto Serif SC,serif;font-size:2.5rem;font-weight:700;display:flex}.title-icon{justify-content:center;align-items:center;width:48px;height:48px;display:flex}.title-icon svg{width:100%;height:100%;fill:var(--gold)}.app-subtitle{color:var(--gold-light);letter-spacing:.15em;margin-top:1rem;font-size:1rem;font-weight:300}.header-actions{z-index:2;gap:.5rem;display:flex;position:absolute;top:1.5rem;right:1.5rem}.settings-btn{width:36px;height:36px;color:var(--gold);border:1px solid var(--gold);border-radius:var(--radius-sm);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:all .3s;display:flex}.settings-btn:hover{background:var(--gold);color:var(--ink)}.settings-btn svg{width:18px;height:18px}.history-btn{color:var(--gold);border:1px solid var(--gold);border-radius:var(--radius-sm);cursor:pointer;background:0 0;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.85rem;font-weight:500;transition:all .3s;display:flex}.history-btn:hover{background:var(--gold);color:var(--ink)}.history-btn svg{width:16px;height:16px}.loading-screen{background:var(--paper);justify-content:center;align-items:center;min-height:100vh;display:flex}.app-main{z-index:1;flex:1;width:100%;max-width:900px;margin:0 auto;padding:3rem 2rem;position:relative}.section-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-float);border:1px solid var(--border-light);background:#fff;padding:2.5rem;position:relative}.section-card:before{content:"";background:linear-gradient(90deg,transparent,var(--vermillion),transparent);border-radius:2px;width:60px;height:3px;position:absolute;top:0;left:50%;transform:translate(-50%)}.section-title{color:var(--text-primary);text-align:center;margin-bottom:.5rem;font-family:Noto Serif SC,serif;font-size:1.5rem;font-weight:600}.section-desc{color:var(--text-secondary);text-align:center;margin-bottom:2rem;font-size:.95rem}.upload-section{animation:.6s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.processing-section .section-card{justify-content:center;align-items:center;min-height:300px;display:flex}.error-card{text-align:center;padding:3rem 2rem}.error-icon{width:64px;height:64px;color:var(--vermillion);margin:0 auto 1.5rem}.error-icon svg{width:100%;height:100%}.error-title{color:var(--vermillion);margin-bottom:.5rem;font-family:Noto Serif SC,serif;font-size:1.5rem}.error-message{color:var(--text-secondary);margin-bottom:2rem}.retry-btn{color:#fff;background:var(--vermillion);border-radius:var(--radius-sm);cursor:pointer;border:none;padding:.875rem 2.5rem;font-size:1rem;font-weight:500;transition:all .3s}.retry-btn:hover{background:var(--vermillion-dark);transform:translateY(-2px);box-shadow:0 4px 12px #c53d434d}.result-section{animation:.6s fadeIn}.result-header{margin-bottom:1.5rem}.back-btn{color:var(--text-secondary);border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;background:#fff;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.9rem;font-weight:500;transition:all .2s;display:inline-flex}.back-btn:hover{color:var(--vermillion);border-color:var(--vermillion)}.back-btn svg{width:16px;height:16px}.app-footer{text-align:center;background:var(--ink);color:var(--text-muted);z-index:1;padding:1.5rem 2rem;position:relative}.footer-info{justify-content:center;align-items:center;gap:.5rem;font-size:.85rem;display:flex}.footer-divider{color:var(--gold);opacity:.5}.footer-tokens{color:var(--gold-light);font-weight:400}.current-tokens{color:var(--text-muted)}.history-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;background:#1a1a1a99;position:fixed;inset:0}@media print{.no-print{display:none!important}.app{background:#fff}.app:before{display:none}.app-main{max-width:100%;padding:0}}@media (max-width:640px){.app-header{padding:2rem 1rem}.app-title{letter-spacing:.05em;font-size:1.75rem}.app-subtitle{font-size:.875rem}.section-card{padding:2rem 1.5rem}.history-btn{padding:.5rem .8rem;font-size:.8rem;top:1rem;right:1rem}.app-main{padding:2rem 1rem}}
