/* ===== InBiz_Production_2025 統一メインCSS ===== */
/* Phase 1: CSS フレームワーク統一 - メインファイル */
/* 作成日: 2025-08-25 */

/* ===== 基盤スタイルのインポート ===== */
@import url("./base/_variables.css");
@import url("./base/_reset.css");
@import url("./base/_typography.css");
@import url("./base/_layout.css");

/* ===== アニメーションコンポーネントのインポート ===== */
@import url("./components/_animations.css");
@import url("./components/_forms.css");
@import url("./components/_card-shadows.css");

/* ===== 外部フォントのインポート ===== */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap");

/* ===== Bootstrap 5 カスタマイズ ===== */
/* Bootstrap 5の変数をカスタマイズ */
:root {
  /* Bootstrap 5のプライマリカラーを統一 */
  --bs-primary: var(--primary-color);
  --bs-primary-rgb: 15, 76, 129;
  --bs-secondary: var(--secondary-color);
  --bs-secondary-rgb: 230, 185, 128;
  --orange: #fd7e14; /* オレンジ色の定義を追加 */

  /* Bootstrap 5のフォント設定を統一 */
  --bs-font-sans-serif: var(--font-family-primary);
  --bs-body-font-family: var(--font-family-primary);
  --bs-body-font-size: var(--font-size-base);
  --bs-body-font-weight: var(--font-weight-normal);
  --bs-body-line-height: var(--line-height-normal);
  --bs-body-color: var(--text-primary);
  --bs-body-bg: var(--bg-primary);

  /* Bootstrap 5のボーダー設定 */
  --bs-border-color: var(--border-color);
  --bs-border-radius: var(--border-radius-md);
  --bs-border-radius-sm: var(--border-radius-sm);
  --bs-border-radius-lg: var(--border-radius-lg);
  --bs-border-radius-xl: var(--border-radius-xl);

  /* Bootstrap 5のシャドウ設定 */
  --shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.4);
  --bs-box-shadow: var(--shadow-md);
  --bs-box-shadow-sm: var(--shadow-sm);
  --bs-box-shadow-lg: var(--shadow-lg);
}

/* ===== グローバルスタイル調整 ===== */
body {
  font-family: var(--font-family-primary);
  background-color: var(--bg-primary);
}

/* ===== Bootstrap コンポーネントのカスタマイズ ===== */

/* ナビゲーション統一 */
.navbar {
  background-color: var(--bg-primary);
  border-bottom: 1px solid var(--border-color);
  box-shadow: var(--shadow-sm);
}

.navbar-brand {
  font-weight: var(--font-weight-semibold);
  color: var(--primary-color) !important;
}

.navbar-nav .nav-link {
  font-weight: var(--font-weight-medium);
  color: var(--text-primary) !important;
  transition: var(--transition-all);
}

.navbar-nav .nav-link:hover {
  color: var(--primary-color) !important;
}

/* ボタン統一 */
.btn {
  border-radius: var(--border-radius-md);
  font-weight: var(--font-weight-medium);
  transition: var(--transition-all);
  border: 2px solid transparent;
}

.btn-primary {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: white;
}

.btn-primary:hover {
  background-color: var(--primary-dark);
  border-color: var(--primary-dark);
  transform: translateY(-2px);
  box-shadow: var(--shadow-primary);
}

.btn-secondary {
  background-color: var(--secondary-color);
  border-color: var(--secondary-color);
  color: var(--text-primary);
}

.btn-secondary:hover {
  background-color: var(--secondary-dark);
  border-color: var(--secondary-dark);
  transform: translateY(-2px);
}

.btn-outline-primary {
  color: var(--primary-color);
  border-color: var(--primary-color);
}

.btn-outline-primary:hover {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: white;
  transform: translateY(-2px);
}

/* カード統一 */
.card {
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-all);
}

.card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.card-header {
  background-color: var(--bg-secondary);
  border-bottom: 1px solid var(--border-color);
  font-weight: var(--font-weight-semibold);
}

/* フォーム要素統一 */
.form-control {
  border: 2px solid var(--border-color);
  border-radius: var(--border-radius-md);
  transition: var(--transition-all);
}

.form-control:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 0.2rem rgba(15, 76, 129, 0.25);
}

.form-label {
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  margin-bottom: var(--spacing-sm);
}

/* アラート統一 */
.alert {
  border-radius: var(--border-radius-md);
  border: none;
}

.alert-primary {
  background-color: var(--primary-lighter);
  color: var(--primary-dark);
}

.alert-secondary {
  background-color: var(--secondary-lighter);
  color: var(--secondary-dark);
}

/* モーダル統一 */
.modal-content {
  border-radius: var(--border-radius-lg);
  border: none;
  box-shadow: var(--shadow-xl);
}

.modal-header {
  border-bottom: 1px solid var(--border-color);
}

.modal-footer {
  border-top: 1px solid var(--border-color);
}

/* テーブル統一 */
.table {
  border-color: var(--border-color);
}

.table-striped > tbody > tr:nth-of-type(odd) > td,
.table-striped > tbody > tr:nth-of-type(odd) > th {
  background-color: var(--bg-secondary);
}

/* ===== カスタムコンポーネント ===== */

/* ヒーローセクション */
.hero-section {
  background: var(--gradient-primary);
  color: white;
  padding: var(--spacing-4xl) 0;
  position: relative;
  overflow: hidden;
}

.hero-section::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.1);
  z-index: 1;
}

.hero-section .container {
  position: relative;
  z-index: 2;
}

/* セクションタイトル */
.section-title {
  text-align: center;
  margin-bottom: var(--spacing-2xl);
}

.section-title h2 {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--primary-color);
  margin-bottom: var(--spacing-md);
}

.section-title p {
  font-size: var(--font-size-lg);
  color: var(--text-secondary);
  max-width: 600px;
  margin: 0 auto;
}

/* フィーチャーカード */
.feature-card {
  text-align: center;
  padding: var(--spacing-xl);
  border-radius: var(--border-radius-lg);
  background: var(--bg-primary);
  border: 1px solid var(--border-color);
  transition: var(--transition-all);
  height: 100%;
}

.feature-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-lg);
  border-color: var(--primary-color);
}

.feature-card .icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--spacing-lg);
  background: var(--gradient-primary);
  border-radius: var(--border-radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: var(--font-size-2xl);
}

/* CTAセクション */
.cta-section {
  background: var(--gradient-accent);
  color: white;
  padding: var(--spacing-3xl) 0;
  text-align: center;
}

.cta-section h2 {
  color: white;
  margin-bottom: var(--spacing-lg);
}

.cta-section.with-bg-image {
  background:
    linear-gradient(rgba(0, 123, 255, 0.7), rgba(0, 123, 255, 0.7)),
    url("../images/hero/slide1.jpg") center/cover no-repeat;
  height: 25vh;
}

.cta-section p {
  color: rgba(255, 255, 255, 0.9);
  font-size: var(--font-size-lg);
  margin-bottom: var(--spacing-xl);
}

/* フッター */
.footer {
  background-color: var(--bg-dark);
  color: white;
  padding: var(--spacing-3xl) 0 var(--spacing-xl);
}

.footer h5 {
  color: white;
  margin-bottom: var(--spacing-lg);
}

.footer a {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
  transition: var(--transition-all);
}

.footer a:hover {
  color: white;
  text-decoration: none;
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  padding-top: var(--spacing-lg);
  margin-top: var(--spacing-2xl);
  text-align: center;
  color: rgba(255, 255, 255, 0.6);
}

/* ===== ユーティリティクラス ===== */

/* ホバーエフェクト */
.hover-lift {
  transition: var(--transition-all);
}

.hover-lift:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

/* グラデーション背景 */
.bg-gradient-primary {
  background: var(--gradient-primary) !important;
}

.bg-gradient-secondary {
  background: var(--gradient-secondary) !important;
}

.bg-gradient-accent {
  background: var(--gradient-accent) !important;
}

/* アニメーション */
.fade-in {
  opacity: 0;
  transform: translateY(30px);
  transition: all 0.6s ease;
}

.fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ===== レスポンシブ調整 ===== */
@media (max-width: 768px) {
  .hero-section {
    padding: var(--spacing-2xl) 0;
  }

  .section-title h2 {
    font-size: var(--font-size-2xl);
  }

  .feature-card {
    padding: var(--spacing-lg);
  }

  .cta-section {
    padding: var(--spacing-2xl) 0;
  }
}

/* ===== プリント用スタイル ===== */
@media print {
  .hero-section,
  .cta-section {
    background: none !important;
    color: var(--text-primary) !important;
  }

  .btn {
    border: 1px solid var(--border-color) !important;
    background: none !important;
    color: var(--text-primary) !important;
  }
}
