/* responsive.css — 媒体查询断点 */

/* ≥ 1440px — 大屏桌面，默认样式（见各 CSS 文件） */

/* ≤ 1439px — 标准桌面 */
@media (max-width: 1439px) {
  .container {
    padding: 0 1.5rem;
  }
}

/* ≤ 1199px — 小屏桌面 / 笔记本 */
@media (max-width: 1199px) {
  .products__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .analysis__content {
    gap: var(--spacing-md);
  }
}

/* ≤ 1023px — 平板横屏 */
@media (max-width: 1023px) {
  .products__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .research__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .analysis__content {
    flex-direction: column;
  }

  .analysis__img {
    flex: none;
    max-width: 100%;
  }

  .carousel {
    height: 480px;
  }
}

/* ≤ 767px — 平板竖屏 */
@media (max-width: 767px) {
  .navbar__menu {
    display: none;
    flex-direction: column;
    position: absolute;
    top: var(--navbar-height);
    left: 0;
    right: 0;
    background: var(--color-primary);
    padding: var(--spacing-sm) 0;
    gap: 0;
  }

  .navbar__menu--open {
    display: flex;
  }

  .navbar__link {
    padding: 0.75rem var(--spacing-md);
    width: 100%;
  }

  .navbar__hamburger {
    display: flex;
  }

  .products__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .research__grid {
    grid-template-columns: repeat(1, 1fr);
  }

  .section__title {
    font-size: 1.5rem;
  }

  .carousel {
    height: 380px;
  }

  .carousel__btn {
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1rem;
  }
}

/* ≤ 599px — 小屏手机兜底 */
@media (max-width: 599px) {
  .products__grid {
    grid-template-columns: repeat(1, 1fr);
  }

  .carousel {
    height: 280px;
    min-height: 200px;
  }

  .carousel__btn--prev {
    left: var(--spacing-sm);
  }

  .carousel__btn--next {
    right: var(--spacing-sm);
  }

  .logo-scroll__track img {
    height: 45px;
  }

  .section {
    padding: var(--spacing-md) 0;
  }
}

/* 数据库介绍区响应式 */
@media (max-width: 1023px) {
  .db-intro__content,
  .db-intro__content--reverse {
    flex-direction: column;
  }

  .db-intro__img-wrap {
    flex: none;
    max-width: 100%;
    width: 100%;
  }
}

@media (max-width: 767px) {
  .db-intro__tags {
    gap: var(--spacing-sm);
  }

  .db-tag img {
    width: 36px;
    height: 36px;
  }
}
