body {
  font-family: Verdana, "メイリオ", Meiryo, sans-serif;
}

.heading01 {
  font-size: 16px;
  font-size: 1.6rem;
  border-radius: 3px;
  padding: 15px 20px;
  margin: 70px 0 30px;
  font-weight: bold;
}

.column3 {
  width: 310px;
  margin-top: 30px;
  margin-right: 15px;
}

.pageTop {
  right: 50px;
  bottom: 50px;
  cursor: pointer;
}

.footerWrap {
  position: relative;
}

.pageTop.is-stop {
  position: absolute;
  bottom: 170px;
}

/* このページのみのスタイル */

.header {
  background: #f2f4f3;
}

.headerIn {
  width: 960px;
  margin: 0 auto;
  padding: 16px 0;
  text-align: center;
}

.header .logo {
  float: none;
}

.flow {
  width: 960px;
  margin: 0 auto;
}

.heroTtl {
  margin-bottom: 30px;
  padding: 20px 0;
  border-bottom: 1px solid #111987;
}

.heroTtl > * {
  width: 960px;
  margin: 0 auto;
  font-size: 24px;
  text-align: center;
  color: #111987;
}

.downloadBtn {
  margin-top: 50px;
  text-align: center;
}

.downloadBtn > a {
  padding: 16px 36px;
  border: 1px solid #111987;
  border-radius: 3px;
  transition: .3s;
}

.downloadBtn > a:hover {
  text-decoration: none;
  color: #fff;
  background: #111987;
}

.linkBtn {
  margin-top: 50px;
  text-align: center;
}

.linkBtn > a {
  padding: 16px 36px;
  border: 1px solid #111987;
  border-radius: 3px;
  transition: .3s;
}

.linkBtn > a:hover {
  text-decoration: none;
  color: #fff;
  background: #111987;
}

.columnWrap {
  overflow: hidden;
  margin-top: -30px;
  margin-right: -15px;
}

.productBox .productBoxIn {
  margin: 0;
  border: 1px solid #ddd;
}

.productBox > .productBoxIn > * {
  margin: 0;
  padding: 10px 15px;
}

.productBox > .productBoxIn > .title {
  font-weight: bold;
  background: #f2f4f3;
}

.productBox > .productBoxIn > .title.type2 {
  background: #f4f5fe;
}

.productBox > .productBoxIn > .boxImg {
  display: table;
  width: 100%;
  padding: 15px;
  box-sizing: border-box;
}

.productBox > .productBoxIn > .boxImg > .image,
.productBox > .productBoxIn > .boxImg > .text {
  display: table-cell;
  margin: 0;
  vertical-align: top;
}

.productBox > .productBoxIn > .boxImg > .image img {
  max-width: 130px;
}

.productBox > .productBoxIn > .boxImg > .text {
  padding-left: 15px;
}

.productBox > .productBoxIn > .link > a {
  display: inline-block;
  margin-right: 15px;
}

.productBox > .button {
  margin: 0;
}

.productBox > .button > a {
  display: block;
  padding: 10px 15px;
  color: #fff;
  background: #111987;
}

.productBox > .button > a::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-right: 7px;
  margin-bottom: 2px;
  display: inline-block;
  vertical-align: middle;
  overflow: hidden;
  background: url(/shared/images/ico_common.png) no-repeat -15px -19px;
}

.productBox > .button > a:hover {
  -ms-filter: "alpha(opacity=70)";
  opacity: 0.7;
  text-decoration: none;
}

.flow {
  position: relative;
}

.optionBox {
  display: table;
  width: 100%;
  margin-top: 15px;
}

.optionBox > * {
  display: table-cell;
  vertical-align: top;
}

.optionBox > .title {
  width: 1px;
  font-weight: bold;
  white-space: nowrap;
  color: #111987;
}

.optionBox > .list {
  padding: 0 0 0 15px;
  list-style: none;
}

.optionBox > .list > * {
  display: inline-block;
  margin-right: 15px;
}

.ttl01 {
  display: table;
  width: 100%;
  margin: 0 0 15px;
  padding: 3px 0 3px 17px;
  font-size: 16px;
  font-weight: bold;
  color: #111987;
  border-left: 3px solid #111987;
}

.ttl01 > * {
  display: table-cell;
  vertical-align: middle;
}

[class*="flowBtn"] {
  position: relative;
  display: table;
  min-width: 155px;
  height: 45px;
  margin: 0 auto;
  font-size: 14px;
  text-align: center;
}

[class*="flowBtn"] > * {
  display: table-cell;
  padding: 0 15px;
  vertical-align: middle;
  color: #333;
  border-radius: 5px;
  box-sizing: border-box;
}

[class*="flowBtn"] > * .sub {
  display: block;
  font-size: 12px;
}

[class*="flowBtn"].w175 {
  min-width: 175px;
}

[class*="flowBtn"].h55 {
  height: 55px;
}

[class*="flowBtn"].fsS {
  font-size: 12px;
}

[class*="flowBtn"].noWrap {
  white-space: nowrap;
}

[class*="flowBtn"][data-mh] {
  height: auto;
}

[class*="flowBtn"].icoQ > * {
  padding-right: 27px;
}

[class*="flowBtn"].icoQ [class*="balloonOpen"] {
  position: absolute;
  top: 50%;
  right: 10px;
  width: 17px;
  height: 17px;
  margin-top: -8.5px;
  background: url(/promo/product/noisefilter/selection/images/ico_question_01.png) no-repeat;
  cursor: pointer;
}

.flowBtn > * {
  background: #111987;
}

.flowBtn > * {
  color: #fff;
}

.flowBtn2 > * {
  border: 1px solid #b0b3d5;
  background: #e7e8f3;
}

.flowBtn3 {
  text-align: left;
  background: #fdffbf; /* Old browsers */
  background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIwJSIgeTI9IjEwMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2ZkZmZiZiIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNmYmZmODMiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGllbnQ+CiAgPHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEiIGhlaWdodD0iMSIgZmlsbD0idXJsKCNncmFkLXVjZ2ctZ2VuZXJhdGVkKSIgLz4KPC9zdmc+);
  background: -moz-linear-gradient(top, #fdffbf 0%, #fbff83 100%); /* FF3.6-15 */
  background: -webkit-linear-gradient(top, #fdffbf 0%,#fbff83 100%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom, #fdffbf 0%,#fbff83 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fdffbf', endColorstr='#fbff83',GradientType=0 ); /* IE6-8 */
}

.flowBtn3 > a {
  padding-left: 38px;
  border: 1px solid #c7c989;
}

.flowBtn3::before {
  content: url(/promo/product/noisefilter/selection/images/ico_arrow_01.png);
  position: absolute;
  top: 50%;
  left: 15px;
  width: 13px;
  height: 13px;
  margin-top: -6.5px;
  line-height: 1;
}

.flowBtn3 > a:hover {
  background: #f8fc6e;
}

.flowBtn4 > * {
  color: #fff;
  background: #11877d;
}

[class*="flowBd"] {
  position: relative;
}

[class*="flowBd"]::before, [class*="flowBd"]::after {
  display: block;
  position: absolute;
  left: 50%;
  z-index: -1;
}

.flowBd::before {
  content: url(/promo/product/noisefilter/selection/images/img_border_01.png);
  bottom: -41px;
  width: 409px;
  height: 41px;
  margin-left: -204.5px;
}

.flowBd2::before {
  content: url(/promo/product/noisefilter/selection/images/img_border_02.png);
  top: -137px;
  width: 209px;
  height: 137px;
  margin-left: -104.5px;
}

.flowBd3::before {
  content: url(/promo/product/noisefilter/selection/images/img_border_03.png);
  bottom: -41px;
  width: 209px;
  height: 41px;
  margin-left: -104.5px;
}

.flowBd4::before {
  content: url(/promo/product/noisefilter/selection/images/img_border_04.png);
  bottom: -41px;
  width: 409px;
  height: 41px;
  margin-left: -204.5px;
}

.flowBd5::before {
  content: url(/promo/product/noisefilter/selection/images/img_border_05.png);
  top: 22.5px;
  left: 0;
  width: 20px;
  height: 135px;
}

.flowBd6::before {
  content: "";
  top: 45px;
  left: 50%;
  width: 1px;
  height: 20px;
  background: #555;
}

.flowBd6 + * {
  margin-top: 20px;
}

.flowBd7::before {
  content: url(/promo/product/noisefilter/selection/images/img_border_06.png);
  top: -22px;
  left: 84px;
  height: 22px;
  width: 290px;
}

.flowBd7::after {
  content: url(/promo/product/noisefilter/selection/images/img_border_07.png);
  top: 27.5px;
  left: calc(50% - 9px);
  width: 9px;
  height: 67px;
}

.flowBd8::before {
  content: url(/promo/product/noisefilter/selection/images/img_border_08.png);
  top: 22.5px;
  left: 0;
  width: 20px;
  height: 70px;
}

.flowCat {
  position: absolute;
  top: 0;
  left: 0;
  height: 100px;
  margin: 0;
  padding: 20px;
  font-size: 12px;
  list-style: none;
  border: 1px solid #ddd;
  box-sizing: border-box;
}

.flowCat > * {
  margin-top: 10px;
}

.flowCat > ::before {
  content: "";
  display: inline-block;
  width: 40px;
  height: 25px;
  margin-right: 10px;
  vertical-align: middle;
  border-radius: 3px;
  box-sizing: border-box;
}

.flowCat > :first-child {
  margin-top: 0;
}

.flowCat .cat::before {
  border: 1px solid #b0b3d5;
  background: #e7e8f3;
}

.flowCat .cat2::before {
  border: 1px solid #c7c989;
  background: #fdffbf; /* Old browsers */
  background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIwJSIgeTI9IjEwMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2ZkZmZiZiIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiNmYmZmODMiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGllbnQ+CiAgPHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEiIGhlaWdodD0iMSIgZmlsbD0idXJsKCNncmFkLXVjZ2ctZ2VuZXJhdGVkKSIgLz4KPC9zdmc+);
  background: -moz-linear-gradient(top, #fdffbf 0%, #fbff83 100%); /* FF3.6-15 */
  background: -webkit-linear-gradient(top, #fdffbf 0%,#fbff83 100%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom, #fdffbf 0%,#fbff83 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fdffbf', endColorstr='#fbff83',GradientType=0 ); /* IE6-8 */
}

[class*="flowCol"]::after {
  content: "";
  display: block;
  clear: both;
}

[class*="flowCol"] > .col {
  float: left;
  width: 50%;
}

.flowCol {
  width: calc(960px - 20%);
  margin: 41px 0 0 auto;
}

.flowCol2,
.flowCol3 {
  width: 960px;
  margin: 41px auto 0;
}

/* .flowCol2 > .col {
  width: 30%;
}
 */
.flowCol2 > .col, .flowCol3 > .col {
  width: 40%;
}

.flowCol2 > .col:first-child, .flowCol3 > .col:first-child {
  width: 20%;
}

/* .flowCol2 > .col {
  float: right;
} */

.flowCol3 [class*="flowBtn"] {
  margin-top: 20px;
}

.flowCol3 [class*="flowBtn"]:first-child {
  margin-top: 0;
}

.flowCol3 .flowBtn3 > * {
  padding: 0 10px 0 38px;
}

.flowCol4 {
  position: absolute;
  top: 0;
  left: 20px;
}

.gridTable {
  display: table;
  width: 100%;
}

.gridTable > .col {
  display: table-cell;
  width: 50%;
  vertical-align: top;
}

[class^="flowBalloon"] {
  display: none;
  position: absolute;
  top: 70px;
  width: 220px;
  padding: 20px;
  border: 1px solid #ddd;
  background: #fff;
  cursor: pointer;
  border-radius: 5px;
  box-shadow: 5px 5px 0 rgba(0,0,0,0.1);
}

[class^="flowBalloon"] img {
  width: 100%;
}

[class^="flowBalloon"]::before,
[class^="flowBalloon"]::after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  margin: 0;
  border: 15px solid transparent;
  border-top-width: 20px;
}

[class^="flowBalloon"]::before {
  right: 17px;
  bottom: -35px;
  border-top-color: rgba(0,0,0,0.1);
}

[class^="flowBalloon"]::after {
  right: 22px;
  bottom: -30px;
  border-top-color: #fff;
}

.flowBalloon {
  left: 23px;
}

.flowBalloon2 {
  left: 215px;
}

.indent-1 {
  text-indent: -1em;
}

.note {
  display: block;
  font-size: 12px;
  color: #777;
}

.note.hang1 {
  padding-left: 1em;
  text-indent: -1em;
}

.note.hang2 {
  padding-left: 2em;
  text-indent: -2em;
}