/* kickreel LP アップロード embed: 共有スタイル
 *
 * 用途:
 *   - lp-upload-embed.js が注入する hidden DOM の非表示を確実にする
 *   - `.loading` を LP 用の中央オーバーレイ化（index.css の挙動を上書き）
 *   - `.upload-suitability` / `.upload-help` / `.upload-caveat` / `.hard-limit-notice`
 *     を LP からも参照できるよう、index.css から抽出
 *
 * DESIGN.md 準拠 — 値はすべて tokens.css の var(--kr-*) を参照。
 */

/* ── 注入 DOM の非表示 ─────────────────────────── */
/* uploadArea は LP では見せない（CTA が file picker を叩く形式）。 */
#krLpUploadEmbed > .upload-area,
#krLpUploadEmbed > .upload-area#uploadArea {
  display: none !important;
}
/* fileInput は元々 display:none だが念のため。 */
#krLpUploadEmbed #fileInput { display: none; }

/* renderJobs() の書き込み先。LP では一切表示しない。 */
#krLpUploadEmbed > #jobList { display: none !important; }

/* invite / billing / bonus は guarded だが、見せたくないので確実に非表示。 */
#krLpUploadEmbed > .kr-invite-banner,
#krLpUploadEmbed > .billing-banner,
#krLpUploadEmbed > .kr-bonus-slot { display: none !important; }

/* ── アップロード進捗オーバーレイ ───────────── */
/* LP 上ではコンテンツ階層に挿入する位置がないため、fixed overlay 化。
   index.css の `.loading { display: none; padding: 20px 0; }` /
   `.loading.active { display: block; }` を上書きする。 */
#loading {
  position: fixed;
  inset: 0;
  background: rgba(242, 241, 234, .96); /* var(--kr-bg) 相当 */
  z-index: 1500;
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: 64px 20px;
  overflow-y: auto;
}
#loading.active { display: flex; }
#loading #flowChartMount {
  width: 100%;
  max-width: 720px;
}

/* ── Flow chart / hint-block（index.css から複製） ───
   index.js:202-246 が #flowChartMount に挿入する DOM のスタイル。
   LP-A は index.css を読み込まないので、ここに同じ定義を持つ。
   index.css 側を編集したらこちらも合わせて更新する。 */
@keyframes kr-soft-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

.flow-chart {
  background: var(--kr-surface); border: 1px solid var(--kr-hair); border-radius: var(--kr-radius-md); padding: 28px 20px;
  margin-bottom: 16px;
  box-shadow: var(--kr-shadow-card);
}
.flow-chart__eta {
  text-align: center; font-size: 0.95rem; color: var(--kr-ink); margin-bottom: 4px;
}
.flow-chart__eta .eta-label { color: var(--kr-ink-dim); font-size: 0.8rem; margin-right: 6px; }
.flow-chart__eta .eta-value { color: #854d0e; font-weight: 600; }
.flow-chart__eta-note { text-align: center; font-size: 0.75rem; color: var(--kr-ink-dimmer); margin-bottom: 20px; }
.flow-chart__steps {
  display: flex; justify-content: space-between; gap: 6px;
  position: relative; margin: 0 4px;
}
.flow-chart__step {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  text-align: center; position: relative; min-width: 0;
}
.flow-chart__step + .flow-chart__step::before {
  content: ''; position: absolute; top: 14px; left: -50%; width: 100%; height: 2px;
  background: var(--kr-hair); z-index: 0;
}
.flow-chart__step.done::before { background: var(--kr-accent) !important; }
.flow-chart__icon {
  width: 28px; height: 28px; border-radius: 50%; background: var(--kr-surface); border: 2px solid var(--kr-hair);
  display: flex; align-items: center; justify-content: center; color: var(--kr-ink-dim);
  position: relative; z-index: 1; font-family: 'Material Symbols Outlined'; font-size: 18px;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.flow-chart__step.done .flow-chart__icon { background: var(--kr-accent-sub); border-color: var(--kr-accent); color: var(--kr-accent); }
.flow-chart__step.active .flow-chart__icon {
  background: rgba(250,204,21,.14); border-color: #854d0e; color: #854d0e;
  animation: kr-soft-pulse 1.6s ease-in-out infinite;
}
.flow-chart__step.await .flow-chart__icon { background: rgba(251,146,60,.12); border-color: #c2410c; color: #c2410c; }
.flow-chart__label { font-size: 0.78rem; color: var(--kr-ink-dim); margin-top: 8px; line-height: 1.3; }
.flow-chart__step.active .flow-chart__label { color: #854d0e; font-weight: 600; }
.flow-chart__step.done .flow-chart__label { color: var(--kr-accent); }
.flow-chart__step.await .flow-chart__label { color: #c2410c; font-weight: 600; }
.flow-chart__est { font-size: 0.7rem; color: var(--kr-ink-dimmer); margin-top: 4px; line-height: 1.3; }
.flow-chart__detail { font-size: 0.72rem; color: var(--kr-ink-dim); margin-top: 4px; min-height: 1em; }
.flow-chart__step.active .flow-chart__detail { color: #854d0e; }
.flow-chart__footer {
  text-align: center; margin-top: 22px; font-size: 0.78rem; color: var(--kr-ink-dim); line-height: 1.6;
}
.flow-chart__footer.warn {
  text-align: left; margin-top: 24px; padding: 14px 16px;
  background: rgba(251,146,60,.10);
  border: 1px solid rgba(251,146,60,.45);
  border-radius: var(--kr-radius-md);
  color: #c2410c;
  font-size: 0.88rem; line-height: 1.6;
  display: flex; align-items: flex-start; gap: 12px;
}
.flow-chart__footer.warn::before {
  content: '\26A0\FE0F'; font-size: 1.4rem; line-height: 1.2; flex-shrink: 0;
}
.flow-chart__footer-headline {
  display: block; font-weight: 700; font-size: 0.95rem; margin-bottom: 4px;
}
.flow-chart__footer-sub {
  display: block; color: #9a3412; font-size: 0.82rem;
}
@media (max-width: 520px) {
  .flow-chart__label { font-size: 0.7rem; }
  .flow-chart__est { font-size: 0.65rem; }
  .flow-chart__icon { width: 24px; height: 24px; font-size: 15px; }
  .flow-chart__step + .flow-chart__step::before { top: 12px; }
}

.hint-block {
  margin-top: 22px; padding: 14px; background: var(--kr-surface-2);
  border: 1px solid var(--kr-hair); border-radius: var(--kr-radius-md);
}
.hint-block__header {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--kr-font-mono); font-size: 0.72rem;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--kr-ink-dim); margin-bottom: 8px;
}
.hint-block__desc {
  font-size: 0.85rem; color: var(--kr-ink-dim); line-height: 1.6; margin-bottom: 12px;
}
#hintVideo {
  width: 100%; max-width: 100%; background: #000;
  border-radius: var(--kr-radius-sm); display: block;
}
.hint-block__row {
  display: flex; align-items: center; gap: 12px; margin-top: 12px; flex-wrap: wrap;
}
.hint-block__time {
  font-family: var(--kr-font-mono); letter-spacing: .18em; color: var(--kr-ink);
  font-size: 0.9rem; min-width: 60px;
}
.hint-block__status {
  margin-top: 10px; font-size: 0.8rem; color: var(--kr-ink-dim); min-height: 1em; line-height: 1.5;
}
.hint-block.confirmed {
  background: var(--kr-accent-sub); border-color: var(--kr-accent);
}
.hint-block.confirmed .hint-block__status {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 12px; padding: 0;
  color: var(--kr-accent);
  font-size: 0.85rem; font-weight: 600; line-height: 1.4;
}
.hint-block.confirmed .hint-block__status::before {
  content: 'check_circle'; font-family: 'Material Symbols Outlined';
  font-size: 1.1rem; font-weight: 400;
}
/* 確定後は編集 UI を畳み、控えめな「選び直す」だけ残す。 */
.hint-block.confirmed .hint-block__edit { display: none; }
.hint-block__redo {
  display: none; align-items: center; gap: 6px; margin-top: 12px;
  background: none; border: none; padding: 0; cursor: pointer;
  font-family: var(--kr-font-sans); font-size: 0.8rem; color: var(--kr-ink-dim);
  text-decoration: underline; text-underline-offset: 3px;
}
.hint-block__redo .material-symbols-outlined { font-size: 1rem; }
.hint-block__redo:hover { color: var(--kr-ink); }
.hint-block.confirmed .hint-block__redo { display: inline-flex; }

/* ── upload-suitability / help / caveat / hard-limit-notice ────
   index.css から抽出（LP 上でも同じ見た目で使えるように）。 */
.upload-suitability {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  text-align: left;
}
.upload-suitability__col {
  border: 1px solid var(--kr-hair);
  border-radius: var(--kr-radius-md);
  padding: 16px;
  background: var(--kr-surface);
}
.upload-suitability__col--ok {
  background: var(--kr-accent-sub);
  border-color: rgba(11, 61, 46, 0.18);
}
.upload-suitability__head {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.9rem; font-weight: 700; color: var(--kr-ink);
  margin-bottom: 8px;
}
.upload-suitability__head .material-symbols-outlined { font-size: 20px; }
.upload-suitability__col--ok .upload-suitability__head .material-symbols-outlined { color: var(--kr-accent); }
.upload-suitability__col--ng .upload-suitability__head .material-symbols-outlined { color: var(--kr-ink-dim); }
.upload-suitability ul {
  list-style: none; padding: 0; margin: 0;
  font-size: 0.85rem; color: var(--kr-ink-dim); line-height: 1.65;
}
.upload-suitability li { position: relative; padding-left: 12px; }
.upload-suitability li + li { margin-top: 4px; }
.upload-suitability li::before {
  content: ""; position: absolute; left: 0; top: 0.65em;
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--kr-ink-dimmer);
}

/* 「こんな動画におすすめ」は LP 全ペルソナで 2 列構成のまま。
   狭い viewport では padding / font-size を詰めて 2 列を維持する。
   ※ 単純に grid-template-columns: 1fr へ落とすと、NG / OK の対比が
   1 列縦並びになって意味が薄れる（過去に LP-B で 1 列化が指摘された）。 */
@media (max-width: 560px) {
  .upload-suitability { gap: 6px; }
  .upload-suitability__col { padding: 10px 12px; }
  .upload-suitability__head { font-size: 0.82rem; }
  .upload-suitability__head .material-symbols-outlined { font-size: 18px; }
  .upload-suitability ul { font-size: 0.78rem; line-height: 1.55; }
}

/* hard-limit-notice — index.js:534 が動的に作る */
.hard-limit-notice {
  display: none;
  margin: 0 auto 12px;
  max-width: 640px;
  padding: 12px 16px;
  background: var(--kr-surface);
  border: 1px solid var(--kr-rec);
  border-radius: var(--kr-radius-sm);
  color: var(--kr-ink);
  font-size: 0.9rem;
  line-height: 1.6;
}

/* iPhone 写真アプリの注意（折りたたみ） */
.upload-help { text-align: left; margin-top: 8px; }
.upload-help summary {
  color: var(--kr-ink-dim); font-size: 0.85rem; line-height: 1.7;
  cursor: pointer; list-style: none;
}
.upload-help summary::-webkit-details-marker { display: none; }
.upload-help .help-body {
  text-align: left;
  background: var(--kr-surface);
  border: 1px solid var(--kr-hair);
  border-radius: var(--kr-radius-md);
  padding: 16px 20px;
  margin-top: 8px;
  font-size: 0.85rem;
  color: var(--kr-ink-dim);
  line-height: 1.7;
}
.upload-help .help-body ol { padding-left: 20px; margin: 0; }
.upload-help .help-body li { margin-bottom: 4px; }

.upload-caveat {
  margin-top: 8px;
  text-align: left;
  font-size: 0.85rem;
  color: var(--kr-ink-dim);
  line-height: 1.7;
}
.upload-caveat strong { color: var(--kr-ink); font-weight: 700; }

/* ── Consent / Auth モーダル（index.css:418-462 から抽出）─────
   #consentModal / #consentAuthModal / #playerSelectionModal 用。
   `.kr-modal-overlay` 系（shared/kr-modal.css）とは別系統なので分けて持つ。 */
#authRegInviteBanner:not([hidden]) { display: flex; }

.modal-overlay {
  display: none; position: fixed; inset: 0; background: rgba(16,18,21,0.55);
  z-index: 100; align-items: center; justify-content: center;
}
.modal-overlay.active { display: flex; }
.modal-box {
  background: var(--kr-surface);
  border: 1px solid var(--kr-hair);
  border-radius: var(--kr-radius-lg);
  padding: 32px;
  max-width: 520px; width: 90%; max-height: 80vh; overflow-y: auto;
  box-shadow: var(--kr-shadow-pop);
}
.modal-box h2 { font-size: 1.1rem; margin-bottom: 16px; }
.modal-box ul { list-style: disc; padding-left: 20px; margin-bottom: 20px; }
.modal-box li { color: var(--kr-ink-dim); font-size: 0.85rem; line-height: 1.6; margin-bottom: 8px; }
.modal-actions { display: flex; gap: 12px; justify-content: flex-end; }
.btn-consent {
  background: var(--kr-accent); color: var(--kr-accent-ink); border: none;
  border-radius: var(--kr-radius-md);
  padding: 8px 20px; cursor: pointer; font-size: 0.85rem; font-weight: 700;
  transition: filter 0.15s;
}
.btn-consent:hover { filter: brightness(1.06); }
.btn-cancel {
  background: transparent; color: var(--kr-ink-dim);
  border: 1px solid var(--kr-hair); border-radius: var(--kr-radius-md);
  padding: 8px 20px; cursor: pointer; font-size: 0.85rem;
}
.btn-cancel:hover { background: var(--kr-accent-sub); color: var(--kr-ink); }
.modal-desc { color: var(--kr-ink-dim); font-size: 0.85rem; line-height: 1.6; margin-bottom: 16px; }
.auth-tabs { display: flex; border-bottom: 1px solid var(--kr-hair); margin-bottom: 16px; }
.auth-tab {
  flex: 1; text-align: center; padding: 8px 0; cursor: pointer;
  color: var(--kr-ink-dim); font-size: 0.85rem;
  border: none; border-bottom: 2px solid transparent;
  background: none; transition: color 0.2s, border-color 0.2s;
}
.auth-tab.active { color: var(--kr-accent); border-bottom-color: var(--kr-accent); }
.form-group { margin-bottom: 12px; }
.form-group label { display: block; font-size: 0.8rem; color: var(--kr-ink-dim); margin-bottom: 4px; }
.form-group input {
  width: 100%; background: var(--kr-surface); border: 1px solid var(--kr-hair);
  border-radius: var(--kr-radius-md);
  padding: 8px 12px; color: var(--kr-ink); font-size: 0.85rem;
}
.form-group input:focus { border-color: var(--kr-accent); outline: 3px solid var(--kr-accent-sub); outline-offset: 0; }
.password-hint { font-size: 0.75rem; color: var(--kr-ink-dim); margin-top: 4px; }
.error-msg { color: var(--kr-rec); font-size: 0.8rem; min-height: 1.2em; margin-bottom: 8px; }
/* SMS（電話番号）認証モーダル */
#authPhoneCode {
  font-family: var(--kr-font-mono); letter-spacing: .35em; text-align: center; font-size: 1.1rem;
}
.auth-otp-actions { text-align: center; margin-top: 12px; font-size: 0.8rem; }
.auth-otp-sep { color: var(--kr-ink-dimmer); margin: 0 8px; }
.link-btn {
  background: none; border: none; color: var(--kr-ink-dim); cursor: pointer;
  text-decoration: underline; padding: 0; font-size: inherit;
}
.link-btn:disabled { color: var(--kr-ink-dimmer); cursor: default; text-decoration: none; }
/* 認証モーダルの同意文（アクション最優先の再構成: フォーム下の細字＋折りたたみ） */
.consent-note { color: var(--kr-ink-dim); font-size: 0.78rem; line-height: 1.6; margin: 4px 0 0; }
.consent-details { margin-top: 8px; }
.consent-details > summary { color: var(--kr-ink-dim); font-size: 0.8rem; cursor: pointer; }
.consent-details > ul { margin-top: 8px; margin-bottom: 0; }
