@font-face {
  font-family: "PromoMigMixBold";
  src: url("../fonts/migmix-1p-bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
}

@font-face {
  font-family: "PromoMigMixRegular";
  src: url("../fonts/migmix-1p-regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
}

:root {
  --promo-font-migmix_bold: "PromoMigMixBold", sans-serif;
  --promo-font-migmix_regular: "PromoMigMixRegular", sans-serif;
}

/* 生成動画と同じ縦長9:16・同じ縮尺で編集する黒バックのステージ（下の生成プレビューと同じ表示サイズ）。
   .promo-telop-stage-scaler は生成動画と同じ幅1080pxの座標系で、JS が実表示幅に合わせて
   transform: scale する（フォントサイズの px が焼き込み結果と一致する）。 */
.promo-telop-stage {
  position: relative;
  overflow: hidden;
  width: 270px; /* 生成プレビュー動画（max-width: 270px）と同じ */
  aspect-ratio: 9 / 16;
  border-radius: var(--bs-border-radius, 0.375rem);
  background: #000;
  cursor: text;
}

.promo-telop-stage-scaler {
  position: relative;
  width: 1080px;
  transform-origin: top left;
  /* 実レンダリングと同じ余白: 上96px・左右60px（テロップ最大幅 960px） */
  padding: 96px 60px 48px;
}

[data-controller="promo-tiptap-editor"] .promo-tiptap-editor {
  /* 実レンダリングと同じ「幅960の枠（左右余白60px）に左詰め」。枠いっぱいに広げて左から流す */
  color: #fff;
  caret-color: #fff;
}

[data-controller="promo-tiptap-editor"] .promo-tiptap-content {
  outline: none;
  min-height: 1.2em;
  line-height: 1.2; /* 実レンダリングは行を密に結合するため近づける */
  /* スタイル未指定の文字の既定値（PromoPlan::DEFAULT_TELOP_FONT / DEFAULT_FONT_SIZE=90「中」） */
  font-family: var(--promo-font-migmix_bold);
  font-size: 90px;
  /* 実レンダリングのスモーク影(黒ぼかし)の近似 */
  text-shadow: 0 0 8px rgba(0, 0, 0, 0.9), 0 0 16px rgba(0, 0, 0, 0.6);
}

[data-controller="promo-tiptap-editor"] .promo-tiptap-content p {
  margin: 0;
}

[data-controller="promo-tiptap-editor"] .promo-tiptap-toolbar .btn.active {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
  color: #fff;
}
