/* ============================================================
   Syn3Chat laugh.css v1.1
   AIお喋りTab — 3Dスロット / カテゴリボタン / 結果カード
   ============================================================ */

/* ================= AIお喋りビュー ================= */
#view-laugh{
  flex:1;display:none;flex-direction:column;min-height:0;overflow:hidden;
  padding:14px 0 0;
}
#view-laugh.active{display:flex}

.laugh-wrap{
  max-width:860px;margin:0 auto;width:100%;
  display:flex;flex-direction:column;gap:14px;flex:1;min-height:0;
  padding:0 14px 14px;
}

/* ---- カテゴリボタン群 ---- */
.cat-row{
  display:flex;flex-wrap:wrap;gap:6px;justify-content:center;flex-shrink:0;
}
.cat-btn{
  padding:7px 14px;border-radius:22px;cursor:pointer;
  background:rgba(255,255,255,.85);border:1.5px solid rgba(14,165,233,.22);
  font:800 12px 'Sora',sans-serif;color:var(--txt2);
  display:flex;align-items:center;gap:6px;
  transition:all .18s;box-shadow:var(--shadow-sm);
  user-select:none;
}
.cat-btn:hover{
  background:#fff;transform:translateY(-1px);
  box-shadow:0 4px 14px rgba(14,165,233,.18);
  border-color:var(--brand-sky);
}
.cat-btn.active{
  background:var(--brand-grad);color:#fff;border-color:transparent;
  box-shadow:0 4px 16px rgba(14,165,233,.4);
}
.cat-btn .cat-emoji{font-size:15px}

/* ---- スロット中央ブロック ---- */
.slot-block{
  background:linear-gradient(135deg,#fff 0%,rgba(255,255,255,.94) 100%);
  border:1px solid rgba(14,165,233,.2);border-radius:18px;
  padding:18px 20px 16px;box-shadow:var(--shadow-md);
  display:flex;flex-direction:column;align-items:center;gap:12px;
  flex-shrink:0;position:relative;overflow:hidden;
}
.slot-block::before{
  content:'';position:absolute;top:-50%;right:-20%;width:300px;height:300px;
  background:radial-gradient(circle,rgba(249,115,22,.06),transparent 70%);
  pointer-events:none;
}
.slot-title{
  font:800 13px 'Sora',sans-serif;color:var(--txt2);
  display:flex;align-items:center;gap:8px;
}
.slot-title .slot-cat-badge{
  font:700 10px 'JetBrains Mono',monospace;
  padding:3px 10px;background:rgba(249,115,22,.12);color:var(--brand-orange);
  border:1px solid rgba(249,115,22,.3);border-radius:14px;
}

/* ---- 3Dドラム式スロット (CSS 3D) ---- */
.slot-drums{
  display:flex;gap:10px;perspective:800px;
  padding:6px 0;
}
.drum{
  width:120px;height:78px;border-radius:12px;
  background:linear-gradient(180deg,#f8fafc,#e2e8f0);
  border:2px solid rgba(0,0,0,.12);
  box-shadow:
    inset 0 3px 8px rgba(0,0,0,.15),
    inset 0 -3px 8px rgba(0,0,0,.15),
    0 2px 6px rgba(0,0,0,.08);
  position:relative;overflow:hidden;
  transform-style:preserve-3d;
}
.drum::before,.drum::after{
  content:'';position:absolute;left:0;right:0;height:18px;z-index:3;pointer-events:none;
}
.drum::before{top:0;background:linear-gradient(180deg,rgba(255,255,255,.85),transparent)}
.drum::after{bottom:0;background:linear-gradient(0deg,rgba(0,0,0,.15),transparent)}
.drum-inner{
  position:absolute;inset:0;display:flex;flex-direction:column;
  transition:transform .08s linear;
  will-change:transform;
}
.drum.spinning .drum-inner{transition:none}
.drum-item{
  height:78px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  font:800 13px 'Sora',sans-serif;color:var(--txt);
  text-align:center;padding:6px 8px;letter-spacing:-.3px;
  line-height:1.3;
}
.drum.result-777{
  border-color:#fbbf24;
  animation:drum777 .6s ease infinite;
  box-shadow:
    inset 0 3px 8px rgba(251,191,36,.4),
    inset 0 -3px 8px rgba(251,191,36,.4),
    0 0 18px rgba(251,191,36,.7);
}
@keyframes drum777{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}

/* ---- スロット操作ボタン ---- */
.slot-ctrl{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.slot-btn{
  padding:10px 22px;border-radius:10px;cursor:pointer;border:none;
  font:800 13px 'Sora',sans-serif;
  transition:all .16s;display:flex;align-items:center;gap:6px;
  letter-spacing:-.2px;
}
.slot-btn-spin{
  background:linear-gradient(135deg,#f97316,#dc2626);color:#fff;
  box-shadow:0 4px 14px rgba(249,115,22,.4);
}
.slot-btn-spin:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(249,115,22,.55)}
.slot-btn-stop{
  background:linear-gradient(135deg,#1e293b,#334155);color:#fff;
  box-shadow:0 4px 14px rgba(30,41,59,.3);
}
.slot-btn-stop:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(30,41,59,.45)}
.slot-btn-3ai{
  background:var(--brand-grad);color:#fff;
  box-shadow:0 4px 14px rgba(139,92,246,.4);
}
.slot-btn-3ai:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(139,92,246,.55)}
.slot-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}

/* ---- 777 ボーナス演出 ---- */
.bonus-flash{
  position:fixed;inset:0;z-index:500;pointer-events:none;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 50%,rgba(251,191,36,.5),transparent 60%);
  animation:bonusFlash 1.6s ease forwards;
}
.bonus-flash .bonus-inner{
  font:900 56px 'Sora',sans-serif;
  background:linear-gradient(135deg,#fbbf24,#f97316,#dc2626);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 4px 20px rgba(249,115,22,.6);
  letter-spacing:-2px;
}
.bonus-flash .bonus-tok{
  position:absolute;top:62%;left:50%;transform:translateX(-50%);
  font:800 16px 'JetBrains Mono',monospace;color:#fff;
  padding:6px 18px;background:rgba(30,41,59,.85);border-radius:20px;
  backdrop-filter:blur(8px);
}
@keyframes bonusFlash{
  0%{opacity:0;transform:scale(.6)}
  30%{opacity:1;transform:scale(1.15)}
  70%{opacity:1;transform:scale(1)}
  100%{opacity:0;transform:scale(1.05)}
}

/* ---- お題表示 (スロット停止後) ---- */
.topic-display{
  background:linear-gradient(135deg,rgba(249,115,22,.08),rgba(139,92,246,.06));
  border:2px dashed rgba(249,115,22,.3);border-radius:14px;
  padding:14px 20px;text-align:center;flex-shrink:0;
  animation:topicIn .4s ease;
}
@keyframes topicIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.topic-label{font:700 10px 'JetBrains Mono',monospace;color:var(--brand-orange);letter-spacing:.8px;margin-bottom:4px}
.topic-text{font:800 16px 'Sora',sans-serif;color:var(--txt);letter-spacing:-.3px;line-height:1.4}

/* ---- 自由入力ボックス ---- */
.freeform-box{
  display:none;flex-shrink:0;background:#fff;border-radius:14px;border:1.5px solid rgba(14,165,233,.25);
  padding:14px;box-shadow:var(--shadow-sm);
}
.freeform-box.show{display:block}
.freeform-box label{
  display:block;font:700 10px 'JetBrains Mono',monospace;color:var(--txt3);margin-bottom:6px;letter-spacing:.5px;
}
.freeform-input{
  width:100%;padding:10px 14px;border-radius:9px;border:1px solid rgba(14,165,233,.22);
  font:600 14px 'Noto Sans JP',sans-serif;color:var(--txt);outline:none;background:#f8fafc;
}
.freeform-input:focus{border-color:var(--brand-sky);background:#fff;box-shadow:0 0 0 3px rgba(14,165,233,.12)}

/* ---- 3AI回答カード (AIお喋り用) ---- */
.laugh-results{
  flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;min-height:0;
  padding-right:2px;
}
.laugh-card{
  background:#fff;border-radius:14px;padding:12px 14px;
  border:1px solid rgba(0,0,0,.08);box-shadow:var(--shadow-sm);
  animation:cardIn .3s ease;
}
@keyframes cardIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.laugh-card.c-claude{border-left:4px solid var(--claude)}
.laugh-card.c-gpt{border-left:4px solid var(--gpt)}
.laugh-card.c-grok{border-left:4px solid var(--grok)}

.laugh-card-head{
  display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap;
}
.laugh-ai-icon{
  width:24px;height:24px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  font:800 12px 'Sora',sans-serif;color:#fff;
}
.c-claude .laugh-ai-icon{background:linear-gradient(135deg,#f97316,#b45309)}
.c-gpt .laugh-ai-icon{background:linear-gradient(135deg,#10b981,#047857)}
.c-grok .laugh-ai-icon{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}
.laugh-ai-name{font:800 12px 'Sora',sans-serif}
.c-claude .laugh-ai-name{color:var(--claude)}
.c-gpt .laugh-ai-name{color:var(--gpt)}
.c-grok .laugh-ai-name{color:var(--grok)}
.laugh-mode-badge{
  font:700 9px 'JetBrains Mono',monospace;padding:1px 7px;border-radius:10px;
  background:rgba(148,163,184,.12);color:var(--txt3);border:1px solid rgba(148,163,184,.22);
}
.laugh-card-body{
  font-size:13.5px;line-height:1.6;color:var(--txt);white-space:pre-wrap;word-wrap:break-word;
}
.laugh-thinking{
  font:500 11px 'JetBrains Mono',monospace;color:var(--txt4);
  display:flex;align-items:center;gap:5px;
}
.laugh-thinking::after{
  content:'...';animation:thinkDot 1.2s steps(4) infinite;
}
@keyframes thinkDot{
  0%,25%{content:''}
  50%{content:'.'}
  75%{content:'..'}
  100%{content:'...'}
}

/* ---- アクションバー (シェア/もう一回) ---- */
.laugh-actions{
  display:flex;gap:8px;justify-content:center;flex-wrap:wrap;
  padding:4px 0;flex-shrink:0;
}
.share-btn,.again-btn{
  padding:8px 18px;border-radius:22px;cursor:pointer;border:none;
  font:800 12px 'Sora',sans-serif;
  display:flex;align-items:center;gap:6px;transition:all .16s;
}
.share-btn{
  background:linear-gradient(135deg,#000,#1e293b);color:#fff;
  box-shadow:0 3px 10px rgba(0,0,0,.25);
}
.share-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.35)}
.again-btn{
  background:#fff;color:var(--brand-orange);border:2px solid rgba(249,115,22,.35);
}
.again-btn:hover{background:rgba(249,115,22,.08);border-color:var(--brand-orange)}

/* ---- ゲーム1 (スライム) ---- */
#view-game1,#view-game2{
  flex:1;display:none;overflow-y:auto;min-height:0;padding:10px;
}
#view-game1.active,#view-game2.active{display:block}
.game-wrap{
  max-width:520px;margin:0 auto;padding:20px 16px;
  background:rgba(255,255,255,.92);border-radius:14px;
  box-shadow:var(--shadow-md);border:1px solid rgba(14,165,233,.18);
}
.game-placeholder{
  padding:60px 24px;text-align:center;color:var(--txt4);
  background:rgba(255,255,255,.85);border-radius:14px;border:2px dashed rgba(14,165,233,.22);
  max-width:500px;margin:40px auto;
}
.game-placeholder .ph-emoji{font-size:48px;margin-bottom:10px;opacity:.5}
.game-placeholder .ph-title{font:800 14px 'Sora',sans-serif;color:var(--txt2);margin-bottom:6px}
.game-placeholder .ph-desc{font-size:12px;color:var(--txt3);line-height:1.6}

/* ---- 管理パネル ---- */
#view-adm{display:none;flex:1;overflow-y:auto;padding:12px;min-height:0}
#view-adm.active{display:block}
.adm-title{font:800 14px 'Sora',sans-serif;color:var(--err);margin-bottom:12px;padding:8px 12px;background:rgba(185,28,28,.06);border-radius:8px;border-left:4px solid var(--err)}
.adm-section{background:#fff;border-radius:10px;padding:12px;margin-bottom:12px;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.08)}
.adm-section-title{font:800 11px 'Sora',sans-serif;color:var(--txt2);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.adm-add-row{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.adm-add-input{padding:6px 9px;border-radius:6px;border:1px solid rgba(0,0,0,.14);font-size:11px;color:var(--txt);background:#fff;outline:none}
.adm-add-input:focus{border-color:var(--brand-sky)}
.adm-btn{padding:6px 13px;border-radius:6px;cursor:pointer;border:none;font:700 10px 'Sora',sans-serif;transition:all .14s}
.adm-btn-save{background:var(--brand-sky);color:#fff}
.adm-btn-save:hover{background:#0284c7}
.adm-btn-del{background:rgba(185,28,28,.1);color:var(--err);border:1px solid rgba(185,28,28,.3)}
.adm-btn-del:hover{background:rgba(185,28,28,.2)}
.adm-refresh-btn{margin-left:auto;padding:4px 10px;background:rgba(14,165,233,.1);color:var(--brand-sky);border:1px solid rgba(14,165,233,.3);border-radius:6px;cursor:pointer;font:700 10px 'JetBrains Mono',monospace}
.adm-msg{font:600 11px 'JetBrains Mono',monospace;margin-top:8px;padding:6px 10px;border-radius:6px;display:none}
.adm-msg.show{display:block}
.adm-msg.ok{background:rgba(4,120,87,.08);color:var(--ok);border:1px solid rgba(4,120,87,.22)}
.adm-msg.err{background:rgba(185,28,28,.08);color:var(--err);border:1px solid rgba(185,28,28,.22)}
.adm-user-row{display:grid;grid-template-columns:70px 90px 90px 140px 80px 80px auto;gap:5px;padding:6px;border-bottom:1px solid rgba(0,0,0,.06);align-items:center;font-size:11px}
.adm-user-row.head{font:800 10px 'JetBrains Mono',monospace;color:var(--txt3);background:rgba(14,165,233,.04);border-radius:5px;padding:6px;margin-bottom:4px}
.adm-user-row input{padding:4px 7px;border-radius:5px;border:1px solid rgba(0,0,0,.14);font-size:10px;outline:none;background:#fff}
.adm-user-role{padding:1px 6px;border-radius:3px;font:800 8px 'JetBrains Mono',monospace}
.adm-user-role.admin{background:rgba(185,28,28,.12);color:var(--err)}
.adm-user-role.user{background:rgba(14,165,233,.1);color:var(--brand-sky)}
