/* =========================================================
   トリセツ! — 生徒用スマホアプリ プロトタイプ
   デザインシステム / 共通スタイル
   ========================================================= */

:root{
  /* ブランドカラー */
  --c-teal:#64a19c;
  --c-blue:#76a3db;
  --c-gold:#d29a24;
  --c-purple:#bf6ea3;
  --brand:var(--c-teal);
  --brand-dark:#4f857f;

  /* ベース */
  --bg:#f4f6f7;
  --surface:#ffffff;
  --line:#e6eaec;
  --text:#1f2a2e;
  --text-sub:#65757b;
  --text-mute:#9aa7ac;

  /* 状態色 */
  --ok:#3a9d6e;
  --warn:#d29a24;
  --danger:#d2604f;

  --radius:14px;
  --radius-sm:10px;
  --shadow:0 2px 10px rgba(31,42,46,.06);
  --shadow-lg:0 8px 28px rgba(31,42,46,.16);
  --font:"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,system-ui,sans-serif;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--font);
  color:var(--text);
  background:#dfe4e6;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

/* ===== スマホフレーム ===== */
.device-frame{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
}
.device-screen{
  position:relative;
  width:100%;max-width:420px;height:880px;max-height:92vh;
  background:var(--bg);
  border-radius:34px;
  box-shadow:var(--shadow-lg);
  overflow:hidden;
  display:flex;flex-direction:column;
  border:10px solid #1f2a2e;
}
/* スマホ幅では枠を外して全画面 */
@media (max-width:560px){
  .device-frame{padding:0;}
  .device-screen{max-width:none;height:100vh;max-height:none;border:0;border-radius:0;}
}

/* ===== ヘッダー ===== */
.app-header{
  flex:0 0 auto;
  display:flex;align-items:center;gap:8px;
  height:56px;padding:0 8px;
  background:var(--surface);
  border-bottom:1px solid var(--line);
  z-index:5;
}
.hdr-back{
  border:0;background:none;font-size:30px;line-height:1;
  color:var(--brand);width:40px;height:40px;border-radius:50%;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.hdr-back:hover{background:var(--bg);}
.hdr-back[hidden]{display:none;}
.hdr-title{
  flex:1;margin:0;font-size:17px;font-weight:700;
  text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.hdr-action{
  border:0;background:none;color:var(--brand);font-size:14px;font-weight:700;
  padding:8px 10px;border-radius:8px;cursor:pointer;min-width:40px;
}
.hdr-action:hover{background:var(--bg);}

/* ===== メイン ===== */
.app-main{
  flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:16px;
}
.app-main.no-pad{padding:0;}

/* ===== 下部ナビ ===== */
.bottom-nav{
  flex:0 0 auto;display:flex;
  background:var(--surface);
  border-top:1px solid var(--line);
  padding:6px 4px env(safe-area-inset-bottom,6px);
}
.nav-item{
  flex:1;border:0;background:none;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:6px 0;color:var(--text-mute);font-size:11px;font-weight:600;
}
.nav-ico{font-size:21px;line-height:1;}
.nav-item.active{color:var(--brand);}

/* =========================================================
   汎用パーツ
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:0;border-radius:12px;cursor:pointer;
  font-family:inherit;font-size:16px;font-weight:700;
  padding:15px 18px;width:100%;
  background:var(--brand);color:#fff;
  transition:filter .15s,transform .05s;
}
.btn:hover{filter:brightness(1.05);}
.btn:active{transform:translateY(1px);}
.btn.secondary{background:#fff;color:var(--brand);border:2px solid var(--brand);}
.btn.ghost{background:var(--bg);color:var(--text);}
.btn.line{background:#06c755;color:#fff;}
.btn.danger{background:#fff;color:var(--danger);border:2px solid var(--danger);}
.btn.sm{width:auto;padding:9px 14px;font-size:13px;border-radius:10px;}
.btn.block{width:100%;}
.btn:disabled{opacity:.5;cursor:not-allowed;}
.btn-row{display:flex;gap:10px;}
.btn-row .btn{flex:1;}

.link{
  background:none;border:0;color:var(--brand);font-weight:700;
  cursor:pointer;font-size:14px;font-family:inherit;padding:4px;
}
.link:hover{text-decoration:underline;}

.card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);
  overflow:hidden;
}

.field{margin-bottom:14px;}
.field label{display:block;font-size:13px;font-weight:700;color:var(--text-sub);margin-bottom:6px;}
.field input,.field select,.field textarea{
  width:100%;padding:13px 14px;font-size:16px;font-family:inherit;
  border:1.5px solid var(--line);border-radius:11px;background:#fff;color:var(--text);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand);}
.field textarea{resize:vertical;min-height:120px;}
.field .hint{font-size:12px;color:var(--text-mute);margin-top:5px;}

.badge{
  display:inline-flex;align-items:center;gap:4px;
  font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;
  background:var(--bg);color:var(--text-sub);
}
.badge.ok{background:#e6f4ee;color:var(--ok);}
.badge.warn{background:#fbf1dc;color:#a9781a;}
.badge.danger{background:#fbe7e3;color:var(--danger);}
.badge.info{background:#e9f1fb;color:#3f6fa8;}
.badge.brand{background:#e3f0ef;color:var(--brand-dark);}

.section-title{
  font-size:13px;font-weight:700;color:var(--text-mute);
  margin:18px 2px 8px;letter-spacing:.02em;
}
.divider{height:1px;background:var(--line);margin:14px 0;}

/* プログレスバー */
.progress{height:8px;border-radius:999px;background:#e9eef0;overflow:hidden;}
.progress > i{display:block;height:100%;border-radius:999px;background:var(--brand);}
.progress.thin{height:5px;}

/* リスト行 */
.list-row{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;border-bottom:1px solid var(--line);
  background:var(--surface);cursor:pointer;text-align:left;width:100%;border:0;
  font-family:inherit;font-size:15px;color:var(--text);
}
.list-row:last-child{border-bottom:0;}
.list-row:hover{background:#fafbfb;}
.list-row .lr-main{flex:1;min-width:0;}
.list-row .lr-title{font-weight:700;}
.list-row .lr-sub{font-size:12px;color:var(--text-mute);}
.list-row .lr-chev{color:var(--text-mute);font-size:22px;}

.empty{
  text-align:center;color:var(--text-mute);padding:48px 20px;
}
.empty .big{font-size:42px;margin-bottom:8px;}

/* =========================================================
   認証画面（ログイン／登録）
   ========================================================= */
.auth{
  min-height:100%;display:flex;flex-direction:column;
  padding:32px 22px;background:
    radial-gradient(120% 60% at 50% 0%, #eaf3f2 0%, var(--bg) 60%);
}
.auth-logo{text-align:center;margin:18px 0 26px;}
.auth-logo .mark{
  width:64px;height:64px;border-radius:18px;margin:0 auto 12px;
  background:linear-gradient(135deg,var(--c-teal),var(--c-blue));
  display:flex;align-items:center;justify-content:center;font-size:32px;
  box-shadow:var(--shadow);
}
.auth-logo h1{font-size:22px;margin:0;}
.auth-logo p{font-size:13px;color:var(--text-sub);margin:4px 0 0;}
.auth .card{padding:20px;}
.auth-foot{margin-top:18px;display:flex;flex-direction:column;gap:6px;align-items:center;}
.or-sep{display:flex;align-items:center;gap:10px;color:var(--text-mute);font-size:12px;margin:14px 0;}
.or-sep::before,.or-sep::after{content:"";flex:1;height:1px;background:var(--line);}

/* ステップインジケータ（登録フロー） */
.steps{display:flex;gap:6px;margin-bottom:18px;}
.steps > i{flex:1;height:5px;border-radius:999px;background:var(--line);}
.steps > i.on{background:var(--brand);}

/* =========================================================
   書籍カード（ホーム）
   ========================================================= */
.book-grid{display:flex;flex-direction:column;gap:14px;}
.book-card{display:flex;gap:14px;padding:14px;align-items:center;cursor:pointer;}
.book-thumb{
  width:78px;height:104px;flex:0 0 auto;border-radius:10px;
  display:flex;align-items:flex-end;padding:8px;color:#fff;font-weight:800;
  font-size:13px;line-height:1.3;box-shadow:var(--shadow);
}
.book-card .bc-main{flex:1;min-width:0;}
.book-card .bc-title{font-weight:800;font-size:16px;margin-bottom:4px;}
.book-card .bc-meta{font-size:12px;color:var(--text-sub);}
.book-card .bc-prog{margin-top:10px;}
.book-card.expired{opacity:.72;}

/* 動画プレイヤー */
.player{
  background:#0e1416;color:#fff;position:relative;aspect-ratio:16/9;width:100%;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.player .pl-bg{position:absolute;inset:0;background:
  radial-gradient(circle at 50% 40%, #25343a, #0e1416);}
.player .pl-play{
  position:relative;width:74px;height:74px;border-radius:50%;
  background:rgba(255,255,255,.16);border:0;color:#fff;font-size:30px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;backdrop-filter:blur(2px);
}
.player .pl-time{position:absolute;left:0;right:0;bottom:0;padding:10px 12px;
  display:flex;align-items:center;gap:10px;font-size:12px;
  background:linear-gradient(transparent,rgba(0,0,0,.55));}
.player .pl-bar{flex:1;height:5px;border-radius:999px;background:rgba(255,255,255,.3);overflow:hidden;}
.player .pl-bar > i{display:block;height:100%;background:var(--c-blue);width:32%;}
.player .pl-badge{position:absolute;top:10px;left:10px;font-size:11px;
  background:rgba(0,0,0,.5);padding:4px 9px;border-radius:8px;}

.video-row{display:flex;align-items:center;gap:12px;padding:13px 14px;border-bottom:1px solid var(--line);background:#fff;}
.video-row:last-child{border-bottom:0;}
.video-row .vr-play{
  width:42px;height:42px;flex:0 0 auto;border-radius:50%;border:0;cursor:pointer;
  background:var(--bg);color:var(--brand);font-size:18px;display:flex;align-items:center;justify-content:center;
}
.video-row .vr-play.done{background:var(--brand);color:#fff;}
.video-row .vr-main{flex:1;min-width:0;}
.video-row .vr-title{font-weight:700;font-size:14px;}
.video-row .vr-sub{font-size:11px;color:var(--text-mute);margin-top:2px;display:flex;gap:8px;flex-wrap:wrap;}
.video-row .vr-dl{border:0;background:none;cursor:pointer;font-size:20px;color:var(--text-mute);padding:6px;}
.video-row .vr-dl.done{color:var(--ok);}

/* 大きい数値（ダッシュボード的） */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px;}
.stat .s-num{font-size:24px;font-weight:800;}
.stat .s-lbl{font-size:12px;color:var(--text-sub);}

/* QRスキャン風 */
.qr-box{
  aspect-ratio:1;background:#0e1416;border-radius:16px;position:relative;
  display:flex;align-items:center;justify-content:center;color:#cfd8db;overflow:hidden;
}
.qr-frame{width:62%;aspect-ratio:1;border:3px solid rgba(255,255,255,.5);border-radius:14px;position:relative;}
.qr-frame::before{content:"";position:absolute;left:6px;right:6px;height:2px;background:var(--c-blue);
  top:50%;box-shadow:0 0 12px var(--c-blue);animation:scan 2.4s ease-in-out infinite;}
@keyframes scan{0%,100%{top:14%;}50%{top:86%;}}

/* トースト */
.toast{
  position:fixed;left:50%;bottom:90px;transform:translateX(-50%);
  background:#1f2a2e;color:#fff;padding:12px 18px;border-radius:12px;
  font-size:14px;font-weight:600;z-index:1000;box-shadow:var(--shadow-lg);
  max-width:88%;text-align:center;
}

/* モーダル */
.modal-overlay{
  position:fixed;inset:0;background:rgba(20,28,31,.5);z-index:900;
  display:flex;align-items:flex-end;justify-content:center;padding:0;
}
.modal{
  background:#fff;width:100%;max-width:440px;border-radius:20px 20px 0 0;
  padding:22px;max-height:84vh;overflow-y:auto;box-shadow:var(--shadow-lg);
}
.modal h3{margin:0 0 6px;font-size:18px;}
.modal .m-sub{color:var(--text-sub);font-size:13px;margin-bottom:16px;}
@media (min-width:560px){
  .modal-overlay{align-items:center;}
  .modal{border-radius:20px;}
}

/* 注意ボックス */
.note{
  background:#f0f6f5;border:1px solid #d8e7e5;border-radius:12px;
  padding:13px 14px;font-size:13px;color:var(--text-sub);
}
.note.warn{background:#fbf4e3;border-color:#eed9a8;color:#8a6614;}
.note.danger{background:#fbeae6;border-color:#f0c7bd;color:#9c3a29;}
.note strong{color:inherit;}

.kv{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px;}
.kv:last-child{border-bottom:0;}
.kv .k{color:var(--text-sub);}
.kv .v{font-weight:700;text-align:right;}

.fab{
  position:absolute;right:16px;bottom:80px;z-index:6;
  width:auto;padding:14px 18px;border-radius:999px;box-shadow:var(--shadow-lg);
}

/* hidden属性を常に優先（display指定で上書きされ、モーダル等が表示されてしまう不具合の修正） */
[hidden]{display:none !important;}
