/* =========================================================
   NetMaster — TCP/IP習熟アプリ  デザインシステム
   ========================================================= */
:root{
  --side-w: 264px;
  --radius: 14px;
  --radius-sm: 10px;
  --gap: 16px;
  --maxw: 920px;
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Kaku Gothic ProN",
          "Yu Gothic", Meiryo, system-ui, sans-serif;
  --mono: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
  --speed: .22s;
}

/* ---- カラーテーマ ---- */
[data-theme="dark"]{
  --bg: #0b1220;        --bg2:#0f1830;      --panel:#131f3a;   --panel2:#0e1730;
  --ink:#e8eefc;        --ink-soft:#a9b6d6; --ink-dim:#8d9bc0;
  --line:#243358;       --line-soft:#1b2747;
  --brand:#5b8cff;      --brand-ink:#cfe0ff; --brand-deep:#2f5fd6;
  --accent:#19d3c5;     --accent-ink:#0a3b38;
  --ok:#37d67a;         --warn:#ffb02e;     --bad:#ff5c7a;
  --shadow: 0 10px 30px rgba(0,0,0,.45);
  --code-bg:#06101f;
}
[data-theme="light"]{
  --bg:#f3f6fc;         --bg2:#eaf0fb;      --panel:#ffffff;   --panel2:#f7f9ff;
  --ink:#162033;        --ink-soft:#46566f; --ink-dim:#5c6884;
  --line:#dbe3f2;       --line-soft:#e9eefaff;
  --brand:#2f5fd6;      --brand-ink:#1d3a86; --brand-deep:#2f5fd6;
  --accent:#0bb3a6;     --accent-ink:#e6fffb;
  --ok:#1eae5e;         --warn:#c97a00;     --bad:#e23b5a;
  --shadow: 0 8px 24px rgba(40,60,110,.12);
  --code-bg:#0d1830;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0; font-family:var(--font); background:var(--bg); color:var(--ink);
  -webkit-font-smoothing:antialiased; line-height:1.7; font-size:16px;
  overscroll-behavior-y:none;
}
a{ color:var(--brand); text-decoration:none; }
h1,h2,h3,h4{ line-height:1.35; margin:.2em 0 .5em; }
h1{ font-size:1.6rem; } h2{ font-size:1.28rem; } h3{ font-size:1.08rem; }
p{ margin:.5em 0; }
code,kbd{ font-family:var(--mono); }

/* =========================================================
   レイアウト
   ========================================================= */
#app-shell{ display:flex; min-height:100dvh; }

#sidebar{
  width:var(--side-w); flex:0 0 var(--side-w); background:var(--panel2);
  border-right:1px solid var(--line); display:flex; flex-direction:column;
  position:sticky; top:0; height:100dvh; z-index:40;
}
.brand{ display:flex; gap:10px; align-items:center; padding:18px 18px 10px; }
.brand-logo{ font-size:1.7rem; }
.brand-text strong{ display:block; font-size:1.05rem; letter-spacing:.02em; }
.brand-text small{ color:var(--ink-dim); font-size:.74rem; }

#main-nav{ flex:1; overflow-y:auto; padding:8px 10px 12px; }
.nav-group-title{ font-size:.72rem; color:var(--ink-dim); padding:14px 12px 6px; letter-spacing:.08em; }
.nav-item{
  display:flex; align-items:center; gap:10px; width:100%; text-align:left;
  background:none; border:0; color:var(--ink-soft); cursor:pointer;
  padding:9px 12px; border-radius:10px; font-size:.92rem; transition:var(--speed);
}
.nav-item:hover{ background:var(--bg2); color:var(--ink); }
.nav-item.active{ background:linear-gradient(90deg,var(--brand-deep),transparent); color:#fff; }
.nav-item .nav-ic{ width:22px; text-align:center; }
.nav-item .nav-badge{ margin-left:auto; font-size:.7rem; color:var(--ink-dim); }
.nav-item.done .nav-badge{ color:var(--ok); }

.sidebar-foot{ display:flex; gap:8px; padding:10px; border-top:1px solid var(--line); }
.ghost-btn{
  flex:1; background:var(--bg2); border:1px solid var(--line); color:var(--ink-soft);
  border-radius:10px; padding:8px; font-size:.78rem; cursor:pointer; transition:var(--speed);
}
.ghost-btn:hover{ color:var(--ink); border-color:var(--brand); }

#main-wrap{ flex:1; min-width:0; display:flex; flex-direction:column; }
#topbar{
  position:sticky; top:0; z-index:30; display:flex; align-items:center; gap:12px;
  padding:12px 20px; background:color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter:saturate(140%) blur(8px); border-bottom:1px solid var(--line-soft);
}
#menu-toggle{ display:none; }
.icon-btn{ background:none; border:0; color:var(--ink); font-size:1.3rem; cursor:pointer; padding:4px 8px; border-radius:8px; }
.icon-btn:hover{ background:var(--bg2); }
#breadcrumb{ flex:1; min-width:0; color:var(--ink-soft); font-size:.86rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
#breadcrumb b{ color:var(--ink); }

.mini-ring{ position:relative; width:34px; height:34px; }
.mini-ring svg{ width:34px; height:34px; transform:rotate(-90deg); }
.ring-bg{ fill:none; stroke:var(--line); stroke-width:3; }
.ring-fill{ fill:none; stroke:var(--accent); stroke-width:3; stroke-linecap:round;
  stroke-dasharray:100 100; stroke-dashoffset:100; transition:stroke-dashoffset .6s ease; }
#ring-label{ position:absolute; inset:0; display:grid; place-items:center; font-size:.6rem; color:var(--ink-soft); }

#view{ flex:1; padding:26px 20px 60px; outline:none; }
.page{ max-width:var(--maxw); margin:0 auto; animation:fade .3s ease; }
@keyframes fade{ from{opacity:0; transform:translateY(6px);} to{opacity:1; transform:none;} }

/* 下タブ（スマホ） */
#bottom-nav{ display:none; }

/* =========================================================
   共通パーツ
   ========================================================= */
.card{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:18px; box-shadow:var(--shadow);
}
.card + .card{ margin-top:var(--gap); }
.grid{ display:grid; gap:var(--gap); }
.grid.cols-2{ grid-template-columns:repeat(2,1fr); }
.grid.cols-3{ grid-template-columns:repeat(3,1fr); }

.btn{
  display:inline-flex; align-items:center; gap:8px; justify-content:center;
  background:var(--brand-deep); color:#fff; border:0; border-radius:10px;
  padding:11px 18px; font-size:.95rem; font-weight:600; cursor:pointer; transition:var(--speed);
}
.btn:hover{ filter:brightness(1.08); transform:translateY(-1px); }
.btn:disabled{ opacity:.5; cursor:not-allowed; transform:none; }

/* キーボード操作時のフォーカス可視化（WCAG 2.4.7 Focus Visible） */
:focus-visible{ outline:3px solid var(--accent); outline-offset:2px; border-radius:6px; }
.choice:focus-visible, .nav-item:focus-visible, .tile:focus-visible,
.btn:focus-visible, .icon-btn:focus-visible, #bottom-nav button:focus-visible{
  outline:3px solid var(--accent); outline-offset:2px;
}
.btn.secondary{ background:var(--bg2); color:var(--ink); border:1px solid var(--line); }
.btn.accent{ background:var(--accent); color:var(--accent-ink); }
.btn.block{ width:100%; }
.btn-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:14px; }

.pill{ display:inline-block; padding:3px 10px; border-radius:999px; font-size:.74rem;
  background:var(--bg2); color:var(--ink-soft); border:1px solid var(--line); }
.pill.ok{ color:var(--ok); border-color:color-mix(in srgb,var(--ok) 40%, var(--line)); }
.pill.lab{ color:var(--accent); border-color:color-mix(in srgb,var(--accent) 40%, var(--line)); }

.tag-list{ display:flex; gap:8px; flex-wrap:wrap; margin:8px 0; }

/* 進捗バー */
.bar{ height:8px; background:var(--bg2); border-radius:999px; overflow:hidden; }
.bar > span{ display:block; height:100%; background:linear-gradient(90deg,var(--brand),var(--accent)); width:0; transition:width .6s ease; }

/* コードや出力 */
.mono-box{ font-family:var(--mono); background:var(--code-bg); color:#d6e4ff; border-radius:var(--radius-sm);
  padding:14px; overflow:auto; font-size:.85rem; border:1px solid var(--line); }

/* 注意ボックス */
.callout{ border-left:4px solid var(--brand); background:var(--bg2); padding:12px 14px; border-radius:8px; margin:12px 0; }
.callout.tip{ border-color:var(--accent); }
.callout.warn{ border-color:var(--warn); }
.callout.key{ border-color:var(--ok); }
.callout .ttl{ font-weight:700; font-size:.85rem; display:block; margin-bottom:4px; }

/* 段階開示（ヒント→途中→答え） */
details.reveal{ border:1px solid var(--line); border-radius:10px; padding:0 14px; margin:10px 0; background:var(--panel2); }
details.reveal > summary{ cursor:pointer; padding:12px 0; font-weight:600; list-style:none; display:flex; gap:8px; align-items:center; }
details.reveal > summary::-webkit-details-marker{ display:none; }
details.reveal > summary::before{ content:"▶"; font-size:.7rem; color:var(--brand); transition:var(--speed); }
details.reveal[open] > summary::before{ transform:rotate(90deg); }
details.reveal .reveal-body{ padding-bottom:14px; color:var(--ink-soft); }

/* =========================================================
   ダッシュボード / カード一覧
   ========================================================= */
.hero{ background:linear-gradient(135deg,var(--brand-deep),var(--panel)); border:1px solid var(--line);
  border-radius:var(--radius); padding:24px; margin-bottom:var(--gap); position:relative; overflow:hidden; }
.hero h1{ color:#fff; margin-top:0; }
.hero p{ color:var(--brand-ink); max-width:60ch; }
.hero .hero-stats{ display:flex; gap:22px; margin-top:14px; flex-wrap:wrap; }
.hero .stat b{ font-size:1.5rem; color:#fff; display:block; }
.hero .stat small{ color:var(--brand-ink); }

.tile{
  display:flex; flex-direction:column; gap:6px; text-align:left; cursor:pointer;
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:16px; transition:var(--speed); color:inherit;
}
.tile:hover{ transform:translateY(-3px); border-color:var(--brand); box-shadow:var(--shadow); }
.tile .tile-ic{ font-size:1.7rem; }
.tile .tile-title{ font-weight:700; }
.tile .tile-sub{ font-size:.8rem; color:var(--ink-dim); }
.tile .bar{ margin-top:8px; }

/* =========================================================
   クイズ
   ========================================================= */
.quiz-q{ font-size:1.05rem; font-weight:600; margin-bottom:14px; }
.choice{ display:block; width:100%; text-align:left; background:var(--panel2); border:1.5px solid var(--line);
  border-radius:12px; padding:13px 15px; margin:9px 0; cursor:pointer; font-size:.95rem; color:var(--ink); transition:var(--speed); }
.choice:hover{ border-color:var(--brand); }
.choice.selected{ border-color:var(--brand); background:color-mix(in srgb,var(--brand) 14%, var(--panel2)); }
.choice.correct{ border-color:var(--ok); background:color-mix(in srgb,var(--ok) 16%, var(--panel2)); }
.choice.wrong{ border-color:var(--bad); background:color-mix(in srgb,var(--bad) 14%, var(--panel2)); }
.choice .mark{ float:right; font-weight:700; }
.explain{ margin-top:14px; }

.fill-input{ font-family:var(--mono); background:var(--panel2); border:1.5px solid var(--line); color:var(--ink);
  border-radius:8px; padding:9px 12px; font-size:1rem; width:auto; min-width:120px; }
.fill-input:focus{ outline:none; border-color:var(--brand); }

.quiz-progress{ display:flex; align-items:center; gap:10px; margin-bottom:16px; color:var(--ink-dim); font-size:.82rem; }
.quiz-progress .bar{ flex:1; }

/* 結果 */
.result-score{ font-size:3rem; font-weight:800; text-align:center; }
.result-score small{ font-size:1rem; color:var(--ink-dim); font-weight:400; }

/* =========================================================
   ラボ共通
   ========================================================= */
.lab-stage{ background:var(--panel2); border:1px solid var(--line); border-radius:var(--radius); padding:16px; margin:14px 0; }
.field-row{ display:flex; gap:10px; flex-wrap:wrap; align-items:flex-end; margin:10px 0; }
.field{ display:flex; flex-direction:column; gap:4px; }
.field label{ font-size:.78rem; color:var(--ink-dim); }
.field input,.field select{ background:var(--panel); border:1.5px solid var(--line); color:var(--ink);
  border-radius:8px; padding:9px 11px; font-size:.95rem; font-family:var(--mono); }
.field input:focus,.field select:focus{ outline:none; border-color:var(--brand); }

/* 2進数表示 */
.bits{ font-family:var(--mono); letter-spacing:1px; display:flex; flex-wrap:wrap; gap:2px; }
.bits .octet{ display:inline-flex; gap:1px; padding:3px 5px; background:var(--code-bg); border-radius:6px; }
.bits .b{ width:13px; text-align:center; }
.bits .b.net{ color:var(--brand); text-decoration:underline solid; text-underline-offset:3px; }
.bits .b.host{ color:var(--accent); text-decoration:underline dotted; text-underline-offset:3px; }
.bits .b.on{ font-weight:700; }

table.netinfo{ width:100%; border-collapse:collapse; font-size:.9rem; }
table.netinfo td{ padding:8px 10px; border-bottom:1px solid var(--line-soft); }
table.netinfo td:first-child{ color:var(--ink-dim); width:42%; }
table.netinfo td:last-child{ font-family:var(--mono); }

/* 端末エミュ */
.term{ background:#04101e; border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.term-head{ display:flex; align-items:center; gap:6px; padding:8px 12px; background:#0a1830; border-bottom:1px solid var(--line); }
.term-dot{ width:11px; height:11px; border-radius:50%; }
.term-body{ font-family:var(--mono); font-size:.84rem; color:#cfe8ff; padding:12px; height:340px; overflow-y:auto; }
.term-line{ white-space:pre-wrap; word-break:break-all; }
.term-line.cmd{ color:#7fffd4; }
.term-line.muted{ color:#6f86a8; }
.term-inputline{ display:flex; gap:8px; padding:8px 12px; border-top:1px solid var(--line); background:#061426; }
.term-inputline span{ color:#7fffd4; font-family:var(--mono); }
.term-inputline input{ flex:1; background:none; border:0; color:#cfe8ff; font-family:var(--mono); font-size:.84rem; outline:none; }

/* パケットの旅 / 図解アニメ */
.stack{ display:flex; flex-direction:column; gap:6px; }
.layer{ border:1.5px solid var(--line); border-radius:10px; padding:10px 12px; transition:var(--speed); background:var(--panel); }
.layer.lit{ border-color:var(--brand); box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 25%, transparent); }
.layer .layer-name{ font-size:.78rem; color:var(--ink-dim); }
.pkt{ display:flex; align-items:stretch; border-radius:8px; overflow:hidden; border:1px solid var(--line); font-size:.72rem; font-family:var(--mono); margin-top:6px; }
.pkt .seg{ padding:6px 8px; white-space:nowrap; }
.pkt .seg.h{ background:color-mix(in srgb,var(--brand) 30%, var(--panel)); }
.pkt .seg.data{ background:var(--panel2); flex:1; }

/* トースト */
#toast{ position:fixed; left:50%; bottom:26px; transform:translateX(-50%) translateY(20px);
  background:var(--panel); color:var(--ink); border:1px solid var(--line); box-shadow:var(--shadow);
  padding:12px 18px; border-radius:12px; z-index:100; opacity:0; transition:var(--speed); font-size:.9rem; }
#toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }
#toast.ok{ border-color:var(--ok); } #toast.bad{ border-color:var(--bad); }

#scrim{ position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:35; }

/* =========================================================
   レスポンシブ（スマホ）
   ========================================================= */
@media (max-width: 820px){
  #sidebar{ position:fixed; left:0; top:0; transform:translateX(-100%); transition:transform var(--speed); }
  #app-shell.nav-open #sidebar{ transform:none; }
  #menu-toggle{ display:inline-block; }
  #view{ padding:18px 14px 84px; }
  .grid.cols-2,.grid.cols-3{ grid-template-columns:1fr; }
  .hero{ padding:18px; }
  #bottom-nav{
    display:flex; position:fixed; bottom:0; left:0; right:0; z-index:30;
    background:color-mix(in srgb,var(--panel) 92%, transparent); backdrop-filter:blur(8px);
    border-top:1px solid var(--line); padding:6px 4px calc(6px + env(safe-area-inset-bottom));
  }
  #bottom-nav button{ flex:1; background:none; border:0; color:var(--ink-dim); font-size:.66rem;
    display:flex; flex-direction:column; align-items:center; gap:2px; padding:6px 2px; cursor:pointer; }
  #bottom-nav button .bic{ font-size:1.25rem; }
  #bottom-nav button.active{ color:var(--brand); }
}
@media (max-width: 420px){
  body{ font-size:15px; }
  .result-score{ font-size:2.4rem; }
}

@media (prefers-reduced-motion: reduce){ *{ animation:none !important; transition:none !important; } }
