/* =====================================================================
   助動詞・仮定法 完全制覇アプリ — AIはらだくん共通デザイン
   （ハブ harada-aiharadakun と同じ配色・フォント体系）
   ===================================================================== */
:root{
  --bg:#0f1226; --panel:#1a1d3a; --panel2:#22264a; --ink:#eef0ff;
  --muted:#a6acd6; --accent:#ffd166; --accent2:#06d6a0; --pink:#ef476f;
  --blue:#3a86ff; --border:#343a6e;
  --headgrad:linear-gradient(120deg,#3a1c71,#d76d77,#ffaf7b);
  --ok:#0f4d3a; --okb:#1e8e6c; --okt:#9ff5d3;
  --ng:#5a1a30; --ngb:#a13452; --ngt:#ffc1d4;
  --r:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:clip}
body{
  font-family:"Segoe UI","Hiragino Sans","Yu Gothic UI",sans-serif;
  background:var(--bg);color:var(--ink);
  min-height:100vh;overflow-x:clip;padding-bottom:92px;-webkit-font-smoothing:antialiased;
}
#stars{display:none}
.ja{font-family:"Hiragino Sans","Yu Gothic UI",sans-serif}

/* ===== トップバー ===== */
.topbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
  padding:13px 22px;background:var(--headgrad);box-shadow:0 4px 20px rgba(0,0,0,.35);position:sticky;top:0;z-index:50}
.brand{display:flex;align-items:center;gap:12px}
.brand-emoji{font-size:32px}
.brand-text h1{font-size:20px;letter-spacing:.5px;color:#fff;font-weight:700;line-height:1.15}
.brand-text p{font-size:12px;opacity:.85;color:#fff}
.hud{display:flex;gap:7px}
.hud-item{display:flex;align-items:center;gap:5px;background:rgba(0,0,0,.24);border:1px solid rgba(255,255,255,.2);
  padding:6px 11px;border-radius:999px;font-weight:600;font-size:14px;color:#fff}
.hud-item span{font-size:15px}
.mute-btn{cursor:pointer;font-family:inherit;font-size:16px;color:#fff;line-height:1}
.mute-btn.off{background:rgba(0,0,0,.4);border-color:var(--pink)}

/* ===== 画面切替 ===== */
#app{max-width:760px;margin:0 auto;padding:18px 16px}
.screen{display:none;animation:fade .3s ease both}
.screen.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ===== ヒーロー ===== */
.hero{text-align:center;padding:8px 0 4px}
.hero-bot{font-size:54px}
.hero-title{font-size:24px;margin-top:6px;color:var(--accent);font-weight:700}
.hero-sub{color:var(--muted);font-size:14px;margin-top:8px;max-width:480px;margin-inline:auto;line-height:1.7}

/* ===== フィルター ===== */
.filter-bar{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin:20px 0}
.filter-bar>span{font-size:13px;color:var(--muted)}
.chip{cursor:pointer;border:1px solid var(--border);background:#222855;color:var(--ink);
  padding:8px 16px;border-radius:999px;font-family:inherit;font-weight:600;font-size:14px;transition:.15s}
.chip:hover{background:#2c3370}
.chip.active{background:var(--accent);color:#222;border-color:var(--accent)}

/* ===== モードグリッド ===== */
.mode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:13px;margin-top:8px}
.mode-card{cursor:pointer;text-align:left;border:1px solid var(--border);border-radius:var(--r);
  padding:16px 16px 15px;background:var(--panel);color:var(--ink);box-shadow:0 2px 14px rgba(0,0,0,.18);
  font-family:inherit;transition:.16s;position:relative;text-decoration:none;display:block;border-left:4px solid var(--accent2)}
.mode-card.c1{border-left-color:var(--accent)}
.mode-card.c2{border-left-color:var(--blue)}
.mode-card.c3{border-left-color:var(--accent2)}
.mode-card.c4{border-left-color:#ffaf7b}
.mode-card.c5{border-left-color:var(--pink)}
.mode-card.c6{border-left-color:#9ff5d3}
.mode-card:hover{background:var(--panel2);transform:translateY(-3px);box-shadow:0 8px 22px rgba(0,0,0,.3)}
.mode-ic{font-size:28px}
.mode-card h3{font-size:17px;margin:7px 0 4px;color:var(--ink);font-weight:700}
.mode-card p{font-size:12.5px;color:var(--muted);line-height:1.6}

/* ===== プレイ画面 ===== */
.play-top{display:flex;align-items:center;gap:12px;margin:0 0 16px}
.back-btn{cursor:pointer;background:transparent;border:1px solid var(--border);color:var(--ink);
  font-family:inherit;font-weight:600;padding:8px 14px;border-radius:8px;white-space:nowrap}
.back-btn:hover{background:var(--panel2)}
.progress-wrap{flex:1;height:8px;background:#11132b;border:1px solid var(--border);border-radius:999px;overflow:hidden}
.progress-bar{height:100%;width:0;border-radius:999px;background:var(--accent2);transition:width .35s}
.play-meta{display:flex;flex-direction:column;align-items:flex-end;font-weight:600;font-size:13px;min-width:46px}
.timer{color:var(--accent)}

/* タイマーバー（1問ごと自動カウント） */
.qtimer{display:flex;align-items:center;gap:10px;margin:0 0 14px}
.qtimer .twrap{flex:1;height:8px;background:#11132b;border:1px solid var(--border);border-radius:999px;overflow:hidden}
.qtimer .tbar{height:100%;width:100%;border-radius:999px;background:var(--accent2);transition:width 1s linear}
.qtimer .tbar.warn{background:var(--pink)}
.qtimer .tnum{font-weight:700;font-size:14px;color:var(--accent);min-width:54px;text-align:right}
.qtimer .tnum.over{color:var(--pink)}

.card-stage{}
.q-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--r);
  padding:20px 20px;box-shadow:0 2px 14px rgba(0,0,0,.18);position:relative}
.q-card.shake{animation:shake .35s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-7px)}50%{transform:translateX(6px)}75%{transform:translateX(-4px)}}
.q-tag{display:inline-block;font-size:11px;font-weight:600;background:#2c3370;color:#cfd4ff;
  padding:3px 10px;border-radius:999px;margin-bottom:13px}
/* 音声＝確認用の小さめボタン */
.audio-btn{cursor:pointer;display:inline-flex;align-items:center;gap:6px;margin:0 0 14px;
  border:1px solid var(--border);border-radius:8px;font-family:inherit;font-weight:600;font-size:13px;
  padding:6px 12px;color:var(--ink);background:transparent;transition:.15s}
.audio-btn:hover{background:var(--panel2);border-color:var(--accent2)}
.audio-btn.playing{border-color:var(--accent);color:var(--accent)}
/* ヒント（日本語訳）トグル */
.hint-ja{display:none;margin:0 0 14px;padding:10px 13px;border-radius:8px;background:#11132b;
  border-left:3px solid var(--accent);color:var(--muted);font-size:14px;line-height:1.7;
  font-family:"Hiragino Sans","Yu Gothic UI",sans-serif}
.hint-ja.show{display:block;animation:fade .2s both}
.q-body{font-size:19px;line-height:1.7;font-weight:600;margin-bottom:16px}
.q-body .blank{color:var(--accent);border-bottom:2px dashed var(--accent);padding:0 22px}
.q-body .ja{display:block;font-size:14px;color:var(--muted);font-weight:400;margin-top:10px}

.choices{display:grid;gap:9px}
.choice{cursor:pointer;text-align:left;border:1px solid var(--border);background:#11132b;
  color:var(--ink);font-family:inherit;font-weight:600;font-size:15.5px;padding:13px 15px;border-radius:10px;
  transition:.14s;display:flex;align-items:center;gap:11px}
.choice .key{width:24px;height:24px;flex:none;display:grid;place-items:center;border-radius:6px;
  background:#2c3370;font-size:12px;color:#cfd4ff}
.choice:hover:not(:disabled){background:#1f244d;border-color:#4a5296}
.choice:disabled{cursor:default}
.choice.correct{background:var(--ok);border-color:var(--okb)}
.choice.wrong{background:var(--ng);border-color:var(--ngb)}

.primary-btn{cursor:pointer;border:none;border-radius:8px;font-family:inherit;font-weight:600;font-size:15px;
  padding:12px 20px;color:#062f23;background:var(--accent2);transition:.15s}
.primary-btn:hover{filter:brightness(1.1)}
.ghost-btn{cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--ink);
  font-family:inherit;font-weight:600;font-size:14px;padding:12px 16px;border-radius:8px}
.ghost-btn:hover{background:var(--panel2)}

.feedback{margin-top:15px;font-weight:600;font-size:15px;line-height:1.6;display:none}
.feedback.show{display:block;animation:fade .25s both}
.feedback .res{font-size:18px;font-weight:700}
.feedback.good .res{color:var(--okt)}
.feedback.bad .res{color:var(--ngt)}
.feedback .ans{margin-top:6px}
.feedback .ans b{color:var(--accent)}
.feedback .exp{margin-top:8px;font-weight:400;font-size:13.5px;color:var(--muted);
  background:#11132b;padding:10px 12px;border-radius:8px;border-left:3px solid var(--accent2)}
.feedback .ask{margin-top:10px;cursor:pointer;font-size:13px;color:var(--okt);background:none;border:none;
  font-family:inherit;font-weight:600;text-decoration:underline}

.next-btn{display:block;width:100%;max-width:760px;margin:16px auto 0;cursor:pointer;border:none;border-radius:10px;
  font-weight:700;font-size:16px;padding:14px;color:#062f23;background:var(--accent2);transition:.15s;font-family:inherit}
.next-btn:hover{filter:brightness(1.1)}

/* ===== リザルト ===== */
.result-card{text-align:center;background:var(--panel);border:1px solid var(--border);border-radius:var(--r);
  padding:32px 22px;max-width:480px;margin:24px auto;box-shadow:0 2px 14px rgba(0,0,0,.18)}
.result-emoji{font-size:60px}
#resTitle{font-size:26px;margin:6px 0;color:var(--accent)}
#resMsg{color:var(--muted);font-size:14px;margin-bottom:20px}
.result-stats{display:flex;justify-content:center;gap:26px;margin-bottom:24px}
.result-stats div{display:flex;flex-direction:column}
.result-stats span{font-size:30px;font-weight:700;color:var(--accent)}
.result-stats small{font-size:12px;color:var(--muted)}
.result-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ===== コンフェッティ（控えめ） ===== */
.confetti{position:fixed;top:-12px;width:9px;height:13px;z-index:60;pointer-events:none;border-radius:2px}

/* ===== チャットボット ===== */
#botFab{position:fixed;right:18px;bottom:18px;z-index:40;cursor:pointer;border:none;border-radius:999px;
  display:flex;align-items:center;gap:8px;padding:12px 18px;color:#062f23;font-family:inherit;font-weight:700;font-size:15px;
  background:var(--accent2);box-shadow:0 6px 22px rgba(0,0,0,.4)}
#botFab:hover{filter:brightness(1.08)}
.fab-emoji{font-size:22px}

.chat-panel{position:fixed;right:18px;bottom:18px;z-index:45;width:min(380px,calc(100vw - 24px));
  height:min(560px,calc(100vh - 36px));background:var(--panel);border:1px solid var(--border);border-radius:14px;
  display:flex;flex-direction:column;overflow:hidden;box-shadow:0 16px 50px rgba(0,0,0,.55)}
.chat-panel[hidden]{display:none}   /* hidden属性のときは確実に隠す（display:flexの上書き対策） */
.chat-head{display:flex;justify-content:space-between;align-items:center;padding:13px 15px;background:var(--headgrad)}
.chat-head-info{display:flex;align-items:center;gap:10px}
.chat-avatar{font-size:26px;background:rgba(255,255,255,.2);border-radius:50%;padding:4px}
.chat-head-info b{display:block;font-size:15px;color:#fff}
.chat-head-info small{font-size:11.5px;color:#fff;opacity:.85}
.chat-close{cursor:pointer;background:rgba(0,0,0,.2);border:none;color:#fff;width:30px;height:30px;border-radius:50%;font-size:15px}
.chat-log{flex:1;overflow-y:auto;padding:15px;display:flex;flex-direction:column;gap:11px;background:#181a3a}
.msg{max-width:84%;padding:10px 13px;border-radius:14px;font-size:14px;line-height:1.65;white-space:pre-wrap;word-wrap:break-word}
.msg.bot{align-self:flex-start;background:#262a55;color:var(--ink);border-bottom-left-radius:4px}
.msg.user{align-self:flex-end;background:var(--blue);color:#fff;border-bottom-right-radius:4px}
.msg.bot .who{font-size:11px;color:var(--accent2);font-weight:700;display:block;margin-bottom:3px}
.typing{display:inline-flex;gap:4px}
.typing i{width:7px;height:7px;background:var(--muted);border-radius:50%;animation:ty 1s infinite}
.typing i:nth-child(2){animation-delay:.2s}.typing i:nth-child(3){animation-delay:.4s}
@keyframes ty{50%{opacity:.4;transform:translateY(-3px)}}
.chat-quick{display:flex;gap:6px;padding:0 12px 8px;flex-wrap:wrap;background:#181a3a}
.chat-quick button{cursor:pointer;font-family:inherit;font-size:11.5px;color:#cfd4ff;
  background:#2c3370;border:none;border-radius:999px;padding:6px 11px}
.chat-quick button:hover{background:var(--accent);color:#222}
.chat-input{display:flex;gap:8px;padding:11px;border-top:1px solid var(--border);background:#181a3a}
.chat-input input{flex:1;border:1px solid var(--border);background:#11132b;color:var(--ink);
  font-family:inherit;font-size:14px;padding:11px 13px;border-radius:999px;outline:none}
.chat-input input:focus{border-color:var(--accent2)}
#chatSend{cursor:pointer;border:none;width:44px;border-radius:50%;font-size:17px;color:#062f23;background:var(--accent2)}
#chatSend:disabled{opacity:.5;cursor:default}

/* チャット内 Markdown */
.msg .md-h{display:block;font-weight:700;color:var(--accent2);margin:9px 0 3px;font-size:14px}
.msg .md-h:first-child{margin-top:0}
.msg .md-b{color:var(--accent);font-weight:700;margin-right:2px}
.msg .md-code{background:#11132b;padding:1px 6px;border-radius:5px;font-size:.92em}
.msg .md-hr{border:none;border-top:1px solid var(--border);margin:9px 0}

@media(max-width:480px){
  .mode-grid{grid-template-columns:repeat(2,1fr);gap:11px}
  .fab-label{display:none}
  #botFab{padding:13px}
  #app{padding:16px 13px}
}
