@charset "UTF-8";
:root {
  --brand:        #1279e8;
  /* 品牌色 */
  --on-brand:     #FAFAF7;
  /* 品牌色上的文本 */
  --surface:      #FAFAF7;
  /* 页面底色 */
  --on-surface:   #121212;
  /* 页面底色上的文本 */
  --secondary: color-mix(in oklab, var(--on-surface) 70%, var(--surface) 30%);
  --card: color-mix(in oklab, var(--surface) 38%, white);
  /* 卡片背景色 */
  --product-background: linear-gradient(to top, #EAF4FF 0%, #B9DAFA 50%, #76AFE8 100%);
  /* 产品图片背景色 */
  --container-narrow: 56rem;
  /* 窄版：以阅读为主 */
  --container:        72rem;
  /* 默认：常规页面 */
  --container-wide:   80rem;
  /* 宽版：营销/视觉模块 */
  --border:       1px solid #E7E5DD;
  /* 全站统一边框 */
  --space: 0.5rem;
  --height-button: 3.5rem;
  --height-input: 2.5rem;
  --height-header: 4.5rem;
  --radius-s: 12px;
  /* 按钮、输入框、小标签 */
  --radius-m: 16px;
  /* 卡片 */
  --radius-l: 24px;
  /* 大面板 */
  --radius-pill: 999px;
  /* 胶囊 */
  --shadow: 0 1px 2px rgba(18, 18, 18, 0.03), 0 10px 28px rgba(18, 18, 18, 0.05);
  --shadow-hover: 0 2px 4px rgba(18, 18, 18, 0.04), 0 18px 40px rgba(18, 18, 18, 0.08);
  --shadow-inset: inset 0 1px 0 rgba(255, 255, 255, 0.32), inset 0 1px 2px rgba(18, 18, 18, 0.08), inset 0 0 0 1px rgba(18, 18, 18, 0.04);
  --transition-base: 180ms cubic-bezier(0.22, 0.72, 0.18, 1);
  --focus-outline: 2px solid color-mix(in oklab, var(--brand) 45%, white);
  --focus-offset: 2px;
  --z-base: 0;
  /* 普通内容 */
  --z-header: 10;
  /* 吸顶头部 */
  --z-panel: 20;
  /* 下拉、弹出层、抽屉 */
  --z-modal: 30;
  /* 遮罩、弹窗这类最高层 */ }

/* ==========================================================================
   - 响应式断点
   - 容器宽度
   - 按钮基础样式
   - 输入框基础样式
   - 阴影、圆角、过渡等常用组合
   - visually-hidden、line-clamp、focus-ring 等工具型规则

   使用方式：
   - 用 @mixin 定义
   - 用 @include 调用
   ========================================================================== */
/* 本来需要先@use "sass:map"，但不太顺利，就把map.get改成了兼容的map-get */
/* 1. 让元素的宽高计算更省心，写的尺寸会把内边距和边框一起算进去 */
*,
*::before,
*::after {
  box-sizing: border-box; }

/* 2. 清掉标题、段落、列表等标签自带的外边距，避免页面间距乱掉 */
body,
h1, h2, h3, h4, h5, h6,
p,
ul, ol,
figure,
blockquote,
dl, dd {
  margin: 0; }

/* 3. 清掉列表默认的左侧缩进，避免 ul、ol 天生往右偏一块 */
ul,
ol {
  padding: 0; }

/* 4. 去掉列表前面自带的小圆点和数字，常用于导航和自定义列表 */
ul,
ol {
  list-style: none; }

/* 5. 让图片和视频按块级元素显示，并且不会撑破父容器 */
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%; }

/* 6. 让输入框、按钮、下拉框这些表单元素继承页面字体，保证风格统一 */
input,
button,
textarea,
select {
  font: inherit; }

/* 7. 去掉 button 自带的原生外观，方便完全按自己的样式来设计按钮 */
button {
  background: none;
  border: 0;
  padding: 0;
  color: inherit; }

/* 8. 去掉链接默认的蓝色和下划线，让链接样式由你自己控制 */
a {
  color: inherit;
  text-decoration: none; }

/* 9. 合并表格边框和空隙，让表格看起来更整齐干净 */
table {
  border-collapse: collapse;
  border-spacing: 0; }

/* 10. 限制文本域只能上下拉伸，避免用户横向拖拽把布局弄乱 */
textarea {
  resize: vertical; }

/* ==========================================================================
   Base
   --------------------------------------------------------------------------
   这里存放全站的基础样式，用来定义网站默认的视觉起点。

   一般放：
   - body 的字体、字号、行高、文字颜色、背景色
   - h1-h6、p、small、strong 等基础文字元素
   - a 链接的默认颜色、悬停效果
   - img、svg 等媒体元素的默认表现
   - ul、ol、blockquote、hr、code 等常见内容元素
   - .container 这类全站通用基础容器
   - section、main 等常见结构元素的基础间距
   - 少量全站通用的辅助类（如果不单独拆 helpers）

   ========================================================================== */
body {
  background-color: var(--surface); }

.container {
  box-sizing: border-box;
  max-width: var(--container);
  width: 100%;
  margin-inline: auto;
  padding-inline: calc(var(--space) * 1); }

/* 在 .container 后面使用，保证能覆盖 */
.container--wide {
  --container: var(--container-wide); }

.container--narrow {
  --container: var(--container-narrow); }

.font-meta {
  font-size: 0.875rem;
  font-weight: 400; }

.font-body {
  font-size: 1rem;
  font-weight: 400; }

.font-title-xs {
  font-size: 1.2rem;
  font-weight: 500; }

.font-title-s {
  font-size: 1.5rem;
  font-weight: 500; }

.font-title-l {
  font-size: 2rem;
  font-weight: 500; }

.font-display {
  font-size: 2.5rem;
  font-weight: 600; }

body.is-menu-open {
  overflow: hidden; }

.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  box-shadow: var(--shadow); }

.site-header__bar {
  background-color: var(--surface); }

.site-header__inner {
  min-height: var(--height-header);
  display: flex;
  padding-inline: calc(var(--space) * 2);
  align-items: center;
  gap: calc(var(--space) * 2); }

.site-header__logo {
  display: inline-flex;
  align-items: center; }

.site-header__logo-image {
  display: block;
  max-height: 3.5rem;
  width: auto; }

.site-header__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: calc(var(--space) * 1);
  margin-left: auto; }

.site-header__icon-button {
  width: 100%;
  min-width: 1rem;
  min-height: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding-left: calc(var(--space) * 1);
  box-shadow: var(--shadow-inset);
  border: var(--border);
  background-color: #ffffff;
  color: var(--on-surface);
  cursor: pointer;
  transition: color var(--transition-base), background-color var(--transition-base), border-color var(--transition-base), transform var(--transition-base); }

.site-header__icon-button:hover,
.site-header__icon-button:focus-visible,
.site-header__icon-button:active,
.site-header__nav-link:hover,
.site-header__nav-link:focus-visible,
.site-header__nav-link:active,
.site-header__submenu-link:hover,
.site-header__submenu-link:focus-visible,
.site-header__submenu-link:active,
.site-header__mobile-link:hover,
.site-header__mobile-link:focus-visible,
.site-header__mobile-link:active,
.site-header__language-link:hover,
.site-header__language-link:focus-visible,
.site-header__language-link:active,
.site-header__back:hover,
.site-header__back:focus-visible,
.site-header__back:active {
  color: var(--brand);
  background-color: color-mix(in oklab, var(--surface) 92%, black); }

.site-header__icon-button:focus-visible,
.site-header__nav-link:focus-visible,
.site-header__submenu-link:focus-visible,
.site-header__mobile-link:focus-visible,
.site-header__language-link:focus-visible,
.site-header__back:focus-visible {
  outline: var(--focus-outline);
  outline-offset: var(--focus-offset); }

.site-header__icon-button:active,
.site-header__nav-link:active,
.site-header__submenu-link:active,
.site-header__mobile-link:active,
.site-header__language-link:active,
.site-header__back:active {
  transform: translateY(1px); }

.site-header__language {
  position: relative;
  flex: 0 0 auto; }

.site-header__language summary {
  list-style: none;
  user-select: none;
  -webkit-user-select: none; }

.site-header__language summary::-webkit-details-marker {
  display: none; }

.site-header__language-label {
  white-space: nowrap; }

.site-header__language-icon {
  width: 1.3rem;
  height: 1rem;
  transition: transform var(--transition-base); }

.site-header__language[open] .site-header__language-icon {
  transform: rotate(180deg); }

.site-header__language-list {
  position: absolute;
  top: calc(100% + calc(var(--space) * 0.5));
  left: 0;
  right: 0;
  width: 100%;
  min-width: 100%;
  margin: 0;
  box-sizing: border-box;
  padding: calc(var(--space) * 1);
  border: var(--border);
  background-color: #ffffff;
  box-shadow: var(--shadow-inset);
  display: grid;
  gap: calc(var(--space) * 1); }

.site-header__language-link {
  display: flex;
  width: 100%;
  align-items: center;
  user-select: none;
  -webkit-user-select: none;
  transition: color var(--transition-base), background-color var(--transition-base), transform var(--transition-base); }

.site-header__language-link--current {
  color: var(--brand); }

.site-header__menu-toggle {
  min-width: 3rem;
  min-height: 3rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-left: calc(var(--space) * 1);
  color: var(--on-surface);
  cursor: pointer; }

.site-header__menu-toggle-box {
  width: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: calc(var(--space) * 0.8); }

.site-header__menu-toggle-line {
  display: block;
  width: 100%;
  height: 2px;
  border-radius: var(--radius-pill);
  background-color: currentColor;
  transition: transform var(--transition-base), opacity var(--transition-base); }

.site-header[data-menu-state="open"] .site-header__menu-toggle-line:nth-child(1) {
  transform: translateY(0.51rem) rotate(45deg); }

.site-header[data-menu-state="open"] .site-header__menu-toggle-line:nth-child(2) {
  opacity: 0; }

.site-header[data-menu-state="open"] .site-header__menu-toggle-line:nth-child(3) {
  transform: translateY(-0.51rem) rotate(-45deg); }

.site-header__nav {
  display: none;
  margin-left: auto; }

.site-header__nav-list,
.site-header__submenu,
.site-header__mobile-list {
  display: flex;
  flex-direction: column; }

.site-header__nav-link,
.site-header__submenu-link,
.site-header__mobile-link {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: calc(var(--space) * 1);
  min-height: 3rem;
  padding-inline: calc(var(--space) * 1.25);
  border-radius: var(--radius-s);
  transition: color var(--transition-base), background-color var(--transition-base), transform var(--transition-base); }

.site-header__nav-link--current,
.site-header__submenu-link--current {
  color: var(--brand); }

.site-header__nav-caret,
.site-header__mobile-arrow {
  width: 1rem;
  height: 1rem;
  flex: 0 0 auto; }

.site-header__drawer {
  position: fixed;
  top: var(--height-header);
  right: 0;
  bottom: 0;
  left: 0;
  background-color: var(--surface);
  border-top: var(--border);
  overflow: hidden;
  opacity: 0;
  transform: translateY(-1rem) scaleY(0.96);
  transform-origin: top;
  transition: opacity 240ms ease, transform 240ms ease; }

.site-header[data-menu-state="open"] .site-header__drawer {
  opacity: 1;
  transform: translateY(0) scaleY(1); }

.site-header__drawer-inner {
  height: 100%;
  display: flex;
  flex-direction: column;
  padding: calc(var(--space) * 2); }

.site-header__mobile-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: calc(var(--space) * 2);
  margin-bottom: calc(var(--space) * 2); }

.site-header__mobile-title {
  flex: 1; }

.site-header__mobile-panels {
  position: relative;
  flex: 1; }

.site-header__mobile-panel {
  position: absolute;
  inset: 0; }

.site-header__mobile-list {
  gap: calc(var(--space) * 0.5); }

.site-header__mobile-link {
  min-height: 3.5rem;
  padding-inline: 0;
  border-radius: 0;
  border-bottom: var(--border); }

.site-header__mobile-link--submenu {
  cursor: pointer; }

.site-header__back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: calc(var(--space) * 6);
  block-size: calc(var(--space) * 6);
  padding: 0;
  border-radius: var(--radius-pill);
  color: var(--on-surface);
  flex: 0 0 auto;
  font-size: 1.25rem;
  line-height: 1;
  transition: color var(--transition-base), background-color var(--transition-base), border-color var(--transition-base), transform var(--transition-base); }

@media (min-width: 64rem) {
  .site-header__actions {
    order: 3;
    margin-left: 0; }
  .site-header__menu-toggle,
  .site-header__drawer {
    display: none; }
  .site-header__nav {
    display: block;
    order: 2; }
  .site-header__nav-list {
    flex-direction: row;
    align-items: center;
    gap: calc(var(--space) * 0.5); }
  .site-header__nav-item {
    position: relative; }
  .site-header__nav-link {
    width: auto;
    min-height: 2.75rem; }
  .site-header__nav-item--has-children:hover .site-header__submenu,
  .site-header__nav-item--has-children:focus-within .site-header__submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto; }
  .site-header__submenu {
    position: absolute;
    top: calc(100% + calc(var(--space) * 1));
    left: 0;
    min-width: 15rem;
    padding: calc(var(--space) * 1);
    border: var(--border);
    border-radius: var(--radius-m);
    background-color: var(--card);
    box-shadow: var(--shadow);
    gap: calc(var(--space) * 0.5);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-0.5rem);
    pointer-events: none;
    transition: opacity var(--transition-base), transform var(--transition-base), visibility var(--transition-base); }
    .site-header__submenu::before {
      content: "";
      position: absolute;
      top: calc(-1 * calc(var(--space) * 1));
      left: 0;
      right: 0;
      height: calc(var(--space) * 1); }
  .site-header__submenu-link {
    min-height: 2.75rem; } }

.site-footer {
  margin-top: calc(var(--space) * 8);
  border-top: var(--border);
  background: linear-gradient(to bottom, #F4FAFF 0%, #DCEEFF 100%);
  color: var(--on-surface); }

.site-footer__main {
  padding-block: calc(var(--space) * 6); }

.site-footer__grid {
  display: grid;
  gap: calc(var(--space) * 4); }

.site-footer__column {
  min-width: 0; }

.site-footer__title {
  margin-bottom: calc(var(--space) * 1.5); }

.site-footer__list {
  display: grid;
  gap: calc(var(--space) * 1.25); }

.site-footer__link,
.site-footer__meta {
  color: var(--on-surface);
  line-height: 1.6; }

.site-footer__link {
  text-underline-offset: 0.15em;
  transition: color var(--transition-base), opacity var(--transition-base), transform var(--transition-base); }

.site-footer__link:hover,
.site-footer__link:focus-visible,
.site-footer__link:active {
  color: var(--brand); }

.site-footer__link:focus-visible {
  outline: var(--focus-outline);
  outline-offset: var(--focus-offset); }

.site-footer__link:active {
  transform: translateY(1px); }

.site-footer__copyright {
  border-top: var(--border); }

.site-footer__copyright-text {
  margin: 0;
  padding-block: calc(var(--space) * 2.5);
  color: var(--on-surface); }

@media (min-width: 48rem) {
  .site-footer__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: calc(var(--space) * 3); } }

/* Sidebar
   侧边栏区域样式。
   这里写侧栏本身的宽度、间距、吸附、边框等区域级规则，
   不负责里面每个小组件的详细外观。 */
/* Section
   页面内容区块的通用外层样式。
   这里统一管理各 section 的上下留白、容器宽度、
   区块之间的节奏和基础布局。 */
.section {
  position: relative;
  padding-block: calc(var(--space) * 4); }

.section__inner {
  display: grid;
  gap: calc(var(--space) * 3); }

.section__header {
  display: grid;
  gap: calc(var(--space) * 2);
  text-align: center; }

.section__title {
  color: var(--on-surface); }

.section__description {
  margin: 0 auto;
  max-width: 120ch;
  color: var(--secondary); }

.button {
  background-color: var(--brand);
  color: var(--on-brand);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--height-button);
  padding: 0.625rem 1.5rem;
  line-height: 1;
  border-radius: var(--radius-s);
  box-shadow: var(--shadow);
  transition: transform var(--transition-base), box-shadow var(--transition-base), background-color var(--transition-base);
  cursor: pointer; }

.button:focus-visible {
  outline: var(--focus-outline);
  outline-offset: var(--focus-offset); }

.button:hover {
  background-color: color-mix(in oklab, var(--brand) 92%, black);
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px); }

.button:active {
  background-color: color-mix(in oklab, var(--brand) 84%, black);
  transform: translateY(0);
  box-shadow: var(--shadow); }

.lead-form {
  min-width: 0; }

.lead-form__form {
  display: grid;
  gap: calc(var(--space) * 2); }

.lead-form__fields {
  display: grid;
  gap: calc(var(--space) * 1.5); }

.lead-form__field {
  display: grid;
  gap: calc(var(--space) * 0.75);
  min-width: 0; }

.lead-form__label {
  color: var(--on-surface); }

.lead-form__input {
  width: 100%;
  min-height: var(--height-input);
  padding: 0.75rem 1rem;
  border: var(--border);
  border-radius: var(--radius-s);
  background-color: color-mix(in oklab, white 88%, var(--surface));
  color: var(--on-surface);
  box-shadow: var(--shadow-inset);
  transition: border-color var(--transition-base), background-color var(--transition-base), box-shadow var(--transition-base), color var(--transition-base); }

.lead-form__field:focus-within .lead-form__label {
  color: var(--brand); }

.lead-form__input:hover {
  border-color: color-mix(in oklab, var(--brand) 24%, #E7E5DD);
  background-color: white; }

.lead-form__input:focus-visible {
  outline: var(--focus-outline);
  outline-offset: var(--focus-offset);
  border-color: color-mix(in oklab, var(--brand) 32%, #E7E5DD);
  background-color: white; }

.lead-form__input:active {
  border-color: color-mix(in oklab, var(--brand) 40%, #E7E5DD);
  background-color: color-mix(in oklab, white 94%, var(--surface)); }

.lead-form__input--textarea {
  min-height: 9rem;
  line-height: 1.6; }

.lead-form__captcha {
  min-width: 0; }

.lead-form__captcha .cf-turnstile {
  max-width: 100%; }

.lead-form__submit {
  width: 100%; }

.lead-form__honeypot {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0; }

@media (min-width: 48rem) {
  .lead-form__fields {
    grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lead-form__field--full {
    grid-column: 1 / -1; }
  .lead-form__submit {
    width: auto;
    justify-self: start; } }

.breadcrumbs {
  padding-block: calc(var(--space) * 1);
  border-bottom: 1px solid #E7E5DD; }

.breadcrumbs__list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: calc(var(--space) * 0.75);
  color: var(--secondary); }

.breadcrumbs__item {
  display: inline-flex;
  align-items: center;
  min-width: 0; }

.breadcrumbs__item + .breadcrumbs__item::before {
  content: "›";
  margin-right: calc(var(--space) * 0.75);
  color: color-mix(in oklab, var(--secondary) 70%, var(--surface) 30%); }

.breadcrumbs__link,
.breadcrumbs__current {
  font-size: 0.875rem;
  line-height: 1.4; }

.breadcrumbs__link {
  display: inline-flex;
  align-items: center;
  border-radius: var(--radius-s);
  color: inherit;
  transition: color var(--transition-base), background-color var(--transition-base), transform var(--transition-base); }

.breadcrumbs__link:hover,
.breadcrumbs__link:focus-visible {
  color: var(--brand); }

.breadcrumbs__link:focus-visible {
  outline: var(--focus-outline);
  outline-offset: var(--focus-offset); }

.breadcrumbs__link:active {
  transform: translateY(1px); }

.breadcrumbs__link[aria-disabled="true"],
.breadcrumbs__link:disabled,
.breadcrumbs__link--disabled {
  opacity: 0.5;
  pointer-events: none; }

.breadcrumbs__current {
  color: var(--on-surface);
  font-weight: 500;
  overflow-wrap: anywhere; }

.home-hero {
  position: relative;
  min-height: 78svh;
  display: flex;
  overflow: hidden; }

.home-hero__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover; }

.home-hero__inner {
  position: relative;
  display: flex;
  gap: calc(var(--space) * 6);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  color: var(--surface); }

.home-trusted {
  background: linear-gradient(to bottom, #F4FAFF 0%, #DCEEFF 100%); }

.home-trusted__list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: calc(var(--space) * 2); }

.home-trusted__logo-link {
  min-height: 4.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: calc(var(--space) * 1); }

.home-trusted__logo {
  max-width: 100%;
  width: auto;
  height: 3rem;
  object-fit: contain; }

.home-stats {
  padding-block: calc(var(--space) * 4);
  background: linear-gradient(to bottom, #F4FAFF 0%, #DCEEFF 100%); }

.home-stats__grid {
  display: grid;
  gap: calc(var(--space) * 2);
  grid-template-columns: repeat(2, minmax(0, 1fr)); }

.home-stats__item {
  padding: calc(var(--space) * 2);
  border-radius: var(--radius-m);
  border: var(--border);
  background-color: var(--card);
  box-shadow: var(--shadow);
  transition: transform var(--transition-base), box-shadow var(--transition-base), background-color var(--transition-base), opacity var(--transition-base); }

.home-stats__item:hover,
.home-stats__item:focus-within {
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px); }

.home-stats__item:active {
  transform: translateY(0); }

.home-stats__item[aria-disabled="true"] {
  opacity: 0.65;
  pointer-events: none;
  box-shadow: none; }

.home-stats--js .home-stats__item {
  transform: translateY(6px);
  opacity: 0; }

.home-stats--visible .home-stats__item {
  animation: home-stats-rise 420ms ease-out forwards; }

.home-stats__value {
  color: var(--brand); }

.home-stats__label {
  margin: calc(var(--space) * 1) 0 0;
  color: var(--on-surface); }

.home-company__overview {
  display: grid;
  gap: calc(var(--space) * 2); }

.home-company__media {
  border: var(--border);
  border-radius: var(--radius-m);
  overflow: hidden;
  transition: box-shadow var(--transition-base); }

.home-company__image {
  width: 100%;
  object-fit: cover;
  aspect-ratio: 4 / 3;
  transition: transform var(--transition-base);
  will-change: transform; }

.home-company__media:hover,
.home-company__media:focus-within {
  box-shadow: var(--shadow-hover); }

.home-company__media:hover .home-company__image,
.home-company__media:focus-within .home-company__image {
  transform: scale(1.06); }

.home-company__summary {
  display: grid;
  gap: calc(var(--space) * 3); }

.home-company__title {
  text-align: center; }

.home-company__quote {
  width: fit-content;
  margin: 0 auto; }

.home-company__factory-gallery {
  overflow: hidden;
  border-radius: var(--radius-m);
  outline: none; }

.home-company__factory-track {
  display: flex;
  gap: calc(var(--space) * 2);
  width: max-content;
  animation: home-company-factory-marquee 36s linear infinite;
  will-change: transform; }

.home-company__factory-gallery:hover .home-company__factory-track,
.home-company__factory-gallery:focus-visible .home-company__factory-track,
.home-company__factory-gallery:active .home-company__factory-track,
.home-company__factory-gallery[aria-disabled="true"] .home-company__factory-track {
  animation-play-state: paused; }

.home-company__factory-gallery[aria-disabled="true"] {
  opacity: 0.65;
  pointer-events: none; }

.home-company__factory-gallery:focus-visible {
  outline: var(--focus-outline);
  outline-offset: var(--focus-offset); }

.home-company__factory-item {
  flex: 0 0 Min(78vw, 20rem); }

.home-company__factory-image {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: var(--radius-m);
  border: var(--border);
  object-fit: cover;
  aspect-ratio: 4 / 3; }

@media (min-width: 48rem) {
  .home-stats__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .home-company__overview {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: start; }
  .home-company__factory-item {
    flex-basis: Min(36vw, 20rem); } }

@media (prefers-reduced-motion: reduce) {
  .home-company__factory-track {
    animation: none; } }

@keyframes home-stats-rise {
  from {
    opacity: 0;
    transform: translateY(6px); }
  to {
    opacity: 1;
    transform: translateY(0); } }

@keyframes home-company-factory-marquee {
  from {
    transform: translateX(0); }
  to {
    transform: translateX(calc(-50% - calc(var(--space) * 1))); } }

.home-reports {
  background: linear-gradient(to bottom, #F4FAFF 0%, #DCEEFF 100%); }

.home-reports__list {
  display: flex;
  gap: calc(var(--space) * 2);
  flex-wrap: nowrap;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scrollbar-width: thin; }

.home-reports__item {
  flex: 0 0 Min(72vw, 14rem);
  border: var(--border);
  box-shadow: var(--shadow);
  transition: transform var(--transition-base), box-shadow var(--transition-base), opacity var(--transition-base); }

.home-reports__item:hover,
.home-reports__item:focus-within {
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px); }

.home-reports__item:active {
  transform: translateY(0); }

.home-reports__image {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover; }

.products-list__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: calc(var(--space) * 2); }

.products-list__card {
  display: flex;
  flex-direction: column;
  height: 100%;
  border: var(--border);
  border-radius: var(--radius-m);
  background: var(--product-background);
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: transform var(--transition-base), box-shadow var(--transition-base), background-color var(--transition-base); }
  .products-list__card:hover, .products-list__card:focus-visible {
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
    color: var(--brand); }
  .products-list__card:focus-visible {
    outline: var(--focus-outline);
    outline-offset: var(--focus-offset); }
  .products-list__card:active {
    transform: translateY(0); }
  .products-list__card[aria-disabled="true"] {
    opacity: 0.65;
    pointer-events: none;
    box-shadow: none; }

.products-list__media {
  aspect-ratio: 4 / 3; }

.products-list__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block; }

.products-list__content {
  display: grid;
  gap: calc(var(--space) * 1);
  padding: calc(var(--space) * 2);
  text-align: center; }

@media (min-width: 48rem) {
  .products-list__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)); } }

@media (min-width: 64rem) {
  .products-list__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)); } }

@media (min-width: 80rem) {
  .products-list__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)); } }

.product-single__title {
  text-align: center; }

.product-single__overview {
  display: grid;
  gap: calc(var(--space) * 2); }

.product-single__media {
  border: var(--border);
  border-radius: var(--radius-m);
  overflow: hidden;
  background: var(--product-background); }

.product-single__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 4 / 3; }

.product-single__summary {
  display: grid;
  gap: calc(var(--space) * 3); }

.product-single__quote {
  width: fit-content;
  margin: 0 auto; }

.product-single__details {
  padding-top: calc(var(--space) * 3);
  border-top: 1px solid #E7E5DD;
  display: grid;
  gap: calc(var(--space) * 2); }

.product-single__details-title {
  text-align: center; }

.product-single__content {
  display: grid;
  gap: calc(var(--space) * 1.5); }

.product-single__content p {
  color: var(--on-surface); }

@media (min-width: 48rem) {
  .product-single__overview {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: start; } }

.insights-list__list {
  display: grid;
  grid-template-columns: 1fr; }

.insights-list__item {
  border-bottom: var(--border); }

.insights-list__card {
  display: grid;
  gap: calc(var(--space) * 2);
  padding-block: calc(var(--space) * 2.5);
  color: var(--on-surface);
  transition: color var(--transition-base); }
  .insights-list__card:hover, .insights-list__card:focus-visible {
    color: var(--brand); }
  .insights-list__card:focus-visible {
    outline: var(--focus-outline);
    outline-offset: var(--focus-offset); }

.insights-list__media {
  aspect-ratio: 16 / 9;
  border-radius: var(--radius-s);
  overflow: hidden;
  background-color: color-mix(in oklab, var(--surface) 86%, var(--brand)); }

.insights-list__image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover; }

.insights-list__content {
  display: grid;
  grid-template-rows: auto 1fr auto;
  align-content: start;
  gap: calc(var(--space) * 1.25);
  min-width: 0; }

.insights-list__title {
  color: currentColor; }

.insights-list__excerpt {
  color: var(--on-surface);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden; }

.insights-list__meta {
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--space) * 0.5) calc(var(--space) * 1.5);
  color: var(--secondary); }

@media (min-width: 48rem) {
  .insights-list__card {
    grid-template-columns: minmax(0, 220px) minmax(0, 1fr);
    align-items: stretch;
    gap: calc(var(--space) * 3); } }

.case-studies-list__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: calc(var(--space) * 2); }

.case-studies-list__item {
  min-width: 0; }

.case-studies-list__card {
  display: flex;
  flex-direction: column;
  height: 100%;
  border: var(--border);
  border-radius: var(--radius-m);
  background-color: var(--card);
  box-shadow: var(--shadow);
  color: var(--on-surface);
  overflow: hidden;
  transition: transform var(--transition-base), box-shadow var(--transition-base), background-color var(--transition-base), color var(--transition-base); }
  .case-studies-list__card:hover, .case-studies-list__card:focus-visible {
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
    color: var(--brand); }
  .case-studies-list__card:focus-visible {
    outline: var(--focus-outline);
    outline-offset: var(--focus-offset); }
  .case-studies-list__card:active {
    transform: translateY(0); }

.case-studies-list__media {
  aspect-ratio: 16 / 9;
  background-color: color-mix(in oklab, var(--surface) 86%, var(--brand)); }

.case-studies-list__image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover; }

.case-studies-list__content {
  display: grid;
  align-content: start;
  gap: calc(var(--space) * 2);
  padding: calc(var(--space) * 2); }

.case-studies-list__excerpt {
  color: var(--on-surface);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden; }

.case-studies-list__meta {
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--space) * 0.5) calc(var(--space) * 1.5);
  color: var(--secondary); }

@media (min-width: 48rem) {
  .case-studies-list__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)); } }

@media (min-width: 64rem) {
  .case-studies-list__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)); } }

.contact__form-header,
.contact__direct-header {
  display: grid;
  gap: calc(var(--space) * 1); }

.contact__form-description,
.contact__direct-description {
  color: var(--secondary); }

.contact__form-body,
.contact__direct-body {
  background-color: white;
  margin-block: calc(var(--space) * 4);
  padding: calc(var(--space) * 4);
  border-radius: var(--radius-l);
  border: var(--border); }

.contact__direct-body {
  display: grid;
  gap: calc(var(--space) * 2); }

.contact__direct-item {
  display: grid;
  gap: calc(var(--space) * 0.75); }

.contact__direct-item + .contact__direct-item {
  padding-top: calc(var(--space) * 2);
  border-top: var(--border); }

.contact__direct-label {
  color: var(--secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em; }

.contact__direct-value {
  margin: 0;
  color: var(--on-surface);
  line-height: 1.6; }

a.contact__direct-value {
  text-decoration: none; }

a.contact__direct-value:hover,
a.contact__direct-value:focus-visible {
  color: var(--brand); }

.contact__form-body,
.contact__direct-body {
  margin-block: calc(var(--space) * 3) 0; }

.resources-page__article {
  display: grid;
  gap: calc(var(--space) * 2.5); }

.resources-page__media {
  border: var(--border);
  border-radius: var(--radius-m);
  overflow: hidden;
  background-color: color-mix(in oklab, var(--surface) 86%, var(--brand)); }

.resources-page__image {
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover; }

.resources-page__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: calc(var(--space) * 0.5) calc(var(--space) * 1.5);
  color: var(--secondary); }

.resources-page__title {
  color: var(--on-surface); }

.resources-page__content {
  display: grid;
  gap: calc(var(--space) * 1.5); }

.resources-page__content :is(h2, h3, h4) {
  margin-top: calc(var(--space) * 2); }

.resources-page__content p,
.resources-page__content li {
  color: var(--on-surface); }
