:root{
  --bg:#f6f3ef; --card:#fff; --ink:#33302c; --muted:#8a847c;
  --line:#e7e1d8; --accent:#b08968; --accent-d:#8c6b50;
  --good:#3a8a5f; --bad:#c0392b; --soft:#faf7f2;
  --shadow:0 2px 10px rgba(80,60,40,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:"Hiragino Sans","Yu Gothic",-apple-system,"Segoe UI",sans-serif;
  background:var(--bg);color:var(--ink);font-size:16px;line-height:1.6;-webkit-text-size-adjust:100%}
a{color:var(--accent-d);text-decoration:none}

/* ---- ログイン ---- */
.login-container{max-width:360px;margin:14vh auto;background:var(--card);
  padding:36px 30px;border-radius:18px;box-shadow:var(--shadow);text-align:center}
.login-container h2{margin:0 0 22px;font-weight:600;letter-spacing:.04em}
.login-container input{width:100%;padding:14px;margin:8px 0;border:1px solid var(--line);
  border-radius:10px;font-size:16px}
.error{color:var(--bad);margin:6px 0}

/* ---- ヘッダ ---- */
header.top{background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.top-inner{max-width:1080px;margin:0 auto;display:flex;align-items:center;
  justify-content:space-between;padding:12px 18px}
.brand{font-size:19px;font-weight:700;letter-spacing:.04em;color:var(--accent-d);
  white-space:nowrap;flex-shrink:0;margin-right:12px}
.brand small{font-weight:400;color:var(--muted);font-size:12px;margin-left:8px}
nav.menu{display:flex;flex-wrap:wrap;gap:4px}
nav.menu a{padding:8px 12px;border-radius:9px;color:var(--ink);font-size:14px}
nav.menu a.active,nav.menu a:hover{background:var(--soft);color:var(--accent-d)}
.logout{color:var(--muted);font-size:13px}

main{max-width:1080px;margin:0 auto;padding:20px 16px 80px}
/* データ一覧ページは表をゆったり見せるため本文幅を広げる */
body.wide main{max-width:1320px}
h1.page{font-size:22px;font-weight:700;margin:6px 0 18px}

/* ---- ボタン ---- */
.btn{display:inline-block;padding:13px 20px;border:none;border-radius:11px;
  font-size:16px;font-weight:600;cursor:pointer;transition:.15s}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-d)}
.btn-ghost{background:var(--soft);color:var(--accent-d);border:1px solid var(--line)}
.btn-sm{padding:6px 12px;font-size:13px;border-radius:8px}
.btn-del{background:#fbeae8;color:var(--bad);border:1px solid #f3cfca}
.btn-del:hover{background:#f7d8d3}

/* ---- カード/サマリ ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:22px}
.card{background:var(--card);border-radius:16px;padding:20px;box-shadow:var(--shadow);border:1px solid var(--line)}
.card .label{color:var(--muted);font-size:13px;margin-bottom:6px}
.card .value{font-size:30px;font-weight:700;letter-spacing:.02em}
.card.good .value{color:var(--good)}
.card.bad .value{color:var(--bad)}
.card.accent{background:linear-gradient(135deg,#b08968,#8c6b50);color:#fff;border:none}
.card.accent .label{color:rgba(255,255,255,.85)}

.warn{background:#fdecea;border:1px solid #f5c6cb;color:var(--bad);
  padding:14px 18px;border-radius:12px;margin-bottom:18px}
.warn b{font-weight:700}
.warn ul{margin:6px 0 0;padding-left:20px}

/* ---- 大ボタン入力導線 ---- */
.bigbtns{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:24px}
.bigbtns button{padding:28px 14px;font-size:19px;font-weight:700;border:none;border-radius:18px;
  background:var(--card);box-shadow:var(--shadow);cursor:pointer;color:var(--ink);
  border:1px solid var(--line);transition:.15s}
.bigbtns button:hover{transform:translateY(-2px);border-color:var(--accent)}
.bigbtns .ic{display:block;font-size:34px;margin-bottom:8px}

/* ---- フォーム ---- */
.formbox{background:var(--card);border-radius:16px;padding:22px;box-shadow:var(--shadow);
  border:1px solid var(--line);margin-bottom:18px;display:none}
.formbox.open{display:block}
.formbox h3{margin:0 0 16px;font-size:18px}
.field{margin-bottom:14px}
.field label{display:block;font-size:14px;color:var(--muted);margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;padding:13px;border:1px solid var(--line);
  border-radius:10px;font-size:16px;background:#fff}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ---- テーブル ---- */
.tablewrap{background:var(--card);border-radius:16px;box-shadow:var(--shadow);
  border:1px solid var(--line);overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{padding:13px 14px;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap;vertical-align:middle}
th{background:var(--soft);color:var(--muted);font-weight:600;font-size:13px;
  position:sticky;top:56px;z-index:2}
tbody tr:nth-child(odd) td{background:#fbf9f6}
tbody tr:hover td{background:#f4eee6}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum";white-space:nowrap}
/* 商品名など長文セルは折り返して読めるように（十分な幅を確保） */
td.name,th.name{white-space:normal;min-width:240px;max-width:360px;line-height:1.45}
.tot td{font-weight:700;background:var(--soft)}
tbody tr:nth-child(odd) .tot td{background:var(--soft)}
.pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}
.pill.cash{background:#eef6ef;color:var(--good)}
.pill.credit{background:#eef1f8;color:#3b5b9b}
.pill.trial{background:#fdf3e7;color:#b07d2a}
.pill.sold{background:#eef6ef;color:var(--good)}
.pill.treat{background:#eef1f8;color:#3b5b9b}
.pill.adjust{background:#f3eef8;color:#7b5ba6}
.pill.cur{background:var(--accent);color:#fff}
/* 今月の行ハイライト（既存accentを流用） */
tr.thismonth td{background:var(--soft);font-weight:700;box-shadow:inset 3px 0 0 var(--accent)}
tbody tr.thismonth:nth-child(odd) td,tbody tr.thismonth:hover td{background:var(--soft)}
.red{color:var(--bad);font-weight:700}
.gray{color:var(--muted)}

.tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.tabs a{padding:8px 16px;border-radius:9px;background:var(--card);border:1px solid var(--line);font-size:14px}
.tabs a.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ---- トースト ---- */
#toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(20px);
  background:#33302c;color:#fff;padding:14px 26px;border-radius:12px;font-size:15px;
  opacity:0;pointer-events:none;transition:.3s;z-index:200;box-shadow:0 6px 20px rgba(0,0,0,.2)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.err{background:var(--bad)}

.btn-edit{background:#eef1f8;color:#3b5b9b;border:1px solid #d4ddef}
.btn-edit:hover{background:#e2e8f6}
.rowbtns{display:flex;gap:6px;justify-content:flex-end}
.rowbtns form{margin:0}

/* ---- 1行ヒント ---- */
.hint{background:#fbf6ee;border:1px solid #efe4d2;color:#7a6a52;
  padding:11px 16px;border-radius:11px;margin:0 0 16px;font-size:14px}
.hint b{color:var(--accent-d)}

/* ---- 編集モーダル ---- */
.modal-bg{position:fixed;inset:0;background:rgba(50,40,30,.45);z-index:300;
  display:none;align-items:flex-start;justify-content:center;padding:24px 14px;overflow-y:auto}
.modal-bg.open{display:flex}
.modal{background:var(--card);border-radius:18px;padding:24px;width:100%;max-width:460px;
  box-shadow:0 12px 40px rgba(0,0,0,.25);margin:auto}
.modal h3{margin:0 0 16px;font-size:18px}
.modal .modal-actions{display:flex;gap:10px;margin-top:6px}
.modal .modal-actions .btn{flex:1}

/* ---- 使い方ページ ---- */
.help h2{font-size:20px;margin:30px 0 12px;padding-bottom:8px;border-bottom:2px solid var(--line);
  color:var(--accent-d)}
.help h2:first-of-type{margin-top:8px}
.help h3{font-size:17px;margin:20px 0 8px}
.help p{margin:8px 0}
.help .step{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:18px 20px;margin:14px 0;box-shadow:var(--shadow)}
.help .step .no{display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;
  font-weight:700;margin-right:10px;font-size:15px}
.help .eg{background:var(--soft);border-left:4px solid var(--accent);padding:10px 14px;
  border-radius:8px;margin:8px 0;font-size:14px;color:#6a5f50}
.help .eg b{color:var(--accent-d)}
.help ul{margin:8px 0;padding-left:22px}
.help li{margin:5px 0}
.help .tip{color:var(--good);font-weight:600}
.help .glossary{display:grid;grid-template-columns:130px 1fr;gap:6px 14px;
  background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px;
  box-shadow:var(--shadow);font-size:15px}
.help .glossary dt{font-weight:700;color:var(--accent-d)}
.help .glossary dd{margin:0;color:var(--ink)}
.help .qa{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:6px 20px;box-shadow:var(--shadow)}
.help .qa details{border-bottom:1px solid var(--line);padding:12px 0}
.help .qa details:last-child{border-bottom:none}
.help .qa summary{font-weight:600;cursor:pointer;font-size:15px}
.help .qa details p{margin:8px 0 0;color:#6a5f50;font-size:14px}
.help .lead{font-size:16px;background:linear-gradient(135deg,#b08968,#8c6b50);color:#fff;
  padding:20px 22px;border-radius:16px;margin-bottom:8px;line-height:1.7}

@media(max-width:640px){
  body{font-size:17px}
  .help .glossary{grid-template-columns:1fr}
  .help .glossary dt{margin-top:8px}
  .top-inner{flex-direction:column;align-items:stretch;gap:8px}
  nav.menu{justify-content:center}
  .field-row{grid-template-columns:1fr}
  .card .value{font-size:25px}
  h1.page{font-size:20px}

  /* ---- スマホ: 表を「1行＝1カード」に変換（JSなし・data-label方式） ---- */
  .tablewrap{background:transparent;border:none;box-shadow:none;
    border-radius:0;overflow:visible;padding:0}
  .tablewrap table,
  .tablewrap thead,
  .tablewrap tbody,
  .tablewrap tfoot,
  .tablewrap tr,
  .tablewrap th,
  .tablewrap td{display:block;width:auto}
  /* ヘッダー行は隠す（各セルに項目名を出すため） */
  .tablewrap thead{position:absolute;left:-9999px;top:-9999px;height:0;overflow:hidden}
  .tablewrap tbody tr{
    background:var(--card);border:1px solid var(--line);border-radius:14px;
    box-shadow:var(--shadow);padding:6px 4px;margin:0 0 14px}
  .tablewrap tbody tr:nth-child(odd) td,
  .tablewrap tbody tr:hover td{background:transparent}
  .tablewrap tbody td{
    border:none;border-bottom:1px solid var(--line);
    display:flex;justify-content:space-between;align-items:center;gap:14px;
    padding:10px 14px;text-align:right;white-space:normal;min-width:0;max-width:none}
  .tablewrap tbody td:last-child{border-bottom:none}
  /* 項目名をセル左に表示 */
  .tablewrap tbody td::before{
    content:attr(data-label);font-size:13px;font-weight:600;color:var(--muted);
    text-align:left;flex:0 0 38%;white-space:nowrap}
  .tablewrap tbody td.name{font-weight:600}
  /* 値が空のセルはカードから隠してスッキリ */
  .tablewrap tbody td:empty{display:none}
  /* 操作ボタンセル: ラベルを出さず横並び＆押しやすく */
  .tablewrap tbody td.act{justify-content:flex-end;padding-top:12px;padding-bottom:12px}
  .tablewrap tbody td.act::before{content:none}
  .tablewrap td.act .rowbtns,
  .tablewrap td.act form{width:auto}
  .tablewrap td.act .rowbtns{gap:10px}
  .tablewrap td.act .btn-sm{padding:11px 18px;font-size:15px;border-radius:10px}
  /* 合計行（tfoot / .tot）もカード調で */
  .tablewrap tfoot tr,
  .tablewrap tbody tr.tot{
    background:var(--soft);border:1px solid var(--line);border-radius:14px;
    box-shadow:none;padding:6px 4px;margin:0 0 14px}
  .tablewrap tfoot td,
  .tablewrap tbody tr.tot td{
    display:flex;justify-content:space-between;border:none;
    border-bottom:1px solid var(--line);padding:10px 14px;font-weight:700}
  .tablewrap tfoot td:last-child,
  .tablewrap tbody tr.tot td:last-child{border-bottom:none}
  .tablewrap tfoot td::before,
  .tablewrap tbody tr.tot td::before{
    content:attr(data-label);font-weight:600;color:var(--muted)}
  .tablewrap tfoot td:empty,
  .tablewrap tbody tr.tot td:empty{display:none}
  .tablewrap tfoot td[colspan]::before,
  .tablewrap tbody tr.tot td[colspan]::before{content:none}
}
