/* Base CSS - 全ページ共通スタイル（真の最適化版） */

/* フォント適用 */
body {
  font-family: var(--font-family);
}

/* ========================================
   トランジション共通化（重複削除）
   ======================================== */
.transition-base { transition: var(--transition-base); }
.transition-fast { transition: var(--transition-fast); }

/* ========================================
   ボタンコンポーネント
   ======================================== */
.btn-primary {
  display: inline-flex;
  align-items: center;
  background: var(--color-bg);
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-full);
  padding: 1.25rem 2.5rem;
  color: var(--color-primary);
  font-family: var(--font-family);
  font-size: var(--fs-lg);
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.05em;
  cursor: pointer;
  text-decoration: none;
}

.btn-primary:hover {
  background: var(--color-accent);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,173,169,0.2);
}

.btn-icon {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  background: var(--color-bg);
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-full);
  padding: 3px;
  cursor: pointer;
  text-decoration: none;
}

.btn-icon-text {
  font-family: var(--font-family);
  font-size: var(--icon-text-size, var(--fs-lg));
  font-weight: 600;
  color: var(--color-primary);
  padding: var(--icon-text-padding, 1.25rem 2.5rem);
  line-height: 1;
  letter-spacing: 0.05em;
}

/* ========================================
   アイコン（CSS変数で統一管理）
   ======================================== */
.icon-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--icon-arrow-size, 4.5rem);
  height: var(--icon-arrow-size, 4.5rem);
  background: var(--color-accent);
  border-radius: var(--radius-circle);
  flex-shrink: 0;
  position: relative;
}

.icon-arrow::after {
  content: '→';
  font-size: var(--icon-arrow-font, 1.5rem);
  font-weight: bold;
  color: var(--color-primary);
  line-height: 1;
}

/* サイズバリエーション（CSS変数使用） */
.icon-arrow--sm {
  --icon-arrow-size: 2rem;
  --icon-arrow-font: 1rem;
}

.icon-arrow--md {
  --icon-arrow-size: 2.5rem;
  --icon-arrow-font: 1.25rem;
}

/* ボタンホバー効果 */
.btn-icon:hover {
  background: var(--color-accent);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.btn-icon:hover .btn-icon-text {
  color: var(--color-primary);
}

.btn-icon:hover .icon-arrow {
  background: var(--color-primary);
  transform: translateX(3px);
}

.btn-icon:hover .icon-arrow::after {
  color: var(--color-text-white);
}

/* CTAボタン（全ページ共通） */
.cta-btn-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
}

.cta-btn {
  display: inline-flex;
  align-items: center;
  background: var(--color-bg);
  border: 2px solid var(--color-primary);
  border-radius: 50px;
  cursor: pointer;
  transition: var(--transition-base);
  padding: 0;
  text-decoration: none;
  outline: none;
  font-family: var(--font-family);
}

.cta-btn-text {
  font-size: 20px;
  font-weight: 600;
  color: var(--color-primary);
  padding: 18px 38px 18px 28px;
  white-space: nowrap;
  line-height: 1;
  letter-spacing: 0.03em;
}

.cta-btn-arrow {
  width: 45px;
  height: 45px;
  background: var(--color-accent);
  border-radius: 50%;
  margin: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-base);
  flex-shrink: 0;
}

.cta-btn-arrow::before {
  content: '→';
  font-size: 26px;
  font-weight: bold;
  color: var(--color-primary);
  line-height: 1;
}

/* CTAボタンホバー効果 */
.cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,173,169,0.2);
  background: var(--color-accent);
}

.cta-btn:hover .cta-btn-arrow {
  transform: translateX(2px);
  background: var(--color-primary);
}

.cta-btn:hover .cta-btn-arrow::before {
  color: var(--color-text-white);
}

/* ========================================
   インタビュー吹き出しスタイル
   ======================================== */
.interview-qa-item {
  margin-bottom: 30px;
}

.interview-question {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 15px;
}

.interview-question-content {
  max-width: 80%;
  background: var(--color-primary);
  color: var(--color-text-white);
  padding: 15px 20px;
  border-radius: 20px 20px 0 20px;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}

.interview-question-label {
  font-size: 12px;
  margin-bottom: 5px;
  opacity: 0.9;
}

.interview-question-text {
  font-size: 15px;
  line-height: 1.6;
}

.interview-answer {
  display: flex;
  justify-content: flex-start;
}

.interview-answer-content {
  max-width: 80%;
  background: #f5f5f5;
  color: var(--color-text);
  padding: 15px 20px;
  border-radius: 20px 20px 20px 0;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}

.interview-answer-label {
  font-size: 12px;
  margin-bottom: 5px;
  color: var(--color-primary);
  font-weight: 600;
}

.interview-answer-text {
  font-size: 15px;
  line-height: 1.7;
}

@media (max-width: 768px) {
  .interview-question-content,
  .interview-answer-content {
    max-width: 90%;
  }
  
  .interview-question-text,
  .interview-answer-text {
    font-size: 14px;
  }
}

/* ========================================
   タブ切り替え（全ページ共通）
   ======================================== */
.tab-container {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  background: var(--color-bg);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

.tab-nav {
  display: flex;
  background: var(--color-bg);
}

.tab-button {
  flex: 1;
  padding: var(--spacing-md) var(--spacing-lg);
  background: var(--color-bg);
  border: none;
  cursor: pointer;
  font-size: var(--fs-xl);
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.4;
  letter-spacing: 0.05em;
  transition: var(--transition-base);
  position: relative;
  display: flex;
  justify-content: center;
  text-align: right;
}

.tab-button::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: transparent;
  transition: background 0.3s ease;
}

.tab-button.active {
  background: var(--color-primary);
  color: var(--color-text-white);
}

.tab-button:not(.active)::after {
  background: var(--color-primary);
}

.tab-button:hover:not(.active) {
  background: #f8f8f8;
  color: var(--color-text);
}

.tab-content {
  padding: var(--spacing-3xl) var(--spacing-xl);
  background: var(--color-bg);
}

.tab-panel {
  display: none;
  animation: fadeIn 0.3s ease-in-out;
}

.tab-panel.active {
  display: block;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.tab-description {
  font-size: var(--fs-lg);
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.3;
  letter-spacing: 0.03em;
  margin-bottom: var(--spacing-xl);
}

.tab-button-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.tab-content-button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 80px;
  padding: 0;
  background: var(--color-bg);
  border: 2px solid #e0e0e0;
  cursor: pointer;
  transition: var(--transition-fast);
  font-size: var(--fs-lg);
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.03em;
  color: var(--color-text);
  text-decoration: none;
  overflow: hidden;
}

.tab-content-button span {
  flex: 1;
  padding: var(--spacing-md) var(--spacing-sm) var(--spacing-md) var(--spacing-lg);
  display: flex;
  align-items: center;
}

.tab-content-button:hover {
  transform: translateX(-5px);
  box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}

.tab-content-button:hover .arrow-square {
  background: #ffcc00;
}

/* 四角い矢印ボタン（タブ用） */
.arrow-square {
  background: var(--color-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s ease;
}

.arrow-square::after {
  content: '→';
  color: var(--color-primary);
  font-weight: 900;
  font-size: 1.8em;
  line-height: 1;
}

.arrow-square--large {
  width: 80px;
  height: 80px;
}

.arrow-square--small {
  width: 32px;
  height: 32px;
}

.arrow-square--medium {
  width: 40px;
  height: 40px;
}

/* セクションラッパー */
.section-wrapper {
  padding: 20px;
  width: 100%;
}

/* タブレスポンシブ（1024px） */
@media (max-width: 1024px) {
  .tab-container {
    max-width: 720px;
  }
  
  .tab-button {
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--fs-lg);
  }
  
  .tab-content {
    padding: var(--spacing-xl) var(--spacing-lg);
  }
  
  .arrow-square--large {
    width: 75px;
    height: 75px;
  }
}

/* ========================================
   カードコンポーネント
   ======================================== */
.card {
  background: var(--color-bg);
  border-radius: var(--radius-md);
  padding: var(--spacing-lg);
  box-shadow: var(--shadow-sm);
}

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

.card--bordered {
  border: 1px solid var(--color-primary);
}

.card--primary {
  background: var(--color-primary);
  color: var(--color-text-white);
}

.card--accent {
  background: var(--color-accent);
  color: var(--color-primary);
}

/* ========================================
   タグコンポーネント
   ======================================== */
.tag {
  display: inline-block;
  padding: 0.5rem 1.25rem;
  font-size: var(--fs-sm);
  font-weight: 600;
  border-radius: var(--radius-full);
}

.tag--primary {
  background: var(--color-bg);
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
}

.tag--accent {
  background: var(--color-accent);
  color: var(--color-primary);
}

.tag--inverse {
  background: var(--color-primary);
  color: var(--color-text-white);
}

/* ========================================
   Elementor専用テキストカラー（詳細度を高く）
   ======================================== */
.elementor-widget-heading .text--primary .elementor-heading-title,
.text--primary.elementor-widget-heading .elementor-heading-title,
.text--primary .elementor-heading-title {
  color: var(--color-primary);
}

.elementor-widget-heading .text--accent .elementor-heading-title,
.text--accent.elementor-widget-heading .elementor-heading-title,
.text--accent .elementor-heading-title {
  color: var(--color-accent);
}

.elementor-widget-heading .text--light .elementor-heading-title,
.text--light.elementor-widget-heading .elementor-heading-title,
.text--light .elementor-heading-title {
  color: var(--color-text-light);
}

.elementor-widget-heading .text--white .elementor-heading-title,
.text--white.elementor-widget-heading .elementor-heading-title,
.text--white .elementor-heading-title {
  color: var(--color-text-white);
}

/* テキストエディタウィジェット用 */
.elementor-widget-text-editor .text--primary,
.text--primary .elementor-text-editor,
.text--primary.elementor-text-editor {
  color: var(--color-primary);
}

.elementor-widget-text-editor .text--accent,
.text--accent .elementor-text-editor,
.text--accent.elementor-text-editor {
  color: var(--color-accent);
}

/* 汎用テキストカラー */
.text--primary {
  color: var(--color-primary);
}

.text--accent {
  color: var(--color-accent);
}

.text--light {
  color: var(--color-text-light);
}

.text--white {
  color: var(--color-text-white);
}

/* ========================================
   背景色ユーティリティ
   ======================================== */
.bg--primary {
  background-color: var(--color-primary);
}

.bg--accent {
  background-color: var(--color-accent);
}

.bg--gray {
  background-color: var(--color-bg-gray);
}

.bg--light {
  background-color: var(--color-bg-light);
}

/* ========================================
   文字サイズユーティリティ
   ======================================== */
.text--xs { font-size: var(--fs-xs); }
.text--sm { font-size: var(--fs-sm); }
.text--base { font-size: var(--fs-base); }
.text--md { font-size: var(--fs-md); }
.text--lg { font-size: var(--fs-lg); }
.text--xl { font-size: var(--fs-xl); }
.text--2xl { font-size: var(--fs-2xl); }
.text--3xl { font-size: var(--fs-3xl); }

/* ========================================
   余白ユーティリティ
   ======================================== */
.p--xs { padding: var(--spacing-xs); }
.p--sm { padding: var(--spacing-sm); }
.p--md { padding: var(--spacing-md); }
.p--lg { padding: var(--spacing-lg); }
.p--xl { padding: var(--spacing-xl); }

.mt--xs { margin-top: var(--spacing-xs); }
.mt--sm { margin-top: var(--spacing-sm); }
.mt--md { margin-top: var(--spacing-md); }
.mt--lg { margin-top: var(--spacing-lg); }
.mt--xl { margin-top: var(--spacing-xl); }

.mb--xs { margin-bottom: var(--spacing-xs); }
.mb--sm { margin-bottom: var(--spacing-sm); }
.mb--md { margin-bottom: var(--spacing-md); }
.mb--lg { margin-bottom: var(--spacing-lg); }
.mb--xl { margin-bottom: var(--spacing-xl); }

/* ========================================
   必須ユーティリティのみ
   ======================================== */

/* コンテナ */
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  box-sizing: border-box;
}

@media (max-width: 768px) {
  .container {
    padding: 0 20px;
  }
}

@media (max-width: 568px) {
  .container {
    padding: 0 15px;
  }
}

/* ========================================
   レスポンシブ（CSS変数で一括管理）
   ======================================== */
@media (max-width: 1024px) {
  :root {
    /* アイコン自動調整 */
    --icon-arrow-size: 3.75rem;
    --icon-arrow-font: 1.25rem;
    --icon-text-size: var(--fs-md);
    --icon-text-padding: 1rem 2rem;
    /* コンテナ調整 */
    --container-padding: var(--spacing-md);
  }
}

@media (max-width: 768px) {
  :root {
    /* アイコン縮小 */
    --icon-arrow-size: 3.25rem;
    --icon-arrow-font: 1rem;
    --icon-text-size: var(--fs-base);
    --icon-text-padding: 0.875rem 1.75rem;
  }
  
  /* モバイル非表示 */
  .hide-mobile {
    display: none;
  }
  
  /* CTAボタン */
  .cta-btn-text {
    font-size: 18px;
    padding: 14px 24px;
  }
  
  .cta-btn-arrow {
    width: 45px;
    height: 45px;
  }
  
  .cta-btn-arrow::before {
    font-size: 18px;
  }
  
  /* タブレスポンシブ */
  .tab-button {
    padding: 12px 16px;
    font-size: var(--fs-md);
  }
  
  .tab-content {
    padding: var(--spacing-lg) var(--spacing-sm);
  }
  
  .tab-content-button {
    height: 70px;
    font-size: var(--fs-md);
  }
  
  .tab-content-button span {
    padding: 14px 8px 14px 16px;
  }
  
  .arrow-square--large {
    width: 70px;
    height: 70px;
  }
  
  .arrow-square::after {
    font-size: 1.5em;
  }
}

@media (max-width: 568px) {
  :root {
    --container-padding: var(--spacing-sm);
  }
  
  /* タブレスポンシブ */
  .tab-content-button {
    height: 65px;
    font-size: var(--fs-md);
  }
  
  .tab-content-button span {
    padding: 12px 8px 12px 16px;
  }
  
  .arrow-square--large {
    width: 65px;
    height: 65px;
  }
}

@media (max-width: 480px) {
  :root {
    /* 最小サイズ */
    --icon-arrow-size: 3rem;
    --icon-arrow-font: 0.875rem;
    --icon-text-size: var(--fs-sm);
    --icon-text-padding: 0.75rem 1.25rem;
  }
  
  /* CTAボタン */
  .cta-btn-text {
    font-size: 16px;
    padding: 12px 20px;
  }
  
  .cta-btn-arrow {
    width: 40px;
    height: 40px;
  }
  
  .cta-btn-arrow::before {
    font-size: 16px;
  }
  
  /* タブレスポンシブ */
  .tab-content-button {
    height: 60px;
    font-size: var(--fs-base);
  }
  
  .tab-content-button span {
    padding: 12px 8px 12px 14px;
  }
  
  .arrow-square--large {
    width: 60px;
    height: 60px;
  }
  
  .arrow-square::after {
    font-size: 1.4em;
  }
}

@media (max-width: 320px) {
  :root {
    /* 極小画面対応 */
    --fs-3xl: var(--fs-2xl);
    --fs-2xl: var(--fs-xl);
  }
  
  /* タブレスポンシブ */
  .tab-content-button {
    height: 50px;
    font-size: var(--fs-sm);
  }
  
  .tab-content-button span {
    padding: 8px 8px 8px 12px;
  }
  
  .arrow-square--large {
    width: 50px;
    height: 50px;
  }
  
  .arrow-square::after {
    font-size: 1.3em;
  }
}

/* ========================================
   アニメーション（GPU最適化）
   ======================================== */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fade-in {
  animation: fadeIn 0.5s ease forwards;
  will-change: opacity, transform;
}



/* ========================================
   フッターセクション
   ======================================== */
.hika-site-footer {
  background: var(--color-primary);
  color: var(--color-text-white);
  padding: 60px 0 30px;
  margin-top: 0;
  font-size: 16px; /* 全体のフォントサイズ統一 */
}

.footer-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--spacing-lg);
}

/* フッター上部（メインコンテンツ） */
.footer-content {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  margin-bottom: 50px;
}

/* ロゴセクション - 全カラム共通の高さ */
.footer-logo-row {
  height: 200px; /* ロゴサイズに合わせて高さ調整 */
  display: flex;
  align-items: flex-end;
  margin-bottom: 20px;
}

.footer-logo {
  /* heightを削除し、中身に応じたサイズに */
  display: flex;
  align-items: flex-end;
}

.footer-logo img {
  height: 200px; /* デスクトップ版200px */
  width: auto; /* 縦横比を保つ */
  max-width: 200px; /* 幅の上限を設定 */
  object-fit: contain; /* 縦横比を維持 */
  margin-left: 0; /* 左端を見出しと揃える */
}

/* 各カラムの見出し */
.footer-column h3 {
  font-size: 16px; /* 16pxに統一 */
  font-weight: 700; /* 太字に変更 */
  color: var(--color-text-white);
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 2px solid rgba(255, 255, 255, 0.5); /* 線を太く */
  letter-spacing: 0.05em;
}

/* リンクリスト */
.footer-column ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-column li {
  margin-bottom: 12px;
}

.footer-column a {
  color: var(--color-text-white);
  text-decoration: none;
  font-size: 16px; /* 16pxに統一 */
  transition: var(--transition-fast);
  display: inline-block;
  position: relative;
  padding-left: 0;
}

.footer-column a:hover {
  opacity: 0.8;
  transform: translateX(3px);
}

/* お問い合わせカラムのスタイル */
.footer-column:last-child ul {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

/* FOLLOW USセクション */
.footer-follow {
  margin-top: 20px;
}

.footer-follow-title {
  font-size: 16px; /* 16pxに統一 */
  font-weight: 700; /* 太字に */
  color: var(--color-text-white);
  margin-bottom: 10px;
  letter-spacing: 0.1em;
}

/* Xアイコン */
.social-icons {
  display: flex;
  gap: 12px;
}

.social-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px; /* 高さのみ指定 */
  /* 背景色とボーダー削除 - 画像そのまま使用 */
  transition: var(--transition-fast);
}

.social-icon:hover {
  transform: translateY(-3px);
  opacity: 0.8;
}

.social-icon img {
  width: 40px;
  height: 40px;
  object-fit: contain;
}

/* コピーライト */
.footer-bottom {
  text-align: right; /* デスクトップは右寄せ */
  padding-top: 30px;
  border-top: 2px solid rgba(255, 255, 255, 0.5); /* 線を太く */
}

.footer-copyright {
  font-size: 16px; /* 16pxに統一 */
  opacity: 0.9;
  letter-spacing: 0.05em;
}

/* モバイルのみ改行 */
.mobile-only {
  display: none;
}

/* タブレット対応 (769px〜1024px) */
@media (min-width: 769px) and (max-width: 1024px) {
  .footer-content {
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
  }
}

/* スマホ対応 (768px以下) */
@media (max-width: 768px) {
  .hika-site-footer {
    padding: 40px 0 20px;
    margin-top: 0;
    overflow-x: hidden; /* 横スクロール防止 */
  }
  
  .footer-container {
    padding: 0 var(--spacing-md);
    max-width: 100%; /* 幅制限 */
    overflow-x: hidden; /* 横スクロール防止 */
  }
  
  .footer-content {
    grid-template-columns: 1fr;
    gap: 30px;
    margin-bottom: 40px;
  }
  
  /* ロゴ行の調整 */
  .footer-logo-row {
    justify-content: center; /* 中央寄せ */
    height: auto;
    margin-bottom: 30px;
  }
  
  .footer-logo {
    text-align: center; /* 中央寄せ */
    max-width: 100%; /* 幅制限追加 */
  }
  
  .footer-logo img {
    height: 100px; /* 少し小さく調整 */
    width: auto; /* 縦横比を保つ */
    max-width: calc(100vw - 48px); /* 画面幅からpadding(--spacing-md)分を引いた幅 */
    object-fit: contain;
  }
  
  /* 見出しの下線を維持 */
  .footer-column h3 {
    margin-bottom: 15px;
    padding-bottom: 8px;
    border-bottom: 2px solid rgba(255, 255, 255, 0.5);
  }
  
  .footer-column li {
    margin-bottom: 10px;
  }
  
  /* FOLLOW USをお問い合わせ内に統合表示 */
  .footer-follow {
    margin-top: 15px;
    padding-top: 15px;
    border-top: 2px solid rgba(255, 255, 255, 0.5); /* 線を太く */
  }
  
  .social-icon {
    height: 36px;
  }
  
  .social-icon img {
    width: 36px;
    height: 36px;
  }
  
  /* コピーライトを中央寄せ・2行表示 */
  .footer-bottom {
    text-align: center;
    padding-top: 20px;
  }
  
  .footer-copyright {
    line-height: 1.6;
  }
  
  /* モバイルで改行表示 */
  .mobile-only {
    display: inline;
  }
}

/* スマホ小 (480px以下) */
@media (max-width: 480px) {
  .hika-site-footer {
    padding: 35px 0 20px;
  }
  
  .footer-container {
    padding: 0 var(--spacing-sm);
  }
  
  .footer-logo img {
    height: 80px; /* サイズを調整 */
    width: auto; /* 縦横比を保つ */
    max-width: calc(100vw - 40px); /* 画面幅からpadding分を引いた幅に制限 */
    object-fit: contain;
  }
}

/* スマホ極小 (320px以下) */
@media (max-width: 320px) {
  .footer-content {
    gap: 25px;
  }
  
  .footer-column h3 {
    margin-bottom: 12px;
  }
  
  .footer-logo img {
    height: 60px; /* さらに小さく */
    max-width: calc(100vw - 30px); /* padding考慮 */
  }
  
  .social-icon {
    height: 32px;
  }
  
  .social-icon img {
    width: 32px;
    height: 32px;
  }
}

/* ========================================
   ヘッダー 769px～1024px：2行レイアウト
   ======================================== */
@media (min-width: 769px) and (max-width: 1024px) {
  :root {
    --header-height: 110px;
  }
  
  .hika-site-header {
    height: var(--header-height);
  }
  
  .header-inner {
    height: 100%;
    display: flex;
    align-items: center;
  }
  
  .container {
    height: 100%;
    display: flex;
    align-items: stretch;
  }
  
  .header-content {
    display: grid;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: 1fr 1fr;
    gap: 8px 20px;
    align-items: center;
    width: 100%;
    height: 100%;
  }
  
  .site-branding {
    grid-row: 1 / 3;
    align-self: center;
  }
  
  .main-navigation {
    grid-column: 2;
    grid-row: 1 / 3;
    display: flex;
    align-items: center;
    height: 100%;
  }
  
  .nav-menu {
    display: grid;
    grid-template-columns: repeat(3, auto);
    grid-template-rows: 1fr 1fr;
    gap: 6px 10px;
    width: 100%;
    align-content: center;
    height: 100%;
  }
  
  .menu-item {
    display: flex;
    align-items: center;
  }
  
  .menu-item:nth-child(1) { grid-column: 1; grid-row: 1; }
  .menu-item:nth-child(2) { grid-column: 2; grid-row: 1; }
  .menu-item:nth-child(3) { grid-column: 3; grid-row: 1; }
  .menu-item:nth-child(4) { grid-column: 2; grid-row: 2; }
  .menu-item:nth-child(5) { grid-column: 3; grid-row: 2; }
  
  .header-cta {
    grid-column: 3;
    grid-row: 1 / 3;
    display: flex;
    align-items: stretch;
  }
  
  .cta-button {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 24px;
  }
}