:root{
  --black:#10100f;
  --ink:#171715;
  --white:#ffffff;
  --stone:#f5f4ef;
  --warm:#ebe7dd;
  --hover-gray:#f7f7f5;
  --nav-hover:#fbfbfa;
  --guide-gray:#fafafa;
  --line-soft:rgba(16,16,15,.12);
  --line-strong:rgba(16,16,15,.22);
  --text:#111111;
  --muted:#57544e;
  --line:rgba(0,0,0,.14);
  --max:1480px;
  --ease:cubic-bezier(.22,1,.36,1);
  --type-hero:78px;
  --type-feature:52px;
  --type-section:46px;
  --type-card:26px;
  --measure-hero:980px;
  --measure-feature:820px;
  --measure-section:940px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"OPPO Sans",Inter,"Helvetica Neue",Arial,sans-serif;
  color:var(--text);
  background:var(--stone);
  line-height:1.68;
  letter-spacing:0;
  text-rendering:optimizeLegibility;
}
img{display:block;width:100%;height:auto}
a{color:inherit;text-decoration:none}
.wrap{width:min(var(--max),calc(100% - 64px));margin:0 auto}
h1,h2,h3{
  letter-spacing:0;
  text-wrap:balance;
  font-weight:520;
  color:var(--ink);
}
h1,h2{
  font-weight:590;
}
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.94);
  border-bottom:1px solid rgba(11,11,11,.1);
  backdrop-filter:blur(18px);
}
.header-inner{
  min-height:80px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:38px;
  align-items:center;
}
.brand img{width:158px}
.main-nav{
  display:flex;
  justify-content:center;
  gap:40px;
  flex-wrap:wrap;
  color:var(--black);
  font-size:14px;
  font-weight:540;
  letter-spacing:.018em;
}
.main-nav > a,
.nav-item > a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:38px;
  position:relative;
  color:#2b2a27;
  transition:color .24s var(--ease), transform .24s var(--ease);
}
.main-nav > a::before,
.nav-item > a::before{
  content:"";
  position:absolute;
  left:50%;
  bottom:3px;
  width:18px;
  height:1px;
  background:rgba(16,16,15,.34);
  transform:translateX(-50%) scaleX(0);
  transform-origin:center;
  transition:transform .3s var(--ease), width .3s var(--ease), background-color .3s var(--ease);
}
.main-nav > a:hover,
.main-nav > a:focus-visible,
.nav-item > a:hover,
.nav-item > a:focus-visible{
  color:#000;
  transform:translateY(-1px);
}
.main-nav > a:hover::before,
.main-nav > a:focus-visible::before,
.nav-item > a:hover::before,
.nav-item > a:focus-visible::before{
  width:22px;
  transform:translateX(-50%) scaleX(1);
  background:rgba(16,16,15,.28);
}
.main-nav > a[aria-current="page"]::before,
.nav-item > a[aria-current="page"]::before,
.has-mega:hover > a::before,
.has-mega:focus-within > a::before{
  width:24px;
  transform:translateX(-50%) scaleX(1);
  background:rgba(16,16,15,.46);
}
.main-nav > a[aria-current="page"],
.nav-item > a[aria-current="page"],
.has-mega:hover > a,
.has-mega:focus-within > a{
  color:#000;
}
.main-nav > a.has-submenu::after,
.nav-item > a.has-submenu::after{
  content:"";
  width:6px;
  height:6px;
  border-right:1.4px solid currentColor;
  border-bottom:1.4px solid currentColor;
  transform:rotate(45deg) translateY(-1px);
  opacity:.8;
}
.nav-item{
  display:flex;
  align-items:center;
  min-height:80px;
}
.mega-menu{
  position:absolute;
  left:0;
  right:0;
  top:100%;
  background:#fff;
  border-top:1px solid rgba(16,16,15,.045);
  border-bottom:1px solid rgba(16,16,15,.09);
  box-shadow:0 24px 48px rgba(16,16,15,.08);
  overflow-x:hidden;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(-8px);
  transition:opacity .26s var(--ease), transform .26s var(--ease), visibility 0s linear .26s;
}
.has-mega:hover .mega-menu,
.has-mega:focus-within .mega-menu{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0);
  transition:opacity .26s var(--ease), transform .26s var(--ease), visibility 0s;
}
.has-mega:hover > a,
.has-mega:focus-within > a{
  color:#000;
}
.mega-inner{
  display:grid;
  width:min(1120px,calc(100% - 80px));
  grid-template-columns:minmax(220px,.92fr) minmax(280px,1.05fr) minmax(320px,.98fr);
  gap:52px;
  padding:40px 0 44px;
  align-items:start;
}
.mega-column h3{
  margin:0 0 22px;
  color:var(--black);
  font-size:21px;
  line-height:1.15;
  font-weight:590;
  letter-spacing:0;
}
.mega-column a{
  display:flex;
  align-items:center;
  width:100%;
  min-height:36px;
  padding:7px 0 8px;
  color:#6c6962;
  font-size:14px;
  line-height:1.28;
  font-weight:540;
  letter-spacing:.018em;
  position:relative;
  transition:padding-left .24s var(--ease), color .24s var(--ease), background-color .24s var(--ease);
}
.mega-column a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width:60%;
  height:1px;
  background:rgba(16,16,15,.028);
}
.mega-column a:hover{
  padding-left:6px;
  background:var(--nav-hover);
  color:#24231f;
}
.mega-column a.mega-link-cta{
  color:#2b2a26;
}
.mega-column a.mega-link-cta::before{
  content:"";
  position:absolute;
  right:38%;
  width:7px;
  height:7px;
  border-right:1.3px solid currentColor;
  border-top:1.3px solid currentColor;
  transform:rotate(45deg);
  opacity:.72;
  transition:transform .24s var(--ease), opacity .24s var(--ease);
}
.mega-column a.mega-link-cta:hover::before{
  transform:translateX(3px) rotate(45deg);
  opacity:1;
}
.main-nav .mega-feature{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:0;
  padding:18px 18px 17px;
  border-left:1px solid rgba(16,16,15,.07);
  background:#fbfbfa;
  color:var(--black);
  min-width:0;
  max-width:100%;
  transition:background-color .24s var(--ease), transform .24s var(--ease);
}
.main-nav .mega-feature:hover{
  background:#f8f8f6;
  transform:translateY(-1px);
}
.main-nav .mega-feature.product-guide-card{
  justify-content:start;
  padding:0;
  border-left:0;
  background:transparent;
  transform:none;
}
.main-nav .mega-feature.product-guide-card:hover{
  background:transparent;
  transform:none;
}
.main-nav .mega-feature.product-guide-card img{
  max-height:224px;
  aspect-ratio:1.56;
  object-fit:contain;
  object-position:left center;
  background:transparent;
}
.main-nav .mega-feature.product-guide-card strong{
  max-width:260px;
  margin-top:16px;
  font-size:18px;
  line-height:1.18;
}
.main-nav .mega-feature.product-guide-card b{
  margin-top:13px;
  font-size:13px;
  font-weight:500;
  color:#5d5b56;
  border-bottom:0;
  padding-bottom:0;
  align-items:center;
  gap:8px;
}
.main-nav .mega-feature.product-guide-card b::after{
  content:"";
  width:7px;
  height:7px;
  border-right:1.2px solid currentColor;
  border-top:1.2px solid currentColor;
  transform:rotate(45deg);
  opacity:.78;
  transition:transform .24s var(--ease), opacity .24s var(--ease);
}
.main-nav .mega-feature.product-guide-card:hover b::after{
  transform:translateX(3px) rotate(45deg);
  opacity:1;
}
.main-nav .mega-feature.resource-guide-card img{
  max-height:172px;
  aspect-ratio:1.65;
  object-fit:contain;
  object-position:left center;
}
.main-nav .mega-feature.resource-guide-card strong{
  max-width:100%;
  white-space:nowrap;
}
.main-nav .mega-feature.solution-guide-card img{
  max-height:172px;
  aspect-ratio:1.65;
  object-fit:contain;
  object-position:left center;
}
.main-nav .mega-feature span{
  display:block;
  margin-bottom:13px;
  color:#8e8b84;
  font-size:11px;
  line-height:1;
  font-weight:560;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.main-nav .mega-feature img{
  width:100%;
  max-height:154px;
  aspect-ratio:1.9;
  object-fit:cover;
  background:#f3f2ee;
}
.main-nav .mega-feature.text-only{
  min-height:100%;
  justify-content:center;
  padding:26px 24px 24px;
  border-left:1px solid rgba(16,16,15,.07);
  background:linear-gradient(180deg,#fbfbfa 0%,#f7f7f5 100%);
}
.main-nav .mega-feature.text-only span{
  margin-bottom:18px;
}
.main-nav .mega-feature.text-only strong{
  max-width:310px;
  margin-top:0;
  font-size:20px;
  line-height:1.28;
}
.main-nav .mega-feature.text-only em{
  max-width:320px;
  margin-top:13px;
}
.main-nav .mega-feature strong{
  display:block;
  max-width:290px;
  margin-top:16px;
  color:var(--black);
  font-size:18px;
  line-height:1.22;
  font-weight:590;
  letter-spacing:0;
  text-wrap:balance;
}
.main-nav .mega-feature em{
  display:block;
  max-width:292px;
  margin-top:9px;
  color:#716e66;
  font-size:13px;
  line-height:1.45;
  font-style:normal;
  font-weight:430;
  letter-spacing:.02em;
}
.main-nav .mega-feature small{
  display:inline-flex;
  width:max-content;
  margin-top:12px;
  padding-top:7px;
  border-top:1px solid rgba(16,16,15,.07);
  color:#6c6962;
  font-size:12px;
  line-height:1;
  font-weight:540;
  letter-spacing:.045em;
}
.main-nav .mega-feature small + small{
  margin-top:8px;
}
.main-nav .mega-feature b{
  display:inline-flex;
  width:max-content;
  margin-top:18px;
  color:#191917;
  font-size:13px;
  line-height:1;
  font-weight:620;
  letter-spacing:.02em;
  border-bottom:1px solid rgba(16,16,15,.38);
  padding-bottom:4px;
}
.header-actions{display:flex;align-items:center;gap:14px}
.header-actions .btn{
  min-height:48px;
  padding:0 21px;
  font-size:13px;
  letter-spacing:0;
}
.link-action,.text-link,.section-link{
  color:inherit;
  font-size:13px;
  font-weight:700;
}
.section-link{border-bottom:1px solid currentColor;padding-bottom:3px}
.section-link.light{color:var(--white)}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:0 22px;
  border:1px solid var(--line-strong);
  border-radius:3px;
  font-size:13px;
  font-weight:620;
  letter-spacing:.02em;
  white-space:nowrap;
  transition:transform .28s var(--ease), background-color .28s var(--ease), border-color .28s var(--ease), color .28s var(--ease);
}
.btn:hover{transform:translateY(-1px)}
.btn-dark{background:var(--ink);color:var(--white);border-color:var(--ink)}
.btn-outline-dark{background:transparent;color:var(--ink);border-color:rgba(16,16,15,.36)}
.btn-light{background:var(--white);color:var(--black);border-color:var(--white)}
.btn-outline-light{background:rgba(255,255,255,.06);color:var(--white);border-color:rgba(255,255,255,.42)}
.btn-dark:hover{background:#000;border-color:#000}
.btn-outline-dark:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-menu-light{
  background:#fff;
  color:var(--black);
  border-color:var(--black);
}
.mobile-menu-panel .btn-dark{
  background:var(--black);
  color:var(--white);
  border-color:var(--black);
}
.mobile-menu{display:none}
.mobile-menu > summary{
  list-style:none;
  width:44px;
  height:44px;
  border:1px solid rgba(0,0,0,.16);
  border-radius:5px;
  position:relative;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:border-color .35s cubic-bezier(.22,1,.36,1), background-color .35s cubic-bezier(.22,1,.36,1), transform .35s cubic-bezier(.22,1,.36,1);
}
.mobile-menu > summary::-webkit-details-marker{display:none}
.mobile-menu > summary span,
.mobile-menu > summary::before,
.mobile-menu > summary::after{
  content:"";
  position:absolute;
  left:12px;
  right:12px;
  height:2px;
  background:var(--black);
  border-radius:999px;
  transition:transform .42s cubic-bezier(.22,1,.36,1), top .42s cubic-bezier(.22,1,.36,1), bottom .42s cubic-bezier(.22,1,.36,1), opacity .28s ease;
}
.mobile-menu > summary span{
  top:20px;
}
.mobile-menu > summary::before{top:15px}
.mobile-menu > summary::after{bottom:15px}
.mobile-menu.is-open > summary::before{
  top:20px;
  transform:rotate(45deg);
}
.mobile-menu.is-open > summary::after{
  bottom:auto;
  top:20px;
  transform:rotate(-45deg);
}
.mobile-menu.is-open > summary span{
  opacity:0;
  transform:scaleX(.45);
}
.mobile-menu.is-open > summary{
  border-color:rgba(0,0,0,.22);
  background:rgba(0,0,0,.01);
}
.mobile-menu-panel{
  position:fixed;
  left:50%;
  top:76px;
  transform:translateX(-50%);
  width:calc(100vw - 32px);
  max-width:520px;
  max-height:calc(100svh - 104px);
  padding:16px;
  border:1px solid rgba(0,0,0,.14);
  border-radius:6px;
  background:#fff;
  box-shadow:0 22px 52px rgba(0,0,0,.14);
  display:grid;
  gap:6px;
  overflow-y:auto;
  overscroll-behavior:contain;
  z-index:60;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateX(-50%) translateY(-8px) scale(.982);
  transition:opacity .32s cubic-bezier(.22,1,.36,1), transform .32s cubic-bezier(.22,1,.36,1), visibility 0s linear .32s;
}
.mobile-menu.is-open .mobile-menu-panel{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateX(-50%) translateY(0) scale(1);
  transition:opacity .32s cubic-bezier(.22,1,.36,1), transform .32s cubic-bezier(.22,1,.36,1), visibility 0s;
}
.mobile-menu-panel > a{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:16px;
  font-weight:500;
  color:var(--black);
  padding:10px 4px;
  opacity:0;
  transform:translateY(-5px);
  transition:opacity .24s ease, transform .24s ease;
}
.mobile-nav-group{
  opacity:0;
  transform:translateY(-5px);
  border-bottom:1px solid rgba(16,16,15,.08);
  transition:opacity .24s ease, transform .24s ease;
}
.mobile-nav-group > summary{
  list-style:none;
  min-height:44px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:10px 4px;
  color:var(--black);
  font-size:16px;
  font-weight:540;
  cursor:pointer;
}
.mobile-nav-group > summary::-webkit-details-marker{display:none}
.mobile-nav-group > summary::after{
  content:"";
  width:6px;
  height:6px;
  border-right:1.4px solid currentColor;
  border-bottom:1.4px solid currentColor;
  transform:rotate(45deg) translateY(-1px);
  opacity:.68;
  transition:transform .28s var(--ease), opacity .28s var(--ease);
}
.mobile-nav-group[open] > summary::after{
  transform:rotate(225deg) translate(-1px,-1px);
  opacity:1;
}
.mobile-submenu{
  display:grid;
  gap:8px;
  padding:6px 0 18px 16px;
  animation:mobilePanelReveal .32s var(--ease) both;
}
.mobile-menu-block{
  display:block;
  margin-left:2px;
  border-left:1px solid rgba(16,16,15,.09);
}
.mobile-menu-block > summary{
  list-style:none;
  min-height:36px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 0 8px 16px;
  color:#1f1e1a;
  font-size:16px;
  font-weight:500;
  line-height:1.25;
  cursor:pointer;
}
.mobile-menu-block > summary::-webkit-details-marker{display:none}
.mobile-menu-block > summary::before{
  content:"";
  width:5px;
  height:5px;
  border-right:1.3px solid currentColor;
  border-bottom:1.3px solid currentColor;
  transform:rotate(-45deg);
  opacity:.62;
  transition:transform .28s var(--ease), opacity .28s var(--ease);
}
.mobile-menu-block[open] > summary::before{
  transform:rotate(45deg) translateY(-1px);
  opacity:1;
}
.mobile-menu-block > div{
  display:grid;
  padding:2px 0 10px 24px;
  animation:mobilePanelReveal .3s var(--ease) both;
}
.mobile-menu-panel .mobile-menu-block a,
.mobile-menu-panel .mobile-menu-cta{
  display:flex;
  align-items:center;
  gap:8px;
  min-height:32px;
  padding:6px 0 6px 10px;
  color:#68645b;
  font-size:13px;
  line-height:1.28;
  font-weight:500;
  letter-spacing:.006em;
  border-bottom:1px solid rgba(16,16,15,.04);
  opacity:1;
  transform:none;
}
.mobile-menu-panel .mobile-menu-cta{
  color:var(--black);
  font-weight:590;
  padding-left:14px;
}
.mobile-menu-panel .mobile-menu-cta::after{
  content:"";
  width:6px;
  height:6px;
  margin-left:auto;
  border-top:1.3px solid currentColor;
  border-right:1.3px solid currentColor;
  transform:rotate(45deg);
  opacity:.72;
}
.mobile-menu.is-open .mobile-menu-panel > a,
.mobile-menu.is-open .mobile-nav-group{
  opacity:1;
  transform:translateY(0);
}
.mobile-nav-group[open] > .mobile-submenu{
  animation:mobilePanelReveal .34s var(--ease) both;
}
@keyframes mobilePanelReveal{
  from{
    opacity:.78;
    transform:translateY(-6px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}
.mobile-menu.is-open .mobile-menu-panel > a:nth-child(1){transition-delay:.03s}
.mobile-menu.is-open .mobile-menu-panel > a:nth-child(2){transition-delay:.06s}
.mobile-menu.is-open .mobile-menu-panel > a:nth-child(3){transition-delay:.09s}
.mobile-menu.is-open .mobile-menu-panel > a:nth-child(4){transition-delay:.12s}
.mobile-menu.is-open .mobile-menu-panel > a:nth-child(5){transition-delay:.15s}
.mobile-menu.is-open .mobile-menu-panel > a:nth-child(6){transition-delay:.18s}
.mobile-menu.is-open .mobile-menu-panel > a:nth-child(7){transition-delay:.21s}
.mobile-menu:not(.is-open) .mobile-menu-panel > a:nth-child(1){transition-delay:.14s}
.mobile-menu:not(.is-open) .mobile-menu-panel > a:nth-child(2){transition-delay:.11s}
.mobile-menu:not(.is-open) .mobile-menu-panel > a:nth-child(3){transition-delay:.08s}
.mobile-menu:not(.is-open) .mobile-menu-panel > a:nth-child(4){transition-delay:.05s}
.mobile-menu:not(.is-open) .mobile-menu-panel > a:nth-child(5){transition-delay:.02s}
.mobile-menu:not(.is-open) .mobile-menu-panel > a:nth-child(6){transition-delay:0s}
.mobile-menu:not(.is-open) .mobile-menu-panel > a:nth-child(7){transition-delay:0s}
.mobile-menu-panel a.has-submenu::after{
  content:"";
  width:5px;
  height:5px;
  border-right:1.4px solid currentColor;
  border-bottom:1.4px solid currentColor;
  transform:rotate(45deg) translateY(-1px);
  opacity:.75;
}
.hero{
  position:relative;
  min-height:calc(100svh - 80px);
  background:#070707;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.hero-carousel-stage{
  position:relative;
  flex:1;
  width:100%;
  max-width:100vw;
  min-height:calc(100svh - 156px);
  overflow:hidden;
  background:#070707;
  cursor:grab;
  touch-action:pan-y;
  isolation:isolate;
  -webkit-user-select:none;
  user-select:none;
}
.hero-carousel-stage.is-dragging{
  cursor:grabbing;
}
.is-hero-dragging,
.is-hero-dragging *{
  -webkit-user-select:none !important;
  user-select:none !important;
}
.hero-carousel-track{
  height:100%;
  min-height:inherit;
  width:100%;
  min-width:100%;
  display:flex;
  transition:transform .78s cubic-bezier(.22,1,.36,1);
  will-change:transform;
}
.hero-slide{
  position:relative;
  flex:0 0 100%;
  width:100%;
  max-width:100%;
  min-width:100%;
  overflow:hidden;
  background:#070707;
}
.hero-media,.hero-overlay{position:absolute;inset:0}
.hero-media{
  overflow:hidden;
  background:#070707;
}
.hero-media img{
  width:100%;
  height:100%;
  min-width:100%;
  min-height:100%;
  -webkit-user-drag:none;
  object-fit:cover;
  object-position:center;
  opacity:.55;
  filter:grayscale(.05) contrast(1.08) saturate(.76);
  transform:scale(1.04);
  transition:transform 8s ease, opacity .5s ease;
}
.hero-slide.is-active .hero-media img{
  transform:scale(1);
}
.hero-overlay{
  background:
    linear-gradient(90deg,rgba(7,7,7,.96) 0%,rgba(7,7,7,.84) 42%,rgba(7,7,7,.38) 100%),
    linear-gradient(0deg,rgba(7,7,7,.88) 0%,rgba(7,7,7,.2) 42%,rgba(7,7,7,.54) 100%);
}
.hero-layout{
  position:relative;
  z-index:2;
  min-height:calc(100svh - 154px);
  display:flex;
  align-items:center;
  padding:80px 0 38px;
}
.hero-copy{
  max-width:var(--measure-hero);
}
.kicker{
  margin:0;
  color:rgba(255,255,255,.68);
  font-size:12px;
  font-weight:620;
  letter-spacing:.2em;
  text-transform:uppercase;
}
.kicker.dark{color:var(--muted)}
.hero h1{
  margin:20px 0 0;
  max-width:var(--measure-hero);
  color:var(--white);
  font-size:var(--type-hero);
  line-height:.94;
}
.hero-copy p:not(.kicker){
  max-width:720px;
  margin:30px 0 0;
  color:rgba(255,255,255,.8);
  font-size:17px;
  line-height:1.8;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-carousel-status{
  position:absolute;
  top:24px;
  right:clamp(18px,4vw,54px);
  z-index:3;
  display:flex;
  align-items:center;
  gap:9px;
  color:rgba(255,255,255,.68);
  font-size:11px;
  font-weight:620;
  letter-spacing:.18em;
  line-height:1;
  pointer-events:none;
}
.hero-status-sep{
  width:22px;
  height:1px;
  background:rgba(255,255,255,.26);
}
.hero-strip{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  margin-top:-2px;
  padding-top:2px;
  border-top:0;
  border-bottom:0;
  background:#070707;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.055);
  backdrop-filter:blur(10px);
}
.hero-strip a{
  min-height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 18px;
  color:var(--white);
  border-right:1px solid rgba(255,255,255,.12);
  font-size:14px;
  font-weight:620;
}
.hero-strip a:last-child{border-right:0}
.hero-strip a::after{content:"+";color:rgba(255,255,255,.58)}
.section,.intro{padding:116px 0}
.intro{padding-top:148px}
.band-white{background:#ffffff;color:#111}
.band-stone{background:var(--stone);color:#111}
.band-black{background:var(--black);color:var(--white)}
.product-explore{
  padding-top:104px;
  border-top:1px solid rgba(16,16,15,.08);
}
.intro-showcase,.selection-layout,.material-grid,.trust-grid,.resources-grid{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:76px;
  align-items:start;
}
.selection-layout{
  grid-template-columns:.72fr minmax(180px,.28fr) 1.28fr;
  align-items:start;
}
.section-head-side{
  display:flex;
  justify-content:flex-start;
  align-items:flex-start;
  padding-top:34px;
}
h2{
  margin:12px 0 0;
  max-width:var(--measure-section);
  color:inherit;
  font-size:var(--type-section);
  line-height:1.08;
}
.band-black h2,.final-cta h2{color:var(--white)}
.lead,.section-note{
  margin:0;
  max-width:62ch;
  color:inherit;
  opacity:.74;
  font-size:16px;
  line-height:1.8;
}
.section-head{
  display:flex;
  justify-content:space-between;
  gap:34px;
  align-items:end;
  margin-bottom:46px;
}
.section-head h2{max-width:var(--measure-section)}
.section-head > div{max-width:860px}
.section-note{max-width:380px}
.intro-showcase{align-items:center}
.intro-gallery{
  display:grid;
  grid-template-columns:1.08fr .82fr;
  grid-template-rows:224px 224px;
  gap:22px;
  align-items:center;
}
.intro-gallery figure{
  position:relative;
  margin:0;
  min-height:0;
  overflow:hidden;
  background:#ddd;
}
.intro-gallery img{
  height:100%;
  object-fit:cover;
  filter:saturate(.88) contrast(1.04);
}
.intro-gallery .gallery-tall{
  grid-row:span 2;
  height:596px;
}
.intro-gallery .gallery-wide{
  width:100%;
  justify-self:start;
  transform:translateY(22px);
}
.intro-content{
  display:grid;
  justify-items:start;
  gap:28px;
}
.intro-content h2{
  max-width:var(--measure-feature);
  font-size:var(--type-feature);
  line-height:1.04;
}
.intro-content .lead{
  max-width:68ch;
}
.intro-content > p:not(.kicker):not(.lead){
  margin:0;
  max-width:68ch;
  color:rgba(17,17,17,.72);
  font-size:16px;
  line-height:1.82;
}
.product-system{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.product-system-cta{
  display:flex;
  justify-content:flex-end;
  margin-top:22px;
}
.product-system-cta-mobile{
  display:none;
}
.family-feature{
  display:grid;
  grid-template-columns:1fr;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  transition:transform .34s var(--ease), border-color .34s var(--ease), box-shadow .34s var(--ease);
}
.family-feature img{
  height:auto;
  min-height:0;
  aspect-ratio:16/6.9;
  object-fit:cover;
  transition:transform .7s var(--ease), filter .7s var(--ease);
}
.family-feature:hover{
  transform:translateY(-3px);
  border-color:rgba(16,16,15,.28);
  box-shadow:0 22px 42px rgba(16,16,15,.08);
}
.family-feature:hover img{
  transform:scale(1.025);
  filter:saturate(.96) contrast(1.05);
}
.family-feature div{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:18px;
}
.family-feature span,.custom-main span,.resource-cards span{
  color:var(--muted);
  font-size:12px;
  font-weight:500;
  letter-spacing:.16em;
  text-transform:uppercase;
}
h3{
  margin:12px 0 0;
  color:inherit;
  font-size:var(--type-card);
  line-height:1.08;
}
.family-feature p,.custom-main p,.custom-list p,.resource-cards p{
  margin:10px 0 0;
  line-height:1.58;
  color:inherit;
}
.family-feature .text-link{margin-top:12px}
.signature-primary strong{
  display:block;
  margin-top:10px;
  color:var(--ink);
  font-size:22px;
  font-weight:590;
  line-height:1.08;
}
.signature-secondary{
  display:grid;
  grid-template-rows:1fr 1fr;
  gap:14px;
  height:100%;
}
.signature-secondary article{
  min-height:0;
  height:100%;
  display:grid;
  grid-template-columns:.92fr 1fr;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  transition:transform .34s var(--ease), border-color .34s var(--ease), box-shadow .34s var(--ease);
}
.signature-secondary img{
  height:100%;
  aspect-ratio:auto;
  object-fit:cover;
  filter:saturate(.9) contrast(1.03);
  transition:transform .7s var(--ease), filter .7s var(--ease);
}
.signature-secondary article:hover{
  transform:translateY(-3px);
  border-color:rgba(16,16,15,.28);
  box-shadow:0 18px 34px rgba(16,16,15,.07);
}
.signature-secondary article:hover img{
  transform:scale(1.03);
  filter:saturate(.98) contrast(1.06);
}
.signature-secondary div{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:17px;
}
.signature-secondary span{
  color:#a8a8a2;
  font-size:12px;
  font-weight:500;
  letter-spacing:.16em;
}
.signature-secondary strong{
  display:block;
  margin-top:10px;
  color:var(--ink);
  font-size:21px;
  font-weight:590;
  line-height:1.08;
}
.signature-secondary p{
  margin:7px 0 0;
  color:rgba(17,17,17,.72);
  font-size:14px;
  line-height:1.46;
}
.signature-secondary .text-link{
  margin-top:10px;
}
.family-list{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:12px;
  margin-top:24px;
}
.supporting-family-list{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.supporting-family-list a{
  grid-column:auto;
}
.family-list a{
  min-height:132px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:18px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  transition:transform .28s var(--ease), border-color .28s var(--ease), background-color .28s var(--ease);
}
.family-list a.has-thumb{
  min-height:190px;
  padding:0;
  overflow:hidden;
}
.family-list a.has-thumb img{
  aspect-ratio:16/8.5;
  object-fit:cover;
  filter:saturate(.9) contrast(1.03);
}
.family-list a.has-thumb strong,
.family-list a.has-thumb span{
  padding-left:16px;
  padding-right:16px;
}
.family-list a.has-thumb span{margin-top:12px}
.family-list a.has-thumb strong{padding-bottom:14px}
.family-list a:hover{border-color:rgba(16,16,15,.24);background:var(--hover-gray)}
.family-list .family-guide{
  position:relative;
  min-height:190px;
  justify-content:flex-end;
  background:var(--guide-gray);
  border-color:rgba(16,16,15,.16);
  overflow:hidden;
}
.family-list .family-guide::after{
  content:"";
  position:absolute;
  top:-34px;
  right:-34px;
  width:152px;
  height:152px;
  opacity:.72;
  background:url("./whatsapp.svg") center / contain no-repeat;
  pointer-events:none;
}
.family-list .family-guide strong,
.family-list .family-guide span{
  position:relative;
  z-index:1;
}
.family-list .family-guide strong{
  max-width:14ch;
  color:var(--ink);
  font-size:22px;
  line-height:1.08;
  letter-spacing:0;
}
.family-list .family-guide span{
  margin-top:14px;
  color:rgba(17,17,17,.68);
  line-height:1.55;
}
.family-list .family-guide:hover{
  background:var(--hover-gray);
  border-color:rgba(16,16,15,.26);
}
.family-list strong{
  color:inherit;
  font-size:15px;
  font-weight:590;
  line-height:1.18;
  letter-spacing:0;
}
.family-list span{
  font-size:12px;
  font-weight:500;
  letter-spacing:.14em;
  color:#a8a8a2;
}
.family-list .family-guide strong{
  max-width:14ch;
  color:var(--ink);
  font-size:22px;
  font-weight:590;
  line-height:1.08;
  letter-spacing:0;
}
.family-list .family-guide span{
  margin-top:14px;
  color:rgba(17,17,17,.68);
  font-size:14px;
  font-weight:400;
  letter-spacing:0;
  line-height:1.55;
}
.workflow-row,.application-notes,.faq-preview,.certificate-strip{
  display:grid;
  gap:12px;
}
.workflow-row article,
.application-notes article,
.faq-preview article{
  padding:22px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
}
.workflow-row span,
.application-notes strong,
.faq-preview strong,
.certificate-strip span{
  display:block;
  color:var(--muted);
  font-size:12px;
  font-weight:620;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.workflow-row{
  grid-template-columns:repeat(4,minmax(0,1fr));
  margin-top:24px;
}
.workflow-row article{min-height:160px}
.workflow-row strong{display:block;margin-top:12px;color:inherit;font-size:19px;text-transform:none;letter-spacing:0}
.workflow-row p,.application-notes p,.faq-preview p{margin:10px 0 0}
.path-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1px;
  border:1px solid rgba(0,0,0,.14);
  background:rgba(0,0,0,.14);
}
.path-grid article{
  min-height:196px;
  padding:24px;
  border:0;
  background:#fff;
}
.path-grid span{
  display:block;
  color:var(--black);
  font-size:12px;
  font-weight:620;
}
.path-grid strong{
  display:block;
  margin-top:24px;
  color:var(--black);
  font-size:18px;
  font-weight:560;
}
.path-grid p{margin:10px 0 0;color:var(--black);font-size:15px}
.material-grid{align-items:center}
.material-copy .btn{margin-top:26px}
.chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:30px;
}
.chip-row span{
  padding:11px 14px;
  border:1px solid rgba(0,0,0,.14);
  background:var(--stone);
  font-size:13px;
}
.material-stack{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.material-stack article{
  overflow:hidden;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
}
.material-stack img{
  aspect-ratio:4/5;
  object-fit:cover;
}
.material-stack strong,
.material-stack p{
  display:block;
  margin:0;
  padding:0 16px;
}
.material-stack strong{
  padding-top:14px;
  color:inherit;
  font-size:18px;
}
.material-stack p{
  padding-top:8px;
  padding-bottom:16px;
}
.custom-layout{
  display:grid;
  grid-template-columns:1.12fr .88fr;
  gap:24px;
}
.custom-section{
  padding:88px 0;
}
.custom-section .section-head{
  margin-bottom:34px;
}
.custom-section .section-note{
  max-width:430px;
}
.custom-main{
  overflow:hidden;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
}
.custom-main img{aspect-ratio:16/7.4;object-fit:cover}
.custom-main div{padding:24px}
.custom-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.custom-list article{
  position:relative;
  min-height:176px;
  padding:20px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  overflow:hidden;
}
.custom-list strong,
.custom-list ul{
  position:relative;
  z-index:1;
}
.custom-list strong{
  display:block;
  color:inherit;
  font-size:19px;
  line-height:1.12;
  font-weight:560;
}
.custom-list ul{
  display:grid;
  gap:7px;
  margin:16px 0 0;
  padding:0;
  list-style:none;
}
.custom-list li{
  position:relative;
  padding-left:14px;
  color:rgba(17,17,17,.72);
  font-size:14px;
  line-height:1.36;
}
.custom-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.66em;
  width:4px;
  height:4px;
  border-radius:50%;
  background:rgba(17,17,17,.38);
}
.custom-pattern-card::after,
.custom-material-card::after,
.custom-color-card::after,
.custom-install-card::after{
  content:"";
  position:absolute;
  right:2px;
  bottom:2px;
  width:72px;
  height:72px;
  opacity:.72;
  pointer-events:none;
}
.custom-pattern-card::after{background:url("./custom-dwg.svg") center / contain no-repeat}
.custom-material-card::after{background:url("./materials.svg") center / contain no-repeat}
.custom-color-card::after{background:url("./color.svg") center / contain no-repeat}
.custom-install-card::after{
  background:url("./install.svg") center / contain no-repeat;
  transform:scaleX(-1);
}
.custom-material-card::after,
.custom-color-card::after,
.custom-install-card::after{
  right:10px;
  bottom:10px;
  width:58px;
  height:58px;
}
.applications{
  border-top:1px solid rgba(16,16,15,.08);
}
.application-head{
  margin-bottom:34px;
}
.application-carousel{
  position:relative;
}
.application-viewport{
  overflow:hidden;
}
.application-track{
  --application-index:0;
  --application-gap:16px;
  --application-card-width:calc((100% - 48px) / 4);
  display:flex;
  gap:var(--application-gap);
  transform:translateX(calc((var(--application-card-width) + var(--application-gap)) * var(--application-index) * -1));
  transition:transform .56s var(--ease);
  will-change:transform;
}
.application-card{
  flex:0 0 var(--application-card-width);
  display:grid;
  grid-template-rows:248px 1fr;
  min-height:462px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  transition:transform .32s var(--ease), border-color .32s var(--ease), background-color .32s var(--ease), box-shadow .32s var(--ease);
}
.application-card:hover{
  transform:translateY(-2px);
  border-color:rgba(16,16,15,.25);
  background:var(--hover-gray);
  box-shadow:0 16px 32px rgba(16,16,15,.06);
}
.application-card img{
  height:100%;
  object-fit:cover;
  filter:saturate(.88) contrast(1.04);
  transition:transform .7s var(--ease), filter .7s var(--ease);
}
.application-card:hover img{
  transform:scale(1.025);
  filter:saturate(.96) contrast(1.06);
}
.application-card div{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:22px;
}
.application-card span{
  display:block;
  color:#a8a8a2;
  font-size:12px;
  font-weight:500;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.application-card strong{
  display:block;
  margin-top:12px;
  color:var(--ink);
  font-size:23px;
  font-weight:590;
  line-height:1.08;
}
.application-card p{
  margin:13px 0 0;
  color:rgba(17,17,17,.7);
  font-size:14px;
  line-height:1.58;
}
.carousel-controls{
  position:absolute;
  inset:50% -21px auto -21px;
  z-index:3;
  display:flex;
  justify-content:space-between;
  opacity:0;
  pointer-events:none;
  transform:translateY(-50%);
  transition:opacity .28s var(--ease);
}
.application-carousel:hover .carousel-controls,
.application-carousel:focus-within .carousel-controls{
  opacity:1;
}
.carousel-btn{
  width:42px;
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(16,16,15,.2);
  border-radius:3px;
  background:#fff;
  color:var(--ink);
  cursor:pointer;
  pointer-events:auto;
  box-shadow:0 12px 28px rgba(16,16,15,.12);
  transition:background-color .28s var(--ease), border-color .28s var(--ease), transform .28s var(--ease);
}
.carousel-btn::before{
  content:"";
  width:8px;
  height:8px;
  border-left:1.6px solid currentColor;
  border-bottom:1.6px solid currentColor;
  transform:rotate(45deg) translate(1px,-1px);
}
.carousel-btn.next::before{
  transform:rotate(225deg) translate(1px,-1px);
}
.carousel-btn:hover{
  transform:translateY(-1px);
  background:var(--hover-gray);
  border-color:rgba(16,16,15,.3);
}
.application-layout{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:16px;
  align-items:stretch;
}
.application-feature,
.application-side article,
.application-mini article{
  overflow:hidden;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  transition:transform .32s var(--ease), border-color .32s var(--ease), background-color .32s var(--ease), box-shadow .32s var(--ease);
}
.application-feature:hover,
.application-side article:hover,
.application-mini article:hover{
  transform:translateY(-2px);
  border-color:rgba(16,16,15,.25);
  background:var(--hover-gray);
  box-shadow:0 16px 32px rgba(16,16,15,.06);
}
.application-layout img{
  object-fit:cover;
  filter:saturate(.88) contrast(1.04);
  transition:transform .7s var(--ease), filter .7s var(--ease);
}
.application-feature:hover img,
.application-side article:hover img,
.application-mini article:hover img{
  transform:scale(1.025);
  filter:saturate(.96) contrast(1.06);
}
.application-feature{
  display:grid;
  grid-template-rows:minmax(300px,1fr) auto;
}
.application-feature img{
  height:100%;
  min-height:300px;
}
.application-feature div{
  padding:24px;
}
.application-feature span,
.application-side span,
.application-mini span{
  display:block;
  color:#a8a8a2;
  font-size:12px;
  font-weight:500;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.application-feature strong{
  display:block;
  max-width:19ch;
  margin-top:12px;
  color:var(--ink);
  font-size:28px;
  font-weight:590;
  line-height:1.05;
}
.application-feature p{
  max-width:58ch;
  margin:14px 0 0;
  color:rgba(17,17,17,.7);
  font-size:15px;
  line-height:1.68;
}
.application-side{
  display:grid;
  grid-template-rows:1fr 1fr;
  gap:16px;
}
.application-side article{
  display:grid;
  grid-template-columns:.9fr 1fr;
  min-height:0;
}
.application-side img{
  height:100%;
  min-height:188px;
}
.application-side div{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:20px;
}
.application-side strong,
.application-mini strong{
  display:block;
  margin-top:10px;
  color:var(--ink);
  font-size:19px;
  font-weight:570;
  line-height:1.16;
}
.application-mini{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.application-mini article{
  display:grid;
  grid-template-rows:auto 1fr;
  min-height:0;
  padding-bottom:18px;
}
.application-mini img{
  aspect-ratio:16/7.6;
}
.application-mini span,
.application-mini strong{
  padding-left:18px;
  padding-right:18px;
}
.application-mini span{
  margin-top:16px;
}
.process-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.quality-points{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.quality-points article{
  min-height:156px;
  padding:22px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.035);
}
.quality-points span{
  display:block;
  color:rgba(255,255,255,.42);
  font-size:12px;
  font-weight:560;
  letter-spacing:.14em;
}
.quality-points strong{
  display:block;
  margin-top:28px;
  color:#fff;
  font-size:24px;
  font-weight:590;
  line-height:1.08;
}
.quality-points p{
  margin:10px 0 0;
  color:rgba(255,255,255,.64);
  font-size:14px;
  line-height:1.5;
}
.trust-grid h2 + .lead{
  margin-top:30px;
}
.iso-badge{
  display:inline-flex;
  align-items:center;
  gap:12px;
  margin-top:30px;
}
.iso-badge img{
  width:34px;
  height:34px;
  opacity:.9;
}
.iso-badge strong{
  display:block;
  color:#fff;
  font-size:16px;
  font-weight:560;
  line-height:1.1;
}
.process-list div{
  display:flex;
  align-items:center;
  gap:14px;
  min-height:68px;
  padding:14px 16px;
  border:1px solid rgba(0,0,0,.14);
  background:transparent;
  color:inherit;
  font-weight:560;
}
.band-black .process-list div,
.band-black .certificate-strip span{
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  color:#fff;
}
.band-black .process-list span{
  border-color:rgba(255,255,255,.2);
  color:#fff;
}
.process-list span{
  width:34px;
  height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(0,0,0,.16);
  color:var(--muted);
  font-size:12px;
}
.resource-cards{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1px;
  border:1px solid rgba(0,0,0,.08);
  background:rgba(0,0,0,.08);
  margin-top:18px;
}
.resources-section{
  padding:84px 0;
}
.resources-section .resources-grid{
  grid-template-columns:.82fr 1.18fr;
  gap:32px;
  align-items:center;
}
.resources-copy h2 + .lead{
  margin-top:26px;
  max-width:56ch;
}
.resources-copy .btn{
  margin-top:26px;
}
.resource-visual{
  margin:0;
  overflow:visible;
  background:transparent;
}
.resource-visual img{
  width:100%;
  height:auto;
  max-width:100%;
  object-fit:contain;
  transform:none;
}
.resource-cards article{
  min-height:112px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:16px 22px;
  border:0;
  background:#fff;
}
.resource-cards strong{
  display:block;
  margin-top:8px;
  color:inherit;
  font-size:18px;
  line-height:1.15;
  font-weight:560;
}
.resource-cards a{
  margin-top:12px;
  color:var(--ink);
  font-size:13px;
  font-weight:620;
}
.resource-cards a::after{
  content:"";
  display:inline-block;
  width:6px;
  height:6px;
  margin-left:8px;
  border-top:1.4px solid currentColor;
  border-right:1.4px solid currentColor;
  transform:rotate(45deg) translateY(-1px);
}
.faq-preview{
  grid-template-columns:repeat(3,minmax(0,1fr));
  margin-top:24px;
}
.faq-preview strong{
  color:inherit;
  font-size:16px;
  letter-spacing:0;
  text-transform:none;
}
.certificate-strip{
  grid-template-columns:repeat(4,minmax(0,1fr));
  margin-top:12px;
}
.certificate-strip span{
  padding:14px 16px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
}
.section-cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:40px;
}
.final-cta{
  padding:92px 0;
  background:var(--black);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.18);
}
.final-cta-inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:72px;
  align-items:center;
}
.final-cta h2{max-width:1040px;font-size:var(--type-feature);line-height:1.04}
.final-cta p:not(.kicker){max-width:76ch;margin:22px 0 0;color:rgba(255,255,255,.72);line-height:1.75}
.final-actions{display:flex;flex-wrap:wrap;gap:12px}
.site-footer{
  padding:96px 0 42px;
  background:#020202;
  color:#fff;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.36fr .78fr .78fr .78fr;
  gap:64px;
  padding-bottom:46px;
  border-bottom:1px solid rgba(255,255,255,.08);
  align-items:start;
}
.footer-brand img{width:160px;filter:invert(1) brightness(1.16)}
.footer-brand p{
  max-width:34ch;
  margin:22px 0 0;
  color:rgba(255,255,255,.7);
  font-size:14px;
  line-height:1.7;
}
.footer-contact{
  margin-top:12px;
  color:#fff;
  font-size:15px;
  font-weight:560;
  line-height:1.35;
  white-space:nowrap;
}
.footer-contact a{
  margin:0;
  color:inherit;
  font-size:inherit;
  font-weight:inherit;
  text-decoration:none;
}
.footer-social{
  display:flex;
  align-items:center;
  gap:18px;
  margin-top:14px;
}
.footer-social a{
  width:22px;
  height:22px;
  margin:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:opacity .28s var(--ease), transform .28s var(--ease);
}
.footer-social img{
  width:100%;
  height:100%;
  object-fit:contain;
  filter:invert(1) brightness(1.18);
}
.footer-social a:hover{
  opacity:.72;
  transform:translateY(-1px);
}
.footer-grid strong{
  display:block;
  margin-bottom:22px;
  color:rgba(255,255,255,.52);
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.footer-grid a{
  display:block;
  margin-top:14px;
  color:rgba(255,255,255,.85);
  font-size:14px;
}
.footer-contact a{
  display:inline;
  margin:0;
  color:inherit;
  font-size:inherit;
  font-weight:inherit;
  text-decoration:none;
}
.footer-social a{
  display:inline-flex;
  margin:0;
}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  gap:18px;
  padding-top:34px;
  color:rgba(255,255,255,.85);
  font-size:14px;
  font-weight:400;
  letter-spacing:0;
  text-transform:none;
}
.footer-bottom a{
  color:inherit;
  transition:color .28s var(--ease);
}
.footer-bottom a:hover{
  color:#fff;
}
.back-to-top{
  position:fixed;
  right:22px;
  bottom:22px;
  width:34px;
  height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--black);
  border-radius:8px;
  background:var(--black);
  color:var(--white);
  box-shadow:0 12px 28px rgba(0,0,0,.12);
  z-index:70;
}
.back-to-top::before{
  content:"";
  width:5px;
  height:5px;
  border-right:1.4px solid currentColor;
  border-bottom:1.4px solid currentColor;
  transform:rotate(-135deg) translateY(-1px);
  opacity:.9;
}
.back-to-top:hover{transform:translateY(-1px)}
.site-float-actions{
  position:fixed;
  right:18px;
  top:50%;
  transform:translateY(-50%);
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:78;
}
.float-action{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  width:54px;
  height:54px;
  border:1px solid rgba(16,16,15,.14);
  border-radius:12px;
  background:#fff;
  color:#111;
  box-shadow:0 10px 24px rgba(16,16,15,.08);
  transition:transform .24s var(--ease), border-color .24s var(--ease), box-shadow .24s var(--ease), background-color .24s var(--ease);
}
.float-action:hover{
  transform:translateX(-2px);
  border-color:rgba(16,16,15,.22);
  box-shadow:0 14px 30px rgba(16,16,15,.12);
  background:#fcfcfb;
}
.float-icon{
  width:23px;
  height:23px;
  display:block;
}
.float-whatsapp .float-icon{
  background:currentColor;
  -webkit-mask:url("./whatsapp.svg") center / contain no-repeat;
  mask:url("./whatsapp.svg") center / contain no-repeat;
}
.float-email .float-icon{
  fill:none;
  stroke:currentColor;
  stroke-width:1.6;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.float-label{
  position:absolute;
  right:64px;
  top:50%;
  transform:translate(6px,-50%);
  padding:8px 10px;
  border:1px solid rgba(16,16,15,.12);
  border-radius:999px;
  background:#fff;
  color:#1f1f1d;
  font-size:12px;
  font-weight:560;
  letter-spacing:.04em;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:opacity .24s var(--ease), transform .24s var(--ease);
}
.float-action:hover .float-label,
.float-action:focus-visible .float-label{
  opacity:1;
  transform:translate(0,-50%);
}
@media (max-width:1200px){
  :root{
    --type-hero:66px;
    --type-feature:50px;
    --type-section:42px;
    --type-card:25px;
    --measure-hero:900px;
    --measure-feature:780px;
    --measure-section:860px;
  }
  .header-inner{grid-template-columns:auto 1fr auto}
  .main-nav{display:none}
  .header-actions{display:none}
  .mobile-menu{
    display:block;
    position:relative;
    justify-self:end;
  }
  .hero-layout,.intro-showcase,.selection-layout,.material-grid,.trust-grid,.resources-grid,.product-system,.custom-layout,.application-layout,.footer-grid{
    grid-template-columns:1fr;
  }
  .family-feature{grid-template-columns:1fr}
  .family-feature img{min-height:320px}
  .signature-secondary{grid-template-columns:1fr 1fr}
  .signature-secondary article{grid-template-columns:1fr;min-height:auto}
  .signature-secondary img{aspect-ratio:4/3}
  .application-feature{grid-template-rows:auto auto}
  .application-feature img{aspect-ratio:16/7;min-height:0}
  .application-mini{grid-template-columns:repeat(3,minmax(0,1fr))}
  .application-track{--application-card-width:calc((100% - 16px) / 2)}
  .application-card{grid-template-rows:220px 1fr;min-height:420px}
  .workflow-row,.faq-preview,.certificate-strip{grid-template-columns:1fr 1fr}
  .supporting-family-list{grid-template-columns:repeat(2,minmax(0,1fr))}
  .intro-gallery{
    grid-template-columns:1fr 1fr;
    grid-template-rows:300px 220px;
  }
  .intro-gallery .gallery-tall{grid-column:span 2;grid-row:auto}
  .intro-gallery .gallery-wide{width:100%;transform:none}
  .section-head > div{max-width:100%}
  .mobile-menu-panel{
    left:50%;
    right:auto;
    transform:translateX(-50%);
    top:72px;
    max-width:560px;
  }
  .intro{padding-top:118px}
  .site-float-actions{right:14px}
}
@media (max-width:760px){
  :root{
    --type-hero:34px;
    --type-feature:34px;
    --type-section:28px;
    --type-card:21px;
    --measure-hero:100%;
    --measure-feature:100%;
    --measure-section:100%;
  }
  .wrap{width:min(var(--max),calc(100% - 28px))}
  .header-inner{min-height:68px;grid-template-columns:auto auto;justify-content:space-between}
  .brand img{width:132px}
  .mobile-menu-panel{
    left:50%;
    right:auto;
    transform:translateX(-50%);
    top:64px;
    width:calc(100vw - 20px);
    max-width:none;
    max-height:calc(100svh - 84px);
  }
  .hero{min-height:auto}
  .hero-carousel-stage{min-height:520px}
  .hero-layout{min-height:520px;padding:50px 0 44px}
  .hero h1{max-width:11.5em;line-height:1.02}
  .hero-copy p:not(.kicker){max-width:34ch;font-size:15px;line-height:1.72}
  .hero-actions{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin-top:28px;
  }
  .hero-actions .btn{
    min-width:0;
    width:100%;
    min-height:44px;
    padding:0 12px;
    font-size:12px;
    text-align:center;
    white-space:normal;
  }
  .kicker{font-size:11px;letter-spacing:.14em;line-height:1.4}
  .hero-strip{display:none}
  .section,.intro{padding:64px 0}
  .intro{display:none}
  .section-head{display:grid;gap:16px;align-items:start;margin-bottom:30px}
  h2,.section-head h2{max-width:100%}
  .lead,.section-note{max-width:100%;font-size:15px;line-height:1.66}
  .family-list,.path-grid,.custom-list,.application-mini,.process-list,.resource-cards,.material-stack,.workflow-row,.application-notes,.faq-preview,.certificate-strip{
    grid-template-columns:1fr;
  }
  .product-explore{padding-top:64px}
  .product-system{gap:12px}
  .product-system-cta-desktop{
    display:none;
  }
  .product-system-cta{
    display:flex;
    justify-content:stretch;
    margin-top:16px;
  }
  .product-system-cta .btn{
    width:100%;
  }
  .family-feature img{
    width:100%;
    min-height:0;
    aspect-ratio:16/7.4;
    object-fit:cover;
  }
  .family-feature div{padding:15px}
  .family-feature span,
  .signature-secondary span{
    font-size:12px;
    letter-spacing:.16em;
  }
  .signature-primary strong,
  .signature-secondary strong{
    font-size:18px;
    line-height:1.08;
  }
  .family-feature p,
  .signature-secondary p{
    font-size:13px;
    line-height:1.42;
  }
  .family-feature .text-link,
  .signature-secondary .text-link{
    margin-top:10px;
  }
  .signature-secondary{grid-template-columns:1fr}
  .signature-secondary article{
    grid-template-columns:1fr;
    min-height:0;
  }
  .signature-secondary img{
    width:100%;
    height:auto;
    aspect-ratio:16/7.4;
    object-fit:cover;
  }
  .signature-secondary div{padding:15px}
  .supporting-family-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .family-list a.has-thumb{min-height:0}
  .family-list a.has-thumb img{aspect-ratio:4/3}
  .family-list a.has-thumb span,
  .family-list a.has-thumb strong{padding-left:12px;padding-right:12px}
  .family-list a.has-thumb span{margin-top:10px;font-size:11px;letter-spacing:.12em}
  .family-list a.has-thumb strong{padding-bottom:12px;font-size:14px;line-height:1.18}
  .family-list .family-guide{
    min-height:154px;
    padding:18px;
  }
  .family-list .family-guide::after{
    width:118px;
    height:118px;
    top:-28px;
    right:-24px;
  }
  .family-list .family-guide strong{font-size:20px;max-width:none}
  .family-list .family-guide span{max-width:25ch;font-size:13px;line-height:1.48}
  .intro-showcase{
    gap:40px;
  }
  .intro-content{
    order:1;
    gap:22px;
  }
  .intro-gallery{
    order:2;
  }
  .intro-gallery{
    grid-template-columns:1fr 1fr;
    grid-template-rows:224px 132px;
    gap:12px;
  }
  .intro-gallery .gallery-tall{
    grid-column:span 2;
    grid-row:auto;
    height:auto;
  }
  .intro-gallery .gallery-wide{grid-column:auto;grid-row:auto;width:100%}
  .intro-gallery figure{height:auto}
  .intro-content h2{max-width:100%}
  .family-list a{min-height:108px}
  .product-system .family-feature img{min-height:0}
  .application-side article{grid-template-columns:1fr}
  .application-side img,
  .application-mini img{aspect-ratio:4/3;min-height:0}
  .application-feature img{aspect-ratio:4/3}
  .application-track{
    --application-card-width:calc((100% - 10px) / 2);
    --application-gap:10px;
  }
  .application-card{
    grid-template-rows:132px auto;
    min-height:0;
  }
  .application-card div{padding:13px}
  .application-card span{
    font-size:10px;
    letter-spacing:.11em;
  }
  .application-card strong{
    margin-top:8px;
    font-size:16px;
    line-height:1.14;
    display:-webkit-box;
    -webkit-line-clamp:3;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }
  .application-card p{
    margin-top:8px;
    font-size:12px;
    line-height:1.42;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }
  .carousel-controls{
    inset:78px 8px auto 8px;
    margin:0;
    opacity:1;
  }
  .carousel-btn{
    width:36px;
    height:36px;
    opacity:.9;
  }
  .section-cta-row{margin-top:26px;gap:10px}
  .section-cta-row .btn{flex:1 1 100%;min-height:44px}
  .section-cta-row .btn:nth-child(n+2){display:none}
  .custom-section{padding:58px 0}
  .custom-layout{gap:14px}
  .custom-main img{aspect-ratio:16/6.6}
  .custom-main div{padding:16px}
  .custom-main h3{font-size:20px;line-height:1.12}
  .custom-main p{font-size:13px;line-height:1.46}
  .custom-list{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
  }
  .custom-list article{
    min-height:132px;
    padding:14px;
  }
  .custom-list strong{font-size:15px;line-height:1.14}
  .custom-list ul{gap:5px;margin-top:10px}
  .custom-list li{
    padding-left:10px;
    font-size:11px;
    line-height:1.28;
  }
  .custom-list li:nth-child(n+4){display:none}
  .custom-list li::before{
    top:.58em;
    width:3px;
    height:3px;
  }
  .custom-pattern-card::after,
  .custom-material-card::after,
  .custom-color-card::after,
  .custom-install-card::after{
    width:38px;
    height:38px;
    right:8px;
    bottom:8px;
    opacity:.5;
  }
  .trust-grid{gap:18px}
  .trust-stack{margin-top:0}
  .quality-points{grid-template-columns:1fr 1fr;gap:8px}
  .quality-points article{min-height:108px;padding:14px}
  .quality-points span{font-size:10px;letter-spacing:.12em}
  .quality-points strong{margin-top:16px;font-size:16px;line-height:1.12}
  .quality-points p{margin-top:7px;font-size:11px;line-height:1.36}
  .resources-section{padding:64px 0}
  .resources-section .resources-grid{gap:20px}
  .resources-copy h2 + .lead{margin-top:18px}
  .resources-copy .btn{margin-top:22px}
  .resource-visual img{max-height:260px;object-fit:contain}
  .resource-cards{display:none}
  .resource-cards article{min-height:94px;padding:14px 16px}
  .resource-cards strong{font-size:16px}
  .final-cta{padding:68px 0}
  .final-cta-inner{display:grid;gap:22px}
  .final-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .final-actions .btn{min-width:0;min-height:44px;padding:0 12px;font-size:12px;text-align:center;white-space:normal}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .site-footer{padding:58px 0 28px}
  .site-footer .wrap{
    width:min(var(--max),calc(100% - 44px));
  }
  .footer-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:30px 26px;
    padding-bottom:34px;
  }
  .footer-brand{
    min-width:0;
  }
  .footer-brand img{width:132px}
  .footer-brand p{display:none}
  .footer-contact{
    margin-top:12px;
    font-size:12px;
    line-height:1.5;
    white-space:normal;
  }
  .footer-social{gap:14px;margin-top:12px}
  .footer-social a{width:20px;height:20px}
  .footer-grid strong{margin-bottom:16px;font-size:11px;letter-spacing:.15em}
  .footer-grid a{margin-top:12px;font-size:14px;line-height:1.35}
  .back-to-top{right:16px;bottom:16px;width:32px;height:32px}
  .site-float-actions{
    top:62%;
    right:14px;
    bottom:auto;
    transform:translateY(-50%);
    gap:8px;
  }
  .float-action{
    width:48px;
    height:48px;
    border-radius:11px;
  }
  .float-icon{
    width:21px;
    height:21px;
  }
  .float-label{display:none}
}
