:root {
  --purple: #28176f;
  --purple-dark: #1f125a;
  --orange: #f29536;
  --ink: #2d2d33;
  --muted: #777985;
  --line: #e7e7eb;
  --soft: #f6f6f8;
  --white: #fff;
  --container: 1440px;
  --shadow: 0 18px 45px rgba(31, 20, 80, .12);
  --ease-out: cubic-bezier(.22, .61, .36, 1);
  --ease-smooth: cubic-bezier(.4, 0, .2, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); font-family: Inter, "Segoe UI", Arial, sans-serif; line-height: 1.6; background: #fff; }
body.menu-open { overflow: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
button { cursor: pointer; }
.container { width: min(calc(100% - 48px), var(--container)); margin-inline: auto; }
.section { padding: 100px 0; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; z-index: 9999; top: 10px; left: 10px; padding: 10px 16px; color: #fff; background: var(--purple); transform: translateY(-150%); }
.skip-link:focus { transform: none; }

.site-header { position: sticky; z-index: 100; top: -100px; background: #fff; }
.topbar { min-height: 100px; display: flex; align-items: center; justify-content: space-between; gap: 40px; }
.brand { display: inline-flex; align-items: center; color: var(--purple); }
.brand img { width: 195px; height: auto; transition: opacity .4s var(--ease-out), transform .45s var(--ease-out); }
.brand:hover img, .brand:focus-visible img { opacity: .86; transform: translateY(-1px); }
.topbar-contact { display: flex; align-items: center; gap: clamp(28px, 5vw, 76px); }
.topbar-contact a { display: flex; align-items: center; gap: 14px; transition: color .35s var(--ease-out), transform .4s var(--ease-out); }
.topbar-contact a:hover, .topbar-contact a:focus-visible { transform: translateY(-2px); }
.topbar-contact small, .topbar-contact strong { display: block; }
.topbar-contact small { color: #555; font-size: 14px; }
.topbar-contact strong { color: var(--purple); font-size: 16px; }
.contact-icon { color: var(--orange); font-size: 30px; line-height: 1; transition: transform .4s var(--ease-out); }
.topbar-contact a:hover .contact-icon { transform: scale(1.06); }

.main-nav { position: sticky; top: 0; background: var(--purple); color: #fff; transition: box-shadow .4s var(--ease-out), background-color .4s var(--ease-out); }
.main-nav.scrolled { box-shadow: 0 12px 28px rgba(21, 12, 62, .25); }
.nav-inner { min-height: 66px; display: flex; align-items: stretch; justify-content: space-between; }
.primary-menu { display: flex; align-items: stretch; margin: 0; padding: 0; list-style: none; }
.primary-menu > li { position: relative; display: flex; align-items: stretch; perspective: 800px; }
.primary-menu a { min-width: 130px; height: 100%; padding: 0 28px; display: grid; place-items: center; font-size: 18px; font-weight: 700;transition: color .38s var(--ease-out), background-color .38s var(--ease-out); font-family: "Gilroy-Bold";}
.primary-menu li+li a::before{
  position: absolute;
  left: 0px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 99;
  width: 1px;
  height: 12px;
  background: rgba(255,255,255,.24);
  content: "";
}

.primary-menu a:hover, .primary-menu a.active { background: var(--orange);color: #fff; }
.submenu-toggle { position: absolute; z-index: 2; right: 7px; top: 50%; width: 22px; height: 22px; padding: 0; border: 0; background: transparent; transform: translateY(-50%); }
.submenu-toggle::after { content: ""; position: absolute; top: 7px; left: 7px; width: 6px; height: 6px; border-right: 1px solid #fff; border-bottom: 1px solid #fff; transform: rotate(45deg); transition: transform .2s ease; }
.has-submenu.open > .submenu-toggle::after,
.has-submenu:hover > .submenu-toggle::after,
.has-submenu:focus-within > .submenu-toggle::after { transform: rotate(225deg) translate(-2px, -2px); }
.submenu {
  position: absolute;
  z-index: 20;
  top: 100%;
  left: 0;
  min-width: 230px;
  padding: 8px 0;
  border-bottom: 3px solid var(--orange);
  color: var(--ink);
  background: #fff;
  box-shadow: 0 8px 18px rgba(0,0,0,.2);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: rotateX(-90deg);
  transform-origin: 0 0;
  transform-style: preserve-3d;
  backface-visibility: hidden;
  will-change: transform, opacity;
  transition:
    transform .5s cubic-bezier(.2,.75,.25,1),
    opacity .3s ease,
    visibility 0s linear .5s;
}
.submenu a { 
  min-width: 0; 
  height: auto; 
  padding: 0 22px; 
  display: block; 
  border: 0; 
  color: #666; 
  font-size: 16px; 
  font-weight: 500; 
  line-height: 42px; 
  white-space: nowrap; 
  transition: color .3s ease, background-color .3s ease, padding-left .3s ease; 
  }
.submenu a:hover, .submenu a:focus-visible { padding-left: 26px; color: #fff; background: #28176f;;}
.has-submenu:hover > .submenu,
.has-submenu:focus-within > .submenu,
.has-submenu.open > .submenu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: rotateX(0deg);
  transition:
    transform .5s cubic-bezier(.2,.75,.25,1),
    opacity .3s ease,
    visibility 0s;
}
.megamenu { left: -240px; width: min(850px, calc(100vw - 48px)); padding: 28px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; }
.megamenu strong { display: block; min-height: 48px; margin-bottom: 10px; color: var(--purple); font-size: 14px; line-height: 1.3; }
.megamenu a { padding: 8px 0; white-space: normal; }
.megamenu a:hover, .megamenu a:focus-visible { padding-left: 8px; color: #fff; background: #222; }
.nav-tools { display: flex; align-items: center; gap: 22px; }
.icon-button, .language-button, .menu-toggle { border: 0; color: #fff; background: transparent; transition: color .35s var(--ease-out), opacity .35s var(--ease-out), background-color .35s var(--ease-out); }
.icon-button { font-size: 38px; }
.icon-button:hover, .icon-button:focus-visible, .language-button:hover, .language-button:focus-visible { color: var(--orange); }
.language-button { min-width: 104px; height: 66px; display: inline-flex; align-items: center; justify-content: center; gap: 7px; padding: 0 8px; font-size: 14px; font-weight: bold; line-height: 1; white-space: nowrap;font-family: "Gilroy-Bold"; }
.language-globe { position: relative; width: 16px; height: 16px; flex: 0 0 16px; border: 1.5px solid currentColor; border-radius: 50%; }
.language-globe::before { content: ""; position: absolute; inset: 2px 5px; border-right: 1px solid currentColor; border-left: 1px solid currentColor; border-radius: 50%; }
.language-globe::after { content: ""; position: absolute; top: 6px; right: 1px; left: 1px; border-top: 1px solid currentColor; }
.language-arrow { width: 7px; height: 7px; margin-top: -4px; border-right: 1px solid currentColor; border-bottom: 1px solid currentColor; transform: rotate(45deg); transition: transform .2s ease; }
.language-select.open .language-arrow { margin-top: 4px; transform: rotate(225deg); }
.language-select { position: relative; height: 100%; display: flex; align-items: center; }
.language-menu { position: absolute; z-index: 25; top: calc(100% + 0px); right: 0; min-width: 150px; padding: 0 0; color: var(--ink); background: #fff; box-shadow: var(--shadow); opacity: 0; visibility: hidden; transform: translateY(10px); transition: .22s ease; }
.language-select.open .language-menu { opacity: 1; visibility: visible; transform: none; }
.language-menu div a{ display: flex; width: 100%; padding: 10px 18px; border: 0; text-align: left; color: #555; background: transparent; transition: color .32s var(--ease-out), background-color .32s var(--ease-out), padding-left .32s var(--ease-out);align-items: center; font-size: 14px;}
.language-menu div a:hover, .language-menu div a.active { color: #fff; background: var(--purple); }
.menu-toggle { display: none; width: 48px; padding: 12px; }
.menu-toggle span:not(.sr-only) { display: block; height: 2px; margin: 6px 0; background: currentColor; }
.search-panel { position: absolute; z-index: -1; top: 100%; right: max(24px, calc((100% - var(--container)) / 2)); display: flex; width: min(440px, calc(100% - 48px)); padding: 14px; background: #fff; box-shadow: var(--shadow); opacity: 0; transform: translateY(-12px); visibility: hidden; transition: .25s ease; }
.search-panel.open { z-index: 5; opacity: 1; transform: none; visibility: visible; }
.search-panel input { flex: 1; min-width: 0; padding: 12px 14px; border: 1px solid var(--line); outline: none; }
.search-panel button { padding: 12px 20px; border: 0; color: #fff; background: var(--orange); transition: color .35s var(--ease-out), background-color .35s var(--ease-out); }
.search-panel button:hover, .search-panel button:focus-visible { background: var(--purple); }

.hero { position: relative; height: 783px; overflow: hidden; background: var(--purple-dark); }
.hero .swiper-wrapper { height: 100%; }
.hero-slide { position: relative; height: 100%; display: grid; align-items: start; }
/* .hero-slide-medical { --hero-image: url("../images/jstrump/hero.webp"); }
.hero-slide-mould { --hero-image: url("../images/jstrump/mould-showcase.webp"); }
.hero-slide-factory { --hero-image: url("../images/jstrump/factory-main.webp"); }
.hero-slide-partnership { --hero-image: url("../images/jstrump/news-2.webp"); } */


.hero-overlay { 
  position: absolute; inset: 0; 
  /* background: linear-gradient(90deg, rgba(24, 15, 78, .82) 0%, rgba(33, 24, 91, .52) 48%, rgba(35, 26, 84, .16) 100%);  */
  }
.hero-content { position: relative; z-index: 1; padding-top: 180px; color: #fff; }
.hero-content h1, .hero-content h2 { max-width: 1000px; margin: 0 0 24px; font-size: clamp(44px, 3.4vw, 68px); line-height: 1.15;  color: #fff;
font-family: "Gilroy-Bold";}
.hero-content .p { max-width: 720px; margin: 0 0 40px; font-size: clamp(16px, 1.25vw, 20px); }
.hero-points { display: grid; grid-template-columns: repeat(2, minmax(240px, max-content)); gap: 4px 55px; margin: 0 0 4.6875vw; 
padding: 0; list-style: none; font-weight: 700; 
font-size: 20px;
}
.hero-points p::before {content: "";margin-right: 10px;color: #fff;width: 10px;height: 10px;border-radius: 50%;opacity: 1;display: inline-block;border: 2px solid rgba(255,255,255,.6);}
.button { display: inline-flex; min-height: 52px; padding: 0 28px; align-items: center; justify-content: center; border: 0; border-radius: 4px; font-weight: 700; transition: color .4s var(--ease-out), background-color .4s var(--ease-out), box-shadow .45s var(--ease-out), transform .45s var(--ease-out); }
.button:hover, .button:focus-visible { color: #fff; background: #242424; box-shadow: 0 12px 24px rgba(0,0,0,.16); transform: translateY(-2px); }
.button-orange { color: #fff; background: var(--orange);border-radius: 30px; background: rgba(242, 149, 54, .88);}
.hero-content .button { width: auto; min-width: 210px; min-height: 58px; white-space: nowrap; }
.hero-pagination { bottom: 56px !important; display: flex; justify-content: center; gap: 17px; }
.hero-pagination .swiper-pagination-bullet { width: 14px; height: 14px; margin: 0 4px !important; border: 2px solid #fff; 
background: transparent; opacity: .55; transition: opacity .35s var(--ease-out), background-color .35s var(--ease-out), transform .35s var(--ease-out); }
.hero-pagination .swiper-pagination-bullet-active { background: #fff; opacity: 1; }
.hero-pagination .swiper-pagination-bullet:hover { opacity: 1; transform: scale(1.12); }

.section-heading { max-width: 1370px; margin: 0 auto 68px; }
.section-heading.centered { text-align: center; }
.section-heading h2 { margin: 6px 0 18px; color: var(--purple); font-size: clamp(34px, 3.2vw, 48px); line-height: 1.15;font-family: "Gilroy-Bold"; font-weight: bold;}
.section-heading .pp { margin: 0; color: #333; font-size: 18px; }
.eyebrow { color: var(--orange); font-size: 16px; font-weight: bold; text-transform: uppercase; letter-spacing: .03em; font-family: "Gilroy-Bold";}
.eyebrow.light { color: #fff; opacity: .85; }
.about { padding-top: 72px; padding-bottom: 120px; background: url(//wm.cdn.cn86.cn/suzhoucanpukeji/2026/06/58afd3acce51dhog.jpg) no-repeat center;background-size: cover; }
.about-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.about-card { position: relative; padding-bottom: 108px;     -webkit-transition: .5s ease;
    -moz-transition: .5s ease;
    transition: .5s ease;}
.about-card img { width: 100%; height: 263px; object-fit: cover; transition: transform .7s var(--ease-out), filter .7s var(--ease-out); }
.about-card > div { position: absolute; right: 8%; bottom: 0; left: 8%; min-height: 162px; padding: 26px 28px; background: #fff; box-shadow: var(--shadow); transition: box-shadow .55s var(--ease-out), transform .55s var(--ease-out); }
.about-card h3 { margin: 0 0 6px; color: var(--purple); font-size: 24px; font-family: "Gilroy-Bold";}
.about-card p { margin: 0 0 16px; color: var(--muted); line-height: 1.35; }
.about-card a { color: var(--purple); font-size: 14px; font-weight: normal; transition: color .35s var(--ease-out); display: flex;align-items: center;opacity: .7;}
.about-card a span{width: 10px;height: 10px;background: url(//wm.cdn.cn86.cn/suzhoucanpukeji/2026/06/bb3fb64568akbsn5.png) no-repeat center;margin-left: 9px;display: inline-block;}
.about-card:hover { transform: translateY(-34px); }
.about-card:hover > div { box-shadow: 0 22px 50px rgba(31, 20, 80, .16); transform: translateY(-3px); }
.about-card a:hover, .about-card a:focus-visible { color: var(--orange); }

.mould-showcase { position: relative; width: 100%; aspect-ratio: 1920 / 663; min-height: 0; overflow: hidden; background: #e8f3f7; }
.mould-showcase > img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 64.3%; }
.hotspot { position: absolute; width: 24px; height: 24px; padding: 0; border: 5px solid rgba(255,255,255,.55); border-radius: 50%; color: #fff; background: var(--purple); box-shadow: 0 0 0 5px rgba(40,23,111,.12); transform: translate(-50%, -50%); transition: background-color .35s var(--ease-out), box-shadow .35s var(--ease-out), scale .35s var(--ease-out); }
.hotspot span { display: grid; width: 100%; height: 100%; place-items: center; line-height: 1; }
.hotspot.active { background: var(--purple); }
.hotspot:hover, .hotspot:focus-visible { background: var(--orange); box-shadow: 0 0 0 8px rgba(242,149,54,.18); scale: 1.12; }
.hotspot-1 { top: 22.9%; left: 31.77%; }
.hotspot-2 { top: 39.7%; left: 52.6%; }
.hotspot-3 { top: 57.5%; left: 18.23%; }
.hotspot-4 { top: 62.3%; left: 72.34%; }
.hotspot-label { position: absolute; z-index: 3; left: 0; top: 0; width: max-content; max-width: min(390px, calc(100% - 32px)); min-height: 48px; padding: 13px 24px; border-radius: 28px; color: var(--purple); background: rgba(255,255,255,.95); box-shadow: 0 9px 28px rgba(31,20,80,.14); font-size: 15px; font-weight: 800; line-height: 1.4; white-space: nowrap; pointer-events: none; opacity: 0; transform: translateY(-50%); transition: left .25s ease, top .25s ease, opacity .2s ease; }
.hotspot-label.positioned { opacity: 1; }
.hotspot-label.on-left { transform: translate(-100%, -50%); }

.factory { position: relative; display: grid; grid-template-columns: 628fr 1292fr; height: auto; aspect-ratio: 1920 / 579; min-height: 0; overflow: hidden; color: #fff; background: #333; }
.factory-copy { position: relative; z-index: 3; background: linear-gradient(rgba(40,23,111,.88), rgba(40,23,111,.88)), url("../images/jstrump/factory-panel.webp") 42% center/cover; padding: 20px;padding-top: 4.166vw;}
.factory-copy-inner { position: relative; top: 0; right: 0; bottom: 0; left: 0; max-width: 435px;    margin: 0 auto;}
.factory-copy h2 { margin: 3px 0 18px; font-size: clamp(34px, 2.5vw, 48px); line-height: 1.15; }
.factory-title-line { display: block; width: 82px; height: 6px; margin-bottom: 38px; background: #fff; }
.factory-copy .ul { margin: 0 0 38px; padding: 0; list-style: none; }
.factory-copy .ul p { position: relative; min-height: 49px; padding: 13px 0 10px 26px; border-bottom: 1px solid rgba(255,255,255,.1); font-size: clamp(13px, .95vw, 16px); line-height: 1.35; white-space: nowrap; }
.factory-copy .ul p::before { content: "●"; position: absolute; left: 0; color: #a99de8; font-size: 11px; }
.factory-copy .button { min-width: 166px; min-height: 50px; border-radius: 28px; font-weight: 400; }
.factory-nav-rail { position: relative; z-index: 6; right: 0; bottom: 0; left: 0; height: 80px; display: flex; align-items: center; justify-content: flex-end; gap: 28px; padding-right: 28px; background: var(--purple); width: 628px;}
.factory-nav-rail button { width: 30px; height: 48px; padding: 0; border: 0; color: #fff; background: transparent; font-size: 42px; font-weight: 200; line-height: 1; opacity: .9; transition: color .35s var(--ease-out), opacity .35s var(--ease-out), transform .35s var(--ease-out); }
.factory-nav-rail button:hover, .factory-nav-rail button:focus-visible { color: var(--orange); opacity: 1; transform: scale(1.08); }
.machine-gallery { position: relative; min-width: 0; overflow: hidden; background: #333; }
.machine-swiper { position: absolute; top: 14.85%; right: -6.4%; left: 3.125vw; height: 59.25%; overflow: hidden; }

.machine-swiper figure { margin: 0; overflow: hidden; background: #292929; display: block;}
.machine-swiper img { width: 100%; height: 100%; object-fit: cover; transition: transform .75s var(--ease-out), filter .75s var(--ease-out); }
.machine-swiper figure:hover img { transform: scale(1.025); filter: saturate(1.04) contrast(1.015); }
.machine-pagination { bottom: 12.4% !important; display: flex; justify-content: center; gap: 20px; width: 100%;}
.machine-pagination .swiper-pagination-bullet { width: 14px; height: 14px; margin: 0 !important; border-radius: 0; background: #777; opacity: 1; transition: background-color .35s var(--ease-out), transform .35s var(--ease-out); }
.machine-pagination .swiper-pagination-bullet-active { background: #fff; }
.machine-pagination .swiper-pagination-bullet:hover { background: #aaa; transform: scale(1.12); }

.products { background: repeating-linear-gradient(120deg, #fff 0, #fff 7px, #fafafd 7px, #fafafd 9px); margin-top: -80px;padding-top: 120px;}
.products .section-heading { margin-bottom: 54px; }
.product-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 38px; }
.product-card { min-width: 0; background: #fff; transition: transform .5s var(--ease-out), box-shadow .5s var(--ease-out); }
.product-card.hidden { display: none; }
.product-media { position: relative; overflow: hidden; border: 1px solid var(--line); background: #fff; }
.product-media > img { width: 100%; aspect-ratio: 1; object-fit: contain; transition: transform .75s var(--ease-out), filter .75s var(--ease-out); }
.product-overlay { position: absolute; right: 0; bottom: 0; left: 0; min-height: 100px; padding: 50px 10px 20px; text-align: center; color: #fff; background: #28176f; opacity: 0; transform: translateY(100%); transition: transform .55s var(--ease-out), opacity .45s var(--ease-out); }
.product-overlay h3 { margin: 0; color: inherit; font-size: 18px; line-height: 1.35; opacity: 0; transform: translateY(10px); transition: opacity .4s var(--ease-out), transform .4s var(--ease-out); transition-delay: 0s; }
.product-overlay a { position: absolute; top: 0; left: 50%; display: grid; width: 72px; height: 72px; place-items: center; border-radius: 50%; color: var(--purple); background: #fff; box-shadow: 0 0 15px rgba(0,0,0,.3); font-size: 24px; line-height: 1; opacity: 0; transform: translate(-50%, -42%); transition: color .4s var(--ease-out), opacity .4s var(--ease-out), transform .45s var(--ease-out); transition-delay: 0s; }
.product-overlay a:hover, .product-overlay a:focus-visible { color: var(--orange); transform: translate(-50%, -50%) rotate(45deg); }
.product-media:hover .product-overlay, .product-media:focus-within .product-overlay { opacity: 1; transform: translateY(0); }
.product-media:hover .product-overlay h3, .product-media:focus-within .product-overlay h3 { opacity: 1; transform: translateY(0); transition-delay: .18s; }
.product-media:hover .product-overlay a, .product-media:focus-within .product-overlay a { opacity: 1; transform: translate(-50%, -50%); transition-delay: .1s; }
.product-media:hover > img, .product-media:focus-within > img { transform: scale(1.025); }
.product-card:hover { box-shadow: 0 18px 38px rgba(31,20,80,.11); transform: translateY(-4px); }

.cta-banner { position: relative; min-height: 327px; display: flex; align-items: center; overflow: hidden; color: #fff; background: #14285c; }
.cta-main-image { position: absolute; inset: 0 20% 0 0; background: url("//wm.cdn.cn86.cn/suzhoucanpukeji/2026/06/b60718163ain3tpo.jpg") center 55%/cover; }
.cta-banner > img { position: absolute; top: 0; right: 0; width: 21.7%; height: 100%; object-fit: cover; }

.button-orange2{border-radius: 30px;min-width: 166px; min-height: 50px; border-radius: 28px; font-weight: 400;}


.cta-content { position: relative; z-index: 2; }
.cta-banner h2 { margin: 0 0 8px; font-size: clamp(32px, 3.3vw, 52px); }
.cta-banner p { margin: 0 0 28px; font-size: 18px; }
.equipment-feature { display: grid; grid-template-columns: 1fr 1fr; }
.equipment-feature > img { width: 100%; height: 100%; object-fit: cover; transition: filter .75s var(--ease-out); }
.equipment-feature:hover > img { filter: saturate(1.035) contrast(1.01); }
.equipment-copy { display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding: clamp(50px, 8vw, 140px); }
.equipment-copy h2 { margin: 0 0 30px; color: var(--purple); font-size: clamp(38px, 3.6vw, 48px); line-height: 1.16; font-family: "Gilroy-Bold";}
.equipment-copy h2 span { color: var(--orange); }
.equipment-copy .pp { max-width: 650px; margin: 0 0 45px; color: #555; font-size: 18px; }
.services { display: grid; grid-template-columns: 1fr 1fr; aspect-ratio: 1920 / 650; min-height: 0; overflow: hidden; background: #333; color: #fff; }
.service-copy { display: flex; min-height: 0; flex-direction: column; align-items: flex-start; justify-content: flex-start; padding: 10.2% 7% 7% 25.1%; overflow: hidden; }
.service-copy h2 { margin: 0 0 22px; font-size: clamp(38px, 2.7vw, 48px); line-height: 1.12;font-family: "Gilroy-Bold"; }
.service-copy h2 span { color: var(--orange); }
.service-copy .pp { max-width: 560px; margin: 0; color: #eee; font-size: 18px; line-height: 1.45; }
.service-copy .ul { display: grid; grid-template-columns: max-content max-content; gap: 12px 38px; margin: 34px 0 62px; padding: 0; list-style: none; color: #c7c7c7; font-size: 18px; font-weight: 700; font-family: "Gilroy-Bold";}
.service-copy .ul p::before { content: ""; margin-right: 10px; color: var(--orange); font-size: 10px; width: 12px;height: 12px;background: url(//wm.cdn.cn86.cn/suzhoucanpukeji/2026/06/f35f67a3bauhqgvu.png) no-repeat center; display: inline-block;}
.service-copy .ul p { transition: color .35s var(--ease-out), transform .35s var(--ease-out); }
.service-copy .ul p:hover { color: #fff; transform: translateX(3px); }
.service-copy .button { min-width: 166px; min-height: 50px; border-radius: 28px; font-weight: 400; }
.service-images { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); grid-template-rows: repeat(2, minmax(0, 1fr)); min-width: 0; min-height: 0; overflow: hidden; }
.service-images img { width: 100%; height: 100%; min-width: 0; min-height: 0; object-fit: cover; transition: transform .75s var(--ease-out), filter .75s var(--ease-out); }
.service-images img:hover { transform: scale(1.025); filter: saturate(1.04) contrast(1.015); }

.news-grid { display: grid; grid-template-columns: 1fr 1fr 1.05fr; gap: 34px; }
.news-card, .news-list article { overflow: hidden; border-radius: 8px; background: #f4f4f5; transition: transform .5s var(--ease-out), box-shadow .5s var(--ease-out), background-color .5s var(--ease-out); }
.news-card img { width: 100%; height: 265px; object-fit: cover; transition: transform .75s var(--ease-out), filter .75s var(--ease-out); }
.news-card div.txt { padding: 28px; }
.news time { color: #999daa; font-size: 13px; }
.news h3 a{ margin: 9px 0 16px; font-size: 22px; line-height: 1.22;display: block; color: #333333;font-weight: bold;font-family: "Gilroy-Bold";}
.news .pp { color: #858894; line-height: 1.4; min-height: calc(1.4em * 2); }
.news-card a { color: var(--purple); font-weight: 700; transition: color .35s var(--ease-out); }
.news-card:hover, .news-list article:hover { background: #fff; box-shadow: 0 18px 42px rgba(31,20,80,.12); transform: translateY(-4px); }
.news-card:hover img { transform: scale(1.025); filter: saturate(1.04); }
.news-card a:hover, .news-card a:focus-visible { color: var(--orange); }
.news-list { display: grid; gap: 30px; }
.news-list article { padding: 32px; }
.news-list article:hover h3 a{color: var(--orange);}


.contact-strip { padding: 58px 0; color: #fff; background: var(--purple); }
.contact-layout { display: grid; grid-template-columns: 280px 1fr; gap: 60px; align-items: center; }
.contact-layout h2 { margin: 0; font-size: 44px; font-family: "Gilroy-Bold";}
.contact-form { position: relative; display: grid; grid-template-columns: 1fr 1fr 1fr 1.35fr 150px; gap: 18px; }
.contact-form label, .contact-form input, .contact-form textarea { width: 100%; }
.contact-form input,.contact-form textarea { height: 60px; padding: 0 20px; border: 2px solid transparent; border-radius: 4px; outline: none; transition: border-color .35s var(--ease-out), box-shadow .35s var(--ease-out), background-color .35s var(--ease-out);background: #fff; }
.contact-form textarea{padding-top: 14px;}
.contact-form input:focus,.contact-form textarea:focus { border-color: var(--orange); }
.contact-form input.invalid,.contact-form textarea.invalid { border-color: #e55050; }
.contact-form button { height: 60px; border: 0; border-radius: 4px; color: #fff; background: var(--orange); font-size: 26px; transition: background-color .4s var(--ease-out), transform .4s var(--ease-out), box-shadow .4s var(--ease-out); display: flex;align-items: center;justify-content: center;}
.contact-form button:hover, .contact-form button:focus-visible { background: #d87f28; box-shadow: 0 10px 24px rgba(0,0,0,.16); transform: translateY(-2px); }
.contact-form.form-submit .form-input.captcha img{top: 10px;}


.form-status { position: absolute; top: calc(100% + 5px); left: 0; margin: 0; font-size: 13px; }
.site-footer { background: #29166f; }
.footer-grid { display: grid; grid-template-columns: 1.1fr .75fr 1.15fr .75fr 1.25fr; gap: 40px; padding-top: 70px; padding-bottom: 70px;background: #fff; }
    
.footer-top{   z-index: 1;margin-bottom: -90px;position: relative;}
.footer-top::before {
  content: "";
  position: absolute;
  width: 50%;
  top: 0;
  bottom: 0;
  background-color: #FFFFFF;
  z-index: -1;
}

.footer-grid h3 { margin: 0 0 20px; font-size: 20px; color: #000; font-weight: bold; font-family: "Gilroy-Bold";}
.footer-grid a, .footer-grid p { display: block; margin: 0 0 10px; color: #666666; font-size: 16px; }

.footer-grid .lxxx .ppp p{display: flex;align-items: flex-start;}
.footer-grid .lxxx .ppp p img{margin-right: 10px;margin-top: 5px;}

.footer-grid a { transition: color .35s var(--ease-out), transform .35s var(--ease-out); }
.footer-grid a:hover { color: var(--purple); transform: translateX(2px); }
.footer-brand { display: flex; flex-direction: column; align-items: flex-start; gap: 45px; }
.wechat-qr { width: 130px; height: 130px; }
.copyright { padding: 28px 24px; text-align: center; color: #a8a8ad; background: #333; font-size: 16px;padding-top: 110px; }
.contact-rail { position: fixed; z-index: 50; right: 8px; top: 52%; width: 72px; border-radius: 4px; overflow: hidden; color: #fff; background: var(--purple); box-shadow: var(--shadow); transform: translateY(-50%); }
.contact-rail a, .contact-rail button { display: grid; width: 100%; min-height: 68px; place-items: center; padding: 8px 4px; border: 0; border-bottom: 1px solid rgba(255,255,255,.18); color: inherit; background: transparent; font-size: 11px; transition: background-color .4s var(--ease-out), color .4s var(--ease-out); }
.contact-rail span { display: block; font-size: 20px; line-height: 1; }
.contact-rail a:hover, .contact-rail button:hover { background: var(--orange); }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }

/* Large laptops and smaller desktop screens */
@media (max-width: 1500px) and (min-width: 1181px) {
  .container { width: min(calc(100% - 56px), 1320px); }
  .section { padding-block: clamp(76px, 6.5vw, 96px); }
  .primary-menu a { min-width: 112px; padding-inline: 20px; font-size: 16px; }
  .topbar-contact { gap: clamp(24px, 3vw, 48px); }
  .hero { height: clamp(650px, 48vw, 760px); }
  .hero-content { padding-top: clamp(105px, 8vw, 135px); }
  .hero-points { margin-bottom: 38px; gap: 4px 36px; }
  .about-cards, .news-grid { gap: 26px; }
  .factory-copy { padding-top: 3.4vw; }
  .factory-copy-inner { max-width: 420px; }
  .factory-copy h2 { margin-bottom: 10px; font-size: clamp(32px, 2.45vw, 40px); }
  .factory-title-line { height: 4px; margin-bottom: 18px; }
  .factory-copy .ul { margin-bottom: 18px; }
  .factory-copy .ul p { min-height: 36px; padding: 8px 0 7px 20px; font-size: clamp(12px, .9vw, 14px); }
  .factory-copy .button, .service-copy .button { min-width: 140px; min-height: 42px; }
  .factory-nav-rail { width: 100%; height: 65px; }
  .service-copy { padding: 7.5% 6% 5% 18%; }
  .service-copy h2 { margin-bottom: 14px; font-size: clamp(34px, 2.6vw, 42px); }
  .service-copy .pp { font-size: clamp(14px, 1vw, 16px); line-height: 1.45; }
  .service-copy .ul { gap: 8px 20px; margin: 26px 0 30px; font-size: clamp(13px, 1vw, 15px); }
  .product-grid { gap: 28px; }
  .footer-grid { gap: 28px; }
}

/* Tablets in landscape and compact laptops */
@media (max-width: 1180px) {
  .container { width: min(calc(100% - 40px), var(--container)); }
  .section { padding-block: clamp(68px, 8vw, 88px); }
  .topbar-contact a:first-child { display: none; }
  .topbar-contact { gap: 24px; }
  .primary-menu a { min-width: auto; padding-inline: 16px; font-size: 15px; }
  .nav-tools { gap: 14px; }
  .language-button { min-width: 90px; }
  .megamenu { left: -180px; width: min(760px, calc(100vw - 30px)); }
  .hero { height: clamp(620px, 66vw, 720px); }
  .hero-content { padding-top: clamp(90px, 10vw, 120px); }
  .hero-content h1, .hero-content h2 { font-size: clamp(40px, 5.1vw, 56px); }
  .hero-content .p { font-size: clamp(16px, 1.8vw, 18px); }
  .hero-points { margin-bottom: 38px; gap: 4px 30px; }
  .section-heading { margin-bottom: clamp(44px, 5vw, 58px); }
  .section-heading h2 { font-size: clamp(32px, 4vw, 44px); }
  .section-heading .pp, .equipment-copy .pp, .cta-banner p { font-size: 16px; }
  .about-cards { gap: 24px; }
  .about-card > div { right: 5%; left: 5%; padding: 22px; }
  .about-card h3 { font-size: 21px; }
  .factory-copy { padding-top: 3vw; }
  .factory-copy-inner { max-width: 350px; }
  .factory-copy h2 { font-size: clamp(29px, 3vw, 35px); }
  .factory-title-line { height: 4px; margin-bottom: 16px; }
  .factory-copy .ul { margin-bottom: 16px; }
  .factory-copy .ul p { min-height: 34px; padding: 7px 0 6px 19px; font-size: 12px; }
  .factory-copy .button { min-width: 132px; min-height: 40px; }
  .factory-nav-rail { width: 100%; height: 62px; }
  .product-grid { grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .equipment-copy { padding: clamp(48px, 6vw, 76px); }
  .service-copy { padding: 7% 5% 5% 10%; }
  .service-copy h2 { margin-bottom: 14px; font-size: clamp(32px, 3.4vw, 38px); }
  .service-copy .pp { font-size: 14px; }
  .service-copy .ul { gap: 8px 16px; margin: 22px 0 26px; font-size: 12px; }
  .service-copy .button { min-width: 140px; min-height: 42px; }
  .news-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  .news-list { grid-column: 1 / -1; grid-template-columns: 1fr 1fr; gap: 24px; }
  .contact-layout { grid-template-columns: 1fr; gap: 24px; }
  .contact-layout h2 { font-size: clamp(34px, 4vw, 42px); }
  .contact-form { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .contact-form .message-field { grid-column: auto; }
  .footer-grid { grid-template-columns: repeat(3, 1fr); gap: 32px; }
}

/* Tablets, foldables and mobile navigation */
@media (max-width: 900px) {
  body { line-height: 1.55; }
  .site-header { top: -74px; }
  .topbar { min-height: 74px; }
  .brand img { width: clamp(145px, 22vw, 165px); }
  .topbar-contact { display: none; }
  .menu-toggle { display: block; }
  .nav-inner { min-height: 58px; align-items: center; }
  .primary-menu { position: fixed; inset: var(--menu-top, 132px) 0 0; z-index: 20; display: block; padding: 20px clamp(16px, 4vw, 28px) 40px; overflow-y: auto; overscroll-behavior: contain; background: var(--purple-dark); transform: translateX(-100%); transition: transform .3s ease; }
  .menu-open .primary-menu { transform: none; }
  .primary-menu > li { display: block; }
  .primary-menu a { height: auto; padding: 14px 12px; justify-content: start; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.12); font-size: 16px; }
  .primary-menu li + li a::before { display: none; }
  .submenu-toggle { top: 5px; right: 4px; width: 44px; height: 44px; transform: none; }
  .submenu-toggle::after { top: 15px; left: 17px; width: 8px; height: 8px; }
  .submenu { position: static; display: none; min-width: 0; padding: 0 0 8px 14px; border-bottom: 0; color: #fff; background: rgba(255,255,255,.04); box-shadow: none; opacity: 1; visibility: visible; pointer-events: auto; transform: none; transition: none; }
  .has-submenu:hover > .submenu, .has-submenu:focus-within > .submenu { display: none; }
  .has-submenu.open > .submenu, .has-submenu.open > .megamenu { display: block; }
  .submenu a { padding-block: 11px; color: rgba(255,255,255,.78); font-size: 14px; line-height: 1.4; white-space: normal; }
  .submenu a:hover, .submenu a:focus-visible { padding-left: 12px; color: #fff; background: rgba(255,255,255,.08); }
  .megamenu { width: auto; padding: 12px 16px; }
  .megamenu > div + div { margin-top: 14px; }
  .megamenu strong { min-height: 0; margin-bottom: 3px; color: var(--orange); }
  .language-menu { position: fixed; top: var(--menu-top, 132px); right: 16px; }
  .search-panel { right: 20px; width: calc(100% - 40px); }
  .hero { height: clamp(590px, 84vw, 680px); }
  .hero-content { padding-top: clamp(72px, 12vw, 100px); }
  .hero-content h1, .hero-content h2 { max-width: 760px; margin-bottom: 18px; font-size: clamp(36px, 7vw, 50px); line-height: 1.12; letter-spacing: -.025em; }
  .hero-content .p { margin-bottom: 26px; font-size: clamp(15px, 2.4vw, 17px); }
  .hero-points { grid-template-columns: 1fr; gap: 2px; margin-bottom: 30px; font-size: 15px; }
  .hero-content .button { min-width: 180px; min-height: 54px; }
  .hero-pagination { bottom: 30px !important; gap: 13px; }
  .section { padding-block: clamp(58px, 9vw, 76px); }
  .section-heading { margin-bottom: clamp(36px, 6vw, 48px); }
  .section-heading h2 { margin-bottom: 14px; font-size: clamp(30px, 5.5vw, 40px); }
  .eyebrow { font-size: 14px; }
  .about { padding: 58px 0 82px; }
  .about-cards { grid-template-columns: 1fr; gap: 42px; }
  .about-card { max-width: 650px; margin-inline: auto; }
  .about-card:hover { transform: translateY(-10px); }
  .mould-showcase { aspect-ratio: auto; height: clamp(400px, 62vw, 500px); }
  .factory { grid-template-columns: 1fr; aspect-ratio: auto; }
  .factory-copy { min-height: 0; padding: 0; }
  .factory-copy-inner { position: relative; inset: auto; max-width: none; padding: clamp(54px, 9vw, 72px) clamp(24px, 8vw, 64px) 46px; margin: 0; }
  .factory-copy h2 { font-size: clamp(34px, 6vw, 42px); }
  .factory-title-line { height: 5px; margin-bottom: 26px; }
  .factory-copy .ul { margin-bottom: 30px; }
  .factory-copy .ul p { min-height: 44px; padding: 12px 0 10px 24px; font-size: 14px; white-space: normal; }
  .factory-copy .button { min-width: 156px; min-height: 48px; }
  .factory-nav-rail { width: 100%; height: 66px; }
  .machine-gallery { min-height: clamp(420px, 66vw, 520px); }
  .machine-swiper { top: 44px; right: 20px; bottom: 100px; left: 20px; height: auto; }
  .machine-pagination { bottom: 0px !important; position: relative;margin-top: 30px;}
  .products { margin-top: 0; padding-top: clamp(58px, 9vw, 76px); }
  .product-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; }
  .equipment-feature, .services { grid-template-columns: 1fr; }
  .equipment-feature > img { height: clamp(360px, 62vw, 500px); }
  .equipment-copy { padding: clamp(52px, 9vw, 76px) clamp(24px, 8vw, 64px); }
  .equipment-copy h2 { margin-bottom: 22px; font-size: clamp(34px, 6vw, 42px); }
  .equipment-copy .pp { margin-bottom: 34px; }
  .services { aspect-ratio: auto; overflow: visible; }
  .service-copy { min-height: 0; padding: clamp(54px, 9vw, 72px) clamp(24px, 8vw, 64px); }
  .service-copy h2 { font-size: clamp(34px, 6vw, 42px); }
  .service-copy .pp { font-size: 16px; }
  .service-copy .ul { grid-template-columns: 1fr 1fr; gap: 10px 20px; margin: 34px 0; font-size: 14px; }
  .service-images img { min-height: 220px; }
  .cta-banner { min-height: 320px; }
  .cta-banner h2 { font-size: clamp(30px, 5.5vw, 42px); }
  .news h3 a { font-size: 20px; }
  .news-card div.txt, .news-list article { padding: 24px; }
  .contact-strip { padding-block: 48px; }
  .contact-form { grid-template-columns: 1fr 1fr; gap: 14px; }
  .contact-form input, .contact-form textarea, .contact-form button { height: 56px; }
  .footer-grid { grid-template-columns: 1fr 1fr; padding-block: 58px; }
  .footer-top { margin-bottom: -70px; }
  .copyright { padding-top: 90px; font-size: 14px; }
  .contact-rail { display: none; }
}

/* Phones */
@media (max-width: 620px) {
  .site-footer{margin-bottom: 70px;}
  .container { width: min(calc(100% - 32px), var(--container)); }
  .site-header { top: -68px; }
  .topbar { min-height: 68px; }
  .brand img { width: 142px; }
  .nav-inner { min-height: 54px; }
  .nav-tools { gap: 6px; }
  .icon-button { font-size: 30px; }
  .language-button { min-width: 78px; height: 54px; padding-inline: 4px; font-size: 12px; }
  .menu-toggle { width: 44px; padding: 10px; }
  .primary-menu { inset-block-start: var(--menu-top, 122px); padding-top: 14px; }
  .language-menu { top: var(--menu-top, 122px); }
  .search-panel { right: 16px; width: calc(100% - 32px); padding: 10px; }
  .search-panel input { padding: 10px; }
  .search-panel button { padding-inline: 14px; }
  .hero { height: clamp(560px, 150vw, 650px); }
  .hero-content { padding-top: clamp(64px, 17vw, 82px); }
  .hero-content h1, .hero-content h2 { margin-bottom: 16px; font-size: clamp(31px, 9vw, 38px); line-height: 1.13; letter-spacing: -.02em; }
  .hero-content .p { margin-bottom: 22px; font-size: 15px; line-height: 1.55; }
  .hero-points { margin-bottom: 26px; font-size: 14px; line-height: 1.45; }
  .hero-points p { margin-block: 5px; }
  .hero-content .button { min-width: 165px; min-height: 50px; padding-inline: 22px; }
  .hero-pagination { bottom: 22px !important; }
  .section { padding-block: clamp(50px, 14vw, 64px); }
  .section-heading { margin-bottom: 34px; }
  .section-heading h2 { font-size: clamp(28px, 8vw, 34px); line-height: 1.18; }
  .section-heading .pp, .equipment-copy .pp, .cta-banner p { font-size: 15px; line-height: 1.55; }
  .about { padding: 50px 0 72px; }
  .about-cards { gap: 36px; }
  .about-card { padding-bottom: 98px; }
  .about-card img { height: clamp(210px, 62vw, 260px); }
  .about-card > div { right: 4%; left: 4%; min-height: 148px; padding: 20px; }
  .about-card h3 { font-size: 20px; }
  .about-card p { font-size: 14px; }
  .mould-showcase { height: clamp(340px, 105vw, 420px); }
  .hotspot { width: 28px; height: 28px; border-width: 5px; }
  .hotspot-label { max-width: calc(100% - 32px); min-height: 42px; padding: 10px 15px; font-size: 13px; white-space: normal; }
  .factory-copy-inner { padding: 50px 20px 42px; }
  .factory-copy h2, .service-copy h2, .equipment-copy h2 { font-size: clamp(30px, 8vw, 36px); }
  .factory-copy .ul p { font-size: 13px; }
  .machine-gallery { min-height: clamp(360px, 112vw, 430px); min-height: 100%;padding: 30px 20px;}
  .machine-swiper { top: 0; right: 0; bottom: 0; left: 0; position: relative;}
  .machine-pagination { bottom: 0 !important; gap: 14px; }
  .product-grid { grid-template-columns: 1fr; gap: 22px; }
  .product-card { width: min(100%, 400px); margin-inline: auto; }
  .product-overlay { min-height: 88px; padding-top: 42px; }
  .product-overlay a { width: 60px; height: 60px; }
  .equipment-feature > img { height: clamp(300px, 96vw, 400px); }
  .equipment-copy, .service-copy { padding: 50px 20px; }
  .service-copy .ul { grid-template-columns: 1fr; gap: 8px; margin: 28px 0 34px; }
  .service-images { grid-template-columns: 1fr; }
  .service-images img { min-height: 210px; max-height: 300px; }
  .cta-banner { min-height: 340px; }
  .cta-main-image { right: 0; }
  .cta-banner > img { display: none; }
  .cta-banner h2 { font-size: clamp(28px, 8vw, 36px); line-height: 1.18; }
  .news-grid, .news-list { grid-template-columns: 1fr; }
  .news-card img { height: clamp(210px, 64vw, 265px); }
  .news-card div.txt, .news-list article { padding: 20px; }
  .news h3 a { margin-bottom: 12px; font-size: 19px; }
  .contact-layout h2 { font-size: clamp(30px, 9vw, 38px); }
  .contact-form { grid-template-columns: 1fr; }
  .contact-form .message-field { grid-column: auto; }
  .contact-form button { width: 100%; font-size: 22px; }
  .footer-grid { grid-template-columns: 1fr; gap: 26px; padding-block: 48px; }
  .footer-grid h3 { margin-bottom: 14px; font-size: 18px; }
  .footer-grid a, .footer-grid p { font-size: 14px; }
  .footer-brand { gap: 28px; }
  .footer-top { margin-bottom: -58px; }
  .copyright { padding: 76px 16px 22px; font-size: 13px; }
  .machine-pagination .swiper-pagination-bullet{width: 10px;height: 10px;}
}

/* Very small phones */
@media (max-width: 380px) {
  .container { width: calc(100% - 24px); }
  .brand img { width: 130px; }
  .language-button { min-width: 70px; }
  .language-button .language-globe { display: none; }
  .hero-content h1, .hero-content h2 { font-size: 29px; }
  .hero-content .p { font-size: 14px; }
  .section-heading h2 { font-size: 27px; }
  .button { padding-inline: 20px; }
  .about-card > div { right: 2%; left: 2%; padding: 18px; }
  .factory-copy-inner, .equipment-copy, .service-copy { padding-inline: 16px; }
}

/* Short landscape phones */
@media (max-width: 900px) and (max-height: 520px) and (orientation: landscape) {
  .site-header { position: relative; top: 0; }
  .primary-menu { inset-block-start: 112px; }
  .hero { height: auto; min-height: 520px; }
  .hero-content { padding-block: 54px 80px; }
  .hero-content h1, .hero-content h2 { font-size: clamp(30px, 5vw, 40px); }
  .hero-points { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-pagination { bottom: 18px !important; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
