@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=Noto+Sans+SC:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";.welcome-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;align-items:center;padding:20px;font-family:Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.welcome-card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:60px 50px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff1a;text-align:center;max-width:420px;width:100%;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.welcome-title{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px;letter-spacing:2px}.welcome-subtitle{font-size:1.1rem;color:#6b7280;font-weight:500;margin-bottom:20px;line-height:1.8}.welcome-logo{width:120px;height:auto;margin:0 auto 30px;display:block;border-radius:12px;box-shadow:0 4px 12px #00000026}.welcome-button-group{display:flex;flex-direction:column;gap:20px}.welcome-btn{display:block;width:100%;text-decoration:none;color:#fff;padding:18px 32px;font-size:1.1rem;font-weight:500;border:none;border-radius:14px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;font-family:Noto Sans SC,sans-serif}.welcome-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.welcome-btn:hover:before{left:100%}.welcome-btn-1{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;box-shadow:0 4px 15px #f5576c66}.welcome-btn-1:hover{transform:translateY(-3px);box-shadow:0 8px 25px #f5576c80}.welcome-btn-1b{background:linear-gradient(135deg,#ff8c42,#ff6b35);color:#fff;box-shadow:0 4px 15px #ff6b3566}.welcome-btn-1b:hover{transform:translateY(-3px);box-shadow:0 8px 25px #ff6b3580}.welcome-btn-2{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;box-shadow:0 4px 15px #4facfe66}.welcome-btn-2:hover{transform:translateY(-3px);box-shadow:0 8px 25px #4facfe80}.welcome-btn-3{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff;box-shadow:0 4px 15px #43e97b66}.welcome-btn-3:hover{transform:translateY(-3px);box-shadow:0 8px 25px #43e97b80}.welcome-btn-4{background:linear-gradient(135deg,#a78bfa,#7c3aed);color:#fff;box-shadow:0 4px 15px #7c3aed66}.welcome-btn-4:hover{transform:translateY(-3px);box-shadow:0 8px 25px #7c3aed80}.welcome-btn:active{transform:translateY(-1px)}@media (max-width: 480px){.welcome-container{padding:16px}.welcome-card{padding:40px 24px;max-width:100%;border-radius:20px}.welcome-title{font-size:2rem;letter-spacing:1px}.welcome-subtitle{font-size:1rem;margin-bottom:16px}.welcome-logo{width:140px;margin:0 auto 24px}.welcome-button-group{gap:16px}.welcome-btn{padding:20px 28px;font-size:1.15rem;border-radius:16px}}@media (max-width: 360px){.welcome-card{padding:32px 20px}.welcome-title{font-size:1.75rem}.welcome-logo{width:120px;margin:0 auto 24px}.welcome-btn{padding:18px 24px;font-size:1.1rem}}.grader-container{min-height:100vh;background:linear-gradient(135deg,#fff5e6,#ffe5cc,#ffd8c0);font-family:Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.grader-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,107,53,.15);position:sticky;top:0;z-index:100}.grader-back-btn{display:flex;align-items:center;gap:4px;padding:8px 12px;border:none;background:transparent;color:#666;font-size:14px;cursor:pointer;border-radius:8px;transition:all .2s;font-family:inherit}.grader-back-btn:hover{background:#ff6b351a;color:#ff6b35}.grader-title{font-size:1.1rem;font-weight:700;color:#2c3e50}.grader-header-spacer{width:72px}.grader-content{padding:20px;max-width:600px;margin:0 auto}.grader-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh}.grader-upload-area{background:#fff;border-radius:20px;padding:40px 24px;text-align:center;box-shadow:0 4px 20px #ff6b351a;border:2px dashed rgba(255,140,66,.3);margin-bottom:20px}.grader-upload-icon{width:80px;height:80px;margin:0 auto 16px;background:linear-gradient(135deg,#fff5e6,#ffe5cc);border-radius:50%;display:flex;align-items:center;justify-content:center}.grader-upload-text{font-size:1rem;color:#666;margin-bottom:24px}.grader-upload-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.grader-upload-btn{display:flex;align-items:center;gap:8px;padding:14px 24px;border:none;border-radius:14px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;font-family:inherit}.grader-upload-btn-camera{background:linear-gradient(135deg,#ff8c42,#ff6b35);color:#fff;box-shadow:0 4px 15px #ff6b3566}.grader-upload-btn-camera:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b3580}.grader-upload-btn-file{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #764ba266}.grader-upload-btn-file:hover{transform:translateY(-2px);box-shadow:0 6px 20px #764ba280}.grader-hidden-input{display:none}.grader-tips{background:#fff;border-radius:16px;padding:20px 24px;box-shadow:0 2px 12px #0000000f}.grader-tips-title{font-size:1rem;font-weight:700;color:#2c3e50;margin-bottom:12px}.grader-tips-list{list-style:none;padding:0;margin:0;counter-reset:step}.grader-tips-list li{counter-increment:step;padding:8px 0 8px 32px;position:relative;font-size:.9rem;color:#555;line-height:1.6}.grader-tips-list li:before{content:counter(step);position:absolute;left:0;top:8px;width:22px;height:22px;background:linear-gradient(135deg,#ff8c42,#ff6b35);color:#fff;border-radius:50%;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center}.grader-tips-note{margin-top:12px;padding:10px 14px;background:#fff8f0;border-radius:10px;font-size:.8rem;color:#963}.grader-preview-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 4px 20px #ff6b351a;margin-bottom:16px}.grader-preview-image{width:100%;max-height:50vh;object-fit:contain;border-radius:10px}.grader-preview-actions{display:flex;gap:12px}.grader-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border:none;border-radius:14px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;flex:1;font-family:inherit}.grader-btn-primary{background:linear-gradient(135deg,#ff8c42,#ff6b35);color:#fff;box-shadow:0 4px 15px #ff6b3566}.grader-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b3580}.grader-btn-secondary{background:#fff;color:#666;border:2px solid #e5e7eb}.grader-btn-secondary:hover{border-color:#ff8c42;color:#ff6b35}.grader-loading-spinner{margin-bottom:16px}.grader-loading-text{font-size:1.1rem;font-weight:600;color:#2c3e50;margin-bottom:8px}.grader-loading-subtext{font-size:.85rem;color:#999}.grader-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}.grader-stat-item{background:#fff;border-radius:14px;padding:14px 8px;text-align:center;box-shadow:0 2px 10px #0000000d}.grader-stat-value{display:block;font-size:1.5rem;font-weight:800;line-height:1.2}.grader-stat-label{display:block;font-size:.75rem;color:#888;margin-top:4px}.grader-stat-total .grader-stat-value{color:#2c3e50}.grader-stat-correct .grader-stat-value{color:#22c55e}.grader-stat-wrong .grader-stat-value{color:#ef4444}.grader-stat-rate .grader-stat-value{color:#ff6b35}.grader-result-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 4px 20px #ff6b351a;margin-bottom:16px}.grader-result-title{font-size:1rem;font-weight:700;color:#2c3e50;margin-bottom:12px}.grader-result-image-wrapper{background:#f9f9f9;border-radius:10px;overflow:hidden}.grader-result-image{width:100%;display:block}.grader-result-actions{display:flex;gap:12px;margin-bottom:20px}.grader-wrong-list{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 12px #0000000f}.grader-wrong-title{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:700;color:#2c3e50;margin-bottom:12px}.grader-wrong-table{border:1px solid #f0f0f0;border-radius:10px;overflow:hidden}.grader-wrong-header{display:grid;grid-template-columns:1fr 1fr;background:#fff5f5;padding:10px 14px;font-size:.85rem;font-weight:600;color:#999}.grader-wrong-row{display:grid;grid-template-columns:1fr 1fr;padding:10px 14px;border-top:1px solid #f5f5f5;font-size:.9rem}.grader-wrong-text{color:#333}.grader-wrong-answer{color:#ef4444;font-weight:600}@media (max-width: 480px){.grader-content{padding:16px}.grader-upload-area{padding:30px 20px}.grader-upload-buttons{flex-direction:column}.grader-stats{grid-template-columns:repeat(2,1fr)}.grader-stat-value{font-size:1.3rem}.grader-result-actions{flex-direction:column}}body{font-family:Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--color-bg);color:var(--color-text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}.header{position:sticky;top:0;z-index:100;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-xl)}.header-content{display:flex;align-items:center;gap:var(--spacing-md);max-width:1440px;margin:0 auto}.header-logo-container{display:flex;align-items:center;gap:var(--spacing-sm)}.subtitle{font-size:.75rem;color:var(--color-text-muted);font-weight:500;letter-spacing:.02em}.version{font-size:.7rem;color:var(--color-text-muted);font-weight:400}.main{flex:1;display:grid;grid-template-columns:320px 1fr;gap:var(--spacing-xl);padding:var(--spacing-xl);max-width:1440px;margin:0 auto;width:100%}.filter-section+.filter-section{margin-top:var(--spacing-lg)}.filter-title{font-size:1.1rem;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm)}.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:.95rem;font-family:Noto Sans SC,sans-serif;color:var(--color-text-primary);background-color:var(--color-bg-alt);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236B7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-md) center;background-size:16px}.query-button{width:100%;padding:var(--spacing-md);font-size:1rem;font-weight:600;font-family:Noto Sans SC,sans-serif;color:#fff;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-hover));border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #e86a334d}.query-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #e86a3366}.query-button:disabled{opacity:.6;cursor:not-allowed}.reset-button{width:100%;padding:var(--spacing-md);font-size:1rem;font-weight:600;font-family:Noto Sans SC,sans-serif;color:var(--color-text-secondary);background:var(--color-bg-alt);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;margin-top:var(--spacing-sm)}.reset-button:hover:not(:disabled){border-color:var(--color-primary-light);color:var(--color-primary)}.generate-button{width:100%;padding:var(--spacing-md);font-size:1rem;font-weight:600;font-family:Noto Sans SC,sans-serif;color:#fff;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #1a4d3e4d}.generate-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1a4d3e66}.generate-button:disabled{opacity:.6;cursor:not-allowed}.button-group{display:flex;gap:var(--spacing-sm)}.button-group .generate-button,.button-group .reset-button{flex:1}.unit-checkboxes{display:flex;flex-direction:column;gap:var(--spacing-sm)}.unit-selection{padding:var(--spacing-sm) 0}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:.95rem;color:var(--color-text-primary);transition:color .2s ease}.checkbox-label:hover{color:var(--color-primary)}.unit-checkbox{font-weight:600;padding:var(--spacing-xs) 0}.group-checkbox{padding-left:var(--spacing-xl);font-size:.9rem}.checkbox-text{-webkit-user-select:none;user-select:none}.group-checkboxes{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-sm);padding-left:var(--spacing-md)}.content{min-height:60vh}.results-container{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);overflow:hidden}.results-header{padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff}.results-title{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-xs)}.results-meta{display:flex;gap:var(--spacing-lg);font-size:.875rem;opacity:.9}.meta-item{display:flex;align-items:center;gap:var(--spacing-xs)}.results-content{padding:var(--spacing-xl)}.welcome-placeholder,.empty-state,.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;text-align:center;color:var(--color-text-muted);padding:var(--spacing-2xl)}.placeholder-icon{width:64px;height:64px;margin-bottom:var(--spacing-lg);opacity:.4;color:var(--color-text-muted)}.welcome-placeholder h3,.empty-state h3{font-size:1.25rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.welcome-placeholder p,.empty-state p{font-size:.95rem;max-width:360px}.spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:var(--spacing-md)}.error-message{background:#fef2f2;color:#991b1b;padding:var(--spacing-md);border-radius:var(--radius-md);font-size:.9rem;border:1px solid #FECACA;margin-top:var(--spacing-md)}.footer{text-align:center;padding:var(--spacing-lg);color:var(--color-text-muted);font-size:.8rem;border-top:1px solid var(--color-border-light)}.tts-config-section{background:var(--color-bg-alt);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg)}.tts-section-title{font-size:1.1rem;font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-md)}.tts-config-row{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.tts-config-label{font-size:.9rem;font-weight:600;color:var(--color-text-secondary);white-space:nowrap;min-width:80px}.tts-config-input{flex:1;padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;max-width:100px}.tts-controls{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.tts-button{flex:1;padding:var(--spacing-md);font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.tts-start-button{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff}.tts-start-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1a4d3e66}.tts-stop-button{background:var(--color-bg-alt);color:var(--color-text-secondary);border:2px solid var(--color-border)}.tts-stop-button:hover:not(:disabled){border-color:#ef4444;color:#ef4444}.tts-button:disabled{opacity:.5;cursor:not-allowed}.current-word-display{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--color-card);border-radius:var(--radius-md);border:2px solid var(--color-primary);text-align:center}.current-word-label{font-size:.85rem;color:var(--color-text-muted);display:block;margin-bottom:var(--spacing-xs)}.wrong-word-controls{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.wrong-word-btn{flex:1;padding:var(--spacing-md);font-size:.95rem;font-weight:600;border:2px solid var(--color-accent);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;background:#fff;color:var(--color-accent)}.wrong-word-btn:hover{background:var(--color-accent);color:#fff}.retry-wrong-btn{flex:1;padding:var(--spacing-md);font-size:.95rem;font-weight:600;border:2px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;background:#fff;color:var(--color-primary)}.retry-wrong-btn:hover:not(:disabled){background:var(--color-primary);color:#fff}.retry-wrong-btn:disabled{opacity:.5;cursor:not-allowed}.progress-bar{height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));transition:width .3s ease;border-radius:3px}.progress-text{text-align:center;font-size:.8rem;color:var(--color-text-muted);margin-top:var(--spacing-xs)}.word-tag{display:inline-flex;flex-direction:column;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-alt);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;font-size:.9rem}.word-tag:hover{border-color:var(--color-primary-light);transform:translateY(-1px)}.word-replayable{border-color:var(--color-primary);background:#1a4d3e0d}.word-playing{border-color:var(--color-accent);background:#e86a330d;animation:pulse 1s ease-in-out infinite}.wrong-selected{border-color:#ef4444;background:#ef444414}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}.word-speaker-icon{font-size:1.2rem}.wrong-word-icon{color:#ef4444;font-weight:700;font-size:.9rem}.words-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:var(--spacing-sm)}@media (max-width: 1024px){.main{grid-template-columns:1fr;padding:var(--spacing-md);gap:var(--spacing-md)}.sidebar{position:static}}@media (max-width: 768px){.header{padding:var(--spacing-sm) var(--spacing-md)}.title{font-size:1.4rem}.results-meta{flex-direction:column;gap:var(--spacing-xs)}.words-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}@media (max-width: 480px){.words-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}.tts-type-order-item{flex-wrap:wrap}.tts-type-order-item span:first-child{min-width:auto}.tts-type-select{flex:1 1 100px;min-width:0}.tts-type-auto{flex:1 1 auto;min-width:0}}.app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-bg);overflow-x:hidden}.header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;padding:var(--spacing-lg) var(--spacing-xl);box-shadow:var(--shadow-md)}.header-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.version{font-size:.75rem;color:#ffffffb3;margin:4px 0 0;font-weight:400}.title-tip{font-size:.85rem;color:#fff;margin:4px 0 0;font-weight:400}.header-logo{height:3rem;width:auto;max-width:400px;object-fit:contain;display:block}.header-logo-container{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.header-logo-text{font-size:.875rem;font-weight:400;color:#ffffffe6;text-align:center;margin:0}.subtitle{font-size:.95rem;opacity:.9;font-weight:300;color:#ffffffd9}.main{flex:1;display:grid;grid-template-columns:320px 1fr;gap:var(--spacing-lg);max-width:1400px;width:100%;margin:0 auto;padding:var(--spacing-xl)}.filter-title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:600;color:var(--color-primary);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--color-accent)}.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:.95rem;font-family:Noto Sans SC,sans-serif;color:var(--color-text-primary);background-color:var(--color-bg-alt);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236B7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-md) center;background-size:16px}.results-meta{display:flex;gap:var(--spacing-lg)}.units-container{display:flex;flex-direction:column;gap:var(--spacing-lg)}.unit-card{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);overflow:hidden;transition:all .2s ease}.unit-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light)}.unit-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);color:#fff}.unit-title{font-family:Playfair Display,serif;font-size:1.25rem;font-weight:600}.unit-count{font-size:.875rem;font-weight:500;background:#fff3;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.words-display{padding:var(--spacing-lg);font-family:Noto Sans SC,sans-serif;font-size:1.125rem;line-height:2;color:var(--color-text-primary);background:var(--color-bg-alt)}.footer{text-align:center;padding:var(--spacing-lg);color:var(--color-text-muted);font-size:.875rem;border-top:1px solid var(--color-border);background:var(--color-bg-alt);margin-top:var(--spacing-xl)}.groups-display{display:flex;flex-direction:column;gap:var(--spacing-md)}.group-section{background:var(--color-bg-alt);border-radius:var(--radius-md);padding:var(--spacing-md);border:1px solid var(--color-border-light);transition:all .2s ease}.group-section:hover{background:var(--color-border-light);border-color:var(--color-primary-light)}.group-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-border-light)}.group-title{font-family:Playfair Display,serif;font-size:1.125rem;font-weight:600;color:var(--color-primary)}.group-count{font-size:.875rem;color:var(--color-text-muted);font-weight:500}.group-words{font-size:1rem;color:var(--color-text-primary);line-height:1.8;word-spacing:.5em;font-weight:400}.no-groups{padding:var(--spacing-lg);text-align:center;color:var(--color-text-muted);font-style:italic}@media (max-width: 1024px){.main{grid-template-columns:1fr}.sidebar{position:static}.title{font-size:1.75rem}}@media (max-width: 768px){.header{padding:var(--spacing-md) var(--spacing-lg)}.title{font-size:1.5rem}.subtitle{font-size:.875rem}.main{padding:var(--spacing-md)}.results-title{font-size:1.5rem}.unit-title{font-size:1.125rem}.words-display{font-size:1rem;padding:var(--spacing-md)}}.action-buttons-section{display:flex;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-lg) 0;border-bottom:2px solid var(--color-border-light);margin-bottom:var(--spacing-lg)}.action-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md)}.action-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.action-button:active:not(:disabled){transform:translateY(0)}.action-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.action-button .button-icon{width:24px;height:24px}.tts-config-section{background:var(--color-bg-alt);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.tts-section-title{font-size:1.3rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-lg) 0;padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-border)}.tts-config-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.tts-config-label{font-size:1rem;font-weight:500;color:var(--color-text-primary);flex:1}.tts-config-input{width:100px;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;font-weight:500;color:var(--color-text-primary);text-align:center;background:#fff;transition:all .3s ease}.tts-config-input:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed;opacity:.6}.tts-button .button-icon{width:20px;height:20px}.bimo-section{border-color:var(--color-primary);background:linear-gradient(135deg,#fff,#f0fdf4)}.choumo-section{border-color:var(--color-accent);background:linear-gradient(135deg,#fff,#fef3e2)}.bimo-section .section-title{color:var(--color-primary)}.choumo-section .section-title{color:var(--color-accent)}.words-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-sm)}.word-tag{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);background:var(--color-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all .3s ease;border:2px solid var(--color-border);position:relative;overflow:hidden}.word-tag:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.word-tag:before{content:attr(data-index);position:absolute;top:2px;right:6px;font-size:.6rem;color:var(--color-text-muted);font-weight:500}.bimo-tag{border-color:var(--color-primary);background:linear-gradient(135deg,#fff,#f0fdf4)}.bimo-tag:hover{border-color:var(--color-primary-dark);background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.choumo-tag{border-color:var(--color-accent);background:linear-gradient(135deg,#fff,#fef3e2)}.choumo-tag:hover{border-color:var(--color-accent-hover);background:linear-gradient(135deg,#fef3e2,#fed7aa)}.word-text{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);text-align:center;line-height:1.5;margin-bottom:var(--spacing-xs)}.word-pinyin{font-size:.875rem;font-weight:400;color:var(--color-text-secondary);text-align:center;line-height:1.3;margin-bottom:var(--spacing-xs);letter-spacing:.05em;font-family:PingFang SC,Microsoft YaHei,sans-serif}.word-unit{font-size:.75rem;color:var(--color-text-secondary);text-align:center;font-weight:500;opacity:.8}@media (max-width: 768px){.words-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--spacing-xs)}.word-text{font-size:1.125rem}.word-unit{font-size:.7rem}.section-title{font-size:1.25rem}}:root{--color-primary: #1A4D3E;--color-primary-light: #2D6B5A;--color-primary-dark: #0F352A;--color-bg: #FAF8F5;--color-bg-alt: #F5F3EF;--color-card: #FFFFFF;--color-accent: #E86A33;--color-accent-hover: #D95822;--color-text-primary: #1F2937;--color-text-secondary: #6B7280;--color-text-muted: #9CA3AF;--color-border: #E5E7EB;--color-border-light: #F3F4F6;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--color-bg);color:var(--color-text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-bg)}.header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;padding:var(--spacing-sm) 0;box-shadow:var(--shadow-md);z-index:100}.header-content{max-width:1440px;margin:0 auto;padding:0 var(--spacing-xl);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.header-logo-container{display:flex;flex-direction:column;align-items:flex-start;gap:2px;flex:0 0 auto}.header-tip-container{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-md);flex:1;text-align:center}.header-logo-container .title,.header-logo-container .subtitle{white-space:nowrap}.title{font-family:Playfair Display,serif;font-size:2rem;font-weight:700;letter-spacing:-.02em;margin:0;flex-shrink:0}.subtitle{font-size:.95rem;opacity:.9;font-weight:300;color:#ffffffd9;margin:0}.header-qr-container{display:flex;flex-direction:column;align-items:flex-start;gap:2px;flex:0 0 auto}.header-qr-image{width:65px;height:65px;object-fit:contain;border-radius:4px;background:#fff;padding:3px}.header-qr-text{font-size:.75rem;opacity:.9;font-weight:400;color:#ffffffd9;margin:0;text-align:left}.main{flex:1;display:grid;grid-template-columns:280px 1fr;gap:var(--spacing-lg);max-width:1440px;width:100%;margin:0 auto;padding:var(--spacing-xl)}.sidebar{position:sticky;top:calc(var(--spacing-xl) + 80px);height:fit-content}.filter-section{background:var(--color-card);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.filter-title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:600;color:var(--color-primary);margin-bottom:var(--spacing-lg);padding-left:12px;padding-bottom:var(--spacing-md);border-bottom:2px solid var(--color-accent)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:.05em}.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:.95rem;font-family:Noto Sans SC,sans-serif;color:var(--color-text-primary);background-color:var(--color-bg-alt);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236B7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-md) center;background-size:16px}.form-select:hover{border-color:var(--color-primary-light);background-color:#fff}.form-select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #e86a331a}.query-button{width:100%;padding:var(--spacing-md);font-size:1rem;font-weight:600;font-family:Noto Sans SC,sans-serif;color:#fff;background-color:var(--color-accent);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.query-button:hover:not(:disabled){background-color:var(--color-accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.query-button:active:not(:disabled){transform:translateY(0)}.query-button:disabled{background-color:var(--color-text-muted);cursor:not-allowed;opacity:.6}.reset-button{width:100%;padding:var(--spacing-md);font-size:1rem;font-weight:600;font-family:Noto Sans SC,sans-serif;color:var(--color-text-primary);background-color:var(--color-bg-alt);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;margin-top:var(--spacing-sm)}.reset-button:hover:not(:disabled){background-color:var(--color-border-light);border-color:var(--color-primary-light)}.reset-button:disabled{opacity:.6;cursor:not-allowed}.error-message{margin-top:var(--spacing-md);padding:var(--spacing-md);background-color:#fee2e2;border:1px solid #FECACA;border-radius:var(--radius-md);color:#dc2626;font-size:.875rem}.content{min-height:600px}.welcome-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:500px;text-align:center;color:var(--color-text-secondary)}.placeholder-icon{width:80px;height:80px;margin-bottom:var(--spacing-lg);color:var(--color-primary-light);opacity:.6}.placeholder-icon svg{width:100%;height:100%}.welcome-placeholder h3{font-family:Playfair Display,serif;font-size:1.75rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.welcome-placeholder p{font-size:1rem;color:var(--color-text-secondary)}.results-container{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.results-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-border)}.results-title{font-family:Playfair Display,serif;font-size:2rem;font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-md)}.results-meta{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;color:var(--color-text-secondary)}.meta-icon{width:18px;height:18px;color:var(--color-accent)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-lg)}.spinner{width:48px;height:48px;border:4px solid var(--color-border-light);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.loading-state p{font-size:1rem;color:var(--color-text-secondary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;color:var(--color-text-secondary)}.empty-icon{width:72px;height:72px;margin-bottom:var(--spacing-lg);color:var(--color-text-muted);opacity:.5}.empty-icon svg{width:100%;height:100%}.empty-state h3{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.empty-state p{font-size:1rem;color:var(--color-text-secondary)}.unit-checkboxes{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:300px;overflow-y:auto;padding-right:var(--spacing-sm)}.unit-checkboxes::-webkit-scrollbar{width:6px}.unit-checkboxes::-webkit-scrollbar-track{background:var(--color-bg-alt);border-radius:3px}.unit-checkboxes::-webkit-scrollbar-thumb{background:var(--color-primary-light);border-radius:3px}.unit-selection{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.unit-selection:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.unit-checkbox{background:linear-gradient(135deg,#fff,#f0fdf4);border:2px solid var(--color-primary);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);transition:all .3s ease}.unit-checkbox:hover{transform:translate(4px);box-shadow:var(--shadow-md)}.unit-checkbox input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-primary)}.choumo-mode-selector{background:linear-gradient(135deg,#fff7ed,#ffedd5);border:2px solid var(--color-accent);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.mode-checkbox{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);cursor:pointer;transition:all .2s ease}.mode-checkbox:hover{opacity:.9}.mode-checkbox input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-accent)}.mode-description{font-size:.875rem;color:var(--color-text-secondary);line-height:1.6;margin:0;padding-left:28px;font-style:italic}.group-checkboxes{display:flex;flex-direction:column;gap:var(--spacing-xs);padding-left:var(--spacing-lg);margin-top:var(--spacing-xs);border-left:2px solid var(--color-border-light)}.group-checkbox{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-xs) var(--spacing-sm);transition:all .2s ease}.group-checkbox:hover{background:var(--color-bg-alt);border-color:var(--color-primary-light)}.group-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary)}.group-checkbox .checkbox-text{font-size:.875rem;color:var(--color-text-secondary)}.group-disabled{cursor:not-allowed!important;background:#f5f5f5!important}.group-disabled .checkbox-text{color:#999}.group-disabled input[type=checkbox]{cursor:not-allowed}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-bg-alt);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;border:1px solid var(--color-border)}.checkbox-label:hover{background:var(--color-border-light);border-color:var(--color-primary-light)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.checkbox-text{font-size:.9rem;color:var(--color-text-primary);-webkit-user-select:none;user-select:none}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;font-family:Noto Sans SC,sans-serif;background:var(--color-card);color:var(--color-text-primary);transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1a4d3e1a}.button-group{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.generate-button{flex:1;padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-hover) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-sm)}.generate-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.generate-button:active:not(:disabled){transform:translateY(0)}.generate-button:disabled{opacity:.5;cursor:not-allowed}.reset-button{flex:1;padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-bg-alt);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.reset-button:hover{background:var(--color-border-light);border-color:var(--color-primary-light)}.results-content{min-height:400px}.generated-words{display:flex;flex-direction:column;gap:var(--spacing-xl)}.tts-config-section{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:16px;padding:var(--spacing-xl);margin-bottom:var(--spacing-xl);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.tts-section-title{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-lg) 0;padding-bottom:var(--spacing-md);border-bottom:2px solid #e2e8f0;display:flex;align-items:center;gap:var(--spacing-sm)}.tts-section-title:before{content:"";display:block;width:4px;height:24px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);border-radius:2px}.tts-config-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:#fff;border-radius:12px;border:1px solid #e2e8f0;transition:all .3s ease}.tts-config-row:hover{border-color:var(--color-primary-light);box-shadow:0 2px 8px #0000000d}.tts-config-label{font-size:1rem;font-weight:600;color:#475569;flex:1;display:flex;align-items:center}.tts-config-input-wrapper{flex:0 0 auto}.tts-small-input{width:80px!important}.tts-config-input{width:180px;padding:.6rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;font-weight:600;color:#1e293b;text-align:center;background:#fff;transition:all .3s ease;cursor:pointer}.tts-config-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1a4d3e1a}.tts-config-input:hover:not(:disabled){border-color:var(--color-primary-light);transform:translateY(-1px)}.tts-config-input:disabled{background-color:#f8fafc;color:#94a3b8;cursor:not-allowed;opacity:.6;transform:none}.tts-config-row-three{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}.tts-config-item{display:flex;align-items:center;gap:8px;padding:12px 14px;background:linear-gradient(135deg,#fafbfc,#f5f7fa);border-radius:10px;border:1px solid #e8ecf1;transition:all .25s ease}.tts-config-item:hover{background:linear-gradient(135deg,#fff,#f8fafb);border-color:var(--color-primary-light);box-shadow:0 2px 8px #1a4d3e14}.tts-config-small-label{font-size:.85rem;font-weight:600;color:#4a5568;white-space:nowrap;letter-spacing:.02em}.tts-config-small-input{width:56px;padding:8px 10px;border:2px solid #d1d5db;border-radius:8px;font-size:.9rem;font-weight:700;color:#1e293b;text-align:center;background:#fff;transition:all .25s ease;-moz-appearance:textfield}.tts-config-small-input::-webkit-outer-spin-button,.tts-config-small-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.tts-config-small-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1a4d3e1f;background:#fafcfa}.tts-config-small-input:hover:not(:disabled){border-color:var(--color-primary-light);background:#fefefe}.tts-config-small-input:disabled{background-color:#f1f5f9;color:#94a3b8;cursor:not-allowed;opacity:.6}.tts-config-unit{font-size:.8rem;font-weight:500;color:#6b7280;min-width:20px}.tts-type-tabs{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-sm);background:#fff;border-radius:12px;border:2px solid #e2e8f0;box-shadow:0 2px 4px #0000000d}.tts-tab{flex:1;padding:1rem 1.5rem;border:none;border-radius:10px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#64748b;box-shadow:0 2px 4px #0000000d;text-transform:uppercase;letter-spacing:.05em}.tts-tab:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:currentColor;opacity:0;transition:opacity .3s ease}.tts-tab:hover:not(.active){transform:translateY(-3px);color:#475569;box-shadow:0 4px 12px #0000001a}.tts-tab.active{color:#fff!important;transform:translateY(-3px) scale(1.02);box-shadow:0 8px 20px #00000026}.tts-tab.active:before{opacity:0}.tts-tab-word.active{background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 8px 20px #3b82f666;color:#fff!important}.tts-tab-phrase.active{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 8px 20px #10b98166;color:#fff!important}.tts-tab-sentence.active{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 8px 20px #f59e0b66;color:#fff!important}.tts-tab:active:not(.active){transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.tts-type-order{margin-bottom:var(--spacing-xl)}.tts-type-order-selectors{display:flex;flex-direction:column;gap:var(--spacing-md)}.tts-type-order-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#fff;border-radius:10px;border:2px solid #e2e8f0;transition:all .3s ease}.tts-type-order-item:hover{border-color:var(--color-primary-light);box-shadow:0 2px 8px #0000000d}.tts-type-order-item span:first-child{font-size:.95rem;font-weight:600;color:#64748b;min-width:60px}.tts-type-select{flex:0 0 140px;padding:.6rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;font-weight:600;color:#1e293b;background:#fff;transition:all .3s ease;cursor:pointer}.tts-type-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1a4d3e1a}.tts-type-select:hover:not(:disabled){border-color:var(--color-primary-light);transform:translateY(-1px)}.tts-type-select:disabled{background-color:#f8fafc;color:#94a3b8;cursor:not-allowed;opacity:.6;transform:none}.tts-type-auto{flex:1;padding:.6rem 1rem;background:#f8fafc;border-radius:8px;font-size:.95rem;font-weight:600;color:#94a3b8;text-align:center}.tts-example{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);margin-bottom:var(--spacing-xl);background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:12px;box-shadow:0 2px 8px #fbbf2433}.tts-example-label{font-size:.95rem;font-weight:700;color:#92400e;white-space:nowrap}.tts-example-text{flex:1;font-size:.95rem;font-weight:600;color:#78350f;background:#fff;padding:.5rem 1rem;border-radius:8px;border:1px solid #fbbf24;word-break:break-all}.tts-controls{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:2px solid var(--color-border)}.tts-button{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;padding:var(--spacing-md) var(--spacing-lg);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md)}.tts-button .button-icon{width:24px;height:24px}.tts-start-button{background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-hover) 100%);color:#fff}.tts-start-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.tts-start-button.playing{background:linear-gradient(135deg,#f59e0b,#d97706)}.tts-start-button.paused{background:linear-gradient(135deg,#10b981,#059669)}.tts-stop-button{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.tts-stop-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.tts-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.current-word-display{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-card);border:2px solid var(--color-primary);border-radius:var(--radius-md)}.current-word-label{font-size:1rem;font-weight:500;color:var(--color-text-secondary)}.current-word-text{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.tts-progress{margin-top:var(--spacing-md)}.progress-bar{width:100%;height:8px;background:var(--color-border);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:var(--spacing-sm)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-accent) 100%);transition:width .3s ease}.progress-text{text-align:center;font-size:.9rem;font-weight:500;color:var(--color-text-secondary)}.words-display-container{display:flex;flex-direction:column;gap:var(--spacing-lg)}.word-section{background:var(--color-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:2px solid var(--color-border);transition:all .3s ease}.word-section:hover{box-shadow:var(--shadow-md)}.section-title{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-md);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--spacing-sm)}.section-title:before{content:"";display:block;width:4px;height:24px;background:currentColor;border-radius:2px}.words-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-sm)}.word-tag{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);background:var(--color-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all .3s ease;border:2px solid var(--color-border);position:relative;overflow:hidden;cursor:pointer}.word-tag:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary-light)}.word-en{font-size:1.1rem;font-weight:600;color:var(--color-text-primary);text-align:center;line-height:1.4;margin-bottom:var(--spacing-xs);font-family:JetBrains Mono,monospace}.word-cn{font-size:.875rem;font-weight:400;color:var(--color-text-secondary);text-align:center;line-height:1.3;margin-bottom:var(--spacing-xs)}.word-unit{font-size:.75rem;color:var(--color-text-muted);text-align:center;font-weight:500;opacity:.8}.sentences-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.sentence-item{display:flex;flex-direction:column;background:var(--color-card);padding:var(--spacing-md);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all .2s ease;border:1px solid var(--color-border);cursor:pointer}.sentence-item:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light)}.sentence-item .word-en{font-size:1rem;line-height:1.6;color:var(--color-text-primary);font-weight:500;word-wrap:break-word;overflow-wrap:break-word;margin-bottom:var(--spacing-xs)}.sentence-item .word-cn{font-size:.875rem;line-height:1.6;color:var(--color-text-secondary);word-wrap:break-word;overflow-wrap:break-word;margin-top:var(--spacing-xs)}.sentence-item .word-unit{font-size:.75rem;color:var(--color-text-muted);font-weight:500;opacity:.8;margin-top:var(--spacing-xs)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.word-tag{animation:fadeInUp .3s ease-out}.word-tag:nth-child(1){animation-delay:.05s}.word-tag:nth-child(2){animation-delay:.1s}.word-tag:nth-child(3){animation-delay:.15s}.word-tag:nth-child(4){animation-delay:.2s}.word-tag:nth-child(5){animation-delay:.25s}.word-replayable{cursor:pointer!important;position:relative}.word-replayable:hover{transform:translateY(-3px)!important;box-shadow:0 8px 16px #00000026!important;border-color:var(--color-accent)!important}.word-replayable:active{transform:translateY(-1px)!important}.word-speaker-icon{position:absolute;top:4px;left:6px;font-size:.65rem;opacity:0;transition:opacity .2s ease}.word-replayable:hover .word-speaker-icon{opacity:1}.word-playing{animation:wordPulse .6s ease-in-out!important;border-color:var(--color-accent)!important;box-shadow:0 0 0 3px #e86a3333!important}@keyframes wordPulse{0%{transform:scale(1)}30%{transform:scale(1.06)}60%{transform:scale(.98)}to{transform:scale(1)}}.wrong-word-controls{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-md);justify-content:center}.wrong-word-btn{padding:var(--spacing-sm) var(--spacing-xl);border:2px solid var(--color-accent);border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;background:#fff;color:var(--color-accent)}.wrong-word-btn:hover{background:var(--color-accent);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}.retry-wrong-btn{padding:var(--spacing-sm) var(--spacing-xl);border:2px solid var(--color-primary);border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff}.retry-wrong-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.retry-wrong-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;background:var(--color-text-muted);border-color:var(--color-text-muted)}.word-tag.wrong-selected,.sentence-item.wrong-selected{background:linear-gradient(135deg,#fee2e2,#fecaca)!important;border-color:#ef4444!important;box-shadow:0 0 0 3px #ef444433!important}.word-tag.wrong-selected:hover,.sentence-item.wrong-selected:hover{background:linear-gradient(135deg,#fecaca,#fca5a5)!important;transform:translateY(-3px)!important}.wrong-word-icon{position:absolute;top:4px;left:6px;font-size:.7rem;color:#ef4444;font-weight:700}.sentence-item .wrong-word-icon{position:absolute;top:4px;left:6px}.sentence-item{position:relative}@media (max-width: 1024px){.main{grid-template-columns:1fr}.sidebar{position:static}.title{font-size:1.75rem}.header-content{flex-direction:row}}@media (max-width: 768px){.header{padding:var(--spacing-md) var(--spacing-lg)}.header-content{flex-direction:column;text-align:center}.title{font-size:1.5rem}.subtitle{font-size:.875rem}.header-qr-container{margin-top:var(--spacing-sm)}.header-qr-image{width:70px;height:70px}.header-qr-text{font-size:.7rem}.main{padding:var(--spacing-md)}.results-title{font-size:1.5rem}.unit-title{font-size:1.125rem}.words-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-xs)}.word-text{font-size:1.125rem}.word-unit{font-size:.7rem}.section-title{font-size:1.25rem}.tts-controls{flex-direction:column}.tts-config-row{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.tts-config-row-three{grid-template-columns:1fr;gap:var(--spacing-sm)}.tts-config-item{padding:10px 12px}}@media (max-width: 480px){.results-meta{flex-direction:column;gap:var(--spacing-sm)}.unit-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}.tongji-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:24px}.tongji-auth-card{max-width:380px;margin:120px auto 0;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:40px 32px;text-align:center;box-shadow:0 20px 60px #00000026}.tongji-auth-title{font-size:24px;font-weight:700;color:#2d3748;margin:0 0 8px}.tongji-auth-desc{color:#718096;margin:0 0 24px;font-size:14px}.tongji-auth-input{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:16px;outline:none;transition:border-color .2s;box-sizing:border-box}.tongji-auth-input:focus{border-color:#667eea}.tongji-auth-error{color:#e53e3e;font-size:13px;margin-top:8px}.tongji-auth-btn{width:100%;margin-top:16px;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .1s,box-shadow .2s}.tongji-auth-btn:hover{transform:translateY(-1px);box-shadow:0 4px 15px #667eea66}.tongji-auth-btn:active{transform:translateY(0)}.tongji-header{max-width:1100px;margin:0 auto 24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.tongji-title{color:#fff;font-size:28px;font-weight:700;margin:0}.tongji-controls{display:flex;gap:8px;align-items:center}.tongji-select{padding:8px 12px;border:none;border-radius:8px;font-size:14px;background:#ffffffe6;cursor:pointer;outline:none}.tongji-refresh-btn{padding:8px 16px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:8px;font-size:14px;cursor:pointer;transition:background .2s}.tongji-refresh-btn:hover{background:#ffffff4d}.tongji-refresh-btn:disabled{opacity:.6;cursor:not-allowed}.tongji-records-btn{padding:8px 16px;background:#ffffffe6;color:#667eea;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.tongji-records-btn:hover{background:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.tongji-cards{max-width:1100px;margin:0 auto 24px;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.tongji-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:14px;padding:20px 16px;text-align:center;box-shadow:0 4px 15px #00000014}.tongji-card-label{font-size:13px;color:#718096;margin-bottom:8px}.tongji-card-value{font-size:28px;font-weight:700}.tongji-card-today .tongji-card-value{color:#667eea}.tongji-card-kousuan .tongji-card-value{color:#e53e3e}.tongji-card-kousuan-grade .tongji-card-value{color:#e67e22}.tongji-card-pdftts .tongji-card-value{color:#3182ce}.tongji-card-ttsen .tongji-card-value{color:#38a169}.tongji-card-essay-grade .tongji-card-value{color:#7c3aed}.tongji-card-users .tongji-card-value{color:#d69e2e}.tongji-section{max-width:1100px;margin:0 auto;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:24px;box-shadow:0 4px 15px #00000014}.tongji-section-title{font-size:18px;font-weight:600;color:#2d3748;margin:0 0 16px;display:flex;align-items:baseline;gap:8px}.tongji-section-sub{font-size:13px;font-weight:400;color:#a0aec0}.tongji-table-wrap{overflow-x:auto}.tongji-table{width:100%;border-collapse:collapse;font-size:14px}.tongji-table th{background:#f7fafc;padding:10px 14px;text-align:left;font-weight:600;color:#4a5568;border-bottom:2px solid #e2e8f0;white-space:nowrap}.tongji-table td{padding:10px 14px;border-bottom:1px solid #edf2f7;color:#2d3748}.tongji-table tr:hover td{background:#f7fafc}.tongji-badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:13px;font-weight:500}.tongji-badge-kousuan{background:#fed7d7;color:#c53030}.tongji-badge-kousuan-grade{background:#feebc8;color:#c05621}.tongji-badge-pdftts{background:#bee3f8;color:#2b6cb0}.tongji-badge-ttsen{background:#c6f6d5;color:#276749}.tongji-badge-essay-grade{background:#e9d8fd;color:#6b46c1}.tongji-user-id{font-family:Courier New,monospace;font-size:12px;color:#718096}.tongji-time{font-size:12px;color:#a0aec0;white-space:nowrap}.tongji-empty{text-align:center;padding:40px;color:#a0aec0;font-size:15px}.tongji-loading{text-align:center;padding:40px;color:#718096;font-size:15px}.tongji-records-list{display:flex;flex-direction:column;gap:12px}.tongji-record-item{background:#f7fafc;border-radius:12px;padding:14px 16px;display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:start;border:1px solid #edf2f7;transition:all .2s}.tongji-record-item:hover{background:#edf2f7;border-color:#e2e8f0;transform:translate(2px)}.tongji-record-time{font-family:Courier New,monospace;font-size:12px;color:#4a5568;font-weight:600;white-space:nowrap}.tongji-record-user,.tongji-record-action,.tongji-record-detail{font-size:13px;display:flex;flex-direction:column;gap:2px}.tongji-record-label{font-size:11px;color:#a0aec0;text-transform:uppercase;letter-spacing:.5px}.tongji-record-value{color:#2d3748;font-weight:500}.tongji-record-module{justify-self:end}.tongji-record-detail{grid-column:1 / -1;padding-top:8px;border-top:1px solid #e2e8f0;margin-top:4px}.tongji-record-alias{display:flex;gap:4px;align-items:center;margin-top:4px}.tongji-alias-label{font-size:11px;color:#a0aec0;text-transform:uppercase;letter-spacing:.5px}.tongji-alias-value{font-size:13px;color:#d69e2e;font-weight:600}.tongji-alias-btn{margin-top:4px;padding:4px 10px;background:#d69e2e1a;color:#d69e2e;border:1px solid rgba(214,158,46,.3);border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s}.tongji-alias-btn:hover{background:#d69e2e33;border-color:#d69e2e80}.tongji-alias-edit{margin-top:8px;display:flex;flex-direction:column;gap:6px}.tongji-alias-input{padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;outline:none;transition:border-color .2s}.tongji-alias-input:focus{border-color:#d69e2e}.tongji-alias-actions{display:flex;gap:6px}.tongji-alias-save,.tongji-alias-delete,.tongji-alias-cancel{padding:4px 12px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s}.tongji-alias-save{background:#d69e2e;color:#fff;border:none}.tongji-alias-save:hover{background:#b7791f}.tongji-alias-delete{background:#e53e3e;color:#fff;border:none}.tongji-alias-delete:hover{background:#c53030}.tongji-alias-cancel{background:#e2e8f0;color:#4a5568;border:1px solid #cbd5e0}.tongji-alias-cancel:hover{background:#cbd5e0}@media (max-width: 640px){.tongji-record-item{grid-template-columns:1fr;gap:8px}.tongji-record-module{justify-self:start}}@media (max-width: 640px){.tongji-container{padding:12px}.tongji-header{flex-direction:column;align-items:flex-start}.tongji-title{font-size:22px}.tongji-cards{grid-template-columns:repeat(2,1fr)}.tongji-section{padding:16px}.tongji-table th,.tongji-table td{padding:8px 10px;font-size:12px}}.essay-container{min-height:100vh;background:linear-gradient(135deg,#f5f0ff,#e8d8ff,#d4b8ff);font-family:Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.essay-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(124,58,237,.15);position:sticky;top:0;z-index:100}.essay-back-btn{display:flex;align-items:center;gap:4px;padding:8px 12px;border:none;background:transparent;color:#666;font-size:14px;cursor:pointer;border-radius:8px;transition:all .2s;font-family:inherit}.essay-back-btn:hover{background:#7c3aed1a;color:#7c3aed}.essay-title{font-size:1.1rem;font-weight:700;color:#2c3e50}.essay-header-spacer{width:72px}.essay-content{padding:20px;max-width:600px;margin:0 auto}.essay-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh}.essay-upload-area{background:#fff;border-radius:20px;padding:40px 24px;text-align:center;box-shadow:0 4px 20px #7c3aed1a;border:2px dashed rgba(124,58,237,.3);margin-bottom:20px}.essay-upload-icon{width:80px;height:80px;margin:0 auto 16px;background:linear-gradient(135deg,#f5f0ff,#e8d8ff);border-radius:50%;display:flex;align-items:center;justify-content:center}.essay-upload-text{font-size:1rem;color:#666;margin-bottom:24px}.essay-upload-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.essay-upload-btn{display:flex;align-items:center;gap:8px;padding:14px 24px;border:none;border-radius:14px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;font-family:inherit}.essay-upload-btn-camera{background:linear-gradient(135deg,#a78bfa,#7c3aed);color:#fff;box-shadow:0 4px 15px #7c3aed66}.essay-upload-btn-camera:hover{transform:translateY(-2px);box-shadow:0 6px 20px #7c3aed80}.essay-upload-btn-file{background:linear-gradient(135deg,#818cf8,#6366f1);color:#fff;box-shadow:0 4px 15px #6366f166}.essay-upload-btn-file:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f180}.essay-hidden-input{display:none}.essay-tips{background:#fff;border-radius:16px;padding:20px 24px;box-shadow:0 2px 12px #0000000f}.essay-tips-title{font-size:1rem;font-weight:700;color:#2c3e50;margin-bottom:12px}.essay-tips-list{list-style:none;padding:0;margin:0;counter-reset:step}.essay-tips-list li{counter-increment:step;padding:8px 0 8px 32px;position:relative;font-size:.9rem;color:#555;line-height:1.6}.essay-tips-list li:before{content:counter(step);position:absolute;left:0;top:8px;width:22px;height:22px;background:linear-gradient(135deg,#a78bfa,#7c3aed);color:#fff;border-radius:50%;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center}.essay-tips-note{margin-top:12px;padding:10px 14px;background:#f9f5ff;border-radius:10px;font-size:.8rem;color:#7c3aed}.essay-preview-list{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}.essay-preview-thumb{position:relative;width:100px;height:130px;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #0000001a}.essay-preview-thumb img{width:100%;height:100%;object-fit:cover}.essay-preview-page{position:absolute;bottom:4px;left:4px;background:#0009;color:#fff;font-size:.7rem;padding:2px 6px;border-radius:4px}.essay-preview-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;background:#ef4444e6;color:#fff;border:none;border-radius:50%;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.essay-preview-remove:hover{background:#ef4444;transform:scale(1.1)}.essay-preview-add{width:100px;height:130px;border:2px dashed rgba(124,58,237,.4);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:#7c3aed;background:#7c3aed0d;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s;font-family:inherit}.essay-preview-add:hover{background:#7c3aed1a;border-color:#7c3aed}.essay-option-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid #f0f0f0}.essay-option-label{font-size:.95rem;font-weight:600;color:#2c3e50}.essay-grade-dropdown{position:relative;display:flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;font-size:.9rem;font-weight:600;color:#2c3e50;min-width:100px;justify-content:space-between}.essay-grade-menu{position:absolute;top:100%;left:0;right:0;margin-top:6px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 6px 20px #0000001f;z-index:50;overflow:hidden}.essay-grade-item{padding:10px 14px;font-size:.9rem;cursor:pointer;transition:all .15s;color:#333}.essay-grade-item:hover{background:#f5f0ff;color:#7c3aed}.essay-grade-item.active{background:#f5f0ff;color:#7c3aed;font-weight:600}.essay-preview-actions{display:flex;gap:12px;margin-top:16px}.essay-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border:none;border-radius:14px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;flex:1;font-family:inherit}.essay-btn:disabled{opacity:.5;cursor:not-allowed}.essay-btn-primary{background:linear-gradient(135deg,#a78bfa,#7c3aed);color:#fff;box-shadow:0 4px 15px #7c3aed66}.essay-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #7c3aed80}.essay-btn-secondary{background:#fff;color:#666;border:2px solid #e5e7eb}.essay-btn-secondary:hover{border-color:#a78bfa;color:#7c3aed}.essay-btn-enhance{background:linear-gradient(135deg,#34d399,#059669);color:#fff;box-shadow:0 4px 15px #05966966;padding:16px 28px;font-size:1.05rem;width:100%}.essay-btn-enhance:hover{transform:translateY(-2px);box-shadow:0 6px 20px #05966980}.essay-enhance-section{margin:20px 0;text-align:center}.essay-enhance-desc{font-size:.8rem;color:#999;margin-top:8px}.essay-loading-spinner{margin-bottom:16px}.essay-loading-text{font-size:1.1rem;font-weight:600;color:#2c3e50;margin-bottom:8px}.essay-loading-subtext{font-size:.85rem;color:#999}.essay-thumbs-section{background:#fff;border-radius:16px;padding:16px;box-shadow:0 4px 20px #7c3aed1a;margin-bottom:16px}.essay-thumbs-row{display:flex;gap:10px;margin-bottom:12px;flex-wrap:wrap}.essay-thumb-item{position:relative;width:80px;height:105px;border-radius:10px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .2s}.essay-thumb-item.active{border-color:#7c3aed;box-shadow:0 2px 10px #7c3aed4d}.essay-thumb-item img{width:100%;height:100%;object-fit:cover}.essay-thumb-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#0009);color:#fff;font-size:.65rem;text-align:center;padding:8px 0 3px}.essay-thumb-zoom{position:absolute;top:4px;right:4px;width:22px;height:22px;background:#00000080;color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.essay-thumb-item:hover .essay-thumb-zoom{opacity:1}.essay-thumb-preview{border-radius:10px;overflow:hidden;background:#f9f9f9}.essay-thumb-preview img{width:100%;display:block}.essay-zoom-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.essay-zoom-content{position:relative;max-width:100%;max-height:100%}.essay-zoom-content img{max-width:100%;max-height:85vh;border-radius:12px;box-shadow:0 8px 40px #0006}.essay-zoom-close{position:absolute;top:-12px;right:-12px;width:36px;height:36px;background:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #0000004d}.essay-annotated-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 4px 20px #7c3aed1a;margin-bottom:16px}.essay-annotated-legend{display:flex;gap:14px;margin-bottom:14px;flex-wrap:wrap}.essay-legend-item{display:flex;align-items:center;gap:5px;font-size:.78rem;font-weight:600;padding:3px 8px;border-radius:6px}.essay-legend-error{background:#fef2f2;color:#ef4444}.essay-legend-error:before{content:"";width:10px;height:3px;background:#ef4444;border-radius:2px;text-decoration:line-through}.essay-legend-grammar{background:#fff7ed;color:#f97316}.essay-legend-grammar:before{content:"";width:10px;height:10px;border:2px solid #f97316;border-radius:2px}.essay-legend-good{background:#f0fdf4;color:#22c55e}.essay-legend-good:before{content:"";width:10px;height:3px;background:#22c55e;border-radius:2px}.essay-annotated-body{font-size:1rem;line-height:2.2;color:#333}.essay-annotated-line{text-indent:2em;min-height:1.4em}.essay-annotated-blank{height:1em}.essay-mark-wrapper{position:relative;display:inline}.essay-mark{cursor:pointer;border-radius:2px;transition:all .15s;padding:0 1px}.essay-mark:hover{filter:brightness(.95)}.essay-mark-error{background:#ef444426;text-decoration:underline wavy #ef4444;text-decoration-thickness:2px;text-underline-offset:4px;color:#dc2626;font-weight:600}.essay-mark-grammar{background:#f973161f;border-bottom:2px solid #f97316;padding-bottom:1px}.essay-mark-good{background:#22c55e1a;border-bottom:2px solid #22c55e;color:#16a34a}.essay-mark-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#1e293b;color:#fff;font-size:.8rem;font-weight:500;padding:6px 12px;border-radius:8px;white-space:nowrap;z-index:60;pointer-events:none;box-shadow:0 4px 15px #00000040;max-width:280px;white-space:normal;text-indent:0;line-height:1.5}.essay-mark-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1e293b}.essay-result-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 4px 20px #7c3aed1a;margin-bottom:16px}.essay-result-title{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:700;color:#2c3e50;margin-bottom:12px}.essay-result-image-wrapper{background:#f9f9f9;border-radius:10px;overflow:hidden}.essay-result-image{width:100%;display:block}.essay-result-actions{display:flex;gap:12px;margin:16px 0}.essay-text-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 12px #0000000f;margin-bottom:16px}.essay-text-content{font-size:.95rem;line-height:1.8;color:#333;white-space:pre-wrap}.essay-text-content p{margin:0;text-indent:2em}.essay-score-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 20px #7c3aed1a;margin-bottom:16px}.essay-score-main{text-align:center;margin-bottom:16px}.essay-score-total{font-size:3rem;font-weight:800;color:#7c3aed;line-height:1}.essay-score-max{font-size:1.2rem;color:#bbb;font-weight:400}.essay-score-details{display:flex;flex-direction:column;gap:10px}.essay-score-item{display:flex;align-items:center;gap:10px}.essay-score-item-label{width:36px;font-size:.85rem;color:#666;font-weight:600;text-align:right;flex-shrink:0}.essay-score-bar-bg{flex:1;height:10px;background:#f0f0f0;border-radius:5px;overflow:hidden}.essay-score-bar{height:100%;background:linear-gradient(90deg,#a78bfa,#7c3aed);border-radius:5px;transition:width .8s ease-out}.essay-score-item-value{width:36px;font-size:.85rem;color:#7c3aed;font-weight:700;flex-shrink:0}.essay-comment-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 12px #0000000f;margin-bottom:16px}.essay-comment-text{font-size:.95rem;line-height:1.8;color:#444}.essay-errors-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 4px 20px #ef44441a;margin-bottom:16px}.essay-errors-table{border:1px solid #f0f0f0;border-radius:10px;overflow:hidden}.essay-errors-header{display:grid;grid-template-columns:1fr 1fr auto;background:#fff5f5;padding:10px 14px;font-size:.85rem;font-weight:600;color:#999}.essay-errors-row{display:grid;grid-template-columns:1fr 1fr auto;padding:10px 14px;border-top:1px solid #f5f5f5;font-size:.9rem}.essay-errors-original{color:#ef4444;text-decoration:line-through}.essay-errors-correct{color:#22c55e;font-weight:600}.essay-errors-type{color:#999;font-size:.8rem;padding:2px 8px;background:#f5f5f5;border-radius:4px}.essay-good-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 4px 20px #22c55e1a;margin-bottom:16px}.essay-good-item{padding:12px 0;border-bottom:1px solid #f0f0f0}.essay-good-item:last-child{border-bottom:none}.essay-good-sentence{font-size:.95rem;color:#22c55e;font-weight:600;font-style:italic;margin-bottom:4px}.essay-good-comment{font-size:.85rem;color:#888}.essay-suggestions-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 12px #0000000f;margin-bottom:16px}.essay-suggestions-list{list-style:none;padding:0;margin:0;counter-reset:suggestion}.essay-suggestions-list li{counter-increment:suggestion;padding:8px 0 8px 32px;position:relative;font-size:.9rem;color:#555;line-height:1.6}.essay-suggestions-list li:before{content:counter(suggestion);position:absolute;left:0;top:8px;width:22px;height:22px;background:linear-gradient(135deg,#34d399,#059669);color:#fff;border-radius:50%;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center}.essay-reference-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 4px 20px #7c3aed1a;margin-bottom:16px}.essay-reference-note{font-size:.8rem;color:#7c3aed;margin-bottom:12px;padding:6px 10px;background:#f5f0ff;border-radius:6px;display:inline-block}.essay-reference-text{font-size:.95rem;line-height:1.8;color:#333;white-space:pre-wrap}.essay-reference-text p{margin:0;text-indent:2em}.essay-enhance-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:30px 0;color:#7c3aed;font-weight:600}@media (max-width: 480px){.essay-content{padding:16px}.essay-upload-area{padding:30px 20px}.essay-upload-buttons{flex-direction:column}.essay-preview-list{justify-content:center}.essay-result-actions{flex-direction:column}.essay-score-total{font-size:2.5rem}.essay-thumbs-row{justify-content:center}.essay-annotated-body{font-size:.92rem;line-height:2}.essay-mark-tooltip{max-width:220px}}/*! tailwindcss v4.2.4 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-500:oklch(63.7% .237 25.331);--color-green-500:oklch(72.3% .219 149.579);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-800:oklch(27.8% .033 256.848);--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-xl:36rem;--container-2xl:42rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-2xl:1rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--ease-out:cubic-bezier(0, 0, .2, 1);--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.fixed{position:fixed}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.flex{display:flex}.grid{display:grid}.inline-flex{display:inline-flex}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-10{height:calc(var(--spacing) * 10)}.h-12{height:calc(var(--spacing) * 12)}.h-16{height:calc(var(--spacing) * 16)}.min-h-screen{min-height:100vh}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-8{width:calc(var(--spacing) * 8)}.w-12{width:calc(var(--spacing) * 12)}.w-16{width:calc(var(--spacing) * 16)}.w-full{width:100%}.max-w-md{max-width:var(--container-md)}.max-w-xl{max-width:var(--container-xl)}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-\[\#FF6B35\]{border-color:#ff6b35}.bg-white{background-color:var(--color-white)}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-\[\#FF6B35\]{--tw-gradient-from:#ff6b35;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-\[\#FFF8E7\]{--tw-gradient-from:#fff8e7;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.via-\[\#FFE5D0\]{--tw-gradient-via:#ffe5d0;--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.to-\[\#F7931E\]{--tw-gradient-to:#f7931e;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-\[\#FFD8C9\]{--tw-gradient-to:#ffd8c9;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-2{padding-block:calc(var(--spacing) * 2)}.pt-0{padding-top:calc(var(--spacing) * 0)}.text-center{text-align:center}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-none{--tw-leading:1;line-height:1}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-\[\#2C3E50\]{color:#2c3e50}.text-\[\#7F8C8D\]{color:#7f8c8d}.text-\[\#7c3aed\]{color:#7c3aed}.text-\[\#95A5A6\]{color:#95a5a6}.text-\[\#FF6B35\]{color:#ff6b35}.text-\[\#FF8C42\]{color:#ff8c42}.text-gray-600{color:var(--color-gray-600)}.text-green-500{color:var(--color-green-500)}.text-red-500{color:var(--color-red-500)}.text-white{color:var(--color-white)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled~*){cursor:not-allowed}.peer-disabled\:opacity-70:is(:where(.peer):disabled~*){opacity:.7}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}@media (hover:hover){.hover\:bg-white\/50:hover{background-color:#ffffff80}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/50:hover{background-color:color-mix(in oklab,var(--color-white) 50%,transparent)}}.hover\:text-gray-800:hover{color:var(--color-gray-800)}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-offset-0:focus{--tw-ring-offset-width:0px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width:40rem){.sm\:max-w-2xl{max-width:var(--container-2xl)}.sm\:p-4{padding:calc(var(--spacing) * 4)}.sm\:p-6{padding:calc(var(--spacing) * 6)}}}*{box-sizing:border-box;margin:0;padding:0}html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root{min-height:100vh}body{background:linear-gradient(135deg,#fff8e7,#ffe5d0,#ffd8c9)}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}:root{--primary-orange: #FF6B35;--primary-orange-light: #FF8A5B;--primary-orange-dark: #E55A2B;--bg-cream: #FFF5EB;--bg-light: #FFEFE4;--bg-white: #FFFFFF;--text-primary: #333333;--text-secondary: #666666;--text-muted: #999999;--border-orange: #FF6B35;--border-light: #FFD4C4;--shadow-sm: 0 2px 4px rgba(255, 107, 53, .1);--shadow-md: 0 4px 12px rgba(255, 107, 53, .15);--shadow-lg: 0 8px 24px rgba(255, 107, 53, .2)}.app-container{min-height:100vh;padding:20px;display:flex;justify-content:center;align-items:flex-start}.main-card{background:var(--bg-cream);border-radius:24px;box-shadow:var(--shadow-lg);width:100%;max-width:800px;overflow:hidden;border:2px solid var(--border-light)}.header-section{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 24px 16px}.header-left{display:flex;align-items:center;gap:12px}.header-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--primary-orange) 0%,var(--primary-orange-light) 100%);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;box-shadow:var(--shadow-md)}.header-title{font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.header-right{text-align:center}.logo-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.logo-img{width:80px;height:80px;border-radius:8px;object-fit:contain;border:1px solid var(--border-light);background:#fff;box-shadow:var(--shadow-sm)}.logo-text{font-size:12px;color:var(--text-muted);text-align:center;font-weight:500;line-height:1.2}.content-section{padding:0 24px 24px}.form-group{margin-bottom:24px}.form-row{display:flex;gap:20px;margin-bottom:24px}.form-col{flex:1}.form-label{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:12px;display:block}.input-wrapper{display:flex;align-items:center;gap:12px}.custom-input{width:120px;height:44px;padding:0 16px;border:2px solid var(--border-orange);border-radius:10px;font-size:16px;font-weight:600;color:var(--text-primary);background:var(--bg-white);outline:none;transition:all .2s}.custom-input:focus{box-shadow:0 0 0 3px #ff6b3533}.input-hint{font-size:14px;color:var(--text-muted)}.operation-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.operation-item{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:var(--bg-white);border:2px solid var(--border-orange);border-radius:10px;cursor:pointer;transition:all .2s}.operation-item:hover,.operation-item.checked{background:var(--bg-light)}.custom-checkbox{width:20px;height:20px;border:2px solid var(--border-orange);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.custom-checkbox.checked{background:var(--primary-orange);border-color:var(--primary-orange)}.custom-checkbox svg{width:14px;height:14px;color:#fff;opacity:0}.custom-checkbox.checked svg{opacity:1}.operation-label{font-size:16px;font-weight:500;color:var(--text-primary)}.radio-group{display:flex;flex-direction:column;gap:12px}.radio-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-white);border:2px solid var(--border-orange);border-radius:10px;cursor:pointer;transition:all .2s}.radio-item:hover{background:var(--bg-light)}.custom-radio{width:20px;height:20px;border:2px solid var(--border-orange);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.custom-radio.checked{border-color:var(--primary-orange)}.custom-radio-inner{width:10px;height:10px;background:var(--primary-orange);border-radius:50%;opacity:0;transition:all .2s}.custom-radio.checked .custom-radio-inner{opacity:1}.radio-label{font-size:16px;font-weight:500;color:var(--text-primary)}.range-options-row{display:flex;gap:24px;align-items:flex-start;margin-bottom:24px}.range-input-wrapper{flex:1}.range-input-container{display:flex;flex-direction:column;gap:4px}.range-input{width:100%;height:44px;padding:0 16px;border:2px solid var(--border-orange);border-radius:10px;font-size:16px;font-weight:600;color:var(--text-primary);background:var(--bg-white);outline:none;transition:all .2s}.range-input:focus{box-shadow:0 0 0 3px #ff6b3533}.range-hint{text-align:center}.range-hint-text{font-size:14px;color:var(--text-muted);font-weight:500}.checkbox-group-row{display:flex;gap:12px;align-items:center;margin-top:30px;height:100%;justify-content:center}.checkbox-item-row{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-white);border:2px solid var(--border-orange);border-radius:10px;cursor:pointer;transition:all .2s;white-space:nowrap;height:44px;box-sizing:border-box}.checkbox-item-row:hover{background:var(--bg-light)}.checkbox-item-row.disabled{opacity:.5;cursor:not-allowed}.checkbox-text{font-size:14px;font-weight:500;color:var(--text-primary)}.generate-btn{width:100%;padding:16px;background:linear-gradient(135deg,var(--primary-orange) 0%,var(--primary-orange-light) 100%);border:none;border-radius:12px;color:#fff;font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow-md);transition:all .2s;margin-top:8px}.generate-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.generate-btn:active{transform:translateY(0)}.generate-btn svg{width:20px;height:20px}.generate-btn-alt{width:100%;padding:14px;background:linear-gradient(135deg,var(--primary-orange) 0%,var(--primary-orange-light) 100%);border:none;border-radius:10px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow-md);transition:all .2s;margin-bottom:4px}.generate-btn-alt:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.generate-btn-alt:active{transform:translateY(0)}.generate-btn-alt svg{width:18px;height:18px}.generate-btn-secondary{width:100%;padding:12px;background:var(--bg-white);border:2px solid var(--border-orange);border-radius:10px;color:var(--text-primary);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow-sm);transition:all .2s}.generate-btn-secondary:hover{background:var(--bg-light);transform:translateY(-1px);box-shadow:var(--shadow-md)}.generate-btn-outline{width:100%;padding:12px;background:var(--bg-white);border:2px solid var(--border-orange);border-radius:10px;color:var(--primary-orange);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow-sm);transition:all .2s}.generate-btn-outline:hover{background:var(--primary-orange);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}.error-text{color:#e74c3c!important}.error-border{border-color:#e74c3c!important}@media (max-width: 640px){.app-container{padding:12px}.main-card{border-radius:20px}.header-section{padding:20px 20px 12px}.header-icon{width:40px;height:40px;font-size:20px}.header-title{font-size:20px}.logo-img{width:60px;height:60px}.content-section{padding:0 20px 20px}.form-row{flex-direction:column;gap:16px}.operation-grid{grid-template-columns:repeat(2,1fr)}.range-options-row{flex-direction:column;gap:16px}.checkbox-group-row{width:100%;justify-content:center;margin-top:30px}.checkbox-item-row{flex:1;justify-content:center}}
