/* ---------- colour palette ---------- */
:root{
  --dark-teal:#003f52;        /* buttons + accents */
  --medium-teal:#006d7c;      /* card headings */
  --charcoal:#333333;         /* body copy */
  --grey-border:#f1f3f3;      /* card stroke */
}

/* ---------- base ---------- */
.pss-wrapper{
  max-width:1160px;
  margin:auto;
  padding:40px 20px;
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

/* ---------- search bar ---------- */
.pss-search-form{
  display:flex;
  gap:12px;
  margin-bottom:12px;
}
.pss-search-form input{
  flex:1;
  padding:12px 18px;
  border:1px solid var(--grey-border);
  border-radius:56px;
  font-size:16px;
  color:var(--charcoal);
}
/* .pss-btn{
  display:flex;
  align-items:center;
  gap:8px;
  background: #324849;
  color:#fff;
  border:0;
  border-radius:4px;
  padding:0 24px;
  font:600 16px/48px "open sans";
  cursor:pointer;
  transition:background .25s;
  border-radius: 56px;
}
.pss-btn:hover{
  background:#5a787b;
} */

button {
  border: none;
  padding: 15px 35px;
  background-color: #5a787b;
  font-size: 16px;
  font-weight: 600;
  color: #fff;
  outline: none;
  border-radius: 56px;
  text-transform: uppercase;
  cursor: pointer;
  font-family: 'Open Sans';
}

/*Background Effects*/
/*Wipe Background to the Right*/
.bg-wipe {
  transform: translate(0);
  position: relative;
  border-radius: 56px;
}
.bg-wipe:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #414042;
  /*change scale and origin if you want to wipe from different directions*/
  transform: scaleX(0);
  transform-origin: 0;
}
.bg-wipe:hover:before{
  transition: 0.5s;
  transform: scale(1);
  border-radius: 56px;
}
.pss-btn svg{display:block;}

/* ---------- helper text & CTA ---------- */
.pss-note{
  font:700 18px/1.45 "open sans";
  color: #414042;
  margin:18px 0;
}
 .pss-contact-btn{
  font:600 16px/1 "open sans";
  color: #fff;
}
/*
.pss-contact-btn:hover{
  background:var(--dark-teal);
  color:#fff;
} */

/* ---------- grid ---------- */
.pss-grid{
  display:grid;
  gap:36px;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
}

/* ---------- card ---------- */
.pss-card{
  background:#fff;
/*   border:1px solid var(--grey-border); */
  border-radius:56px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:box-shadow .25s;
}
.pss-card:hover{
  box-shadow:0 8px 20px rgba(0,0,0,.08);
}
.pss-card img{
  width:100%;
  height:180px;
  object-fit:cover;
}
.pss-card h3{
  font:700 16px/1.2 "open sans";
  color: #5a787b;
  margin:20px 24px 8px;
  text-align: left;
}

#bg-b {
  margin-bottom:32px;
}

.pss-card p{
  font:400 16px/1.45 "open sans";
  color: #414042;
  margin:0 24px 24px;
  flex:1;
  text-align: left;
}
.pss-card a{
  align-self:flex-start;
  margin:0 24px 32px;
  padding: 15px 35px;
  border-radius:40px;
  background: #5a787b;
  color:#fff;
  font:600 14px/1 "open sans";
  text-decoration:none;
  transition:background .25s;
}
/* .pss-card a:hover{
  background:var(--dark-teal);
} */

/* ---------- responsive tweaks ---------- */
@media (max-width:640px){
  .pss-note{font-size:16px;}
  .pss-search-form input{font-size:14px;}
  .pss-btn{font-size:14px;padding:0 18px;}
}