/* ============================================
   YAYO STEAM 予約サイト スタイル
   テーマ: 白 × ベージュ の上品ミニマル(高級エステサロン)
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@500;600&display=swap');

:root {
  --bg:        #faf8f4;   /* ほぼ白の生成り背景 */
  --surface:   #ffffff;   /* カード白 */
  --beige:     #e9e1d4;   /* ベージュ */
  --beige-pale:#f3eee5;   /* 薄ベージュ */
  --taupe:     #b6a892;   /* トープ(くすみベージュ) */
  --gold:      #a98c5f;   /* アクセントのゴールド系 */
  --ink:       #3b362f;   /* 文字(濃いブラウングレー) */
  --ink-soft:  #8a8170;   /* 補助テキスト */
  --line:      #e6ded1;   /* 細い罫線 */
  --danger:    #a85c54;   /* くすんだ朱 */
  --radius:    4px;
  --shadow:    0 8px 30px rgba(120, 105, 80, 0.08);
  --serif:     "Shippori Mincho", "Yu Mincho", "YuMincho", serif;
  --sans:      "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.9;
  letter-spacing: 0.04em;
  -webkit-font-smoothing: antialiased;
}

/* ---- ヘッダー ---- */
header.site-header {
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  padding: 30px 16px 26px;
  text-align: center;
}
header.site-header h1 {
  font-family: var(--serif);
  font-size: 1.7rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  color: var(--ink);
  text-indent: 0.32em;
}
header.site-header .site-logo {
  max-height: 64px;
  max-width: 70%;
  object-fit: contain;
}
header.site-header p {
  font-size: 0.7rem;
  color: var(--taupe);
  letter-spacing: 0.4em;
  text-indent: 0.4em;
  margin-top: 10px;
}

.mock-banner {
  background: var(--beige-pale);
  color: var(--ink-soft);
  text-align: center;
  font-size: 0.78rem;
  padding: 7px 10px;
  letter-spacing: 0.08em;
  border-bottom: 1px solid var(--line);
}

main { max-width: 720px; margin: 0 auto; padding: 36px 18px 90px; }

/* ---- ステップ表示 ---- */
.steps {
  display: flex;
  justify-content: center;
  gap: 0;
  margin-bottom: 34px;
  flex-wrap: wrap;
}
.steps .step {
  font-size: 0.7rem;
  padding: 6px 14px;
  color: var(--ink-soft);
  letter-spacing: 0.08em;
  position: relative;
  white-space: nowrap;
}
.steps .step + .step::before {
  content: "·";
  position: absolute;
  left: -2px;
  color: var(--line);
}
.steps .step.active { color: var(--gold); font-weight: 600; }
.steps .step.done { color: var(--taupe); }

/* ---- カード ---- */
.card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 34px 30px;
  margin-bottom: 22px;
}
.card h2 {
  font-family: var(--serif);
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: 0.12em;
  padding-bottom: 14px;
  margin-bottom: 22px;
  border-bottom: 1px solid var(--line);
  position: relative;
}
.card h2::after {
  content: "";
  position: absolute;
  left: 0; bottom: -1px;
  width: 46px; height: 1px;
  background: var(--gold);
}
.card .hint { font-size: 0.84rem; color: var(--ink-soft); margin-bottom: 18px; }

/* ---- メニュー選択 ---- */
.course-list { display: grid; gap: 14px; }
.course-item {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 20px 22px;
  cursor: pointer;
  transition: all 0.2s ease;
  background: var(--surface);
}
.course-item:hover { border-color: var(--taupe); }
.course-item.selected {
  border-color: var(--gold);
  background: var(--beige-pale);
  box-shadow: inset 0 0 0 1px var(--gold);
}
.course-item .course-name {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--ink);
  letter-spacing: 0.08em;
}
.course-item .course-meta { font-size: 0.9rem; color: var(--gold); margin-top: 6px; letter-spacing: 0.06em; }
.course-item .course-meta small { color: var(--ink-soft); }
.course-item .course-desc { font-size: 0.84rem; color: var(--ink-soft); margin-top: 8px; }
.course-item.disabled { opacity: 0.5; cursor: default; background: var(--beige-pale); }
.course-item.disabled:hover { border-color: var(--line); }
.course-unavailable { font-size: 0.8rem; color: var(--danger); margin-top: 8px; }

/* ---- カレンダー ---- */
.cal-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 14px;
}
.cal-header .cal-title { font-family: var(--serif); font-weight: 600; color: var(--ink); font-size: 1.1rem; letter-spacing: 0.1em; }
.cal-header button {
  background: transparent; border: 1px solid var(--line);
  border-radius: var(--radius); padding: 7px 16px; cursor: pointer;
  font-size: 0.84rem; color: var(--ink); transition: all 0.2s; font-family: var(--sans);
}
.cal-header button:hover { border-color: var(--taupe); background: var(--beige-pale); }
.cal-header button:disabled { opacity: 0.3; cursor: default; }

table.calendar { width: 100%; border-collapse: collapse; table-layout: fixed; }
table.calendar th {
  font-size: 0.72rem; padding: 8px 0; color: var(--ink-soft); font-weight: 600; letter-spacing: 0.1em;
}
table.calendar th.sun { color: var(--danger); }
table.calendar th.sat { color: #6f7d93; }
table.calendar td { text-align: center; padding: 3px; height: 50px; vertical-align: middle; }
.day-cell {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  width: 100%; height: 100%; border-radius: var(--radius); border: 1px solid transparent;
  cursor: pointer; font-size: 0.92rem; transition: all 0.15s;
}
.day-cell .mark { font-size: 0.66rem; line-height: 1.4; }
.day-cell.open { border-color: var(--line); background: var(--surface); }
.day-cell.open:hover { background: var(--beige-pale); border-color: var(--taupe); }
.day-cell.open .mark { color: var(--gold); }
.day-cell.full { background: var(--beige-pale); color: var(--taupe); cursor: default; }
.day-cell.full .mark { color: var(--taupe); }
.day-cell.closed, .day-cell.past { color: #cfc8ba; cursor: default; }
.day-cell.closed .mark { color: #cfc8ba; }
/* 過ぎた日付=グレー / 今日=薄い赤 / まだ来ていない日=白(open) */
.day-cell.is-past { background: #eceae5; color: #b8b2a6; }
.day-cell.is-past .mark { color: #c7c1b5; }
.day-cell.is-today { background: #fbeceb; border-color: #e3b3ad; }
.day-cell.selected { background: var(--gold); color: #fff; border-color: var(--gold); }
.day-cell.selected .mark { color: #fff; }

/* 共通トップバー(全ページ統一) */
.app-header { position: relative; }
.app-header .header-user { position: absolute; top: 10px; right: 16px; font-size: 0.82rem; }
.app-header .header-shift { position: absolute; top: 12px; left: 16px; font-size: 0.8rem; color: var(--taupe); max-width: 30%; }
.opsnav { display: flex; gap: 8px; padding: 10px 16px; background: var(--beige-pale); border-bottom: 1px solid var(--line); }
.opsnav a { flex: 1; text-align: center; white-space: nowrap; }
.opsnav a.cur { background: var(--gold); color: #fff; border-color: var(--gold); }
.training-bar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; padding: 16px 16px; background: #c0392b; border-top: 3px solid #8a2820; border-bottom: 3px solid #8a2820; font-size: 0.95rem; color: #fff; font-weight: bold; position: sticky; top: 0; z-index: 250; }
.training-bar #trainRemain { color: #fff; font-weight: bold; text-decoration: underline; }
.training-bar .btn-small { background: #fff; color: #c0392b; border-color: #fff; font-weight: bold; }
@media (max-width: 760px) {
  .app-header .header-user, .app-header .header-shift { position: static; max-width: none; text-align: center; margin-top: 6px; }
  .opsnav { flex-wrap: wrap; } .opsnav a { flex: 1 1 30%; }
}

/* ---- 時間枠(「◯時台」ごとの段組み) ---- */
.time-hour { display: flex; align-items: stretch; gap: 12px; margin-bottom: 10px; }
.time-hour-label {
  flex-shrink: 0; width: 4.4em; display: flex; align-items: center; justify-content: center;
  font-size: 0.82rem; font-weight: 600; color: var(--gold);
  background: var(--beige-pale); border-radius: var(--radius); letter-spacing: 0.06em;
}
.time-hour-slots { flex: 1; display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.time-slot {
  border: 1px solid var(--line); border-radius: var(--radius);
  padding: 10px 4px; text-align: center; cursor: pointer; background: var(--surface);
  transition: all 0.15s;
}
.time-slot:hover { border-color: var(--taupe); background: var(--beige-pale); }
.time-slot.selected { border-color: var(--gold); background: var(--beige-pale); box-shadow: inset 0 0 0 1px var(--gold); }
.time-slot.full { background: var(--beige-pale); color: var(--taupe); cursor: default; }
.time-slot .seats-left { display: block; font-size: 0.92rem; font-weight: 600; color: var(--gold); margin-top: 2px; }
.time-slot.full .seats-left { color: var(--taupe); }
.time-slot.few .seats-left { color: var(--danger); }

/* ---- 注意事項・問診票 ---- */
.caution-box {
  background: var(--beige-pale); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 18px 20px; margin-bottom: 16px;
}
.caution-box ul { padding-left: 20px; font-size: 0.86rem; color: var(--ink); }
.caution-box li { margin-bottom: 6px; }

.agree-row { display: flex; align-items: flex-start; gap: 10px; padding: 12px 4px; font-size: 0.92rem; }
.agree-row input[type="checkbox"] { width: 20px; height: 20px; margin-top: 5px; flex-shrink: 0; accent-color: var(--gold); }

.q-item { padding: 18px 0; border-bottom: 1px solid var(--line); }
.q-item:last-child { border-bottom: none; }
.q-text { font-weight: 600; font-size: 0.94rem; margin-bottom: 12px; color: var(--ink); }
.q-text .req { color: var(--danger); font-size: 0.72rem; margin-left: 8px; font-weight: normal; }
.q-options { display: flex; flex-wrap: wrap; gap: 10px; }
.q-options label {
  border: 1px solid var(--line); border-radius: 2px;
  padding: 8px 20px; cursor: pointer; font-size: 0.88rem; background: var(--surface);
  transition: all 0.15s; letter-spacing: 0.04em;
}
.q-options label.checked { border-color: var(--gold); background: var(--beige-pale); font-weight: 600; color: var(--gold); }
.q-options input[type="radio"], .q-options input[type="checkbox"] { display: none; }

.block-message {
  background: #f6ebe9; border: 1px solid #ddbeb9; color: var(--danger);
  border-radius: var(--radius); padding: 14px 16px; font-size: 0.88rem; margin-top: 10px; display: none;
}
.block-message.show { display: block; }

/* ---- 入力フォーム ---- */
.form-row { margin-bottom: 18px; }
.form-row label { display: block; font-weight: 600; font-size: 0.88rem; margin-bottom: 6px; letter-spacing: 0.04em; }
.form-row label .req { color: var(--danger); font-size: 0.72rem; margin-left: 8px; font-weight: normal; }
.form-row input[type="text"], .form-row input[type="tel"], .form-row input[type="email"],
.form-row input[type="password"], .form-row input[type="number"], .form-row textarea, .form-row select {
  width: 100%; padding: 12px 14px; border: 1px solid var(--line);
  border-radius: 2px; font-size: 1rem; background: var(--surface); color: var(--ink);
  font-family: var(--sans); transition: border-color 0.15s;
}
.form-row input:focus, .form-row textarea:focus, .form-row select:focus {
  outline: none; border-color: var(--gold);
}

/* ---- 確認画面 ---- */
.confirm-table { width: 100%; border-collapse: collapse; font-size: 0.92rem; }
.confirm-table th, .confirm-table td {
  text-align: left; padding: 13px 8px; border-bottom: 1px solid var(--line); vertical-align: top;
}
.confirm-table th { width: 36%; color: var(--ink-soft); font-weight: 600; }

/* ---- 決済(ダミー)・お知らせ ---- */
.dummy-note {
  background: var(--beige-pale); color: var(--ink-soft); border-radius: var(--radius);
  padding: 14px 16px; font-size: 0.84rem; margin-bottom: 16px;
}

/* ---- 完了画面 ---- */
.done-icon { text-align: center; font-size: 2.6rem; margin-bottom: 10px; color: var(--gold); }
.reserve-no {
  text-align: center; font-family: var(--serif); font-size: 1.2rem; font-weight: 600;
  color: var(--gold); margin-bottom: 18px; letter-spacing: 0.1em;
}

/* ---- ボタン ---- */
.btn-row { display: flex; gap: 12px; justify-content: space-between; margin-top: 14px; }
.btn {
  display: inline-block; border: none; border-radius: 2px;
  padding: 14px 34px; font-size: 0.95rem; cursor: pointer; font-weight: 600;
  letter-spacing: 0.1em; transition: all 0.2s; font-family: var(--sans);
}
.btn-primary { background: var(--gold); color: #fff; }
.btn-primary:hover { background: #95794f; }
.btn-primary:disabled { background: #d6cdbb; cursor: default; }
.btn-secondary { background: var(--surface); color: var(--ink); border: 1px solid var(--line); }
.btn-secondary:hover { border-color: var(--taupe); background: var(--beige-pale); }
.btn-wide { width: 100%; }

/* ---- 管理画面 ---- */
.admin-toolbar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 18px; }
.admin-toolbar input[type="date"] {
  padding: 9px 11px; border: 1px solid var(--line); border-radius: 2px; font-size: 0.92rem; background: var(--surface);
}
.admin-table { width: 100%; border-collapse: collapse; font-size: 0.86rem; background: var(--surface); }
.admin-table th, .admin-table td { padding: 12px 9px; border-bottom: 1px solid var(--line); text-align: left; }
.admin-table th { background: var(--beige-pale); color: var(--ink); font-weight: 600; letter-spacing: 0.06em; }
.admin-table tr.canceled td { color: var(--taupe); text-decoration: line-through; }
.badge { display: inline-block; padding: 3px 11px; border-radius: 999px; font-size: 0.72rem; letter-spacing: 0.04em; }
.badge.ok { background: var(--beige-pale); color: var(--gold); }
.badge.cancel { background: #f3e6e4; color: var(--danger); }
.badge.member { background: #eef0f3; color: #6f7d93; }
/* 初回のお客様: 緑+白文字で目立たせる */
.badge.first { background: #4a8a4a; color: #fff; font-weight: 700; font-size: 0.8rem; padding: 4px 12px; }
/* リピーター: 落ち着いた表示 */
.badge.repeat { background: var(--beige-pale); color: var(--ink-soft); }
.btn-small {
  border: 1px solid var(--line); background: var(--surface); border-radius: 2px;
  padding: 5px 14px; cursor: pointer; font-size: 0.8rem; color: var(--ink);
  text-decoration: none; display: inline-block; transition: all 0.15s;
}
.btn-small:hover { border-color: var(--taupe); background: var(--beige-pale); }
.btn-small.danger { color: var(--danger); border-color: #ddbeb9; }
.empty-note { text-align: center; color: var(--ink-soft); padding: 34px 0; }
.day-cell.admin-day { cursor: pointer; border-color: var(--line); background: var(--surface); }
.day-cell.admin-day:hover { background: var(--beige-pale); }
.day-cell.admin-day.has-res .mark {
  background: var(--gold); color: #fff; border-radius: 999px; padding: 1px 9px; font-weight: 600;
}
.day-cell.admin-day.selected { background: var(--gold); border-color: var(--gold); color: #fff; }
.day-cell.admin-day.selected .mark { background: #fff; color: var(--gold); }
.day-cell.admin-day.today { outline: 1px solid var(--gold); outline-offset: -1px; }
.day-cell.admin-day.is-past { background: #eceae5; color: #b8b2a6; }
.day-cell.admin-day.is-today { background: #fbeceb; border-color: #e3b3ad; }
.day-cell.admin-day.is-closed { background: #efe7e6; color: #a85c54; }
.day-cell.admin-day.is-closed .mark { color: #a85c54; font-weight: bold; }

/* ---- 時間帯タブ(管理画面の電話予約) ---- */
.hour-tabs { display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 0; }
.hour-tab {
  border: 1px solid var(--line); background: var(--surface); color: var(--ink);
  border-radius: 999px; padding: 7px 16px; cursor: pointer; font-size: 0.9rem;
  font-family: var(--sans); transition: all 0.15s;
}
.hour-tab:hover { border-color: var(--taupe); background: var(--beige-pale); }
.hour-tab.active { background: var(--gold); color: #fff; border-color: var(--gold); font-weight: 600; }

/* ---- 部屋割りグリッド(管理画面の電話予約) ---- */
.room-grid { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.room-grid th, .room-grid td { border: 1px solid var(--line); text-align: center; padding: 8px 6px; }
.room-grid th { background: var(--beige-pale); color: var(--ink); font-weight: 600; }
.room-grid .rg-time { font-weight: 600; background: var(--beige-pale); white-space: nowrap; }
.room-grid .rg-free { color: var(--gold); font-weight: 700; cursor: pointer; font-size: 1.05rem; }
.room-grid .rg-free:hover { background: var(--beige-pale); }
.room-grid .rg-full { color: var(--taupe); background: #f3eee5; }
.room-grid td.picked { background: var(--gold); color: #fff; }

/* ---- ログインメッセージ ---- */
.login-message { font-size: 0.85rem; color: var(--danger); margin: 10px 0; }

footer.site-footer {
  text-align: center; font-size: 0.74rem; color: var(--ink-soft); padding: 30px 16px;
  letter-spacing: 0.16em; border-top: 1px solid var(--line); margin-top: 20px;
}
footer.site-footer a { color: var(--gold); text-decoration: none; }

@media (max-width: 480px) {
  .card { padding: 24px 18px; }
  .btn { padding: 13px 22px; font-size: 0.9rem; }
  header.site-header h1 { font-size: 1.4rem; letter-spacing: 0.2em; }
}

/* ============================================================
   スマホ共通の底上げ(全ページ向け)
   ・余白を詰める / 見出しを少し小さく / 表は横スクロール可
   ・各ページの個別レイアウトはページ側で微調整する
   ============================================================ */
@media (max-width: 600px) {
  main { padding: 20px 12px 80px; }
  h2 { font-size: 1.3rem; }
  h3 { font-size: 1.1rem; }
  /* ページ共通の各ラッパー(各ページの inline style より後勝ちで詰める) */
  .cust-wrap, .cd-wrap, .tc-wrap, .sr-wrap, .sc-wrap, .mp-wrap, .sv-wrap, .sh-wrap { padding: 12px !important; }
  /* 通常のデータ表だけ横スクロール可(シフトの格子表 .sh-grid/.sv-grid は対象外) */
  .admin-table, .cust-table { display: block; max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  /* ボタン類のタップ領域を確保しつつ詰める */
  .btn-small, .btn-u { padding: 9px 12px; }
  /* 横並びが多い操作列は折り返す */
  .opsnav { gap: 6px; padding: 8px 10px; }
}
