/* ============================================================
 * みえるDM v3 - admin 共通スタイル
 *
 * version : 1.4
 * 更新日   : 2026-05-10
 *
 * 範囲（v1.4）:
 *   - ★v1.4 追加: 認証モーダル用スタイル（dialog 要素・dialog::backdrop・dialog-content）
 *   - 以下は v1.3 から継続
 *
 * 範囲（v1.3）:
 *   - CSS 変数（ブランドカラー・余白・タイポグラフィ）
 *   - リセット / ベース
 *   - ログイン画面（.login-wrap / .login-card / .fg / .btn / .error）
 *   - 画面ロック overlay（.loading-overlay）
 *   - ページレイアウト（.page / .page-header / .page-body）
 *   - テーブル（.data-table）+ ステータスバッジ（.badge / .badge-lite）
 *   - ナビゲーション（.page-nav）
 *   - フォームカード（.form-card / .form-section / .form-row）
 *   - 検索ボックス・ツールバー（.search-box / .toolbar）
 *   - ★v1.3 追加: 入力タイプ拡充（email / url / date / select）
 *   - ★v1.3 追加: チェックボックス・ラジオ（.checkbox-label / .radio-label）
 *   - ★v1.3 追加: フォーム補助メッセージ（.form-hint / .form-warn / .form-warn-box / .form-success-msg）
 *   - ★v1.3 追加: 戻るリンク（.back-link）
 *
 * 改訂履歴:
 *   - v1.4 (2026-05-10): 認証モーダル（共通機能）用に dialog 系スタイルを追加
 *   - v1.3 (2026-05-10): create.html 用に入力タイプ追加・ラジオ・注意書きボックスを追加
 *   - v1.2 (2026-05-09): 顧客管理画面用にナビゲーション・フォームカード・検索ボックス・ツールバーを追加
 *   - v1.1 (2026-05-09): list.html 用にページレイアウト・テーブル・バッジを追加
 *   - v1.0 (2026-05-09): 初版
 *
 * 範囲外（後の段階で追加）:
 *   - サイドバー / モーダル / トースト
 *   - 各画面（customers / detail / settings / monitoring）固有スタイル
 *
 * 関連:
 *   - reference/rules/coding_rules_prompt_v3.md（ブランドカラー・命名規則）
 * ============================================================ */

/* ----- CSS 変数 ----- */
:root {
  /* ブランドカラー（CLAUDE §8 / coding_rules_prompt_v3 より） */
  --brand-main: #1A9AD5;
  --brand-text-dark: #185FA5;
  --brand-bg-light: #E6F1FB;
  --brand-border: #B5D4F4;

  /* 機能色 */
  --color-text: #1B2A4A;
  --color-text-muted: #64748b;
  --color-bg: #f8fafc;
  --color-surface: #ffffff;
  --color-danger: #dc2626;
  --color-success: #10b981;

  /* レイアウト */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 10px;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);

  /* タイポグラフィ */
  --font-family-base: 'Noto Sans JP', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-size-base: 14px;
}

/* ----- リセット / ベース ----- */
* {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
  font-family: var(--font-family-base);
  font-size: var(--font-size-base);
  color: var(--color-text);
  background: var(--color-bg);
}

img {
  max-width: 100%;
  height: auto;
}

button {
  font-family: inherit;
}

/* ----- ログイン画面 ----- */
.login-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.login-card {
  width: 100%;
  max-width: 400px;
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  border-top: 3px solid var(--brand-main);
  padding: 32px 28px;
}

.login-header {
  text-align: center;
  margin-bottom: 24px;
}

.login-header img {
  max-width: 180px;
  height: auto;
}

.login-header p {
  margin: 12px 0 0;
  font-size: 14px;
  font-weight: 500;
  color: var(--brand-text-dark);
}

.login-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* フォームグループ */
.fg {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.fg label {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text);
}

.fg input[type="text"],
.fg input[type="password"],
.fg input[type="email"],
.fg input[type="url"],
.fg input[type="search"],
.fg input[type="date"],
.fg select {
  width: 100%;
  padding: 9px 12px;
  font-size: 14px;
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  font-family: inherit;
}

.fg input[type="text"]:focus,
.fg input[type="password"]:focus,
.fg input[type="email"]:focus,
.fg input[type="url"]:focus,
.fg input[type="search"]:focus,
.fg input[type="date"]:focus,
.fg select:focus {
  border-color: var(--brand-main);
  box-shadow: 0 0 0 3px rgba(26, 154, 213, 0.15);
}

.fg input:disabled,
.fg select:disabled {
  background: var(--brand-bg-light);
  color: var(--color-text-muted);
  cursor: not-allowed;
}

/* ----- ボタン ----- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  font-size: 14px;
  font-weight: 600;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-decoration: none;
  transition: background-color 0.15s, border-color 0.15s, color 0.15s, opacity 0.15s;
  font-family: inherit;
}

.btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.btn-primary {
  background: var(--brand-main);
  color: var(--color-surface);
  border-color: var(--brand-main);
}

.btn-primary:hover:not(:disabled) {
  background: var(--brand-text-dark);
  border-color: var(--brand-text-dark);
}

.btn-ghost {
  background: var(--color-surface);
  color: var(--color-text);
  border-color: var(--brand-border);
}

.btn-ghost:hover:not(:disabled) {
  border-color: var(--brand-main);
  color: var(--brand-main);
}

.btn-block {
  display: flex;
  width: 100%;
}

/* ----- エラーメッセージ ----- */
.error {
  font-size: 12px;
  color: var(--color-danger);
  min-height: 16px;
}

.success {
  font-size: 12px;
  color: var(--color-success);
}

/* ----- ログイン後ビュー ----- */
.welcome-view {
  text-align: center;
}

.welcome-view h1 {
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 600;
  color: var(--brand-text-dark);
}

.welcome-view .user-info {
  margin: 12px 0 24px;
  padding: 12px;
  background: var(--brand-bg-light);
  border-radius: var(--radius-sm);
  font-size: 13px;
  color: var(--color-text);
}

.welcome-view .user-info .label {
  font-weight: 600;
  color: var(--color-text-muted);
  margin-right: 6px;
}

/* ----- 画面ロック overlay ----- */
.loading-overlay {
  position: fixed;
  inset: 0;
  background: rgba(255, 255, 255, 0.85);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.loading-overlay.show {
  display: flex;
}

.lo-box {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: 24px 32px;
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.lo-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--brand-border);
  border-top-color: var(--brand-main);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.lo-msg {
  font-size: 13px;
  color: var(--color-text);
}

/* ----- ユーティリティ ----- */
.hidden {
  display: none !important;
}

/* ============================================================
 * ページレイアウト（list.html 等で使用）
 * ============================================================ */

.page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.page-header {
  background: var(--color-surface);
  border-bottom: 1px solid var(--brand-border);
  padding: 14px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.page-header .page-logo {
  display: flex;
  align-items: center;
  gap: 12px;
}

.page-header .page-logo img {
  height: 28px;
  width: auto;
}

.page-header .page-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--brand-text-dark);
  margin: 0;
}

.page-header .page-user {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 12px;
  color: var(--color-text-muted);
}

.page-body {
  flex: 1;
  padding: 24px;
}

.page-body h1 {
  font-size: 18px;
  font-weight: 600;
  color: var(--color-text);
  margin: 0 0 16px;
}

/* ----- データテーブル ----- */

.data-table-wrap {
  background: var(--color-surface);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  overflow-x: auto;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.data-table thead th {
  background: var(--brand-bg-light);
  color: var(--brand-text-dark);
  font-weight: 600;
  font-size: 12px;
  text-align: left;
  padding: 10px 12px;
  border-bottom: 1px solid var(--brand-border);
  white-space: nowrap;
}

.data-table tbody td {
  padding: 10px 12px;
  border-bottom: 1px solid #f1f5f9;
  vertical-align: middle;
  white-space: nowrap;
  color: var(--color-text);
}

.data-table tbody tr:last-child td {
  border-bottom: none;
}

.data-table tbody tr:hover {
  background: rgba(26, 154, 213, 0.04);
}

.data-table .num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* 空状態 */
.empty-state {
  text-align: center;
  padding: 48px 16px;
  color: var(--color-text-muted);
}

.empty-state .empty-title {
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 6px;
  color: var(--color-text);
}

.empty-state .empty-desc {
  font-size: 12px;
}

/* ----- ナビゲーション（ヘッダー内） ----- */

.page-nav {
  display: flex;
  gap: 4px;
  margin-left: 24px;
}

.page-nav a {
  padding: 6px 14px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text);
  text-decoration: none;
  transition: background-color 0.15s, color 0.15s;
}

.page-nav a:hover {
  background: var(--brand-bg-light);
  color: var(--brand-text-dark);
}

.page-nav a.active {
  background: var(--brand-main);
  color: var(--color-surface);
}

/* ----- フォームカード（顧客管理 等） ----- */

.form-card {
  background: var(--color-surface);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: 20px 24px;
  max-width: 720px;
}

.form-card h2 {
  margin: 0 0 16px;
  font-size: 15px;
  font-weight: 600;
  color: var(--brand-text-dark);
  padding-bottom: 8px;
  border-bottom: 1px solid var(--brand-border);
}

.form-card .form-section {
  margin-bottom: 20px;
}

.form-card .form-section:last-of-type {
  margin-bottom: 0;
}

.form-card .form-section h3 {
  margin: 0 0 10px;
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.form-card .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

.form-card .form-row.single {
  grid-template-columns: 1fr;
}

.form-card textarea {
  width: 100%;
  min-height: 60px;
  padding: 9px 12px;
  font-size: 14px;
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text);
  font-family: inherit;
  resize: vertical;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.form-card textarea:focus {
  border-color: var(--brand-main);
  box-shadow: 0 0 0 3px rgba(26, 154, 213, 0.15);
}

.form-card .form-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--brand-border);
}

.form-card .read-only-value {
  padding: 9px 12px;
  font-size: 14px;
  color: var(--color-text);
  background: var(--brand-bg-light);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-sm);
}

/* ----- 検索ボックス ----- */

.search-box {
  width: 100%;
  max-width: 400px;
  padding: 8px 12px;
  font-size: 13px;
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text);
  outline: none;
  margin-bottom: 12px;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.search-box:focus {
  border-color: var(--brand-main);
  box-shadow: 0 0 0 3px rgba(26, 154, 213, 0.15);
}

/* ----- 操作行（ヘッダーエリア下のツールバー） ----- */

.toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

/* ----- バッジ ----- */

.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid transparent;
  white-space: nowrap;
}

.badge-status {
  background: var(--brand-bg-light);
  color: var(--brand-text-dark);
  border-color: var(--brand-border);
}

.badge-active {
  background: #ecfdf5;
  color: #047857;
  border-color: #a7f3d0;
}

.badge-closed {
  background: #f1f5f9;
  color: #64748b;
  border-color: #e2e8f0;
}

.badge-warn {
  background: #fffbeb;
  color: #b45309;
  border-color: #fde68a;
}

.badge-lite {
  background: #ede9fe;
  color: #6d28d9;
  border-color: #ddd6fe;
  margin-left: 6px;
}

/* ============================================================
 * フォーム補助メッセージ（create.html 等で使用）
 * ============================================================ */

.form-hint {
  font-size: 12px;
  color: var(--color-text-muted);
  line-height: 1.5;
}

.form-warn {
  font-size: 12px;
  color: #b45309;
  background: #fffbeb;
  border: 1px solid #fde68a;
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  line-height: 1.5;
}

.form-success-msg {
  font-size: 12px;
  color: #047857;
}

.form-warn-box {
  margin-top: 12px;
  padding: 12px 14px;
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: var(--radius-sm);
  font-size: 13px;
  color: #92400e;
  line-height: 1.6;
}

.form-warn-box strong {
  display: block;
  margin-bottom: 6px;
  color: #b45309;
}

.form-warn-box ul {
  margin: 0;
  padding-left: 20px;
}

.form-warn-box li {
  margin-bottom: 2px;
}

/* ============================================================
 * チェックボックス / ラジオボタン（create.html 等で使用）
 * ============================================================ */

.checkbox-label,
.radio-label {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13px;
  color: var(--color-text);
  cursor: pointer;
  padding: 6px 0;
  line-height: 1.5;
}

.checkbox-label input,
.radio-label input {
  margin-top: 3px;
  cursor: pointer;
  accent-color: var(--brand-main);
}

.checkbox-label input:disabled,
.radio-label input:disabled {
  cursor: not-allowed;
}

.radio-label + .radio-label {
  margin-top: 4px;
}

/* ============================================================
 * 戻るリンク（create.html 等のページ上部で使用）
 * ============================================================ */

.back-link {
  display: inline-block;
  font-size: 13px;
  color: var(--brand-text-dark);
  text-decoration: none;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  transition: background-color 0.15s;
}

.back-link:hover {
  background: var(--brand-bg-light);
}

/* ============================================================
 * 認証モーダル（dialog 要素・askAdminPassword / askDangerConfirm 用）
 * ============================================================ */

dialog.auth-dialog {
  border: none;
  border-radius: var(--radius-lg);
  padding: 0;
  background: var(--color-surface);
  box-shadow: var(--shadow-md);
  max-width: 440px;
  width: calc(100% - 32px);
  color: var(--color-text);
  font-family: var(--font-family-base);
  font-size: var(--font-size-base);
}

dialog.auth-dialog::backdrop {
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(2px);
}

dialog.auth-dialog .dialog-content {
  padding: 24px 24px 20px;
}

dialog.auth-dialog .dialog-title {
  margin: 0 0 8px;
  font-size: 15px;
  font-weight: 600;
  color: var(--brand-text-dark);
}

dialog.auth-dialog .dialog-title.danger {
  color: var(--color-danger);
}

dialog.auth-dialog .dialog-message {
  margin: 0 0 16px;
  font-size: 13px;
  color: var(--color-text);
  line-height: 1.6;
  white-space: pre-line;
}

dialog.auth-dialog .dialog-error {
  font-size: 12px;
  color: var(--color-danger);
  min-height: 16px;
  margin-bottom: 8px;
}

dialog.auth-dialog .fg {
  margin-bottom: 12px;
}

dialog.auth-dialog .dialog-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  padding: 12px 24px 20px;
  border-top: 1px solid var(--brand-border);
  background: #fafbfc;
  border-bottom-left-radius: var(--radius-lg);
  border-bottom-right-radius: var(--radius-lg);
}

dialog.auth-dialog .danger-required-text {
  font-size: 12px;
  color: var(--color-text-muted);
  margin-bottom: 6px;
}

dialog.auth-dialog .danger-required-text strong {
  color: var(--color-danger);
  font-size: 13px;
}
