html,body{height:100%;margin:0;overflow:hidden}.app-container{display:flex;height:100vh;font-family:"Noto Serif CJK JP",-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}:lang(ja){font-family:"Noto Serif CJK JP",-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:500}:lang(zh){font-family:"Noto Serif CJK SC",Noto Sans SC,PingFang SC,Microsoft YaHei,system-ui,sans-serif;font-weight:500}.left-panel{flex:1;padding:2rem;overflow-y:auto;min-height:0;overscroll-behavior:contain;background-color:#e4e6e9;border-right:1px solid #e0e0e0}.right-panel{flex:1;padding:2rem;min-height:0;overflow-y:auto;overscroll-behavior:contain;background-color:#e4e6e9}.content-wrapper{background-color:#f8f9fa;border-radius:8px;padding:1.5rem;box-shadow:0 2px 10px #0000001a;margin-bottom:1.5rem}h1{color:#333;text-align:center;margin-bottom:2rem;font-size:2rem}.button-container{display:flex;justify-content:center;gap:1rem;margin-bottom:1.5rem;align-items:center}.display-mode-buttons{display:flex;border:1px solid #dee2e6;border-radius:6px;overflow:hidden}.mode-button{background:#fff;border:none;padding:8px 16px;font-size:14px;cursor:pointer;transition:all .2s ease;border-right:1px solid #dee2e6}.mode-button:last-child{border-right:none}.mode-button:hover{background:#f8f9fa}.mode-button.active{background:#4caf50;color:#fff}.mode-button.active:hover{background:#45a049}.generate-button{padding:.875rem 2rem;background:linear-gradient(135deg,#ff6b6b,#ff8e53);color:#fff;border:none;border-radius:6px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 8px #00000026}.generate-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #ff6b6b66}.generate-button:disabled{opacity:.6;cursor:not-allowed}.pinyin-toggle-button{padding:.875rem 1.5rem;background:linear-gradient(135deg,#56ab2f,#a8e063);color:#fff;border:none;border-radius:6px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.pinyin-toggle-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #56ab2f66}.pinyin-toggle-button:disabled{opacity:.6;cursor:not-allowed}.japanese-toggle-button{padding:.875rem 1.5rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:6px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.japanese-toggle-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #f093fb66}.import-button{display:inline-block;padding:.75rem 1.5rem;background:linear-gradient(135deg,#4ecdc4,#44a08d);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 8px #00000026}.import-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #4ecdc466}.error-message{margin-top:1.5rem;padding:1rem;background-color:#fee;border-left:4px solid #f44336;color:#c00;border-radius:4px}.result-container{margin-top:1.5rem;padding:0}.text-title{color:#333;font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid #56ab2f}.generated-text{font-size:1.2rem;line-height:2.2;color:#333;padding:0;min-height:100px;white-space:pre-wrap;word-wrap:break-word}.generated-text ruby{ruby-align:center}.generated-text ruby rt{font-size:.6em;color:#666;transition:color .2s ease}.generated-text ruby.pinyin-hidden rt{color:transparent}.vocabulary-title{color:#333;font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid #f5576c}.grammar-title{color:#333;font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid #667eea}.vocabulary-container{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.vocabulary-card{display:flex;flex-wrap:wrap;align-items:baseline;background-color:#fff;border-radius:6px;padding:.8rem 1rem;box-shadow:0 1px 4px #0000003d;transition:box-shadow .2s;gap:0}.vocabulary-card:hover{box-shadow:0 2px 8px #0000003d}.vocab-word{font-size:1.1rem;font-weight:600;color:#333;flex:0 0 auto;font-family:Noto Sans CJK SC,sans-serif}.vocab-pinyin{font-size:.9rem;color:#666;margin:0 0 0 .5rem;flex:0 0 auto}.vocab-meaning{font-size:.7rem;color:#555;width:100%;flex:1 0 100%;margin-top:.25rem}.grammar-points-container{display:flex;flex-direction:column;gap:1rem}.grammar-point-card{background-color:#f8f9fa;border-radius:8px;padding:.6rem 1rem;box-shadow:0 2px 8px #0000003d;transition:box-shadow .2s}.grammar-point-card:hover{box-shadow:0 4px 12px #0000003d}.grammar-point-title{color:#667eea;font-size:1.3rem;margin-bottom:.5rem;font-weight:600}.grammar-explanation{color:#555;line-height:1.6;margin-bottom:.8rem;font-size:.95rem}.grammar-example{background-color:#fff;border-left:3px solid #667eea;padding:.8rem;border-radius:4px;margin-top:.8rem}.example-label{color:#888;font-size:.85rem;margin-right:.5rem}.example-text{color:#333;font-size:1.05rem;font-family:Noto Sans CJK SC,sans-serif}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:16px;padding:2.5rem;max-width:800px;width:80vw;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out;position:relative}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.modal-title{font-size:1.8rem;color:#333;text-align:center;margin-bottom:2rem;border-bottom:3px solid #ff6b6b;padding-bottom:.5rem}.title-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1rem;margin-bottom:2rem}.title-option{background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s ease;text-align:left;min-height:120px;display:flex;flex-direction:column;justify-content:center;position:relative}.title-option:hover{transform:translateY(-3px);border-color:#ff6b6b;box-shadow:0 8px 25px #ff6b6b33;background:linear-gradient(135deg,#fff,#f8f9fa)}.title-zh{font-size:1.3rem;font-weight:600;color:#333;margin-bottom:.5rem;line-height:1.4}.title-ja{font-size:1.1rem;color:#666;line-height:1.4;margin-bottom:.5rem}.button-date{position:absolute;top:.5rem;right:.5rem;font-size:.65rem;color:#999;background:#ffffffe6;padding:.2rem .4rem;border-radius:3px;border:1px solid #eee;white-space:nowrap}.modal-close{display:block;margin:0 auto;padding:.75rem 2rem;background:linear-gradient(135deg,#6c757d,#5a6268);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.modal-close:hover{transform:translateY(-2px);box-shadow:0 5px 15px #6c757d4d}@media (max-width: 768px){.app-container{position:relative;overflow:hidden;display:block}.panels-wrapper{display:flex;width:200%;transition:transform .3s ease-out;height:100vh;height:100dvh}.panels-wrapper.show-left{transform:translate(0)}.panels-wrapper.show-right{transform:translate(-50%)}.left-panel{width:50%;flex:none;border-right:none;height:100vh;height:100dvh;box-sizing:border-box;position:relative;padding:.5rem}.right-panel{width:50%;flex:none;height:100vh;height:100dvh;box-sizing:border-box;position:relative;padding:.5rem}.left-panel:before,.right-panel:before{content:"";position:absolute;top:0;width:33.33%;height:100%;z-index:10;pointer-events:none}.left-panel:before{left:0}.right-panel:before{right:0}.content-wrapper,.button-container,.vocabulary-container,.grammar-points-container,.generated-text,.vocabulary-card,.grammar-point-card,.text-title{-webkit-user-select:text;user-select:text;cursor:auto}.panel-indicator{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:12px;z-index:100;background:#ffffffe6;padding:8px 12px;border-radius:20px;box-shadow:0 2px 10px #0000001a}.indicator-dot{width:20px;height:20px;border-radius:50%;background:#ccc;transition:background .3s ease;cursor:pointer;position:relative}.indicator-dot:before{content:"";position:absolute;inset:-10px;border-radius:50%}.indicator-dot.active{background:#ff6b6b}.content-wrapper{padding:.75rem;margin-bottom:.75rem}.button-container{margin-bottom:.75rem;gap:.5rem;flex-wrap:wrap}.generate-button{padding:.625rem 1.25rem;font-size:1rem}.import-button{padding:.5rem 1rem;font-size:.9rem}.mode-button{padding:6px 12px;font-size:13px}.text-title{font-size:1.25rem;margin-bottom:1rem}.generated-text{font-size:1rem;line-height:1.8}.vocabulary-title,.grammar-title{font-size:1.25rem;margin-bottom:1rem;padding-bottom:.25rem}.vocabulary-card{padding:.5rem .75rem;display:flex;flex-wrap:wrap;align-items:baseline;gap:0}.vocab-word{font-size:1rem;min-width:auto;flex:0 0 auto}.vocab-pinyin{font-size:.85rem;margin:0 0 0 .5rem;min-width:auto;flex:0 0 auto}.vocab-meaning{font-size:.65rem;width:100%;min-width:100%;flex:1 0 100%;margin-top:.25rem}.grammar-point-card{padding:.5rem .75rem}.grammar-point-title{font-size:1.1rem;margin-bottom:.25rem}.grammar-explanation{font-size:.85rem;margin-bottom:.5rem}.grammar-example{padding:.5rem;margin-top:.5rem}.example-label{font-size:.75rem}.example-text{font-size:.95rem}.title-grid{grid-template-columns:1fr}.modal-overlay{padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px));align-items:flex-start;overflow-y:auto}.modal-content{width:calc(100vw - 2rem);width:calc(100dvw - 2rem);max-width:calc(100dvw - 2rem);max-height:calc(100dvh - 2rem - env(safe-area-inset-bottom,0px));padding:1rem;box-sizing:border-box;margin:1rem auto;margin-bottom:calc(1rem + env(safe-area-inset-bottom,0px));overflow-y:auto}.modal-title{font-size:1.4rem;margin-bottom:1rem}.title-option{min-height:80px;padding:.75rem;box-sizing:border-box;width:100%}.title-zh{font-size:1.1rem;margin-bottom:.25rem}.title-ja{font-size:.95rem;margin-bottom:.25rem}.vocabulary-container{grid-template-columns:repeat(2,1fr);gap:.35rem}.grammar-points-container{gap:.5rem}img{max-width:200px!important}}@media (min-width: 769px){.app-container{display:flex}.panel-indicator{display:none}.panels-wrapper{display:contents}.left-panel,.right-panel{flex:1;width:auto;height:auto}}.audio-player-simple{display:inline-flex;align-items:center;gap:10px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:0 15px;height:42px}.play-pause-btn{background:transparent;border:none;font-size:18px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.play-pause-btn:hover:not(:disabled){transform:scale(1.1)}.play-pause-btn:disabled{opacity:.5;cursor:not-allowed}.seekbar{width:200px;height:4px;border-radius:2px;appearance:none;background:#e0e0e0;outline:none;cursor:pointer}.seekbar::-webkit-slider-thumb{appearance:none;width:12px;height:12px;border-radius:50%;background:#4caf50;cursor:pointer}.seekbar::-webkit-slider-thumb:hover{background:#45a049}.seekbar::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#4caf50;cursor:pointer;border:none}.seekbar::-moz-range-thumb:hover{background:#45a049}.seekbar:disabled{opacity:.5;cursor:not-allowed}.time-display{font-size:13px;color:#495057;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-weight:500;white-space:nowrap;min-width:70px}@media (max-width: 768px){.audio-player-simple{gap:8px;padding:0 10px;height:36px;font-size:.9em}.play-pause-btn{font-size:16px;width:26px;height:26px}.seekbar{width:120px;height:3px}.seekbar::-webkit-slider-thumb{width:10px;height:10px}.seekbar::-moz-range-thumb{width:10px;height:10px}.time-display{font-size:11px;min-width:60px}}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh;background:#e4e6e9;background-attachment:fixed}#root{min-height:100vh;display:flex;align-items:center;justify-content:center}.app{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003}
