*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #4CAF50;--primary-hover: #45a049;--secondary-color: #2196F3;--secondary-hover: #0b7dda;--danger-color: #f44336;--danger-hover: #da190b;--text-color: #333;--text-light: #666;--bg-color: #f5f5f5;--card-bg: #ffffff;--border-color: #ddd;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--shadow-hover: 0 4px 12px rgba(0, 0, 0, .15);--border-radius: 8px;--transition: all .3s ease}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--bg-color);color:var(--text-color);line-height:1.6;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.container{width:100%;max-width:600px;background:var(--card-bg);border-radius:var(--border-radius);box-shadow:var(--shadow);overflow:hidden}header{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;padding:24px 20px;text-align:center}header h1{font-size:24px;font-weight:600}main{padding:24px 20px}.warning{background-color:#fff3cd;border:1px solid #ffc107;border-radius:var(--border-radius);padding:16px;margin-bottom:20px;text-align:center}.warning p{margin:4px 0;color:#856404}.hidden{display:none}.control-section{text-align:center;margin-bottom:24px}button{border:none;border-radius:var(--border-radius);padding:14px 28px;font-size:16px;font-weight:500;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow);min-width:160px}button:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}button:active{transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover)}.btn-primary.recording{background-color:var(--danger-color)}.btn-primary.recording:hover{background-color:var(--danger-hover)}.btn-secondary{background-color:var(--secondary-color);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--secondary-hover)}.btn-icon{font-size:20px}.status{margin-top:12px;font-size:14px;color:var(--text-light);min-height:20px}.text-section{margin-bottom:24px}.text-display{background-color:var(--bg-color);border:2px solid var(--border-color);border-radius:var(--border-radius);padding:20px;min-height:200px;max-height:400px;overflow-y:auto;font-size:16px;line-height:1.8;color:var(--text-color);white-space:pre-wrap;word-wrap:break-word}.text-display:empty:before{content:"변환된 텍스트가 여기에 표시됩니다...";color:var(--text-light)}.text-display.has-text{color:var(--text-color)}.action-section{text-align:center;position:relative}footer{background-color:var(--bg-color);padding:16px 20px;text-align:center;border-top:1px solid var(--border-color)}.hint{font-size:13px;color:var(--text-light);margin:0}.contact{font-size:13px;color:var(--text-light);margin:8px 0 0}.contact a{color:var(--primary-color);text-decoration:none}.contact a:hover{text-decoration:underline}@media(min-width:768px){header h1{font-size:28px}main{padding:32px 28px}button{font-size:18px;padding:16px 32px;min-width:180px}.btn-icon{font-size:22px}.text-display{font-size:17px;min-height:250px}footer{padding:20px}.hint,.contact{font-size:14px}}@media(min-width:1024px){body{padding:40px}header h1{font-size:32px}main{padding:40px 36px}.text-display{font-size:18px;min-height:300px}}.text-display::-webkit-scrollbar{width:8px}.text-display::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.text-display::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.text-display::-webkit-scrollbar-thumb:hover{background:#555}@media(hover:none)and (pointer:coarse){button{min-height:48px}}.history-panel{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;display:flex;align-items:center;justify-content:center}.history-panel.hidden{display:none}.history-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000080;animation:fadeIn .3s ease}.history-content{position:relative;width:90%;max-width:700px;max-height:80vh;background:var(--card-bg);border-radius:var(--border-radius);box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;animation:slideUp .3s ease;z-index:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.history-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;border-radius:var(--border-radius) var(--border-radius) 0 0}.history-header h2{font-size:20px;font-weight:600;margin:0}.btn-close{background:#fff3;color:#fff;border:none;width:32px;height:32px;min-width:32px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:var(--transition);box-shadow:none}.btn-close:hover{background:#ffffff4d;transform:rotate(90deg)}.history-body{flex:1;overflow-y:auto;padding:20px 24px}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{background:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:16px;cursor:pointer;transition:var(--transition)}.history-item:hover{border-color:var(--secondary-color);box-shadow:var(--shadow);transform:translateY(-2px)}.history-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.history-date{font-size:13px;color:var(--text-light);font-weight:500}.history-duration{font-size:12px;color:var(--text-light);background:#0000000d;padding:2px 8px;border-radius:4px}.history-preview{font-size:14px;color:var(--text-color);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.history-full-text{display:none;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color);font-size:14px;color:var(--text-color);line-height:1.8;white-space:pre-wrap;word-wrap:break-word}.history-item.expanded .history-preview{display:none}.history-item.expanded .history-full-text{display:block}.empty-history{text-align:center;padding:40px 20px;color:var(--text-light)}.empty-history p:first-child{font-size:48px;margin-bottom:12px}.empty-history p:last-child{font-size:15px}.action-section{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.action-section button{flex:1;min-width:140px}#history-count{font-size:13px;opacity:.9}.history-body::-webkit-scrollbar{width:8px}.history-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.history-body::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.history-body::-webkit-scrollbar-thumb:hover{background:#555}@media(max-width:767px){.history-content{width:95%;max-height:85vh}.history-header{padding:16px 20px}.history-header h2{font-size:18px}.history-body{padding:16px 20px}.action-section button{min-width:120px;font-size:14px;padding:12px 16px}.btn-icon{font-size:18px}#history-count{font-size:12px}}.modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2000;display:flex;align-items:center;justify-content:center}.modal.hidden{display:none}.modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#0009;animation:fadeIn .3s ease}.modal-content{position:relative;width:90%;max-width:500px;background:var(--card-bg);border-radius:var(--border-radius);box-shadow:0 10px 40px #0000004d;z-index:1;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:24px;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;border-radius:var(--border-radius) var(--border-radius) 0 0}.modal-header h2{font-size:20px;font-weight:600;margin:0}.modal-body{padding:24px;color:var(--text-color)}.modal-body p{margin:0 0 16px;line-height:1.6}.modal-info-list{list-style:none;margin:16px 0;background:var(--bg-color);border-radius:8px;padding:16px}.modal-info-list li{padding:8px 0;line-height:1.6}.modal-info-list li:not(:last-child){border-bottom:1px solid var(--border-color)}.modal-question{margin-top:20px!important;font-weight:600;font-size:16px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:center}.btn-modal{padding:12px 24px;border:none;border-radius:var(--border-radius);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-cancel{background:var(--card-bg);color:var(--text-color);border:1px solid var(--border-color)}.btn-cancel:hover{background:var(--bg-color)}.btn-confirm{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff}.btn-confirm:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6366f166}@media(max-width:767px){.modal-content{width:95%;max-width:none}.modal-header,.modal-body,.modal-footer{padding:16px}.modal-header h2{font-size:18px}.modal-body{font-size:14px}.modal-footer{flex-direction:column-reverse}.btn-modal{width:100%}}#snackbar-container{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:2000;display:flex;flex-direction:column;align-items:center;gap:10px;pointer-events:none}.snackbar{background-color:#323232;color:#fff;padding:14px 24px;border-radius:4px;font-size:14px;font-weight:500;box-shadow:0 3px 10px #0000004d;opacity:0;transform:translateY(20px);animation:snackbarSlideIn .3s ease forwards,snackbarFadeOut .3s ease 2.7s forwards;pointer-events:auto}.snackbar-progress{animation:snackbarSlideIn .3s ease forwards;background-color:#2196f3}@keyframes snackbarSlideIn{to{opacity:1;transform:translateY(0)}}@keyframes snackbarFadeOut{to{opacity:0;transform:translateY(10px)}}@media(max-width:767px){#snackbar-container{bottom:16px;left:16px;right:16px;transform:none}.snackbar{width:100%;max-width:calc(100vw - 32px);padding:12px 20px;font-size:13px}}.tab-buttons{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid var(--border-color)}.tab-btn{flex:1;background:none;border:none;border-bottom:3px solid transparent;padding:12px 16px;font-size:15px;font-weight:500;color:var(--text-light);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:6px;min-width:auto;box-shadow:none;margin-bottom:-2px}.tab-btn:hover{color:var(--text-color);background-color:#00000005;transform:none}.tab-btn.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.tab-icon{font-size:18px}.tab-text{font-size:14px}.tab-content{display:none}.tab-content.active{display:block;animation:fadeIn .3s ease}.file-upload-section{text-align:center;margin-bottom:24px}.file-input-wrapper{margin-bottom:16px}.file-input{display:none}.file-label{display:inline-flex;align-items:center;justify-content:center;gap:10px;background-color:var(--bg-color);border:2px dashed var(--border-color);border-radius:var(--border-radius);padding:32px 24px;cursor:pointer;transition:var(--transition);min-width:280px}.file-label:hover{border-color:var(--primary-color);background-color:#4caf500d}.file-icon{font-size:32px}.file-label-text{font-size:15px;font-weight:500;color:var(--text-color)}.file-info{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:16px;margin-bottom:16px}.file-info p{margin:4px 0;font-size:14px}.file-name{font-weight:500;color:var(--text-color)}.file-duration{color:var(--text-light)}.progress-bar{width:100%;height:8px;background-color:var(--bg-color);border-radius:4px;overflow:hidden;margin-top:16px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));width:0%;transition:width .3s ease}@media(max-width:767px){.tab-btn{padding:10px 12px;font-size:13px}.tab-icon{font-size:16px}.tab-text{font-size:12px}.file-label{padding:24px 20px;min-width:auto;width:100%}.file-icon{font-size:28px}.file-label-text{font-size:14px}}
