/* ディスプレイ書体：Saira Condensed（テクニカル/レーシング）。数字・見出し・LIVE等に使う */
@font-face {
  font-family: "Saira Cond";
  src: url("/fonts/SairaCondensed-Black.ttf") format("truetype");
  font-weight: 900; font-display: swap;
}
@font-face {
  font-family: "Saira Cond";
  src: url("/fonts/SairaCondensed-Bold.ttf") format("truetype");
  font-weight: 700; font-display: swap;
}

:root {
  /* カーボン×レーシングレッドで全サービス統一 */
  --bg: #0a0a0d;            /* カーボンブラック */
  --bg-elev: #16161c;       /* パネル */
  --bg-elev2: #20202a;      /* 一段上 */
  --border: #2d2d37;        /* 中立ヘアライン */
  --border-red: rgba(255, 45, 63, .26); /* 赤ヘアライン */
  --text: #e9ecf1;
  --text-dim: #8b909c;
  --accent: #ff2d3f;        /* 主役＝レーシングレッド（旧シアン） */
  --accent-2: #c10500;      /* 深い赤（グラデの相方・旧ティール） */
  --rev: #e10600;           /* レーシングレッド */
  --rev-2: #ff2d3f;         /* 明るい赤（グロー用） */
  --gold: #ffcf4a;
  --display: "Saira Cond", "Hiragino Kaku Gothic ProN", "Noto Sans JP", sans-serif;
  --danger: #ff5572;
  --warn: #ffb020;
  --ok: #2ee6a0;
  --radius: 12px;
  --shadow: 0 8px 28px rgba(0, 0, 0, 0.45);
  --font: "Segoe UI", "Hiragino Kaku Gothic ProN", "Noto Sans JP", system-ui, sans-serif;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: var(--font);
  background:
    repeating-linear-gradient(118deg, transparent 0 44px, rgba(225, 6, 0, 0.035) 44px 45px),
    radial-gradient(1100px 620px at 50% -14%, rgba(225, 6, 0, 0.34), transparent 60%),
    radial-gradient(760px 520px at 102% 102%, rgba(225, 6, 0, 0.14), transparent 55%),
    radial-gradient(680px 520px at -4% 96%, rgba(225, 6, 0, 0.08), transparent 55%),
    #08090c;
  background-attachment: fixed;
  color: var(--text);
  min-height: 100vh;
  line-height: 1.6;
  overflow-x: hidden;   /* ライブ順位の右スライドインで横スクロールバーを出さない */
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

h1, h2, h3 { line-height: 1.25; margin: 0 0 .5em; }
h1 { font-size: 1.7rem; letter-spacing: .02em; }
h2 { font-size: 1.25rem; }
h3 { font-size: 1.05rem; }

.muted { color: var(--text-dim); }
.small { font-size: .85rem; }
.right { text-align: right; }
.center { text-align: center; }
.row { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.spread { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.stack > * + * { margin-top: 14px; }
.grow { flex: 1; }

/* ---- ブランド ---- */
.brand {
  font-family: var(--display);
  font-weight: 900;
  font-size: 1.55rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  background: linear-gradient(92deg, #fff 0%, var(--rev-2) 55%, var(--rev) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  filter: drop-shadow(0 0 14px rgba(225, 6, 0, .35));
}

/* ---- ヘッダー ---- */
.topbar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 22px;
  background: rgba(10, 10, 13, 0.82);
  border-bottom: 1px solid rgba(255, 45, 63, .22);
  box-shadow: 0 1px 0 rgba(225, 6, 0, .25), 0 8px 24px -16px rgba(225, 6, 0, .5);
  backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 10;
}
.topbar .nav { display: flex; gap: 18px; align-items: center; }

/* ---- レイアウト ---- */
.container { max-width: 1080px; margin: 0 auto; padding: 24px 22px 80px; }
.narrow { max-width: 460px; }

/* ---- カード ---- */
.card {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
  box-shadow: var(--shadow);
}
.card + .card { margin-top: 16px; }

.grid { display: grid; gap: 16px; }
.grid.cols-2 { grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }

/* ---- ボタン ---- */
.btn {
  display: inline-flex; align-items: center; gap: 8px; justify-content: center;
  padding: 10px 16px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg-elev2);
  color: var(--text);
  font-size: .95rem; font-weight: 600;
  cursor: pointer;
  transition: .15s;
  text-decoration: none;
}
.btn:hover { border-color: var(--accent); text-decoration: none; }
.btn.primary {
  background: linear-gradient(100deg, var(--rev-2), var(--rev) 70%);
  color: #fff; border: none; font-weight: 700;
  box-shadow: 0 6px 20px -8px rgba(225, 6, 0, .8);
}
.btn.primary:hover { filter: brightness(1.1); box-shadow: 0 8px 24px -8px rgba(225, 6, 0, .95); }
.btn.danger { color: var(--danger); border-color: #4a2330; }
.btn.danger:hover { background: #2a141b; border-color: var(--danger); }
.btn.sm { padding: 6px 11px; font-size: .82rem; }
.btn:disabled { opacity: .5; cursor: not-allowed; }

/* ---- フォーム ---- */
label { display: block; font-size: .88rem; color: var(--text); font-weight: 600; margin-bottom: 6px; }
/* ラベル内に混ざった説明文は今のまま（細字・薄色） */
label .muted, label .small { font-weight: 400; }
input, select, textarea {
  width: 100%;
  padding: 10px 12px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--text);
  font-size: .95rem;
  font-family: inherit;
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent); }
/* ファイル選択：ネイティブの素のボタン＋「選択されていません」が潰れて崩れるのを整える */
input[type=file] {
  width: auto;
  /* 自動幅だとボタン横の「選択されていません」が入りきらず切れるので最低幅を確保（狭い画面では親幅まで） */
  min-width: min(100%, 19rem);
  max-width: 100%;
  padding: 7px 10px;
  font-size: .82rem;
  color: var(--text-dim);
  cursor: pointer;
}
input[type=file]::file-selector-button,
input[type=file]::-webkit-file-upload-button {
  margin-right: 12px;
  padding: 8px 15px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg-elev2);
  color: var(--text);
  font-weight: 600;
  font-size: .85rem;
  font-family: inherit;
  cursor: pointer;
  transition: border-color .15s, color .15s;
}
input[type=file]::file-selector-button:hover { border-color: var(--accent); color: var(--accent); }
/* ファイル選択ボックス（ボタン＋アップロード済み画像のサムネイルを枠の中に表示） */
.filebox { display: flex; align-items: center; gap: 10px; padding: 6px 8px; background: var(--bg); border: 1px solid var(--border); border-radius: 10px; min-width: min(100%, 19rem); max-width: 100%; }
.filebox .fb-thumb { height: 34px; max-width: 130px; object-fit: contain; border-radius: 6px; background: #fff; flex: none; }
.filebox .fb-empty { color: var(--text-dim); font-size: .85rem; }
.filebox .fb-spacer { flex: 1; }
/* 日付・時刻のカレンダー/時計アイコンをダークテーマで見えるように＋クリックしやすく */
input[type=date], input[type=time], input[type=month], input[type="datetime-local"] { cursor: pointer; }
input[type=date]::-webkit-calendar-picker-indicator,
input[type=time]::-webkit-calendar-picker-indicator,
input[type=month]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator {
  filter: invert(0.85);
  opacity: .8;
  cursor: pointer;
}
.field { margin-bottom: 14px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

/* ---- テーブル ---- */
table { width: 100%; border-collapse: collapse; }
th, td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--border); }
th { color: var(--text-dim); font-size: .8rem; font-weight: 600; text-transform: uppercase; letter-spacing: .03em; }
tbody tr:hover { background: rgba(255,255,255,0.02); }

/* ---- バッジ ---- */
.badge {
  display: inline-block; padding: 2px 10px; border-radius: 999px;
  font-size: .75rem; font-weight: 700; border: 1px solid var(--border);
}
.badge.draft { color: var(--text-dim); }
.badge.active { color: var(--ok); border-color: #1c4d3a; background: #0f261d; }
.badge.finished { color: var(--accent); border-color: #1d3a4d; background: #0f1f29; }
.badge.archived { color: var(--text-dim); }

/* ---- アラート ---- */
.alert { padding: 11px 14px; border-radius: 10px; font-size: .9rem; margin-bottom: 14px; }
.alert.error { background: #2a141b; color: #ffb3c0; border: 1px solid #4a2330; }
.alert.ok { background: #0f261d; color: #9af2cf; border: 1px solid #1c4d3a; }
.hidden { display: none !important; }

/* ---- 空状態 ---- */
.empty { text-align: center; padding: 40px 20px; color: var(--text-dim); }

/* ---- アイコン（SVG・絵文字の代替・currentColor追従） ---- */
[data-ic] svg, .ic svg, .ico svg { width: 1em; height: 1em; vertical-align: -0.14em; display: inline-block; }
[data-ic], .ic { display: inline-flex; align-items: center; }

@media (max-width: 560px) {
  .field-row { grid-template-columns: 1fr; }
  .container { padding: 16px 12px 64px; }
  /* スマホ運営：表は横スクロールで見切れないように（レイアウト崩れ防止） */
  .card table { display: block; overflow-x: auto; white-space: nowrap; -webkit-overflow-scrolling: touch; }
  th, td { padding: 8px 10px; }
  /* モーダルは画面いっぱい近くに */
  [id*="modal"] > .card { max-width: 100% !important; }
  .btn { padding: 9px 13px; }
}
