*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Noto Sans KR,Malgun Gothic,sans-serif;background:linear-gradient(160deg,#fff5f7,#f5f0ff 60%,#ffe9f3);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}button,textarea,input{font-family:inherit}*{font-family:Jua,sans-serif}.app{max-width:480px;margin:0 auto;min-height:100vh;padding-bottom:48px;position:relative}.header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;position:relative;position:sticky;top:0;background:#fff5f7d9;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:10;border-bottom:1px solid rgba(199,125,255,.1)}.app-title{position:absolute;left:50%;transform:translate(-50%);font-size:24px;font-weight:800;background:linear-gradient(135deg,#ff6b9d,#c77dff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;text-align:center;line-height:1.5;white-space:nowrap}.header-title{font-size:17px;font-weight:700;color:#1a1a2e;margin:0}.icon-btn{width:40px;height:40px;border:none;background:#fff;border-radius:12px;font-size:17px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #c77dff26;color:#1a1a2e;transition:transform .15s}.lang-btn{height:40px;padding:0 12px;border:none;background:linear-gradient(135deg,#ff6b9d,#c77dff);border-radius:12px;font-size:13px;font-weight:800;cursor:pointer;color:#fff;box-shadow:0 2px 10px #c77dff4d;transition:transform .15s,opacity .15s}.lang-btn:active{transform:scale(.94);opacity:.85}.header-right{display:flex;align-items:center;gap:8px}.icon-btn:active{transform:scale(.93)}.hero{text-align:center;padding:28px 24px 4px}.hero-text{font-size:24px;font-weight:800;color:#1a1a2e;line-height:1.4;margin:0 0 6px}.hero-sub{font-size:14px;color:#aaa;margin:0}.form-container{padding:20px 20px 0;display:flex;flex-direction:column;gap:22px}.form-section{display:flex;flex-direction:column;gap:10px}.form-label{font-size:12px;font-weight:700;color:#aaa;text-transform:uppercase;letter-spacing:.6px}.situation-input{width:100%;border:2px solid #f0e6ff;border-radius:16px;padding:16px;font-size:15px;color:#1a1a2e;background:#fff;resize:none;line-height:1.65;transition:border-color .2s,box-shadow .2s;outline:none;-webkit-appearance:none}.situation-input:focus{border-color:#c77dff;box-shadow:0 0 0 4px #c77dff1a}.situation-input::placeholder{color:#ccc}.btn-group{display:flex;gap:8px;flex-wrap:wrap}.tone-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.sel-btn{border:2px solid #f0e6ff;border-radius:12px;padding:10px 12px;font-size:14px;font-weight:600;background:#fff;color:#888;cursor:pointer;transition:all .18s;white-space:nowrap;flex:1;min-width:0;text-align:center;-webkit-tap-highlight-color:transparent}.sel-btn.active{background:linear-gradient(135deg,#ff6b9d,#c77dff);border-color:transparent;color:#fff;box-shadow:0 4px 14px #c77dff59}.sel-btn:active:not(.active){background:#f5f0ff}.generate-btn{width:100%;padding:18px;border:none;border-radius:18px;background:linear-gradient(135deg,#ff6b9d,#c77dff);color:#fff;font-size:17px;font-weight:800;cursor:pointer;transition:all .2s;box-shadow:0 8px 24px #c77dff61;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px;-webkit-tap-highlight-color:transparent}.generate-btn:active:not(:disabled){transform:scale(.97);box-shadow:0 4px 12px #c77dff4d}.generate-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}@keyframes spin{to{transform:rotate(360deg)}}.spinner{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .75s linear infinite;flex-shrink:0}.spinner-large{width:44px;height:44px;border:3px solid #f0e6ff;border-top-color:#c77dff;border-radius:50%;animation:spin .75s linear infinite}.situation-recap{display:flex;align-items:center;gap:8px;padding:10px 20px 12px;border-bottom:1px solid rgba(199,125,255,.12)}.recap-badge{background:linear-gradient(135deg,#ff6b9d,#c77dff);color:#fff;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700;white-space:nowrap;flex-shrink:0}.recap-text{font-size:13px;color:#999;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading-box{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:18px}.loading-msg{color:#bbb;font-size:14px;margin:0}.replies-list{padding:20px;display:flex;flex-direction:column;gap:14px}.reply-card{background:#fff;border-radius:20px;padding:20px;box-shadow:0 4px 18px #c77dff21;border:1.5px solid #f5f0ff;animation:fadeUp .3s ease both}.reply-card:nth-child(2){animation-delay:.07s}.reply-card:nth-child(3){animation-delay:.14s}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.reply-label{font-size:11px;font-weight:700;color:#c77dff;text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px}.reply-text{font-size:16px;color:#1a1a2e;line-height:1.65;margin:0 0 14px;word-break:keep-all;white-space:pre-wrap}.copy-btn{width:100%;padding:12px;border:2px solid #f0e6ff;border-radius:12px;background:transparent;color:#c77dff;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.copy-btn.copied{background:linear-gradient(135deg,#ff6b9d,#c77dff);border-color:transparent;color:#fff}.copy-btn:active:not(.copied){background:#f5f0ff}.adjust-section{padding:4px 20px 8px}.adjust-label{font-size:12px;font-weight:700;color:#ccc;margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px}.adjust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.adjust-btn{padding:12px 6px;border:2px solid #f0e6ff;border-radius:12px;background:#fff;color:#888;font-size:13px;font-weight:600;cursor:pointer;transition:all .18s;text-align:center;line-height:1.4;-webkit-tap-highlight-color:transparent}.adjust-btn:active{background:#f5f0ff;border-color:#c77dff;color:#c77dff}.history-list{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.history-card{background:#fff;border-radius:18px;padding:18px;box-shadow:0 3px 14px #0000000f;cursor:pointer;border:1.5px solid #f5f0ff;transition:transform .15s;-webkit-tap-highlight-color:transparent}.history-card:active{transform:scale(.98)}.history-meta{display:flex;align-items:center;gap:6px;margin-bottom:10px}.badge{border-radius:20px;padding:3px 11px;font-size:12px;font-weight:700;color:#fff}.badge-rel{background:linear-gradient(135deg,#ff6b9d,#c77dff)}.badge-tone{background:linear-gradient(135deg,#c77dff,#8b5cf6)}.history-time{font-size:12px;color:#ccc;margin-left:auto}.history-situation{font-size:14px;color:#1a1a2e;font-weight:600;margin:0 0 6px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:keep-all}.history-preview{font-size:13px;color:#bbb;margin:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:10px;color:#ccc;text-align:center}.empty-icon{font-size:52px;margin-bottom:4px}.empty-text{font-size:15px;margin:0}.empty-sub{font-size:13px;color:#ddd;margin:0}.mock-banner{margin:12px 20px 0;padding:10px 14px;background:#fffbe6;border:1.5px solid #ffe58f;border-radius:12px;font-size:13px;color:#7a5c00;line-height:1.5}.mock-banner code{background:#00000012;border-radius:4px;padding:1px 5px;font-size:12px}.spacer{width:40px;height:40px}
