.iev-wrap{
  --i:#3B5BA5; --i-ink:#0E1E45; --i-soft:#E8EDF7;
  --e:#F2A623; --e-ink:#7A4E06; --e-soft:#FCF1DC;
  --accent:#5B6470; --accent-soft:#F1F2F4;
  max-width:560px; margin:0 auto; padding:8px 16px 60px;
  font-family:'Pretendard','Noto Sans KR',system-ui,sans-serif; color:#222;
}
.iev-wrap.v-e{ --accent:var(--e); --accent-soft:var(--e-soft); }
.iev-wrap.v-i{ --accent:var(--i); --accent-soft:var(--i-soft); }

.iev-head{ text-align:center; margin:24px 0 28px; }
.iev-title{ font-size:34px; font-weight:900; letter-spacing:-1px; margin:0; }
.iev-title span{ color:var(--accent); }
.iev-sub{ margin:8px 0 0; color:#666; font-size:15px; }
.iev-sub b{ color:var(--accent); }

.iev-stage{ animation:ievIn .35s ease; }
@keyframes ievIn{ from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:none;} }

/* upload */
.iev-drop{
  display:block; border:2.5px dashed #cfd4dc; border-radius:20px;
  padding:48px 20px; text-align:center; cursor:pointer;
  background:#fafbfc; transition:.18s;
}
.iev-drop.is-over,.iev-drop:hover{ border-color:var(--accent); background:var(--accent-soft); }
.iev-drop-icon{ font-size:48px; line-height:1; color:var(--accent); font-weight:300; }
.iev-drop-text{ font-size:19px; font-weight:800; margin-top:10px; }
.iev-drop-hint{ font-size:13px; color:#8a9099; margin-top:8px; }
.iev-privacy{
  margin:16px 4px 0; font-size:13px; color:#5a6470; text-align:center;
  background:#f3f6fb; border-radius:12px; padding:12px 14px;
}
.iev-privacy b{ color:#2c3a55; }

/* scan */
.iev-scanbox{
  position:relative; width:fit-content; max-width:100%; margin:20px auto 0;
  border-radius:16px; overflow:hidden; box-shadow:0 8px 30px rgba(0,0,0,.12);
}
.iev-scanbox canvas{ display:block; max-width:100%; filter:grayscale(.5) contrast(1.05); }
.iev-scanline{
  position:absolute; left:0; right:0; height:3px; top:0;
  background:linear-gradient(90deg,transparent,#46e0b8,transparent);
  box-shadow:0 0 16px 3px rgba(70,224,184,.7);
  animation:ievScan 1.6s ease-in-out infinite;
}
@keyframes ievScan{ 0%{top:2%;} 50%{top:96%;} 100%{top:2%;} }
.iev-scantext{ text-align:center; margin-top:18px; font-weight:700; color:#46a98c; letter-spacing:.3px; }

/* verdict */
.iev-verdict{
  position:relative; text-align:center; border-radius:24px; padding:36px 24px 30px;
  background:var(--accent-soft); border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);
  overflow:hidden;
}
.iev-letter{
  font-size:150px; font-weight:900; line-height:.9; color:var(--accent);
  text-shadow:0 6px 0 color-mix(in srgb,var(--accent) 22%,transparent);
  animation:ievPop .5s cubic-bezier(.2,1.4,.4,1) both;
}
@keyframes ievPop{ 0%{transform:scale(.3); opacity:0;} 100%{transform:scale(1); opacity:1;} }
.iev-stamp{
  position:absolute; top:30px; right:24px; border:4px solid #d6322b; color:#d6322b;
  font-weight:900; font-size:22px; padding:4px 12px; border-radius:8px;
  transform:rotate(11deg) scale(0); opacity:.85;
  animation:ievStamp .35s ease-out .45s both;
}
@keyframes ievStamp{ 0%{transform:rotate(11deg) scale(2.2); opacity:0;} 100%{transform:rotate(11deg) scale(1); opacity:.85;} }
.iev-label{ font-size:26px; font-weight:900; margin-top:6px; color:var(--accent); }
.iev-quote{ margin:10px auto 0; max-width:420px; font-size:16px; color:#444; line-height:1.6; }

/* gauge */
.iev-gauge{ margin:26px 4px 0; }
.iev-gauge-ends{ display:flex; justify-content:space-between; font-size:12px; color:#8a9099; font-weight:700; margin-bottom:6px; }
.iev-gauge-bar{
  position:relative; height:14px; border-radius:8px;
  background:linear-gradient(90deg,var(--i),#b9bfc9 48%,#b9bfc9 52%,var(--e));
}
.iev-gauge-needle{
  position:absolute; top:-6px; width:6px; height:26px; border-radius:4px;
  background:#1c1f24; box-shadow:0 0 0 3px #fff,0 2px 6px rgba(0,0,0,.3);
  transform:translateX(-50%); left:0; transition:left 1s cubic-bezier(.2,.8,.2,1);
}
.iev-gauge-score{ text-align:center; margin-top:12px; font-weight:900; font-size:17px; color:var(--accent); }

/* metrics */
.iev-metrics{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:22px 0 0; }
.iev-metric{
  border-radius:14px; padding:14px; background:#f7f8fa; border:1px solid #eceef1;
  display:flex; flex-direction:column; gap:3px;
}
.iev-metric-label{ font-size:12px; color:#8a9099; font-weight:700; }
.iev-metric-value{ font-size:24px; font-weight:900; color:#222; }
.iev-metric-tag{ font-size:12px; font-weight:800; }
.iev-metric.is-e{ background:var(--e-soft); border-color:color-mix(in srgb,var(--e) 22%,transparent); }
.iev-metric.is-e .iev-metric-tag{ color:var(--e-ink); }
.iev-metric.is-i{ background:var(--i-soft); border-color:color-mix(in srgb,var(--i) 22%,transparent); }
.iev-metric.is-i .iev-metric-tag{ color:var(--i-ink); }

.iev-disclaimer{
  margin:20px 0 0; font-size:13px; color:#7a818b; text-align:center;
  background:#fbf7ed; border:1px solid #f1e6cf; border-radius:12px; padding:12px 14px;
}
.iev-disclaimer b{ color:#a5781c; }

/* actions */
.iev-actions{ display:flex; gap:10px; margin:20px 0 0; flex-wrap:wrap; }
.iev-btn{
  flex:1; min-width:120px; padding:14px 16px; border-radius:14px; font-size:15px; font-weight:800;
  border:1.5px solid #d6dae1; background:#fff; color:#333; cursor:pointer; transition:.15s;
}
.iev-btn:hover{ border-color:var(--accent); color:var(--accent); }
.iev-btn-primary{ background:var(--accent); border-color:var(--accent); color:#fff; }
.iev-btn-primary:hover{ color:#fff; filter:brightness(1.05); }
.iev-btn-ghost{ flex:0 0 auto; min-width:0; color:#8a9099; }
.iev-copytoast{ text-align:center; margin:10px 0 0; color:#2e9c6f; font-weight:800; font-size:14px; }

/* standard faces */
.iev-standard{ margin:46px 0 0; padding-top:28px; border-top:1px solid #eceef1; }
.iev-std-title{ font-size:16px; font-weight:800; color:#5a6470; text-align:center; margin:0 0 16px; }
.iev-std-grid{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.iev-std-card{
  margin:0; text-align:center; border-radius:18px; padding:22px 12px;
}
.iev-std-i{ background:var(--i-soft); }
.iev-std-e{ background:var(--e-soft); }
.iev-std-face{ font-size:56px; line-height:1; }
.iev-std-card figcaption{ margin-top:10px; font-size:13px; color:#555; line-height:1.5; }
.iev-std-i figcaption b{ color:var(--i); }
.iev-std-e figcaption b{ color:var(--e); }
.iev-std-note{ text-align:center; font-size:13px; color:#9aa0a8; margin:16px 0 0; }

@media (max-width:420px){
  .iev-title{ font-size:28px; }
  .iev-letter{ font-size:120px; }
  .iev-metrics{ grid-template-columns:1fr; }
}

/* ===== 얼굴 패널 ===== */
.iev-faces{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:18px 0 0; }
.iev-face{ margin:0; text-align:center; }
.iev-face canvas{ width:100%; max-width:300px; aspect-ratio:1; border-radius:16px; background:#0b1020; }
.iev-face figcaption{ margin-top:8px; font-size:13px; font-weight:700; color:#6b7280; }

/* ===== 섹션 공통 타이틀 ===== */
.iev-sec-title{ font-size:17px; font-weight:800; color:#3a4250; text-align:center; margin:0 0 6px; }
.iev-sec-title span{ color:#9aa0a8; font-weight:700; font-size:15px; }

/* ===== 평균 얼굴 ===== */
.iev-average{ margin:46px 0 0; padding-top:28px; border-top:1px solid #eceef1; }
.iev-avg-counter{ text-align:center; font-size:14px; font-weight:700; color:#5b6470; margin:0 0 16px; }
.iev-avg-grid{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.iev-avg-card{ margin:0; text-align:center; border-radius:18px; padding:16px 12px; }
.iev-avg-i{ background:var(--i-soft); }
.iev-avg-e{ background:var(--e-soft); }
.iev-avg-card canvas{ width:100%; max-width:240px; aspect-ratio:1; }
.iev-avg-card figcaption{ margin-top:8px; font-size:13px; color:#555; }
.iev-avg-i figcaption b{ color:var(--i); display:block; }
.iev-avg-e figcaption b{ color:var(--e); display:block; }
.iev-avg-card figcaption span{ font-size:12px; color:#9aa0a8; }
.iev-avg-note{ text-align:center; font-size:12.5px; color:#9aa0a8; margin:16px 0 0; line-height:1.6; }

/* ===== 댓글 ===== */
.iev-comments{ margin:46px 0 0; padding-top:28px; border-top:1px solid #eceef1; }
.iev-cmt-form{ background:#f7f8fa; border:1px solid #eceef1; border-radius:16px; padding:14px; margin:14px 0 20px; }
.iev-cmt-row{ display:flex; align-items:center; gap:8px; margin-bottom:8px; flex-wrap:wrap; }
.iev-input{ width:100%; border:1.5px solid #dde1e7; border-radius:10px; padding:10px 12px; font-size:14px; font-family:inherit; box-sizing:border-box; resize:vertical; }
.iev-input:focus{ outline:none; border-color:var(--accent); }
.iev-nick{ max-width:180px; }
.iev-honey{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.iev-mytag{ font-size:12px; font-weight:800; padding:4px 10px; border-radius:20px; }
.iev-mytag.is-e,.iev-ctag.is-e{ background:var(--e-soft); color:var(--e-ink); }
.iev-mytag.is-i,.iev-ctag.is-i{ background:var(--i-soft); color:var(--i-ink); }
.iev-cmt-actions{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:8px; }
.iev-cmt-hint{ font-size:12px; color:#8a9099; }
.iev-btn-sm{ flex:0 0 auto; min-width:0; padding:10px 18px; font-size:14px; }

.iev-cmt-list{ display:flex; flex-direction:column; gap:14px; }
.iev-cmt{ border-radius:14px; }
.iev-cmt.is-reply{ background:#f7f8fa; border-radius:12px; padding:12px; margin-top:10px; }
.iev-cmt-head{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.iev-cmt-head b{ font-size:14px; font-weight:800; color:#2c3340; }
.iev-ctag{ font-size:11px; font-weight:800; padding:2px 8px; border-radius:20px; }
.iev-cmt-ago{ font-size:12px; color:#a0a6ae; margin-left:auto; }
.iev-cmt-body{ font-size:14.5px; color:#33373f; line-height:1.6; margin:6px 0 0; white-space:pre-wrap; word-break:break-word; }
.iev-cmt-foot{ display:flex; align-items:center; gap:14px; margin-top:8px; }
.iev-cvote{ border:1px solid #dde1e7; background:#fff; color:#6b7280; border-radius:20px; padding:5px 12px; font-size:13px; font-weight:700; cursor:pointer; transition:.15s; }
.iev-cvote span{ font-weight:900; }
.iev-cvote:hover{ border-color:var(--accent); color:var(--accent); }
.iev-cvote.is-voted{ background:var(--accent); border-color:var(--accent); color:#fff; }
.iev-clink{ border:none; background:none; color:#8a9099; font-size:13px; font-weight:700; cursor:pointer; padding:5px 4px; }
.iev-clink:hover{ color:var(--accent); }
.iev-replies{ margin-left:16px; border-left:2px solid #eceef1; padding-left:12px; }
.iev-reply-form{ margin-top:10px; display:flex; flex-direction:column; gap:8px; }
.iev-cmt-empty{ text-align:center; color:#9aa0a8; font-size:14px; padding:20px 0; }

@media (max-width:420px){
  .iev-faces{ gap:8px; }
  .iev-nick{ max-width:140px; }
}

/* ===== 3패널 얼굴 ===== */
.iev-faces-3{ grid-template-columns:1fr 1fr 1fr; gap:8px; }
.iev-faces-3 .iev-face figcaption{ font-size:12px; }

/* ===== 컨페티 ===== */
.iev-verdict{ position:relative; }
.iev-confetti{ position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:5; border-radius:24px; }
.iev-confetti span{ position:absolute; top:-30px; will-change:transform,opacity; animation:ievFall linear forwards; }
@keyframes ievFall{
  0%{ transform:translateY(0) rotate(0); opacity:0; }
  12%{ opacity:1; }
  100%{ transform:translateY(440px) rotate(var(--rot)); opacity:0; }
}
@media (prefers-reduced-motion: reduce){ .iev-confetti{ display:none; } }

/* 결과 글자 더 크고 요란하게 */
.iev-letter{ font-size:168px; }
.iev-label{ font-size:28px; letter-spacing:-0.5px; }
.iev-stamp{ font-size:24px; }

/* ===== 발랄+두꺼운 면책 ===== */
.iev-disclaimer{
  margin:20px 0 0; font-size:13.5px; color:#7a6a3e; text-align:left;
  background:#fdf8ec; border:1.5px solid #f0e3c2; border-radius:16px; padding:16px 18px; line-height:1.65;
}
.iev-disclaimer p{ margin:0 0 8px; }
.iev-disclaimer p:last-child{ margin-bottom:0; }
.iev-disc-head{ font-size:15px; font-weight:900; color:#a5781c; }
.iev-disclaimer b{ color:#9a6f12; font-weight:800; }

@media (max-width:420px){
  .iev-faces-3{ gap:6px; }
  .iev-faces-3 .iev-face figcaption{ font-size:11px; }
  .iev-letter{ font-size:128px; }
}

/* ===== AI 아우라 ===== */
.iev-ai{ margin:18px 0 0; }
.iev-ai-btn{
  width:100%; padding:16px; border-radius:16px; border:none; cursor:pointer;
  background:#5b4bd6; color:#fff; font-size:16px; font-weight:800; letter-spacing:-0.3px;
  transition:.15s; box-shadow:0 4px 16px rgba(91,75,214,.28);
}
.iev-ai-btn:hover{ filter:brightness(1.06); transform:translateY(-1px); }
.iev-ai-btn:disabled{ opacity:.65; cursor:default; transform:none; box-shadow:none; }
.iev-ai-result{
  margin-top:12px; background:#f3f1fd; border:1.5px solid #ddd6f7; border-radius:16px; padding:16px 18px;
  animation:ievIn .35s ease;
}
.iev-ai-tag{ font-size:12px; font-weight:900; color:#5b4bd6; margin-bottom:6px; }
.iev-ai-text{ margin:0; font-size:15.5px; line-height:1.7; color:#33304a; min-height:1.7em; white-space:pre-wrap; }
.iev-ai-text::after{ content:"▍"; color:#5b4bd6; animation:ievBlink 1s step-end infinite; }
@keyframes ievBlink{ 50%{ opacity:0; } }
.iev-ai-result.done .iev-ai-text::after{ content:""; }

/* ===== superuser 네비 ===== */
.iev-adminnav{
  display:inline-block; margin:0 0 12px; padding:8px 16px; border-radius:20px;
  background:#1f2937; color:#fff; font-size:13px; font-weight:800; text-decoration:none;
  transition:.15s;
}
.iev-adminnav:hover{ background:#374151; }
.ievd-back{
  display:inline-block; margin:0 0 8px; color:#5b6470; font-size:14px; font-weight:700;
  text-decoration:none;
}
.ievd-back:hover{ color:#1f2937; }

/* ===== 미니 푸터 (네비/푸터 숨긴 몰입형) ===== */
.iev-minifoot{
  margin:40px 0 0; padding-top:24px; border-top:1px solid #eceef1; text-align:center;
}
.iev-minifoot a{ color:#8a9099; font-size:13px; font-weight:700; text-decoration:none; }
.iev-minifoot a:hover{ color:#5b6470; }
.iev-minifoot span{ color:#cfd4dc; margin:0 6px; font-size:13px; }
.iev-minifoot p{ margin:10px 0 0; font-size:12px; color:#aeb4bf; line-height:1.5; }

/* ===== 셀링포인트 배지 ===== */
.iev-perks{ display:flex; flex-wrap:wrap; gap:7px; justify-content:center; margin:0 0 16px; }
.iev-perk{
  font-size:12.5px; font-weight:800; color:#4a5260; background:#f1f3f6;
  border:1px solid #e6e9ee; border-radius:20px; padding:6px 12px;
}
