/* style.css — PROMPT ARCADE
   実在する日本のゲーム投稿サイト風（unityroom／ふりーむ系の実用トーン）。
   リンクは青、文字は小さめ、白背景＋薄いグレー罫線。装飾・絵文字UIは使わない。 */

:root{
  --link:#2f6fA8;
  --link-hover:#1d5a91;
  --cta:#e8650d;          /* 投稿ボタンだけ暖色（サイトの唯一のアクセント） */
  --cta-hover:#cf5808;
  --bg:#f4f5f6;
  --surface:#fff;
  --line:#d9dcde;
  --line-light:#e8eaec;
  --text:#333;
  --muted:#888;
  --head:#444;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--text);
  font-family:"Hiragino Kaku Gothic ProN","Yu Gothic UI","Meiryo",sans-serif;
  font-size:13px;line-height:1.8;
}
a{color:var(--link);text-decoration:none}
a:hover{color:var(--link-hover);text-decoration:underline}
img{max-width:100%}

/* ---- ヘッダー ---- */
.nav{
  background:var(--surface);border-bottom:1px solid var(--line);
  height:52px;display:flex;align-items:center;gap:18px;padding:0 16px;
}
.nav-inner{max-width:1000px;margin:0 auto;width:100%;display:flex;align-items:center;gap:18px}
.brand{display:flex;flex-direction:column;line-height:1.25;text-decoration:none}
.brand b{font-size:17px;letter-spacing:.4px;color:#222}
.brand small{font-size:10.5px;color:var(--muted);font-weight:400}
.brand:hover{text-decoration:none}
.nav .spacer{flex:1}
.nav a.link{color:#555;font-size:13px}
.nav a.link:hover{color:var(--link)}
.lang-switch{display:flex;gap:0;border:1px solid var(--line);border-radius:3px;overflow:hidden;margin-left:4px}
.lang-switch button{background:#fff;border:0;border-left:1px solid var(--line);color:#777;font-size:11.5px;padding:4px 8px;cursor:pointer;font-family:inherit}
.lang-switch button:first-child{border-left:0}
.lang-switch button.on{background:var(--link);color:#fff}
.playbar .lang-switch{margin-left:4px}
.btn{
  display:inline-block;padding:7px 16px;border-radius:3px;border:0;cursor:pointer;
  font-weight:700;font-size:13px;background:var(--cta);color:#fff;font-family:inherit;
  text-decoration:none;
}
.btn:hover{background:var(--cta-hover);color:#fff;text-decoration:none}
.btn.sub{background:#fff;color:#555;border:1px solid var(--line);font-weight:400}
.btn.sub:hover{color:var(--link);border-color:var(--link);background:#fff}

.wrap{max-width:1000px;margin:0 auto;padding:0 16px}
html{scroll-behavior:smooth}

/* ---- ヒーロー（黒×電撃イエローのキャッチー帯） ---- */
.hero{
  background:#0e0e10;color:#fff;text-align:center;
  padding:58px 20px 62px;border-bottom:5px solid #ffe000;
  position:relative;overflow:hidden;
}
.hero .sticker{position:absolute;font-size:46px;opacity:.16;user-select:none;pointer-events:none}
.hero-inner{max-width:920px;margin:0 auto;position:relative;z-index:1}
.hero .kicker{
  display:inline-block;font-size:13px;font-weight:800;letter-spacing:2px;
  color:#0e0e10;background:#ffe000;padding:5px 15px;border-radius:3px;
  transform:rotate(-1.5deg);margin-bottom:24px;
}
.hero .hero-h{
  font-size:clamp(31px,7.2vw,68px);font-weight:900;line-height:1.28;margin:0;
  letter-spacing:.5px;text-shadow:0 2px 0 rgba(0,0,0,.3);
}
.hero .hero-h .hl{
  color:#ffe000;white-space:nowrap;
  border-bottom:7px solid rgba(255,224,0,.35);padding:0 2px;
}
.hero .sub{
  color:#c9c9cf;font-size:clamp(13px,2.2vw,16px);
  margin:24px auto 0;max-width:600px;line-height:1.95;
}
.hero .cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:32px}
.hero .cta-row .btn{font-size:15px;padding:13px 30px;border-radius:4px;font-weight:700}
.hero .cta-row .btn.primary{background:#ffe000;color:#0e0e10;font-weight:900;border:0}
.hero .cta-row .btn.primary:hover{background:#ffd400;color:#0e0e10}
.hero .cta-row .btn.ghost{background:transparent;color:#fff;border:1px solid #555}
.hero .cta-row .btn.ghost:hover{border-color:#ffe000;color:#ffe000;background:transparent}

/* ---- 2カラム ---- */
.cols{display:grid;grid-template-columns:1fr 240px;gap:18px;align-items:start;margin-top:18px}
@media(max-width:820px){.cols{grid-template-columns:1fr}}

/* ---- 検索バー ---- */
.searchbar{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.searchbar input{
  flex:1;padding:9px 12px;border:1px solid var(--line);border-radius:3px;
  background:var(--surface);font-size:13px;font-family:inherit
}
.searchbar input:focus{outline:none;border-color:var(--link)}
.filter-info{font-size:12px;color:var(--muted);white-space:nowrap}
.filter-info a{font-size:12px}

/* ---- お題バナー ---- */
.theme-banner{
  background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--cta);
  border-radius:2px;padding:12px 16px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:14px
}
.theme-banner .tlabel{font-size:10.5px;color:var(--cta);font-weight:800;letter-spacing:1px}
.theme-banner .ttitle{font-size:16px;font-weight:700;color:#333}
.theme-banner .tdesc{color:var(--muted);font-size:12px;margin-top:1px}
.theme-banner .tends{margin-left:auto;color:var(--muted);font-size:12px}

/* クリック可能タグ */
.tag-link{
  display:inline-block;font-size:11.5px;color:var(--link);background:#eef3f8;border:1px solid #d3e0eb;
  border-radius:2px;padding:1px 8px;cursor:pointer
}
.tag-link:hover{background:#e1ebf5}

/* ---- 共通ボックス ---- */
.box{background:var(--surface);border:1px solid var(--line);border-radius:2px;margin-bottom:16px}
.box-head{
  font-size:13px;font-weight:700;color:var(--head);
  padding:8px 12px;border-bottom:1px solid var(--line-light);background:#fafbfb;
  display:flex;align-items:center;gap:10px
}
.box-head .more{margin-left:auto;font-weight:400;font-size:12px}
.box-body{padding:12px}

/* サイトについて（控えめな紹介文） */
.about p{margin:0;color:#555}
.about .rule-line{color:var(--muted);font-size:12px;margin-top:4px}

/* お知らせ */
.news li{list-style:none;border-bottom:1px dotted var(--line-light);padding:5px 0;font-size:12.5px}
.news li:last-child{border-bottom:0}
.news ul{margin:0;padding:0}
.news .date{color:var(--muted);margin-right:8px;font-size:11.5px}

/* サイド：テキストランキング */
.side-rank ol{margin:0;padding:0 0 0 2px;counter-reset:r}
.side-rank li{
  list-style:none;counter-increment:r;border-bottom:1px dotted var(--line-light);
  padding:6px 0;font-size:12.5px;display:flex;gap:8px;align-items:baseline
}
.side-rank li:last-child{border-bottom:0}
.side-rank li::before{
  content:counter(r);min-width:17px;height:17px;text-align:center;line-height:17px;
  background:#9aa4ab;color:#fff;font-size:11px;border-radius:2px;flex:none;font-weight:700
}
.side-rank li:nth-child(1)::before{background:#c9a13b}
.side-rank li:nth-child(2)::before{background:#9fa8b0}
.side-rank li:nth-child(3)::before{background:#ad7d52}
.side-rank .cnt{margin-left:auto;color:var(--muted);font-size:11px;flex:none}

/* ---- 並び替えタブ（テキストリンク風） ---- */
.sort-links{margin-left:auto;font-size:12px;font-weight:400;display:flex;gap:2px}
.sort-links a{color:var(--link);padding:1px 7px;border-radius:2px}
.sort-links a.active{background:var(--link);color:#fff;text-decoration:none}
.sort-links a:hover{text-decoration:none}

/* ---- 作品グリッド ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:12px}
.card{display:block;text-decoration:none}
.card:hover{text-decoration:none}
.card .thumb{
  aspect-ratio:4/3;border:1px solid var(--line);border-radius:2px;background:#fff;
  display:grid;place-items:center;overflow:hidden;position:relative
}
.card .thumb .ch{font-size:34px;font-weight:700;opacity:.9}
.card .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.card:hover .thumb{border-color:#b9c2c8}
.card h3{
  margin:6px 0 0;font-size:12.5px;line-height:1.45;font-weight:700;color:var(--link);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden
}
.card:hover h3{color:var(--link-hover);text-decoration:underline}
.card .by{color:var(--muted);font-size:11.5px;margin-top:1px}
.card .stat{color:var(--muted);font-size:11px;margin-top:1px;display:flex;gap:8px;flex-wrap:wrap}
.chip{
  display:inline-block;font-size:10.5px;color:#777;background:#f1f3f4;
  border:1px solid var(--line-light);border-radius:2px;padding:0 5px;line-height:1.6
}
.chip.log{color:#2e7d32;background:#eef6ee;border-color:#d5e8d5}

/* ---- 作品ページ ---- */
.game-head{margin:18px 0 10px}
.game-head h1{margin:0;font-size:20px;line-height:1.4}
.game-head .by{color:var(--muted);font-size:12.5px;margin-top:2px}
.game-layout{display:grid;grid-template-columns:1fr 250px;gap:18px;align-items:start}
@media(max-width:840px){.game-layout{grid-template-columns:1fr}}

.player{background:var(--surface);border:1px solid var(--line);border-radius:2px;overflow:hidden}
.player iframe{width:100%;aspect-ratio:4/3;max-height:70vh;border:0;display:block;background:#fff}
.player .player-bar{
  display:flex;align-items:center;gap:12px;background:#fafbfb;border-top:1px solid var(--line-light);
  padding:8px 12px;font-size:12px;color:var(--muted)
}
.player .player-bar .grow{flex:1}

.tabs{display:flex;gap:0;margin:18px 0 0;border-bottom:2px solid var(--line)}
.tabs button{
  background:none;border:0;color:#777;padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;
  font-family:inherit;border-bottom:2px solid transparent;margin-bottom:-2px
}
.tabs button.active{color:#333;border-bottom-color:var(--link)}
.panel{display:none;padding:14px 2px}
.panel.active{display:block}

/* メイキング（チャット風） */
.making{display:flex;flex-direction:column;gap:8px}
.note{background:#fdf8e8;border:1px solid #e8dba8;border-radius:2px;padding:10px 13px;font-size:12.5px}
.note.plain{background:#fafbfb;border-color:var(--line-light);color:var(--muted)}
.msg{max-width:88%;padding:8px 12px;border-radius:4px;font-size:12.5px;white-space:pre-wrap;border:1px solid var(--line-light)}
.msg.user{align-self:flex-end;background:#eef3f8;border-color:#d3e0eb}
.msg.ai{align-self:flex-start;background:#fff}
.msg .who{font-size:11px;color:var(--muted);margin-bottom:1px;font-weight:700}

/* サイド共通 */
.side .row{display:flex;justify-content:space-between;font-size:12.5px;padding:4px 0;border-bottom:1px dotted var(--line-light)}
.side .row:last-child{border:0}
.vote-btn{
  width:100%;display:flex;align-items:center;gap:8px;
  padding:9px 12px;border-radius:2px;border:1px solid var(--line);background:#fff;
  color:#555;font-weight:700;cursor:pointer;margin-bottom:8px;font-size:13px;font-family:inherit
}
.vote-btn:hover{border-color:#aab4bb}
.vote-btn .n{margin-left:auto;color:var(--muted);font-weight:400}
.vote-btn.on{border-color:var(--link);background:#eef3f8;color:var(--link)}
.tagrow{display:flex;flex-wrap:wrap;gap:5px}
.tagrow span{font-size:11px;color:#777;background:#f1f3f4;border:1px solid var(--line-light);border-radius:2px;padding:1px 7px}

/* ---- 単独プレイページ ---- */
.playbody{background:#26282a;display:flex;flex-direction:column;min-height:100vh}
.playbar{
  background:#fff;border-bottom:1px solid var(--line);height:46px;
  display:flex;align-items:center;gap:14px;padding:0 14px;flex:none
}
.playbar .t{font-weight:700;font-size:14px;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.playbar .grow{flex:1}
.playbar .small{font-size:12px}
.playarea{flex:1;display:grid;place-items:center;padding:14px}
.playarea iframe{
  width:min(100%,1100px);height:min(calc(100vh - 46px - 28px),825px);
  border:0;background:#fff;box-shadow:0 2px 14px rgba(0,0,0,.35)
}

/* ---- 投げ銭 ---- */
.donate-meter{margin:6px 0 16px}
.donate-meter .dm-total{font-size:14px;color:#333}
.donate-meter .dm-total b{font-size:18px;color:var(--cta)}
.donate-meter .dm-total span{color:var(--muted);font-size:12px;margin-left:4px}
.amount-btns{display:flex;gap:8px;flex-wrap:wrap}
.amount-btns button{
  border:1px solid var(--line);background:#fff;border-radius:3px;padding:8px 16px;
  font-size:14px;font-weight:700;color:#555;cursor:pointer;font-family:inherit
}
.amount-btns button:hover{border-color:var(--cta)}
.amount-btns button.on{background:var(--cta);color:#fff;border-color:var(--cta)}
.wall-item{border-bottom:1px dotted var(--line-light);padding:7px 0;font-size:12.5px}
.wall-item:last-child{border-bottom:0}
.wall-amt{color:var(--cta);font-size:11.5px;margin-left:6px}
.wall-msg{color:#555;margin-top:1px}

/* ---- フォーム ---- */
.form{max-width:620px;margin:22px auto 50px;background:var(--surface);border:1px solid var(--line);border-radius:2px;padding:22px 26px}
.form h1{margin:0 0 4px;font-size:19px}
.form .field{margin-bottom:15px}
.form label{display:block;font-weight:700;font-size:12.5px;margin-bottom:4px}
.form label .req{color:#c0392b;font-size:11px;margin-left:6px}
.form label .opt{color:#999;font-size:11px;margin-left:6px;font-weight:400}
.form input,.form textarea{
  width:100%;padding:8px 10px;border-radius:2px;border:1px solid #c7ccd0;
  background:#fff;color:var(--text);font-size:13px;font-family:inherit
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--link)}
.form textarea{min-height:80px;resize:vertical}
.form .hint{font-size:11.5px;color:var(--muted);margin-top:3px}
.form .err{color:#c0392b;font-size:12.5px;margin:6px 0;min-height:18px}
details.optional{border:1px solid var(--line);border-radius:2px;background:#fafbfb;padding:0 13px;margin-bottom:15px}
details.optional summary{cursor:pointer;font-weight:700;font-size:12.5px;color:#666;padding:9px 0}
details.optional[open]{padding-bottom:8px}

/* AIに貼るだけ：プロンプトテンプレ */
details.prompt-help{border:1px solid #d8e6f2;border-radius:2px;background:#f4f9fe;padding:0 13px;margin:0 0 16px}
details.prompt-help summary{cursor:pointer;font-weight:700;font-size:13px;color:var(--link);padding:11px 0}
details.prompt-help[open]{padding-bottom:12px}
details.prompt-help .hint{font-size:12px;color:var(--muted);margin:0 0 8px;line-height:1.6}
details.prompt-help textarea{width:100%;min-height:200px;resize:vertical;padding:10px;border:1px solid #c7ccd0;border-radius:2px;
  background:#fff;color:var(--text);font-size:12px;line-height:1.55;font-family:"SFMono-Regular",Consolas,"Courier New",monospace}
details.prompt-help #copyTpl{margin-top:8px}

/* 使用AIチップ */
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}
.chips .chip-item{
  display:inline-flex;align-items:center;gap:5px;font-size:12px;background:#eef3f8;color:#41617d;
  border:1px solid #d3e0eb;border-radius:2px;padding:2px 8px
}
.chips .chip-item button{border:0;background:none;color:#888;cursor:pointer;font-size:13px;padding:0;line-height:1}
.ai-suggest{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.ai-suggest button{
  font-size:11.5px;border:1px solid var(--line);background:#fff;border-radius:2px;
  padding:2px 9px;color:#777;cursor:pointer;font-family:inherit
}
.ai-suggest button:hover{border-color:var(--link);color:var(--link)}

/* ---- ルール ---- */
.rules{background:var(--surface);border:1px solid var(--line);border-radius:2px;padding:22px 28px;margin:22px 0 50px}
.rules h1{font-size:19px;margin:0 0 12px}
.rules h2{font-size:14.5px;margin:24px 0 8px;border-left:4px solid var(--link);padding-left:9px}
.rules table{width:100%;border-collapse:collapse;margin:10px 0;font-size:12.5px}
.rules th,.rules td{border:1px solid var(--line);padding:7px 10px;text-align:left;vertical-align:top}
.rules th{background:#fafbfb;color:#777}
.ok{color:#2e7d32;font-weight:800}
.ng{color:#c0392b;font-weight:800}
.gray{color:#41617d;font-weight:800}
.rules .lead{background:#fdf8e8;border:1px solid #e8dba8;border-radius:2px;padding:12px 16px;font-size:13px}

/* ---- フッター ---- */
.footer{
  border-top:1px solid var(--line);margin-top:36px;padding:18px 16px 26px;
  background:var(--surface);color:#999;font-size:12px
}
.footer-inner{max-width:1000px;margin:0 auto}
.footer-links{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:8px}
.footer-links a{color:#777}
.footer .copy{color:#aaa;font-size:11.5px}

/* ---- 広告枠（AdSense） ---- */
/* 未設定時は ads.js が display:none にする。表示時はサイドの箱に馴染ませる */
.ad-slot{margin-bottom:16px;min-height:0;overflow:hidden;text-align:center}
.ad-slot ins{display:block}

/* ---- 共有・埋め込み ---- */
.share-row{display:flex;gap:6px;flex-wrap:wrap}
.share-btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;padding:6px 13px;border-radius:3px;
  border:1px solid var(--line);background:#fff;color:#555;cursor:pointer;
  text-decoration:none;font-family:inherit;
}
.share-btn:hover{text-decoration:none}
.share-btn.x{background:#0e0e10;color:#fff;border-color:#0e0e10}
.share-btn.reddit{background:#ff4500;color:#fff;border-color:#ff4500}
.share-btn.line{background:#06c755;color:#fff;border-color:#06c755}
.share-btn.copy:hover{border-color:var(--link);color:var(--link)}
.embed-box{margin-top:10px}
.embed-box summary{cursor:pointer;font-size:12.5px;font-weight:700;color:#666}
.embed-code{width:100%;font-family:ui-monospace,monospace;font-size:11px;border:1px solid var(--line);border-radius:3px;padding:6px}
.new-banner{
  background:#fff8e1;border:1px solid #f0d98a;border-radius:3px;
  padding:11px 14px;font-weight:700;color:#7a5d00;margin:14px 0 0;font-size:13.5px;
}

.toast{
  position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(16px);
  background:#333;color:#fff;padding:9px 20px;border-radius:3px;font-weight:700;font-size:12.5px;
  opacity:0;transition:.22s;z-index:50;pointer-events:none
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.loading{color:var(--muted);text-align:center;padding:36px;font-size:12.5px}

/* ============ スマホ最適化（〜600px） ============ */
@media (max-width:600px){
  /* ナビ：肩書きとテキストリンクは隠し、ロゴ＋投稿ボタン＋言語切替だけに */
  .nav{height:auto;padding:8px 12px}
  .nav-inner{gap:10px}
  .brand b{font-size:16px}
  .brand small{display:none}
  .nav a.link{display:none}
  .nav .btn{padding:6px 12px}

  /* ヒーロー：余白と文字を詰め、下段ステッカーは非表示 */
  .hero{padding:38px 16px 42px}
  .hero .hero-h{font-size:clamp(26px,8.2vw,60px);line-height:1.3}
  .hero .sub{margin-top:18px;line-height:1.85}
  .hero .kicker{margin-bottom:18px}
  .hero .cta-row{margin-top:24px;gap:10px}
  .hero .cta-row .btn{flex:1 1 auto;text-align:center;padding:12px 14px;font-size:14px}
  .hero .sticker{font-size:26px;opacity:.12}
  .hero .sticker:nth-of-type(3),
  .hero .sticker:nth-of-type(4){display:none}

  /* 一覧：2カラム＋詰め。検索バーは折り返し可 */
  .cols{gap:14px;margin-top:14px}
  .searchbar{flex-wrap:wrap;gap:8px}
  .grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}

  /* 作品ページ：プレイヤーバーは折り返し */
  .game-head h1{font-size:18px}
  .game-layout{gap:14px}
  .player-bar{flex-wrap:wrap;gap:8px}
  .player-bar .grow{flex-basis:100%;height:0}
  .player iframe{max-height:62vh}

  /* フォーム・ルール：余白を詰める／表は横スクロール可 */
  .form{padding:18px 15px;margin:16px auto 40px}
  .rules{padding:18px 15px}
  .rules h1{font-size:18px}
  .rules table{display:block;overflow-x:auto;white-space:nowrap}
  .rules td:nth-child(2){white-space:normal;min-width:220px}
  #list{overflow-x:auto}

  /* 単独プレイページ：バーを折り返し、ゲーム領域を最大化 */
  .playbar{height:auto;min-height:46px;flex-wrap:wrap;gap:8px;padding:7px 10px}
  .playbar .t{max-width:46vw}
  .playarea{padding:10px}
  .playarea iframe{width:100%;height:min(calc(100vh - 120px),900px)}
}

/* ごく狭い端末（〜380px）：見出しと余白をさらに調整 */
@media (max-width:380px){
  .brand b{font-size:15px}
  .hero .hero-h{font-size:clamp(23px,8.6vw,40px)}
  .grid{grid-template-columns:1fr 1fr;gap:8px}
}
