html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{margin:0;padding:0}button{font-family:inherit}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#c9a46c;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#b8924a}::selection{background:#b8433e26;color:#2c1810}:root{--primary: #3da0f5;--primary-light: #5cb8ff;--primary-dark: #2680d0;--accent: #ff8c32;--accent-light: #ffc078;--gold: #ffc107;--green: #4cc05c;--pink: #f06292;--purple: #9c6cf0;--bg: #e8f4fd;--bg-warm: #f0f8ff;--bg-card: rgba(255, 255, 255, .82);--bg-card-solid: #ffffff;--text: #1a2b4a;--text-light: #4a6080;--text-muted: #8899aa;--border: rgba(60, 140, 220, .18);--border-light: rgba(60, 140, 220, .1);--shadow-sm: 0 2px 10px rgba(60, 140, 220, .1);--shadow: 0 6px 28px rgba(60, 140, 220, .14);--shadow-lg: 0 14px 52px rgba(60, 140, 220, .18);--shadow-glow: 0 0 30px rgba(61, 160, 245, .15);--radius: 24px;--radius-sm: 16px;--radius-xs: 10px;--transition: cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}.app{max-width:100%;margin:0 auto;padding:12px 16px;height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:center;padding:2px 0;position:relative;flex-shrink:0}.app-logo{height:clamp(56px,10vw,80px);width:auto;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.12))}.settings-btn{position:absolute;right:0;top:50%;transform:translateY(-50%);width:32px;height:32px;border:none;background:#00000040;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-radius:50%;font-size:.95rem;cursor:pointer;box-shadow:none;transition:all .3s var(--transition);display:flex;align-items:center;justify-content:center;color:#fff;opacity:.7}.settings-btn:hover{transform:translateY(-50%) rotate(90deg);opacity:1;background:#0006}.progress-bar-container{margin-bottom:16px;background:#ffffffbf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-sm);padding:12px 16px;border:1px solid rgba(255,255,255,.5);box-shadow:var(--shadow-sm)}.progress-info{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--text-light);margin-bottom:8px}.progress-text{font-weight:600;color:var(--text)}.progress-stats{display:flex;align-items:center;gap:10px}.streak-badge{background:linear-gradient(135deg,var(--accent),#ff6b35);color:#fff;padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:700;letter-spacing:.5px;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 #ff8c324d}50%{box-shadow:0 0 14px 3px #ff8c3240}}.progress-track{height:5px;background:var(--border-light);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--primary-light),var(--primary));border-radius:3px;transition:width .5s var(--transition);position:relative}.progress-fill:after{content:"";position:absolute;top:0;right:0;width:20px;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4));border-radius:3px}.content-backdrop{flex:1;display:flex;flex-direction:column;min-height:0;background:#ffffff59;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:28px;padding:4px 8px 8px;box-shadow:0 4px 30px #00000014,inset 0 0 0 1px #fff6}.app-main{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:2px 0;min-height:0;overflow:hidden}.game-card{width:100%;height:100%;perspective:1400px;overflow:hidden}.game-card.empty{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--text-muted);font-size:1.2rem}.card-inner{position:relative;width:100%;height:100%;transition:transform .7s var(--transition);transform-style:preserve-3d}.game-card.flipped .card-inner{transform:rotateY(180deg)}.card-front,.card-back{background:#ffffffd1;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:var(--radius);box-shadow:var(--shadow),0 0 0 1px #fff6;border:1px solid rgba(255,255,255,.5)}.card-front{backface-visibility:hidden;height:100%;overflow:hidden}.card-back{backface-visibility:hidden;transform:rotateY(180deg);position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.card-image-area{width:100%;aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;border-radius:var(--radius)}.idiom-image{width:100%;height:100%;display:block;object-fit:cover;border-radius:var(--radius);transition:transform .4s var(--transition)}.idiom-image:hover{transform:scale(1.02)}.image-loading{display:flex;flex-direction:column;align-items:center;gap:20px;color:var(--text-muted)}.image-loading p{font-size:.9rem;letter-spacing:1px}.loading-spinner{width:52px;height:52px;border:3px solid var(--border-light);border-top-color:var(--primary);border-right-color:var(--accent);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.image-error,.image-placeholder{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-muted);padding:32px 20px;text-align:center}.image-placeholder span{font-size:3.5rem}.error-detail{font-size:.75rem;color:var(--text-muted);max-width:80%;word-break:break-all;opacity:.7}.retry-btn{padding:10px 24px;border:2px solid var(--primary);background:transparent;color:var(--primary);border-radius:24px;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .25s var(--transition);letter-spacing:1px}.retry-btn:hover{background:var(--primary);color:#fff;box-shadow:0 4px 16px #3da0f54d;transform:translateY(-1px)}.card-action-area{padding:12px 16px}.hint-panel{margin-bottom:16px}.hints-container{display:flex;flex-direction:column;gap:10px}.hint-item{border-radius:var(--radius-sm);overflow:hidden}.hint-btn{width:100%;padding:12px 18px;border:2px dashed rgba(61,160,245,.25);background:linear-gradient(135deg,#3da0f50f,#4cc05c0f);color:var(--text-light);cursor:pointer;font-size:.9rem;border-radius:var(--radius-sm);transition:all .25s var(--transition);text-align:left;position:relative;overflow:hidden}.hint-btn:before{content:"";position:absolute;left:0;top:0;width:4px;height:100%;background:linear-gradient(180deg,var(--primary),var(--green));opacity:0;transition:opacity .25s}.hint-btn:hover:not(:disabled){background:linear-gradient(135deg,#3da0f51a,#4cc05c1a);border-color:var(--primary);color:var(--text);transform:translate(2px)}.hint-btn:hover:not(:disabled):before{opacity:1}.hint-btn:disabled{opacity:.35;cursor:not-allowed}.hint-content{display:flex;align-items:center;gap:10px;padding:12px 18px;background:linear-gradient(135deg,#e3f2fd,#f0f8ff);border-radius:var(--radius-sm);border:1px solid rgba(61,160,245,.15);font-size:.9rem;flex-wrap:wrap;animation:hint-reveal .4s var(--transition)}@keyframes hint-reveal{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.hint-label{background:linear-gradient(135deg,var(--primary),var(--purple));color:#fff;padding:4px 12px;border-radius:8px;font-size:.72rem;font-weight:700;white-space:nowrap;letter-spacing:.5px;text-transform:uppercase}.difficulty-tag{color:#fff;padding:3px 10px;border-radius:6px;font-size:.72rem;font-weight:700}.pinyin-initials{font-family:Georgia,Times New Roman,serif;font-size:1.2rem;font-weight:700;letter-spacing:6px;color:var(--accent)}.reveal-btn{width:100%;padding:15px;background:linear-gradient(135deg,var(--accent),#ff6b35);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1.05rem;font-weight:700;cursor:pointer;transition:all .3s var(--transition);letter-spacing:3px;position:relative;overflow:hidden}.reveal-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.reveal-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #ff8c3259}.reveal-btn:hover:before{left:100%}.revealed-inline{display:flex;align-items:center;justify-content:center;padding:14px 18px;background:linear-gradient(135deg,#e3f2fd,#fff3e0);border-radius:var(--radius-sm);border:1px solid rgba(61,160,245,.2);animation:reveal-pop .5s var(--transition)}@keyframes reveal-pop{0%{opacity:0;transform:scale(.95)}50%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.revealed-idiom{font-size:1.4rem;font-weight:800;color:var(--accent);letter-spacing:2px}.revealed-score{font-size:.95rem;color:var(--primary);font-weight:700}.bonus{color:var(--accent);font-weight:700}.answer-reveal{flex:1;padding:24px;text-align:center;display:flex;flex-direction:column;justify-content:center;overflow:hidden}.answer-idiom{font-size:2rem;font-weight:900;color:var(--accent);margin-bottom:4px;letter-spacing:8px;text-shadow:0 2px 4px rgba(255,140,50,.15)}.answer-pinyin{font-size:.9rem;color:var(--text-muted);margin-bottom:24px;font-style:italic;letter-spacing:1px}.answer-section{margin-bottom:8px;text-align:left;padding:10px 14px;background:#fff;border-radius:var(--radius-sm);border:1px solid var(--border-light);transition:box-shadow .2s}.answer-section:hover{box-shadow:var(--shadow-sm)}.answer-label{font-size:.7rem;color:var(--primary);font-weight:700;margin-bottom:6px;text-transform:uppercase;letter-spacing:3px}.answer-text{font-size:.95rem;line-height:1.7;color:var(--text)}.answer-score{margin-top:20px;display:flex;align-items:center;justify-content:center;gap:14px;padding:16px;background:linear-gradient(135deg,#fff3e0,#e3f2fd);border-radius:var(--radius-sm);border:1px solid rgba(255,140,50,.2)}.score-main{font-size:1.6rem;font-weight:800;color:var(--accent);letter-spacing:1px}.score-bonus{font-size:.9rem;color:var(--pink);font-weight:700}.flip-back-btn{width:calc(100% - 32px);margin:0 auto 16px;padding:12px;display:block;flex-shrink:0;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:700;cursor:pointer;letter-spacing:2px;transition:all .25s var(--transition)}.flip-back-btn:hover{transform:translateY(-2px);box-shadow:0 4px 16px #3da0f54d}.flip-to-back-btn{width:100%;padding:12px;margin-top:10px;background:transparent;color:var(--primary);border:2px solid rgba(61,160,245,.25);border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;cursor:pointer;letter-spacing:1px;transition:all .25s var(--transition)}.flip-to-back-btn:hover{background:var(--primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 16px #3da0f540}.navigation{display:flex;gap:12px;padding:8px 0;justify-content:center;flex-shrink:0}.nav-btn{flex:1;padding:12px 8px;border:none;background:#ffffffeb;color:var(--text);border-radius:var(--radius-sm);font-size:.95rem;font-weight:700;cursor:pointer;transition:all .25s var(--transition);max-width:150px;letter-spacing:1px;box-shadow:0 2px 10px #0000001f}.nav-btn:hover:not(:disabled){background:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #3da0f559}.nav-btn:active:not(:disabled){transform:translateY(0)}.nav-btn:disabled{opacity:.25;cursor:not-allowed}.nav-random{color:var(--accent);background:#ffffffeb}.nav-random:hover:not(:disabled){background:var(--accent);color:#fff;box-shadow:0 6px 20px #ff8c3259}.config-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#143c6459;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:overlay-in .3s var(--transition)}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.config-panel{background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius);width:100%;max-width:560px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg),0 0 0 1px #ffffff80;border:1px solid rgba(255,255,255,.6);animation:panel-in .35s var(--transition)}@keyframes panel-in{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.config-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid rgba(61,160,245,.1);position:sticky;top:0;background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:1}.config-tabs{display:flex;gap:4px;background:var(--bg);border-radius:var(--radius-xs);padding:3px}.tab-btn{padding:8px 18px;border:none;background:transparent;color:var(--text-light);cursor:pointer;font-size:.88rem;font-weight:600;border-radius:6px;transition:all .25s var(--transition)}.tab-btn.active{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;box-shadow:0 3px 12px #3da0f54d}.tab-btn:hover:not(.active){color:var(--text);background:#00000008}.close-btn{width:34px;height:34px;border:1px solid rgba(61,160,245,.15);background:var(--bg);font-size:1.2rem;cursor:pointer;color:var(--text-light);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn:hover{background:var(--pink);color:#fff;border-color:var(--pink)}.config-body{padding:24px}.skip-current-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:linear-gradient(135deg,#fff3e0,#fce4ec);border-bottom:1px solid rgba(255,140,50,.15);gap:12px}.skip-current-label{font-size:.85rem;color:var(--text-light)}.skip-current-label strong{color:var(--accent);letter-spacing:1px}.skip-current-btn{padding:6px 16px;border:1.5px solid #dc3545;background:transparent;color:#dc3545;border-radius:8px;font-size:.78rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .2s var(--transition)}.skip-current-btn:hover{background:#dc3545;color:#fff}.config-group{margin-bottom:18px}.config-group label{display:block;font-size:.82rem;color:var(--text-light);margin-bottom:8px;font-weight:700;letter-spacing:.5px}.config-group input,.config-group select{width:100%;padding:11px 16px;border:1.5px solid var(--border);border-radius:var(--radius-xs);font-size:.9rem;background:#fff;color:var(--text);outline:none;transition:all .25s var(--transition)}.config-group input:focus,.config-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3da0f51f}.save-btn{width:100%;padding:13px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;border:none;border-radius:var(--radius-xs);font-size:.95rem;cursor:pointer;font-weight:700;transition:all .25s var(--transition);letter-spacing:1px}.save-btn:hover{box-shadow:0 4px 16px #3da0f54d;transform:translateY(-1px)}.image-pregen-panel{padding:16px 0 0}.pregen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.pregen-header h3{font-size:1rem;color:var(--text);font-weight:700}.pregen-summary{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:14px;font-size:.88rem;font-weight:600;color:var(--text-light)}.pregen-actions{display:flex;gap:6px;flex-wrap:wrap}.pregen-btn{padding:7px 16px;border:1.5px solid var(--border);background:#fff;color:var(--text);border-radius:var(--radius-xs);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s var(--transition)}.pregen-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.pregen-btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.pregen-btn.primary:hover{background:var(--primary-dark)}.pregen-btn.danger{background:#dc3545;color:#fff;border-color:#dc3545}.pregen-btn.small{padding:5px 12px;font-size:.75rem}.pregen-progress{margin-bottom:14px}.pregen-progress-bar{height:5px;background:var(--border-light);border-radius:3px;overflow:hidden;margin-bottom:8px}.pregen-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--primary));transition:width .3s}.pregen-progress-text{font-size:.8rem;color:var(--text-muted)}.pregen-list{max-height:280px;overflow-y:auto;border:1px solid var(--border-light);border-radius:var(--radius-sm);margin-bottom:14px;background:#fff}.pregen-item{display:flex;align-items:center;gap:8px;padding:9px 14px;border-bottom:1px solid var(--border-light);font-size:.85rem;transition:background .15s}.pregen-item:hover{background:var(--bg)}.pregen-item:last-child{border-bottom:none}.pregen-item.cached{background:#f0faf0}.pregen-item.skipped{background:#fef0f0;opacity:.55}.pregen-checkbox{display:flex;align-items:center;cursor:pointer;flex-shrink:0}.pregen-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.skipped-count{color:var(--text-muted);font-size:.82rem}.pregen-status{font-size:.85rem}.pregen-idiom{flex:1;font-weight:600}.pregen-idiom.clickable{cursor:pointer;color:var(--primary);text-decoration:underline;text-decoration-style:dashed;text-underline-offset:3px;transition:color .2s}.pregen-idiom.clickable:hover{color:var(--primary-dark)}.image-preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:overlay-in .2s var(--transition)}.image-preview-modal{background:var(--bg-card);border-radius:var(--radius);max-width:90vw;width:700px;max-height:90vh;overflow:auto;box-shadow:var(--shadow-lg);animation:panel-in .3s var(--transition)}.image-preview-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border-light)}.image-preview-title{font-size:1.1rem;font-weight:700;color:var(--primary);letter-spacing:2px}.image-preview-body{padding:12px}.image-preview-body img{width:100%;border-radius:var(--radius-sm);display:block}.pregen-difficulty{font-size:.68rem;padding:2px 8px;border-radius:4px;color:#fff;font-weight:700;letter-spacing:.5px}.pregen-difficulty.easy{background:var(--green)}.pregen-difficulty.medium{background:var(--accent)}.pregen-difficulty.hard{background:var(--pink)}.pregen-log{border:1px solid var(--border-light);border-radius:var(--radius-sm);overflow:hidden;background:#fff}.log-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--bg);border-bottom:1px solid var(--border-light);font-size:.8rem;font-weight:700;color:var(--text-light)}.log-content{max-height:150px;overflow-y:auto;padding:10px 14px;font-size:.75rem;font-family:SF Mono,Consolas,Menlo,monospace;color:var(--text-light)}.log-line{padding:3px 0}.idioms-management{padding:20px 24px}.all-idioms-section{margin-bottom:20px}.skip-count-info{font-size:.78rem;color:var(--pink);font-weight:600}.idiom-search-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-xs);font-size:.88rem;background:#fff;color:var(--text);outline:none;margin-bottom:10px;transition:border-color .2s}.idiom-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3da0f51f}.all-idioms-list{max-height:240px;overflow-y:auto;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:#fff}.all-idiom-item{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid var(--border-light);font-size:.84rem;transition:background .15s}.all-idiom-item:last-child{border-bottom:none}.all-idiom-item:hover{background:var(--bg)}.all-idiom-item.skipped{background:#fef0f0;opacity:.6}.all-idiom-item.skipped .ai-idiom-name{text-decoration:line-through;color:var(--text-muted)}.ai-idiom-name{font-weight:700;color:var(--text);white-space:nowrap}.ai-idiom-source{font-size:.68rem;color:var(--text-muted);flex:1;text-align:right}.ai-toggle-btn{padding:4px 12px;border-radius:6px;font-size:.7rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s;flex-shrink:0}.ai-toggle-btn.skip{border:1px solid #dc3545;background:transparent;color:#dc3545}.ai-toggle-btn.skip:hover{background:#dc3545;color:#fff}.ai-toggle-btn.restore{border:1px solid var(--green);background:transparent;color:var(--green)}.ai-toggle-btn.restore:hover{background:var(--green);color:#fff}.model-selector{display:flex;gap:8px}.model-selector input{flex:1;padding:11px 16px;border:1.5px solid var(--border);border-radius:var(--radius-xs);font-size:.9rem;background:#fff;color:var(--text);outline:none;transition:all .25s var(--transition)}.model-selector input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3da0f51f}.fetch-models-btn{padding:8px 16px;border:1.5px solid var(--accent);background:#fff;color:var(--accent);border-radius:var(--radius-xs);font-size:.82rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .2s var(--transition)}.fetch-models-btn:hover:not(:disabled){background:var(--accent);color:#fff}.fetch-models-btn:disabled{opacity:.5;cursor:not-allowed}.model-error{font-size:.78rem;color:#dc3545;margin-top:6px}.model-list{margin-top:8px;max-height:200px;overflow-y:auto;border:1px solid var(--border-light);border-radius:var(--radius-xs);background:#fff}.model-item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 14px;border:none;border-bottom:1px solid var(--border-light);background:#fff;cursor:pointer;text-align:left;font-size:.82rem;transition:background .15s}.model-item:last-child{border-bottom:none}.model-item:hover{background:var(--bg)}.model-item.active{background:linear-gradient(135deg,#3da0f514,#3da0f524);border-left:3px solid var(--primary)}.model-name{font-weight:600;color:var(--text);word-break:break-all}.model-tags{display:flex;gap:4px;flex-shrink:0}.model-tag{padding:2px 6px;border-radius:4px;font-size:.65rem;font-weight:700;background:var(--bg);color:var(--text-muted);border:1px solid var(--border-light)}.gen-section{margin-bottom:24px;padding:20px;background:linear-gradient(135deg,#f0f8ff,#fff8e1);border-radius:var(--radius-sm);border:1px solid rgba(61,160,245,.1)}.gen-section h4{margin-bottom:14px;color:var(--text);font-size:.95rem;font-weight:700}.gen-controls{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.gen-field{display:flex;flex-direction:column;gap:6px}.gen-field label{font-size:.72rem;color:var(--text-muted);font-weight:700;letter-spacing:.5px}.gen-field select{padding:9px 14px;border:1.5px solid var(--border);border-radius:var(--radius-xs);font-size:.85rem;background:#fff;color:var(--text)}.gen-field input[type=text],.gen-field input[type=number]{padding:9px 14px;border:1.5px solid var(--border);border-radius:var(--radius-xs);font-size:.85rem;background:#fff;color:var(--text);width:100%;box-sizing:border-box}.gen-count-input{width:70px!important}.manual-add-form{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}.manual-add-form .gen-field{flex:1;min-width:80px}.manual-add-form .gen-field:first-child{flex:0 0 120px}.manual-add-form .gen-field:nth-child(2){flex:2}.gen-btn{padding:9px 24px;background:linear-gradient(135deg,var(--accent),#ff6b35);color:#fff;border:none;border-radius:var(--radius-xs);font-size:.85rem;cursor:pointer;font-weight:700;white-space:nowrap;transition:all .25s var(--transition);letter-spacing:.5px}.gen-btn:disabled{opacity:.45;cursor:not-allowed}.gen-btn:hover:not(:disabled){box-shadow:0 4px 16px #ff8c324d;transform:translateY(-1px)}.gen-result{margin-top:12px;font-size:.85rem;color:var(--green);font-weight:600;padding:8px 12px;background:#4cc05c14;border-radius:var(--radius-xs)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.section-header h4{font-size:.95rem;color:var(--text);font-weight:700}.clear-btn{padding:5px 14px;border:1.5px solid #dc3545;background:transparent;color:#dc3545;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.clear-btn:hover{background:#dc3545;color:#fff}.empty-tip{text-align:center;color:var(--text-muted);font-size:.88rem;padding:28px 20px}.custom-idioms-list{max-height:280px;overflow-y:auto;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:#fff}.custom-idiom-item{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--border-light);font-size:.85rem;transition:background .15s}.custom-idiom-item:hover{background:var(--bg)}.custom-idiom-item:last-child{border-bottom:none}.ci-idiom{font-weight:700;white-space:nowrap;color:var(--text)}.ci-difficulty{font-size:.68rem;padding:2px 8px;border-radius:4px;color:#fff;font-weight:700;white-space:nowrap}.ci-difficulty.easy{background:var(--green)}.ci-difficulty.medium{background:var(--accent)}.ci-difficulty.hard{background:var(--pink)}.ci-meaning{flex:1;color:var(--text-muted);font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ci-delete{padding:4px 12px;border:1px solid #dc3545;background:transparent;color:#dc3545;border-radius:6px;font-size:.7rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s}.ci-delete:hover{background:#dc3545;color:#fff}@media(max-width:480px){.app{padding:8px 10px}.card-action-area{padding:12px}.nav-btn{font-size:.85rem;padding:10px 6px}.config-panel{max-height:92vh;border-radius:16px 16px 0 0}.gen-controls{flex-direction:column}.gen-btn{width:100%}.card-image-area{max-height:40vh}}@media(min-width:768px){.app{padding:16px 36px}.card-front{display:flex;flex-direction:row}.card-image-area{width:55%;aspect-ratio:auto;height:100%;border-radius:var(--radius) 0 0 var(--radius)}.card-action-area{width:45%;padding:24px;display:flex;flex-direction:column;justify-content:center}.hint-btn,.hint-content{padding:14px 20px;font-size:.95rem}.reveal-btn{padding:16px;font-size:1.1rem}.revealed-inline{padding:16px 22px}.revealed-idiom{font-size:1.6rem}.navigation{padding:12px 0;gap:16px}.nav-btn{padding:14px 16px;font-size:1rem;max-width:180px}.answer-reveal{padding:36px}.answer-idiom{font-size:3rem}.answer-section{padding:18px 22px}.config-panel{max-width:680px}}@media(min-width:1024px){.app{padding:20px 52px}.settings-btn{width:36px;height:36px;font-size:1.1rem}.card-image-area{aspect-ratio:auto;height:100%}.card-action-area{padding:32px}.hints-container{gap:12px}.navigation{gap:20px}.nav-btn{max-width:200px;padding:15px 24px;font-size:1.05rem}}
