@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Noto+Sans+KR:wght@400;500;700&display=swap";:root{--bg:#f5edd6;--bg-accent-1:#a8d8b04d;--bg-accent-2:#ffd54f33;--card-bg:linear-gradient(180deg, #fffdf0 0%, #fff8e1 100%);--card-border:#c8ad7f;--card-shadow-1:#a68a5b;--card-shadow-2:#785a281f;--inner-border:#c8ad7f40;--input-bg:#fffef5;--input-border:#d4c5a0;--input-focus-border:#a68a5b;--input-focus-shadow:#a68a5b26;--input-placeholder:#c8b890;--text-primary:#4a3520;--text-secondary:#8b7355;--text-tertiary:#a68a5b;--text-muted:#c8b890;--btn-bg:linear-gradient(180deg, #8b7355 0%, #7a6548 100%);--btn-border:#6b5335;--btn-shadow:#4a3520;--btn-text:#fff8e1;--btn-stop-bg:linear-gradient(180deg, #c07040 0%, #a06030 100%);--btn-stop-border:#803820;--btn-stop-shadow:#602818;--voice-card-border:#e8dcc0;--voice-card-active-border:#8b7355;--voice-card-active-bg:#f5edd6;--slider-track:#e8dcc0;--slider-thumb:#8b7355;--slider-thumb-border:#6b5335;--bubble-bg:#fffef0;--bubble-border:#8b7355;--highlight:#ffd93d;--font-display:"Nunito", "Noto Sans KR", sans-serif;--font-body:"Noto Sans KR", "Nunito", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{min-height:100%}body{background:var(--bg);background-image:radial-gradient(circle at 20% 80%, var(--bg-accent-1) 0%, transparent 50%), radial-gradient(circle at 80% 20%, var(--bg-accent-2) 0%, transparent 50%);min-height:100vh;font-family:var(--font-body);color:var(--text-primary);-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}@keyframes villagerTalk{0%{transform:scaleY(1)}to{transform:scaleY(.92)scaleX(1.04)}}@keyframes popIn{0%{opacity:0;transform:scale(.85)translateY(10px)}70%{transform:scale(1.02)translateY(-2px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes leafSway{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.app-shell{flex-direction:column;align-items:center;min-height:100vh;padding:24px 16px 40px;display:flex}.app-header{align-items:center;gap:10px;margin-bottom:8px;animation:.5s ease-out popIn;display:flex}.app-header__leaf{font-size:28px;animation:3s ease-in-out infinite leafSway;display:inline-block}.app-header__title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.5px;font-size:24px;font-weight:900}.app-header__badge{color:var(--text-tertiary);background:#a68a5b1f;border-radius:999px;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:700}.app-subtitle{text-align:center;color:var(--text-tertiary);margin-bottom:20px;font-size:12px;font-weight:600;animation:.5s ease-out .1s both popIn}.main-card{background:var(--card-bg);border:3px solid var(--card-border);width:100%;max-width:480px;box-shadow:0 4px 0 var(--card-shadow-1), 0 8px 20px var(--card-shadow-2);border-radius:24px;padding:24px;animation:.5s ease-out .15s both popIn;position:relative}.main-card:after{content:"";border:2px solid var(--inner-border);pointer-events:none;border-radius:18px;position:absolute;inset:8px}.input-area{border:2.5px solid var(--input-border);width:100%;min-height:92px;font-size:14px;font-family:var(--font-body);background:var(--input-bg);color:var(--text-primary);resize:none;border-radius:14px;outline:none;padding:14px 16px;line-height:1.8;transition:border-color .2s,box-shadow .2s}.input-area:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-shadow)}.input-area::placeholder{color:var(--input-placeholder)}.char-count{text-align:right;color:var(--text-muted);margin-top:4px;font-size:10px}.shorten-toggle{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;margin-top:8px;margin-bottom:16px;font-size:13px;font-weight:500;display:flex}.shorten-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--text-secondary);cursor:pointer}.section-label{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:10px;font-size:12px;font-weight:700;display:flex}.section-label__icon{font-size:14px}.voice-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;display:grid}.voice-card{border:2.5px solid var(--voice-card-border);background:var(--input-bg);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:14px;align-items:center;gap:8px;padding:10px 12px;transition:all .15s;display:flex}.voice-card:hover{border-color:var(--card-border);background:#fff8e1;transform:translateY(-1px)}.voice-card.active{border-color:var(--voice-card-active-border);background:var(--voice-card-active-bg);box-shadow:0 2px 0 var(--card-shadow-1)}.voice-card--random{background:#ffd93d14;border-style:dashed;grid-column:span 3;justify-content:center}.voice-card--random:hover{border-color:var(--card-border);background:#ffd93d2e}.voice-card--random.active{border-color:var(--voice-card-active-border);background:#ffd93d38;border-style:solid}.voice-card__emoji{flex-shrink:0;font-size:20px}.voice-card__label{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:700;overflow:hidden}.voice-detail{color:var(--text-tertiary);margin-bottom:8px;font-size:11px}.slider-row{gap:16px;margin-bottom:4px;display:flex}.slider-col{flex:1}.slider-label{color:var(--text-secondary);justify-content:space-between;margin-bottom:5px;font-size:11px;font-weight:700;display:flex}input[type=range]{background:var(--slider-track);appearance:none;cursor:pointer;border-radius:3px;outline:none;width:100%;height:6px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--slider-thumb);border:2.5px solid var(--slider-thumb-border);cursor:pointer;border-radius:50%;width:18px;height:18px;transition:transform .1s;box-shadow:0 1px 3px #0003}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}input[type=range]::-moz-range-thumb{background:var(--slider-thumb);border:2.5px solid var(--slider-thumb-border);cursor:pointer;border-radius:50%;width:18px;height:18px}.controls-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px;display:grid}.control-item{flex-direction:column;gap:4px;display:flex}.control-item .slider-label{margin-bottom:3px}.select-row{gap:10px;margin-bottom:8px;display:flex}.select-wrapper{flex-direction:column;flex:1;gap:4px;display:flex}.mini-select{border:2px solid var(--voice-card-border);background:var(--input-bg);width:100%;height:36px;color:var(--text-primary);cursor:pointer;border-radius:10px;outline:none;padding:0 10px;font-size:12px;font-weight:600;transition:border-color .15s}.mini-select:focus{border-color:var(--input-focus-border)}.speech-area{align-items:flex-end;gap:12px;min-height:40px;margin-top:16px;display:flex}.villager-avatar{border:3px solid #0000001f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:28px;transition:background .3s;display:flex;box-shadow:0 3px 8px #0000001a}.villager-avatar.talking{animation:.2s ease-in-out infinite alternate villagerTalk}.speech-bubble{background:var(--bubble-bg);border:3px solid var(--bubble-border);box-shadow:0 3px 0 var(--btn-border), inset 0 0 0 2px #8b735514;font-size:13px;line-height:1.9;font-family:var(--font-body);color:var(--text-primary);letter-spacing:.3px;word-break:break-all;border-radius:16px 16px 16px 4px;flex:1;max-height:100px;padding:12px 16px;position:relative;overflow-y:auto}.speech-bubble__tail-outer{border-left:12px solid #0000;border-right:4px solid #0000;border-top:12px solid var(--bubble-border);width:0;height:0;position:absolute;bottom:-12px;left:14px}.speech-bubble__tail-inner{border-left:9px solid #0000;border-right:3px solid #0000;border-top:9px solid var(--bubble-bg);width:0;height:0;position:absolute;bottom:-8px;left:16px}.char-highlight{border-radius:3px;padding:1px 0;transition:background 40ms,font-weight 40ms}.char-highlight.active{background:var(--highlight);font-weight:700}.speech-bubble.empty{opacity:.5;border-style:dashed}.speech-bubble__placeholder{color:var(--text-muted);font-size:12px;font-style:italic}.play-btn{border:3px solid var(--btn-border);background:var(--btn-bg);width:100%;color:var(--btn-text);font-family:var(--font-display);cursor:pointer;box-shadow:0 4px 0 var(--btn-shadow), 0 6px 14px #4a352033;letter-spacing:1px;border-radius:14px;justify-content:center;align-items:center;gap:8px;margin-top:16px;padding:15px 0;font-size:17px;font-weight:800;transition:all .1s;display:flex;position:relative;overflow:hidden}.play-btn:hover:not(:disabled){box-shadow:0 5px 0 var(--btn-shadow), 0 8px 18px #4a352040;transform:translateY(-1px)}.play-btn:active:not(:disabled){box-shadow:0 1px 0 var(--btn-shadow);transform:translateY(2px)}.play-btn.stop{background:var(--btn-stop-bg);border-color:var(--btn-stop-border);box-shadow:0 4px 0 var(--btn-stop-shadow), 0 6px 14px #60281833}.play-btn.stop:hover:not(:disabled){box-shadow:0 5px 0 var(--btn-stop-shadow), 0 8px 18px #60281840}.secondary-actions{gap:8px;margin-top:10px;display:flex}.btn-secondary{border:2px solid var(--voice-card-border);background:var(--input-bg);color:var(--text-secondary);font-family:var(--font-display);cursor:pointer;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 0;font-size:13px;font-weight:700;transition:all .12s;display:flex}.btn-secondary:hover:not(:disabled){border-color:var(--card-border);background:#fff8e1;transform:translateY(-1px)}.btn-secondary:active:not(:disabled){transform:translateY(1px)}.advanced-toggle{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;gap:6px;width:100%;margin-top:16px;padding:8px;font-size:11px;font-weight:700;transition:color .15s;display:flex}.advanced-toggle:hover{color:var(--text-secondary)}.advanced-toggle__arrow{transition:transform .2s;display:inline-block}.advanced-toggle__arrow.open{transform:rotate(180deg)}.advanced-panel{opacity:0;max-height:0;margin-top:0;transition:max-height .35s,opacity .25s,margin .25s;overflow:hidden}.advanced-panel.open{opacity:1;max-height:600px;margin-top:14px}.advanced-inner{border:2px solid var(--voice-card-border);background:#fffef599;border-radius:14px;padding:16px}.status-bar{text-align:center;color:var(--text-tertiary);min-height:16px;margin-top:10px;font-size:11px;transition:color .2s}.status-bar.error{color:#c07040}.sample-section{width:100%;max-width:480px;margin-top:20px;animation:.5s ease-out .25s both popIn}.sample-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.sample-card{border:2px solid var(--voice-card-border);cursor:pointer;text-align:left;background:#fffdf0cc;border-radius:14px;flex-direction:column;gap:4px;padding:12px 14px;transition:all .15s;display:flex}.sample-card:hover:not(:disabled){border-color:var(--card-border);background:#fff8e1;transform:translateY(-1px)}.sample-card__label{color:var(--text-primary);font-size:13px;font-weight:700}.sample-card__text{color:var(--text-tertiary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:11px;line-height:1.5;display:-webkit-box;overflow:hidden}.tech-details{border:1.5px solid var(--voice-card-border);background:#fffdf0b3;border-radius:12px;width:100%;max-width:480px;margin-top:16px;padding:10px 14px;animation:.5s ease-out .3s both popIn}.tech-details summary{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:12px;font-weight:700}.tech-details__content{color:var(--btn-border);margin-top:8px;font-size:11px;line-height:1.8}.tech-details__content p{margin:2px 0}.toggle-row{gap:10px;margin-top:10px;display:flex}.toggle-item{border:2px solid var(--voice-card-border);color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;background:#fffef580;border-radius:10px;flex:1;align-items:center;gap:8px;padding:10px 12px;font-size:12px;font-weight:600;transition:border-color .15s;display:flex}.toggle-item:hover{border-color:var(--card-border)}.toggle-item input[type=checkbox]{width:15px;height:15px;accent-color:var(--text-secondary);cursor:pointer;flex-shrink:0}.hint-badge{color:var(--text-tertiary);background:#a68a5b1a;border-radius:8px;align-items:center;gap:4px;margin-top:6px;padding:4px 10px;font-size:10px;font-weight:600;display:inline-flex}@media (width<=460px){.voice-grid{grid-template-columns:repeat(2,1fr)}.voice-card--random{grid-column:span 2}.sample-grid,.controls-grid{grid-template-columns:1fr}}
