/* =================================
   TLCS テーマシステム v2.0
   カラースキーム + ダークモード分離版
   ================================= */

/* 基本カラー変数 */
:root {
  /* デフォルト: TLCS グリーン */
  --primary-color: #2c8b80;
  --primary-light: #56d1a7;
  --primary-dark: #0f3d3e;
  --accent-color: #ffc107;

  /* ライトモード（デフォルト） */
  --text-primary: #333333;
  --text-secondary: #666666;
  --text-light: #ffffff;
  --background-primary: #ffffff;
  --background-secondary: #f8f9fa;
  --background-dark: #0f3d3e;
  --border-color: #e9ecef;
  --shadow-color: rgba(0, 0, 0, 0.1);

  /* グラデーション */
  --gradient-primary: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
  --gradient-secondary: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary-color) 100%);
}

/* =================================
   カラースキーム定義（4種類）
   ================================= */

/* スキーム1: TLCS グリーン（デフォルト） */
[data-color-scheme="tlcs-green"] {
  --primary-color: #2c8b80 !important;
  --primary-light: #56d1a7 !important;
  --primary-dark: #0f3d3e !important;
  --accent-color: #ffc107 !important;
}

/* スキーム2: オーシャンブルー */
[data-color-scheme="ocean-blue"] {
  --primary-color: #0077be !important;
  --primary-light: #4fc3f7 !important;
  --primary-dark: #003d5b !important;
  --accent-color: #ff6b35 !important;
}

/* スキーム3: サンセットオレンジ */
[data-color-scheme="sunset-orange"] {
  --primary-color: #ff6b35 !important;
  --primary-light: #ffab91 !important;
  --primary-dark: #d84315 !important;
  --accent-color: #4caf50 !important;
}

/* スキーム4: ロイヤルパープル */
[data-color-scheme="royal-purple"] {
  --primary-color: #7b1fa2 !important;
  --primary-light: #ba68c8 !important;
  --primary-dark: #4a148c !important;
  --accent-color: #ffd54f !important;
}

/* =================================
   ダークモード定義
   ================================= */

/* ダークモード適用時 */
[data-dark-mode="true"] {
  --text-primary: #ffffff !important;
  --text-secondary: #b0bec5 !important;
  --text-light: #ffffff !important;
  --background-primary: #121212 !important;
  --background-secondary: #1e1e1e !important;
  --background-dark: #000000 !important;
  --border-color: #424242 !important;
  --shadow-color: rgba(255, 255, 255, 0.1) !important;
}

/* ライトモード適用時（明示的） */
[data-dark-mode="false"] {
  --text-primary: #333333 !important;
  --text-secondary: #666666 !important;
  --text-light: #ffffff !important;
  --background-primary: #ffffff !important;
  --background-secondary: #f8f9fa !important;
  --background-dark: var(--primary-dark) !important;
  --border-color: #e9ecef !important;
  --shadow-color: rgba(0, 0, 0, 0.1) !important;
}

/* =================================
   要素への適用
   ================================= */

/* 基本要素 */
body {
  background-color: var(--background-primary) !important;
  color: var(--text-primary) !important;
  transition: background-color 0.3s ease, color 0.3s ease !important;
}

/* ナビゲーション */
.navbar {
  background-color: var(--background-primary) !important;
  border-bottom: 1px solid var(--border-color) !important;
}

.navbar-brand,
.nav-link {
  color: var(--text-primary) !important;
}

.nav-link:hover {
  color: var(--primary-color) !important;
}

/* ボタン */
.btn-primary {
  background-color: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
  color: var(--text-light) !important;
}

.btn-primary:hover {
  background-color: var(--primary-dark) !important;
  border-color: var(--primary-dark) !important;
}

.btn-outline-primary {
  color: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
  background-color: transparent !important;
}

.btn-outline-primary:hover {
  background-color: var(--primary-color) !important;
  color: var(--text-light) !important;
}

/* カード */
.card {
  background-color: var(--background-primary) !important;
  border-color: var(--border-color) !important;
  box-shadow: 0 2px 10px var(--shadow-color) !important;
}

.card-header {
  background-color: var(--background-secondary) !important;
  border-bottom-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

.card-body {
  color: var(--text-primary) !important;
}

/* フォーム */
.form-control {
  background-color: var(--background-primary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

.form-control:focus {
  border-color: var(--primary-color) !important;
  box-shadow: 0 0 0 0.2rem rgba(var(--primary-color), 0.25) !important;
}

.form-label,
label {
  color: var(--text-primary) !important;
}

/* テーブル */
.table {
  color: var(--text-primary) !important;
}

.table th {
  background-color: var(--background-dark) !important;
  color: var(--text-light) !important;
  border-color: var(--border-color) !important;
}

.table td {
  background-color: var(--background-primary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

/* フッター */
footer {
  background-color: var(--background-dark) !important;
  color: var(--text-light) !important;
}

footer a {
  color: var(--primary-light) !important;
}

footer a:hover {
  color: var(--text-light) !important;
}

/* リンク */
a {
  color: var(--primary-color) !important;
}

a:hover {
  color: var(--primary-dark) !important;
}

/* ページヘッダー */
.page-header,
.hero-section {
  background: var(--gradient-secondary) !important;
  color: var(--text-light) !important;
}

/* ドロップダウン */
.dropdown-menu {
  background-color: var(--background-primary) !important;
  border-color: var(--border-color) !important;
  box-shadow: 0 4px 20px var(--shadow-color) !important;
}

.dropdown-item {
  color: var(--text-primary) !important;
}

.dropdown-item:hover {
  background-color: var(--background-secondary) !important;
  color: var(--primary-color) !important;
}

/* モーダル */
.modal-content {
  background-color: var(--background-primary) !important;
  border-color: var(--border-color) !important;
}

.modal-header {
  background-color: var(--background-secondary) !important;
  border-bottom-color: var(--border-color) !important;
}

.modal-title {
  color: var(--text-primary) !important;
}

.modal-body {
  color: var(--text-primary) !important;
}

/* 法的ページ専用 */
.legal-content h3 {
  color: var(--primary-dark) !important;
  border-bottom-color: var(--primary-color) !important;
}

.legal-content h4 {
  color: var(--primary-color) !important;
}

.info-table th,
.company-info-table th {
  background-color: var(--background-dark) !important;
  color: var(--text-light) !important;
}

.info-table td,
.company-info-table td {
  background-color: var(--background-primary) !important;
  color: var(--text-primary) !important;
}

/* =================================
   ダークモード専用の追加スタイル
   ================================= */

/* ダークモード時の特別な調整 */
[data-dark-mode="true"] .card {
  box-shadow: 0 4px 20px rgba(255, 255, 255, 0.1) !important;
}

[data-dark-mode="true"] .form-control:focus {
  box-shadow: 0 0 0 0.2rem rgba(100, 181, 246, 0.25) !important;
}

[data-dark-mode="true"] .btn-primary {
  background-color: var(--primary-color) !important;
  color: #000000 !important;
}

/* 既存の背景クラスを上書き */
[data-dark-mode="true"] .bg-white,
[data-dark-mode="true"] .bg-light,
[data-dark-mode="true"] .bg-gray-50,
[data-dark-mode="true"] .bg-secondary {
  background-color: var(--background-primary) !important;
}

[data-dark-mode="true"] .text-dark,
[data-dark-mode="true"] .text-gray-900,
[data-dark-mode="true"] .text-secondary {
  color: var(--text-primary) !important;
}

/* =================================
   アニメーション
   ================================= */

* {
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease !important;
}

/* アニメーション除外 */
.no-transition,
.no-transition * {
  transition: none !important;
}
