.ws-techb,
.ws-techb *{
  box-sizing:border-box;
}

.ws-techb{
  --ws-techb-accent:var(--ws-btn-primary-bg, #FFD152);
  --ws-techb-bg:#1d1b1b;
  --ws-techb-card:#1d1b1b;
  --ws-techb-line:rgba(255,255,255,.09);
  --ws-techb-muted:rgba(255,255,255,.72);
  padding:32px 0;
  background:var(--ws-techb-bg);
  color:#fff;
}

.ws-techb__container{
  width:min(100%, 90rem);
  margin:0 auto;
  padding:0 24px;
}

.ws-techb__head{
  max-width:780px;
  margin:0 auto 22px;
  text-align:center;
  position:relative;
}

.ws-techb__eyebrow{
  margin:0 0 8px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  font-family:var(--font-body, "Montserrat", sans-serif);
  font-size:13px;
  line-height:1;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:none;
  color:var(--ws-techb-accent);
}

.ws-techb .ws-techb__eyebrow,
.ws-techb .ws-techb__eyebrow span{
  color:var(--ws-techb-accent) !important;
}

.ws-techb__eyebrow-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  color:var(--ws-techb-accent);
}

.ws-techb__eyebrow-icon svg{
  width:17px;
  height:17px;
  display:block;
}

.ws-techb__title{
  margin:0;
  font-family:var(--font-head, "Roboto Slab", serif);
  font-size:var(--h2-size);
  line-height:1.08;
  letter-spacing:var(--h-track);
  font-weight:800;
  color:#fff;
}

.ws-techb__title mark,
.ws-techb__title span,
.ws-techb__subtitle mark,
.ws-techb__subtitle span{
  padding:0;
  background:transparent;
  color:var(--ws-techb-accent) !important;
  -webkit-text-fill-color:var(--ws-techb-accent) !important;
}

.ws-techb__title-accent{
  color:var(--ws-techb-accent) !important;
  -webkit-text-fill-color:var(--ws-techb-accent) !important;
}

.ws-techb__subtitle{
  margin:.55rem auto 0;
  max-width:860px;
  font-family:var(--font-body, "Montserrat", sans-serif);
  font-size:var(--txt-size);
  line-height:1.45;
  font-weight:500;
  color:rgba(255,255,255,.78);
}

.ws-techb__head::after{
  content:"";
  display:block;
  width:190px;
  height:22px;
  margin:8px auto 0;
  background:
    linear-gradient(var(--ws-techb-accent), var(--ws-techb-accent)) left 50% / 78px 1px no-repeat,
    linear-gradient(var(--ws-techb-accent), var(--ws-techb-accent)) right 50% / 78px 1px no-repeat;
  opacity:.85;
}

.ws-techb__head::before{
  content:"×";
  position:absolute;
  left:50%;
  bottom:0;
  width:22px;
  height:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  transform:translateX(-50%);
  font-family:var(--font-body, "Montserrat", sans-serif);
  font-size:22px;
  line-height:1;
  font-weight:500;
  color:var(--ws-techb-accent);
}

.ws-techb__grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(420px, 1fr);
  gap:40px;
  align-items:start;
}

.ws-techb__left,
.ws-techb__features{
  display:grid;
  gap:14px;
}

.ws-techb__card,
.ws-techb__feature,
.ws-techb__stats,
.ws-techb__layers,
.ws-techb__trust{
  border:1px solid var(--ws-techb-line);
  border-radius:10px;
  background:var(--ws-techb-card);
  box-shadow:0 18px 40px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.04);
}

.ws-techb__card,
.ws-techb__feature{
  display:flex;
  align-items:flex-start;
  gap:16px;
  padding:18px;
}

.ws-techb__main{
  min-height:132px;
}

.ws-techb__icon{
  width:48px;
  height:48px;
  flex:0 0 48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(255,209,82,.18);
  border-radius:8px;
  background:rgba(255,209,82,.055);
  color:var(--ws-techb-accent);
}

.ws-techb__icon svg{
  width:28px;
  height:28px;
}

.ws-techb h3{
  margin:0;
  font-family:var(--font-head, "Roboto Slab", serif);
  font-size:var(--h5-size);
  line-height:1.18;
  letter-spacing:var(--h-track);
  font-weight:800;
  color:#fff;
}

.ws-techb p{
  margin:9px 0 0;
  font-family:var(--font-body, "Montserrat", sans-serif);
  font-size:var(--txt-size);
  line-height:var(--txt-lh);
  font-weight:500;
  color:var(--ws-techb-muted);
}

.ws-techb__stats{
  padding:16px 20px 18px;
}

.ws-techb__stats > p,
.ws-techb__layers > p{
  margin:0 0 12px;
  color:#fff;
  font-weight:700;
}

.ws-techb__stats-row{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:0;
}

.ws-techb__stat{
  display:grid;
  grid-template-columns:34px minmax(0, 1fr);
  column-gap:12px;
  align-items:center;
  padding:6px 18px;
}

.ws-techb__stat + .ws-techb__stat{
  border-left:1px solid var(--ws-techb-line);
}

.ws-techb__stat span{
  grid-row:span 2;
  color:var(--ws-techb-accent);
}

.ws-techb__stat svg{
  width:28px;
  height:28px;
}

.ws-techb__stat strong{
  font-family:var(--font-head, "Roboto Slab", serif);
  font-size:var(--h5-size);
  line-height:1.1;
  color:#fff;
}

.ws-techb__stat small{
  font-family:var(--font-body, "Montserrat", sans-serif);
  color:var(--ws-techb-muted);
  font-size:14px;
}

.ws-techb__layers{
  padding:14px;
}

.ws-techb__layers > p{
  color:var(--ws-techb-accent);
  text-align:center;
}

.ws-techb__layers-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:8px;
}

.ws-techb__layer{
  min-width:0;
  display:grid;
  gap:10px;
  justify-items:center;
  padding:14px 8px;
  border:1px solid var(--ws-techb-line);
  border-radius:8px;
  background:rgba(0,0,0,.14);
  text-align:center;
}

.ws-techb__layer span{
  width:64px;
  height:42px;
  border-radius:4px;
  background:
    linear-gradient(135deg, rgba(255,209,82,.35), rgba(255,255,255,.12)),
    repeating-linear-gradient(145deg, rgba(255,255,255,.18) 0 5px, rgba(0,0,0,.08) 5px 10px);
}

.ws-techb__layer strong{
  font-family:var(--font-body, "Montserrat", sans-serif);
  font-size:13px;
  line-height:1.2;
  color:#fff;
}

.ws-techb__feature{
  min-height:104px;
  transition:transform .22s ease, border-color .22s ease;
}

.ws-techb__feature:hover{
  transform:translateY(-2px);
  border-color:rgba(255,209,82,.32);
}

.ws-techb__trust{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  width:min(100%, 78rem);
  margin:22px auto 0;
  overflow:hidden;
}

.ws-techb .ws-techb__trust{
  display:none !important;
}

.ws-techb__trust-item{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:13px;
  min-width:0;
  padding:16px 22px;
  border-right:1px solid var(--ws-techb-line);
}

.ws-techb__trust-item:last-child{
  border-right:0;
}

.ws-techb__trust-item > span{
  color:var(--ws-techb-accent);
}

.ws-techb__trust-item svg{
  width:34px;
  height:34px;
}

.ws-techb__trust-item div{
  display:flex;
  flex-direction:column;
  gap:3px;
  font-family:var(--font-body, "Montserrat", sans-serif);
}

.ws-techb__trust-item strong{
  color:#fff;
  font-size:13px;
  line-height:1.2;
  font-weight:800;
  text-transform:uppercase;
}

.ws-techb__trust-item small{
  color:var(--ws-techb-muted);
  font-size:12px;
  line-height:1.25;
}

@media (max-width: 1100px){
  .ws-techb__grid{
    grid-template-columns:1fr;
    gap:20px;
  }
}

@media (max-width: 767.98px){
  .ws-techb{
    padding:28px 0;
  }

  .ws-techb__container{
    padding:0 16px;
  }

  .ws-techb__title{
    font-size:clamp(32px, 10vw, 46px);
  }

  .ws-techb__subtitle,
  .ws-techb p{
    font-size:15px;
  }

  .ws-techb__card,
  .ws-techb__feature{
    padding:15px;
    gap:12px;
  }

  .ws-techb__icon{
    width:42px;
    height:42px;
    flex-basis:42px;
  }

  .ws-techb__icon svg{
    width:24px;
    height:24px;
  }

  .ws-techb__stats-row,
  .ws-techb__trust{
    grid-template-columns:1fr;
  }

  .ws-techb__stat + .ws-techb__stat,
  .ws-techb__trust-item{
    border-left:0;
    border-right:0;
    border-top:1px solid var(--ws-techb-line);
  }

  .ws-techb__trust-item:first-child{
    border-top:0;
  }

  .ws-techb__layers-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}
