/* Upload layout + cards */
.wrap{max-width:1000px;margin:40px auto;padding:0 16px;}
h1{font-size:28px;margin:16px 0 14px;text-align:center;}

.card{
  background:var(--panel);border:1px solid var(--border);
  border-radius:14px;padding:16px;margin-bottom:16px;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}

.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:900px){.grid{grid-template-columns:1fr}}

label{display:block;font-weight:600;margin-bottom:6px;color:var(--muted)}

/* 入力系コンポーネントまわり */
input[type=text], textarea, select, input[type=number]{
  display:block;width:100%;
  background:#ffffff;border:1px solid var(--border);color:var(--fg);
  padding:10px 12px;border-radius:10px;outline:none;font:inherit;
  transition:border-color .15s ease, box-shadow .15s ease;
}
input:focus, textarea:focus, select:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(79,140,255,.15);
}
textarea{min-height:140px;resize:vertical}

/* ドロップゾーン */
.drop{
  border:2px dashed #cbd5e1;border-radius:14px;padding:24px;text-align:center;
  background:linear-gradient(180deg, rgba(79,140,255,.06), transparent);
  transition:.15s border-color; cursor:pointer;
}
.drop.drag{border-color:var(--accent)}

.muted{color:var(--muted)}

/* ボタン類 */
.btn{
  appearance:none;border:none;background:var(--accent);color:white;font-weight:700;
  padding:10px 14px;border-radius:10px;cursor:pointer;transition:.15s transform ease, opacity .15s, background-color .15s ease;
}
.btn:disabled{opacity:.6;cursor:not-allowed}
.btn:active{transform:translateY(1px)}
.btn.gray{background:#e5e7eb;color:#111}
.btn.green{background:var(--accent-2)}
.btn.orange{background:var(--warn)}
.btn.orange:hover{background:#d97706}
.btn.orange:focus-visible{box-shadow:0 0 0 3px rgba(245,158,11,.3)}
.hint{font-size:12px;color:var(--muted)}

/* 進捗バー */
.bar{height:10px;background:#f3f4f6;border:1px solid var(--border);border-radius:999px;overflow:hidden}
.bar>i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),#7c4dff)}
.ok{color:var(--accent-2)} .warn{color:var(--warn)} .err{color:var(--danger)}

/* JSON 表示用コードブロック */
pre{background:#f8fafc;border:1px solid var(--border);padding:12px;border-radius:12px;overflow:auto;max-height:420px}
code{font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;font-size:12px}
.pill{display:inline-block;border:1px solid var(--border);padding:4px 8px;border-radius:999px;color:var(--muted)}
.foot{margin-top:8px;color:var(--muted);font-size:12px}

/* 自動抽出サムネイルのグリッド */
.thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media (max-width:720px){.thumbs{grid-template-columns:repeat(2,1fr)}}
.thumb{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#ffffff;}
.thumb img{display:block;width:100%;height:auto}
.thumb figcaption{font-size:12px;color:var(--muted);padding:6px 8px;display:flex;justify-content:space-between;align-items:center}
.thumb a{color:var(--muted);text-decoration:none}
.thumb a:hover{color:#111;text-decoration:underline}

/* 動画プレビュー */
.preview{display:block;width:100%;max-height:320px;object-fit:contain;background:#f8fafc;border:1px solid var(--border);border-radius:12px}
.previewRow{display:flex;justify-content:space-between;align-items:center;margin-top:8px;color:var(--muted);font-size:12px;gap:8px}

/* 出品フォームのレイアウト調整 */
.formgrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  grid-auto-flow:row dense;    
  align-items:start;
}
@media (max-width:900px){ .formgrid{grid-template-columns:1fr} }

.field{ display:flex; flex-direction:column; gap:6px; }
.field.full{ grid-column:1 / -1; }    
.stack > * + *{ margin-top:8px; }     
.actions{display:flex;flex-wrap:wrap;gap:8px}
#publishCard .actions{justify-content:center}

/* カバー画像セレクタ */
.coverGrid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
@media (max-width:900px){.coverGrid{grid-template-columns:repeat(3,1fr)}}
.coverItem{position:relative;border:1px solid var(--border);border-radius:10px;overflow:hidden}
.coverItem input{position:absolute;inset:8px auto auto 8px;scale:1.2}
.coverItem img{display:block;width:100%;height:auto}

.small{font-size:12px}