:root{
  --ink:#191f28; --gray:#4e5968; --dim:#8b95a1; --line:#e5e8eb;
  --bg:#ffffff; --soft:#f2f4f6; --acc:#3182f6; --acc-d:#1b64da;
  --ok:#12b886; --warn:#f59f00; --bad:#f5556d;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:var(--bg); color:var(--ink);
  font-family:"Pretendard",-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo",sans-serif;
  -webkit-font-smoothing:antialiased; letter-spacing:-0.02em;
  word-break:keep-all; overflow-wrap:break-word;
}
h1,h2,h3,p{word-break:keep-all;margin:0}

/* 앱 셸 — 흰 배경 그대로(좌우 회색 거터 없음) */
#app{max-width:640px;margin:0 auto;background:var(--bg);min-height:100dvh}
.screen{display:none;flex-direction:column;height:100dvh}
.screen.active{display:flex}
.content{flex:1;overflow-y:auto;padding:26px 24px;display:flex;flex-direction:column;gap:18px}
.content.center{justify-content:center;align-items:center;text-align:center;gap:24px}
.content.scroll{gap:14px}
.actionbar{flex-shrink:0;padding:18px 24px calc(18px + env(safe-area-inset-bottom));background:var(--bg)}

/* 버튼 — 크게 */
button{font-family:inherit;cursor:pointer;border:none;border-radius:16px;font-weight:800;letter-spacing:-0.02em;transition:.15s}
.primary{background:var(--acc);color:#fff;padding:20px;font-size:19px;width:100%;box-shadow:0 8px 22px rgba(49,130,246,.3)}
.primary:hover{background:var(--acc-d)}
.primary:disabled{opacity:.5}
.ghost{background:var(--bg);border:1px solid var(--line);color:var(--gray);padding:12px;font-weight:700}
.ghost.sm{padding:10px 14px;font-size:14px;width:auto;align-self:flex-start;margin-top:6px}
.ghost-dark{background:transparent;border:1px solid #2a2f3a;color:#c9cfd8;padding:18px;font-size:17px;width:100%}
.ghost-dark:hover{background:#12151c}

/* 셋업 */
.home{color:var(--dim);font-size:15px;font-weight:700;text-decoration:none}
.big-q{font-size:38px;line-height:1.25;font-weight:800;margin-top:4px}
.choices{display:flex;flex-direction:column;gap:12px;margin-top:6px}
.choice{display:flex;align-items:center;gap:16px;text-align:left;background:var(--bg);border:1.5px solid var(--line);border-radius:18px;padding:20px;width:100%}
.choice:hover{border-color:var(--acc)}
.choice.sel{border-color:var(--acc);background:#f5f9ff;box-shadow:0 0 0 3px rgba(49,130,246,.12)}
.choice .ic{font-size:28px;line-height:1}
.choice .ct{display:flex;flex-direction:column;gap:3px}
.choice b{font-size:19px;font-weight:800;color:var(--ink)}
.choice small{color:var(--dim);font-size:14.5px;font-weight:500}
/* 회사(빙의) 그리드 */
.co-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}
.co{display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;background:var(--bg);border:1.5px solid var(--line);border-radius:16px;padding:16px}
.co:hover{border-color:var(--acc)}
.co.sel{border-color:var(--acc);background:#f5f9ff;box-shadow:0 0 0 3px rgba(49,130,246,.12)}
.co-e{font-size:24px;line-height:1}
.co b{font-size:18px;font-weight:800;color:var(--ink)}
.co small{color:var(--dim);font-size:13px;font-weight:500;line-height:1.4}
.divider{display:flex;align-items:center;gap:12px;color:var(--dim);font-size:13px;font-weight:700}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}
.cheer{color:var(--gray);font-size:15px;text-align:center;margin-top:2px}
.cheer b{color:var(--ink)}
#jd-input{display:flex;flex-direction:column;gap:10px}
.sen{display:flex;gap:8px}
.sen button{flex:1;background:var(--bg);border:1.5px solid var(--line);border-radius:12px;padding:12px;font-size:15px;font-weight:800;color:var(--gray)}
.sen button.sel{border-color:var(--acc);color:var(--acc);background:#f5f9ff}
#jd-url,#jd-text{width:100%;background:var(--soft);border:1px solid var(--line);color:var(--ink);border-radius:14px;padding:15px;font-family:inherit;font-size:16px;line-height:1.5;resize:vertical}
.tiny{color:var(--dim);font-size:14px;text-align:center}
.warn{color:var(--warn);font-size:14px}

/* 질문 — 아주 크게, 걸으면서 보이게 */
.qcount{color:var(--dim);font-size:15px;letter-spacing:1px;font-weight:800}
.qbig{font-size:34px;line-height:1.4;font-weight:800}
.qmid{font-size:22px;line-height:1.5;font-weight:700}
.brand{font-weight:800;font-size:40px;letter-spacing:-0.04em}
.lede{font-size:22px;line-height:1.5;font-weight:700}

/* 답변(성역): 화면 전체 다크 */
#screen-answer.active{background:#08090c}
.screen.blank .content{gap:30px}
.screen.blank .actionbar{background:#08090c}
.timer{font-size:120px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-5px;color:#e8ecf3;line-height:1}
.timer.low{color:var(--warn)}
.listening{display:flex;align-items:center;gap:12px;color:#8b93a3;font-size:18px}
.listening .dot{width:14px;height:14px;border-radius:50%;background:var(--bad);animation:pulse 1.1s infinite}
@keyframes pulse{0%,100%{opacity:.35;transform:scale(.9)}50%{opacity:1;transform:scale(1.15)}}

/* SOS */
.sos{background:transparent;border:1px dashed #3a4150;color:#8b93a3;padding:11px 20px;font-size:15px;font-weight:700;border-radius:999px;margin-top:8px}
.sos:hover{color:#c9cfd8;border-color:#5a616e}
.sos-overlay{position:absolute;inset:0;background:rgba(8,9,12,.92);display:flex;align-items:center;justify-content:center;padding:24px;z-index:10}
.sos-overlay[hidden]{display:none} /* hidden 속성이 display:flex에 지지 않게 — 답변 시작하자마자 SOS 뜨던 버그 fix */
#screen-answer{position:relative}
.sos-card{background:var(--bg);border-radius:20px;padding:26px 22px;max-width:420px;width:100%;display:flex;flex-direction:column;gap:12px}
.sos-title{font-size:20px;font-weight:800;color:var(--ink)}
.sos-intent{color:var(--acc);font-size:16px;font-weight:700;line-height:1.5}
.sos-label{color:var(--dim);font-size:13px;font-weight:800;margin-top:4px}
.sos-list{margin:0;padding-left:19px;color:var(--gray);font-size:15.5px;line-height:1.8}
.sos-card .primary{margin-top:10px;padding:16px;font-size:17px}
.sos-badge{background:rgba(245,159,0,.14);color:var(--warn);font-size:12px;font-weight:800;padding:3px 10px;border-radius:999px;margin-left:6px}

/* 같은 질문, 다른 표현 */
.alt{margin-top:12px;padding-top:12px;border-top:1px dashed var(--line)}
.alt>span{color:var(--dim);font-size:12.5px;font-weight:800}
.alt-q{color:var(--gray);font-size:14.5px;line-height:1.5;margin-top:6px}

/* 결과 */
.block{background:var(--bg);border:1px solid var(--line);border-radius:16px;padding:16px 18px}
.label{color:var(--gray);font-size:14px;font-weight:800;margin-bottom:10px}
textarea#db-transcript{width:100%;background:var(--soft);border:1px solid var(--line);color:var(--ink);border-radius:12px;padding:12px;font-family:inherit;font-size:16px;line-height:1.55;resize:vertical}
.verdict{background:#f5f9ff;border-color:#d6e4ff}
.verdict-body{font-size:17px;line-height:1.7;color:var(--gray)}
.verdict-body b{color:var(--ink)}
.aim{display:inline-block;font-weight:800;padding:5px 14px;border-radius:999px;font-size:14px;margin-bottom:10px}
.aim.ok{background:rgba(18,184,134,.12);color:var(--ok)}
.aim.part{background:rgba(245,159,0,.14);color:var(--warn)}
.aim.bad{background:rgba(245,85,109,.12);color:var(--bad)}
.intent{color:var(--gray);font-size:15px;margin:2px 0 9px}
.intent b{color:var(--ink)}
.card ul{margin:0;padding-left:19px;line-height:1.9;font-size:16px}
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.chip{background:var(--soft);border:1px solid var(--line);border-radius:999px;padding:5px 12px;font-size:13px;color:var(--gray)}
.model{white-space:pre-wrap;background:var(--soft);border:1px solid var(--line);border-radius:12px;padding:14px;font-size:14px;line-height:1.7;color:var(--ink);max-height:340px;overflow:auto;font-family:inherit;margin-top:8px}
