.ws-categories,
.ws-categories *{
  box-sizing:border-box;
}

.ws-categories{
  padding-top:0;
  padding-bottom:32px;
}

.ws-categories__container{
  max-width:1440px;
  margin:0 auto;
  padding:0 20px;
}

/* =========================================
   HEADER
========================================= */

.ws-categories__header,
.ws-categories__head{
  text-align:center;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  max-width:86.25rem;
  margin-left:auto;
  margin-right:auto;
}

.ws-categories__header > *,
.ws-categories__head > *{
  min-width:0;
}

.ws-categories__title{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  margin:2rem 0 0;
  max-width:100%;
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:normal;
  font-family:var(--font-head, "Roboto Slab", serif);
  font-weight:700;
}

.ws-categories__title::before,
.ws-categories__title::after{
  content:none !important;
  display:none !important;
}

.ws-categories__subtitle,
.ws-categories__sub{
  margin:0.25rem 0 1.125rem !important;
  max-width:100%;
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:normal;
  text-align:center;
  background:none !important;
  color:inherit !important;
  padding:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  font-family:var(--font-body, "Montserrat", sans-serif);
  font-weight:500;
}

.ws-categories__subtitle .ws-categories__hl,
.ws-categories__subtitle mark,
.ws-categories__sub .ws-categories__hl,
.ws-categories__sub mark{
  display:inline;
  padding:.08em .34em;
  border-radius:.38em;
  background:#FFD152;
  color:#111 !important;
  box-shadow:none;
  -webkit-box-decoration-break:clone;
  box-decoration-break:clone;
}

/* =========================================
   GRID
========================================= */

.ws-categories__grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:16px;
}

.ws-categories__card{
  position:relative;
  display:block;
  overflow:hidden;
  border-radius:24px;
  text-decoration:none;
  color:inherit;
  background:#ddd;
  aspect-ratio:0.72 / 1;
  isolation:isolate;
  transition:transform .2s ease, box-shadow .2s ease;
}

.ws-categories__card:hover,
.ws-categories__card:focus,
.ws-categories__card:focus-visible,
.ws-categories__card:active,
.ws-categories__card:visited{
  color:inherit;
  text-decoration:none;
}

.ws-categories__card:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 32px rgba(0,0,0,.16);
}

.ws-categories__card:focus-visible{
  outline:2px solid rgba(255, 209, 82, .85);
  outline-offset:3px;
}

.ws-categories__media,
.ws-categories__img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}

.ws-categories__img{
  object-fit:cover;
  transition:transform .45s ease;
}

.ws-categories__card:hover .ws-categories__img{
  transform:scale(1.04);
}

.ws-categories__overlay{
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(
    180deg,
    rgba(0,0,0,.72) 0%,
    rgba(0,0,0,.50) 24%,
    rgba(0,0,0,.24) 52%,
    rgba(0,0,0,.12) 100%
  );
}

.ws-categories__content,
.ws-categories__meta{
  position:absolute;
  top:18px;
  left:18px;
  right:18px;
  z-index:2;
  display:flex;
  align-items:flex-start;
  gap:14px;
}

.ws-categories__logo{
  flex:0 0 68px;
  width:68px;
  height:68px;
  border-radius:999px;
  overflow:hidden;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 8px 22px rgba(0,0,0,.14);
}

.ws-categories__logo img{
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
  background:#fff;
}

.ws-categories__body,
.ws-categories__text{
  min-width:0;
  display:flex;
  flex-direction:column;
  padding-top:6px;
}

.ws-categories__card-title,
.ws-categories__name{
  display:block;
  color:#fff;
  font-size:28px;
  line-height:1.05;
  font-weight:800;
  letter-spacing:-0.02em;
  text-shadow:0 2px 10px rgba(0,0,0,.35);
  font-family:var(--font-head, "Roboto Slab", serif);
}

.ws-categories__card-subtitle,
.ws-categories__place{
  display:block;
  margin-top:8px;
  color:rgba(255,255,255,.96);
  font-size:15px;
  line-height:1.25;
  font-weight:600;
  text-shadow:0 2px 8px rgba(0,0,0,.30);
  font-family:var(--font-body, "Montserrat", sans-serif);
}

/* =========================================
   DESKTOP
========================================= */

@media (min-width:981px){
  .ws-categories__grid{
    grid-template-columns:repeat(4, minmax(0,1fr));
    gap:20px;
  }

  .ws-categories__card{
    aspect-ratio:0.62 / 1;
  }
}

/* =========================================
   MOBILE
========================================= */

@media (max-width:767px){
  .ws-categories{
    padding-top:0;
    padding-bottom:32px;
  }

  .ws-categories__container{
    padding:0 14px;
  }

  .ws-categories__header,
  .ws-categories__head{
    padding:0 10px !important;
  }

  .ws-categories__title{
    gap:7px;
  }

  .ws-categories__title::before,
  .ws-categories__title::after{
    font-size:1em;
  }

  .ws-categories__subtitle,
  .ws-categories__sub{
    margin:0.25rem 0 1.125rem !important;
  }

  .ws-categories__grid{
    gap:12px;
  }

  .ws-categories__card{
    border-radius:18px;
  }

  .ws-categories__content,
  .ws-categories__meta{
    top:12px;
    left:12px;
    right:12px;
    gap:10px;
  }

  .ws-categories__logo{
    flex:0 0 46px;
    width:46px;
    height:46px;
  }

  .ws-categories__body,
  .ws-categories__text{
    padding-top:2px;
  }

  .ws-categories__card-title,
  .ws-categories__name{
    font-size:18px;
    line-height:1.1;
    font-weight:800;
  }

  .ws-categories__card-subtitle,
  .ws-categories__place{
    margin-top:4px;
    font-size:12px;
    line-height:1.2;
    font-weight:600;
  }

  .ws-categories__overlay{
    background:linear-gradient(
      180deg,
      rgba(0,0,0,.64) 0%,
      rgba(0,0,0,.46) 24%,
      rgba(0,0,0,.24) 52%,
      rgba(0,0,0,.14) 100%
    );
  }
}