:root{
  --bg:#0a0a0a;
  --card:#161616;
  --card2:#1f1f1f;
  --border:#2e2e2e;
  --text:#f5f5f5;
  --muted:#9a9a9a;
  --accent:#e05a6d;
  --accent-hover:#f06d80;
  --plus:#4ade80;
  --minus:#f87171;
  --gold:#e3b341;
  --silver:#c4c9d4;
  --radius:18px;
}

*{box-sizing:border-box;}

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Sans","Noto Sans JP",sans-serif;
  padding:20px;
  line-height:1.5;
}

/* ===== レイアウト ===== */
.wrap{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:18px;}
header h1{font-size:22px;margin:0;}
header p{margin:4px 0 0;color:var(--muted);font-size:14px;}

.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
}
.label{font-weight:600;margin-bottom:10px;}
.row{display:flex;gap:10px;}

/* メンバー見出し＋追加を1行に */
.label-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:14px;
}
.label-row .label{margin-bottom:0;}
.member-add{flex:1;max-width:340px;min-width:220px;}

/* ===== フォーム共通 ===== */
input,select{
  background:var(--card2);
  border:1px solid var(--border);
  color:var(--text);
  border-radius:12px;
  padding:11px 14px;
  font-size:14px;
  outline:none;
  width:100%;
}
input:focus,select:focus{border-color:var(--accent);}

/* time 入力のダークテーマ調整 */
input[type="time"]{
  color-scheme:dark;
  min-height:40px;
}

button.btn{
  background:var(--accent);
  color:#fff;
  border:none;
  border-radius:12px;
  padding:11px 18px;
  font-size:14px;
  cursor:pointer;
  white-space:nowrap;
}
button.btn:hover{background:var(--accent-hover);}

.unit-suffix{
  display:flex;
  align-items:center;
  color:var(--muted);
  font-size:14px;
  white-space:nowrap;
}

/* ===== 交換率トグル ===== */
.toggle-row{display:flex;align-items:center;gap:12px;}
.mode-label{font-size:14px;color:var(--muted);}
.mode-label.active{color:var(--text);font-weight:600;}

.switch{position:relative;display:inline-block;width:50px;height:28px;flex-shrink:0;}
.switch input{opacity:0;width:0;height:0;}
.slider{
  position:absolute;
  inset:0;
  cursor:pointer;
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:999px;
  transition:.2s;
}
.slider:before{
  content:"";
  position:absolute;
  height:20px;
  width:20px;
  left:3px;
  top:3px;
  background:var(--muted);
  border-radius:50%;
  transition:.2s;
}
.switch input:checked + .slider{background:var(--accent);border-color:var(--accent);}
.switch input:checked + .slider:before{transform:translateX(22px);background:#fff;}

/* ===== メンバーカード ===== */
.member-card{
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:14px;
  padding:16px;
  margin-bottom:12px;
}
.member-card:last-child{margin-bottom:0;}
.member-head{display:flex;justify-content:space-between;align-items:center;gap:10px;}
.member-name{font-size:17px;font-weight:600;}
.member-pl{font-size:13px;color:var(--muted);}
.member-pl b{color:var(--text);}
.x-btn{background:none;border:none;color:var(--accent);font-size:18px;cursor:pointer;}
.x-btn:hover{color:var(--accent-hover);}

.io-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;}
.io-full{grid-column:1/-1;}
.io-box{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:10px;}
.io-box .t{font-size:12px;color:var(--muted);margin-bottom:6px;}
.io-box .f{display:flex;align-items:center;gap:6px;}

/* 稼働時間（回収の隣のセルに収める・コンパクト化） */
.time-box.is-hidden{display:none;}
.time-fields{display:flex;align-items:center;gap:6px;}
.time-fields input{flex:1;min-width:0;padding:9px 8px;font-size:13px;}
.time-sep{color:var(--muted);font-size:13px;}
.time-result{margin-top:6px;font-size:11px;color:var(--muted);}
.time-result b{color:var(--text);}

.empty-members{color:var(--muted);font-size:14px;padding:6px 2px;}

/* ===== ルール・結果 ===== */
.rule-note{font-size:13px;color:var(--muted);margin-top:10px;}

/* ===== サマリー（総損益を主役に） ===== */
.summary{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:4px;
  margin-bottom:6px;
}
.summary-main{font-size:13px;color:var(--muted);}
.summary-pl{font-size:30px;font-weight:700;line-height:1.2;}
.summary-sub{font-size:12px;color:var(--muted);}
.summary-sub b{color:var(--text);font-weight:600;}

table{width:100%;border-collapse:collapse;margin-top:10px;font-size:14px;}
th,td{padding:10px;border-bottom:1px solid var(--border);text-align:right;}
th:first-child,td:first-child{text-align:left;}
th{color:var(--muted);font-weight:600;font-size:12px;}

.plus{color:var(--plus);}
.minus{color:var(--minus);}

.settle-tag{font-size:11px;color:var(--muted);margin-left:2px;}

/* ===== 精算 ===== */
.settle-line{
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 14px;
  margin-top:8px;
  font-size:14px;
}
.settle-line b{color:var(--accent-hover);}

/* ===== 景品チップ（アイコン＋ ×個数） ===== */
.prize-detail{
  margin-top:6px;
  font-size:13px;
  color:var(--text);
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.prize-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:999px;
  padding:4px 11px;
}
.prize-chip .p-ico{
  width:14px;
  height:14px;
  border-radius:3px;
  flex-shrink:0;
}
/* 大景品＝金、中景品＝銀のグラデーション四角 */
.prize-chip .p-ico.big{
  background:linear-gradient(135deg,#f3d27a,var(--gold));
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.25);
}
.prize-chip .p-ico.mid{
  background:linear-gradient(135deg,#e8ecf4,var(--silver));
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.25);
}
.prize-chip .p-name{color:var(--muted);}
.prize-chip .p-mul{color:var(--muted);}
.prize-chip .p-cnt{font-weight:700;}
.prize-chip.zandaka{color:var(--minus);}
.prize-chip.none{color:var(--muted);}

/* ===== 景品引き出し ===== */
.withdraw-line{
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 14px;
  margin-top:8px;
  font-size:14px;
}
.withdraw-line .wname{font-weight:600;}
.withdraw-line .wnote{margin-top:4px;font-size:12px;color:var(--muted);}

.empty{color:var(--muted);font-size:14px;}

/* ===== レスポンシブ ===== */
@media(max-width:520px){
  .io-grid{grid-template-columns:1fr 1fr;}
  .member-add{max-width:none;}
  .summary-pl{font-size:26px;}

  /* 結果テーブルをカード型に切り替え */
  #resultTable thead{
    position:absolute;
    width:1px;height:1px;
    padding:0;margin:-1px;
    overflow:hidden;clip:rect(0,0,0,0);
    white-space:nowrap;border:0;
  }
  #resultTable{margin-top:6px;}
  #resultTable tr{
    display:block;
    background:var(--card2);
    border:1px solid var(--border);
    border-radius:12px;
    padding:6px 14px;
    margin-top:10px;
  }
  #resultTable td{
    display:flex;
    justify-content:space-between;
    align-items:center;
    text-align:right;
    border-bottom:1px solid var(--border);
    padding:9px 0;
  }
  #resultTable tr td:last-child{border-bottom:none;}
  #resultTable td::before{
    content:attr(data-label);
    color:var(--muted);
    font-size:12px;
    text-align:left;
    margin-right:12px;
  }
  #resultTable td:first-child{
    font-size:16px;
    font-weight:700;
    border-bottom:1px solid var(--border);
    padding-top:4px;
  }
  #resultTable td:first-child::before{content:"";margin:0;}
  #resultTable td.empty::before{content:"";margin:0;}
}
