
:root{
 --ease-out:cubic-bezier(0.22,1,0.36,1);
 --ease-spring:cubic-bezier(0.16,1.05,0.32,1);
 --section-y:clamp(72px,10vh,120px);
 --section-y-lg:clamp(96px,14vh,160px);
 --section-x:clamp(20px,4vw,36px);
 --r-sm:12px;
 --r-md:18px;
 --r-lg:22px;
 --r-xl:28px;
 --r-pill:999px;
 --c-ink:#1d1d1f;
 --c-ink-2:#424245;
 --c-muted:#6e6e73;
 --c-mute-2:#86868b;
 --c-line:#e8e8ed;
 --c-bg:#fff;
 --c-bg-2:#f5f5f7;
}
.fx-eyebrow{
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:500;
 letter-spacing:.36em;
 text-transform:uppercase;
 color:var(--blue-link,#1d1d1f);
 margin:0 0 16px;
}
.fx-quote-shell{padding:120px 36px 60px;max-width:1280px;margin:0 auto;}
.fx-quote-hero{text-align:center;margin:0 auto 48px;max-width:880px;}
.fx-quote-eyebrow{
 font-family:'Montserrat',sans-serif;
 font-size:11px;font-weight:500;
 letter-spacing:.36em;text-transform:uppercase;
 color:#1d1d1f;margin:0 0 16px;
}
.fx-quote-h1{
 font-family:'Cormorant Garamond',serif;
 font-size:clamp(48px,6vw,88px);
 font-weight:400;letter-spacing:-.02em;
 margin:0 0 20px;line-height:1.05;
 color:#1d1d1f;
}
.fx-quote-h1 em{
 font-style:italic;
 color:#1d1d1f;
 font-weight:300;
}
.fx-quote-meta{
 font-family:'Montserrat',sans-serif;
 font-size:15px;line-height:1.6;
 color:#6e6e73;max-width:640px;
 margin:0 auto;
}
.fx-quote-grid{
 display:grid;
 grid-template-columns:minmax(0,1fr) minmax(0,1fr);
 gap:60px;
 align-items:start;
 margin-top:24px;
}
.fx-quote-info h3{
 font-family:'Cormorant Garamond',serif;
 font-size:32px;font-weight:400;
 letter-spacing:-.01em;margin:0 0 20px;
 color:#1d1d1f;
}
.fx-quote-info ul{
 list-style:none;padding:0;margin:0;
 font-family:'Montserrat',sans-serif;
 font-size:14px;line-height:1.8;color:#424245;
}
.fx-quote-info li{
 padding:10px 0;
 border-bottom:1px solid #e8e8ed;
}
.fx-quote-info li:last-child{border-bottom:none;}
.fx-calc-card{
 background:#f5f5f7;
 border-radius:28px;
 padding:36px;
 border:1px solid #e8e8ed;
}
.fx-calc-row{margin-bottom:28px;}
.fx-calc-lbl{
 display:block;
 font-family:'Montserrat',sans-serif;
 font-size:11px;font-weight:600;
 letter-spacing:.2em;text-transform:uppercase;
 color:#6e6e73;margin-bottom:12px;
}
.fx-calc-chips{
 display:flex;flex-wrap:wrap;gap:8px;
}
.fx-calc-chips button,
.fx-calc-chips span{
 padding:9px 14px;
 border:1px solid #d2d2d7;
 background:#fff;
 font-family:'Montserrat',sans-serif;
 font-size:12px;font-weight:500;
 cursor:pointer;
 transition:.18s ease;
 border-radius:980px;
 color:#1d1d1f;user-select:none;
}
.fx-calc-chips button:hover,
.fx-calc-chips span:hover{border-color:#1d1d1f;}
.fx-calc-chips button.on,
.fx-calc-chips span.on{
 background:#1d1d1f;color:#fff;border-color:#1d1d1f;
}
.fx-calc-slider{
 display:grid;
 grid-template-columns:1fr auto;
 gap:16px;align-items:center;
}
.fx-calc-slider input[type="range"]{
 -webkit-appearance:none;appearance:none;
 width:100%;height:4px;
 background:#d2d2d7;border-radius:2px;outline:none;
}
.fx-calc-slider input[type="range"]::-webkit-slider-thumb{
 -webkit-appearance:none;appearance:none;
 width:22px;height:22px;
 background:#1d1d1f;border-radius:50%;
 cursor:pointer;border:2px solid #fff;
 box-shadow:0 2px 8px rgba(0,0,0,.18);
}
.fx-calc-slider input[type="range"]::-moz-range-thumb{
 width:22px;height:22px;
 background:#1d1d1f;border-radius:50%;
 cursor:pointer;border:2px solid #fff;
}
.fx-calc-val{
 font-family:'Cormorant Garamond',serif;
 font-size:28px;font-weight:400;
 color:#1d1d1f;min-width:80px;text-align:right;
}
.fx-calc-val small{
 font-family:'Montserrat',sans-serif;
 font-size:12px;color:#86868b;
 margin-left:4px;font-weight:500;
}
.fx-calc-out{
 margin-top:32px;padding-top:24px;
 border-top:1px solid #d2d2d7;
}
.fx-calc-num{
 font-family:'Cormorant Garamond',serif;
 font-size:56px;font-weight:400;
 color:#1d1d1f;letter-spacing:-.02em;
 line-height:1;
}
.fx-calc-num small{
 font-family:'Montserrat',sans-serif;
 font-size:13px;color:#6e6e73;
 margin-left:12px;font-weight:500;
}
.fx-calc-num-secondary{
 font-family:'Montserrat',sans-serif;
 font-size:14px;font-weight:500;
 color:#6e6e73;
 margin-top:8px;
}
.fx-calc-note{
 font-family:'Montserrat',sans-serif;
 font-size:12px;color:#6e6e73;
 margin-top:12px;
 line-height:1.5;
}
.fx-calc-cta{
 display:inline-block;margin-top:24px;
}
@media (max-width:980px){
 .fx-quote-grid{grid-template-columns:1fr;gap:40px;}
 .fx-quote-shell{padding:100px 20px 60px;}
 .fx-calc-card{padding:24px;}
 .fx-calc-num{font-size:48px;}
}
.fx-spec-table-section{
 padding:80px 36px;
 background:#f5f5f7;
}
.fx-spec-table-section h2{
 font-family:'Cormorant Garamond',serif;
 font-size:clamp(32px,4vw,52px);
 font-weight:400;letter-spacing:-.02em;
 text-align:center;margin:0 0 8px;
 color:#1d1d1f;
}
.fx-spec-table-section h2 em{
 font-style:italic;color:#1d1d1f;font-weight:300;
}
.fx-spec-table-section .fx-eyebrow{
 text-align:center;margin-bottom:12px;
}
.fx-spec-table{
 display:grid;
 max-width:920px;
 margin:32px auto 0;
 border-top:1px solid #d2d2d7;
}
.fx-spec-row{
 display:grid;
 grid-template-columns:48px 220px 1fr;
 align-items:center;
 gap:16px;
 padding:20px 8px;
 border-bottom:1px solid #d2d2d7;
}
.fx-spec-row svg{
 width:24px;height:24px;
 color:#1d1d1f;
 stroke-width:1.5;
}
.fx-spec-key{
 font-family:'Montserrat',sans-serif;
 font-size:11px;font-weight:600;
 letter-spacing:.2em;text-transform:uppercase;
 color:#6e6e73;
}
.fx-spec-val{
 font-family:'Montserrat',sans-serif;
 font-size:15px;line-height:1.5;
 color:#1d1d1f;
}
@media (max-width:700px){
 .fx-spec-row{grid-template-columns:36px 1fr;gap:12px;padding:16px 4px;}
 .fx-spec-row svg{width:20px;height:20px;}
 .fx-spec-key{grid-column:2;font-size:10px;}
 .fx-spec-val{grid-column:2;}
}
.fx-fitmatrix{
 padding:80px 36px;
}
.fx-fitmatrix h2{
 font-family:'Cormorant Garamond',serif;
 font-size:clamp(32px,4vw,52px);
 font-weight:400;letter-spacing:-.02em;
 text-align:center;margin:0 0 8px;
 color:#1d1d1f;
}
.fx-fitmatrix h2 em{
 font-style:italic;color:#1d1d1f;font-weight:300;
}
.fx-fitmatrix .fx-eyebrow{
 text-align:center;margin-bottom:12px;
}
.fx-fit-grid{
 display:grid;
 grid-template-columns:repeat(3,1fr);
 gap:24px;
 max-width:1100px;
 margin:32px auto 0;
}
.fx-fit-card{
 background:#f5f5f7;
 border-radius:18px;
 padding:28px;
 border:1px solid #e8e8ed;
}
.fx-fit-card.good{background:#f4faf4;border-color:#d4e8d4;border-top:2px solid #2a7a2a;}
.fx-fit-card.bad{background:#fbf6f6;border-color:#f0d4d4;border-top:2px solid #b04545;}
.fx-fit-card.inspect{background:#faf8f1;border-color:#e8e0c4;border-top:2px solid #1d1d1f;}
.fx-fit-card h3{
 font-family:'Montserrat',sans-serif;
 font-size:11px;font-weight:700;
 letter-spacing:.24em;text-transform:uppercase;
 color:#6e6e73;margin:0 0 16px;
}
.fx-fit-card.good h3{color:#1d1d1f;}
.fx-fit-card.inspect h3{color:#1d1d1f;}
.fx-fit-card ul{
 list-style:none;padding:0;margin:0;
 font-family:'Montserrat',sans-serif;
 font-size:14px;line-height:1.6;
 color:#424245;
}
.fx-fit-card li{
 padding:8px 0;
 border-bottom:1px solid #e8e8ed;
}
.fx-fit-card li:last-child{border-bottom:none;}
@media (max-width:900px){
 .fx-fit-grid{grid-template-columns:1fr;gap:16px;}
 .fx-fitmatrix{padding:60px 20px;}
 .fx-spec-table-section{padding:60px 20px;}
}
.fx-proj-filter{
 display:flex;flex-wrap:wrap;
 gap:8px;
 margin:0 auto 28px;
 justify-content:center;
 max-width:1200px;
 padding:0 20px;
}
.fx-proj-filter span{
 padding:10px 18px;
 border:1px solid #d2d2d7;
 font-family:'Montserrat',sans-serif;
 font-size:11px;font-weight:600;
 letter-spacing:.2em;text-transform:uppercase;
 color:#6e6e73;
 cursor:pointer;
 transition:.2s ease;
 border-radius:980px;
 user-select:none;
}
.fx-proj-filter span:hover{border-color:#1d1d1f;color:#1d1d1f;}
.fx-proj-filter span.on{
 background:#1d1d1f;color:#fff;border-color:#1d1d1f;
}
@keyframes fxHeroLineDraw{
 from{transform:scaleX(0);}
 to{transform:scaleX(1);}
}
.fx-plate-section{
 background:#fff;
 border-bottom:1px solid var(--c-line);
}
.fx-plate-shell{
 display:grid;
 grid-template-columns:minmax(0,1fr) minmax(0,1fr);
 gap:60px;
 align-items:center;
 padding:160px 36px 120px;
 max-width:1280px;
 margin:0 auto;
}
.fx-plate-info{padding-right:20px;}
.fx-plate-eyebrow{
 font-family:'Montserrat',sans-serif;
 font-size:11px;font-weight:500;
 letter-spacing:.36em;text-transform:uppercase;
 color:#1d1d1f;margin:0 0 16px;
}
.fx-plate-h2{
 font-family:'Cormorant Garamond',serif;
 font-size:clamp(40px,5vw,72px);
 font-weight:400;letter-spacing:-.02em;
 line-height:1.05;margin:0 0 20px;
 color:#1d1d1f;
}
.fx-plate-h2 em{
 font-style:italic;color:#1d1d1f;font-weight:300;
}
.fx-plate-meta{
 font-family:'Montserrat',sans-serif;
 font-size:15px;line-height:1.6;
 color:#6e6e73;max-width:480px;
 margin:0 0 28px;
}
.fx-plate-mat-seg{
 display:inline-flex;flex-wrap:wrap;
 gap:0;
 border:1px solid #d2d2d7;
 border-radius:980px;
 padding:4px;
 background:#fff;
 margin-bottom:28px;
}
.fx-plate-mat-seg button,
.fx-plate-mat-seg span{
 padding:8px 14px;
 font-family:'Montserrat',sans-serif;
 font-size:11px;font-weight:600;
 letter-spacing:.14em;text-transform:uppercase;
 color:#6e6e73;
 background:none;
 border:none;
 cursor:pointer;
 border-radius:980px;
 transition:.2s ease;
 user-select:none;
}
.fx-plate-mat-seg button.on,
.fx-plate-mat-seg span.on{
 background:#1d1d1f;color:#fff;
}
.fx-plate-cta-row{
 display:flex;
 flex-wrap:wrap;
 gap:12px;
 margin-top:24px;
}
.fx-plate-cta-row .btn{
 flex:0 1 auto;
}
.fx-plate-meta-row{
 display:grid;grid-template-columns:repeat(3,auto);
 gap:28px;margin-top:8px;
 font-family:'Montserrat',sans-serif;
}
.fx-plate-meta-row>div{
 display:flex;flex-direction:column;gap:4px;
}
.fx-plate-meta-lbl{
 font-size:10px;font-weight:600;
 letter-spacing:.26em;text-transform:uppercase;
 color:#86868b;
}
.fx-plate-meta-row b{
 font-size:13px;font-weight:600;
 color:#1d1d1f;
}
.fx-plate-wrap{
 position:relative;
 height:640px;
 display:flex;
 align-items:center;
 justify-content:center;
 perspective:2200px;
 perspective-origin:50% 50%;
}
.fx-plate-wrap::before{
 content:"";
 position:absolute;
 width:560px;height:60px;
 bottom:60px;
 background:radial-gradient(50% 50% at 50% 50%,rgba(0,0,0,.25),transparent 70%);
 filter:blur(20px);
 max-width:90%;
}
.fx-plate{
 --rx:56deg;--ry:-18deg;--ex:0;
 --plate-scroll-tilt:0deg;
 --plate-body:#efe7d6;
 --plate-top:#efe7d6;
 --plate-primer:#c8893d;
 --plate-substrate:#8a857a;
 position:relative;
 width:min(480px,80vw);
 height:min(480px,80vw);
 transform-style:preserve-3d;
 transform:rotateX(calc(var(--rx)+var(--plate-scroll-tilt))) rotateY(var(--ry));
 transition:transform .9s cubic-bezier(.22,1.2,.36,1);
 will-change:transform;
 cursor:pointer;
}
.fx-plate.idle{animation:fxPlateIdle 28s linear infinite;}
@keyframes fxPlateIdle{
 0%,100%{transform:rotateX(56deg) rotateY(-18deg);}
 50%{transform:rotateX(56deg) rotateY( 18deg);}
}
.fx-plate.is-exploded{--ex:1;--rx:24deg;--ry:-16deg;cursor:zoom-out;animation:none;}
.fx-plate.is-dragging{cursor:grabbing;}
.fx-layer{
 position:absolute;inset:0;
 transform-style:preserve-3d;
 transform:translate3d(0,calc(var(--gap) * var(--ex)),var(--z));
 transition:transform 1.05s cubic-bezier(.16,1.05,.32,1) var(--d,0s),
 filter .5s ease;
 will-change:transform;
}
.fx-plate.is-exploded .fx-layer{
 filter:drop-shadow(0 14px 22px rgba(0,0,0,.18));
}
.fx-l-topcoat{--z:24px;--gap:-130px;--d:.05s;--h:1.5px;--c:var(--plate-top);}
.fx-l-body{--z:6px;--gap:-50px;--d:.12s;--h:16px;--c:var(--plate-body);}
.fx-l-mesh{--z:-9px;--gap:18px;--d:.15s;--h:1.2px;--c:rgba(255,255,255,.55);pointer-events:none;}
.fx-l-primer{--z:-13px;--gap:60px;--d:.18s;--h:2px;--c:var(--plate-primer);}
.fx-l-substrate{--z:-24px;--gap:130px;--d:.24s;--h:9px;--c:var(--plate-substrate);}
.fx-l-mesh .fx-face-top{
 background:
 repeating-linear-gradient(90deg,rgba(245,245,240,.95) 0 .8px,transparent .8px 6px),
 repeating-linear-gradient( 0deg,rgba(245,245,240,.95) 0 .8px,transparent .8px 6px);
 background-color:rgba(180,200,180,.10);
 box-shadow:inset 0 0 0 .5px rgba(255,255,255,.4);
}
.fx-l-mesh .fx-face{background:rgba(255,255,255,.30);}
.fx-plate[data-system="purcem"] .fx-l-substrate .fx-face-N::after,
.fx-plate[data-system="purcem"] .fx-l-substrate .fx-face-S::after,
.fx-plate[data-system="purcem"] .fx-l-substrate .fx-face-E::after,
.fx-plate[data-system="purcem"] .fx-l-substrate .fx-face-W::after{display:none;}
.fx-plate[data-system="concrete"] .fx-l-substrate .fx-face-top{
 background-image:
 radial-gradient(circle at 12% 22%,rgba(200,205,210,.7) 0 .4px,transparent .6px),
 radial-gradient(circle at 47% 78%,rgba(200,205,210,.7) 0 .4px,transparent .6px),
 radial-gradient(circle at 83% 35%,rgba(200,205,210,.7) 0 .4px,transparent .6px),
 radial-gradient(circle at 28% 61%,rgba(220,225,230,.6) 0 .3px,transparent .5px),
 radial-gradient(circle at 68% 14%,rgba(220,225,230,.6) 0 .3px,transparent .5px);
 background-size:7px 9px,11px 8px,6px 7px,9px 11px,13px 10px;
}
.fx-face{
 position:absolute;inset:0;
 background:var(--c);
 backface-visibility:hidden;
}
.fx-face-top{transform:translateZ(var(--h));overflow:hidden;box-shadow:inset 0 0 0 .5px rgba(0,0,0,.08);}
.fx-face-bot{transform:translateZ(calc(var(--h) * -1)) rotateX(180deg);filter:brightness(.62);}
.fx-face-N{left:0;right:0;top:0;height:calc(var(--h) * 2);transform:rotateX(-90deg) translateZ(var(--h));transform-origin:50% 0;filter:brightness(1.04);}
.fx-face-S{left:0;right:0;bottom:0;height:calc(var(--h) * 2);transform:rotateX( 90deg) translateZ(var(--h));transform-origin:50% 100%;filter:brightness(.74);}
.fx-face-E{top:0;bottom:0;right:0;width:calc(var(--h) * 2);transform:rotateY( 90deg) translateZ(var(--h));transform-origin:100% 50%;filter:brightness(.82);}
.fx-face-W{top:0;bottom:0;left:0;width:calc(var(--h) * 2);transform:rotateY(-90deg) translateZ(var(--h));transform-origin:0 50%;filter:brightness(.98);}
.fx-face-N::before,.fx-face-S::before,.fx-face-E::before,.fx-face-W::before{
 content:"";position:absolute;inset:0;
 background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(0,0,0,.18));
 mix-blend-mode:overlay;pointer-events:none;
}
.fx-l-substrate .fx-face-N,
.fx-l-substrate .fx-face-S,
.fx-l-substrate .fx-face-E,
.fx-l-substrate .fx-face-W{
 background-color:#b6ad9c;
 background-image:
 radial-gradient(ellipse 6px 5px at 14% 62%,#6b6358 0 78%,#423d35 79% 92%,transparent 95%),
 radial-gradient(ellipse 7px 4px at 41% 38%,#8a8170 0 70%,#5b5447 75% 92%,transparent 95%),
 radial-gradient(ellipse 5px 6px at 68% 70%,#756a5a 0 75%,#3f3a32 82% 94%,transparent 96%),
 radial-gradient(ellipse 8px 5px at 88% 33%,#9a8f7c 0 72%,#5e5648 80% 94%,transparent 96%),
 radial-gradient(ellipse 4px 5px at 27% 24%,#5d5648 0 80%,transparent 92%),
 radial-gradient(circle at 22% 78%,#d8cfb8 0 .9px,transparent 1.3px),
 radial-gradient(circle at 56% 18%,#c7bda4 0 1.1px,transparent 1.5px),
 radial-gradient(circle at 78% 88%,#cabf9f 0 .8px,transparent 1.2px),
 radial-gradient(circle at 36% 55%,#b8ad92 0 .7px,transparent 1.1px),
 radial-gradient(circle at 62% 48%,#2a2620 0 1.4px,transparent 1.8px),
 radial-gradient(circle at 12% 30%,#1f1c17 0 .9px,transparent 1.3px),
 radial-gradient(circle at 84% 60%,#2c2823 0 1.1px,transparent 1.5px),
 repeating-linear-gradient(90.3deg,rgba(255,250,238,.07) 0 1px,transparent 1px 4px),
 repeating-linear-gradient(89.7deg,rgba(40,35,28,.10) 0 .5px,transparent .5px 7px),
 linear-gradient(180deg,#cfc5b0 0 12%,rgba(0,0,0,.18) 12% 14%,#b6ad9c 14% 88%,#948b7a 100%);
 background-size:
 34px 28px,42px 30px,38px 26px,46px 32px,30px 24px,
 9px 11px,11px 13px,8px 10px,7px 9px,
 24px 18px,20px 22px,28px 20px,
 auto,auto,100% 100%;
 background-blend-mode:
 normal,normal,normal,normal,normal,
 normal,normal,normal,normal,
 normal,normal,normal,
 overlay,multiply,normal;
}
.fx-l-substrate .fx-face-N::after,
.fx-l-substrate .fx-face-S::after,
.fx-l-substrate .fx-face-E::after,
.fx-l-substrate .fx-face-W::after{
 content:"";position:absolute;inset:0;pointer-events:none;
 background-image:
 linear-gradient(180deg,transparent 28%,rgba(220,225,230,.85) 28.5%,rgba(180,185,190,.9) 30%,transparent 31.5%),
 linear-gradient(180deg,transparent 68%,rgba(220,225,230,.85) 68.5%,rgba(180,185,190,.9) 70%,transparent 71.5%);
 mix-blend-mode:screen;
}
.fx-l-substrate .fx-face-top{
 background-image:
 repeating-linear-gradient(90deg,transparent 0 9px,rgba(170,175,180,.30) 9px 10px,transparent 10px 18px),
 repeating-linear-gradient( 0deg,transparent 0 9px,rgba(170,175,180,.30) 9px 10px,transparent 10px 18px),
 radial-gradient(circle at 30% 40%,#8a847a 0 1.4px,transparent 1.8px),
 radial-gradient(circle at 75% 65%,#6e6a60 0 1.2px,transparent 1.6px);
 background-size:18px 18px,18px 18px,22px 22px,17px 19px;
}
.fx-l-body .fx-face-N,
.fx-l-body .fx-face-S,
.fx-l-body .fx-face-E,
.fx-l-body .fx-face-W{
 background-color:var(--plate-body);
 background-image:
 radial-gradient(ellipse 4px 3px at 22% 35%,rgba(255,253,247,.92) 0 70%,rgba(255,255,255,.3) 78% 92%,transparent 96%),
 radial-gradient(ellipse 3px 4px at 73% 60%,rgba(250,246,236,.88) 0 72%,transparent 94%),
 radial-gradient(ellipse 3px 3px at 48% 78%,rgba(40,32,24,.75) 0 70%,transparent 92%),
 radial-gradient(ellipse 4px 2px at 88% 22%,rgba(55,42,30,.65) 0 72%,transparent 94%),
 radial-gradient(circle at 30% 65%,rgba(255,255,255,.4) 0 .8px,transparent 1.2px),
 radial-gradient(circle at 60% 28%,rgba(0,0,0,.35) 0 .6px,transparent 1px),
 radial-gradient(circle at 18% 50%,rgba(0,0,0,.55) 0 .9px,transparent 1.3px),
 linear-gradient(180deg,rgba(255,255,255,.18) 0 6%,transparent 14%,transparent 86%,rgba(0,0,0,.20) 100%);
 background-size:
 26px 20px,22px 18px,28px 22px,24px 16px,
 8px 10px,7px 9px,18px 14px,
 100% 100%;
 background-blend-mode:screen,screen,multiply,multiply,normal,normal,normal,overlay;
}
.fx-l-primer .fx-face-N,.fx-l-primer .fx-face-S,
.fx-l-primer .fx-face-E,.fx-l-primer .fx-face-W{
 background:
 linear-gradient(180deg,#d49b4a 0%,#a86a22 60%,#8a5418 100%);
 box-shadow:inset 0 1px 0 rgba(255,220,140,.6);
}
.fx-l-topcoat .fx-face-N,.fx-l-topcoat .fx-face-S,
.fx-l-topcoat .fx-face-E,.fx-l-topcoat .fx-face-W{
 background:linear-gradient(180deg,
 rgba(255,255,255,.40) 0%,
 rgba(200,210,220,.18) 50%,
 rgba(20,20,22,.10) 100%);
}
.fx-l-mesh .fx-face-N,.fx-l-mesh .fx-face-S{
 background:
 radial-gradient(circle at 6px 50%,rgba(255,255,255,.95) 0 .8px,transparent 1.2px) 0 0/12px 100%,
 rgba(255,255,255,.15);
}
.fx-l-mesh .fx-face-E,.fx-l-mesh .fx-face-W{
 background:
 radial-gradient(circle at 50% 6px,rgba(255,255,255,.95) 0 .8px,transparent 1.2px) 0 0/100% 12px,
 rgba(255,255,255,.15);
}
.fx-l-substrate .fx-face-bot{
 background:radial-gradient(ellipse at 50% 50%,#6a6660,#3e3b36 90%);
}
.fx-l-topcoat .fx-face{background:rgba(20,20,22,.0);box-shadow:none;}
.fx-l-topcoat .fx-face-top{
 background:
 linear-gradient(115deg,transparent 35%,rgba(255,255,255,.55) 50%,transparent 65%),
 linear-gradient(180deg,rgba(20,20,22,.10),rgba(20,20,22,.03));
 box-shadow:inset 0 0 0 1px rgba(255,255,255,.18);
 backdrop-filter:blur(.4px);
}
.fx-l-topcoat .fx-face-bot{background:rgba(20,20,22,.06);}
.fx-l-topcoat .fx-face-N,
.fx-l-topcoat .fx-face-S,
.fx-l-topcoat .fx-face-E,
.fx-l-topcoat .fx-face-W{background:rgba(20,20,22,.18);}
.fx-plate:not(.is-exploded) .fx-l-topcoat .fx-face-top{opacity:.55;}
.fx-plate.is-exploded .fx-l-topcoat .fx-face-top{opacity:1;}
.fx-l-topcoat .fx-face-top{transition:opacity .6s ease;}
.fx-l-body .fx-face-top{
 background-image:var(--plate-top-image,none);
 background-size:cover;
 background-position:center;
 filter:var(--plate-top-filter,none);
 position:relative;
}
.fx-l-body .fx-face-top svg{width:100%;height:100%;display:block;opacity:var(--plate-svg-opacity,1);transition:opacity .4s ease;}
.fx-l-body .fx-face-top::after{
 content:"";position:absolute;inset:0;
 background:
 radial-gradient(ellipse at 28% 18%,rgba(255,255,255,.22),transparent 55%),
 linear-gradient(125deg,transparent 38%,rgba(255,255,255,.10) 50%,transparent 62%);
 mix-blend-mode:screen;
 pointer-events:none;
}
.fx-l-substrate .fx-face-top{
 background-color:var(--plate-substrate,#8a857a);
 background-image:
 linear-gradient(180deg,rgba(0,0,0,.10),rgba(0,0,0,.18)),
 url("images/terrazzo/cement-concrete-texture-copy-space.jpg");
 background-size:cover,220px auto;
 background-position:center,center;
 background-blend-mode:multiply,normal;
 filter:brightness(.78) saturate(.6);
}
.fx-l-primer .fx-face-top{
 background:
 radial-gradient(circle at 18% 22%,rgba(255,255,255,.40) 0 1.5px,transparent 2.2px),
 radial-gradient(circle at 70% 38%,rgba(0,0,0,.30) 0 1.6px,transparent 2.4px),
 radial-gradient(circle at 38% 70%,rgba(255,255,255,.30) 0 1.4px,transparent 2.0px),
 radial-gradient(circle at 84% 78%,rgba(0,0,0,.32) 0 1.5px,transparent 2.2px),
 radial-gradient(circle at 50% 50%,rgba(255,255,255,.20) 0 1.2px,transparent 1.8px),
 radial-gradient(ellipse at 30% 24%,rgba(255,220,140,.45),transparent 60%),
 linear-gradient(180deg,#d49b4a,#b07530);
 background-size:12px 14px,14px 13px,11px 14px,13px 14px,9px 10px,auto,auto;
}
.fx-l-mesh .fx-face-top,
.fx-plate[data-has-mesh="true"] .fx-l-mesh .fx-face-top{
 background:
 repeating-linear-gradient( 45deg,rgba(255,255,255,.55) 0 1px,transparent 1px 6px),
 repeating-linear-gradient(-45deg,rgba(255,255,255,.55) 0 1px,transparent 1px 6px),
 linear-gradient(180deg,#e8dec8,#d2c69c) !important;
}
.fx-layer-tag{
 position:absolute;
 left:100%;top:50%;
 transform:translateY(-50%) translateX(-20px) rotateY(calc(var(--ry) * -1)) rotateX(calc(var(--rx) * -1));
 transform-origin:0 50%;
 white-space:nowrap;
 font-family:'Montserrat',sans-serif;
 font-size:11px;font-weight:600;
 letter-spacing:.14em;text-transform:uppercase;
 color:#1d1d1f;
 background:rgba(255,255,255,.92);
 padding:6px 12px;
 border-radius:999px;
 border:1px solid #d2d2d7;
 margin-left:32px;
 opacity:0;pointer-events:none;
 transition:opacity .4s ease calc(var(--d)+.35s),
 transform .6s cubic-bezier(.16,1.05,.32,1) calc(var(--d)+.25s);
}
.fx-plate.is-exploded .fx-layer-tag{
 opacity:1;
 transform:translateY(-50%) translateX(0) rotateY(calc(var(--ry) * -1)) rotateX(calc(var(--rx) * -1));
}
.fx-layer-tag b{
 display:block;
 font-weight:700;font-size:12px;letter-spacing:.02em;
 text-transform:none;color:#1d1d1f;margin-top:2px;
}
.fx-plate-hint{
 position:absolute;
 bottom:12px;
 left:50%;
 transform:translateX(-50%);
 font-family:'Montserrat',sans-serif;
 font-size:10px;font-weight:500;
 letter-spacing:.3em;text-transform:uppercase;
 color:#6e6e73;
 display:flex;align-items:center;gap:10px;
 white-space:nowrap;
}
.fx-plate-hint::before,.fx-plate-hint::after{
 content:"";
 width:30px;height:1px;
 background:#d2d2d7;
}
@media (max-width:980px){
 .fx-plate-shell{
 grid-template-columns:1fr;
 gap:32px;
 padding:80px 20px;
}
 .fx-plate-wrap{order:-1;height:480px;}
 .fx-plate-info{padding-right:0;}
 .fx-plate-meta-row{grid-template-columns:repeat(3,1fr);gap:16px;}
}
.fx-mat-shell{
 max-width:1280px;
 margin:0 auto;
 padding:0 36px;
}
@media (max-width:768px){
 .fx-mat-shell{padding:0 20px;}
}
.fx-mat-hero{
 padding:140px 36px 80px;
 max-width:1280px;
 margin:0 auto;
 display:grid;
 grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);
 gap:80px;
 align-items:center;
}
.fx-mat-hero__content{padding-right:12px;}
.fx-mat-hero__eyebrow{
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:600;
 letter-spacing:.26em;
 text-transform:uppercase;
 color:#6e6e73;
 margin:0 0 16px;
}
.fx-mat-hero__h1{
 font-family:'Cormorant Garamond',serif;
 font-size:clamp(48px,6vw,88px);
 font-weight:400;
 letter-spacing:-.02em;
 line-height:1.05;
 margin:0 0 20px;
 color:#1d1d1f;
}
.fx-mat-hero__lede{
 font-family:'Montserrat',sans-serif;
 font-size:clamp(16px,1.4vw,19px);
 line-height:1.55;
 color:#424245;
 margin:0 0 32px;
 max-width:540px;
}
.fx-mat-hero__cta-row{
 display:flex;flex-wrap:wrap;gap:12px;
}
.fx-mat-hero__image{
 position:relative;
 border-radius:28px;
 overflow:hidden;
 aspect-ratio:4/5;
 background:#f5f5f7;
}
.fx-mat-hero__image img{
 width:100%;height:100%;
 object-fit:cover;
 display:block;
}
.fx-mat-hero__chip{
 display:inline-flex;flex-wrap:wrap;gap:16px 24px;
 margin-bottom:20px;
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 letter-spacing:.14em;
 text-transform:uppercase;
 color:#6e6e73;
}
.fx-mat-hero__chip span b{
 display:block;
 font-family:'Cormorant Garamond',serif;
 font-size:24px;
 font-weight:400;
 letter-spacing:-.01em;
 text-transform:none;
 color:#1d1d1f;
 margin-top:4px;
}
@media (max-width:980px){
 .fx-mat-hero{grid-template-columns:1fr;gap:40px;padding:120px 20px 60px;}
 .fx-mat-hero__image{aspect-ratio:16/10;}
 .fx-mat-hero__content{padding-right:0;}
}
.fx-mat-section{
 padding:100px 36px;
 max-width:1280px;
 margin:0 auto;
}
.fx-mat-section--grey{
 background:#f5f5f7;
 max-width:100%;
 padding-left:0;padding-right:0;
 margin:0;
}
.fx-mat-section--grey>.fx-mat-section__inner{
 max-width:1280px;
 margin:0 auto;
 padding:0 36px;
}
.fx-mat-section__head{
 display:grid;
 grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);
 gap:60px;
 margin-bottom:60px;
 align-items:end;
}
.fx-mat-section__head h2{
 font-family:'Cormorant Garamond',serif;
 font-size:clamp(36px,4.4vw,64px);
 font-weight:400;
 letter-spacing:-.02em;
 line-height:1.05;
 margin:8px 0 0;
 color:#1d1d1f;
}
.fx-mat-section__lede{
 font-family:'Montserrat',sans-serif;
 font-size:16px;
 line-height:1.6;
 color:#424245;
 margin:0;
 justify-self:start;
}
@media (max-width:980px){
 .fx-mat-section{padding:80px 20px;}
 .fx-mat-section__head{grid-template-columns:1fr;gap:16px;margin-bottom:40px;}
}
.fx-systems-grid{
 display:grid;
 grid-template-columns:repeat(3,minmax(0,1fr));
 gap:24px;
}
.fx-system-card{
 display:flex;
 flex-direction:column;
 background:#fff;
 border:1px solid #e8e8ed;
 border-radius:22px;
 padding:32px 28px;
 text-decoration:none;
 color:inherit;
 transition:transform .35s cubic-bezier(.22,1,.36,1),
 box-shadow .35s cubic-bezier(.22,1,.36,1),
 border-color .35s ease;
}
.fx-system-card:hover{
 transform:translateY(-4px);
 border-color:#d2d2d7;
 box-shadow:0 18px 40px rgba(0,0,0,.06);
}
.fx-system-card__thickness{
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:600;
 letter-spacing:.26em;
 text-transform:uppercase;
 color:#1d1d1f;
 margin:0 0 12px;
}
.fx-system-card__name{
 font-family:'Cormorant Garamond',serif;
 font-size:30px;
 font-weight:400;
 letter-spacing:-.01em;
 line-height:1.1;
 margin:0 0 12px;
 color:#1d1d1f;
}
.fx-system-card__desc{
 font-family:'Montserrat',sans-serif;
 font-size:14px;
 line-height:1.55;
 color:#6e6e73;
 margin:0 0 24px;
 flex:1;
}
.fx-system-card__meta{
 display:flex;
 justify-content:space-between;
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 color:#6e6e73;
 border-top:1px solid #e8e8ed;
 padding-top:16px;
 margin-top:auto;
}
.fx-system-card__meta b{
 color:#1d1d1f;
 font-weight:600;
}
.fx-system-card__link{
 margin-top:16px;
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 font-weight:600;
 letter-spacing:.2em;
 text-transform:uppercase;
 color:#1d1d1f;
}
.fx-system-card:hover .fx-system-card__link::after{transform:translateX(4px);}
.fx-system-card__link::after{
 content:" →";
 display:inline-block;
 transition:transform .25s ease;
}
@media (max-width:980px){
 .fx-systems-grid{grid-template-columns:1fr;}
}
.fx-buildup{
 display:grid;
 grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);
 gap:60px;
 align-items:center;
}
.fx-buildup__visual{
 position:relative;
 display:flex;
 flex-direction:column;
 border-radius:18px;
 overflow:hidden;
 background:#f5f5f7;
 padding:24px;
 box-shadow:0 1px 0 #e8e8ed inset;
}
.fx-buildup__substrate-label{
 font-family:'Montserrat',sans-serif;
 font-size:10px;
 letter-spacing:.26em;
 text-transform:uppercase;
 color:#86868b;
 margin:8px 0 0;
 text-align:center;
}
.fx-buildup-layer{
 position:relative;
 margin-bottom:4px;
 cursor:pointer;
 transition:transform .3s cubic-bezier(.22,1,.36,1);
}
.fx-buildup-layer:last-child{margin-bottom:0;}
.fx-buildup-layer{border-bottom:1px solid rgba(0,0,0,.05);padding-bottom:8px;transition:transform .28s cubic-bezier(.22,1,.36,1);}
.fx-buildup-layer:last-child{border-bottom:0;padding-bottom:0;}
.fx-buildup-layer:hover{transform:translateX(4px);}
.fx-buildup-layer__bar{
 display:flex;
 align-items:center;
 justify-content:space-between;
 padding:0 18px;
 border-radius:8px;
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 font-weight:600;
 letter-spacing:.14em;
 text-transform:uppercase;
 color:#fff;
 white-space:nowrap;
 overflow:hidden;
}
.fx-buildup-layer__role{font-weight:600;}
.fx-buildup-layer__thick{
 font-family:'Cormorant Garamond',serif;
 font-size:14px;
 font-weight:400;
 letter-spacing:0;
 text-transform:none;
 opacity:.85;
}
.fx-buildup-layer--topcoat .fx-buildup-layer__bar{background:#1d1d1f;height:22px;}
.fx-buildup-layer--body .fx-buildup-layer__bar{background:#424245;height:56px;}
.fx-buildup-layer--primer .fx-buildup-layer__bar{background:#6e6e73;height:16px;}
.fx-buildup-layer--prep .fx-buildup-layer__bar{background:#86868b;height:12px;}
.fx-buildup-layer--substrate .fx-buildup-layer__bar{background:#c8c8cd;height:80px;color:#1d1d1f;}
.fx-buildup__legend{
 font-family:'Montserrat',sans-serif;
}
.fx-buildup-row{
 display:grid;
 grid-template-columns:24px 1fr;
 gap:16px;
 padding:16px 0;
 border-bottom:1px solid #e8e8ed;
 align-items:start;
}
.fx-buildup-row:last-child{border-bottom:none;}
.fx-buildup-row__dot{
 width:14px;height:14px;
 border-radius:4px;
 margin-top:4px;
}
.fx-buildup-row__name{
 font-size:14px;
 font-weight:600;
 color:#1d1d1f;
 margin:0 0 4px;
}
.fx-buildup-row__meta{
 font-size:12px;
 color:#6e6e73;
 line-height:1.55;
}
.fx-buildup-row__meta b{color:#1d1d1f;font-weight:600;}
@media (max-width:980px){
 .fx-buildup{grid-template-columns:1fr;gap:32px;}
}
.fx-process{
 display:grid;
 grid-template-columns:repeat(7,minmax(0,1fr));
 gap:16px;
 position:relative;
}
.fx-process::before{
 content:"";
 position:absolute;
 top:22px;left:24px;right:24px;
 height:1px;
 background:#d2d2d7;
 z-index:0;
}
.fx-process-step{
 position:relative;
 z-index:1;
 text-align:left;
}
.fx-process-step__num{
 width:44px;height:44px;
 border-radius:50%;
 background:#1d1d1f;
 color:#fff;
 display:inline-flex;
 align-items:center;
 justify-content:center;
 font-family:'Cormorant Garamond',serif;
 font-size:18px;
 font-weight:400;
 margin-bottom:14px;
}
.fx-process-step__name{
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 font-weight:700;
 letter-spacing:.14em;
 text-transform:uppercase;
 color:#1d1d1f;
 margin:0 0 6px;
}
.fx-process-step__desc{
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 color:#6e6e73;
 line-height:1.5;
 margin:0;
}
.fx-process-step__time{
 display:block;
 font-family:'Cormorant Garamond',serif;
 font-size:16px;
 font-style:italic;
 color:#1d1d1f;
 margin-top:6px;
}
@media (max-width:1100px){
 .fx-process{grid-template-columns:repeat(2,minmax(0,1fr));gap:28px;}
 .fx-process::before{display:none;}
}
@media (max-width:600px){
 .fx-process{grid-template-columns:1fr;}
}
.fx-pitfalls-grid{
 display:grid;
 grid-template-columns:repeat(2,minmax(0,1fr));
 gap:24px;
}
.fx-pitfall{
 background:#fff;
 border:1px solid #e8e8ed;
 border-radius:18px;
 padding:28px;
 border-left:3px solid #d2d2d7;
}
.fx-pitfall__label{
 font-family:'Montserrat',sans-serif;
 font-size:10px;
 font-weight:700;
 letter-spacing:.26em;
 text-transform:uppercase;
 color:#b04545;
 margin:0 0 12px;
}
.fx-pitfall__name{
 font-family:'Cormorant Garamond',serif;
 font-size:24px;
 font-weight:400;
 letter-spacing:-.01em;
 margin:0 0 14px;
 color:#1d1d1f;
}
.fx-pitfall__desc{
 font-family:'Montserrat',sans-serif;
 font-size:14px;
 line-height:1.6;
 color:#424245;
 margin:0 0 14px;
}
.fx-pitfall__fix{
 font-family:'Montserrat',sans-serif;
 font-size:13px;
 line-height:1.55;
 color:#6e6e73;
 border-top:1px solid #f0f0f3;
 padding-top:14px;
}
.fx-pitfall__fix b{color:#1d1d1f;font-weight:600;}
@media (max-width:700px){
 .fx-pitfalls-grid{grid-template-columns:1fr;}
}
.fx-faq{
 max-width:920px;
 margin:0 auto;
 border-top:1px solid #d2d2d7;
}
.fx-faq-item{
 border-bottom:1px solid #d2d2d7;
}
.fx-faq-item__q{
 display:flex;
 justify-content:space-between;
 align-items:flex-start;
 width:100%;
 background:none;
 border:none;
 padding:24px 8px;
 text-align:left;
 cursor:pointer;
 font-family:'Cormorant Garamond',serif;
 font-size:22px;
 font-weight:400;
 letter-spacing:-.01em;
 color:#1d1d1f;
}
.fx-faq-item__q::after{
 content:"+";
 font-family:'Montserrat',sans-serif;
 font-size:24px;
 font-weight:300;
 color:#6e6e73;
 margin-left:24px;
 transition:transform .3s ease;
 flex:0 0 auto;
}
.fx-faq-item.open .fx-faq-item__q::after{
 transform:rotate(45deg);
 color:#1d1d1f;
}
.fx-faq-item__a{
 max-height:0;
 overflow:hidden;
 transition:max-height .35s ease,padding .35s ease;
 font-family:'Montserrat',sans-serif;
 font-size:15px;
 line-height:1.6;
 color:#424245;
 padding:0 8px;
}
.fx-faq-item.open .fx-faq-item__a{
 max-height:800px;
 padding:0 8px 24px;
}
.fx-compare-row{
 display:grid;
 grid-template-columns:repeat(3,minmax(0,1fr));
 gap:16px;
 margin-bottom:16px;
}
.fx-compare-cell{
 background:#fff;
 border:1px solid #e8e8ed;
 border-radius:14px;
 padding:20px;
}
.fx-compare-cell__name{
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:700;
 letter-spacing:.2em;
 text-transform:uppercase;
 color:#6e6e73;
 margin:0 0 8px;
}
.fx-compare-cell__val{
 font-family:'Cormorant Garamond',serif;
 font-size:24px;
 font-weight:400;
 color:#1d1d1f;
 letter-spacing:-.01em;
 line-height:1.2;
}
.fx-compare-cell--this{border-color:#1d1d1f;box-shadow:0 0 0 1px #1d1d1f inset;}
@media (max-width:700px){
 .fx-compare-row{grid-template-columns:1fr;}
}
.fx-mat-cta{
 background:#1d1d1f;
 color:#fff;
 padding:80px 36px;
 text-align:center;
}
.fx-mat-cta h2{
 font-family:'Cormorant Garamond',serif;
 font-size:clamp(40px,4.5vw,64px);
 font-weight:400;
 letter-spacing:-.02em;
 line-height:1.05;
 margin:0 0 20px;
}
.fx-mat-cta p{
 font-family:'Montserrat',sans-serif;
 font-size:16px;
 line-height:1.55;
 color:#c8c8cd;
 max-width:640px;
 margin:0 auto 32px;
}
.fx-mat-cta__row{
 display:inline-flex;
 flex-wrap:wrap;
 gap:12px;
 justify-content:center;
}
.fx-mat-cta__row .btn{
 min-width:200px;
}
.fx-wa{
 position:fixed;
 right:24px;
 bottom:24px;
 z-index:80;
 display:inline-flex;
 align-items:center;
 gap:10px;
 padding:12px 18px 12px 14px;
 background:#25d366;
 color:#fff;
 border-radius:980px;
 font-family:'Montserrat',sans-serif;
 font-size:13px;
 font-weight:600;
 letter-spacing:.04em;
 text-decoration:none;
 box-shadow:0 8px 24px rgba(37,211,102,.35);
 transition:transform .25s ease,box-shadow .25s ease;
}
.fx-wa:hover{
 transform:translateY(-2px);
 box-shadow:0 14px 30px rgba(37,211,102,.45);
}
.fx-wa__icon{
 width:22px;height:22px;
 background:#fff;
 border-radius:50%;
 display:inline-flex;
 align-items:center;
 justify-content:center;
 color:#25d366;
 font-weight:700;
 font-size:12px;
}
@media (max-width:600px){
 .fx-wa{
 left:12px;right:12px;bottom:12px;
 justify-content:center;
}
}
.fx-sample-overlay{
 position:fixed;
 inset:0;
 z-index:200;
 background:rgba(29,29,31,.55);
 -webkit-backdrop-filter:blur(8px);
 backdrop-filter:blur(8px);
 display:none;
 align-items:center;
 justify-content:center;
 padding:20px;
 opacity:0;
 transition:opacity .3s ease;
}
.fx-sample-overlay.open{
 display:flex;
 opacity:1;
}
.fx-sample-modal{
 background:#fff;
 border-radius:28px;
 padding:40px;
 max-width:480px;
 width:100%;
 box-shadow:0 30px 60px rgba(0,0,0,.25);
 position:relative;
 font-family:'Montserrat',sans-serif;
}
.fx-sample-modal__close{
 position:absolute;
 top:14px;right:14px;
 width:36px;height:36px;
 border:none;
 background:#f5f5f7;
 border-radius:50%;
 font-size:18px;
 cursor:pointer;
 color:#6e6e73;
 display:inline-flex;
 align-items:center;
 justify-content:center;
}
.fx-sample-modal__close:hover{background:#e8e8ed;color:#1d1d1f;}
.fx-sample-modal h3{
 font-family:'Cormorant Garamond',serif;
 font-size:36px;
 font-weight:400;
 letter-spacing:-.02em;
 line-height:1.1;
 margin:0 0 8px;
 color:#1d1d1f;
}
.fx-sample-modal p{
 font-size:14px;
 line-height:1.5;
 color:#6e6e73;
 margin:0 0 24px;
}
.fx-sample-modal label{
 display:block;
 font-size:11px;
 font-weight:600;
 letter-spacing:.14em;
 text-transform:uppercase;
 color:#6e6e73;
 margin:16px 0 6px;
}
.fx-sample-modal input,
.fx-sample-modal select,
.fx-sample-modal textarea{
 width:100%;
 padding:12px 14px;
 border:1px solid #d2d2d7;
 border-radius:12px;
 font-family:'Montserrat',sans-serif;
 font-size:14px;
 color:#1d1d1f;
 background:#fff;
 box-sizing:border-box;
}
.fx-sample-modal input:focus,
.fx-sample-modal select:focus,
.fx-sample-modal textarea:focus{
 outline:2px solid #1d1d1f;
 outline-offset:-1px;
 border-color:#1d1d1f;
}
.fx-sample-modal__submit{
 width:100%;
 margin-top:24px;
 padding:14px;
 background:#1d1d1f;
 color:#fff;
 border:none;
 border-radius:980px;
 font-family:'Montserrat',sans-serif;
 font-size:14px;
 font-weight:500;
 cursor:pointer;
}
.fx-sample-modal__note{
 font-size:11px;
 color:#86868b;
 text-align:center;
 margin:12px 0 0;
}
.fx-decision{
 max-width:720px;
 margin:0 auto;
 padding:60px 36px 100px;
}
.fx-decision__progress{
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:600;
 letter-spacing:.26em;
 text-transform:uppercase;
 color:#1d1d1f;
 margin-bottom:8px;
}
.fx-decision__q{
 font-family:'Cormorant Garamond',serif;
 font-size:clamp(36px,4.4vw,56px);
 font-weight:400;
 letter-spacing:-.02em;
 line-height:1.1;
 margin:0 0 32px;
 color:#1d1d1f;
}
.fx-decision__options{
 display:grid;
 grid-template-columns:repeat(2,minmax(0,1fr));
 gap:16px;
}
.fx-decision__option{
 background:#fff;
 border:1px solid #d2d2d7;
 border-radius:18px;
 padding:24px;
 text-align:left;
 cursor:pointer;
 font-family:'Montserrat',sans-serif;
 transition:border-color .25s ease,transform .25s ease;
}
.fx-decision__option:hover{
 border-color:#1d1d1f;
 transform:translateY(-2px);
}
.fx-decision__option-name{
 font-family:'Cormorant Garamond',serif;
 font-size:22px;
 font-weight:400;
 color:#1d1d1f;
 margin:0 0 8px;
}
.fx-decision__option-desc{
 font-size:13px;
 color:#6e6e73;
 line-height:1.5;
}
@media (max-width:600px){
 .fx-decision__options{grid-template-columns:1fr;}
}
.fx-toc{
 position:sticky;
 top:100px;
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 letter-spacing:.14em;
 text-transform:uppercase;
}
.fx-toc__title{
 font-size:10px;
 font-weight:700;
 letter-spacing:.26em;
 color:#86868b;
 margin:0 0 16px;
}
.fx-toc ol{
 list-style:none;
 padding:0;
 margin:0;
 border-left:1px solid #d2d2d7;
}
.fx-toc li a{
 display:block;
 padding:8px 0 8px 16px;
 margin-left:-1px;
 color:#6e6e73;
 text-decoration:none;
 border-left:1px solid transparent;
 transition:color .2s ease,border-color .2s ease;
}
.fx-toc li a:hover,
.fx-toc li a.active{
 color:#1d1d1f;
 border-left-color:#1d1d1f;
}
.fx-stats-row{
 display:grid;
 grid-template-columns:repeat(4,minmax(0,1fr));
 gap:32px;
 padding:60px 0;
 border-top:1px solid #e8e8ed;
 border-bottom:1px solid #e8e8ed;
}
.fx-stat{
 text-align:left;
}
.fx-stat__num{
 font-family:'Cormorant Garamond',serif;
 font-size:48px;
 font-weight:400;
 letter-spacing:-.02em;
 line-height:1;
 color:#1d1d1f;
}
.fx-stat__num em{
 color:#1d1d1f;
 font-style:italic;
}
.fx-stat__label{
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:600;
 letter-spacing:.26em;
 text-transform:uppercase;
 color:#6e6e73;
 margin-top:12px;
}
@media (max-width:768px){
 .fx-stats-row{grid-template-columns:repeat(2,1fr);gap:24px;}
 .fx-stat__num{font-size:36px;}
}
.hero-split .hero-split__bg{
 filter:saturate(1.06) contrast(1.04) brightness(.97);
 transform:scale(1.04);
 transition:transform 1.4s cubic-bezier(.22,1,.36,1),
 filter .8s ease;
 will-change:transform;
}
.hero-split .hero-split__panel:hover .hero-split__bg{
 transform:scale(1.08);
 filter:saturate(1.12) contrast(1.06) brightness(.94);
}
.hero-split .hero-split__panel::before{
 content:"";
 position:absolute;
 inset:0;
 background:
 radial-gradient(ellipse at 35% 75%,
 rgba(0,0,0,.05) 0%,
 rgba(0,0,0,.55) 100%),
 linear-gradient(180deg,
 rgba(0,0,0,0) 30%,
 rgba(0,0,0,.45) 100%);
 z-index:1;
 pointer-events:none;
 opacity:0;
 animation:fxVignetteFadeIn 1.4s cubic-bezier(.22,1,.36,1) .2s forwards;
}
.hero-split .hero-split__panel::after{
 content:"";
 position:absolute;
 inset:0;
 background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .12 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
 background-size:220px 220px;
 opacity:.35;
 mix-blend-mode:overlay;
 z-index:1;
 pointer-events:none;
}
.hero-split .hero-split__content{
 z-index:2;
}
.hero-split .hero-split__eyebrow,
.hero-split .hero-split__title,
.hero-split .hero-split__link{
 opacity:0;
 transform:translateY(28px);
 animation:fxHeroRise 1.1s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-split .hero-split__panel:nth-child(1) .hero-split__eyebrow{animation-delay:.35s;}
.hero-split .hero-split__panel:nth-child(1) .hero-split__title{animation-delay:.50s;}
.hero-split .hero-split__panel:nth-child(1) .hero-split__link{animation-delay:.75s;}
.hero-split .hero-split__panel:nth-child(2) .hero-split__eyebrow{animation-delay:.55s;}
.hero-split .hero-split__panel:nth-child(2) .hero-split__title{animation-delay:.70s;}
.hero-split .hero-split__panel:nth-child(2) .hero-split__link{animation-delay:.95s;}
@keyframes fxHeroRise{
 0%{opacity:0;transform:translateY(28px);}
 60%{opacity:1;}
 100%{opacity:1;transform:translateY(0);}
}
@keyframes fxVignetteFadeIn{
 0%{opacity:0;}
 100%{opacity:1;}
}
.hero-split .hero-split__title{
 position:relative;
 padding-bottom:22px;
}
.hero-split .hero-split__title::after{
 content:"";
 position:absolute;
 left:0;bottom:0;
 width:64px;height:2px;
 background:rgba(255,255,255,.85);
 transform:scaleX(0);
 transform-origin:left center;
 animation:fxLineDraw 1s cubic-bezier(.22,1,.36,1) forwards;
}
.hero-split .hero-split__panel:nth-child(1) .hero-split__title::after{animation-delay:1.1s;}
.hero-split .hero-split__panel:nth-child(2) .hero-split__title::after{animation-delay:1.3s;}
@keyframes fxLineDraw{
 0%{transform:scaleX(0);}
 100%{transform:scaleX(1);}
}
.hero-split .hero-split__link{
 display:inline-flex;
 align-items:center;
 gap:12px;
 position:relative;
 transition:gap .4s cubic-bezier(.22,1,.36,1);
}
.hero-split .hero-split__panel:hover .hero-split__link{
 gap:18px;
}
.header--hero .header__logo-img{
 animation:fxLogoIn 1.2s cubic-bezier(.22,1,.36,1) .1s both;
}
@keyframes fxLogoIn{
 0%{opacity:0;transform:scale(.92) translateY(8px);}
 100%{opacity:1;transform:scale(1) translateY(0);}
}
@media (prefers-reduced-motion:reduce){
 .hero-split .hero-split__bg,
 .hero-split .hero-split__eyebrow,
 .hero-split .hero-split__title,
 .hero-split .hero-split__link,
 .hero-split .hero-split__title::after,
 .hero-split .hero-split__panel::before,
 .header--hero .header__logo-img{
 animation:none !important;
 transition:none !important;
 transform:none !important;
 opacity:1 !important;
}
}
.hero-split__bg,
.fx-mat-hero__image img{
 image-rendering:-webkit-optimize-contrast;
}
.fx-sticky-cta{
 position:fixed;
 bottom:16px;left:16px;right:16px;
 z-index:900;
 display:none;
 gap:8px;
 background:rgba(29,29,31,.96);
 backdrop-filter:saturate(180%) blur(18px);
 border-radius:999px;
 padding:6px;
 box-shadow:0 12px 32px rgba(0,0,0,.18),0 2px 6px rgba(0,0,0,.10);
 opacity:0;
 transform:translateY(80px);
 transition:opacity .35s ease,transform .5s cubic-bezier(.22,1,.36,1);
 pointer-events:none;
}
.fx-sticky-cta.is-visible{opacity:1;transform:translateY(0);pointer-events:auto;}
.fx-sticky-cta__btn{
 flex:1 1 auto;
 text-align:center;
 font-family:'Montserrat',sans-serif;
 font-size:13px;
 font-weight:600;
 letter-spacing:.04em;
 padding:12px 14px;
 border-radius:999px;
 text-decoration:none;
 transition:opacity .2s ease,transform .15s ease;
}
.fx-sticky-cta__btn--ghost{color:#f5f5f7;border:1px solid rgba(255,255,255,.18);}
.fx-sticky-cta__btn--solid{color:#1d1d1f;background:#f5f5f7;}
.fx-sticky-cta__btn--call{flex:0 0 48px;padding:12px 0;color:#f5f5f7;font-size:16px;}
.fx-sticky-cta__btn:active{transform:scale(.97);}
@media (max-width:768px){
 .fx-sticky-cta{display:flex;}
 
 .fx-wa{bottom:86px !important;}
}
.fx-audience{
 background:#fff;
 border-bottom:1px solid #e8e8ed;
 padding:clamp(96px,12vh,132px) clamp(20px,4vw,56px) clamp(20px,3vh,32px);
}
.fx-audience__lead{
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:700;
 letter-spacing:0.22em;
 text-transform:uppercase;
 color:#86868b;
 margin:0 auto 18px;
 max-width:1280px;
 text-align:left;
}
.fx-audience__row{
 max-width:1280px;
 margin:0 auto;
 display:grid;
 grid-template-columns:repeat(3,minmax(0,1fr));
 gap:14px;
}
.fx-audience__card{
 position:relative;
 display:grid;
 grid-template-columns:96px 1fr auto;
 align-items:center;
 gap:16px;
 padding:12px 18px 12px 12px;
 background:#f5f5f7;
 border:1px solid #e8e8ed;
 border-radius:18px;
 text-decoration:none;
 color:#1d1d1f;
 transition:transform .3s cubic-bezier(.22,1,.36,1),border-color .25s ease,box-shadow .3s ease;
}
.fx-audience__card:hover{
 transform:translateY(-2px);
 border-color:#1d1d1f;
 box-shadow:0 14px 28px rgba(0,0,0,.08);
}
.fx-audience__thumb{
 width:96px;
 height:72px;
 border-radius:12px;
 background-size:cover;
 background-position:center;
 background-color:#d2d2d7;
}
.fx-audience__body{min-width:0;}
.fx-audience__tag{
 font-family:'Montserrat',sans-serif;
 font-size:10px;
 font-weight:700;
 letter-spacing:0.16em;
 text-transform:uppercase;
 color:#86868b;
}
.fx-audience__title{
 font-family:'Cormorant Garamond',serif;
 font-size:22px;
 font-weight:500;
 letter-spacing:-0.01em;
 margin:4px 0 2px;
 line-height:1.1;
 color:#1d1d1f;
}
.fx-audience__sub{
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 color:#6e6e73;
 margin:0;
}
.fx-audience__arrow{
 font-size:18px;
 color:#1d1d1f;
 opacity:.55;
 transition:transform .25s cubic-bezier(.22,1,.36,1),opacity .2s ease;
}
.fx-audience__card:hover .fx-audience__arrow{opacity:1;transform:translateX(4px);}
@media (max-width:980px){
 .fx-audience__row{grid-template-columns:1fr;gap:10px;}
 .fx-audience{padding-top:80px;}
 .fx-audience__card{padding:10px 14px 10px 10px;gap:12px;grid-template-columns:80px 1fr auto;}
 .fx-audience__thumb{width:80px;height:60px;}
 .fx-audience__title{font-size:19px;}
}
.fx-audience+.fx-plate-section .fx-plate-shell{
 padding-top:clamp(56px,8vh,96px);
}
.fx-picker{
 background:#f5f5f7;
 padding:clamp(110px,13vh,150px) clamp(20px,4vw,56px) clamp(60px,8vh,96px);
}
.fx-picker__head{
 max-width:1280px;
 margin:0 auto clamp(36px,5vh,56px);
 text-align:left;
}
.fx-picker__eyebrow{
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:700;
 letter-spacing:0.22em;
 text-transform:uppercase;
 color:#86868b;
 margin:0 0 16px;
}
.fx-picker__h1{
 font-family:'Cormorant Garamond',serif;
 font-size:clamp(44px,6vw,84px);
 font-weight:400;
 line-height:1;
 letter-spacing:-0.02em;
 color:#1d1d1f;
 margin:0 0 18px;
}
.fx-picker__h1 em{font-style:italic;font-weight:500;}
.fx-picker__lede{
 font-family:'Montserrat',sans-serif;
 font-size:16px;
 line-height:1.6;
 color:#4a4a4f;
 max-width:620px;
 margin:0;
}
.fx-picker__inline-link{
 color:#1d1d1f;
 border-bottom:1px solid currentColor;
 text-decoration:none;
 transition:opacity .2s ease;
}
.fx-picker__inline-link:hover{opacity:.6;}
.fx-picker__grid{
 max-width:1280px;
 margin:0 auto;
 display:grid;
 grid-template-columns:repeat(3,minmax(0,1fr));
 gap:18px;
}
.fx-tile{
 position:relative;
 display:block;
 background:#fff;
 border-radius:22px;
 overflow:hidden;
 text-decoration:none;
 color:#1d1d1f;
 transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease;
 box-shadow:0 1px 2px rgba(0,0,0,.04);
}
.fx-tile:hover{
 transform:translateY(-4px);
 box-shadow:0 24px 40px rgba(0,0,0,.10),0 6px 14px rgba(0,0,0,.05);
}
.fx-tile__img{
 aspect-ratio:5/3;
 background-size:cover;
 background-position:center;
 background-color:#e5e5ea;
 transition:transform .6s cubic-bezier(.22,1,.36,1);
}
.fx-tile:hover .fx-tile__img{transform:scale(1.04);}
.fx-tile__body{
 padding:18px 22px 22px;
 position:relative;
}
.fx-tile__tag{
 display:inline-block;
 font-family:'Montserrat',sans-serif;
 font-size:10px;
 font-weight:700;
 letter-spacing:0.16em;
 text-transform:uppercase;
 color:#86868b;
 margin:0 0 8px;
}
.fx-tile__name{
 font-family:'Cormorant Garamond',serif;
 font-size:28px;
 font-weight:500;
 letter-spacing:-0.01em;
 color:#1d1d1f;
 margin:0 0 6px;
 line-height:1.1;
}
.fx-tile__meta{
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 color:#6e6e73;
 margin:0;
 line-height:1.5;
 padding-right:28px;
}
.fx-tile__arrow{
 position:absolute;
 right:22px;
 bottom:22px;
 font-size:18px;
 color:#1d1d1f;
 opacity:.55;
 transition:transform .3s cubic-bezier(.22,1,.36,1),opacity .2s ease;
}
.fx-tile:hover .fx-tile__arrow{opacity:1;transform:translateX(4px);}
.fx-picker__foot{
 max-width:1280px;
 margin:clamp(28px,4vh,40px) auto 0;
 display:flex;
 gap:12px;
 flex-wrap:wrap;
}
@media (max-width:980px){
 .fx-picker__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
}
@media (max-width:600px){
 .fx-picker{padding-top:96px;}
 .fx-picker__grid{grid-template-columns:1fr;}
 .fx-picker__h1{font-size:clamp(36px,10vw,52px);}
 .fx-picker__foot{flex-direction:column;}
 .fx-picker__foot .btn{width:100%;text-align:center;}
 .fx-tile__name{font-size:24px;}
}
.fx-hero{
 background:#f5f5f7;
 padding:clamp(110px,13vh,150px) 0 clamp(56px,8vh,88px);
}
.fx-hero__inner{
 max-width:1240px;
 margin:0 auto;
 padding:0 clamp(20px,4vw,56px);
 display:grid;
 grid-template-columns:minmax(0,0.95fr) minmax(0,1.05fr);
 gap:clamp(40px,6vw,80px);
 align-items:center;
}
.fx-hero__copy{display:flex;flex-direction:column;gap:20px;}
.fx-hero__eyebrow{
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:700;
 letter-spacing:0.22em;
 text-transform:uppercase;
 color:#86868b;
 margin:0;
}
.fx-hero__h1{
 font-family:'Cormorant Garamond',serif;
 font-size:clamp(40px,5.5vw,72px);
 font-weight:400;
 line-height:1.02;
 letter-spacing:-0.018em;
 color:#1d1d1f;
 margin:0;
}
.fx-hero__h1 em{font-style:italic;font-weight:500;}
.fx-hero__lede{
 font-family:'Montserrat',sans-serif;
 font-size:16px;
 line-height:1.6;
 color:#4a4a4f;
 max-width:480px;
 margin:0;
}
.fx-hero__cta{
 display:flex;
 gap:12px;
 margin-top:8px;
 flex-wrap:wrap;
}
.fx-hero__media{
 border-radius:24px;
 overflow:hidden;
 aspect-ratio:5/4;
 max-height:520px;
 background:#e5e5ea;
 box-shadow:0 30px 60px rgba(0,0,0,.10),0 8px 20px rgba(0,0,0,.06);
}
.fx-hero__media img{
 width:100%;
 height:100%;
 object-fit:cover;
 display:block;
}
@media (max-width:900px){
 .fx-hero__inner{grid-template-columns:1fr;gap:32px;}
 .fx-hero__h1{font-size:clamp(36px,9vw,52px);}
 .fx-hero__media{aspect-ratio:4/3;max-height:360px;border-radius:18px;}
}
html,body{overflow-x:hidden;max-width:100vw;}
@media (max-width:768px){
 
 
 header.header>nav,
 header.header>.lang-switch{display:none !important;}
 header.header{
 padding:0 16px;
 height:60px;
 justify-content:space-between;
}
 header.header>.logo{margin:0;}
 header.header>.logo .logo-img{height:30px;}
 header.header>.mobile-menu-btn,
 header.header .mobile-menu-btn{display:flex;}
 
 header.header>a.btn{display:none;}
 
 .fx-stack{padding:84px 0 48px;}
 .fx-stack__inner{padding:0 16px;gap:28px;}
 .fx-stack__h1{font-size:clamp(30px,8.5vw,42px);line-height:1.08;}
 .fx-stack__lede{font-size:14px;}
 .fx-stack__seg{
 width:100%;
 overflow-x:auto;
 -webkit-overflow-scrolling:touch;
 flex-wrap:nowrap;
 scrollbar-width:none;
}
 .fx-stack__seg::-webkit-scrollbar{display:none;}
 .fx-stack__seg button{flex:0 0 auto;padding:8px 12px;font-size:11px;}
 .fx-stack__meta{grid-template-columns:1fr;gap:10px;padding-top:14px;}
 .fx-stack__cta{flex-direction:column;align-items:stretch;}
 .fx-stack__cta .btn{width:100%;text-align:center;}
 
 .fx-mat-hero{
 padding:100px 16px 40px !important;
 grid-template-columns:1fr !important;
 gap:28px !important;
}
 .fx-mat-hero__h1{font-size:clamp(34px,9vw,48px) !important;}
 .fx-mat-hero__lede{font-size:14px !important;}
 .fx-mat-hero__image{aspect-ratio:4/3 !important;border-radius:18px !important;}
 .fx-mat-hero__chip{gap:8px !important;}
 .fx-mat-hero__chip span{font-size:10px !important;padding:8px 10px !important;}
 .fx-mat-hero__cta-row{flex-direction:column;align-items:stretch;}
 .fx-mat-hero__cta-row .btn{width:100%;text-align:center;}
 
 .fx-mat-section{padding:48px 16px !important;}
 .fx-mat-section h2{font-size:clamp(28px,7vw,38px) !important;}
 
 .fx-spec-row{
 grid-template-columns:28px 1fr !important;
 gap:10px !important;
 padding:14px 4px !important;
 align-items:start;
}
 .fx-spec-row svg{width:18px;height:18px;}
 .fx-spec-key{font-size:12px !important;}
 .fx-spec-val{grid-column:2 !important;font-size:13px !important;}
 
 .fx-stats-row,
 .fx-systems-grid,
 .fx-pitfalls-grid,
 .fx-buildup,
 .quality-grid,
 .services-grid,
 .trust-grid{
 grid-template-columns:1fr !important;
 gap:16px !important;
}
 .fx-process{grid-template-columns:1fr !important;gap:20px !important;}
 .fx-process::before{display:none !important;}
 
 .hero-split{grid-template-columns:1fr !important;min-height:auto !important;height:auto !important;}
 .hero-split__panel{min-height:50vh;}
 
 .footer-grid{grid-template-columns:1fr 1fr !important;gap:24px !important;}
 .footer-brand{grid-column:1 / -1;}
 .footer-column h4{font-size:12px !important;}
 .footer-column li,.footer-column a{font-size:13px !important;}
 
 .container{padding-left:16px !important;padding-right:16px !important;}
 
 .section-title{font-size:clamp(28px,7vw,38px) !important;}
 
 .fx-toc{display:none !important;}
 
 .fx-wa{font-size:12px !important;padding:10px 14px !important;bottom:16px !important;right:16px !important;}
 
 table,pre{max-width:100%;overflow-x:auto;display:block;}
 
 .fx-sample-modal{width:calc(100vw - 24px) !important;padding:20px !important;}
 
 .fx-decision{padding:24px 16px !important;}
 .fx-decision__buttons{grid-template-columns:1fr !important;}
}
@media (max-width:480px){
 .fx-stack__h1{font-size:28px;}
 .fx-stack__meta{padding-top:10px;}
 .footer-grid{grid-template-columns:1fr !important;}
 .fx-mat-hero__chip{flex-direction:column;align-items:flex-start;}
 .fx-mat-hero__chip span{width:100%;}
}
.fx-plate-sheet{
 display:none;
 position:fixed;
 left:12px;right:12px;
 bottom:86px;
 z-index:880;
 background:#1d1d1f;
 color:#f5f5f7;
 border-radius:22px 22px 18px 18px;
 padding:10px 16px 18px;
 max-height:56vh;
 overflow:auto;
 transform:translateY(120%);
 transition:transform .35s var(--ease-out,cubic-bezier(.22,1,.36,1)),opacity .25s ease;
 box-shadow:0 -16px 40px rgba(0,0,0,.32),0 -2px 8px rgba(0,0,0,.16);
 -webkit-overflow-scrolling:touch;
}
.fx-plate-sheet[data-open]{transform:translateY(0);}
.fx-plate-sheet__grab{
 width:38px;height:4px;
 background:rgba(255,255,255,.32);
 border-radius:999px;
 margin:0 auto 12px;
}
.fx-plate-sheet__title{
 font-family:'Montserrat',sans-serif;
 font-size:10px;font-weight:700;
 letter-spacing:.22em;text-transform:uppercase;
 color:rgba(255,255,255,.55);
 margin:0 0 12px;
}
.fx-plate-sheet__list{
 list-style:none;padding:0;margin:0;
 display:grid;gap:8px;
}
.fx-plate-sheet__list li{
 display:grid;
 grid-template-columns:8px 1fr;
 gap:12px;
 padding:10px 12px;
 border-radius:14px;
 background:rgba(255,255,255,.04);
 border:1px solid rgba(255,255,255,.06);
}
.fx-plate-sheet__list li::before{
 content:"";align-self:center;
 width:8px;height:8px;
 border-radius:999px;
 background:var(--row-color,#d4a857);
}
.fx-plate-sheet__list .row-label{
 font-family:'Cormorant Garamond',serif;
 font-size:17px;font-weight:500;
 color:#f5f5f7;line-height:1.2;
}
.fx-plate-sheet__list .row-sku{
 font-family:'Montserrat',sans-serif;
 font-size:11px;color:rgba(255,255,255,.6);
 margin-top:2px;line-height:1.4;
}
@media (max-width:768px){
 .fx-plate-sheet{display:block;}
 
 .fx-layer-tag{display:none !important;}
}
.fx-scroll-progress{
 position:fixed;top:0;left:0;
 height:2px;width:0%;
 background:linear-gradient(90deg,#1d1d1f,#6e6e73);
 z-index:1500;
 transition:width .12s linear;
 pointer-events:none;
}
@media (max-width:768px){
 
 .fx-picker__grid{
 grid-template-columns:none !important;
 grid-auto-flow:column !important;
 grid-auto-columns:82% !important;
 overflow-x:auto;
 scroll-snap-type:x mandatory;
 scroll-padding-left:16px;
 padding-bottom:8px;
 -webkit-overflow-scrolling:touch;
 scrollbar-width:none;
}
 .fx-picker__grid::-webkit-scrollbar{display:none;}
 .fx-picker__grid .fx-tile{scroll-snap-align:center;}
 
 .fx-tile{transition:transform .25s var(--ease-out),box-shadow .25s var(--ease-out);}
 .fx-tile:active{transform:scale(.97);opacity:.92;}
 
 .fx-audience__row{
 grid-template-columns:88% 88% 88% !important;
 grid-auto-flow:column;
 overflow-x:auto;
 scroll-snap-type:x mandatory;
 scroll-padding-left:16px;
 padding-bottom:8px;
}
 .fx-audience__card{scroll-snap-align:center;}
 
 .fx-plate-hint{font-size:9px !important;bottom:4px !important;}
}
.fx-plate-section{animation:fxPlateRise 1.1s var(--ease-spring) both;}
@keyframes fxPlateRise{
 from{opacity:0;filter:blur(14px);transform:translateY(40px) scale(.97);}
 to{opacity:1;filter:blur(0);transform:none;}
}
@media (prefers-reduced-motion:reduce){
 .fx-plate-section{animation:none;}
}
.fx-hero-lab{
 
 padding:clamp(128px,16vh,200px) clamp(28px,5vw,88px) clamp(80px,10vh,120px);
 max-width:1680px;
 margin:0 auto;
 background:#fff;
 scroll-margin-top:120px;
 overflow:visible;
}
.fx-hero-lab .fx-plate-shell{display:none;}
.fx-hero-lab .fx-layer-tag{display:none !important;}
.fx-hero-lab__intro{
 max-width:820px;
 margin:0 0 clamp(48px,6vh,80px);
 text-align:left;
}
.fx-hero-lab__intro .fx-plate-eyebrow{margin-bottom:16px;}
.fx-hero-lab__intro .fx-plate-h2{margin-bottom:16px;}
.fx-hero-lab__intro .fx-plate-meta{max-width:620px;margin-bottom:0;}
.fx-hero-lab__grid{
 display:grid;
 grid-template-columns:280px minmax(0,1fr) 360px;
 gap:clamp(40px,5vw,80px);
 align-items:start;
 min-height:600px;
}
@media (min-width:981px){
 .fx-hero-lab__stage{
 position:sticky;
 top:88px;
 align-self:start;
}
 .fx-hero-lab__materials{
 position:sticky;
 top:88px;
 align-self:start;
}
}
.fx-hero-lab__panel{margin-left:clamp(20px,3vw,60px);}
@media (max-width:980px){
 .fx-hero-lab__panel{margin-left:0;}
}
.fx-hero-lab__materials{
 display:flex;
 flex-direction:column;
 gap:28px;
 padding-top:4px;
}
.fx-hero-lab__group{display:flex;flex-direction:column;gap:8px;}
.fx-hero-lab__group-label{
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 font-weight:600;
 letter-spacing:.2em;
 text-transform:uppercase;
 color:#6e6e73;
 margin:0 0 8px;
}
.fx-hero-lab__mlist{
 list-style:none;
 margin:0;
 padding:0;
 display:flex;
 flex-direction:column;
 gap:4px;
}
.fx-hero-lab__mat{
 display:flex;
 align-items:center;
 gap:12px;
 width:100%;
 padding:10px 14px;
 background:#fff;
 border:1px solid transparent;
 border-radius:14px;
 font-family:'Montserrat',sans-serif;
 font-size:13px;
 font-weight:500;
 letter-spacing:0;
 color:#1d1d1f;
 text-align:left;
 cursor:pointer;
 transition:background .28s cubic-bezier(.22,1,.36,1),
 color .28s cubic-bezier(.22,1,.36,1),
 border-color .28s cubic-bezier(.22,1,.36,1),
 transform .28s cubic-bezier(.22,1,.36,1);
}
.fx-hero-lab__mat:hover{background:rgba(0,0,0,.025);}
.fx-hero-lab__mat.is-active{
 background:#1d1d1f;
 color:#fff;
}
.fx-hero-lab__mat.is-active .fx-hero-lab__swatch{
 width:22px;height:22px;
 box-shadow:0 0 0 2px rgba(255,255,255,.24),
 inset 0 0 0 .5px rgba(0,0,0,.08),
 inset 0 1px 2px rgba(0,0,0,.25);
}
.fx-hero-lab__swatch{
 width:18px;height:18px;
 border-radius:50%;
 flex-shrink:0;
 box-shadow:inset 0 0 0 1px rgba(0,0,0,.08);
 transition:box-shadow .28s ease;
}
.fx-hero-lab__mat-label{flex:1;line-height:1.2;}
.fx-hero-lab__stage{
 position:relative;
 display:grid;
 grid-template-columns:clamp(150px,13vw,200px) minmax(0,1fr);
 
 column-gap:clamp(32px,4vw,72px);
 align-items:start;
 min-height:600px;
}
@media (max-width:1180px){
 .fx-hero-lab__stage{
 grid-template-columns:1fr;
 column-gap:0;
}
}
.fx-hero-lab__stage .fx-plate-wrap{
 position:relative;
 width:100%;
 height:640px;
 display:flex;
 align-items:center;
 justify-content:center;
 perspective:2400px;
 perspective-origin:50% 50%;
}
.fx-hero-lab__stage .fx-plate-wrap::before{
 content:"";
 position:absolute;
 width:700px;height:78px;
 bottom:90px;
 left:50%;
 transform:translateX(-50%);
 background:radial-gradient(50% 50% at 50% 50%,rgba(0,0,0,.36),transparent 70%);
 filter:blur(32px);
 opacity:.96;
 max-width:96%;
}
.fx-hero-lab__stage .fx-plate{
 width:min(500px,75vw);
 height:min(500px,75vw);
}
.fx-hero-lab__stage .fx-l-body{
 --h:var(--plate-body-h,16px);
}
.fx-hero-lab__stage .fx-l-body .fx-face-top{
 filter:var(--plate-body-filter,none);
 transition:filter .42s cubic-bezier(.22,1,.36,1);
}
.fx-plate[data-system="terrazzo"] .fx-l-body .fx-face-N,
.fx-plate[data-system="terrazzo"] .fx-l-body .fx-face-S,
.fx-plate[data-system="terrazzo"] .fx-l-body .fx-face-E,
.fx-plate[data-system="terrazzo"] .fx-l-body .fx-face-W,
.fx-plate[data-system="terrazzo-dark"] .fx-l-body .fx-face-N,
.fx-plate[data-system="terrazzo-dark"] .fx-l-body .fx-face-S,
.fx-plate[data-system="terrazzo-dark"] .fx-l-body .fx-face-E,
.fx-plate[data-system="terrazzo-dark"] .fx-l-body .fx-face-W,
.fx-plate[data-system="terrazzo-light"] .fx-l-body .fx-face-N,
.fx-plate[data-system="terrazzo-light"] .fx-l-body .fx-face-S,
.fx-plate[data-system="terrazzo-light"] .fx-l-body .fx-face-E,
.fx-plate[data-system="terrazzo-light"] .fx-l-body .fx-face-W{
 background-color:var(--plate-body);
 background-image:
 radial-gradient(circle at 15% 30%,rgba(255,255,255,.65) 0 1.2px,transparent 1.6px),
 radial-gradient(circle at 38% 60%,rgba(255,255,255,.55) 0 1.5px,transparent 2px),
 radial-gradient(circle at 62% 25%,rgba(0,0,0,.55) 0 1px,transparent 1.5px),
 radial-gradient(circle at 80% 70%,rgba(0,0,0,.55) 0 1.4px,transparent 1.8px),
 radial-gradient(circle at 50% 50%,rgba(255,255,255,.45) 0 1.1px,transparent 1.5px),
 radial-gradient(ellipse 5px 3px at 25% 70%,rgba(0,0,0,.45),transparent 80%),
 radial-gradient(ellipse 4px 2.5px at 70% 35%,rgba(255,255,255,.4),transparent 85%),
 linear-gradient(180deg,rgba(255,255,255,.18) 0 6%,transparent 14%,transparent 86%,rgba(0,0,0,.20) 100%);
 background-size:
 14px 16px,18px 14px,12px 14px,16px 12px,11px 13px,
 20px 14px,22px 16px,100% 100%;
 background-blend-mode:normal,normal,multiply,multiply,normal,multiply,screen,overlay;
}
.fx-plate[data-system="epoxy"] .fx-l-body .fx-face-N,
.fx-plate[data-system="epoxy"] .fx-l-body .fx-face-S,
.fx-plate[data-system="epoxy"] .fx-l-body .fx-face-E,
.fx-plate[data-system="epoxy"] .fx-l-body .fx-face-W,
.fx-plate[data-system="epoxy-light"] .fx-l-body .fx-face-N,
.fx-plate[data-system="epoxy-light"] .fx-l-body .fx-face-S,
.fx-plate[data-system="epoxy-light"] .fx-l-body .fx-face-E,
.fx-plate[data-system="epoxy-light"] .fx-l-body .fx-face-W{
 background:
 linear-gradient(180deg,rgba(255,255,255,.22) 0 4%,transparent 18%,transparent 50%,rgba(0,0,0,.10) 96%,rgba(0,0,0,.18) 100%),
 linear-gradient(90deg,rgba(255,255,255,.04) 0%,rgba(0,0,0,.06) 50%,rgba(255,255,255,.04) 100%),
 var(--plate-body);
 box-shadow:inset 0 1px 0 rgba(255,255,255,.18);
}
.fx-plate[data-system="micro"] .fx-l-body .fx-face-N,
.fx-plate[data-system="micro"] .fx-l-body .fx-face-S,
.fx-plate[data-system="micro"] .fx-l-body .fx-face-E,
.fx-plate[data-system="micro"] .fx-l-body .fx-face-W{
 background:
 linear-gradient(180deg,
 rgba(255,255,255,.2) 0%,rgba(255,255,255,.05) 18%,
 rgba(0,0,0,.20) 30%,rgba(0,0,0,.04) 32%,
 rgba(255,255,255,.06) 56%,rgba(0,0,0,.18) 64%,
 rgba(0,0,0,.05) 66%,rgba(0,0,0,.18) 100%),
 var(--plate-body);
}
.fx-plate[data-system="purcem"] .fx-l-body .fx-face-N,
.fx-plate[data-system="purcem"] .fx-l-body .fx-face-S,
.fx-plate[data-system="purcem"] .fx-l-body .fx-face-E,
.fx-plate[data-system="purcem"] .fx-l-body .fx-face-W{
 background-color:var(--plate-body);
 background-image:
 radial-gradient(circle at 20% 30%,rgba(0,0,0,.32) 0 .6px,transparent 1px),
 radial-gradient(circle at 60% 50%,rgba(0,0,0,.28) 0 .8px,transparent 1.2px),
 radial-gradient(circle at 30% 75%,rgba(255,255,255,.4) 0 .6px,transparent 1px),
 radial-gradient(circle at 80% 25%,rgba(255,255,255,.3) 0 .7px,transparent 1.1px),
 radial-gradient(circle at 50% 90%,rgba(0,0,0,.22) 0 .9px,transparent 1.3px),
 linear-gradient(180deg,rgba(255,255,255,.12) 0 6%,transparent 14%,transparent 86%,rgba(0,0,0,.20) 100%);
 background-size:7px 9px,9px 11px,6px 8px,10px 9px,8px 12px,100% 100%;
}
.fx-plate[data-system="mma"] .fx-l-body .fx-face-N,
.fx-plate[data-system="mma"] .fx-l-body .fx-face-S,
.fx-plate[data-system="mma"] .fx-l-body .fx-face-E,
.fx-plate[data-system="mma"] .fx-l-body .fx-face-W{
 background:
 linear-gradient(180deg,rgba(255,255,255,.14) 0 4%,transparent 16%,transparent 60%,rgba(0,0,0,.18) 96%,rgba(0,0,0,.30) 100%),
 var(--plate-body);
 box-shadow:inset 0 1px 0 rgba(255,255,255,.12);
}
.fx-plate[data-system="rubber"] .fx-l-body .fx-face-N,
.fx-plate[data-system="rubber"] .fx-l-body .fx-face-S,
.fx-plate[data-system="rubber"] .fx-l-body .fx-face-E,
.fx-plate[data-system="rubber"] .fx-l-body .fx-face-W{
 background-color:var(--plate-body);
 background-image:
 radial-gradient(circle at 22% 30%,rgba(255,255,255,.18) 0 1.6px,transparent 2.2px),
 radial-gradient(circle at 60% 60%,rgba(0,0,0,.45) 0 2px,transparent 2.6px),
 radial-gradient(circle at 35% 75%,rgba(255,255,255,.12) 0 1.8px,transparent 2.4px),
 radial-gradient(circle at 80% 22%,rgba(0,0,0,.40) 0 1.6px,transparent 2.2px),
 linear-gradient(180deg,rgba(255,255,255,.10) 0 6%,transparent 14%,transparent 86%,rgba(0,0,0,.22) 100%);
 background-size:12px 14px,16px 18px,14px 16px,13px 15px,100% 100%;
}
.fx-plate[data-system="rubber"] .fx-l-body .fx-face-top{
 background-color:var(--plate-body);
 background-image:
 radial-gradient(circle at 18% 22%,rgba(255,255,255,.22) 0 2.5px,transparent 3.2px),
 radial-gradient(circle at 70% 38%,rgba(0,0,0,.40) 0 3px,transparent 3.8px),
 radial-gradient(circle at 38% 70%,rgba(255,255,255,.16) 0 2.8px,transparent 3.4px),
 radial-gradient(circle at 84% 78%,rgba(0,0,0,.45) 0 2.5px,transparent 3.2px),
 radial-gradient(circle at 50% 50%,rgba(255,255,255,.10) 0 2px,transparent 2.8px);
 background-size:18px 20px,24px 22px,20px 22px,22px 24px,16px 18px;
}
.fx-plate[data-system="rubber"] .fx-l-body .fx-face-top svg{opacity:0;}
.fx-l-topcoat .fx-face-N,
.fx-l-topcoat .fx-face-S,
.fx-l-topcoat .fx-face-E,
.fx-l-topcoat .fx-face-W{
 background:
 linear-gradient(180deg,rgba(255,255,255,.45) 0 18%,rgba(255,255,255,.10) 35%,rgba(0,0,0,.10) 100%);
}
.fx-hero-lab__strips,
.fx-hero-lab__flecks,
.fx-hero-lab__texture,
.fx-hero-lab__sheen{
 position:absolute;
 inset:0;
 pointer-events:none;
 transition:opacity .42s cubic-bezier(.22,1,.36,1);
}
.fx-hero-lab__strips{
 opacity:0;
 mix-blend-mode:normal;
}
.fx-hero-lab__flecks{
 opacity:0;
 background:none;
 transition:opacity .42s cubic-bezier(.22,1,.36,1),background .42s cubic-bezier(.22,1,.36,1);
}
.fx-hero-lab__flecks.is-on{opacity:1;}
.fx-hero-lab__flecks.mode-fine{
 background-image:
 radial-gradient(circle at 12% 18%,rgba(255,255,255,.55) 0 1.4px,transparent 2px),
 radial-gradient(circle at 58% 32%,rgba(0,0,0,.55) 0 1.2px,transparent 1.8px),
 radial-gradient(circle at 78% 64%,rgba(255,255,255,.45) 0 1.3px,transparent 1.9px),
 radial-gradient(circle at 32% 80%,rgba(255,255,255,.55) 0 1.4px,transparent 2px);
 background-size:22px 24px,28px 30px,18px 22px,24px 26px;
}
.fx-hero-lab__flecks.mode-coarse{
 background-image:
 radial-gradient(circle at 18% 22%,rgba(255,255,255,.62) 0 3px,transparent 4px),
 radial-gradient(circle at 64% 38%,rgba(0,0,0,.55) 0 3.4px,transparent 4.5px),
 radial-gradient(circle at 38% 78%,rgba(255,255,255,.55) 0 3.2px,transparent 4.2px),
 radial-gradient(circle at 80% 70%,rgba(0,0,0,.55) 0 3px,transparent 4px);
 background-size:36px 38px,42px 44px,38px 40px,40px 42px;
}
.fx-hero-lab__flecks.mode-mica{
 background-image:
 radial-gradient(circle at 14% 22%,rgba(255,240,200,.55) 0 1.6px,transparent 2.4px),
 radial-gradient(circle at 60% 50%,rgba(220,200,160,.55) 0 1.4px,transparent 2.2px),
 radial-gradient(circle at 80% 78%,rgba(255,250,210,.45) 0 1.6px,transparent 2.4px);
 background-size:18px 20px,22px 24px,20px 22px;
 mix-blend-mode:screen;
}
.fx-hero-lab__flecks.mode-metallic{
 background:
 radial-gradient(ellipse at 22% 18%,rgba(220,210,200,.45),transparent 30%),
 radial-gradient(ellipse at 70% 52%,rgba(180,170,160,.45),transparent 35%),
 radial-gradient(ellipse at 38% 80%,rgba(220,210,200,.40),transparent 30%),
 linear-gradient(135deg,rgba(255,255,255,.10) 0%,rgba(0,0,0,.10) 50%,rgba(255,255,255,.10) 100%);
 mix-blend-mode:overlay;
}
.fx-hero-lab__texture{opacity:0;}
.fx-hero-lab__texture.is-on{opacity:1;}
.fx-hero-lab__texture.mode-trowel{
 background:
 repeating-linear-gradient(38deg,rgba(0,0,0,.12) 0 .5px,transparent .5px 8px),
 repeating-linear-gradient(38deg,rgba(255,255,255,.12) 0 .5px,transparent .5px 14px);
 mix-blend-mode:overlay;
}
.fx-hero-lab__texture.mode-wave{
 background:
 repeating-radial-gradient(ellipse 40px 18px at 25% 25%,rgba(0,0,0,.10) 0 .5px,transparent .5px 18px),
 repeating-radial-gradient(ellipse 60px 22px at 75% 75%,rgba(255,255,255,.10) 0 .5px,transparent .5px 22px);
 mix-blend-mode:overlay;
}
.fx-hero-lab__texture.surf-textured,
.fx-hero-lab__texture.bc-fine{
 background-image:
 radial-gradient(circle at 20% 20%,rgba(0,0,0,.30) 0 1px,transparent 1.4px),
 radial-gradient(circle at 70% 50%,rgba(0,0,0,.25) 0 .8px,transparent 1.2px),
 radial-gradient(circle at 40% 80%,rgba(255,255,255,.18) 0 .9px,transparent 1.3px),
 radial-gradient(circle at 88% 78%,rgba(0,0,0,.28) 0 1px,transparent 1.4px);
 background-size:9px 11px,11px 13px,8px 10px,10px 12px;
 mix-blend-mode:multiply;
}
.fx-hero-lab__texture.surf-broadcast,
.fx-hero-lab__texture.bc-coarse{
 background-image:
 radial-gradient(circle at 18% 22%,rgba(0,0,0,.45) 0 2.4px,transparent 3.2px),
 radial-gradient(circle at 64% 36%,rgba(255,255,255,.30) 0 2.6px,transparent 3.4px),
 radial-gradient(circle at 38% 78%,rgba(0,0,0,.40) 0 2.4px,transparent 3.2px),
 radial-gradient(circle at 82% 72%,rgba(255,255,255,.30) 0 2.4px,transparent 3.2px);
 background-size:28px 30px,34px 36px,30px 32px,32px 34px;
 mix-blend-mode:multiply;
}
.fx-hero-lab__sheen{
 background:
 radial-gradient(ellipse at 24% 18%,rgba(255,255,255,.55),transparent 50%),
 linear-gradient(118deg,transparent 38%,rgba(255,255,255,.30) 50%,transparent 62%);
 mix-blend-mode:screen;
 opacity:calc(.4+.55 * var(--plate-gloss,.4));
 pointer-events:none;
 transition:opacity .42s cubic-bezier(.22,1,.36,1);
}
.fx-hero-lab__stage .fx-l-body .fx-face-top{
 position:relative;
 overflow:hidden;
 box-shadow:inset 0 0 80px rgba(0,0,0,.18);
}
.fx-hero-lab__panel{
 display:flex;
 flex-direction:column;
 gap:20px;
 padding-top:4px;
}
.fx-hero-lab__controls{
 display:flex;
 flex-direction:column;
 gap:18px;
}
.fx-hero-lab__controls .fx-hero-lab__group{
 padding-bottom:18px;
 border-bottom:1px solid #e8e8ed;
}
.fx-hero-lab__controls .fx-hero-lab__group:last-child{border-bottom:0;padding-bottom:0;}
.fx-hero-lab__ctrl-label{
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 font-weight:600;
 letter-spacing:.2em;
 text-transform:uppercase;
 color:#6e6e73;
 margin:0 0 12px;
}
.fx-hero-lab__btnrow{
 display:flex;
 flex-wrap:wrap;
 gap:6px;
}
.fx-hero-lab__btn{
 display:inline-flex;
 align-items:center;
 gap:8px;
 padding:8px 14px;
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 font-weight:500;
 letter-spacing:0;
 color:#1d1d1f;
 background:#fff;
 border:1px solid #d2d2d7;
 border-radius:16px;
 cursor:pointer;
 transition:background .28s cubic-bezier(.22,1,.36,1),
 color .28s cubic-bezier(.22,1,.36,1),
 border-color .28s cubic-bezier(.22,1,.36,1),
 box-shadow .28s cubic-bezier(.22,1,.36,1),
 transform .28s cubic-bezier(.22,1,.36,1);
 user-select:none;
 white-space:nowrap;
}
.fx-hero-lab__btn:hover{
 background:#f5f5f7;
 border-color:#c7c7cc;
 transform:translateY(-1px);
}
.fx-hero-lab__btn.is-active{
 background:#1d1d1f;
 color:#fff;
 border-color:#1d1d1f;
 box-shadow:0 0 0 1px #fff,0 0 0 3px #1d1d1f,0 6px 14px rgba(29,29,31,.18);
 transform:translateY(-1px);
}
.fx-hero-lab__btn.is-active .fx-hero-lab__btn-dot{
 box-shadow:0 0 0 1.5px rgba(255,255,255,.28),
 inset 0 0 0 .5px rgba(0,0,0,.10),
 inset 0 1px 2px rgba(0,0,0,.25);
}
.fx-hero-lab__btn-dot{
 width:16px;height:16px;
 border-radius:50%;
 flex-shrink:0;
 box-shadow:inset 0 0 0 1px rgba(0,0,0,.10),
 inset 0 1px 2px rgba(0,0,0,.18),
 0 1px 1px rgba(255,255,255,.55);
 transition:box-shadow .28s ease;
}
.fx-hero-lab__btn-label{line-height:1.2;}
.fx-hero-lab__meta{
 display:grid;
 grid-template-columns:1fr;
 gap:12px;
 padding:18px 0 4px;
 border-top:1px solid #e8e8ed;
 font-family:'Montserrat',sans-serif;
}
.fx-hero-lab__meta>div{
 display:flex;flex-direction:column;gap:2px;
}
.fx-hero-lab__meta-lbl{
 font-size:10px;font-weight:600;
 letter-spacing:.26em;text-transform:uppercase;
 color:#86868b;
}
.fx-hero-lab__meta b{
 font-size:13px;font-weight:600;
 color:#1d1d1f;
}
.fx-hero-lab__cta{
 display:flex;
 flex-direction:column;
 gap:10px;
 padding-top:8px;
}
.fx-hero-lab__cta .btn{width:100%;text-align:center;justify-content:center;}
.fx-hero-lab__cta-primary span{
 display:inline-block;
 margin-left:6px;
 transition:transform .28s cubic-bezier(.22,1,.36,1);
}
.fx-hero-lab__cta-primary:hover span{transform:translateX(4px);}
@media (max-width:980px){
 .fx-hero-lab{
 padding:clamp(112px,18vh,160px) 20px 60px;
}
 .fx-hero-lab__intro{margin-bottom:28px;}
 .fx-hero-lab__grid{
 grid-template-columns:1fr;
 gap:28px;
 min-height:0;
}
 
 .fx-hero-lab__materials{
 flex-direction:column;
 order:-1;
 gap:12px;
}
 .fx-hero-lab__group-label{padding-left:4px;}
 .fx-hero-lab__mlist{
 display:flex;
 flex-direction:row;
 overflow-x:auto;
 overflow-y:hidden;
 scroll-snap-type:x mandatory;
 -webkit-overflow-scrolling:touch;
 gap:8px;
 padding:4px 4px 12px;
 margin:0 -20px;
 padding-left:20px;
 padding-right:20px;
 scrollbar-width:none;
}
 .fx-hero-lab__mlist::-webkit-scrollbar{display:none;}
 .fx-hero-lab__mlist>li{flex:0 0 auto;scroll-snap-align:start;}
 .fx-hero-lab__mat{
 padding:8px 14px;
 border:1px solid #d2d2d7;
 border-radius:999px;
 white-space:nowrap;
}
 .fx-hero-lab__stage{min-height:0;order:0;}
 .fx-hero-lab__stage .fx-plate-wrap{height:440px;}
 .fx-hero-lab__panel{order:1;}
 .fx-hero-lab__meta{grid-template-columns:repeat(3,1fr);gap:16px;}
 .fx-hero-lab__cta{flex-direction:column;}
}
@media (max-width:600px){
 .fx-hero-lab__stage .fx-plate-wrap{height:360px;}
 .fx-hero-lab__btnrow{gap:5px;}
 .fx-hero-lab__btn{padding:6px 10px;font-size:11.5px;}
 .fx-hero-lab__meta{grid-template-columns:repeat(2,1fr);}
}
.fx-hero-lab__stage:empty,
.fx-hero-lab__stage .fx-plate-wrap:empty{
 min-height:520px;
}
@media (prefers-reduced-motion:reduce){
 .fx-hero-lab__btn,
 .fx-hero-lab__mat,
 .fx-hero-lab__strips,
 .fx-hero-lab__flecks,
 .fx-hero-lab__texture,
 .fx-hero-lab__marking,
 .fx-hero-lab__sheen,
 .fx-hero-lab__cta-primary span{transition:none;}
 .fx-plate{transition:none !important;}
}
.fx-hero-lab__sr-live{
 position:absolute !important;
 width:1px;height:1px;
 padding:0;margin:-1px;
 overflow:hidden;clip:rect(0,0,0,0);
 white-space:nowrap;border:0;
}
.fx-hero-lab__cta-helper{
 font-size:12px;
 color:#86868b;
 margin:4px 0 0;
 text-align:center;
 font-family:'Montserrat',sans-serif;
}
.fx-hero-lab__intro{
 opacity:0;
 transform:translateY(20px);
 transition:opacity 600ms cubic-bezier(.22,1,.36,1),
 transform 600ms cubic-bezier(.22,1,.36,1);
}
.fx-hero-lab__intro.is-revealed{
 opacity:1;
 transform:translateY(0);
}
@media (prefers-reduced-motion:reduce){
 .fx-hero-lab__intro{opacity:1 !important;transform:none !important;transition:none !important;}
}
@keyframes fxHeroLabPulse{
 0%{box-shadow:0 0 0 0 rgba(29,29,31,0.7);}
 60%{box-shadow:0 0 0 8px rgba(29,29,31,0.0);}
 100%{box-shadow:0 0 0 0 rgba(29,29,31,0.0);}
}
.fx-hero-lab__btn.is-pulse{
 animation:fxHeroLabPulse 800ms cubic-bezier(.22,1,.36,1);
}
.fx-hero-lab__mat:focus-visible,
.fx-hero-lab__btn:focus-visible,
.fx-hero-lab__cta a:focus-visible,
.fx-plate:focus-visible{
 outline:2px solid #1d1d1f;
 outline-offset:2px;
 border-radius:inherit;
}
.fx-hero-lab__texture.rg-fine{
 background-image:
 radial-gradient(circle at 20% 20%,rgba(0,0,0,.28) 0 1px,transparent 1.4px),
 radial-gradient(circle at 70% 50%,rgba(0,0,0,.22) 0 .8px,transparent 1.2px),
 radial-gradient(circle at 40% 80%,rgba(255,255,255,.16) 0 .9px,transparent 1.3px),
 radial-gradient(circle at 88% 78%,rgba(0,0,0,.26) 0 1px,transparent 1.4px);
 background-size:9px 11px,11px 13px,8px 10px,10px 12px;
 mix-blend-mode:multiply;
}
.fx-hero-lab__texture.rg-coarse{
 background-image:
 radial-gradient(circle at 18% 22%,rgba(0,0,0,.42) 0 2.4px,transparent 3.2px),
 radial-gradient(circle at 64% 36%,rgba(255,255,255,.30) 0 2.6px,transparent 3.4px),
 radial-gradient(circle at 38% 78%,rgba(0,0,0,.40) 0 2.4px,transparent 3.2px),
 radial-gradient(circle at 82% 72%,rgba(255,255,255,.30) 0 2.4px,transparent 3.2px);
 background-size:28px 30px,34px 36px,30px 32px,32px 34px;
 mix-blend-mode:multiply;
}
.fx-hero-lab__marking{
 position:absolute;
 inset:0;
 pointer-events:none;
 opacity:0;
 transition:opacity .42s cubic-bezier(.22,1,.36,1);
 z-index:3;
}
.fx-hero-lab__marking.is-on{opacity:0.92;}
.fx-hero-lab__marking.is-yellow-zone{
 background-image:repeating-linear-gradient(
 45deg,
 rgba(241,196,15,0.92) 0 18px,
 rgba(20,20,20,0.85) 18px 32px
 );
 
 -webkit-mask-image:linear-gradient(135deg,#000 35%,transparent 65%);
 mask-image:linear-gradient(135deg,#000 35%,transparent 65%);
}
.fx-hero-lab__marking.is-white-grid{
 background-image:
 linear-gradient(to right,rgba(255,255,255,.92) 0 3px,transparent 3px 100%),
 linear-gradient(to right,transparent 0 50%,rgba(255,255,255,.92) 50% calc(50%+3px),transparent calc(50%+3px) 100%),
 linear-gradient(to bottom,rgba(255,255,255,.92) 0 3px,transparent 3px 100%),
 linear-gradient(to bottom,transparent 0 50%,rgba(255,255,255,.92) 50% calc(50%+3px),transparent calc(50%+3px) 100%);
 background-size:100% 100%;
 background-repeat:no-repeat;
}
.fx-hero-lab__marking.is-red-safety{
 background-image:
 linear-gradient(to bottom,transparent 0 70%,rgba(200,50,40,0.88) 70% 92%,transparent 92%),
 repeating-linear-gradient(45deg,rgba(255,255,255,0) 0 18px,rgba(255,255,255,.18) 18px 24px);
 background-blend-mode:normal,overlay;
}
.fx-hero-lab__marking.is-pedestrian{
 background-image:repeating-linear-gradient(
 90deg,
 rgba(255,255,255,.92) 0 22px,
 transparent 22px 44px
 );
 background-size:100% 35%;
 background-repeat:no-repeat;
 background-position:0 70%;
}
@media (max-width:1440px){
 .fx-hero-lab__grid{
 grid-template-columns:240px minmax(0,1fr) 320px;
 gap:clamp(28px,4vw,56px);
}
}
@media (max-width:1024px) and (min-width:769px){
 
 .fx-hero-lab__grid{
 grid-template-columns:220px minmax(0,1fr);
 grid-template-areas:
 "mats stage"
 "panel panel";
 gap:28px clamp(24px,4vw,56px);
}
 .fx-hero-lab__materials{grid-area:mats;}
 .fx-hero-lab__stage{grid-area:stage;}
 .fx-hero-lab__panel{grid-area:panel;}
 .fx-hero-lab__panel{
 border-top:1px solid #e8e8ed;
 padding-top:24px;
}
 .fx-hero-lab__controls{
 flex-direction:row;
 flex-wrap:wrap;
 gap:14px 28px;
}
 .fx-hero-lab__controls .fx-hero-lab__group{
 flex:1 1 240px;
 border-bottom:0;
 padding-bottom:0;
}
 .fx-hero-lab__cta{flex-direction:row;gap:12px;flex-wrap:wrap;}
 .fx-hero-lab__cta .btn{flex:1 1 220px;}
 .fx-hero-lab__cta-helper{flex:1 1 100%;}
 .fx-hero-lab__meta{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:768px){
 .fx-hero-lab__grid{
 grid-template-columns:1fr;
 grid-template-areas:none;
 gap:24px;
}
 .fx-hero-lab__panel{padding-top:0;border-top:0;}
 .fx-hero-lab__controls{flex-direction:column;}
 .fx-hero-lab__controls .fx-hero-lab__group{
 flex:none;
 border-bottom:1px solid #e8e8ed;
 padding-bottom:18px;
}
 .fx-hero-lab__controls .fx-hero-lab__group:last-child{border-bottom:0;padding-bottom:0;}
 .fx-hero-lab__cta{flex-direction:column;}
 .fx-hero-lab__cta .btn{flex:none;}
}
@media (max-width:414px){
 .fx-hero-lab{
 padding:clamp(96px,14vh,132px) 14px 48px;
}
 .fx-hero-lab__intro{margin-bottom:20px;}
 .fx-hero-lab__stage .fx-plate-wrap{height:320px;}
 .fx-hero-lab__btn{padding:5px 9px;font-size:11px;}
 .fx-hero-lab__btnrow{gap:4px;}
 .fx-hero-lab__meta{grid-template-columns:1fr;gap:10px;}
}
.fx-plate.is-dragging{
 --plate-scroll-tilt:0deg;
}
.fx-plate.is-exploded{
 --plate-scroll-tilt:0deg;
}
.fx-hero-lab__spec{
 
 align-self:center;
 width:100%;
 list-style:none;
 margin:0;
 padding:0;
 display:flex;
 flex-direction:column;
 gap:10px;
 z-index:4;
 pointer-events:none;
 font-family:'Montserrat',sans-serif;
 transition:gap .6s cubic-bezier(.22,1,.36,1);
}
.fx-hero-lab__spec-row{
 position:relative;
 display:flex;
 align-items:center;
 gap:10px;
 padding:7px 12px 7px 10px;
 background:rgba(255,255,255,.94);
 border:1px solid rgba(0,0,0,.06);
 border-radius:12px;
 box-shadow:0 1px 2px rgba(0,0,0,.04),0 8px 22px -16px rgba(0,0,0,.18);
 backdrop-filter:saturate(1.05) blur(2px);
 transform:translateX(0);
 opacity:1;
 transition:transform .6s cubic-bezier(.22,1,.36,1),
 opacity .42s cubic-bezier(.22,1,.36,1),
 background-color .28s cubic-bezier(.22,1,.36,1);
}
.fx-hero-lab__spec-row::before{
 
 content:'';
 position:absolute;
 right:-10px;
 top:50%;
 width:10px;
 height:1px;
 background:linear-gradient(to right,rgba(0,0,0,.18),transparent);
 transform:translateY(-50%);
}
.fx-hero-lab__spec-row+.fx-hero-lab__spec-row::after{
 
 content:'';
 position:absolute;
 top:-6px;
 left:18px;
 width:1px;
 height:4px;
 background:rgba(0,0,0,.08);
}
.fx-hero-lab__spec-dot{
 width:10px;
 height:10px;
 border-radius:50%;
 flex-shrink:0;
 background:var(--row-color,#ccc);
 box-shadow:inset 0 0 0 1px rgba(0,0,0,.10),0 0 0 1px rgba(255,255,255,.6);
 transition:background .42s cubic-bezier(.22,1,.36,1);
}
.fx-hero-lab__spec-text{
 display:flex;
 flex-direction:column;
 min-width:0;
 line-height:1.15;
}
.fx-hero-lab__spec-role{
 font-size:9.5px;
 font-weight:600;
 letter-spacing:.22em;
 text-transform:uppercase;
 color:#86868b;
 margin-bottom:2px;
}
.fx-hero-lab__spec-sku{
 font-size:11.5px;
 font-weight:500;
 color:#1d1d1f;
 white-space:nowrap;
 overflow:hidden;
 text-overflow:ellipsis;
}
.fx-hero-lab__spec.is-exploded{gap:28px;}
.fx-hero-lab__spec.is-exploded .fx-hero-lab__spec-row{
 transform:translateX(-6px);
 background:rgba(255,255,255,.98);
}
.fx-hero-lab__spec.is-exploded .fx-hero-lab__spec-row+.fx-hero-lab__spec-row::after{
 display:none;
}
@media (max-width:1180px){
 .fx-hero-lab__spec{display:none !important;}
}
.fx-hero-lab__stage .fx-l-body .fx-face-top{
 transition:
 filter .42s cubic-bezier(.22,1,.36,1),
 background-color .28s cubic-bezier(.22,1,.36,1);
}
.fx-hero-lab__color-tint{
 position:absolute;
 inset:0;
 background:var(--plate-tint-color,transparent);
 mix-blend-mode:multiply;
 opacity:var(--plate-tint-strength,0);
 transition:
 opacity 280ms cubic-bezier(.22,1,.36,1),
 background-color 280ms cubic-bezier(.22,1,.36,1);
 pointer-events:none;
 z-index:1;
}
.fx-l-body .fx-face-top svg.fx-plate-pattern{position:relative;z-index:0;}
.fx-hero-lab__strips{z-index:2;}
.fx-hero-lab__flecks{z-index:3;}
.fx-hero-lab__marking{z-index:4;}
.fx-hero-lab__texture{z-index:5;}
.fx-hero-lab__sheen{z-index:6;}
.fx-hero-lab__sheen{
 background:
 radial-gradient(ellipse 60% 35% at 22% 14%,
 rgba(255,255,255,calc(.55 * var(--plate-gloss-shine,.25))),
 transparent 60%),
 linear-gradient(110deg,
 transparent calc(38% - 8% * var(--plate-gloss-reflection,.18)),
 rgba(255,255,255,calc(.55 * var(--plate-gloss-reflection,.18))) 50%,
 transparent calc(62%+8% * var(--plate-gloss-reflection,.18)));
 opacity:calc(.35+.65 * var(--plate-gloss,.25));
}
.fx-plate[data-finish="wetlook"] .fx-hero-lab__sheen{
 background:
 radial-gradient(ellipse 65% 40% at 22% 14%,rgba(255,255,255,.65),transparent 60%),
 linear-gradient(110deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%),
 linear-gradient(180deg,transparent 55%,rgba(255,255,255,.18) 75%,transparent 95%);
 opacity:1;
}
.fx-plate[data-finish="glossy"] .fx-hero-lab__sheen{
 background:
 radial-gradient(ellipse 55% 30% at 24% 16%,rgba(255,255,255,.55),transparent 55%),
 linear-gradient(110deg,transparent 42%,rgba(255,255,255,.42) 50%,transparent 58%);
 opacity:.9;
}
.fx-plate[data-finish="polished"] .fx-hero-lab__sheen{
 background:
 radial-gradient(ellipse 50% 28% at 26% 18%,rgba(255,255,255,.40),transparent 55%),
 linear-gradient(110deg,transparent 44%,rgba(255,255,255,.28) 50%,transparent 56%);
 opacity:.8;
}
.fx-plate[data-finish="satin"] .fx-hero-lab__sheen{
 background:
 radial-gradient(ellipse 70% 40% at 30% 22%,rgba(255,255,255,.22),transparent 65%);
 opacity:.55;
}
.fx-plate[data-finish="matte"] .fx-hero-lab__sheen{
 background:
 radial-gradient(ellipse 80% 60% at 50% 50%,rgba(255,255,255,.04),transparent 70%);
 opacity:.35;
 mix-blend-mode:normal;
}
.fx-hero-lab__strips{
 filter:
 drop-shadow(0 1px 1px rgba(0,0,0,.35))
 drop-shadow(0 0 .5px rgba(255,255,255,.55));
 z-index:2;
}
.fx-hero-lab__texture.rg-fine{
 background-image:
 radial-gradient(circle at 50% 50%,rgba(0,0,0,.55) 0 1px,transparent 1.4px);
 background-size:6px 6px;
 opacity:.55;
 mix-blend-mode:multiply;
}
.fx-hero-lab__texture.rg-coarse{
 background-image:
 radial-gradient(circle at 50% 50%,rgba(0,0,0,.7) 0 2.4px,transparent 3px),
 radial-gradient(circle at 25% 75%,rgba(255,255,255,.35) 0 1.2px,transparent 1.6px);
 background-size:9px 9px,7px 7px;
 opacity:.9;
 mix-blend-mode:multiply;
}
.fx-plate.is-rg-coarse .fx-l-body .fx-face-top{filter:saturate(.85) brightness(.97);}
.fx-hero-lab__flecks.mode-metallic{
 background:
 radial-gradient(ellipse 14px 6px at 22% 18%,rgba(212,176,72,.85),transparent 45%),
 radial-gradient(ellipse 12px 5px at 70% 52%,rgba(166,118,40,.85),transparent 50%),
 radial-gradient(ellipse 14px 5px at 38% 80%,rgba(232,196,96,.80),transparent 45%),
 radial-gradient(ellipse 10px 4px at 58% 32%,rgba(166,118,40,.75),transparent 50%),
 radial-gradient(ellipse 13px 5px at 84% 76%,rgba(232,196,96,.75),transparent 45%);
 background-size:60px 60px,70px 70px,65px 65px,55px 55px,75px 75px;
 mix-blend-mode:screen;
}
.fx-hero-lab__marking.is-yellow-zone{
 background-image:repeating-linear-gradient(
 45deg,
 rgba(245,200,66,0.94) 0 14px,
 rgba(26,26,26,0.92) 14px 26px
 );
 -webkit-mask-image:linear-gradient(135deg,#000 60%,transparent 80%);
 mask-image:linear-gradient(135deg,#000 60%,transparent 80%);
}
.fx-hero-lab__marking.is-red-safety{
 background-image:
 linear-gradient(to bottom,transparent 0 78%,rgba(200,48,42,0.94) 78% 100%);
}
.fx-hero-lab__marking.is-pedestrian{
 background-image:repeating-linear-gradient(
 90deg,
 rgba(250,250,250,.94) 0 14px,
 transparent 14px 22px
 );
 background-size:100% 32%;
 background-repeat:no-repeat;
 background-position:0 60%;
}
.fx-hero-lab__marking.is-white-grid{
 background-image:
 linear-gradient(to right,rgba(255,255,255,.92) 0 2px,transparent 2px 100%),
 linear-gradient(to right,transparent 0 calc(33% - 1px),rgba(255,255,255,.92) calc(33% - 1px) calc(33%+1px),transparent calc(33%+1px) 100%),
 linear-gradient(to right,transparent 0 calc(67% - 1px),rgba(255,255,255,.92) calc(67% - 1px) calc(67%+1px),transparent calc(67%+1px) 100%),
 linear-gradient(to right,transparent 0 calc(100% - 2px),rgba(255,255,255,.92) calc(100% - 2px) 100%),
 linear-gradient(to bottom,rgba(255,255,255,.92) 0 2px,transparent 2px 100%),
 linear-gradient(to bottom,transparent 0 calc(33% - 1px),rgba(255,255,255,.92) calc(33% - 1px) calc(33%+1px),transparent calc(33%+1px) 100%),
 linear-gradient(to bottom,transparent 0 calc(67% - 1px),rgba(255,255,255,.92) calc(67% - 1px) calc(67%+1px),transparent calc(67%+1px) 100%),
 linear-gradient(to bottom,transparent 0 calc(100% - 2px),rgba(255,255,255,.92) calc(100% - 2px) 100%);
 background-size:100% 100%;
 background-repeat:no-repeat;
 mix-blend-mode:screen;
}
@media (prefers-reduced-motion:reduce){
 .fx-hero-lab__spec,
 .fx-hero-lab__spec-row,
 .fx-hero-lab__spec-dot{transition:none !important;}
}
:root{
 --ease-apple:cubic-bezier(.22,.61,.36,1);
 --ease-spring:cubic-bezier(.16,1.05,.32,1);
}
.fx-hero-lab{content-visibility:auto;contain-intrinsic-size:1px 900px;}
.fx-hero-lab__presets{
 display:flex;
 flex-wrap:nowrap;
 overflow-x:auto;
 scroll-behavior:smooth;
 -webkit-overflow-scrolling:touch;
 gap:8px;
 padding:6px 4px 14px;
 margin:-8px 0 24px;
 border-bottom:1px solid rgba(0,0,0,.06);
 scrollbar-width:thin;
}
.fx-hero-lab__presets::-webkit-scrollbar{height:6px;}
.fx-hero-lab__presets::-webkit-scrollbar-thumb{background:rgba(0,0,0,.18);border-radius:999px;}
.fx-hero-lab__preset{
 flex:0 0 auto;
 display:inline-flex;
 align-items:center;
 padding:8px 14px;
 background:#f3f3f5;
 border:1px solid transparent;
 border-radius:999px;
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 font-weight:500;
 letter-spacing:.01em;
 color:#1d1d1f;
 cursor:pointer;
 white-space:nowrap;
 transition:background .25s var(--ease-apple),
 color .25s var(--ease-apple),
 border-color .25s var(--ease-apple),
 transform .25s var(--ease-spring);
}
.fx-hero-lab__preset:hover{background:#e9e9ec;transform:translateY(-1px);}
.fx-hero-lab__preset:focus-visible{outline:2px solid #1d1d1f;outline-offset:2px;}
.fx-hero-lab__preset.is-active{
 background:#1d1d1f;
 color:#fff;
 border-color:#1d1d1f;
}
.fx-gloss{
 position:relative;
 cursor:help;
 border-bottom:1px dotted rgba(0,0,0,.35);
 text-decoration:none;
 color:inherit;
}
.fx-gloss::after{
 content:'i';
 display:inline-block;
 width:14px;height:14px;
 margin-left:4px;
 font-family:'Montserrat',sans-serif;
 font-size:9px;
 font-weight:700;
 line-height:14px;
 text-align:center;
 border-radius:50%;
 background:rgba(0,0,0,.08);
 color:#1d1d1f;
 vertical-align:1px;
}
.fx-gloss__tip{
 position:absolute;
 z-index:50;
 bottom:calc(100%+8px);
 left:50%;
 transform:translateX(-50%) translateY(4px);
 width:260px;
 padding:10px 12px;
 background:#1d1d1f;
 color:#fafafa;
 border-radius:10px;
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 font-weight:400;
 line-height:1.45;
 letter-spacing:0;
 text-align:left;
 white-space:normal;
 pointer-events:none;
 opacity:0;
 transition:opacity .22s var(--ease-apple),transform .22s var(--ease-apple);
 box-shadow:0 12px 32px rgba(0,0,0,.20);
}
.fx-gloss__tip::after{
 content:'';
 position:absolute;
 top:100%;
 left:50%;
 transform:translateX(-50%);
 border:6px solid transparent;
 border-top-color:#1d1d1f;
}
.fx-gloss:hover .fx-gloss__tip,
.fx-gloss:focus .fx-gloss__tip,
.fx-gloss:focus-within .fx-gloss__tip{
 opacity:1;
 transform:translateX(-50%) translateY(0);
}
.fx-hero-lab__btn[data-tooltip]{position:relative;}
.fx-hero-lab__btn[data-tooltip]::before{
 content:attr(data-tooltip);
 position:absolute;
 z-index:50;
 bottom:calc(100%+6px);
 left:50%;
 transform:translateX(-50%) translateY(4px);
 width:max-content;
 max-width:220px;
 padding:8px 10px;
 background:#1d1d1f;
 color:#fafafa;
 border-radius:8px;
 font-size:11px;
 line-height:1.4;
 font-weight:400;
 letter-spacing:0;
 text-align:left;
 white-space:normal;
 pointer-events:none;
 opacity:0;
 transition:opacity .2s var(--ease-apple),transform .2s var(--ease-apple);
 box-shadow:0 8px 24px rgba(0,0,0,.18);
}
.fx-hero-lab__btn[data-tooltip]:hover::before,
.fx-hero-lab__btn[data-tooltip]:focus-visible::before{
 opacity:1;
 transform:translateX(-50%) translateY(0);
}
.fx-hero-lab__custom-color{
 margin-top:10px;
 padding:10px 12px;
 border:1px dashed rgba(0,0,0,.18);
 border-radius:12px;
 background:#fafafa;
 transition:border-color .25s var(--ease-apple),background .25s var(--ease-apple);
}
.fx-hero-lab__custom-color.is-active{
 border-color:#1d1d1f;
 background:#fff;
}
.fx-hero-lab__custom-label{
 display:block;
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:600;
 letter-spacing:.12em;
 text-transform:uppercase;
 color:#6e6e73;
 margin:0 0 6px;
}
.fx-hero-lab__custom-row{
 display:inline-flex;
 align-items:center;
 gap:8px;
}
.fx-hero-lab__custom-picker{
 appearance:none;
 -webkit-appearance:none;
 width:32px;height:32px;
 padding:0;
 border:1px solid rgba(0,0,0,.12);
 border-radius:8px;
 background:#fff;
 cursor:pointer;
}
.fx-hero-lab__custom-picker::-webkit-color-swatch{border:none;border-radius:6px;}
.fx-hero-lab__custom-picker::-webkit-color-swatch-wrapper{padding:0;}
.fx-hero-lab__custom-text{
 width:100px;
 padding:6px 10px;
 border:1px solid rgba(0,0,0,.12);
 border-radius:8px;
 background:#fff;
 font-family:'SF Mono',Menlo,monospace;
 font-size:12px;
 color:#1d1d1f;
}
.fx-hero-lab__custom-text:focus-visible{
 outline:2px solid #1d1d1f;
 outline-offset:1px;
 border-color:#1d1d1f;
}
.fx-hero-lab__meta{
 flex-wrap:wrap;
}
.fx-hero-lab__meta>div{
 flex:1 1 auto;
 min-width:110px;
}
.fx-hero-lab__swatch{
 position:relative;
}
.fx-hero-lab__mat[data-code] .fx-hero-lab__swatch::after{
 content:attr(data-code);
 position:absolute;
 inset:0;
 display:flex;
 align-items:center;
 justify-content:center;
 font-family:'Montserrat',sans-serif;
 font-size:7px;
 font-weight:700;
 letter-spacing:.04em;
 color:rgba(255,255,255,.95);
 text-shadow:0 0 2px rgba(0,0,0,.6);
 pointer-events:none;
}
@keyframes fxSheenSweep{
 0%{opacity:0;transform:translate(-60%,-60%) rotate(18deg);}
 20%{opacity:1;}
 100%{opacity:0;transform:translate(60%,60%) rotate(18deg);}
}
.fx-plate.is-changing .fx-l-body .fx-face-top::before{
 content:'';
 position:absolute;
 inset:-50%;
 background:linear-gradient(110deg,
 rgba(255,255,255,0) 35%,
 rgba(255,255,255,.65) 50%,
 rgba(255,255,255,0) 65%
 );
 pointer-events:none;
 animation:fxSheenSweep 900ms var(--ease-apple) both;
 z-index:9;
 mix-blend-mode:screen;
}
.fx-plate .fx-l-body .fx-face-top{position:relative;overflow:hidden;}
.fx-plate[class*="has-cove-"] .fx-l-body .fx-face-N::after,
.fx-plate[class*="has-cove-"] .fx-l-body .fx-face-S::after,
.fx-plate[class*="has-cove-"] .fx-l-body .fx-face-E::after,
.fx-plate[class*="has-cove-"] .fx-l-body .fx-face-W::after{
 content:'';
 position:absolute;
 bottom:0;left:0;right:0;
 height:12px;
 background:linear-gradient(to top,
 rgba(218,165,82,.55) 0%,
 rgba(218,165,82,.20) 60%,
 transparent 100%
 );
 border-bottom:1px solid rgba(218,165,82,.7);
 border-radius:0 0 0 0 / 12px 12px 0 0;
 pointer-events:none;
}
.fx-plate.has-cove-R150 .fx-l-body .fx-face-N::after,
.fx-plate.has-cove-R150 .fx-l-body .fx-face-S::after,
.fx-plate.has-cove-R150 .fx-l-body .fx-face-E::after,
.fx-plate.has-cove-R150 .fx-l-body .fx-face-W::after{height:22px;}
.fx-plate.has-cove-R100 .fx-l-body .fx-face-N::after,
.fx-plate.has-cove-R100 .fx-l-body .fx-face-S::after,
.fx-plate.has-cove-R100 .fx-l-body .fx-face-E::after,
.fx-plate.has-cove-R100 .fx-l-body .fx-face-W::after{height:18px;}
.fx-plate.has-cove-R75 .fx-l-body .fx-face-N::after,
.fx-plate.has-cove-R75 .fx-l-body .fx-face-S::after,
.fx-plate.has-cove-R75 .fx-l-body .fx-face-E::after,
.fx-plate.has-cove-R75 .fx-l-body .fx-face-W::after{height:14px;}
.fx-plate.has-drain-linear .fx-l-body .fx-face-top::after{
 content:'';
 position:absolute;
 bottom:6%;
 left:10%;
 right:10%;
 height:4px;
 background:linear-gradient(to bottom,rgba(0,0,0,.7),rgba(0,0,0,.2));
 border-radius:2px;
 z-index:7;
 pointer-events:none;
}
.fx-plate.has-drain-radial .fx-l-body .fx-face-top::after{
 content:'';
 position:absolute;
 bottom:14%;right:14%;
 width:24px;height:24px;
 border-radius:50%;
 background:radial-gradient(circle,rgba(0,0,0,.75) 30%,rgba(0,0,0,.25) 60%,transparent 70%);
 z-index:7;
 pointer-events:none;
}
.fx-plate.cert-ESD-conductive .fx-l-body .fx-face-N,
.fx-plate.cert-ESD-conductive .fx-l-body .fx-face-S,
.fx-plate.cert-ESD-conductive .fx-l-body .fx-face-E,
.fx-plate.cert-ESD-conductive .fx-l-body .fx-face-W,
.fx-plate.cert-antistatic .fx-l-body .fx-face-N,
.fx-plate.cert-antistatic .fx-l-body .fx-face-S,
.fx-plate.cert-antistatic .fx-l-body .fx-face-E,
.fx-plate.cert-antistatic .fx-l-body .fx-face-W{
 background-image:
 repeating-linear-gradient(0deg,rgba(184,144,42,.35) 0 1px,transparent 1px 18px),
 repeating-linear-gradient(90deg,rgba(184,144,42,.28) 0 1px,transparent 1px 18px);
}
.fx-plate.cert-cleanroom-ISO5 .fx-l-body .fx-face-top{
 filter:brightness(1.04) contrast(1.02);
}
.fx-hero-lab__btn:focus-visible,
.fx-hero-lab__mat:focus-visible{
 outline:2px solid #1d1d1f;
 outline-offset:2px;
}
@media (prefers-reduced-motion:reduce){
 .fx-plate.is-changing .fx-l-body .fx-face-top::before{animation:none;opacity:0;}
 .fx-hero-lab__preset{transition:none;}
}
@media (orientation:landscape) and (max-height:480px){
 .fx-hero-lab{padding-top:60px;padding-bottom:40px;}
 .fx-hero-lab__intro{margin-bottom:16px;}
 .fx-hero-lab__grid{gap:16px;min-height:auto;}
 .fx-hero-lab__stage .fx-plate-wrap{height:280px;}
}
.fx-plate[class*="is-accents-"] .fx-l-body .fx-face-top::after,
.fx-plate[class*="is-broadcast-"] .fx-l-body .fx-face-top::after,
.fx-plate[class*="is-exposure-"] .fx-l-body .fx-face-top::after,
.fx-plate[class*="is-trowel-"] .fx-l-body .fx-face-top::after,
.fx-plate[class*="is-pattern-"] .fx-l-body .fx-face-top::after{
 content:"";
 position:absolute;
 inset:0;
 pointer-events:none;
 z-index:5;
 mix-blend-mode:normal;
}
.fx-plate.is-accents-mica-pearl .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle,rgba(255,255,255,.90) 0 1.2px,transparent 2px),
 radial-gradient(circle,rgba(255,240,255,.65) 0 1px,transparent 1.6px);
 background-size:28px 30px,18px 22px;
 background-position:6px 4px,10px 12px;
 mix-blend-mode:screen;
 opacity:.85;
}
.fx-plate.is-accents-metal .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle,rgba(220,220,230,.95) 0 1.5px,transparent 2.4px),
 radial-gradient(circle,rgba(180,180,190,.7) 0 1.2px,transparent 1.8px);
 background-size:34px 32px,22px 26px;
 mix-blend-mode:screen;
 opacity:.9;
}
.fx-plate.is-accents-glass .fx-l-body .fx-face-top::after{
 background-image:
 linear-gradient(45deg,rgba(120,200,220,.55) 0 1px,transparent 1px 16px),
 linear-gradient(-45deg,rgba(180,220,255,.45) 0 1px,transparent 1px 14px),
 radial-gradient(circle,rgba(220,250,255,.75) 0 1.4px,transparent 2px);
 background-size:20px 20px,18px 18px,30px 26px;
 mix-blend-mode:screen;
 opacity:.8;
}
.fx-plate.is-accents-brass .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle,rgba(212,176,72,.95) 0 1.5px,transparent 2.4px),
 radial-gradient(circle,rgba(184,144,42,.75) 0 1.2px,transparent 1.8px);
 background-size:32px 30px,20px 22px;
 mix-blend-mode:screen;
 opacity:.9;
}
.fx-plate.is-broadcast-fine .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle,rgba(255,255,255,.45) 0 .8px,transparent 1.2px),
 radial-gradient(circle,rgba(0,0,0,.25) 0 .8px,transparent 1.2px);
 background-size:8px 8px,7px 7px;
 background-position:0 0,3px 4px;
 opacity:.55;
}
.fx-plate.is-broadcast-medium .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle,rgba(255,255,255,.55) 0 1.1px,transparent 1.6px),
 radial-gradient(circle,rgba(0,0,0,.30) 0 1.1px,transparent 1.6px);
 background-size:7px 7px,6px 6px;
 background-position:0 0,3px 3px;
 opacity:.7;
}
.fx-plate.is-broadcast-coarse .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle,rgba(255,255,255,.65) 0 1.4px,transparent 2.2px),
 radial-gradient(circle,rgba(0,0,0,.35) 0 1.3px,transparent 2px);
 background-size:6px 6px,5px 5px;
 background-position:0 0,2.5px 2.5px;
 opacity:.85;
}
.fx-plate.is-broadcast-heavy .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle,rgba(255,255,255,.75) 0 1.6px,transparent 2.4px),
 radial-gradient(circle,rgba(0,0,0,.45) 0 1.6px,transparent 2.4px),
 radial-gradient(circle,rgba(255,255,255,.45) 0 1px,transparent 1.5px);
 background-size:5px 5px,4.5px 4.5px,7px 7px;
 background-position:0 0,2px 2px,3px 0;
 opacity:.95;
}
.fx-plate.is-broadcast-full .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle,rgba(255,255,255,.85) 0 1.8px,transparent 2.6px),
 radial-gradient(circle,rgba(0,0,0,.55) 0 1.8px,transparent 2.6px),
 radial-gradient(circle,rgba(255,255,255,.55) 0 1.2px,transparent 1.8px);
 background-size:4px 4px,3.5px 3.5px,6px 6px;
 background-position:0 0,1.8px 1.8px,2px 0;
 opacity:1;
}
.fx-plate.is-exposure-salt-pepper .fx-l-body .fx-face-top svg{opacity:.35;}
.fx-plate.is-exposure-cream .fx-l-body .fx-face-top svg{opacity:.18;}
.fx-plate.is-exposure-full-aggregate .fx-l-body .fx-face-top svg{opacity:1;}
.fx-plate.is-exposure-full-aggregate .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle,rgba(0,0,0,.35) 0 2.5px,transparent 3.5px),
 radial-gradient(circle,rgba(255,255,255,.55) 0 2.2px,transparent 3.2px),
 radial-gradient(circle,rgba(120,90,60,.55) 0 2.0px,transparent 3px);
 background-size:18px 18px,16px 16px,14px 14px;
 background-position:0 0,4px 6px,7px 3px;
 opacity:.9;
}
.fx-plate.is-exposure-dispersed-glass .fx-l-body .fx-face-top::after{
 background-image:
 linear-gradient(45deg,rgba(120,210,230,.55) 0 1px,transparent 1px 14px),
 linear-gradient(-45deg,rgba(180,230,255,.5) 0 1px,transparent 1px 12px),
 radial-gradient(circle,rgba(220,250,255,.85) 0 1.4px,transparent 2px);
 background-size:18px 18px,16px 16px,24px 22px;
 mix-blend-mode:screen;
 opacity:.9;
}
.fx-plate.is-exposure-metallic-dispersed .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle,rgba(220,220,230,.95) 0 1.6px,transparent 2.4px),
 radial-gradient(circle,rgba(160,160,170,.7) 0 1.3px,transparent 2px),
 radial-gradient(circle,rgba(80,80,90,.5) 0 1.0px,transparent 1.6px);
 background-size:20px 20px,14px 14px,11px 11px;
 background-position:0 0,5px 5px,8px 2px;
 mix-blend-mode:screen;
 opacity:.9;
}
.fx-plate.is-trowel-sweep .fx-l-body .fx-face-top::after{
 background-image:
 repeating-linear-gradient(8deg,
 rgba(255,255,255,.10) 0 2px,
 rgba(0,0,0,.05) 2px 4px,
 transparent 4px 18px);
 opacity:.9;
}
.fx-plate.is-trowel-swirl .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(ellipse 60% 30% at 30% 30%,rgba(255,255,255,.18),transparent 70%),
 radial-gradient(ellipse 60% 30% at 70% 70%,rgba(0,0,0,.18),transparent 70%),
 repeating-radial-gradient(circle at 50% 50%,
 rgba(255,255,255,.05) 0 3px,
 rgba(0,0,0,.05) 3px 6px,
 transparent 6px 24px);
 opacity:.9;
}
.fx-plate.is-trowel-cross .fx-l-body .fx-face-top::after{
 background-image:
 repeating-linear-gradient(45deg,
 rgba(255,255,255,.10) 0 2px,
 rgba(0,0,0,.06) 2px 4px,
 transparent 4px 14px),
 repeating-linear-gradient(-45deg,
 rgba(255,255,255,.10) 0 2px,
 rgba(0,0,0,.06) 2px 4px,
 transparent 4px 14px);
 opacity:.85;
}
.fx-plate.is-pattern-multicolor .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle 30px at 22% 28%,rgba(168,42,40,.85),transparent 60%),
 radial-gradient(circle 36px at 72% 64%,rgba(29,79,138,.85),transparent 60%),
 radial-gradient(circle 28px at 56% 18%,rgba(220,168,88,.80),transparent 60%),
 radial-gradient(circle 26px at 18% 78%,rgba(60,150,90,.78),transparent 60%),
 radial-gradient(circle 22px at 82% 22%,rgba(225,225,225,.55),transparent 60%);
 opacity:.95;
}
.fx-plate.is-pattern-safety .fx-l-body .fx-face-top::after{
 background-image:
 linear-gradient(180deg,rgba(168,42,40,.82) 0 33%,transparent 33% 66%,rgba(29,79,138,.82) 66% 100%);
 opacity:.9;
}
.fx-plate.is-pattern-radial .fx-l-body .fx-face-top::after{
 background-image:
 repeating-radial-gradient(circle at 50% 50%,
 rgba(168,42,40,.55) 0 16px,
 rgba(29,29,31,.0) 16px 32px,
 rgba(29,79,138,.55) 32px 48px,
 rgba(29,29,31,.0) 48px 64px,
 rgba(220,168,88,.50) 64px 80px);
 opacity:.92;
}
.fx-plate.is-pattern-classic .fx-l-body .fx-face-top::after{
 background-image:
 repeating-linear-gradient(90deg,
 rgba(255,255,255,.85) 0 14px,
 rgba(0,0,0,.85) 14px 28px);
 opacity:.55;
}
.fx-hero-lab__flecks.mode-medium{
 background-image:
 radial-gradient(circle,rgba(255,255,255,.55) 0 1.4px,transparent 2px),
 radial-gradient(circle,rgba(0,0,0,.40) 0 1.4px,transparent 2px);
 background-size:10px 10px,8px 8px;
 background-position:0 0,3px 4px;
 opacity:.8;
}
.fx-hero-lab__flecks.mode-full-broadcast{
 background-image:
 radial-gradient(circle,rgba(255,255,255,.75) 0 1.7px,transparent 2.4px),
 radial-gradient(circle,rgba(0,0,0,.55) 0 1.7px,transparent 2.4px),
 radial-gradient(circle,rgba(255,255,255,.45) 0 1.0px,transparent 1.6px);
 background-size:5px 5px,4.5px 4.5px,7px 7px;
 background-position:0 0,2px 2px,3px 0;
 opacity:1;
}
.fx-hero-lab__flecks.mode-metallic-bronze{
 background-image:
 radial-gradient(circle,rgba(205,127,50,.95) 0 1.6px,transparent 2.2px),
 radial-gradient(circle,rgba(120,72,28,.7) 0 1.2px,transparent 1.6px);
 background-size:26px 26px,16px 18px;
 mix-blend-mode:screen;
 opacity:.85;
}
.fx-hero-lab__flecks.mode-metallic-copper{
 background-image:
 radial-gradient(circle,rgba(184,115,51,.95) 0 1.6px,transparent 2.2px),
 radial-gradient(circle,rgba(232,180,124,.7) 0 1.2px,transparent 1.6px);
 background-size:26px 26px,16px 18px;
 mix-blend-mode:screen;
 opacity:.85;
}
.fx-hero-lab__flecks.mode-metallic-pearl{
 background-image:
 radial-gradient(circle,rgba(245,245,250,.95) 0 1.6px,transparent 2.2px),
 radial-gradient(circle,rgba(220,225,235,.65) 0 1.2px,transparent 1.6px);
 background-size:28px 28px,18px 20px;
 mix-blend-mode:screen;
 opacity:.9;
}
@media (prefers-reduced-motion:reduce){
 .fx-hero-lab__btn:hover{transform:none;}
 .fx-buildup-layer:hover{transform:none;}
}
.fx-plate.is-exposure-classA-cream .fx-plate-pattern{opacity:.08;}
.fx-plate.is-exposure-classB-saltPepper .fx-plate-pattern{opacity:.35;}
.fx-plate.is-exposure-classC-medium .fx-plate-pattern{opacity:.65;}
.fx-plate.is-exposure-classD-fullExposed .fx-plate-pattern{opacity:1;}
.fx-plate.is-exposure-classD-fullExposed .fx-l-body .fx-face-top::after{
 content:"";position:absolute;inset:0;
 background-image:radial-gradient(circle at 22% 35%,rgba(0,0,0,.18) 0 3px,transparent 4px),
 radial-gradient(circle at 73% 60%,rgba(0,0,0,.18) 0 4px,transparent 5px),
 radial-gradient(circle at 48% 78%,rgba(0,0,0,.18) 0 3px,transparent 4px);
 background-size:60px 60px,80px 80px,50px 50px;
 pointer-events:none;mix-blend-mode:multiply;opacity:.5;
}
.fx-plate.is-trowel-cloud .fx-l-body .fx-face-top{
 background-image:radial-gradient(ellipse at 30% 40%,rgba(255,255,255,.18) 0 80px,transparent 140px),
 radial-gradient(ellipse at 75% 65%,rgba(0,0,0,.10) 0 60px,transparent 120px),
 var(--plate-top-image);
}
.fx-plate.is-trowel-wave .fx-l-body .fx-face-top{
 background-image:repeating-linear-gradient(125deg,rgba(0,0,0,.08) 0 8px,rgba(255,255,255,.05) 8px 18px),
 var(--plate-top-image);
}
.fx-plate.is-trowel-mineral .fx-l-body .fx-face-top{
 background-image:radial-gradient(ellipse at 25% 25%,rgba(255,255,255,.22) 0 100px,transparent 180px),
 radial-gradient(ellipse at 70% 70%,rgba(0,0,0,.18) 0 80px,transparent 140px),
 var(--plate-top-image);
}
.fx-plate.is-trowel-stone .fx-l-body .fx-face-top{
 background-image:radial-gradient(circle at 20% 20%,rgba(0,0,0,.15) 0 25px,transparent 40px),
 radial-gradient(circle at 60% 50%,rgba(255,255,255,.15) 0 30px,transparent 50px),
 radial-gradient(circle at 80% 80%,rgba(0,0,0,.20) 0 20px,transparent 35px),
 var(--plate-top-image);
}
.fx-plate.is-trowel-concrete-effect .fx-l-body .fx-face-top{
 background-image:repeating-linear-gradient(0deg,rgba(0,0,0,.05) 0 1px,transparent 1px 6px),
 var(--plate-top-image);
 filter:contrast(1.05) saturate(.85);
}
.fx-plate.is-trowel-metallic .fx-l-body .fx-face-top{
 background-image:linear-gradient(115deg,rgba(255,220,160,0) 30%,rgba(255,220,160,.18) 50%,rgba(255,220,160,0) 70%),
 var(--plate-top-image);
 filter:brightness(1.05) saturate(1.15);
}
.fx-plate.is-pattern-blend-2tone .fx-l-body .fx-face-top{
 background-image:radial-gradient(circle at 25% 25%,var(--plate-tint-color,#b54530) 0 60px,transparent 100px),
 radial-gradient(circle at 70% 60%,var(--plate-tint-color,#b54530) 0 40px,transparent 80px),
 radial-gradient(circle at 45% 80%,var(--plate-tint-color,#b54530) 0 50px,transparent 90px);
 background-size:200px 200px,240px 240px,180px 180px;
}
.fx-plate.is-pattern-blend-multi .fx-l-body .fx-face-top{
 background-image:radial-gradient(circle at 15% 20%,#c8302a 0 30px,transparent 50px),
 radial-gradient(circle at 60% 35%,#2a4a8a 0 35px,transparent 55px),
 radial-gradient(circle at 35% 70%,#4a8a2a 0 30px,transparent 50px),
 radial-gradient(circle at 80% 85%,#c8a830 0 28px,transparent 48px),
 radial-gradient(circle at 90% 25%,#fafafa 0 25px,transparent 45px);
 background-size:160px 160px;
}
.fx-plate.is-pattern-island .fx-l-body .fx-face-top{
 background-image:radial-gradient(ellipse at 30% 30%,#c8302a 0 80px,transparent 100px),
 radial-gradient(ellipse at 75% 70%,#4a8a2a 0 90px,transparent 110px);
}
.fx-plate.is-pattern-graphic .fx-l-body .fx-face-top{
 background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.85) 0 2px,transparent 2px 40px),
 repeating-linear-gradient(90deg,rgba(255,255,255,.85) 0 2px,transparent 2px 40px);
}
.fx-plate.is-pattern-sport-lines .fx-l-body .fx-face-top{
 background-image:linear-gradient(90deg,transparent 0 35%,rgba(255,255,255,.92) 35% 36%,transparent 36% 65%,rgba(255,255,255,.92) 65% 66%,transparent 66%);
}
.fx-plate.is-bcm-silicon-carbide .fx-hero-lab__texture{opacity:1;background-image:radial-gradient(circle at 30% 40%,rgba(20,20,20,.6) 0 1.2px,transparent 1.6px);background-size:6px 6px;}
.fx-plate.is-bcm-aluminum-oxide .fx-hero-lab__texture{opacity:1;background-image:radial-gradient(circle at 30% 40%,rgba(180,180,180,.5) 0 1.6px,transparent 2.2px);background-size:8px 8px;}
.fx-plate.is-bcm-color-quartz .fx-hero-lab__texture{opacity:1;background-image:radial-gradient(circle at 30% 40%,rgba(200,170,120,.55) 0 1.4px,transparent 1.9px);background-size:7px 7px;}
.fx-plate.is-bcm-ceramic-granule .fx-hero-lab__texture{opacity:1;background-image:radial-gradient(circle at 30% 40%,rgba(220,200,170,.45) 0 1.3px,transparent 1.7px);background-size:7px 7px;}
.fx-plate.is-cure-cold{
 --plate-tint-color:rgba(120,180,220,.10);
 --plate-tint-strength:0.10;
}
.fx-plate.is-cure-cold~.fx-hero-lab__meta [data-fx="pmCure"]{
 color:#1d6da8;font-weight:700;
}
.fx-plate[data-system="rubber"] .fx-hero-lab__color-tint{mix-blend-mode:multiply;opacity:.85;}
.fx-plate{
 --hover-rx:0deg;
 --hover-ry:0deg;
 --idle-rx:0deg;
 --idle-ry:0deg;
 --explode-scale:1;
}
.fx-plate{
 transform:
 rotateX(calc(var(--rx)+var(--plate-scroll-tilt)+var(--idle-rx)+var(--hover-rx)))
 rotateY(calc(var(--ry)+var(--idle-ry)+var(--hover-ry)))
 scale(var(--explode-scale));
 transition:
 transform .9s cubic-bezier(.22,1.2,.36,1),
 --idle-rx .8s ease,
 --idle-ry .8s ease;
}
.fx-plate.is-hovering:not(.is-dragging):not(.is-exploded){
 transition:transform 200ms cubic-bezier(.22,1,.36,1);
}
.fx-plate.idle{
 animation:
 fxPlateBreatheY 8s cubic-bezier(.45,.05,.55,.95) infinite,
 fxPlateBreatheX 11s cubic-bezier(.45,.05,.55,.95) infinite;
}
@keyframes fxPlateBreatheY{
 0%,100%{--idle-ry:-4deg;}
 50%{--idle-ry:4deg;}
}
@keyframes fxPlateBreatheX{
 0%,100%{--idle-rx:-2deg;}
 50%{--idle-rx:2deg;}
}
.fx-plate.is-dragging,
.fx-plate.is-exploded,
.fx-plate.is-hovering{
 animation:none !important;
 --idle-rx:0deg;
 --idle-ry:0deg;
}
@property --idle-rx{
 syntax:'<angle>';inherits:true;initial-value:0deg;
}
@property --idle-ry{
 syntax:'<angle>';inherits:true;initial-value:0deg;
}
@property --hover-rx{
 syntax:'<angle>';inherits:true;initial-value:0deg;
}
@property --hover-ry{
 syntax:'<angle>';inherits:true;initial-value:0deg;
}
@property --explode-scale{
 syntax:'<number>';inherits:true;initial-value:1;
}
.fx-plate.is-exploded{--explode-scale:1.02;}
.fx-plate.is-exploding-collapse{--explode-scale:0.97;}
.fx-plate.is-exploded .fx-l-topcoat{transition-delay:0s,.04s;}
.fx-plate.is-exploded .fx-l-body{transition-delay:.12s,.04s;}
.fx-plate.is-exploded .fx-l-mesh{transition-delay:.24s,.04s;}
.fx-plate.is-exploded .fx-l-primer{transition-delay:.36s,.04s;}
.fx-plate.is-exploded .fx-l-substrate{transition-delay:.48s,.04s;}
.fx-plate:not(.is-exploded) .fx-l-substrate{transition-delay:0s,.04s;}
.fx-plate:not(.is-exploded) .fx-l-primer{transition-delay:.12s,.04s;}
.fx-plate:not(.is-exploded) .fx-l-mesh{transition-delay:.24s,.04s;}
.fx-plate:not(.is-exploded) .fx-l-body{transition-delay:.36s,.04s;}
.fx-plate:not(.is-exploded) .fx-l-topcoat{transition-delay:.48s,.04s;}
.fx-plate-wrap::before{
 
 width:440px;height:36px;
 bottom:64px;
 background:radial-gradient(50% 50% at 50% 50%,
 rgba(40,30,20,.32),
 rgba(40,30,20,.12) 55%,
 transparent 78%);
 filter:blur(10px);
}
.fx-plate-wrap::after{
 content:"";
 position:absolute;
 width:620px;height:90px;
 bottom:32px;
 background:radial-gradient(50% 50% at 50% 50%,
 rgba(40,30,20,.20),
 transparent 70%);
 filter:blur(36px);
 max-width:95%;
 pointer-events:none;
 
 transform:scaleX(calc(1+var(--plate-scroll-tilt,0deg) / 80deg))
 scaleY(calc(1 - var(--plate-scroll-tilt,0deg) / 240deg));
 transition:transform .6s cubic-bezier(.22,1,.36,1);
}
.fx-plate .fx-l-body .fx-face-top{
 
 box-shadow:
 inset 0 0 0 .5px rgba(0,0,0,.10),
 inset 0 0 60px rgba(0,0,0,.16),
 inset 0 0 120px rgba(0,0,0,.10);
}
.fx-plate .fx-l-body .fx-face-top::before{
 content:"";
 position:absolute;
 inset:0;
 
 background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
 background-size:220px 220px;
 opacity:.06;
 mix-blend-mode:overlay;
 pointer-events:none;
 z-index:7;
}
.fx-plate[data-finish="wetlook"] .fx-l-body .fx-face-top::before,
.fx-plate[data-finish="polished"] .fx-l-body .fx-face-top::before{
 opacity:.03;
}
.fx-plate[data-finish="matte"] .fx-l-body .fx-face-top::before{
 opacity:.09;
}
.fx-plate[data-finish="matte"] .fx-l-body .fx-face-top{
 filter:var(--plate-top-filter,none) contrast(.96) brightness(.98);
}
.fx-plate[data-finish="wetlook"] .fx-l-body .fx-face-top::after{
 background:
 
 radial-gradient(ellipse at 28% 18%,rgba(255,255,255,.22),transparent 55%),
 linear-gradient(125deg,transparent 38%,rgba(255,255,255,.10) 50%,transparent 62%),
 
 linear-gradient(90deg,
 transparent 28%,
 rgba(255,255,255,.18) 36%,
 rgba(255,255,255,.32) 42%,
 rgba(255,255,255,.18) 48%,
 transparent 56%);
 mix-blend-mode:screen;
}
.fx-plate.idle .fx-hero-lab__sheen{
 animation:fxSheenShimmer 6s ease-in-out infinite;
}
@keyframes fxSheenShimmer{
 0%,100%{transform:translateX(-2.5%);}
 50%{transform:translateX( 2.5%);}
}
.fx-plate.is-hovering .fx-hero-lab__sheen,
.fx-plate.is-dragging .fx-hero-lab__sheen,
.fx-plate.is-exploded .fx-hero-lab__sheen{
 animation:none;
}
.fx-plate .fx-l-body .fx-face-N,
.fx-plate .fx-l-body .fx-face-S,
.fx-plate .fx-l-body .fx-face-E,
.fx-plate .fx-l-body .fx-face-W{
 transition:
 background-color 280ms cubic-bezier(.22,1,.36,1),
 filter 280ms cubic-bezier(.22,1,.36,1);
}
.fx-plate .fx-l-topcoat .fx-face-N,
.fx-plate .fx-l-topcoat .fx-face-S,
.fx-plate .fx-l-topcoat .fx-face-E,
.fx-plate .fx-l-topcoat .fx-face-W,
.fx-plate .fx-l-body .fx-face-N,
.fx-plate .fx-l-body .fx-face-S,
.fx-plate .fx-l-body .fx-face-E,
.fx-plate .fx-l-body .fx-face-W,
.fx-plate .fx-l-primer .fx-face-N,
.fx-plate .fx-l-primer .fx-face-S,
.fx-plate .fx-l-primer .fx-face-E,
.fx-plate .fx-l-primer .fx-face-W,
.fx-plate .fx-l-substrate .fx-face-N,
.fx-plate .fx-l-substrate .fx-face-S,
.fx-plate .fx-l-substrate .fx-face-E,
.fx-plate .fx-l-substrate .fx-face-W{
 
 box-shadow:inset 0 1px 0 rgba(255,255,255,.18),
 inset 0 -1px 0 rgba(0,0,0,.10);
}
@media (prefers-reduced-motion:reduce){
 .fx-plate.idle,
 .fx-plate.idle .fx-hero-lab__sheen{animation:none;}
 .fx-plate{transition:none;}
}
.fx-plate.is-mop-iridescent .fx-l-body .fx-face-top::after{
 
 background:
 radial-gradient(ellipse at 22% 28%,rgba(220,200,240,.45),transparent 55%),
 radial-gradient(ellipse at 75% 70%,rgba(180,230,220,.42),transparent 55%),
 radial-gradient(ellipse at 50% 50%,rgba(255,245,230,.25),transparent 70%),
 
 radial-gradient(ellipse at 28% 18%,rgba(255,255,255,.18),transparent 55%);
 mix-blend-mode:screen;
 opacity:.85;
}
.fx-plate.is-agg-palladiana .fx-l-body .fx-face-top{
 
 filter:contrast(1.04) saturate(1.04);
}
.fx-plate .fx-hero-lab__strips{
 filter:drop-shadow(0 0 .8px rgba(0,0,0,.45));
}
.fx-hero-lab__flecks.mode-medium{
 background-image:
 radial-gradient(circle at 18% 22%,rgba(255,255,255,.55) 0 2px,transparent 2.8px),
 radial-gradient(circle at 64% 38%,rgba(0,0,0,.5) 0 2.2px,transparent 3px),
 radial-gradient(circle at 38% 78%,rgba(255,255,255,.5) 0 2px,transparent 2.8px),
 radial-gradient(circle at 80% 70%,rgba(0,0,0,.5) 0 2px,transparent 2.8px);
 background-size:30px 32px,34px 36px,28px 32px,32px 34px;
}
.fx-hero-lab__flecks.mode-full-broadcast{
 
 background-image:
 radial-gradient(circle at 14% 18%,rgba(255,255,255,.62) 0 2.2px,transparent 3px),
 radial-gradient(circle at 38% 32%,rgba(0,0,0,.55) 0 2.4px,transparent 3.2px),
 radial-gradient(circle at 60% 14%,rgba(255,235,180,.55) 0 2px,transparent 2.8px),
 radial-gradient(circle at 78% 50%,rgba(0,0,0,.50) 0 2.2px,transparent 3px),
 radial-gradient(circle at 22% 70%,rgba(255,255,255,.55) 0 2.2px,transparent 3px),
 radial-gradient(circle at 60% 80%,rgba(180,170,160,.55) 0 2.4px,transparent 3.2px),
 radial-gradient(circle at 86% 88%,rgba(0,0,0,.45) 0 2px,transparent 2.8px);
 background-size:18px 18px;
}
.fx-hero-lab__flecks.mode-fine-vinyl-1-16{
 background-image:
 radial-gradient(circle at 20% 24%,rgba(255,255,255,.50) 0 1px,transparent 1.4px),
 radial-gradient(circle at 60% 36%,rgba(0,0,0,.45) 0 1px,transparent 1.4px),
 radial-gradient(circle at 80% 70%,rgba(255,255,255,.45) 0 1px,transparent 1.4px);
 background-size:14px 14px,18px 18px,16px 16px;
}
.fx-hero-lab__flecks.mode-large-vinyl-1-4{
 background-image:
 radial-gradient(circle at 18% 22%,rgba(255,255,255,.62) 0 6px,transparent 7.5px),
 radial-gradient(circle at 62% 36%,rgba(0,0,0,.55) 0 6px,transparent 7.5px),
 radial-gradient(circle at 38% 78%,rgba(180,180,200,.55) 0 5.5px,transparent 7px),
 radial-gradient(circle at 84% 72%,rgba(0,0,0,.50) 0 6px,transparent 7.5px);
 background-size:60px 64px,70px 74px,64px 68px,68px 72px;
}
.fx-hero-lab__flecks.mode-metallic-bronze-stapa,
.fx-hero-lab__flecks.mode-metallic-bronze{
 background:
 radial-gradient(ellipse at 22% 18%,rgba(220,170,90,.55),transparent 35%),
 radial-gradient(ellipse at 70% 52%,rgba(170,120,60,.55),transparent 40%),
 radial-gradient(ellipse at 38% 80%,rgba(220,170,90,.45),transparent 35%),
 linear-gradient(135deg,rgba(255,220,160,.18) 0%,rgba(60,30,10,.10) 50%,rgba(255,220,160,.18) 100%);
 mix-blend-mode:screen;
}
.fx-hero-lab__flecks.mode-metallic-copper-stapa,
.fx-hero-lab__flecks.mode-metallic-copper{
 background:
 radial-gradient(ellipse at 22% 18%,rgba(220,140,80,.55),transparent 35%),
 radial-gradient(ellipse at 70% 52%,rgba(180,90,40,.55),transparent 40%),
 radial-gradient(ellipse at 38% 80%,rgba(230,160,100,.50),transparent 35%),
 linear-gradient(135deg,rgba(255,180,120,.20) 0%,rgba(80,30,10,.10) 50%,rgba(255,180,120,.20) 100%);
 mix-blend-mode:screen;
}
.fx-hero-lab__flecks.mode-mica-pearl-iriodin,
.fx-hero-lab__flecks.mode-metallic-pearl{
 background:
 radial-gradient(ellipse at 24% 22%,rgba(245,235,220,.55),transparent 30%),
 radial-gradient(ellipse at 66% 46%,rgba(220,210,235,.50),transparent 35%),
 radial-gradient(ellipse at 38% 78%,rgba(220,235,230,.45),transparent 32%);
 mix-blend-mode:screen;
 filter:brightness(1.04);
}
.fx-plate.is-rgh-fine .fx-hero-lab__texture{
 opacity:1;
 background-image:
 radial-gradient(circle at 30% 40%,rgba(0,0,0,.20) 0 .8px,transparent 1.2px);
 background-size:7px 7px;
 mix-blend-mode:multiply;
}
.fx-plate.is-rgh-coarse .fx-hero-lab__texture{
 opacity:1;
 background-image:
 radial-gradient(circle at 22% 28%,rgba(0,0,0,.34) 0 1.4px,transparent 1.8px),
 radial-gradient(circle at 64% 58%,rgba(255,255,255,.18) 0 1.2px,transparent 1.6px);
 background-size:6px 7px,8px 9px;
 mix-blend-mode:multiply;
}
.fx-plate.is-rgh-coarse-r12 .fx-hero-lab__texture{
 opacity:1;
 background-image:
 radial-gradient(circle at 18% 22%,rgba(0,0,0,.45) 0 2px,transparent 2.6px),
 radial-gradient(circle at 60% 38%,rgba(255,255,255,.22) 0 1.8px,transparent 2.4px),
 radial-gradient(circle at 78% 78%,rgba(0,0,0,.38) 0 2px,transparent 2.6px),
 radial-gradient(circle at 38% 70%,rgba(255,255,255,.20) 0 1.6px,transparent 2.2px);
 background-size:9px 10px,11px 12px,10px 11px,12px 13px;
 mix-blend-mode:multiply;
}
.fx-plate.is-rgh-coarse-r12 .fx-l-body .fx-face-top{filter:saturate(.88) brightness(.96);}
.fx-plate.is-rgh-barefoot-b .fx-hero-lab__texture{
 opacity:1;
 
 background-image:
 radial-gradient(circle at 30% 30%,rgba(0,0,0,.22) 0 .9px,transparent 1.4px),
 radial-gradient(circle at 70% 70%,rgba(255,255,255,.20) 0 .8px,transparent 1.3px);
 background-size:5px 5px,5px 5px;
 background-position:0 0,2.5px 2.5px;
 mix-blend-mode:multiply;
}
.fx-plate[data-finish="satin"] .fx-l-body .fx-face-top::after{
 
 background:
 radial-gradient(ellipse at 30% 20%,rgba(255,255,255,.16),transparent 60%),
 linear-gradient(125deg,transparent 40%,rgba(255,255,255,.08) 50%,transparent 60%);
 mix-blend-mode:screen;
 opacity:.9;
}
.fx-plate[data-finish="polished"] .fx-l-body .fx-face-top::after{
 background:
 radial-gradient(ellipse at 28% 18%,rgba(255,255,255,.30),transparent 55%),
 linear-gradient(125deg,transparent 38%,rgba(255,255,255,.18) 50%,transparent 62%);
 mix-blend-mode:screen;
}
.fx-plate[data-finish="glossy"] .fx-l-body .fx-face-top::after{
 background:
 radial-gradient(ellipse at 26% 16%,rgba(255,255,255,.45),transparent 50%),
 linear-gradient(125deg,transparent 38%,rgba(255,255,255,.28) 50%,transparent 62%);
 mix-blend-mode:screen;
}
.fx-hero-lab__marking.is-yellow-zone{
 background-image:repeating-linear-gradient(
 45deg,
 rgba(245,200,30,0.95) 0 16px,
 rgba(20,20,20,0.92) 16px 32px
 );
 -webkit-mask-image:linear-gradient(135deg,#000 0%,#000 48%,transparent 62%);
 mask-image:linear-gradient(135deg,#000 0%,#000 48%,transparent 62%);
 
 filter:drop-shadow(0 0 1px rgba(0,0,0,.35));
}
.fx-hero-lab__marking.is-white-grid{
 
 background:
 linear-gradient(90deg,transparent 0 27.5%,rgba(255,255,255,.95) 27.5% 28.5%,transparent 28.5%) no-repeat,
 linear-gradient(90deg,transparent 0 71.5%,rgba(255,255,255,.95) 71.5% 72.5%,transparent 72.5%) no-repeat,
 linear-gradient(0deg,transparent 0 27.5%,rgba(255,255,255,.95) 27.5% 28.5%,transparent 28.5%) no-repeat,
 linear-gradient(0deg,transparent 0 71.5%,rgba(255,255,255,.95) 71.5% 72.5%,transparent 72.5%) no-repeat;
 filter:drop-shadow(0 0 1px rgba(255,255,255,.45));
}
.fx-hero-lab__marking.is-red-safety{
 background:
 linear-gradient(to bottom,
 transparent 0 76%,
 rgba(195,40,32,0.94) 76% 92%,
 transparent 92%) no-repeat;
 filter:drop-shadow(0 1px 2px rgba(60,0,0,.35));
}
.fx-hero-lab__marking.is-pedestrian{
 background:
 repeating-linear-gradient(
 90deg,
 rgba(255,255,255,.96) 0 26px,
 transparent 26px 52px) no-repeat;
 background-size:100% 32%;
 background-position:0 64%;
 filter:drop-shadow(0 1px 1px rgba(0,0,0,.30));
}
.fx-plate.is-pattern-island .fx-l-body .fx-face-top{
 background-image:
 radial-gradient(circle at 30% 35%,#c8302a 0 28%,transparent 28.6%),
 radial-gradient(circle at 72% 68%,#4a8a2a 0 22%,transparent 22.6%),
 radial-gradient(circle at 50% 50%,#1d4f8a 0 14%,transparent 14.6%);
}
.fx-plate.is-pattern-graphic .fx-l-body .fx-face-top{
 background-image:
 
 url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 480 480'>\
<g fill='none' stroke='%23ffffff' stroke-width='4'>\
<rect x='180' y='40' width='120' height='90'/>\
<rect x='180' y='130' width='120' height='90'/>\
<rect x='100' y='220' width='120' height='90'/>\
<rect x='260' y='220' width='120' height='90'/>\
<rect x='180' y='310' width='120' height='90'/>\
</g>\
<g fill='%23ffffff' font-family='Arial Black,sans-serif' font-size='40' text-anchor='middle'>\
<text x='240' y='98'>1</text>\
<text x='240' y='188'>2</text>\
<text x='160' y='278'>3</text>\
<text x='320' y='278'>4</text>\
<text x='240' y='368'>5</text>\
</g></svg>");
 background-repeat:no-repeat;
 background-size:100% 100%;
}
.fx-plate.is-pattern-sport-lines .fx-l-body .fx-face-top{
 background-image:
 linear-gradient(0deg,
 transparent 0 49.5%,
 rgba(255,255,255,.95) 49.5% 50.8%,
 transparent 50.8%) no-repeat;
}
.fx-plate.is-cure-cold{
 --plate-tint-color:rgba(120,180,220,.14);
 --plate-tint-strength:0.14;
}
.fx-plate.is-cure-cold .fx-l-body .fx-face-N,
.fx-plate.is-cure-cold .fx-l-body .fx-face-S,
.fx-plate.is-cure-cold .fx-l-body .fx-face-E,
.fx-plate.is-cure-cold .fx-l-body .fx-face-W,
.fx-plate.is-cure-cold .fx-l-topcoat .fx-face-N,
.fx-plate.is-cure-cold .fx-l-topcoat .fx-face-S,
.fx-plate.is-cure-cold .fx-l-topcoat .fx-face-E,
.fx-plate.is-cure-cold .fx-l-topcoat .fx-face-W{
 
 box-shadow:
 inset 0 1px 0 rgba(180,225,250,.55),
 inset 0 -1px 0 rgba(0,0,0,.10),
 0 0 6px rgba(120,180,220,.30);
}
.fx-plate.is-cure-cold .fx-l-body .fx-face-top{
 
 box-shadow:
 inset 0 0 0 .5px rgba(180,220,250,.35),
 inset 0 0 24px rgba(120,180,220,.18),
 inset 0 0 60px rgba(0,0,0,.16);
}
.fx-hero-lab .fx-plate.is-cure-cold~* [data-fx="pmCure"],
.fx-hero-lab__meta [data-fx="pmCure"]:where(.fx-plate.is-cure-cold~* [data-fx="pmCure"]){
 color:#1d6da8;
 font-weight:700;
 letter-spacing:.02em;
}
.fx-hero-lab:has(.fx-plate.is-cure-cold) [data-fx="pmCure"]{
 color:#1d6da8;
 font-weight:700;
}
.fx-plate.is-exposure-classA-cream .fx-plate-pattern{opacity:.06;}
.fx-plate.is-exposure-classB-saltPepper .fx-plate-pattern{opacity:.32;}
.fx-plate.is-exposure-classC-medium .fx-plate-pattern{opacity:.68;}
.fx-plate.is-exposure-classD-fullExposed .fx-plate-pattern{opacity:1;}
.fx-plate.is-exposure-classD-fullExposed .fx-l-body .fx-face-top{
 
 filter:contrast(1.06) saturate(1.05);
}
.fx-plate.has-cove-R50 .fx-l-body .fx-face-top,
.fx-plate.has-cove-R75 .fx-l-body .fx-face-top,
.fx-plate.has-cove-R100 .fx-l-body .fx-face-top,
.fx-plate.has-cove-R150 .fx-l-body .fx-face-top{
 position:relative;
}
.fx-plate.has-cove-R50 .fx-l-body .fx-face-top::before,
.fx-plate.has-cove-R75 .fx-l-body .fx-face-top::before,
.fx-plate.has-cove-R100 .fx-l-body .fx-face-top::before,
.fx-plate.has-cove-R150 .fx-l-body .fx-face-top::before{
 
 background-image:
 url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>"),
 radial-gradient(ellipse at 50% 100%,rgba(220,170,80,.32) 0 12px,transparent 28px);
 background-repeat:repeat,no-repeat;
 background-size:220px 220px,70% 30%;
 background-position:0 0,center bottom;
}
.fx-plate.has-cove-R150 .fx-l-body .fx-face-top::before{
 
 background-size:220px 220px,92% 38%;
}
.fx-hero-lab__group--slider{padding:6px 0;}
.fx-hero-lab__slider-row{
 display:flex;align-items:center;gap:12px;
 margin-top:4px;
}
.fx-hero-lab__finish-slider{
 -webkit-appearance:none;appearance:none;
 flex:1;min-width:160px;height:24px;
 background:transparent;cursor:pointer;
}
.fx-hero-lab__finish-slider::-webkit-slider-runnable-track{
 height:4px;border-radius:4px;
 background:linear-gradient(90deg,#2a2a2a 0%,#6a6a6a 25%,#b0b0b0 55%,#e8e8e8 80%,#f8f8f8 100%);
}
.fx-hero-lab__finish-slider::-moz-range-track{
 height:4px;border-radius:4px;
 background:linear-gradient(90deg,#2a2a2a 0%,#6a6a6a 25%,#b0b0b0 55%,#e8e8e8 80%,#f8f8f8 100%);
}
.fx-hero-lab__finish-slider::-webkit-slider-thumb{
 -webkit-appearance:none;appearance:none;
 width:16px;height:16px;border-radius:50%;
 background:#1c1c1e;border:2px solid #fff;
 box-shadow:0 1px 4px rgba(0,0,0,.4),0 0 0 1px rgba(0,0,0,.4);
 margin-top:-6px;
 transition:transform .12s ease,box-shadow .12s ease;
}
.fx-hero-lab__finish-slider::-moz-range-thumb{
 width:16px;height:16px;border-radius:50%;
 background:#1c1c1e;border:2px solid #fff;
 box-shadow:0 1px 4px rgba(0,0,0,.4),0 0 0 1px rgba(0,0,0,.4);
}
.fx-hero-lab__finish-slider:hover::-webkit-slider-thumb,
.fx-hero-lab__finish-slider:focus::-webkit-slider-thumb{
 transform:scale(1.15);
 box-shadow:0 2px 10px rgba(0,0,0,.5),0 0 0 4px rgba(184,144,42,.18);
}
.fx-hero-lab__finish-tick{
 font-size:11px;font-weight:600;letter-spacing:.04em;
 text-transform:uppercase;
 min-width:60px;text-align:right;
 color:#5a5a5c;
}
.fx-hero-lab__slider-scale{
 display:flex;justify-content:space-between;
 font-size:9px;color:#9a9a9c;margin-top:2px;
 letter-spacing:.03em;
}
.fx-plate.is-sargel-grid-3x3 .fx-hero-lab__strips,
.fx-plate.is-sargel-grid-2x2 .fx-hero-lab__strips,
.fx-plate.is-sargel-diagonal .fx-hero-lab__strips,
.fx-plate.is-sargel-decorative-meander .fx-hero-lab__strips{
 
 position:absolute;inset:0;
}
.fx-plate.is-sargel-grid-3x3 .fx-l-body .fx-face-top::after,
.fx-plate.is-sargel-grid-2x2 .fx-l-body .fx-face-top::after,
.fx-plate.is-sargel-diagonal .fx-l-body .fx-face-top::after,
.fx-plate.is-sargel-decorative-meander .fx-l-body .fx-face-top::after{
 content:"";position:absolute;inset:0;pointer-events:none;
 z-index:6;
 --sargel-color:rgba(184,144,42,.85);
 --sargel-w:2px;
}
.fx-plate.is-strip-brass4 .fx-l-body .fx-face-top::after,
.fx-plate.is-strip-brass-3mm-arch .fx-l-body .fx-face-top::after{--sargel-color:rgba(184,144,42,.85);}
.fx-plate.is-strip-alu4 .fx-l-body .fx-face-top::after{--sargel-color:rgba(205,208,212,.92);}
.fx-plate.is-strip-black6 .fx-l-body .fx-face-top::after,
.fx-plate.is-strip-pvc-black-compensation .fx-l-body .fx-face-top::after{--sargel-color:rgba(20,20,22,.88);}
.fx-plate.is-strip-mixed .fx-l-body .fx-face-top::after{--sargel-color:rgba(122,90,24,.88);}
.fx-plate.is-strip-aluminum-yellow-forklift .fx-l-body .fx-face-top::after{--sargel-color:rgba(245,216,80,.92);}
.fx-plate.is-sargel-grid-3x3 .fx-l-body .fx-face-top::after{
 background:
 linear-gradient(90deg,transparent 0,transparent calc(33.33% - 1px),var(--sargel-color) calc(33.33% - 1px),var(--sargel-color) calc(33.33%+1px),transparent calc(33.33%+1px),transparent calc(66.66% - 1px),var(--sargel-color) calc(66.66% - 1px),var(--sargel-color) calc(66.66%+1px),transparent calc(66.66%+1px),transparent),
 linear-gradient(0deg,transparent 0,transparent calc(33.33% - 1px),var(--sargel-color) calc(33.33% - 1px),var(--sargel-color) calc(33.33%+1px),transparent calc(33.33%+1px),transparent calc(66.66% - 1px),var(--sargel-color) calc(66.66% - 1px),var(--sargel-color) calc(66.66%+1px),transparent calc(66.66%+1px),transparent);
 filter:drop-shadow(0 1px 0 rgba(0,0,0,.25));
}
.fx-plate.is-sargel-grid-2x2 .fx-l-body .fx-face-top::after{
 background:
 linear-gradient(90deg,transparent 0,transparent calc(50% - 1.5px),var(--sargel-color) calc(50% - 1.5px),var(--sargel-color) calc(50%+1.5px),transparent calc(50%+1.5px),transparent),
 linear-gradient(0deg,transparent 0,transparent calc(50% - 1.5px),var(--sargel-color) calc(50% - 1.5px),var(--sargel-color) calc(50%+1.5px),transparent calc(50%+1.5px),transparent);
}
.fx-plate.is-sargel-diagonal .fx-l-body .fx-face-top::after{
 background:
 repeating-linear-gradient(45deg,transparent 0,transparent 28%,var(--sargel-color) 28%,var(--sargel-color) calc(28%+2px),transparent calc(28%+2px),transparent 56%);
}
.fx-plate.is-sargel-decorative-meander .fx-l-body .fx-face-top::after{
 background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><g fill='none' stroke='%23b8902a' stroke-width='1.5'><rect x='6' y='6' width='88' height='88'/><path d='M14 14 h12 v6 h-6 v6 h12 v-12'/><path d='M86 14 h-12 v6 h6 v6 h-12 v-12'/><path d='M14 86 h12 v-6 h-6 v-6 h12 v12'/><path d='M86 86 h-12 v-6 h6 v-6 h-12 v12'/><line x1='50' y1='42' x2='50' y2='58'/><line x1='42' y1='50' x2='58' y2='50'/></g></svg>");
 background-size:100% 100%;background-repeat:no-repeat;
 opacity:.72;
}
.fx-plate.is-zones-two-zones .fx-l-body .fx-face-top{
 background-image:
 linear-gradient(90deg,
 var(--plate-base) 0%,var(--plate-base) 49.5%,
 rgba(0,0,0,.2) 49.5%,rgba(0,0,0,.2) 50.5%,
 color-mix(in srgb,var(--plate-base) 70%,#000) 50.5%,color-mix(in srgb,var(--plate-base) 70%,#000) 100%);
 background-size:100% 100%;
 background-blend-mode:multiply;
}
.fx-plate.is-zones-three-zones .fx-l-body .fx-face-top{
 background-image:
 linear-gradient(90deg,
 var(--plate-base) 0%,var(--plate-base) 32.5%,
 rgba(0,0,0,.18) 32.5%,rgba(0,0,0,.18) 33.5%,
 color-mix(in srgb,var(--plate-base) 78%,#fff) 33.5%,color-mix(in srgb,var(--plate-base) 78%,#fff) 66.5%,
 rgba(0,0,0,.18) 66.5%,rgba(0,0,0,.18) 67.5%,
 color-mix(in srgb,var(--plate-base) 70%,#000) 67.5%,color-mix(in srgb,var(--plate-base) 70%,#000) 100%);
 background-blend-mode:multiply;
}
.fx-plate.is-zones-quadrants .fx-l-body .fx-face-top{
 background-image:
 linear-gradient(90deg,var(--plate-base) 0 50%,color-mix(in srgb,var(--plate-base) 78%,#fff) 50% 100%),
 linear-gradient(0deg,color-mix(in srgb,var(--plate-base) 70%,#000) 0 50%,transparent 50% 100%);
 background-blend-mode:multiply,multiply;
}
.fx-plate.is-wood-oak-natural{--wood-color:#a07842;--wood-dark:#6a4520;--wood-light:#c08a52;}
.fx-plate.is-wood-oak-rustic{--wood-color:#7a5530;--wood-dark:#4a2f18;--wood-light:#9a7048;}
.fx-plate.is-wood-oak-smoked{--wood-color:#5a3e22;--wood-dark:#2e2010;--wood-light:#7a5430;}
.fx-plate.is-wood-walnut{--wood-color:#5a3825;--wood-dark:#2e1c10;--wood-light:#7a5038;}
.fx-plate.is-wood-ash{--wood-color:#c8a878;--wood-dark:#8a7048;--wood-light:#e0c498;}
.fx-plate.is-wood-maple{--wood-color:#d8b890;--wood-dark:#a08458;--wood-light:#ecd0a8;}
.fx-plate.is-wood-teak{--wood-color:#8a5a2a;--wood-dark:#553318;--wood-light:#a87a40;}
.fx-plate.is-wood-cherry{--wood-color:#9a4a2a;--wood-dark:#5e2812;--wood-light:#b86848;}
.fx-plate.is-wood-rosewood{--wood-color:#5a2820;--wood-dark:#2c1010;--wood-light:#7a3d2c;}
.fx-plate.is-wood-whitewashed{--wood-color:#d8c8b0;--wood-dark:#a89880;--wood-light:#ece0ce;}
.fx-plate.is-plank-narrow{--plank-w:18%;--plank-h:14%;}
.fx-plate.is-plank-medium{--plank-w:26%;--plank-h:20%;}
.fx-plate.is-plank-wide{--plank-w:38%;--plank-h:26%;}
.fx-plate.is-plank-extra-wide{--plank-w:52%;--plank-h:32%;}
.fx-plate[data-system="parquet"] .fx-l-body .fx-face-top{
 background-color:var(--wood-color,#8a5a2a);
 background-image:
 repeating-linear-gradient(90deg,
 transparent 0,
 rgba(0,0,0,.04) 1px,
 transparent 3px,
 rgba(0,0,0,.06) 5px,
 transparent 8px,
 rgba(255,255,255,.03) 11px,
 transparent 14px),
 linear-gradient(180deg,var(--wood-light,#c08a52) 0%,var(--wood-color,#8a5a2a) 50%,var(--wood-dark,#6a4520) 100%);
 background-size:100% 100%,100% 100%;
}
.fx-plate[data-system="parquet"].is-pattern-straight .fx-l-body .fx-face-top{
 background-image:
 repeating-linear-gradient(90deg,transparent 0,transparent calc(var(--plank-w,26%) - 1px),rgba(0,0,0,.45) calc(var(--plank-w,26%) - 1px),rgba(0,0,0,.45) var(--plank-w,26%),transparent var(--plank-w,26%)),
 repeating-linear-gradient(0deg,transparent 0,transparent calc(var(--plank-h,20%) - 1px),rgba(0,0,0,.32) calc(var(--plank-h,20%) - 1px),rgba(0,0,0,.32) var(--plank-h,20%),transparent var(--plank-h,20%)),
 repeating-linear-gradient(90deg,transparent 0,rgba(0,0,0,.04) 1px,transparent 3px,rgba(0,0,0,.06) 5px,transparent 8px),
 linear-gradient(180deg,var(--wood-light) 0%,var(--wood-color) 50%,var(--wood-dark) 100%);
}
.fx-plate[data-system="parquet"].is-pattern-herringbone .fx-l-body .fx-face-top{
 background-image:
 repeating-linear-gradient(45deg,
 var(--wood-light) 0,
 var(--wood-color) 12px,
 var(--wood-dark) 24px,
 rgba(0,0,0,.55) 25px,
 var(--wood-color) 26px,
 var(--wood-light) 38px),
 repeating-linear-gradient(-45deg,
 transparent 0,
 transparent 38px,
 rgba(0,0,0,.35) 38px,
 rgba(0,0,0,.35) 39px,
 transparent 39px,
 transparent 76px);
 background-size:100% 100%,100% 100%;
}
.fx-plate[data-system="parquet"].is-pattern-chevron .fx-l-body .fx-face-top{
 background-image:
 repeating-linear-gradient(60deg,var(--wood-light) 0,var(--wood-color) 14px,var(--wood-dark) 28px,rgba(0,0,0,.5) 29px,var(--wood-color) 30px),
 repeating-linear-gradient(120deg,transparent 0,transparent 30px,rgba(0,0,0,.4) 30px,rgba(0,0,0,.4) 31px,transparent 31px);
}
.fx-plate[data-system="parquet"].is-pattern-fishbone .fx-l-body .fx-face-top{
 background-image:
 repeating-linear-gradient(90deg,var(--wood-light) 0,var(--wood-color) 18px,rgba(0,0,0,.5) 19px,var(--wood-dark) 20px,var(--wood-color) 38px),
 repeating-linear-gradient(0deg,transparent 0,transparent 38px,rgba(0,0,0,.3) 38px,rgba(0,0,0,.3) 39px,transparent 39px);
}
.fx-plate[data-system="parquet"].is-pattern-versailles .fx-l-body .fx-face-top{
 background-image:
 repeating-linear-gradient(45deg,var(--wood-color) 0,var(--wood-color) 8px,var(--wood-light) 8px,var(--wood-light) 16px,var(--wood-dark) 16px,var(--wood-dark) 18px),
 repeating-linear-gradient(0deg,transparent 0,transparent calc(var(--plank-w,26%) - 1px),rgba(0,0,0,.45) calc(var(--plank-w,26%) - 1px),rgba(0,0,0,.45) var(--plank-w,26%),transparent var(--plank-w,26%)),
 repeating-linear-gradient(90deg,transparent 0,transparent calc(var(--plank-w,26%) - 1px),rgba(0,0,0,.45) calc(var(--plank-w,26%) - 1px),rgba(0,0,0,.45) var(--plank-w,26%),transparent var(--plank-w,26%));
 background-size:32px 32px,100% 100%,100% 100%;
}
.fx-plate[data-system="parquet"].is-pattern-modular .fx-l-body .fx-face-top{
 background-image:
 repeating-linear-gradient(0deg,
 var(--wood-color) 0,
 var(--wood-light) 28px,
 rgba(0,0,0,.4) 29px,
 var(--wood-dark) 30px,
 var(--wood-color) 56px,
 rgba(0,0,0,.4) 57px),
 repeating-linear-gradient(90deg,
 transparent 0,
 transparent 22%,
 rgba(0,0,0,.4) 22%,
 rgba(0,0,0,.4) calc(22%+1px),
 transparent calc(22%+1px),
 transparent 51%,
 rgba(0,0,0,.4) 51%,
 rgba(0,0,0,.4) calc(51%+1px),
 transparent calc(51%+1px),
 transparent 78%,
 rgba(0,0,0,.4) 78%,
 rgba(0,0,0,.4) calc(78%+1px),
 transparent calc(78%+1px));
}
.fx-plate[data-system="parquet"] .fx-plate-pattern{opacity:0 !important;}
.fx-plate.is-cure-standard .fx-l-body .fx-face-top{}
.fx-plate.is-cure-fast .fx-l-body .fx-face-top{
 filter:contrast(1.04) saturate(1.05);
}
.fx-plate.is-sargel-linear .fx-hero-lab__strips{
 opacity:1;
 background-image:
 linear-gradient(to right,transparent 23%,var(--sargel-color,#b8902a) 23% 24%,transparent 24% 25%),
 linear-gradient(to right,transparent 48%,var(--sargel-color,#b8902a) 48% 49%,transparent 49% 50%),
 linear-gradient(to right,transparent 73%,var(--sargel-color,#b8902a) 73% 74%,transparent 74% 75%);
}
.fx-plate.is-cove-R50 .fx-l-body::after,
.fx-plate.is-cove-R75 .fx-l-body::after,
.fx-plate.is-cove-R100 .fx-l-body::after,
.fx-plate.is-cove-R150 .fx-l-body::after{
 content:"";position:absolute;
 left:0;right:0;bottom:0;
 height:8px;
 border-bottom-left-radius:12px;
 border-bottom-right-radius:12px;
 background:linear-gradient(to top,rgba(200,137,61,.55) 0,transparent);
 pointer-events:none;
}
.fx-plate.is-cove-R50 .fx-l-body::after{height:8px;}
.fx-plate.is-cove-R75 .fx-l-body::after{height:11px;}
.fx-plate.is-cove-R100 .fx-l-body::after{height:14px;}
.fx-plate.is-cove-R150 .fx-l-body::after{height:18px;}
.fx-plate.is-mark-yellow-zone .fx-hero-lab__marking{
 opacity:1;
 background-image:
 repeating-linear-gradient(45deg,
 rgba(244,196,48,.85) 0 8px,
 rgba(15,15,15,.7) 8px 16px);
 mix-blend-mode:multiply;
}
.fx-plate.is-mark-white-grid .fx-hero-lab__marking{
 opacity:1;
 background-image:
 linear-gradient(to right,rgba(255,255,255,.85) 0 2px,transparent 2px 60px),
 linear-gradient(to bottom,rgba(255,255,255,.85) 0 2px,transparent 2px 60px);
 background-size:60px 60px;
 mix-blend-mode:screen;
}
.fx-plate.is-mark-red-safety .fx-hero-lab__marking{
 opacity:1;
 background-image:
 repeating-linear-gradient(-45deg,
 rgba(208,40,40,.8) 0 6px,
 rgba(255,255,255,.7) 6px 12px);
 mix-blend-mode:multiply;
}
.fx-plate.is-mark-pedestrian .fx-hero-lab__marking{
 opacity:1;
 background-image:
 repeating-linear-gradient(to right,
 rgba(255,255,255,.85) 0 18px,
 transparent 18px 36px);
 mix-blend-mode:screen;
}
.fx-plate.is-fleck-fine .fx-hero-lab__flecks,
.fx-plate.is-fleck-fine-vinyl-1-16 .fx-hero-lab__flecks,
.fx-plate.is-fleck-medium-vinyl-1-8 .fx-hero-lab__flecks{
 opacity:1;
 background-image:radial-gradient(circle at 25% 30%,rgba(0,0,0,.45) 0 1.5px,transparent 2px);
 background-size:12px 12px;
}
.fx-plate.is-fleck-coarse .fx-hero-lab__flecks,
.fx-plate.is-fleck-large-vinyl-1-4 .fx-hero-lab__flecks{
 opacity:1;
 background-image:
 radial-gradient(circle at 30% 40%,rgba(0,0,0,.55) 0 4px,transparent 5px),
 radial-gradient(circle at 70% 70%,rgba(255,255,255,.40) 0 3px,transparent 4px);
 background-size:30px 30px;
}
.fx-plate.is-fleck-xl-vinyl-1-2 .fx-hero-lab__flecks{
 opacity:1;
 background-image:
 radial-gradient(circle at 30% 30%,rgba(0,0,0,.6) 0 8px,transparent 10px),
 radial-gradient(circle at 70% 70%,rgba(255,255,255,.5) 0 7px,transparent 9px);
 background-size:50px 50px;
}
.fx-plate.is-fleck-mica .fx-hero-lab__flecks,
.fx-plate.is-fleck-mica-pearl-iriodin .fx-hero-lab__flecks{
 opacity:1;
 mix-blend-mode:screen;
 background-image:radial-gradient(circle at 30% 30%,rgba(255,255,255,.55) 0 1px,transparent 2px);
 background-size:8px 8px;
}
.fx-plate.is-fleck-metallic .fx-hero-lab__flecks,
.fx-plate.is-fleck-metallic-bronze-stapa .fx-hero-lab__flecks{
 opacity:1;
 mix-blend-mode:screen;
 background-image:
 radial-gradient(circle at 30% 30%,rgba(184,144,42,.7) 0 2px,transparent 3px),
 radial-gradient(circle at 70% 70%,rgba(106,77,18,.6) 0 1.5px,transparent 2.5px);
 background-size:16px 16px;
}
.fx-plate.is-fleck-metallic-copper-stapa .fx-hero-lab__flecks{
 opacity:1;
 mix-blend-mode:screen;
 background-image:
 radial-gradient(circle at 30% 30%,rgba(184,115,51,.7) 0 2px,transparent 3px);
 background-size:14px 14px;
}
.fx-plate.is-fleck-full-broadcast .fx-hero-lab__flecks{
 opacity:1;
 background-image:
 radial-gradient(circle at 25% 25%,rgba(0,0,0,.5) 0 5px,transparent 6px),
 radial-gradient(circle at 60% 60%,rgba(0,0,0,.45) 0 5px,transparent 6px),
 radial-gradient(circle at 80% 30%,rgba(255,255,255,.4) 0 4px,transparent 5px);
 background-size:16px 16px;
}
.fx-plate.cert-standard{}
.fx-plate.cert-cleanroom-ISO5 .fx-l-body .fx-face-top{
 filter:brightness(1.05) saturate(0.92);
}
.fx-plate.cert-cleanroom-ISO5 .fx-l-body .fx-face-top::after{
 content:"";position:absolute;inset:0;
 background:rgba(255,255,255,0.06);
 pointer-events:none;
}
.fx-plate.is-polishLevel-L1-ground-matte .fx-l-body .fx-face-top{
 filter:contrast(0.96) saturate(0.92);
}
.fx-plate.is-polishLevel-L2-honed-satin .fx-l-body .fx-face-top{
 filter:contrast(1.0) saturate(1.0);
}
.fx-plate.is-polishLevel-L3-polished-gloss .fx-l-body .fx-face-top{
 filter:contrast(1.05) saturate(1.05) brightness(1.03);
}
.fx-plate.is-polishLevel-L4-mirror .fx-l-body .fx-face-top{
 filter:contrast(1.1) saturate(1.08) brightness(1.06);
}
.fx-plate.is-polishLevel-L4-mirror .fx-l-body .fx-face-top::after{
 content:"";position:absolute;inset:0;
 background:linear-gradient(135deg,rgba(255,255,255,.18) 0%,transparent 35%,transparent 65%,rgba(255,255,255,.10) 100%);
 pointer-events:none;
}
.fx-plate.is-densifier-lithium-silicate .fx-l-body .fx-face-top{filter:brightness(1.02);}
.fx-plate.is-densifier-sodium-silicate .fx-l-body .fx-face-top{filter:brightness(.985) saturate(.97);}
.fx-plate.is-densifier-potassium-silicate .fx-l-body .fx-face-top{filter:brightness(1.01) saturate(1.02);}
.fx-plate.is-densifier-colloidal-silica .fx-l-body .fx-face-top{filter:brightness(1.03) saturate(1.04);}
.fx-plate.is-stainDye-acid-stain .fx-l-body .fx-face-top{
 background-image:radial-gradient(ellipse at 30% 40%,rgba(120,68,30,.35) 0%,transparent 60%);
 mix-blend-mode:multiply;
}
.fx-plate.is-stainDye-water-dye .fx-l-body .fx-face-top{
 background-image:linear-gradient(120deg,rgba(70,90,140,.18) 0%,rgba(70,90,140,.10) 100%);
}
.fx-plate.is-stainDye-reactive-stain .fx-l-body .fx-face-top{
 background-image:radial-gradient(ellipse at 60% 60%,rgba(70,40,90,.35) 0%,transparent 70%);
 mix-blend-mode:multiply;
}
.fx-plate.is-broadcastDensity-light .fx-hero-lab__flecks{
 opacity:1;
 background-image:radial-gradient(circle at 50% 50%,rgba(0,0,0,.35) 0 1.5px,transparent 2.5px);
 background-size:18px 18px;
}
.fx-plate.is-broadcastDensity-medium .fx-hero-lab__flecks{
 opacity:1;
 background-image:radial-gradient(circle at 50% 50%,rgba(0,0,0,.45) 0 2px,transparent 3px);
 background-size:12px 12px;
}
.fx-plate.is-broadcastDensity-heavy .fx-hero-lab__flecks{
 opacity:1;
 background-image:
 radial-gradient(circle at 30% 30%,rgba(0,0,0,.55) 0 2.5px,transparent 3.5px),
 radial-gradient(circle at 70% 70%,rgba(0,0,0,.4) 0 2px,transparent 3px);
 background-size:8px 8px;
}
.fx-l-mesh[data-cb-type="aramid-mat"] .fx-face-top{
 background:
 repeating-linear-gradient(45deg,rgba(220,200,140,.85) 0 .8px,transparent .8px 5px),
 repeating-linear-gradient(-45deg,rgba(220,200,140,.85) 0 .8px,transparent .8px 5px);
}
.fx-l-mesh[data-cb-type="dry-mix-mesh"] .fx-face-top{
 background:
 radial-gradient(circle at 30% 30%,rgba(255,255,255,.5) 0 .6px,transparent 1px);
 background-size:4px 4px;
}
.fx-plate.is-fin-matte .fx-l-body{filter:contrast(.98) brightness(.98) saturate(.96);}
.fx-plate.is-fin-satin .fx-l-body{filter:contrast(1.01) brightness(1.00) saturate(1.00);}
.fx-plate.is-fin-polished .fx-l-body{filter:contrast(1.04) brightness(1.02) saturate(1.02);}
.fx-plate.is-fin-glossy .fx-l-body{filter:contrast(1.08) brightness(1.04) saturate(1.05);}
.fx-plate.is-fin-wetlook .fx-l-body{filter:contrast(1.12) brightness(1.06) saturate(1.10);}
.fx-plate.is-fleck-medium .fx-hero-lab__flecks{
 opacity:1;
 background-image:
 radial-gradient(circle at 22% 18%,rgba(40,40,40,.55) 0 1.2px,transparent 1.7px),
 radial-gradient(circle at 68% 36%,rgba(80,70,60,.50) 0 1.4px,transparent 2px),
 radial-gradient(circle at 42% 70%,rgba(40,40,40,.55) 0 1.3px,transparent 1.8px),
 radial-gradient(circle at 84% 82%,rgba(60,55,50,.55) 0 1.2px,transparent 1.7px);
 background-size:18px 18px,22px 22px,16px 16px,24px 24px;
 mix-blend-mode:multiply;
}
.fx-plate.is-fleck-metallic-bronze .fx-hero-lab__flecks{
 opacity:.95;
 background-image:
 radial-gradient(circle at 30% 30%,rgba(184,128,46,.85) 0 1.6px,transparent 2.4px),
 radial-gradient(circle at 65% 60%,rgba(212,150,72,.78) 0 1.4px,transparent 2.2px),
 radial-gradient(circle at 18% 78%,rgba(150,98,30,.82) 0 1.4px,transparent 2px);
 background-size:14px 14px,20px 20px,18px 18px;
 mix-blend-mode:screen;
 filter:drop-shadow(0 0 .6px rgba(255,200,140,.6));
}
.fx-plate.is-fleck-metallic-copper .fx-hero-lab__flecks{
 opacity:.95;
 background-image:
 radial-gradient(circle at 28% 32%,rgba(202,108,58,.88) 0 1.5px,transparent 2.3px),
 radial-gradient(circle at 70% 58%,rgba(232,140,82,.78) 0 1.4px,transparent 2.2px),
 radial-gradient(circle at 16% 80%,rgba(176,82,40,.85) 0 1.3px,transparent 2px);
 background-size:14px 14px,20px 20px,18px 18px;
 mix-blend-mode:screen;
 filter:drop-shadow(0 0 .6px rgba(255,170,120,.6));
}
.fx-plate.is-fleck-metallic-pearl .fx-hero-lab__flecks{
 opacity:.85;
 background-image:
 radial-gradient(circle at 26% 28%,rgba(245,240,230,.85) 0 1.6px,transparent 2.4px),
 radial-gradient(circle at 64% 56%,rgba(220,225,235,.78) 0 1.5px,transparent 2.3px),
 radial-gradient(circle at 18% 82%,rgba(255,250,245,.82) 0 1.4px,transparent 2.2px);
 background-size:16px 16px,22px 22px,18px 18px;
 mix-blend-mode:screen;
 filter:drop-shadow(0 0 .8px rgba(255,255,255,.7));
}
.fx-plate[data-cb-on] .fx-l-body .fx-face-top::after{
 content:"";
 position:absolute;
 inset:0;
 pointer-events:none;
 z-index:1;
 background-image:
 repeating-linear-gradient(0deg,rgba(255,255,255,.18) 0 .6px,transparent .6px 7px),
 repeating-linear-gradient(90deg,rgba(255,255,255,.18) 0 .6px,transparent .6px 7px),
 repeating-linear-gradient(0deg,rgba(0,0,0,.10) 0 .4px,transparent .4px 7px),
 repeating-linear-gradient(90deg,rgba(0,0,0,.10) 0 .4px,transparent .4px 7px);
 mix-blend-mode:overlay;
 opacity:.55;
 transition:opacity .28s cubic-bezier(.22,1,.36,1);
}
.fx-plate[data-cb-on="aramid-mat"] .fx-l-body .fx-face-top::after{
 background-image:
 repeating-linear-gradient(45deg,rgba(220,200,140,.6) 0 .7px,transparent .7px 6px),
 repeating-linear-gradient(-45deg,rgba(220,200,140,.6) 0 .7px,transparent .7px 6px);
 opacity:.45;
}
.fx-plate[data-cb-on="dry-mix-mesh"] .fx-l-body .fx-face-top::after{
 background-image:
 radial-gradient(circle at 30% 30%,rgba(255,255,255,.6) 0 .5px,transparent 1px);
 background-size:5px 5px;
 opacity:.35;
}
.fx-plate.is-sargel-grid-3x3[data-cb-on] .fx-l-body .fx-face-top::after,
.fx-plate.is-sargel-grid-2x2[data-cb-on] .fx-l-body .fx-face-top::after,
.fx-plate.is-sargel-diagonal[data-cb-on] .fx-l-body .fx-face-top::after,
.fx-plate.is-sargel-decorative-meander[data-cb-on] .fx-l-body .fx-face-top::after{
 
 opacity:.25;
}
.fx-l-body .fx-face-top>.fx-hero-lab__strips{
 position:absolute;
 inset:0;
 pointer-events:none;
 z-index:3;
 filter:drop-shadow(0 1px 1px rgba(0,0,0,.18));
}
.fx-plate.is-strip-brass4 .fx-l-body .fx-face-top,
.fx-plate.is-strip-brass-3mm-arch .fx-l-body .fx-face-top,
.fx-plate.is-strip-mixed .fx-l-body .fx-face-top{
 box-shadow:
 inset 0 0 0 4px #b8902a,
 inset 0 0 0 5px rgba(255,255,255,.35),
 inset 0 0 10px 5px rgba(0,0,0,.18);
}
.fx-plate.is-strip-alu4 .fx-l-body .fx-face-top,
.fx-plate.is-strip-aluminum-yellow-forklift .fx-l-body .fx-face-top{
 box-shadow:
 inset 0 0 0 4px #cdd0d4,
 inset 0 0 0 5px rgba(255,255,255,.45),
 inset 0 0 10px 5px rgba(0,0,0,.16);
}
.fx-plate.is-strip-black6 .fx-l-body .fx-face-top,
.fx-plate.is-strip-pvc-black-compensation .fx-l-body .fx-face-top{
 box-shadow:
 inset 0 0 0 6px #0a0a0a,
 inset 0 0 0 7px rgba(255,255,255,.20);
}
.fx-plate.is-aggsize-large .fx-l-body .fx-face-top{
 filter:contrast(var(--plate-body-contrast,1.04)) saturate(1.05);
}
.fx-plate.is-aggsize-small .fx-l-body .fx-face-top{
 filter:contrast(0.98) saturate(.98);
}
.fx-decision{
 position:relative;
 padding-top:clamp(48px,8vh,96px);
 padding-bottom:clamp(64px,10vh,128px);
}
.fx-decision::before{
 content:"";
 position:absolute;
 inset:0;
 z-index:-1;
 background:
 radial-gradient(ellipse at 50% 0%,rgba(29,29,31,.04) 0,transparent 60%),
 radial-gradient(ellipse at 50% 100%,rgba(29,29,31,.03) 0,transparent 70%);
 pointer-events:none;
}
.fx-decision__option{
 box-shadow:0 1px 0 rgba(29,29,31,.04);
 transition:border-color .25s ease,transform .25s ease,box-shadow .25s ease;
}
.fx-decision__option:hover{
 box-shadow:0 8px 24px rgba(29,29,31,.10),0 2px 6px rgba(29,29,31,.06);
}
.fx-decision__option-name{
 font-size:24px;
 line-height:1.2;
}
.fx-calc-config{
 margin:0 0 24px;
 padding:18px 22px;
 background:#f5f5f7;
 border-radius:14px;
 border:1px solid #e8e8ed;
}
.fx-calc-config[hidden]{display:none;}
.fx-calc-config__title{
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:700;
 letter-spacing:.2em;
 text-transform:uppercase;
 color:#6e6e73;
 margin:0 0 12px;
}
.fx-calc-config__list{
 display:grid;
 grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
 gap:10px 24px;
 margin:0 0 12px;
}
.fx-calc-config__list dt{
 font-family:'Montserrat',sans-serif;
 font-size:10px;
 font-weight:500;
 letter-spacing:.12em;
 text-transform:uppercase;
 color:#86868b;
 margin:0;
}
.fx-calc-config__list dd{
 font-family:'Montserrat',sans-serif;
 font-size:14px;
 font-weight:500;
 color:#1d1d1f;
 margin:0 0 2px;
}
.fx-calc-config__edit{
 display:inline-block;
 font-size:12px;
 color:#6e6e73;
 text-decoration:none;
 border-bottom:1px dashed #c7c7cc;
 padding-bottom:1px;
 transition:color .2s,border-color .2s;
}
.fx-calc-config__edit:hover{color:#1d1d1f;border-color:#1d1d1f;}
.fx-calc-lead{margin-top:18px;}
.fx-calc-lead__lede{
 font-size:13px;
 color:#6e6e73;
 margin:0 0 14px;
 line-height:1.5;
}
.fx-calc-lead__row{
 display:grid;
 grid-template-columns:1fr 1fr;
 gap:10px;
 margin-bottom:10px;
}
@media (max-width:540px){
 .fx-calc-lead__row{grid-template-columns:1fr;}
}
.fx-calc-lead input{
 font-family:'Inter','Montserrat',sans-serif;
 font-size:14px;
 padding:11px 14px;
 background:#fff;
 border:1px solid #e8e8ed;
 border-radius:10px;
 color:#1d1d1f;
 outline:none;
 transition:border-color .2s,background .2s;
 width:100%;
}
.fx-calc-lead input:focus{border-color:#1d1d1f;}
.fx-calc-lead .fx-calc-cta{
 width:100%;
 margin-top:6px;
 padding:14px 22px;
}
.fx-calc-lead__legal{
 font-size:11px;
 color:#86868b;
 line-height:1.5;
 margin:8px 0 0;
}
.fx-calc-lead__thanks{
 margin-top:18px;
 padding:20px;
 background:#f5f5f7;
 border-radius:14px;
 text-align:center;
}
.fx-calc-lead__thanks h4{
 font-family:'Cormorant Garamond',serif;
 font-size:26px;
 font-weight:500;
 margin:0 0 6px;
}
.fx-calc-lead__thanks p{font-size:14px;color:#6e6e73;margin:0;line-height:1.5;}
.fx-hero-lab__tech{
 margin-top:18px;
 padding-top:18px;
 border-top:1px solid #e8e8ed;
}
.fx-hero-lab__tech-summary{
 display:flex;
 align-items:center;
 justify-content:space-between;
 gap:8px;
 cursor:pointer;
 font-family:'Montserrat',sans-serif;
 font-size:12px;
 font-weight:600;
 letter-spacing:.18em;
 text-transform:uppercase;
 color:#6e6e73;
 list-style:none;
 user-select:none;
 -webkit-user-select:none;
 padding:4px 0;
 transition:color .2s;
}
.fx-hero-lab__tech-summary::-webkit-details-marker{display:none;}
.fx-hero-lab__tech-summary:hover{color:#1d1d1f;}
.fx-hero-lab__tech-caret{
 font-size:16px;
 font-weight:400;
 transition:transform .25s ease;
 color:#c7c7cc;
}
.fx-hero-lab__tech[open] .fx-hero-lab__tech-caret{transform:rotate(90deg);}
.fx-hero-lab__tech-body{
 display:flex;
 flex-direction:column;
 gap:18px;
 padding-top:18px;
}
.fx-hero-lab__tech-body .fx-hero-lab__group{padding-bottom:0;border-bottom:0;}
.fx-hero-lab__tech-body .fx-hero-lab__group+.fx-hero-lab__group{
 padding-top:18px;
 border-top:1px dashed #ececf0;
}
.fx-summary-bar{
 display:flex;
 flex-wrap:nowrap;
 gap:0;
 margin:28px 0 0;
 width:100%;
 padding:18px 4px;
 border-top:1px solid #e8e8ed;
 border-bottom:1px solid #e8e8ed;
 justify-content:space-between;
 
 grid-column:1 / -1;
}
.fx-summary-bar__item{
 display:flex;
 flex-direction:column;
 gap:4px;
 padding:4px 16px;
 min-width:0;
 flex:1 1 auto;
}
.fx-summary-bar__item+.fx-summary-bar__item{
 border-left:1px solid #e8e8ed;
}
.fx-summary-bar__lbl{
 font-family:'Montserrat',sans-serif;
 font-size:10px;
 font-weight:500;
 letter-spacing:.18em;
 text-transform:uppercase;
 color:#86868b;
 white-space:nowrap;
}
.fx-summary-bar__val{
 font-family:'Montserrat',sans-serif;
 font-size:15px;
 font-weight:600;
 color:#1d1d1f;
 line-height:1.25;
 letter-spacing:0;
}
@media (max-width:980px){
 .fx-summary-bar{flex-direction:column;padding:12px 0;}
 .fx-summary-bar__item{flex-direction:row;justify-content:space-between;padding:8px 12px;}
 .fx-summary-bar__item+.fx-summary-bar__item{border-left:0;border-top:1px solid #e8e8ed;}
}
.fx-hero-lab__ctrl-label{display:inline-flex;align-items:center;gap:6px;}
.fx-hero-lab__hint{
 display:inline-flex;
 align-items:center;
 justify-content:center;
 width:14px;
 height:14px;
 font-family:'Montserrat',sans-serif;
 font-size:9px;
 font-weight:700;
 color:#6e6e73;
 background:transparent;
 border:1px solid #c7c7cc;
 border-radius:50%;
 cursor:help;
 letter-spacing:0;
 transition:color .2s,border-color .2s,background .2s;
 position:relative;
 user-select:none;
 -webkit-user-select:none;
}
.fx-hero-lab__hint:hover,
.fx-hero-lab__hint:focus{
 color:#fff;
 background:#1d1d1f;
 border-color:#1d1d1f;
 outline:none;
}
.fx-hero-lab__hint::after{
 content:attr(data-glossary);
 position:absolute;
 bottom:calc(100%+10px);
 left:50%;
 transform:translateX(-50%) translateY(4px);
 width:max-content;
 max-width:280px;
 padding:10px 14px;
 font-family:'Inter','Montserrat',sans-serif;
 font-size:12px;
 font-weight:400;
 line-height:1.45;
 letter-spacing:0;
 text-transform:none;
 color:#f5f5f7;
 background:#1d1d1f;
 border-radius:10px;
 white-space:normal;
 text-align:left;
 pointer-events:none;
 opacity:0;
 transition:opacity .2s,transform .2s;
 z-index:30;
 box-shadow:0 8px 24px rgba(0,0,0,.25);
}
.fx-hero-lab__hint::before{
 content:'';
 position:absolute;
 bottom:calc(100%+4px);
 left:50%;
 transform:translateX(-50%);
 border:5px solid transparent;
 border-top-color:#1d1d1f;
 pointer-events:none;
 opacity:0;
 transition:opacity .2s;
 z-index:30;
}
.fx-hero-lab__hint:hover::after,
.fx-hero-lab__hint:focus::after,
.fx-hero-lab__hint:hover::before,
.fx-hero-lab__hint:focus::before{
 opacity:1;
 transform:translateX(-50%) translateY(0);
}
.fx-hero-lab__more{display:contents;}
.fx-hero-lab__more-hidden{
 display:contents;
}
.fx-hero-lab__more-hidden[hidden]{display:none;}
.fx-hero-lab__more-btn{
 display:inline-flex;
 align-items:center;
 padding:6px 12px;
 font-family:'Montserrat',sans-serif;
 font-size:11px;
 font-weight:500;
 letter-spacing:.04em;
 color:#6e6e73;
 background:transparent;
 border:1px dashed #c7c7cc;
 border-radius:16px;
 cursor:pointer;
 transition:color .2s,border-color .2s,background .2s;
}
.fx-hero-lab__more-btn:hover{
 color:#1d1d1f;
 border-color:#1d1d1f;
 background:#f5f5f7;
}
.blog-card .read-more.is-soon{
 display:inline-block;
 color:#9a9a9a;
 cursor:default;
 pointer-events:none;
 font-style:italic;
 opacity:.75;
}
.blog-card:has(.read-more.is-soon){opacity:.82;}
.hero3d{
 position:relative;
 isolation:isolate;
 overflow:hidden;
 background:#0a0a0c;
 color:#f5f5f7;
 padding:clamp(110px,14vh,170px) 0 clamp(72px,10vh,120px);
}
.hero3d__bg{
 position:absolute;inset:0;
 background-image:url('images/terrazzo/dark-mosaic-textured-background.jpg');
 background-size:cover;
 background-position:center;
 filter:saturate(.55) brightness(.45);
 transform:scale(1.06);
 z-index:-3;
}
.hero3d__veil{
 position:absolute;inset:0;
 background:
 radial-gradient(ellipse at 20% 30%,rgba(255,255,255,.06),transparent 55%),
 radial-gradient(ellipse at 85% 80%,rgba(0,113,227,.22),transparent 55%),
 linear-gradient(180deg,rgba(8,8,12,.55) 0%,rgba(8,8,12,.85) 70%,#0a0a0c 100%);
 z-index:-2;
}
.hero3d__grid{
 position:absolute;inset:0;
 background-image:
 linear-gradient(to right,rgba(255,255,255,.05) 1px,transparent 1px),
 linear-gradient(to bottom,rgba(255,255,255,.05) 1px,transparent 1px);
 background-size:64px 64px;
 mask-image:radial-gradient(circle at 30% 40%,#000 0%,transparent 75%);
 -webkit-mask-image:radial-gradient(circle at 30% 40%,#000 0%,transparent 75%);
 z-index:-1;
}
.hero3d__inner{
 max-width:1320px;
 margin:0 auto;
 padding:0 clamp(20px,4vw,56px);
 display:grid;
 grid-template-columns:minmax(0,1.02fr) minmax(0,1fr);
 gap:clamp(40px,6vw,96px);
 align-items:center;
}
.hero3d__copy{display:flex;flex-direction:column;gap:22px;max-width:640px;}
.hero3d__eyebrow{
 display:inline-flex;align-items:center;gap:10px;
 font-family:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
 font-size:11px;
 letter-spacing:0.22em;
 text-transform:uppercase;
 color:rgba(245,245,247,.66);
 margin:0;
 padding:8px 14px;
 border:1px solid rgba(255,255,255,.14);
 border-radius:999px;
 align-self:flex-start;
 backdrop-filter:blur(6px);
 -webkit-backdrop-filter:blur(6px);
 background:rgba(255,255,255,.04);
}
.hero3d__dot{
 width:7px;height:7px;border-radius:50%;
 background:#0a84ff;
 box-shadow:0 0 0 4px rgba(10,132,255,.22);
 animation:hero3dPulse 1.8s ease-in-out infinite;
}
@keyframes hero3dPulse{50%{transform:scale(.7);opacity:.5;}}
.hero3d__h1{
 font-family:'Cormorant Garamond',Georgia,serif;
 font-weight:400;
 font-size:clamp(44px,6.4vw,88px);
 line-height:1.02;
 letter-spacing:-0.022em;
 color:#fff;
 margin:0;
 text-wrap:balance;
}
.hero3d__h1 em{
 font-style:italic;
 font-weight:500;
 background:linear-gradient(180deg,#ffffff 0%,#c7c7cc 100%);
 -webkit-background-clip:text;
 background-clip:text;
 color:transparent;
}
.hero3d__lede{
 font-family:'Montserrat',sans-serif;
 font-size:clamp(15px,1.15vw,17px);
 line-height:1.6;
 color:rgba(245,245,247,.78);
 max-width:560px;
 margin:0;
}
.hero3d__cta{
 display:flex;gap:12px;flex-wrap:wrap;margin-top:6px;
}
.hero3d__btn{
 display:inline-flex;align-items:center;gap:12px;
 padding:18px 28px;
 font-family:'Montserrat',sans-serif;
 font-size:14.5px;
 font-weight:500;
 letter-spacing:-0.005em;
 text-decoration:none;
 border-radius:999px;
 transition:transform .25s ease,background .2s ease,color .2s ease,border-color .2s ease;
 white-space:nowrap;
}
.hero3d__btn--primary{
 background:#ffffff;
 color:#1d1d1f;
 box-shadow:0 12px 32px rgba(0,0,0,.35),0 4px 10px rgba(0,0,0,.25);
}
.hero3d__btn--primary:hover{
 transform:translateY(-2px);
 background:#f5f5f7;
}
.hero3d__btn--primary:hover .hero3d__btn-arrow{transform:translateX(4px);}
.hero3d__btn-arrow{transition:transform .25s ease;display:inline-block;}
.hero3d__btn--ghost{
 background:rgba(255,255,255,.06);
 color:#f5f5f7;
 border:1px solid rgba(255,255,255,.22);
}
.hero3d__btn--ghost:hover{
 background:rgba(255,255,255,.12);
 border-color:rgba(255,255,255,.4);
}
.hero3d__specs{
 list-style:none;padding:0;margin:12px 0 0;
 display:grid;grid-template-columns:repeat(4,minmax(0,1fr));
 gap:0;
 border-top:1px solid rgba(255,255,255,.14);
}
.hero3d__specs li{
 display:flex;flex-direction:column;gap:4px;
 padding:18px 16px 0 0;
 border-right:1px solid rgba(255,255,255,.10);
}
.hero3d__specs li:last-child{border-right:none;}
.hero3d__specs b{
 font-family:'Cormorant Garamond',Georgia,serif;
 font-weight:500;
 font-size:26px;
 line-height:1;
 color:#fff;
 letter-spacing:-0.01em;
}
.hero3d__specs span{
 font-family:'JetBrains Mono',ui-monospace,monospace;
 font-size:10.5px;
 letter-spacing:0.16em;
 text-transform:uppercase;
 color:rgba(245,245,247,.55);
}
.hero3d__preview{
 display:block;
 position:relative;
 text-decoration:none;
 color:inherit;
 perspective:1600px;
}
.hero3d__frame{
 position:relative;
 border-radius:20px;
 overflow:hidden;
 background:#f5f5f7;
 border:1px solid rgba(255,255,255,.10);
 box-shadow:
 0 60px 120px rgba(0,0,0,.55),
 0 24px 50px rgba(0,113,227,.18),
 0 0 0 1px rgba(255,255,255,.04);
 transform:rotateY(-6deg) rotateX(2deg);
 transform-origin:center;
 transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .4s ease;
 aspect-ratio:4 / 4.3;
 max-height:640px;
}
.hero3d__preview:hover .hero3d__frame{
 transform:rotateY(-2deg) rotateX(1deg) translateY(-6px);
 box-shadow:
 0 80px 140px rgba(0,0,0,.6),
 0 30px 60px rgba(0,113,227,.28),
 0 0 0 1px rgba(255,255,255,.06);
}
.hero3d__chrome{
 position:absolute;top:0;left:0;right:0;
 height:30px;
 display:flex;align-items:center;gap:7px;
 padding:0 14px;
 background:rgba(245,245,247,.92);
 backdrop-filter:blur(8px);
 -webkit-backdrop-filter:blur(8px);
 border-bottom:1px solid rgba(0,0,0,.06);
 z-index:2;
}
.hero3d__chrome i{
 display:block;width:10px;height:10px;border-radius:50%;
 background:#d2d2d7;
}
.hero3d__chrome i:nth-child(1){background:#ff5f57;}
.hero3d__chrome i:nth-child(2){background:#febc2e;}
.hero3d__chrome i:nth-child(3){background:#28c840;}
.hero3d__frame img{
 width:100%;height:100%;
 object-fit:cover;
 object-position:center top;
 display:block;
}
.hero3d__play{
 position:absolute;left:50%;top:50%;
 transform:translate(-50%,-50%);
 width:80px;height:80px;
 display:flex;align-items:center;justify-content:center;
 border-radius:50%;
 box-shadow:0 12px 28px rgba(0,0,0,.4);
 transition:transform .25s ease,box-shadow .25s ease;
 pointer-events:none;
}
.hero3d__preview:hover .hero3d__play{
 transform:translate(-50%,-50%) scale(1.08);
 box-shadow:0 16px 36px rgba(0,0,0,.5);
}
.hero3d__badge{
 position:absolute;left:14px;bottom:14px;
 display:inline-flex;align-items:center;gap:6px;
 padding:6px 10px;
 border-radius:999px;
 background:rgba(10,10,12,.78);
 color:#fff;
 font-family:'JetBrains Mono',ui-monospace,monospace;
 font-size:10px;
 letter-spacing:0.18em;
 text-transform:uppercase;
 border:1px solid rgba(255,255,255,.12);
 backdrop-filter:blur(6px);
 -webkit-backdrop-filter:blur(6px);
}
.hero3d__badge::before{
 content:"";width:6px;height:6px;border-radius:50%;
 background:#28c840;
 box-shadow:0 0 0 3px rgba(40,200,64,.22);
}
.hero3d__caption{
 margin:18px 4px 0;
 font-family:'JetBrains Mono',ui-monospace,monospace;
 font-size:10.5px;
 letter-spacing:0.18em;
 text-transform:uppercase;
 color:rgba(245,245,247,.45);
 text-align:center;
}
@media (max-width:1000px){
 .hero3d__inner{grid-template-columns:1fr;gap:48px;}
 .hero3d__frame{transform:rotateY(0) rotateX(0);aspect-ratio:4 / 4;max-height:520px;}
 .hero3d__preview:hover .hero3d__frame{transform:translateY(-4px);}
}
@media (max-width:640px){
 .hero3d{padding:96px 0 64px;}
 .hero3d__inner{padding:0 18px;gap:36px;}
 .hero3d__h1{font-size:clamp(36px,9.5vw,56px);}
 .hero3d__lede{font-size:14.5px;}
 .hero3d__btn{padding:15px 22px;font-size:14px;}
 .hero3d__specs{grid-template-columns:repeat(2,minmax(0,1fr));}
 .hero3d__specs li{padding:16px 12px 0 0;}
 .hero3d__specs li:nth-child(2){border-right:none;}
 .hero3d__specs li:nth-child(3),
 .hero3d__specs li:nth-child(4){border-top:1px solid rgba(255,255,255,.10);margin-top:14px;padding-top:16px;}
 .hero3d__frame{aspect-ratio:4 / 3.6;max-height:380px;border-radius:14px;}
 .hero3d__chrome{height:24px;}
 .hero3d__play{width:60px;height:60px;}
}
