*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#333;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.container{max-width:800px;margin:0 auto;padding:20px;min-height:100vh;display:flex;flex-direction:column}.header{text-align:center;margin-bottom:40px;color:#fff}.header h1{font-size:2.5rem;font-weight:600;margin-bottom:10px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.header p{font-size:1.1rem;opacity:.9;font-weight:300}.main{background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 40px #0000001a;flex:1}.form-group{margin-bottom:25px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#555;font-size:.95rem}textarea{width:100%;padding:15px;border:2px solid #e1e5e9;border-radius:12px;font-size:16px;font-family:inherit;resize:vertical;transition:border-color .3s ease}textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.char-count{text-align:right;font-size:.85rem;color:#888;margin-top:5px}.controls-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:20px;margin-bottom:30px}select{width:100%;padding:12px 15px;border:2px solid #e1e5e9;border-radius:12px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .3s ease}select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.slider-container{display:flex;align-items:center;gap:10px}input[type=range]{flex:1;height:6px;border-radius:3px;background:#e1e5e9;outline:none;-webkit-appearance:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;box-shadow:0 2px 6px #0003}input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;border:none;box-shadow:0 2px 6px #0003}#rate-value,#pitch-value{font-size:.9rem;font-weight:500;color:#667eea;min-width:50px;text-align:center}.tts-mode-selection{display:flex;gap:20px;justify-content:center;margin-bottom:25px;padding:15px;background:#f8f9fa;border-radius:12px;border:2px solid #e9ecef}.mode-label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 15px;border-radius:8px;transition:all .3s ease;font-weight:500}.mode-label:hover{background:#667eea1a}.mode-label input[type=radio]{margin:0;accent-color:#667eea}.mode-label input[type=radio]:checked+.mode-text{color:#667eea;font-weight:600}.mode-text{font-size:.95rem;color:#495057;transition:color .3s ease}.button-group{display:flex;gap:15px;justify-content:center;margin-bottom:30px}.btn{padding:15px 30px;border:none;border-radius:12px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px;min-width:140px;position:relative}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.btn-secondary{background:#f8f9fa;color:#6c757d;border:2px solid #e9ecef}.btn-secondary:hover{background:#e9ecef;transform:translateY(-1px)}.btn-outline{background:transparent;color:#667eea;border:2px solid #667eea}.btn-outline:hover{background:#667eea;color:#fff;transform:translateY(-1px)}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.output-section{background:#f8f9fa;border-radius:15px;padding:30px;text-align:center;margin-bottom:20px}.audio-player{margin-bottom:20px}audio{width:100%;max-width:400px;border-radius:10px}.playback-status{background:#f0f8ff;border:2px solid #667eea;border-radius:15px;padding:20px;margin-bottom:20px;text-align:center}.status-message{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:15px;font-size:1.1rem;color:#667eea;font-weight:500}.status-icon{font-size:1.5rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.playback-controls{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.playback-controls .btn{min-width:100px;padding:10px 20px;font-size:14px}.tips{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;padding:20px;margin-top:20px;font-size:.9rem}.tips p{margin:0 0 10px;color:#667eea;font-weight:500}.tips ul{margin:0;padding-left:20px;color:#666}.tips li{margin-bottom:5px;line-height:1.5}kbd{background:#f1f3f4;border:1px solid #dadce0;border-radius:4px;color:#3c4043;font-family:monospace;font-size:.85em;padding:2px 6px;box-shadow:0 1px 1px #0000001a}.audio-info{margin-top:10px;text-align:center}.text-muted{color:#6c757d;font-size:.85rem}.download-section{text-align:center}.recording-limitation{background:#fff3cd;border:2px solid #ffc107;border-radius:15px;padding:20px;margin-bottom:20px}.limitation-message{display:flex;align-items:flex-start;gap:15px;margin-bottom:20px}.limitation-content h4{margin:0 0 10px;color:#856404;font-size:1.1rem}.limitation-content p{margin:0 0 15px;color:#856404;line-height:1.5}.alternative-solutions{background:#ffc1071a;border-radius:8px;padding:15px;margin-top:15px}.alternative-solutions h5{margin:0 0 10px;color:#856404;font-size:1rem}.alternative-solutions ul{margin:0;padding-left:20px;color:#856404}.alternative-solutions li{margin-bottom:8px;line-height:1.4}.alternative-solutions strong{color:#495057}.download-help-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000}.modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px}.modal-content{background:#fff;border-radius:15px;max-width:600px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #e9ecef}.modal-header h3{margin:0;color:#333;font-size:1.3rem}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.modal-close:hover{background-color:#f8f9fa}.modal-body{padding:25px}.modal-body p{margin:0 0 20px;line-height:1.6;color:#495057}.method-section{margin-bottom:25px;padding:15px;background:#f8f9fa;border-radius:10px;border-left:4px solid #667eea}.method-section h4{margin:0 0 10px;color:#667eea;font-size:1.1rem}.method-section ul{margin:0;padding-left:20px}.method-section li{margin-bottom:8px;line-height:1.5;color:#495057}.method-section strong{color:#333}.modal-footer{padding:20px 25px;border-top:1px solid #e9ecef;text-align:center}.tts-status{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:15px 20px;border-radius:10px;margin-bottom:20px;text-align:center;font-weight:500;box-shadow:0 4px 15px #667eea4d;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.error-message{background:#fee;color:#c33;padding:15px;border-radius:10px;border-left:4px solid #c33;margin-bottom:20px}.footer{text-align:center;margin-top:40px;color:#fffc;font-size:.9rem}.footer a{color:#ffffffe6;text-decoration:none}.footer a:hover{text-decoration:underline}@media (max-width: 768px){.container{padding:15px}.main{padding:25px}.header h1{font-size:2rem}.controls-row{grid-template-columns:1fr;gap:15px}.button-group{flex-direction:column;align-items:center}.btn{width:100%;max-width:200px}}
