/* Pretendard — 한글·영문·숫자 통일(Mac·Windows 동일 렌더). 동적 서브셋(필요 글자만 로드) */
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.css");
@import url("tokens.css");
/* 라이트 테마 — 마케팅 사이트(site.css)와 동일 톤으로 통일. 브랜드 토큰은 tokens.css */
:root{--bg:#f6f7f9;--panel:#fff;--panel2:#f3f4f8;--shadow:0 1px 2px rgba(16,24,40,.05),0 10px 28px -12px rgba(16,24,40,.14)}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--fg);font-family:"Pretendard Variable",Pretendard,-apple-system,BlinkMacSystemFont,system-ui,"Apple SD Gothic Neo","Segoe UI",Roboto,"Malgun Gothic",sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;word-break:keep-all;overflow-wrap:break-word}
a{color:inherit;text-decoration:none}
header{display:flex;justify-content:space-between;align-items:center;height:64px;padding:0 24px;border-bottom:1px solid var(--bd);position:sticky;top:0;background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(12px);z-index:5}
.brand{font-size:21px;font-weight:800;letter-spacing:-.5px}
.brand .tag{font-size:12px;font-weight:500;color:var(--dim);margin-left:8px;letter-spacing:0}
.wallet{display:flex;align-items:center;gap:10px}
.bal{font-variant-numeric:tabular-nums;font-weight:700;color:var(--good)}
main{max-width:880px;margin:28px auto;padding:0 20px;display:flex;flex-direction:column;gap:18px}
.panel{background:var(--panel);border:1px solid var(--bd);border-radius:16px;padding:24px;box-shadow:var(--shadow)}
.panel h2{margin:0 0 16px;font-size:17px;font-weight:800;letter-spacing:-.3px}
.panel h2 .hint{font-size:12.5px;font-weight:500;color:var(--dim);margin-left:8px}
textarea{width:100%;min-height:140px;background:var(--panel2);border:1px solid var(--bd);border-radius:12px;color:var(--fg);padding:13px 14px;font-size:14px;resize:vertical;font-family:inherit;line-height:1.6}
textarea:focus,.qinput:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,70,229,.12)}
.row{display:flex;gap:12px;align-items:flex-end;margin-top:14px;flex-wrap:wrap}
label{font-size:12.5px;font-weight:600;color:var(--dim);display:flex;flex-direction:column;gap:5px}
select{background:#fff;border:1px solid var(--bd);border-radius:10px;color:var(--fg);padding:9px 11px;font-size:13.5px;font-family:inherit}
.btn{background:var(--cue-grad);color:#fff;border:none;border-radius:12px;padding:11px 20px;font-size:14px;font-weight:700;cursor:pointer;margin-left:auto;box-shadow:0 6px 16px -5px rgba(99,102,241,.5);transition:transform .15s ease,box-shadow .15s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 22px -6px rgba(99,102,241,.55)}
.btn:disabled{opacity:.5;cursor:default;transform:none;box-shadow:none}
.btn-ghost{background:#fff;border:1px solid var(--bd);color:var(--fg);border-radius:10px;padding:7px 13px;font-size:12.5px;font-weight:600;cursor:pointer;transition:.12s}
.btn-ghost:hover{border-color:#c9cdd6;background:var(--bg)}
.hidden{display:none}
.qcard{border:1px solid var(--bd);border-radius:12px;padding:14px 16px;margin-bottom:10px;background:#fff;transition:border-color .12s,box-shadow .12s}
.qcard:hover{border-color:#d9ddff;box-shadow:var(--shadow)}
.qcard .q{font-size:14.5px;font-weight:600;cursor:pointer;display:flex;gap:8px;align-items:baseline}
.qcard .q .num{color:var(--accent);font-weight:800;flex:none}
.qcard .q .qt{flex:1}
.qcard .q .src{flex:none;font-size:11px;font-weight:700;color:#0f9d63;background:#e7f8ef;padding:2px 9px;border-radius:999px}
.qcard .q-native{font-size:13px;font-weight:500;color:var(--ko);margin:5px 0 0;line-height:1.55;cursor:pointer}
.uploadrow{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.upload-btn{display:inline-flex;align-items:center;gap:6px;border:1px dashed #c7ccd6;border-radius:10px;padding:10px 15px;font-size:13.5px;font-weight:600;cursor:pointer;background:var(--panel2);color:var(--fg)}
.upload-btn:hover{border-color:var(--accent);color:var(--accent)}
.qinput{width:100%;background:var(--panel2);border:1px solid var(--bd);border-radius:10px;color:var(--fg);padding:11px 13px;font-size:14px;margin-bottom:8px;font-family:inherit}
.ans{margin-top:14px;border-top:1px solid var(--bd);padding-top:14px}
.ans .bullets{list-style:none;padding:0;margin:0 0 12px;display:flex;flex-wrap:wrap;gap:6px}
.ans .bullets li{background:var(--brand-soft);color:var(--accent);font-size:11.5px;font-weight:700;padding:4px 11px;border-radius:999px;letter-spacing:.01em}
.ans .en{font-size:15px;line-height:1.7;color:var(--fg)}
.ans .pron{font-size:13.5px;color:var(--accent);margin-top:7px;line-height:1.65}
.ans .ko{font-size:13px;color:var(--ko);margin-top:8px;padding-top:8px;border-top:1px dashed var(--bd);line-height:1.6}
.practice{margin-top:13px;background:var(--bg);border:1px solid var(--bd);border-radius:12px;padding:13px 14px}
.practice textarea{min-height:64px;font-size:13px;background:#fff}
.practice .row{margin-top:8px}
.practice .btn-ghost{margin-left:auto}
.scores{display:flex;gap:18px;margin:10px 0 6px;font-size:13.5px}
.scores b{color:var(--good);font-size:16px}
.feedback{font-size:13px;color:var(--dim);line-height:1.6}
.spin{color:var(--dim);font-size:12.5px;padding:4px 0}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:#15171c;color:#fff;border:none;border-radius:12px;padding:11px 18px;font-size:13.5px;opacity:0;transition:.25s;pointer-events:none;font-variant-numeric:tabular-nums;box-shadow:0 12px 30px -8px rgba(16,24,40,.4);z-index:8}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
/* 예상 질문·답변 생성 진행 바 — 토스트(2.8초 뒤 사라짐)와 달리 답변을 다 채울 때까지 상단에 고정 표시(중복 클릭 방지) */
.genbar{position:fixed;top:74px;left:50%;transform:translateX(-50%) translateY(-14px);z-index:4;display:flex;align-items:center;gap:11px;background:#fff;border:1px solid #dfe2ff;border-radius:14px;padding:12px 18px 14px;min-width:248px;max-width:calc(100vw - 28px);box-shadow:0 14px 34px -10px rgba(79,70,229,.42);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
.genbar.show{opacity:1;transform:translateX(-50%) translateY(0)}
.genbar.done{border-color:#bfe9d4;box-shadow:0 14px 34px -12px rgba(15,157,99,.4)}
.genbar-spin{width:16px;height:16px;border:2.5px solid var(--brand-soft);border-top-color:var(--accent);border-radius:50%;animation:genspin .7s linear infinite;flex:none}
.genbar.done .genbar-spin{border:none;animation:none;display:flex;align-items:center;justify-content:center}
.genbar.done .genbar-spin::after{content:"✓";color:var(--good);font-size:16px;font-weight:900;line-height:1}
.genbar-msg{font-size:13.5px;font-weight:700;color:var(--fg)}
.genbar-count{font-size:13px;font-weight:800;color:var(--accent);font-variant-numeric:tabular-nums;flex:none;margin-left:1px}
.genbar.done .genbar-count{color:var(--good)}
.genbar-track{position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--brand-soft);border-radius:0 0 14px 14px;overflow:hidden}
.genbar-fill{height:100%;width:0;background:var(--cue-grad);border-radius:0 0 14px 14px;transition:width .35s ease}
.genbar.done .genbar-fill{background:var(--good)}
.genbar-fill.indet{width:40%;animation:genindet 1.1s ease-in-out infinite}
@keyframes genspin{to{transform:rotate(360deg)}}
@keyframes genindet{0%{margin-left:-40%}100%{margin-left:100%}}
/* 줄내림 보정: 한 덩어리로 묶어 중간에서 끊기지 않게 (가운뎃점 합성어는 typography.js가 별도 처리) */
.nb{white-space:nowrap}
footer a{white-space:nowrap}

.brand .brand-mark{height:1.42em;width:1.42em;vertical-align:-.34em;margin-right:.34em;display:inline-block}



.cue-wm{color:#7c6cff}
@supports ((-webkit-background-clip:text) or (background-clip:text)){.cue-wm{background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:transparent}}
