:root{
  --bb-blue:#0044e2;
  --bb-blue-hover:#0036b8;
  --bb-blue-soft:#e8f0ff;
  --bb-page:#f5f8fc;
  --bb-surface:#fff;
  --bb-ink:#0a0a0a;
  --bb-body:#334155;
  --bb-muted:#64748b;
  --bb-line:#e2e8f0;
  --bb-card-border:#e8eef5;
  --bb-card-ring:#c7dbfe;
  --bb-font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --bb-display:'Benzin',var(--bb-font);
  --bb-mono:ui-monospace,'SF Mono',Menlo,Consolas,monospace;
  --bb-cta-border:1px solid rgba(0,68,204,.35);
  --bb-blue-glow:rgba(0,85,255,.35);
  --bb-btn-shell-bg:#fff;
  --bb-btn-shell-shadow:0 4px 12px rgba(0,0,0,.14),0 2px 4px rgba(0,0,0,.08);
  --bb-btn-shell-shadow-hover:0 6px 18px rgba(0,0,0,.16),0 3px 6px rgba(0,0,0,.1);
  --bb-btn-inner-shadow:0 2px 6px rgba(0,0,0,.12);
  --bb-btn-inner-shadow-hover:0 3px 10px rgba(0,0,0,.16);
  --ok:#22c55e;
  --warn:#eab308;
  --bad:#ef4444;
  --app-max:480px;
  /* 8 dialogue lines + gaps + padding (matches 2/11 full chat) */
  --dialogue-chat-h:434px;
  /* tallest foot: mic recording + shell */
  --dialogue-chat-foot-h:108px;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;height:100%;overflow:hidden;font-family:var(--bb-font);background:var(--bb-page);color:var(--bb-ink);-webkit-tap-highlight-color:transparent}
#app-root{
  display:flex;flex-direction:column;
  height:100dvh;max-height:100dvh;max-width:var(--app-max);margin:0 auto;
  background:var(--bb-surface);
  border:1px solid var(--bb-card-border);
  border-radius:20px 20px 0 0;
  overflow:hidden;
  isolation:isolate;
}
.app-header{
  flex-shrink:0;padding:max(10px,env(safe-area-inset-top)) 18px 10px;
  border-bottom:1px solid var(--bb-line);
  background:linear-gradient(180deg,#fafcff 0%,#fff 100%);
}
.app-header-row{
  position:relative;display:flex;align-items:center;min-height:36px;gap:8px;
}
.app-logo-link{display:flex;align-items:center;text-decoration:none;flex-shrink:0;position:relative;z-index:1}
.app-logo{
  display:block;height:28px;width:auto;margin:0;object-fit:contain;
}
/* Mission header: short title column — dots stay centered, counter on the right */
.app-title-link{
  flex:0 1 auto;min-width:0;max-width:calc(50% - 78px);
  text-decoration:none;
}
.app-title{
  font-family:var(--bb-display);font-weight:800;
  font-size:9px;line-height:1.2;letter-spacing:.03em;text-transform:uppercase;
  color:var(--bb-ink);overflow:hidden;
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;
}
.app-header-dots{
  position:absolute;left:50%;transform:translateX(-50%);
  display:flex;gap:4px;align-items:center;justify-content:center;flex-wrap:nowrap;
  width:min(128px,38vw);max-width:128px;pointer-events:none;
}
.app-step-counter{
  margin-left:auto;flex:0 0 auto;position:relative;z-index:1;
  min-width:4.25rem;text-align:right;
  font-size:10px;color:var(--bb-muted);font-family:var(--bb-mono);letter-spacing:.04em;
}
#sa{
  flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;
  display:flex;flex-direction:column;
  padding:16px 18px 8px;-webkit-overflow-scrolling:touch;
}
.course-nav{
  flex-shrink:0;display:flex;justify-content:center;align-items:center;
  min-height:48px;padding:6px 18px max(10px,env(safe-area-inset-bottom));
}
.course-back-link,
.course-step-hint{
  font-family:var(--bb-mono);font-size:11px;font-weight:400;
  color:var(--bb-muted);letter-spacing:.04em;
}
.course-back-link{
  appearance:none;background:none;border:none;padding:8px 12px;
  cursor:pointer;
}
.course-step-hint{
  display:block;margin:18px 0 0;text-align:left;
}
.course-back-link:hover:not(:disabled){color:var(--bb-blue)}
.course-back-link:disabled{opacity:.35;cursor:default}
.course-back-link[hidden]{display:none}
.course-screen{
  display:flex;flex-direction:column;flex:1;min-height:0;
}
.course-screen__head{flex-shrink:0}
.course-screen__foot{flex-shrink:0;padding-top:4px}
.course-screen--chat .course-screen__chat{
  flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;
  margin-bottom:0;
}
.course-screen--dialogue-chat .course-screen__chat{
  flex:0 0 auto;
  height:var(--dialogue-chat-h);min-height:var(--dialogue-chat-h);max-height:var(--dialogue-chat-h);
  overflow-y:auto;-webkit-overflow-scrolling:touch;
}
.course-screen--dialogue-chat .course-screen__foot{
  flex-shrink:0;min-height:var(--dialogue-chat-foot-h);
  display:flex;flex-direction:column;justify-content:flex-end;
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.intro-hero{
  font-family:var(--bb-display);font-size:clamp(1.2rem,4.2vw,1.55rem);font-weight:800;
  letter-spacing:.06em;text-align:center;text-transform:uppercase;margin:0 0 6px;line-height:1.15;
}
.intro-subhero{
  font-family:var(--bb-font);font-size:.72rem;font-weight:800;letter-spacing:.2em;
  color:var(--bb-muted);text-align:center;text-transform:uppercase;margin:0 0 18px;
}
.home-avatar-wrap{display:flex;justify-content:center;margin:0 0 16px}
.home-avatar-inner{position:relative;display:inline-block}
.home-avatar{
  width:92px;height:92px;border-radius:50%;overflow:hidden;
  border:3px solid #fff;box-shadow:0 0 0 1px var(--bb-line);
  background:linear-gradient(160deg,#dbeafe,#60a5fa);
}
.home-avatar img{width:100%;height:100%;object-fit:cover}
.mission-num{
  font-family:var(--bb-font);font-size:11px;font-weight:800;letter-spacing:.04em;
  color:var(--bb-blue);text-align:center;text-transform:uppercase;margin:0 0 16px;
}
.mission-voice-card{
  position:relative;isolation:isolate;
  border-radius:26px;padding:16px 18px;margin-bottom:12px;
  background:linear-gradient(165deg,#f8fbff 0%,#fff 55%);
  border:none;
  box-shadow:0 0 0 1px var(--bb-card-ring);
  -webkit-transform:translateZ(0);
  transform:translateZ(0);
}
.mission-voice-row{display:flex;gap:14px;align-items:flex-start}
.mission-avatar-wrap{position:relative;flex-shrink:0}
.mission-avatar-lg{
  width:84px;height:84px;border-radius:50%;overflow:hidden;
  background:linear-gradient(160deg,#dbeafe,#60a5fa);
}
.mission-avatar-lg img{width:100%;height:100%;object-fit:cover}
.mission-replay-on-avatar{
  position:absolute;right:-4px;bottom:-4px;width:32px;height:32px;border-radius:50%;
  border:1px solid var(--bb-line);background:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;padding:0;
}
.mission-replay-on-avatar img{width:18px;height:18px}
.mission-replay-on-avatar.is-playing{border-color:#93c5fd;background:var(--bb-blue-soft)}
.mission-replay-on-avatar.script-play--tap{transform:scale(.94)}
.mission-situation{margin:0;font-size:14px;line-height:1.65;color:var(--bb-body)}
.mission-mic-area{display:flex;flex-direction:column;align-items:center;padding:12px 0 4px;position:relative}
.mission-mic-glow{display:none}
.mb2{
  width:64px;height:64px;border-radius:50%;border:var(--bb-cta-border);background:var(--bb-blue);
  color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  position:relative;z-index:1;
  box-shadow:var(--bb-btn-inner-shadow);
  transition:background .15s ease,box-shadow .15s ease;
}
.mb2:hover:not(:disabled){box-shadow:var(--bb-btn-inner-shadow-hover)}
.mb2:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}
.mission-mic-area--disabled .btn-blue-shell{
  opacity:.55;
  box-shadow:0 2px 6px rgba(0,0,0,.06);
}
.mission-mic-area--disabled .mb2{
  background:#7aa8ff;
  opacity:.5;
  box-shadow:none;
  cursor:not-allowed;
}
.mission-mic-area--recording{padding:14px 0 6px}
.vad-shell-wrap{margin-top:0}
.vad-shell{
  position:relative;width:72px;height:72px;display:flex;align-items:center;justify-content:center;
}
.vad-ring{
  position:absolute;inset:-4px;border-radius:50%;
  border:2px solid rgba(0,85,255,.45);
  animation:vadRingPulse 1.35s ease-in-out infinite;
  pointer-events:none;
}
@keyframes vadRingPulse{
  0%,100%{transform:scale(1);opacity:.85}
  50%{transform:scale(1.04);opacity:1}
}
.vad-record-btn{
  position:relative;z-index:1;width:72px;height:72px;border-radius:50%;
  border:var(--bb-cta-border);background:var(--bb-blue);cursor:pointer;
  display:flex;align-items:center;justify-content:center;padding:0;
  box-shadow:var(--bb-btn-inner-shadow);
  transition:box-shadow .15s ease;
}
.vad-record-btn:hover{box-shadow:var(--bb-btn-inner-shadow-hover)}
.vad-bars{
  display:flex;align-items:center;justify-content:center;gap:5px;
  height:28px;width:44px;margin:0;
}
.vad-bar{
  width:5px;border-radius:3px;background:#fff;
  height:calc(8px + var(--vad-h,0.35) * 22px);
  transition:height .07s ease-out;
}
.vad-timer{
  margin-top:12px;font-family:var(--bb-mono);font-size:14px;font-weight:600;
  color:var(--bb-blue);letter-spacing:.08em;text-align:center;
}
.vad-timer--spacer{visibility:hidden;pointer-events:none;user-select:none}
.mission-mic-area--processing{padding:14px 0 6px;text-align:center}
.mission-mic-slot{
  min-height:84px;display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.mission-mic-area--recording .btn-blue-shell--round{min-height:84px;box-sizing:border-box}
.vad-processing{margin:0 0 12px;font-size:15px;font-weight:600;color:var(--bb-body)}
.vad-processing-dots{display:flex;gap:7px;justify-content:center;align-items:center}
.vad-processing-dots span{
  width:7px;height:7px;border-radius:50%;background:var(--bb-blue);
  animation:vadDot 1s ease-in-out infinite;
}
.vad-processing-dots span:nth-child(2){animation-delay:.18s}
.vad-processing-dots span:nth-child(3){animation-delay:.36s}
@keyframes vadDot{0%,100%{opacity:.3;transform:scale(.82)}50%{opacity:1;transform:scale(1)}}
.app-loading .mission-mic-area--processing{opacity:1}
.btn-blue-shell{
  width:100%;box-sizing:border-box;margin-top:10px;padding:6px 7px;
  background:var(--bb-btn-shell-bg);border-radius:100px;
  border:1px solid rgba(0,0,0,.04);
  box-shadow:var(--bb-btn-shell-shadow);
  transition:box-shadow .15s ease,transform .15s ease;
}
.btn-blue-shell:has(.pb:hover:not(:disabled)),
.btn-blue-shell:has(.mb2:hover:not(:disabled)){box-shadow:var(--bb-btn-shell-shadow-hover)}
.btn-blue-shell .pb{margin-top:0;width:100%}
.btn-blue-shell--round{
  width:auto;max-width:100%;margin:12px auto 0;padding:6px;
  background:var(--bb-btn-shell-bg);border-radius:50%;
  border:1px solid rgba(0,0,0,.04);
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:var(--bb-btn-shell-shadow);
  transition:box-shadow .15s ease,transform .15s ease;
}
.btn-blue-shell--round:has(.mb2:hover:not(:disabled)){box-shadow:var(--bb-btn-shell-shadow-hover)}
.mission-mic-area .btn-blue-shell--round{margin-top:0}
.mission-mic-area--recording .btn-blue-shell--round:has(.vad-record-btn:hover){
  box-shadow:var(--bb-btn-shell-shadow-hover);
}
.btn-blue-shell .mb2{margin:0}
.mb2--hero{width:72px;height:72px}
.mb2--hero svg{width:26px;height:26px}
.mb2--dialogue-play svg.mb2__dialogue-icon{width:40px;height:40px}
.mission-play-area{display:flex;justify-content:center;margin:8px 0 20px}
.course-play-btn{
  appearance:none;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 26px;border-radius:var(--radius-pill);
  font-family:var(--bb-font);font-size:16px;font-weight:800;
  border:1px solid rgba(0,68,226,.16);background:rgba(255,255,255,.92);color:var(--bb-ink);
  box-shadow:0 12px 32px rgba(25,55,100,.08);cursor:pointer;
  transition:transform .12s,background .12s,border-color .12s;
}
.course-play-btn:hover{border-color:rgba(0,68,226,.28);background:#fff}
.course-play-btn.is-playing{border-color:rgba(0,68,226,.35);background:var(--bb-blue-soft)}
.course-play-btn__icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:var(--radius-pill);
  background:var(--bb-blue);color:#fff;font-size:12px;line-height:1;
}
.demo-chat{
  display:flex;flex-direction:column;gap:10px;
  padding:14px 12px;
}
.chat-msg{
  display:flex;align-items:flex-end;gap:8px;max-width:100%;
  opacity:.42;transition:opacity .22s ease,transform .22s ease;
}
.chat-msg--ai{align-self:flex-start;flex-direction:row}
.chat-msg--you{align-self:flex-end;flex-direction:row-reverse}
.chat-msg__avatar{
  flex-shrink:0;width:36px;height:36px;border-radius:50%;
}
.chat-msg__bubble{
  padding:10px 14px;border-radius:16px;
  font-size:15px;line-height:1.35;
  transition:background .22s ease,box-shadow .22s ease;
}
.chat-msg--ai .chat-msg__bubble{
  background:#f1f5f9;color:var(--bb-ink);
  border-bottom-left-radius:4px;
}
.chat-msg--you .chat-msg__bubble{
  background:var(--bb-blue-soft);color:var(--bb-ink);
  border-bottom-right-radius:4px;
}
.chat-msg .en{font-weight:600;font-family:var(--bb-mono)}
.demo-dialogue-line--phrase-coffee .chat-msg__bubble{
  background:#e8f0ff;
}
.demo-dialogue-line--active{
  opacity:1;transform:scale(1.01);
}
.demo-dialogue-line--active .chat-msg__bubble{
  background:#fff;
  box-shadow:0 0 0 2px var(--bb-blue),0 4px 14px rgba(0,68,226,.14);
}
.demo-dialogue-line--active.chat-msg--you .chat-msg__bubble{
  background:var(--bb-blue);color:#fff;
}
.demo-dialogue-line--active.chat-msg--you .en{color:#fff}
.chat-msg--confirmed{opacity:1}
.chat-msg__bubble--hint{
  opacity:.55;color:var(--bb-muted);
  background:#f8fafc;
}
.chat-msg__bubble--hint-no{
  box-shadow:0 0 0 1px rgba(239,68,68,.55);
}
.chat-msg__bubble--await-voice{
  padding:10px 16px;color:var(--bb-muted);
  background:#f1f5f9;
}
.chat-recording-indicator{
  display:inline-flex;align-items:center;gap:8px;
}
.chat-recording-indicator__mic{
  display:flex;color:#94a3b8;
}
.chat-recording-indicator__idle{
  width:6px;height:6px;border-radius:50%;background:#cbd5e1;
}
.chat-recording-indicator__dot{
  width:8px;height:8px;border-radius:50%;background:#ef4444;flex-shrink:0;
  animation:chatRecDot 1.1s ease-in-out infinite;
}
.chat-recording-indicator__bar{
  width:3px;border-radius:2px;background:#94a3b8;
  height:calc(4px + var(--bar-h,0.4) * 14px);
}
.chat-recording-indicator--active .chat-recording-indicator__bar{
  animation:chatRecBar .85s ease-in-out infinite;
}
.chat-recording-indicator--active .chat-recording-indicator__bar:nth-child(3){animation-delay:.12s}
.chat-recording-indicator--active .chat-recording-indicator__bar:nth-child(4){animation-delay:.24s}
.chat-recording-indicator--active .chat-recording-indicator__bar:nth-child(5){animation-delay:.08s}
.chat-recording-indicator--active .chat-recording-indicator__bar:nth-child(6){animation-delay:.18s}
.chat-recording-indicator--active .chat-recording-indicator__bar:nth-child(7){animation-delay:.28s}
@keyframes chatRecDot{0%,100%{opacity:.55;transform:scale(.92)}50%{opacity:1;transform:scale(1)}}
@keyframes chatRecBar{0%,100%{transform:scaleY(.45);opacity:.45}50%{transform:scaleY(1);opacity:1}}
.chat-msg__bubble--yes{
  background:#ecfdf3;border:1px solid rgba(34,197,94,.35);
}
.chat-msg__bubble--maybe{
  background:#fffbeb;border:1px solid rgba(245,158,11,.4);
}
.chat-msg__bubble--no{
  background:#fef2f2;border:1px solid rgba(239,68,68,.35);
}
.chat-verdict-mark{
  display:inline-block;margin-right:6px;font-weight:800;
}
.chat-verdict-mark--yes{color:var(--ok)}
.chat-verdict-mark--maybe{color:var(--warn)}
.chat-verdict-mark--no{color:#dc2626}
.mission-mic-area--highlight .btn-blue-shell{
  box-shadow:0 0 0 3px rgba(245,158,11,.45),var(--bb-btn-shell-shadow);
}
.dialogue-replay-wrap{margin:10px 0 4px;text-align:center}
.dialogue-replay-link{
  appearance:none;background:none;border:none;padding:0;
  font:inherit;font-size:14px;font-weight:400;color:var(--bb-muted);
  text-decoration:underline;text-underline-offset:3px;cursor:pointer;
}
.dialogue-replay-link:hover{color:var(--bb-body)}
.dialogue-replay-link:disabled{opacity:.45;cursor:not-allowed;text-decoration:none}
.pb{
  width:100%;background:var(--bb-blue);color:#fff;border:var(--bb-cta-border);
  padding:15px 22px;border-radius:100px;font-family:var(--bb-font);font-size:14px;font-weight:700;
  cursor:pointer;margin-top:0;
  box-shadow:var(--bb-btn-inner-shadow);
  transition:background .15s ease,box-shadow .15s ease;
}
.pb:hover{background:var(--bb-blue-hover);box-shadow:var(--bb-btn-inner-shadow-hover)}
.pb:disabled{opacity:.5;cursor:not-allowed}
a.pb{box-sizing:border-box;display:block;text-decoration:none;text-align:center}
/* Secondary CTA — outer rim via .btn-blue-shell (as .pb); border on the button */
.pb--secondary{
  appearance:none;
  width:100%;
  margin-top:0;
  padding:15px 22px;
  border-radius:100px;
  font-family:var(--bb-font);
  font-size:14px;
  font-weight:700;
  line-height:1.2;
  cursor:pointer;
  background:#fff;
  color:var(--bb-ink);
  border:var(--bb-cta-border);
  box-shadow:none;
  transition:background .15s ease,border-color .15s ease;
}
.pb--secondary:hover{
  background:var(--bb-blue-soft);
  border:1px solid rgba(0,68,204,.45);
}
.pb--secondary:active{transform:scale(.98)}
.pb--secondary:disabled{opacity:.5;cursor:not-allowed}
.pb--secondary.pb--compact{
  width:auto;
  padding:8px 14px;
  font-size:12px;
  font-weight:700;
}
.crd{
  position:relative;isolation:isolate;
  background:#fff;border-radius:22px;padding:16px 18px;margin-bottom:12px;
  border:none;
  box-shadow:0 0 0 1px var(--bb-card-border);
  -webkit-transform:translateZ(0);
  transform:translateZ(0);
}
.clbl{font-size:9px;letter-spacing:.12em;color:var(--bb-muted);text-transform:uppercase;margin-bottom:8px;font-weight:800}
.ctxt{font-size:14px;color:var(--bb-body);line-height:1.65;margin:0}
.feedback-verdict{display:flex;gap:10px;align-items:flex-start;margin:4px 0 4px;font-size:14px;line-height:1.65}
.feedback-verdict--yes .feedback-verdict__mark,.feedback-verdict--yes .feedback-verdict__line{color:var(--ok)}
.feedback-verdict--maybe .feedback-verdict__mark,.feedback-verdict--maybe .feedback-verdict__line{color:var(--warn)}
.feedback-verdict--no .feedback-verdict__mark,.feedback-verdict--no .feedback-verdict__line{color:var(--bad)}
.feedback-comment{margin:0 0 12px;font-size:13px;line-height:1.65;color:var(--bb-body)}
.feedback-fix-line{margin:0;font-size:13px;line-height:1.65;color:var(--bb-body)}
.feedback-heard{
  margin:-2px 0 12px;font-size:12px;line-height:1.5;color:var(--bb-muted);text-align:left;
}
.feedback-fix-section{margin-bottom:4px}
.feedback-model-crd{
  margin-top:12px;
  background:#f1f5f9;
  border-color:var(--bb-line);
}
.feedback-model-crd .feedback-model-line{margin:0}
.feedback-model-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.feedback-model-row .feedback-model-line{flex:1;min-width:0}
.feedback-model-play-shell{
  flex-shrink:0;margin:0;padding:4px;
}
.feedback-model-play-shell.btn-blue-shell--round:has(.feedback-model-play:hover:not(:disabled)){
  box-shadow:var(--bb-btn-shell-shadow-hover);
}
.feedback-model-play{
  appearance:none;width:40px;height:40px;border-radius:50%;padding:0;
  border:var(--bb-cta-border);background:#fff;color:var(--bb-blue);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:none;
  transition:background .15s ease,border-color .15s ease,transform .12s ease;
}
.feedback-model-play:hover{
  background:var(--bb-blue-soft);
  border:1px solid rgba(0,68,204,.45);
}
.feedback-model-play.is-playing{
  background:var(--bb-blue-soft);
  border:1px solid rgba(0,68,204,.45);
}
.feedback-model-play:active{transform:scale(.94)}
.feedback-model-play__icon{width:22px;height:22px;display:block}
.feedback-crd + .btn-blue-shell,
.feedback-model-crd + .btn-blue-shell{margin-top:12px}
.feedback-crd .feedback-fix-section{margin-top:10px;padding-top:2px}
.feedback-crd .feedback-fix-line{overflow:visible;word-break:break-word}
.feedback-fixes-list{margin:0;padding-left:18px;font-size:13px;line-height:1.65;color:var(--bb-body);text-align:left}
.en{font-family:var(--bb-mono);font-size:15px;line-height:1.45;color:var(--bb-ink)}
.crd-model{background:#ebeff5b3}
.crd-retry-fail{margin-bottom:12px}
.crd-ok{
  border:none;
  box-shadow:0 0 0 1px #86efac;
  background:linear-gradient(165deg,#f0fdf4 0%,#ecfdf5 100%);
}
.crd-retry-warn{
  border:none;
  box-shadow:0 0 0 1px rgba(245,158,11,.45);
  background:linear-gradient(165deg,#fffbeb 0%,#fefce8 100%);
}
.status-done-row{display:flex;gap:12px;align-items:flex-start}
.status-done-check{
  width:26px;height:26px;border-radius:50%;background:var(--ok);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0;
}
.status-done-warn{
  width:26px;height:26px;border-radius:50%;background:var(--warn);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;
  flex-shrink:0;line-height:1;
}
.summary-page{text-align:center}
.summary-avatar-wrap{margin-bottom:14px}
.summary-avatar video{
  width:100%;height:100%;object-fit:cover;display:block;
  border-radius:50%;
}
/* Summary reveal sequence: avatar → belt pop → explain → step card → CTA */
@keyframes summaryBeltPop{
  0%{opacity:0;transform:scale(.28)}
  38%{opacity:1;transform:scale(1.48)}
  52%{transform:scale(1.05)}
  68%{transform:scale(1.22)}
  82%{transform:scale(.97)}
  100%{opacity:1;transform:scale(1)}
}
@keyframes summaryRevealUp{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes summaryRevealUpTilt{
  from{opacity:0;transform:translateY(36px) rotate(14deg)}
  to{opacity:1;transform:translateY(0) rotate(0)}
}
.summary-reveal-belt{
  opacity:0;
  transform:scale(.28);
  transform-origin:center center;
  animation:summaryBeltPop .95s cubic-bezier(.22,1.12,.36,1) .4s forwards;
}
.summary-reveal-explain{
  opacity:0;
  animation:summaryRevealUp .55s cubic-bezier(.22,1,.36,1) 1.05s forwards;
}
.summary-reveal-block{
  opacity:0;
  animation:summaryRevealUp .6s cubic-bezier(.22,1,.36,1) forwards;
}
.summary-reveal-block--step{animation-delay:2.2s}
.summary-reveal-block--actions{
  transform-origin:center bottom;
  animation-name:summaryRevealUpTilt;
  animation-duration:.65s;
  animation-delay:3.2s;
}
.summary-reveal-block--actions .btn-blue-shell{margin-top:0}
@media (prefers-reduced-motion:reduce){
  .summary-reveal-belt,
  .summary-reveal-explain,
  .summary-reveal-block{
    animation:none!important;
    opacity:1!important;
    transform:none!important;
  }
}
.summary-belt-tier{
  font-family:var(--bb-display);font-size:clamp(1.2rem,4.2vw,1.55rem);font-weight:800;
  letter-spacing:.06em;color:var(--warn);text-transform:uppercase;margin:0 0 8px;line-height:1.15;
}
.summary-belt-tier--white{color:#94a3b8}
.summary-belt-tier--yellow{color:var(--warn)}
.summary-belt-tier--orange{color:#ea580c}
.summary-belt-tier--green{color:var(--ok)}
.summary-page--mission-result .mission-result-actions{
  opacity:1;
  animation:none;
  transform:none;
}
.summary-page--mission-result .mission-result-actions .btn-blue-shell{margin-top:10px}
.summary-reveal-explain .summary-stat-sub{margin:0 0 10px}
.summary-stat-sub{font-size:12px;color:var(--bb-muted);margin:0 0 22px;line-height:1.5}
.summary-lead{margin:0 0 12px;font-size:14px;line-height:1.65;text-align:center}
.summary-reveal-explain .summary-lead{margin-bottom:0}
.intro-subhero.summary-next-h{margin:22px 0 4px}
.mission-voice-card.summary-next-card{
  text-align:center;
  background-image:
    linear-gradient(165deg,rgba(248,251,255,.94) 0%,rgba(255,255,255,.9) 55%),
    url('../assets/bg.webp');
  background-size:cover,cover;
  background-position:center,center;
  background-repeat:no-repeat,no-repeat;
}
.summary-product-name{
  font-family:var(--bb-display);font-size:1.05rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.04em;margin:0 0 8px;
}
.summary-product-meta,.summary-offer-detail{font-size:12px;color:var(--bb-muted);line-height:1.5;margin:0 0 10px}
.summary-retry-wrap{margin:8px 0 0;text-align:center}
.mission-result-phrases{text-align:left;margin:14px 0 0}
.mission-result-phrase{
  display:flex;gap:10px;align-items:baseline;margin:8px 0;
  font-size:15px;line-height:1.35;
}
.mission-result-mark{flex-shrink:0;font-weight:800;font-size:15px}
.mission-result-mark--ok{color:var(--ok)}
.mission-result-mark--weak{color:var(--warn)}
.result-section-label{
  font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--bb-muted);margin:20px 0 4px;
}
.result-section-label:first-child{margin-top:0}
.summary-retry-link{background:none;border:none;font:inherit;font-size:13px;color:var(--bb-muted);text-decoration:underline;cursor:pointer}
.mic-fallback-page{padding:8px 4px 24px;text-align:center}
.mic-fallback-title{
  margin:0 0 12px;font-family:var(--bb-display);font-size:1.15rem;font-weight:800;
  line-height:1.25;color:var(--bb-ink);
}
.mic-fallback-body,.mic-fallback-menu{
  margin:0 0 14px;font-size:14px;line-height:1.65;color:var(--bb-body);text-align:left;
}
.mic-fallback-menu{font-size:13px;color:var(--bb-muted)}
.mic-fallback-page .btn-blue-shell{margin-top:10px}
.dev-summary-link-wrap{margin:14px 0 0;text-align:center}
.dev-summary-link{
  background:none;border:none;padding:4px 8px;font:inherit;font-size:12px;
  color:var(--bb-muted);text-decoration:underline dotted;cursor:pointer;
}
.dev-summary-link:hover{color:var(--bb-blue)}
.app-toast{
  position:fixed;left:50%;bottom:max(16px,env(safe-area-inset-bottom));transform:translateX(-50%);
  background:#0f172a;color:#fff;font-size:13px;padding:10px 16px;border-radius:12px;
  max-width:min(90%,var(--app-max));z-index:100;opacity:0;pointer-events:none;transition:opacity .2s;
}
.app-toast.is-visible{opacity:1}
.app-loading{opacity:.55;pointer-events:none}
@media (min-width:520px){
  #app-root{
    margin-top:12px;margin-bottom:12px;
    border-radius:24px;
    height:calc(100dvh - 24px);
    max-height:calc(100dvh - 24px);
  }
}
