/* ════════════════════════════════════════════════════════════
   塾学習管理システム  style.css
   ────────────────────────────────────────────────────────────
   構成:
     1. CSS変数
     2. リセット
     3. レイアウト共通 (画面・ヘッダー・タブ)
     4. ボタン
     5. フォーム
     6. カード・タスクカード
     7. バッジ
     8. プログレス・進捗バー
     9. ログイン画面
    10. 生徒画面 (ポータル・カレンダー・自学・SY)
    11. 課題タブ
    12. 学習時間タブ
    13. 相談タブ
    14. 管理者画面・テーブル
    15. モーダル・トースト・バナー
    16. ユーティリティ
    17. アニメーション
    18. レスポンシブ
═══════════════════════════════════════════════════════════ */


/* ════════════════════════════════════════════════════════════
   1. CSS変数
═══════════════════════════════════════════════════════════ */
:root {
  /* 文字色 */
  --ink:     #1a1a14;
  --ink2:    #4a4a40;
  --ink3:    #9a9a8a;
  /* 背景 */
  --bg:      #fafaf7;
  --bg2:     #f0f0ea;
  --card:    #ffffff;
  --border:  #e0e0d6;
  /* アクセントカラー */
  --accent:  #e05a2b;  /* オレンジ（プライマリ） */
  --accent2: #2563eb;  /* 青 */
  --green:   #059669;
  --gold:    #d97706;
  --purple:  #7c3aed;
  --red:     #b91c1c;
  /* 角丸・影 */
  --r:       10px;
  --r-sm:    7px;
  --r-lg:    14px;
  --sh:      0 2px 12px rgba(0,0,0,.08);
  --sh-lg:   0 8px 24px rgba(0,0,0,.2);
  /* フォント */
  --font-mono: 'DM Mono', 'SF Mono', Consolas, monospace;
}


/* ════════════════════════════════════════════════════════════
   2. リセット
═══════════════════════════════════════════════════════════ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html, body {
  height: 100%;
  font-family: 'Zen Kaku Gothic New', 'Hiragino Sans', sans-serif;
  background: var(--bg);
  color: var(--ink);
  font-size: 14px;
  -webkit-text-size-adjust: 100%;
}
button, input, select, textarea { font-family: inherit; }
a { color: inherit; }


/* ════════════════════════════════════════════════════════════
   3. レイアウト共通
═══════════════════════════════════════════════════════════ */
.screen { display: none; min-height: 100vh; }
.screen.active { display: block; }

/* ヘッダー（生徒・管理者共通） */
.app-header {
  background: var(--ink);
  color: #fff;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  position: sticky;
  top: 0;
  z-index: 100;
}

/* 生徒画面の上部固定バー（ヘッダー+タブ） */
.student-top-bar {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--ink);
  box-shadow: 0 2px 8px rgba(0,0,0,.15);
}

.student-header, .admin-header {
  background: var(--ink);
  color: #fff;
  padding: 10px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.admin-header {
  position: sticky;
  top: 0;
  z-index: 100;
}
.student-header { gap: 8px; padding: 10px 14px; }
/* 名前は固定（伸びない） */
.student-header .s-name-wrap { flex: 0 0 auto; min-width: 0; max-width: 110px; overflow: hidden; }
.student-header .s-name { font-size: 14px; font-weight: 900; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.student-header .s-meta { font-size: 10px; color: #aaa; white-space: nowrap; }
.admin-header .title    { color: #fff; font-size: 14px; font-weight: 900; }
.admin-header .sub      { color: #888; font-size: 10px; }

/* 入室時刻＆経過時間（名前の右側） */
.entry-info {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 8px;
  padding: 4px 9px;
  min-width: 72px;
  text-align: center;
  flex-shrink: 0;
}
.entry-info-lbl {
  font-size: 8px;
  color: #94a3b8;
  letter-spacing: .05em;
  line-height: 1.3;
}
.entry-info-time {
  font-size: 13px;
  font-weight: 900;
  color: #fff;
  font-family: var(--font-mono);
  line-height: 1.2;
}
.entry-info-elapsed {
  font-size: 11px;
  color: #6ee7b7;
  font-weight: 700;
  line-height: 1.2;
}

/* タブ（生徒・管理者共通、横スクロール） */
.tabs, .admin-tabs {
  display: flex;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  flex-shrink: 0;
}
.tabs::-webkit-scrollbar,
.admin-tabs::-webkit-scrollbar { display: none; }
.tabs { background: #111; }
.admin-tabs {
  background: #1a1a14;
  border-bottom: 2px solid #333;
}

/* 生徒側タブを大きく目立たせる */
.tab {
  flex: 1;
  min-width: 0;
  padding: 14px 8px;
  color: #999;
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
  border-bottom: 3px solid transparent;
  white-space: nowrap;
  text-align: center;
  transition: color .15s, background .15s;
}
.tab:hover {
  color: #ddd;
  background: rgba(255,255,255,.04);
}
.tab.active {
  color: #fff;
  border-bottom-color: var(--accent);
  background: rgba(224, 90, 43, .08);
}

/* 管理者タブはそのまま */
.admin-tab {
  flex-shrink: 0;
  padding: 9px 14px;
  margin-bottom: -2px;
  color: #888;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
}
.admin-tab.active {
  color: #fff;
  border-bottom-color: var(--accent);
}

.tab-badge {
  display: inline-block;
  background: var(--accent);
  color: #fff;
  border-radius: 10px;
  font-size: 9px;
  padding: 0 5px;
  margin-left: 3px;
  font-weight: 700;
  line-height: 16px;
}
.tab-content { padding: 14px 12px 12px; max-width: 700px; margin: 0 auto; width: 100%; }
.tab-content > div:first-child { margin-top: 4px; }
.admin-cnt   { padding: 14px; max-width: 1100px; margin: 0 auto; }

/* やり直し★（教科バッジの前に表示） */
.task-redo-star {
  font-size: 13px;
  color: var(--gold);
  font-weight: 900;
  flex-shrink: 0;
  letter-spacing: -1px;
}
.task-redo-star:empty { display: none; }


/* ════════════════════════════════════════════════════════════
   4. ボタン
═══════════════════════════════════════════════════════════ */
.btn-primary {
  width: 100%;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 9px;
  padding: 11px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .15s;
}
.btn-primary:hover    { opacity: .88; }
.btn-primary:disabled { opacity: .5; cursor: not-allowed; }

.btn-sm {
  padding: 5px 11px;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  background: var(--bg2);
  color: var(--ink2);
  touch-action: manipulation;
}
.btn-sm:hover         { opacity: .82; }
.btn-sm.active        { background: var(--accent2); color: #fff; border-color: var(--accent2); font-weight: 800; }
.btn-sm.blue          { background: #eff6ff; color: var(--accent2); border-color: #bfdbfe; }
.btn-sm.green         { background: #d1fae5; color: var(--green);   border-color: #6ee7b7; }
.btn-sm.red           { background: #fee2e2; color: var(--red);     border-color: #fca5a5; }
.btn-sm.orange        { background: #fff7ed; color: var(--gold);    border-color: #fed7aa; }
.btn-sm.purple        { background: #f3e8ff; color: var(--purple);  border-color: #c4b5fd; }
.btn-sm.solid         { background: var(--ink); color: #fff; border-color: transparent; }
.btn-sm.solid-accent  { background: var(--accent2); color: #fff; border-color: transparent; }

.btn-logout {
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 7px;
  padding: 6px 14px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}

/* フリー学習スタートボタン */
.btn-free-start {
  width: 100%;
  background: linear-gradient(135deg, #059669, #10b981);
  color: #fff;
  border: none;
  border-radius: 12px;
  padding: 14px;
  font-size: 16px;
  font-weight: 900;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

/* 学習ログボタン */
.log-area { margin: 7px 0; }
.log-btn {
  padding: 6px 14px;
  border: none;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}
.log-btn.start { background: var(--accent2); color: #fff; }
.log-btn.pause { background: var(--gold);    color: #fff; }
.log-btn.stop  { background: #374151;        color: #fff; }
.log-btn:disabled {
  opacity: .4;
  cursor: not-allowed;
  background: #9ca3af !important;
}
.log-mins {
  font-size: 11px;
  color: var(--green);
  font-weight: 700;
  font-family: var(--font-mono);
}

/* おすすめバナーボタン */
.rec-banner-btn {
  padding: 4px 10px;
  background: var(--gold);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
}


/* ════════════════════════════════════════════════════════════
   5. フォーム
═══════════════════════════════════════════════════════════ */
input[type=text],
input[type=email],
input[type=password],
input[type=date],
input[type=time],
input[type=number],
select,
textarea {
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 7px 10px;
  font-size: 13px;
  outline: none;
  background: var(--bg);
  color: var(--ink);
  width: 100%;
}
input:focus, select:focus, textarea:focus { border-color: var(--accent2); }

.memo-ta {
  width: 100%;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  padding: 7px 9px;
  font-size: 12px;
  resize: vertical;
  min-height: 46px;
  outline: none;
  background: var(--bg);
  color: var(--ink);
  margin-top: 6px;
}

.fr {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
}
.fr > * { flex: 1; min-width: 80px; }

.form-row { margin-bottom: 9px; }
label.form-lbl {
  font-size: 11px;
  color: var(--ink3);
  font-weight: 700;
  display: block;
  margin-bottom: 3px;
}

/* 数字パッド */
.numpad { display: flex; gap: 3px; flex-wrap: wrap; margin-bottom: 6px; }
.numpad-btn {
  min-width: 38px;
  padding: 8px 10px;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  background: var(--bg2);
  touch-action: manipulation;
  user-select: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.numpad-btn:focus { outline: none; }
.numpad-btn.bs {
  border-color: #fca5a5;
  background: #fee2e2;
  min-width: 44px;
}

/* 自学フォーム選択ボタン */
.ss-sel-btn {
  padding: 5px 11px;
  border: 1.5px solid var(--border);
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  background: var(--bg);
  color: var(--ink2);
  touch-action: manipulation;
  transition: background .15s, color .15s, border-color .15s;
}
.ss-sel-btn.active {
  background: var(--accent2);
  border-color: var(--accent2);
  color: #fff;
  font-weight: 800;
}


/* ════════════════════════════════════════════════════════════
   6. カード・タスクカード
═══════════════════════════════════════════════════════════ */
.card {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  padding: 13px;
  margin-bottom: 11px;
  box-shadow: var(--sh);
}
.card-title {
  font-size: 13px;
  font-weight: 900;
  margin-bottom: 10px;
}

/* タスクカード */
.task-card {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 9px;
  margin-bottom: 7px;
  overflow: hidden;
}
.task-card.done-card {
  border-color: #a7f3d0;
  background: #f8fffe;
  opacity: .85;
}
.task-hdr {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 11px;
  cursor: pointer;
}
.task-icon {
  font-size: 14px;
  flex-shrink: 0;
  min-width: 18px;
  text-align: center;
}
.task-title {
  flex: 1;
  font-size: 13px;
  font-weight: 700;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.task-title.done,
.task-title.crossed-out {
  text-decoration: line-through;
  color: var(--ink3);
  opacity: .6;
}
.task-rating { font-size: 13px; flex-shrink: 0; }
.task-arrow  { font-size: 10px; color: var(--ink3); flex-shrink: 0; }
.task-body   {
  padding: 0 11px 11px;
  border-top: 1px solid var(--border);
}
.task-desc   { font-size: 12px; color: var(--ink2); padding: 7px 0; }

/* 動画リンク */
.vid-link {
  display: inline-block;
  background: #fee2e2;
  color: var(--accent);
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
  text-decoration: none;
  margin: 4px 0;
}

/* 評価・結果ボタン */
.rating-row, .result-row {
  display: flex;
  gap: 6px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.rating-btn {
  flex: 1;
  padding: 8px 4px;
  border: 2px solid var(--border);
  border-radius: 9px;
  font-size: 18px;
  cursor: pointer;
  background: var(--bg2);
  font-weight: 700;
}
.rating-btn.selected {
  background: #eff6ff;
  border-color: var(--accent2);
}
.result-btn {
  flex: 1;
  min-width: 70px;
  padding: 7px 4px;
  border: 2px solid var(--border);
  border-radius: 9px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  background: var(--bg2);
}
.result-btn.selected-done   { background: var(--green);    color: #fff; border-color: var(--green); }
.result-btn.selected-redo   { background: var(--gold);     color: #fff; border-color: var(--gold); }
.result-btn.selected-skip   { background: var(--red);      color: #fff; border-color: var(--red); }
.result-btn.selected-pause  { background: var(--accent2);  color: #fff; border-color: var(--accent2); }

/* 確定ボタン */
.confirm-btn {
  width: 100%;
  padding: 11px;
  border: none;
  border-radius: 10px;
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
  background: #e2e8f0;
  color: #94a3b8;
}
.confirm-btn.ready {
  background: var(--accent2);
  color: #fff;
  cursor: pointer;
}

/* セクション見出し */
.section-head {
  font-size: 11px;
  color: #64748b;
  text-align: center;
  margin-bottom: 9px;
  font-weight: 700;
  letter-spacing: .1em;
}
.section-lbl {
  font-size: 10px;
  color: var(--ink3);
  font-weight: 700;
  margin-bottom: 6px;
}
.section-lbl.purple { color: var(--purple); margin: 9px 0 5px; letter-spacing: .1em; }


/* ════════════════════════════════════════════════════════════
   7. バッジ（教科）
═══════════════════════════════════════════════════════════ */
.badge {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
}
.badge.英語   { background: #dbeafe; color: #1d4ed8; }
.badge.数学   { background: #fde68a; color: #92400e; }
.badge.国語   { background: #fce7f3; color: #9d174d; }
.badge.理科   { background: #d1fae5; color: #065f46; }
.badge.社会,
.badge.地理,
.badge.歴史,
.badge.公民   { background: #ede9fe; color: #5b21b6; }
.badge.自学,
.badge.フリー { background: #f3e8ff; color: var(--purple); }
.badge.その他 { background: var(--bg2); color: var(--ink2); }


/* ════════════════════════════════════════════════════════════
   8. プログレス・進捗バー
═══════════════════════════════════════════════════════════ */
.progress-bar-bg {
  background: var(--bg2);
  border-radius: 99px;
  height: 8px;
  overflow: hidden;
}
.progress-fill {
  height: 100%;
  background: var(--accent2);
  border-radius: 99px;
  transition: width .4s;
}
.progress-fill.full { background: var(--green); }

.pbar-row {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 5px;
}
.pbar-lbl { font-size: 11px; font-weight: 700; width: 48px; flex-shrink: 0; }
.pbar-bg  { flex: 1; background: var(--bg2); border-radius: 99px; height: 7px; overflow: hidden; }
.pbar-fill{ height: 100%; border-radius: 99px; background: var(--accent2); }
.pbar-cnt { font-size: 10px; color: var(--ink3); width: 36px; text-align: right; }


/* ════════════════════════════════════════════════════════════
   9. ログイン画面
═══════════════════════════════════════════════════════════ */
#login-screen.active {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  background: linear-gradient(160deg, #0f172a, #1e3a5f);
  padding: 30px 20px 20px;
  overflow-y: auto;
}
.login-box {
  background: rgba(255,255,255,.07);
  border: 1.5px solid rgba(255,255,255,.15);
  border-radius: 18px;
  padding: 22px 22px 18px;
  width: 100%;
  max-width: 360px;
  margin-top: 10px;
}
.login-title {
  font-size: 22px;
  font-weight: 900;
  color: #fff;
  text-align: center;
  margin-bottom: 2px;
}
.login-sub {
  font-size: 11px;
  color: #94a3b8;
  text-align: center;
  margin-bottom: 14px;
  letter-spacing: .15em;
}
.login-input {
  width: 100%;
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.2);
  border-radius: 9px;
  padding: 10px 13px;
  font-size: 14px;
  color: #fff;
  outline: none;
  margin-bottom: 10px;
  display: block;
}
.login-input::placeholder { color: #94a3b8; }
.login-input:focus        { border-color: rgba(255,255,255,.5); }

.admin-login-wrap {
  margin-top: 16px;
  padding: 14px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  width: 100%;
  max-width: 360px;
}
.admin-login-wrap .login-input { background: rgba(255,255,255,.08); }

#qr-reader {
  width: 100%;
  max-width: 260px;
  margin: 0 auto 8px;
  border-radius: 10px;
  overflow: hidden;
}
#qr-status {
  font-size: 11px;
  color: #64748b;
  text-align: center;
  margin-bottom: 14px;
}


/* ════════════════════════════════════════════════════════════
   10. 生徒画面（ポータル）
═══════════════════════════════════════════════════════════ */
#student-screen.active { display: flex; flex-direction: column; }

/* ポータル：在室時間ヘッダーカード */
.portal-hero {
  background: linear-gradient(135deg, var(--ink), #2d3748);
  color: #fff;
  margin-bottom: 11px;
  border-radius: var(--r);
  padding: 13px;
}
.portal-hero-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 9px;
}
.portal-hero-lbl   { font-size: 10px; opacity: .7; }
.portal-hero-val   { font-size: 22px; font-weight: 900; font-family: var(--font-mono); }
.portal-hero-study { font-size: 10px; color: #6ee7b7; }
.portal-hero-refresh {
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.3);
  border-radius: 8px;
  padding: 6px 12px;
  color: #fff;
  font-family: inherit;
  font-size: 11px;
  cursor: pointer;
}

/* 進捗カード */
.progress-card-hdr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
}
.progress-pct {
  font-size: 18px;
  font-weight: 900;
  color: var(--accent2);
}
.progress-count {
  font-size: 10px;
  color: var(--ink3);
  margin-top: 4px;
  text-align: right;
}

/* フリー学習中 */
.free-running {
  background: var(--card);
  border: 2px solid var(--green);
  border-radius: 12px;
  padding: 12px;
}
.free-running-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.free-timer {
  font-size: 26px;
  font-weight: 900;
  font-family: var(--font-mono);
  color: var(--ink);
}

/* カレンダー */
.cal-wrap {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.cal-mini-wrap   { flex: 0 0 auto; }
.cal-list-wrap   {
  flex: 1;
  min-width: 0;
  max-height: 260px;
  overflow-y: auto;
}
.cal-table {
  border-collapse: collapse;
  font-size: 10px;
}
.cal-table th {
  width: 28px;
  text-align: center;
  padding: 2px 1px;
  color: var(--ink3);
  font-weight: 700;
  font-size: 9px;
  border-bottom: none;
}
.cal-table td {
  text-align: center;
  padding: 1px 0;
  width: 28px;
  border-bottom: none;
}
.cal-day {
  cursor: pointer;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  position: relative;
}
.cal-day .cal-day-num {
  font-size: 10px;
  line-height: 1;
}
.cal-day.selected {
  background: var(--accent2);
}
.cal-day.selected .cal-day-num { color: #fff; font-weight: 900; }
.cal-day.today {
  background: #fce7f3;
  border: 2px solid #f9a8d4;
}
.cal-day.today .cal-day-num    { font-weight: 900; }
.cal-day.sunday   .cal-day-num { color: #ef4444; }
.cal-day.saturday .cal-day-num { color: #3b82f6; }
.cal-day.selected.sunday   .cal-day-num,
.cal-day.selected.saturday .cal-day-num { color: #fff; }
.cal-day-dot {
  position: absolute;
  bottom: 1px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--accent2);
}
.cal-day.selected .cal-day-dot { background: #fff; }

.cal-month-nav {
  display: flex;
  align-items: center;
  gap: 5px;
}
.cal-month-lbl  { font-size: 11px; font-weight: 700; }
.cal-list-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}
.cal-list-date  { font-size: 11px; font-weight: 700; color: var(--ink2); }
.cal-row {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 6px;
  border-radius: 7px;
  margin-bottom: 4px;
  background: var(--bg);
  border: 1px solid var(--border);
}
.cal-row.done   { background: #f0fdf4; border-color: #6ee7b7; }
.cal-row.skip   { background: var(--bg2); }
.cal-row-icon {
  font-size: 14px;
  flex-shrink: 0;
  cursor: pointer;
  min-width: 18px;
  text-align: center;
}
.cal-row-title {
  flex: 1;
  min-width: 0;
  font-size: 11px;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cal-row-title.crossed-out {
  text-decoration: line-through;
  opacity: .6;
}
.cal-row-btns { display: flex; gap: 3px; flex-shrink: 0; }
.cal-mini-btn {
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 5px;
  cursor: pointer;
  white-space: nowrap;
}
.cal-mini-btn.move   { border: 1px solid var(--border);  background: var(--bg2); }
.cal-mini-btn.delete { border: 1px solid #fca5a5;        background: #fee2e2; }

.cal-legend {
  display: flex;
  gap: 10px;
  margin-top: 7px;
  flex-wrap: wrap;
  font-size: 10px;
}

/* 自学（self-study）追加カード */
.ss-add-card {
  border-color: #a78bfa !important;
  background: #faf5ff !important;
}
.ss-add-card .card-title { color: var(--purple); }
.ss-add-popup {
  background: #faf5ff;
  border: 1.5px solid #c4b5fd;
  border-radius: 9px;
  padding: 9px;
}
.ss-add-popup-title {
  font-size: 11px;
  font-weight: 900;
  color: var(--purple);
  margin-bottom: 7px;
}
.ss-date-btn {
  padding: 5px 10px;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  background: var(--bg2);
  color: var(--ink);
}
.ss-date-btn.active {
  background: var(--green);
  color: #fff;
  border-color: var(--green);
}

/* SY */
.sy-day-btn {
  flex: 1;
  min-width: 38px;
  padding: 6px 4px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  background: var(--bg2);
  color: var(--ink);
  text-align: center;
  flex-shrink: 0;
}
.sy-day-btn.active {
  background: var(--ink);
  color: #fff;
  border-color: transparent;
}
.sy-post-card {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  padding: 10px 13px;
  margin-bottom: 6px;
}


/* ════════════════════════════════════════════════════════════
   11. 課題タブ
═══════════════════════════════════════════════════════════ */
.sched-block { margin-bottom: 11px; }
.period-hdr {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 11px;
  background: var(--ink);
  color: #fff;
  border-radius: var(--r) var(--r) 0 0;
  cursor: pointer;
}
.period-hdr-title { font-size: 13px; font-weight: 900; flex: 1; }
.period-hdr-dates { font-size: 10px; color: #aaa; font-family: var(--font-mono); }
.period-comment {
  background: #fffbeb;
  border: 1px solid #fde68a;
  padding: 7px 11px;
  font-size: 11px;
  color: #92400e;
}
.sched-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 6px;
  padding: 8px 11px;
  border-bottom: 1px solid var(--border);
  align-items: start;
}
.sched-item:last-child   { border-bottom: none; }
.sched-item.row-b        { background: #fafaf7; }
.sched-item.done-item    { background: #f0fdf4; }
.sched-item.today-item   { background: #eff6ff; }
.sched-item-title {
  font-size: 12px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
}
.rec-pill {
  font-size: 9px;
  background: #fef9c3;
  color: #92400e;
  padding: 1px 5px;
  border-radius: 4px;
}
.sched-dates {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
  font-size: 11px;
}
.sched-lbl { color: var(--ink3); font-size: 10px; }
.date-sel, .redo-sel {
  border: 1.5px solid var(--border);
  border-radius: 6px;
  padding: 3px 6px;
  font-size: 11px;
  outline: none;
  background: var(--bg);
  color: var(--ink);
  width: auto;
}
.date-sel.today-set { border-color: var(--accent2); color: var(--accent2); font-weight: 700; }
.date-sel.set       { border-color: var(--green);   color: var(--green);   font-weight: 700; }
.redo-sel.set       { border-color: var(--gold);    color: var(--gold);    font-weight: 700; }


/* ════════════════════════════════════════════════════════════
   12. 学習時間タブ
═══════════════════════════════════════════════════════════ */
.st-hero {
  background: linear-gradient(135deg, #2563eb, #3b82f6);
  border-radius: var(--r);
  padding: 20px;
  text-align: center;
  color: #fff;
  margin-bottom: 11px;
}
.st-hero.green  { background: linear-gradient(135deg, #059669, #10b981); }
.st-hero.orange { background: linear-gradient(135deg, #d97706, #f59e0b); }
.st-hero.purple { background: linear-gradient(135deg, #7c3aed, #8b5cf6); }
.st-total { font-size: 36px; font-weight: 900; font-family: var(--font-mono); }
.st-lbl   { font-size: 11px; opacity: .8; }

.st-pb-row {
  display: flex;
  gap: 6px;
  margin-bottom: 7px;
  flex-wrap: wrap;
}
.st-pb {
  flex: 1;
  min-width: 56px;
  padding: 7px 6px;
  border-radius: 8px;
  border: 1.5px solid var(--border);
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  background: var(--bg2);
  color: var(--ink);
}
.st-pb.active { color: #fff; border-color: transparent; background: var(--accent2); }
.st-pb.green.active  { background: var(--green); }
.st-pb.orange.active { background: var(--gold); }
.st-pb.purple.active { background: var(--purple); }

.st-log-item {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 8px 10px;
  margin-bottom: 5px;
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
}
.st-log-mins {
  font-size: 12px;
  font-weight: 700;
  color: var(--green);
  font-family: var(--font-mono);
  white-space: nowrap;
}
.correct-form {
  display: none;
  width: 100%;
  margin-top: 7px;
  padding-top: 7px;
  border-top: 1px solid var(--border);
}

/* タブ切り替え（学習時間 / 評価一覧） */
.subtabs {
  display: flex;
  gap: 0;
  margin-bottom: 11px;
  background: var(--bg2);
  border-radius: 10px;
  padding: 3px;
}
.subtab {
  flex: 1;
  padding: 8px;
  border: none;
  border-radius: 8px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  background: transparent;
  color: var(--ink3);
}
.subtab.active { background: var(--card); color: var(--ink); }

/* 評価フィルタ */
.rating-filter-row {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  margin-bottom: 11px;
}
.rating-filter-btn {
  padding: 6px 14px;
  border: 1.5px solid var(--border);
  border-radius: 20px;
  font-size: 13px;
  cursor: pointer;
  background: var(--bg2);
  color: var(--ink);
  font-weight: 700;
}
.rating-filter-btn.active {
  background: var(--accent2);
  color: #fff;
  border-color: var(--accent2);
}

/* 評価一覧 */
.rating-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 9px;
  margin-bottom: 5px;
  background: var(--card);
  border: 1.5px solid var(--border);
}
.rating-mark {
  font-size: 20px;
  font-weight: 900;
}
.rating-mark.maru-d { color: var(--green); }
.rating-mark.maru   { color: var(--accent2); }
.rating-mark.sankaku{ color: var(--gold); }
.rating-mark.batsu  { color: var(--red); }


/* ════════════════════════════════════════════════════════════
   13. 相談タブ
═══════════════════════════════════════════════════════════ */
.consult-form {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  padding: 13px;
  margin-bottom: 11px;
}
.consult-item {
  border-radius: 9px;
  padding: 9px 11px;
  margin-bottom: 6px;
  border: 1.5px solid var(--border);
  background: var(--card);
}
.consult-item.has-reply {
  border-color: var(--accent2);
  background: #eff6ff;
}
.consult-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 7px;
  cursor: pointer;
}


/* ════════════════════════════════════════════════════════════
   14. 管理者画面・テーブル
═══════════════════════════════════════════════════════════ */
#admin-screen.active { display: block; }

.tbl-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: 12px; }
thead { background: var(--bg2); }
th, td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  text-align: left;
}
th {
  font-size: 11px;
  font-weight: 700;
  color: var(--ink2);
  white-space: nowrap;
}
tbody tr:hover { background: #f5f5f0; }

.in-pill  { background: #d1fae5; color: var(--green); padding: 2px 8px; border-radius: 4px; font-size: 10px; font-weight: 700; }
.out-pill { background: #fee2e2; color: var(--red);   padding: 2px 8px; border-radius: 4px; font-size: 10px; font-weight: 700; }

.grade-tab-row {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  margin-bottom: 11px;
  padding-bottom: 9px;
  border-bottom: 1.5px solid var(--border);
}
.grade-tab {
  padding: 5px 12px;
  border: 1.5px solid var(--border);
  border-radius: 99px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  background: var(--bg2);
  color: var(--ink2);
}
.grade-tab.active {
  background: var(--ink);
  color: #fff;
  border-color: transparent;
}


/* ════════════════════════════════════════════════════════════
   15. モーダル・トースト・バナー
═══════════════════════════════════════════════════════════ */
.modal-bg {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(0,0,0,.55);
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.modal-bg.open { display: flex; }
.modal {
  background: var(--card);
  border-radius: 16px;
  padding: 20px;
  max-width: 420px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 16px 48px rgba(0,0,0,.25);
}
.modal h2 {
  font-size: 16px;
  font-weight: 900;
  margin-bottom: 12px;
}

/* 退室モーダル */
.lo-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 10px;
  border-radius: 8px;
  cursor: pointer;
  margin-bottom: 4px;
  border: 2px solid;
}

/* トースト */
#toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(80px);
  background: var(--ink);
  color: #fff;
  padding: 10px 20px;
  border-radius: 99px;
  font-size: 13px;
  font-weight: 700;
  z-index: 9999;
  transition: transform .3s, opacity .3s;
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
  max-width: calc(100vw - 32px);
}
#toast.show {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}

/* 衝突バナー（学習タイマー競合） */
.conflict-banner {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 500;
  background: var(--red);
  color: #fff;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 4px 12px rgba(0,0,0,.3);
  animation: slideDown .3s ease;
}
.conflict-banner-body { flex: 1; }
.conflict-banner-title    { font-size: 12px; font-weight: 900; }
.conflict-banner-subtitle { font-size: 10px; opacity: .9; margin-top: 2px; }
.conflict-banner-btn {
  background: #fff;
  color: var(--red);
  border: none;
  border-radius: 7px;
  padding: 6px 12px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 900;
  cursor: pointer;
  white-space: nowrap;
}
.conflict-banner-close {
  background: rgba(255,255,255,.2);
  border: none;
  border-radius: 6px;
  width: 24px;
  height: 24px;
  color: #fff;
  cursor: pointer;
  font-size: 14px;
}

/* 課題更新バナー */
.task-update-banner {
  position: sticky;
  top: 0;
  z-index: 200;
  background: linear-gradient(135deg, #1d4ed8, #2563eb);
  color: #fff;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.task-update-banner-btn {
  background: #fff;
  color: #1d4ed8;
  border: none;
  border-radius: 7px;
  padding: 6px 12px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 900;
  cursor: pointer;
  white-space: nowrap;
}

/* ポップアップメニュー（カレンダーの状態変更等） */
.popup-menu {
  position: fixed;
  z-index: 600;
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 11px;
  padding: 5px;
  box-shadow: var(--sh-lg);
  min-width: 145px;
}
.popup-menu-item {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 7px 10px;
  border: none;
  border-radius: 7px;
  cursor: pointer;
  background: transparent;
  font-family: inherit;
  font-size: 12px;
}
.popup-menu-item:hover { background: var(--bg2); }
.popup-menu-icon { font-size: 15px; }


/* ════════════════════════════════════════════════════════════
   16. ユーティリティ
═══════════════════════════════════════════════════════════ */
.empty {
  text-align: center;
  color: var(--ink3);
  padding: 24px;
  font-size: 13px;
  line-height: 1.7;
}

.flex            { display: flex; }
.flex-1          { flex: 1; }
.flex-center     { display: flex; align-items: center; justify-content: center; }
.flex-between    { display: flex; align-items: center; justify-content: space-between; }
.gap-5           { gap: 5px; }
.gap-6           { gap: 6px; }
.gap-8           { gap: 8px; }
.mt-6            { margin-top: 6px; }
.mt-8            { margin-top: 8px; }
.mt-11           { margin-top: 11px; }
.mb-6            { margin-bottom: 6px; }
.mb-8            { margin-bottom: 8px; }
.mb-11           { margin-bottom: 11px; }
.text-xs         { font-size: 10px; }
.text-sm         { font-size: 11px; }
.text-mono       { font-family: var(--font-mono); }
.text-ink3       { color: var(--ink3); }
.text-accent2    { color: var(--accent2); }
.text-green      { color: var(--green); }
.text-red        { color: var(--red); }
.fw-700          { font-weight: 700; }
.fw-900          { font-weight: 900; }
.text-center     { text-align: center; }
.nowrap          { white-space: nowrap; }
.ellipsis        { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cursor-pointer  { cursor: pointer; }


/* ════════════════════════════════════════════════════════════
   17. アニメーション
═══════════════════════════════════════════════════════════ */
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25%      { transform: translateX(-6px); }
  75%      { transform: translateX(6px); }
}
@keyframes slideDown {
  from { transform: translateY(-100%); opacity: 0; }
  to   { transform: translateY(0);     opacity: 1; }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}


/* ════════════════════════════════════════════════════════════
   17b. 今日の名言カード（生徒・管理者共通）
═══════════════════════════════════════════════════════════ */

/* タイトル */
.quote-title {
  text-align: center;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: .18em;
  color: #b45309;
  padding: 14px 0 8px;
  margin-top: 4px;
  margin-bottom: 10px;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", serif;
  background: linear-gradient(180deg, #fffbeb 0%, #fef3c7 100%);
  border-radius: 11px;
  border: 1.5px solid #fcd34d;
  box-shadow: 0 2px 8px rgba(212, 165, 116, 0.2);
  position: relative;
}
.quote-title::before,
.quote-title::after {
  content: '✦';
  color: #d4a574;
  margin: 0 8px;
  font-size: 14px;
  vertical-align: middle;
}

/* カード本体（左右レイアウト） */
.quote-card {
  background: linear-gradient(135deg, #1a1410 0%, #2c1f17 100%);
  border: 2px solid #d4a574;
  border-radius: 12px;
  padding: 14px;
  margin-bottom: 13px;
  cursor: pointer;
  transition: transform .15s, box-shadow .2s;
  box-shadow: 0 4px 16px rgba(0,0,0,.25), inset 0 0 0 1px rgba(212, 165, 116, .3);
  position: relative;
  overflow: hidden;
}
.quote-card::before {
  content: '';
  position: absolute;
  top: -2px; left: -2px; right: -2px; bottom: -2px;
  background: linear-gradient(135deg, transparent 0%, rgba(212, 165, 116, .15) 50%, transparent 100%);
  pointer-events: none;
}
.quote-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.35), inset 0 0 0 1px rgba(212, 165, 116, .5);
}

/* 左右レイアウト */
.quote-body {
  display: flex;
  gap: 14px;
  align-items: stretch;
  position: relative;
  z-index: 1;
}

/* 左：名言テキスト（画面の半分・名言を目立たせる） */
.quote-left {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 6px 10px;
  border-right: 1px solid rgba(212, 165, 116, .3);
}
.quote-text {
  font-family: "Hiragino Mincho ProN", "Yu Mincho", serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  color: #f4e8d4;
  text-shadow: 0 1px 2px rgba(0,0,0,.4);
  position: relative;
}
.quote-text::before {
  content: '"';
  font-size: 32px;
  color: #d4a574;
  position: absolute;
  top: -14px;
  left: -8px;
  opacity: .6;
}
.quote-text::after {
  content: '"';
  font-size: 32px;
  color: #d4a574;
  margin-left: 3px;
  line-height: 0;
  vertical-align: -10px;
  opacity: .6;
}

/* 右：作者情報 */
.quote-right {
  flex: 0 0 35%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  text-align: left;
  min-width: 100px;
}
.quote-author {
  font-family: "Hiragino Mincho ProN", "Yu Mincho", serif;
  font-size: 15px;
  font-weight: 900;
  color: #f4e8d4;
}
.quote-jobtitle {
  font-size: 10px;
  color: #d4a574;
  font-weight: 700;
}
.quote-country {
  font-size: 11px;
  color: #c7b39c;
  display: flex;
  align-items: center;
  gap: 4px;
}
.quote-flag {
  font-size: 16px;
}
.quote-trivia-hint {
  margin-top: 6px;
  font-size: 9px;
  color: #b89968;
  letter-spacing: .1em;
  opacity: .8;
  padding-top: 5px;
  border-top: 1px dashed rgba(212, 165, 116, .3);
}

/* レスポンシブ：狭い画面では縦並びに */
@media (max-width: 600px) {
  .quote-text { font-size: 15px; }
  .quote-author { font-size: 14px; }
  .quote-left { padding: 4px 8px; }
}
@media (max-width: 400px) {
  .quote-body { flex-direction: column; gap: 8px; }
  .quote-left { border-right: none; border-bottom: 1px solid rgba(212, 165, 116, .3); padding-bottom: 10px; }
  .quote-right { flex: none; }
}

/* 管理者画面の名言カード操作エリア */
.admin-quote-ctrl {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  margin-bottom: 8px;
  align-items: center;
}
.admin-quote-status {
  display: inline-block;
  font-size: 10px;
  padding: 2px 8px;
  border-radius: 11px;
  font-weight: 700;
}
.admin-quote-status.confirmed { background: #d1fae5; color: #065f46; }
.admin-quote-status.preview   { background: #fef3c7; color: #b45309; }

/* ════════════════════════════════════════════════════════════
   17c. 詳細モーダルのアコーディオン
═══════════════════════════════════════════════════════════ */
.det-acc {
  border: 1px solid var(--border);
  border-radius: 9px;
  margin-bottom: 8px;
  background: var(--card);
  overflow: hidden;
}
.det-acc-hdr {
  padding: 9px 12px;
  background: var(--bg);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
  font-weight: 700;
  user-select: none;
}
.det-acc-hdr:hover { background: var(--bg2); }
.det-acc-arrow {
  font-size: 11px;
  color: var(--ink3);
  transition: transform .2s;
}
.det-acc[data-open="1"] .det-acc-arrow { transform: rotate(180deg); }
.det-acc-body {
  padding: 11px 13px;
  border-top: 1px solid var(--border);
  display: none;
}
.det-acc[data-open="1"] .det-acc-body { display: block; }
.det-acc-line {
  padding: 9px 13px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
}

/* 時刻ステッパー（時↑↓・分↑↓） */
.time-stepper {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 8px 10px;
  margin-bottom: 7px;
}
.time-stepper-lbl {
  font-size: 11px;
  font-weight: 700;
  color: var(--ink2);
  margin-bottom: 6px;
}
.time-stepper-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.ts-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  min-width: 48px;
}
.ts-btn-arrow {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 5px;
  width: 100%;
  padding: 4px 0;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  color: var(--accent2);
  user-select: none;
  -webkit-user-select: none;
  line-height: 1;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.ts-btn-arrow:hover {
  background: #eff6ff;
  border-color: var(--accent2);
}
.ts-btn-arrow:active {
  transform: scale(0.92);
}
.ts-num {
  font-size: 22px;
  font-weight: 900;
  font-family: var(--font-mono);
  color: var(--ink);
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 5px;
  padding: 3px 0;
  width: 100%;
  text-align: center;
  min-width: 44px;
}
/* テンキー入力対応: input要素としてのスタイル調整 */
input.ts-input {
  cursor: text;
  outline: none;
  -moz-appearance: textfield;
  appearance: textfield;
  line-height: 1.2;
}
input.ts-input::-webkit-inner-spin-button,
input.ts-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
input.ts-input:focus {
  border-color: var(--accent2);
  box-shadow: 0 0 0 2px rgba(37,99,235,.18);
}
.ts-unit {
  font-size: 9px;
  color: var(--ink3);
  margin-top: 2px;
}
.ts-sep {
  font-size: 22px;
  font-weight: 900;
  color: var(--ink2);
  margin: 0 -2px 14px;
  align-self: center;
}

/* スタート/終了を横並びで2つ並べる場合 */
.stepper-pair {
  display: flex;
  gap: 8px;
  margin-bottom: 8px;
}
.stepper-pair > .time-stepper { flex: 1; }

/* ════════════════════════════════════════════════════════════
   17d. SY掲示板（付箋2列）
═══════════════════════════════════════════════════════════ */
.sy-board-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.sy-note {
  position: relative;
  border-radius: 4px;
  padding: 12px 13px 10px;
  box-shadow: 2px 3px 7px rgba(0,0,0,.12), 0 0 0 1px rgba(0,0,0,.04);
  min-height: 100px;
  display: flex;
  flex-direction: column;
  font-family: "Hiragino Maru Gothic ProN", "Yu Gothic", sans-serif;
  transition: transform .15s;
}
.sy-note:nth-child(odd)  { transform: rotate(-1deg); }
.sy-note:nth-child(even) { transform: rotate(1deg); }
.sy-note:hover { transform: rotate(0) scale(1.02); z-index: 2; }
.sy-note-mine {
  outline: 2px dashed var(--accent);
  outline-offset: 2px;
}
.sy-note-body {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.6;
  flex: 1;
  white-space: pre-wrap;
  word-break: break-word;
  margin-bottom: 8px;
  color: #3a2f1f;
}
.sy-note-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 10px;
  border-top: 1px dashed rgba(0,0,0,.15);
  padding-top: 6px;
}
.sy-note-author {
  font-weight: 900;
  color: #3a2f1f;
}
.sy-note-time {
  color: #7a6c4a;
}
.sy-note-reply {
  background: rgba(255,255,255,.6);
  border-radius: 5px;
  padding: 4px 7px;
  margin-top: 5px;
  font-size: 11px;
  line-height: 1.5;
  color: #3a2f1f;
}
.sy-note-actions {
  display: flex;
  gap: 4px;
  margin-top: 6px;
}

@media (max-width: 400px) {
  .sy-board-grid { gap: 7px; }
  .sy-note { padding: 10px 11px 8px; min-height: 85px; }
  .sy-note-body { font-size: 12px; }
}

/* 大ボタン（学習スタート） */
.btn-start-study {
  width: 100%;
  background: linear-gradient(135deg, var(--green), #059669);
  color: #fff;
  border: none;
  border-radius: 14px;
  padding: 22px 16px;
  font-size: 22px;
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(5, 150, 105, 0.35);
  transition: transform .15s, box-shadow .2s;
  letter-spacing: .05em;
}
.btn-start-study:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(5, 150, 105, 0.45);
}
.btn-start-study:active { transform: translateY(0); }

/* 学習中の表示（控えめ：時間は上のヘッダー entry-elapsed で確認） */
.free-running-row {
  background: #f0fdf4;
  border: 1.5px solid var(--green);
  border-radius: 10px;
  padding: 9px 13px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.btn-stop-study {
  background: var(--card);
  color: var(--ink2);
  border: 1.5px solid var(--border);
  border-radius: 7px;
  padding: 6px 14px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}
.btn-stop-study:hover {
  background: #fef2f2;
  border-color: var(--accent);
  color: var(--accent);
}

/* 退室モーダル */
.lo-summary-card {
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: 11px 13px;
  margin-bottom: 10px;
}
.lo-summary-hdr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  font-weight: 700;
  color: var(--ink2);
  margin-bottom: 5px;
}
.lo-summary-time {
  font-size: 18px;
  font-weight: 900;
  font-family: var(--font-mono);
  color: var(--ink);
  text-align: center;
  padding: 3px 0;
}
.lo-summary-total {
  font-size: 13px;
  color: var(--ink2);
  text-align: center;
  font-weight: 700;
}
.lo-summary-total span {
  font-size: 16px;
  color: var(--green);
  font-weight: 900;
}
.lo-edit-form {
  background: #f0f7ff;
  border: 1.5px solid #bfdbfe;
  border-radius: 10px;
  padding: 11px;
  margin-bottom: 11px;
}
.btn-logout-final {
  width: 100%;
  background: linear-gradient(135deg, var(--accent), #dc2626);
  color: #fff;
  border: none;
  border-radius: 12px;
  padding: 16px;
  font-size: 17px;
  font-weight: 900;
  cursor: pointer;
  margin-top: 14px;
  box-shadow: 0 4px 14px rgba(220, 38, 38, 0.3);
}
.btn-logout-final:hover {
  transform: translateY(-2px);
}
.btn-logout-cancel {
  width: 100%;
  background: transparent;
  color: var(--ink3);
  border: 1.5px solid var(--border);
  border-radius: 9px;
  padding: 8px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  margin-top: 8px;
}
.btn-logout-cancel:hover {
  background: var(--bg);
  color: var(--ink2);
}

/* ════════════════════════════════════════════════════════════
   17e. ポータル新UI（昨日今日サマリ・大ボタン・3カテゴリ）
═══════════════════════════════════════════════════════════ */
.day-summary-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 13px;
}
.day-summary-col {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 9px;
  padding: 9px 11px;
}
.day-summary-col:nth-child(2) {
  border-color: var(--accent);
  background: #fff7ed;
}
.day-summary-lbl {
  font-size: 11px;
  font-weight: 900;
  color: var(--ink2);
  margin-bottom: 5px;
  letter-spacing: .1em;
}
.day-summary-line {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 3px 0;
  font-size: 13px;
  border-bottom: 1px dashed rgba(0,0,0,.06);
}
.day-summary-line:last-child { border-bottom: none; }

/* 大ボタン（学習スタート/終了）配置 */
.study-buttons-wrap {
  margin-bottom: 13px;
}

/* 今日のやること見出し（大きく目立つ） */
.today-todo-hdr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: linear-gradient(90deg, #fef3c7, #fde68a);
  border: 2px solid #f59e0b;
  border-radius: 10px;
  padding: 9px 13px;
  margin: 14px 0 11px;
}
.today-todo-title {
  font-size: 16px;
  font-weight: 900;
  color: #92400e;
  letter-spacing: .05em;
}

/* 今日のやることのカテゴリ */
.todo-category {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 9px;
  padding: 9px 11px;
  margin-bottom: 9px;
}
.todo-cat-title {
  font-size: 12px;
  font-weight: 900;
  color: var(--ink2);
  margin-bottom: 7px;
  padding-bottom: 5px;
  border-bottom: 1px dashed var(--border);
}


/* ════════════════════════════════════════════════════════════
   18. レスポンシブ
═══════════════════════════════════════════════════════════ */
@media (max-width: 500px) {
  .tab, .admin-tab { padding: 8px 10px; font-size: 11px; }
  .task-title      { font-size: 12px; }
  .st-total        { font-size: 28px; }
  .modal           { padding: 16px; }
}


/* ════════════════════════════════════════════════════════════
   19. スクロールバー
═══════════════════════════════════════════════════════════ */
::-webkit-scrollbar       { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 99px; }

/* ════════════════════════════════════════════════════════════
   管理者画面 モバイル対応（スマートフォン）
   768px 以下でコンパクトなレイアウトに切り替え
═══════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ── ヘッダー ── */
  .admin-header {
    padding: 8px 11px;
    gap: 7px;
  }
  .admin-header .title { font-size: 12px; }
  .admin-header .sub   { display: none; }  /* サブタイトルは省略 */

  /* ── タブバー: 絵文字のみ / テキストは小さく ── */
  .admin-tab {
    padding: 8px 10px;
    font-size: 11px;
  }
  /* スマホではタブテキストを絵文字+短縮形に書き換え（JS で制御） */

  /* ── コンテンツエリア ── */
  .admin-cnt { padding: 9px 8px; }

  /* ── カード ── */
  .card       { padding: 10px 10px; }
  .card-title { font-size: 13px; }

  /* ── ボタン ── */
  .btn-sm {
    padding: 5px 9px;
    font-size: 11px;
  }

  /* ── モーダル: 画面幅いっぱいに ── */
  .modal-box,
  [style*="max-width:500px"],
  [style*="max-width: 500px"] {
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
  }

  /* ── テーブル: 横スクロール + 最小幅 ── */
  .tbl-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  #home-table { min-width: 580px; font-size: 11px; }
  #home-table th,
  #home-table td { padding: 6px 5px; }

  /* ── flex が狭い画面で折り返すように ── */
  .flex-between { flex-wrap: wrap; gap: 5px; }

  /* ── 在室カード: 小さく ── */
  #home-live-cards > div { min-width: 60px; }

  /* ── 週テスト管理エリア ── */
  #admin-tab-tasks .flex-between { flex-direction: column; align-items: stretch; }
  #admin-tab-tasks .btn-sm { width: 100%; text-align: center; }

  /* ── 生徒管理テーブル ── */
  #tab-students-table { min-width: 480px; font-size: 11px; }
}

/* さらに狭い画面（iPhone SE: 375px 以下）向け追加調整 */
@media (max-width: 400px) {
  .admin-header { padding: 7px 9px; }
  .admin-tab    { padding: 7px 7px; font-size: 10px; }
  .admin-cnt    { padding: 7px 6px; }
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .85; transform: scale(1.06); }
}

.ss-unit-group { margin-bottom: 8px; }
.ss-unit-header { font-size: 12px; font-weight: 700; color: #555; padding: 5px 10px; background: #f0f0f0; border-radius: 6px; margin-bottom: 2px; }
.ss-test-row { padding: 8px 14px; cursor: pointer; border-radius: 6px; font-size: 13px; }
.ss-test-matome { font-weight: 700; color: #1a73e8; padding: 8px 14px; cursor: pointer; border-radius: 6px; font-size: 13px; margin-bottom: 8px; }
