/* =================================
   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;

  /* New Variables Mapping */
  --color-primary: #2c8b80 !important;
  --color-secondary: #56d1a7 !important;
  --color-accent: #ffc107 !important;
  --color-background-dark: #0f3d3e !important;
}

/* スキーム2: オーシャンブルー */
[data-color-scheme='ocean-blue'] {
  --primary-color: #0077be !important;
  --primary-light: #4fc3f7 !important;
  --primary-dark: #003d5b !important;
  --accent-color: #ff6b35 !important;

  /* New Variables Mapping */
  --color-primary: #0077be !important;
  --color-secondary: #4fc3f7 !important;
  --color-accent: #ff6b35 !important;
  --color-background-dark: #003d5b !important;
}

/* スキーム3: サンセットオレンジ */
[data-color-scheme='sunset-orange'] {
  --primary-color: #ff6b35 !important;
  --primary-light: #ffab91 !important;
  --primary-dark: #d84315 !important;
  --accent-color: #4caf50 !important;

  /* New Variables Mapping */
  --color-primary: #ff6b35 !important;
  --color-secondary: #ffab91 !important;
  --color-accent: #4caf50 !important;
  --color-background-dark: #d84315 !important;
}

/* スキーム4: ロイヤルパープル */
[data-color-scheme='royal-purple'] {
  --primary-color: #7b1fa2 !important;
  --primary-light: #ba68c8 !important;
  --primary-dark: #4a148c !important;
  --accent-color: #ffd54f !important;

  /* New Variables Mapping */
  --color-primary: #7b1fa2 !important;
  --color-secondary: #ba68c8 !important;
  --color-accent: #ffd54f !important;
  --color-background-dark: #4a148c !important;
}

/* スキーム5: Deep Forest & Steel */
[data-color-scheme='deep-forest-steel'] {
  --primary-color: #2f4f4f !important;
  --primary-light: #4682b4 !important;
  --primary-dark: #1a2421 !important;
  --accent-color: #8fbc8f !important;

  /* New Variables Mapping */
  --color-primary: #2f4f4f !important;
  --color-secondary: #4682b4 !important;
  --color-accent: #8fbc8f !important;
  --color-background-dark: #2c3e50 !important;
}

/* スキーム6: Botanical Mineral */
[data-color-scheme='botanical-mineral'] {
  --primary-color: #556b2f !important;
  --primary-light: #8fbc8f !important;
  --primary-dark: #3b4a20 !important;
  --accent-color: #bc8f8f !important;

  /* New Variables Mapping */
  --color-primary: #556b2f !important;
  --color-secondary: #8fbc8f !important;
  --color-accent: #bc8f8f !important;
  --color-background-dark: #3b4a20 !important;
}

/* スキーム7: Twilight Eco */
[data-color-scheme='twilight-eco'] {
  --primary-color: #483d8b !important;
  --primary-light: #20b2aa !important;
  --primary-dark: #2f275b !important;
  --accent-color: #ffd700 !important;

  /* New Variables Mapping */
  --color-primary: #483d8b !important;
  --color-secondary: #20b2aa !important;
  --color-accent: #ffd700 !important;
  --color-background-dark: #2f275b !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;
}
