/* Foxi 7DTD Widget CSS v1.7.7 */

/* 固定360px版（後方互換） */
.foxi7dtd-wrap.foxi7dtd-size-360 { display:block; max-width:360px; }
.foxi7dtd-wrap.foxi7dtd-size-360 .foxi7dtd-row {
  width: 360px;
  height: 105px;
  box-sizing: border-box;
  display: grid;
  grid-template-columns: 1fr 200px;
  gap: 8px;
  align-items: start;
  padding: 10px 10px;
  margin: 8px 0;
  border-radius: 10px;
  background: #ffffff;
  color: #111827;
  box-shadow: 0 1px 2px rgba(0,0,0,0.08), 0 8px 24px rgba(0,0,0,0.06);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Meiryo", sans-serif;
  font-variant-numeric: tabular-nums;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.foxi7dtd-wrap.foxi7dtd-size-360 .foxi7dtd-row.is-down {
  background: #fff6f6;
  box-shadow: 0 1px 2px rgba(0,0,0,0.06), 0 8px 24px rgba(0,0,0,0.04), inset 0 0 0 1px rgba(220,38,38,0.12);
}
.foxi7dtd-wrap.foxi7dtd-size-360 .left { display: grid; grid-template-rows: auto auto 1fr; align-content: start; min-width: 0; }
.foxi7dtd-wrap.foxi7dtd-size-360 .title { font-size: 13px; font-weight: 800; line-height: 1.1; margin-bottom: 2px; color: #111111; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.foxi7dtd-wrap.foxi7dtd-size-360 .meta { display: flex; gap: 8px; align-items: center; font-size: 11px; line-height: 1.1; margin-bottom: 2px; white-space: nowrap; overflow: hidden; }
.foxi7dtd-wrap.foxi7dtd-size-360 .meta .count { font-weight: 800; padding: 0 6px; border-radius: 999px; background: #f3f4f6; color: #374151; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.06); }
.foxi7dtd-wrap.foxi7dtd-size-360 .foxi7dtd-row.is-down .meta .count { background: #fdecec; color: #374151; box-shadow: inset 0 0 0 1px rgba(220,38,38,0.12); }
.foxi7dtd-wrap.foxi7dtd-size-360 .meta .time { color:#111111; }
.foxi7dtd-wrap.foxi7dtd-size-360 .names { display: grid; grid-auto-rows: min-content; row-gap: 2px; font-size: 11px; line-height: 1.1; }
.foxi7dtd-wrap.foxi7dtd-size-360 .names .name .p-name { color: #f59e0b; }
.foxi7dtd-wrap.foxi7dtd-size-360 .names .name .p-level { color:#111111; }
.foxi7dtd-wrap.foxi7dtd-size-360 .names .name.more { color:#6b7280; }
.foxi7dtd-wrap.foxi7dtd-size-360 .names .status-down { color:#dc2626; font-weight:800; }
.foxi7dtd-wrap.foxi7dtd-size-360 .right { display: grid; grid-template-rows: auto 1fr; align-items: start; }
.foxi7dtd-wrap.foxi7dtd-size-360 .g-combo { display: grid; grid-template-rows: auto 1fr; gap: 4px; }
.foxi7dtd-wrap.foxi7dtd-size-360 .g-head { display: flex; align-items: baseline; justify-content: space-between; font-size: 11px; color: #111111; }
.foxi7dtd-wrap.foxi7dtd-size-360 .g-head .vals { display: flex; gap: 6px; align-items: baseline; }
.foxi7dtd-wrap.foxi7dtd-size-360 .g-head .v-fps { color: #166534; } /* FPS濃緑 */
.foxi7dtd-wrap.foxi7dtd-size-360 .g-head .v-rss { color: #f59e0b; } /* RSS橙 */
.foxi7dtd-wrap.foxi7dtd-size-360 .g-head .unit { margin-left:2px; color:#111111; }
.foxi7dtd-wrap.foxi7dtd-size-360 canvas.graph { width: 188px; height: 60px; display: block; background: #f3f4f6; border-radius: 6px; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.06); }

/* fluid版（親幅にフィット。最大360px） */
.foxi7dtd-wrap.foxi7dtd-fluid { width: 100%; max-width: 360px; display:block; }
.foxi7dtd-wrap.foxi7dtd-fluid .foxi7dtd-row{
  width: 100%;
  height: 105px;
  box-sizing: border-box;
  display: grid;
  grid-template-columns: 1fr minmax(140px, 48%);
  gap: 8px;
  align-items: start;
  padding: 10px 10px;
  margin: 8px 0;
  border-radius: 10px;
  background: #ffffff;
  color: #111827;
  box-shadow: 0 1px 2px rgba(0,0,0,0.08), 0 8px 24px rgba(0,0,0,0.06);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Meiryo", sans-serif;
  font-variant-numeric: tabular-nums;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.foxi7dtd-wrap.foxi7dtd-fluid .foxi7dtd-row.is-down {
  background: #fff6f6;
  box-shadow: 0 1px 2px rgba(0,0,0,0.06), 0 8px 24px rgba(0,0,0,0.04), inset 0 0 0 1px rgba(220,38,38,0.12);
}
.foxi7dtd-wrap.foxi7dtd-fluid .left { display: grid; grid-template-rows: auto auto 1fr; align-content: start; min-width: 0; }
.foxi7dtd-wrap.foxi7dtd-fluid .title { font-size: clamp(12px, 1.5vw, 13px); font-weight: 800; line-height: 1.1; margin-bottom: 2px; color: #111111; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.foxi7dtd-wrap.foxi7dtd-fluid .meta { display: flex; gap: 8px; align-items: center; font-size: clamp(10px, 1.3vw, 11px); line-height: 1.1; margin-bottom: 2px; white-space: nowrap; overflow: hidden; }
.foxi7dtd-wrap.foxi7dtd-fluid .meta .count { font-weight: 800; padding: 0 6px; border-radius: 999px; background: #f3f4f6; color: #374151; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.06); }
.foxi7dtd-wrap.foxi7dtd-fluid .foxi7dtd-row.is-down .meta .count { background: #fdecec; color: #374151; box-shadow: inset 0 0 0 1px rgba(220,38,38,0.12); }
.foxi7dtd-wrap.foxi7dtd-fluid .meta .time { color:#111111; }
.foxi7dtd-wrap.foxi7dtd-fluid .names { display: grid; grid-auto-rows: min-content; row-gap: 2px; font-size: clamp(10px, 1.3vw, 11px); line-height: 1.1; }
.foxi7dtd-wrap.foxi7dtd-fluid .names .name .p-name { color: #f59e0b; }
.foxi7dtd-wrap.foxi7dtd-fluid .names .name .p-level { color:#111111; }
.foxi7dtd-wrap.foxi7dtd-fluid .names .name.more { color:#6b7280; }
.foxi7dtd-wrap.foxi7dtd-fluid .names .status-down { color:#dc2626; font-weight:800; }
.foxi7dtd-wrap.foxi7dtd-fluid .right { display: grid; grid-template-rows: auto 1fr; align-items: start; }
.foxi7dtd-wrap.foxi7dtd-fluid .g-combo { display: grid; grid-template-rows: auto 1fr; gap: 4px; }
.foxi7dtd-wrap.foxi7dtd-fluid .g-head { display: flex; align-items: baseline; justify-content: space-between; font-size: clamp(10px, 1.3vw, 11px); color: #111111; }
.foxi7dtd-wrap.foxi7dtd-fluid .g-head .vals { display: flex; gap: 6px; align-items: baseline; }
.foxi7dtd-wrap.foxi7dtd-fluid .g-head .v-fps { color: #166534; }
.foxi7dtd-wrap.foxi7dtd-fluid .g-head .v-rss { color: #f59e0b; }
.foxi7dtd-wrap.foxi7dtd-fluid .g-head .unit { margin-left:2px; color:#111111; }
.foxi7dtd-wrap.foxi7dtd-fluid canvas.graph {
  width: 100%; height: 60px; display: block;
  background: #f3f4f6;
  border-radius: 6px; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.06);
}
.last-login{
  color:#b79b7a;
  font-size:12px;
}
/* last login を1行表示にする */
.foxi7dtd-wrap .last-login {
  display: flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
}

.foxi7dtd-wrap .last-login .label,
.foxi7dtd-wrap .last-login .ago {
  display: inline;
}
@media (max-width: 320px){
  .foxi7dtd-wrap.foxi7dtd-fluid .foxi7dtd-row{ grid-template-columns: 1fr minmax(120px, 44%); }
}

/* ===== Enhancements: Blood Moon / Sunday / Names expand ===== */

/* Blood Moon（現実曜日ベース）:
   日曜 0:00 〜 月曜 6:00 の間だけ、日時＋曜日を「普通の赤」＋太字。
   白テーマ前提で、濃すぎない赤（#dc2626）にする。
   ※グラフの背景/枠/FPS/RSS には影響させない。
*/
.foxi7dtd-wrap .foxi7dtd-row.is-bm .meta .time .dt,
.foxi7dtd-wrap .foxi7dtd-row.is-bm .meta .time .wd{
  font-weight: 800;
  color: #dc2626;
}

/* 通常時の曜日はデフォルト（inherit） */
.foxi7dtd-wrap .meta .time .wd{
  color: inherit;
  font-weight: inherit;
}

/* Names: hover tooltip + expand button */
.foxi7dtd-wrap .names{
  position: relative;
}
.foxi7dtd-wrap .names.has-more .names-tooltip{
  display: none;
  position: absolute;
  left: 0;
  top: calc(100% + 6px);
  z-index: 50;
  min-width: 220px;
  max-width: 320px;
  max-height: 220px;
  overflow: auto;
  padding: 8px;
  border-radius: 10px;
  background: #ffffff;
  color: #111827;
  box-shadow: 0 8px 24px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.08);
  border: 1px solid rgba(0,0,0,0.08);
}
.foxi7dtd-wrap .names.has-more:hover .names-tooltip{
  display: block;
}
.foxi7dtd-wrap .names .names-tooltip .tt-item{
  font-size: 11px;
  line-height: 1.35;
  padding: 2px 0;
  white-space: nowrap;
}
.foxi7dtd-wrap .names .more-btn{
  margin-top: 2px;
}
.foxi7dtd-wrap .names-more-btn{
  appearance: none;
  border: 0;
  padding: 3px 8px;
  border-radius: 999px;
  cursor: pointer;
  font-size: 11px;
  font-weight: 700;
  background: #f3f4f6;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.08);
}
.foxi7dtd-wrap .names-more-btn:hover{
  background: #e5e7eb;
}

/* Expand: ボタン押下で全員表示し、縦幅を伸ばす */
.foxi7dtd-wrap .names .names-all{
  display: none;
  margin-top: 6px;
  row-gap: 2px;
}
.foxi7dtd-wrap .foxi7dtd-row.names-expanded .names-tooltip{
  display: none !important;
}
.foxi7dtd-wrap .foxi7dtd-row.names-expanded .names .names-all{
  display: grid;
}
.foxi7dtd-wrap .foxi7dtd-row.names-expanded{
  height: auto !important;
}

