/* レスポンシブ対応 */

/* Tablet (768px以上) */
@media (min-width: 768px) {
  /* Logo */
  .logo-text {
    display: inline;
  }

  /* Navigation */
  .nav-toggle {
    display: none;
  }

  .nav-brand {
    display: none;
  }

  .nav-list {
    position: static;
    width: auto;
    max-width: none;
    height: auto;
    flex-direction: row;
    align-items: center;
    gap: 0;
    padding: 0;
    margin: 0;
    box-shadow: none;
    background-color: transparent;
    background: transparent;
  }

  .nav-link {
    font-size: var(--font-size-small);
    padding: var(--spacing-lg) var(--spacing-md);
    position: relative;
    text-align: left;
    border-radius: 0;
  }

  .nav-link:hover {
    background-color: transparent;
  }

  .nav-link.active {
    background-color: transparent;
  }

  .nav-link.active::after {
    content: "";
    position: absolute;
    bottom: var(--spacing-md);
    left: var(--spacing-md);
    right: var(--spacing-md);
    height: 3px;
    background: var(--color-thunder-blue);
    border-radius: 2px;
  }

  /* Hero */
  .hero {
    min-height: 100vh;
    padding: var(--spacing-3xl) 0;
  }

  /* Section */
  .section {
    padding: var(--section-padding-y) 0;
  }

  /* Card Grid */
  .card-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-xl);
  }

  /* Feature Grid */
  .feature-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Footer */
  .footer-content {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Desktop (1024px以上) */
@media (min-width: 1024px) {
  /* Container Padding */
  .container {
    padding: 0 var(--spacing-xl);
  }

  /* Hero */
  .hero {
    padding: calc(var(--spacing-3xl) + var(--spacing-xl)) 0;
  }

  /* Card Grid */
  .card-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  /* Feature Grid */
  .feature-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  /* Footer */
  .footer-content {
    grid-template-columns: 2fr 1fr 1fr;
  }
}

/* Large Desktop (1280px以上) */
@media (min-width: 1280px) {
  /* Container */
  .container {
    padding: 0 var(--spacing-2xl);
  }
}

/* タッチデバイス対応 */
@media (hover: none) {
  /* タッチデバイスではホバーアニメーションを無効化 */
  .card:hover {
    transform: none;
  }

  .feature-item:hover {
    transform: none;
  }

  .btn-primary:hover {
    transform: none;
  }
}

/* タップターゲットサイズ確保 */
@media (max-width: 767px) {
  a, button {
    min-height: 44px;
    min-width: 44px;
  }

  /* ヘッダー */
  .header {
    height: 64px;
  }

  .header-content {
    height: 64px;
    display: flex;
    align-items: center;
  }

  .logo {
    font-size: var(--font-size-base);
  }

  .logo img {
    height: 36px;
  }

  .logo-text {
    display: inline;
    font-size: var(--font-size-xs);
  }

  .nav {
    display: flex;
    align-items: center;
    height: 100%;
  }

  .nav-toggle {
    display: flex;
    align-items: center;
  }

  /* メインコンテンツの上部マージン調整 */
  main {
    margin-top: 64px;
  }

  /* モバイルメニューのパディング調整 */
  .nav-list {
    padding-top: calc(64px + var(--spacing-xl));
  }
}
