@charset "shift_jis";

@media screen and (min-width: 769px) {
 .pc_off {
  display: none;
 }

 body {
  margin-top: 105px;
 }

 header {}

 h1 {}

 h2 {
  text-align: center;
  font-size: 28px;
 }

 ul {
  padding: 0;
  margin: 0;
  list-style: none;
 }

 .side_btn {
  position: fixed;
  right: 0;
  top: 30%;
  z-index: 1000;
 }

 .sozoku_con_wrap div::after {
  content: none;
 }

 /*--------------------contact----------------------*/

 .contact_wrap {
  width: 100%;
  height: 280px;
  background: #2e3a41;
 }

 .contact_co {
  width: 1100px;
  margin: 0 auto;
  padding-top: 40px;
  text-align: center;
  color: #fff;
 }

 .con_title {
  font-size: 22px;
  font-weight: bold;
  line-height: 1;
  margin-bottom: 20px;
 }

 .contact_co p {
  margin: 0px auto 40px;
  font-size: 35px;
  font-weight: bold;
  line-height: 1;
 }

 .contact_btn {
  display: flex;
  justify-content: center;
 }

 .contact_btn a {
  width: 450px;
  height: 80px;
  display: block;
  margin: 0 10px;
  background: #fff;
  line-height: 25px;
  text-decoration: none;
  color: #000;
  font-size: 25px;
  font-weight: bold;
  border-radius: 40px;
  text-indent: 15px;
  position: relative;
  padding: 20px 0;
  box-sizing: border-box;
 }

 .contact_btn a:hover {
  color: #7f0608;
 }

 .contact_btn a span {
  font-size: 14px;
  display: block;
  font-weight: normal;
 }

 .contact_btn a:first-child {
  font-size: 35px;
 }


 /*--------------------/contact----------------------*/

 .sozoku_con_wrap {
  overflow: hidden;
  color: #000;
 }

 .sozoku_con_wrap h2 {
  font-size: 40px;
  line-height: 40px;
  font-weight: bold;
  text-align: center;
  color: #000;
  margin: 0 0 40px;
 }

 .sozoku_ti {
  margin-bottom: 40px;
 }

 .sozoku_ti h2 {
  margin: 0 0 20px;
 }

 .sozoku_ti span {
  display: block;
  text-align: center;
  color: #7f0608;
  font-size: 25px;
  line-height: 25px;
  font-weight: bold;
  letter-spacing: 0.1em;
 }


 /*--------------------main----------------------*/
 .sozoku_main_wrap {
  background: url(../img/main_bg.png);
  background-size: cover;
  background-position: center;
  height: 500px;
  box-sizing: border-box;
  padding-top: 90px;
 }

 .sozoku_main_wrap img {
  margin-right: -120px;
 }

 .sozoku_main_inner {
  width: 1000px;
  margin: 0 auto;
  text-align: center;
 }

 .sozoku_main_subti span {
  color: #fff;
  font-size: 35px;
  font-weight: bold;
  line-height: 35px;
  border-bottom: 1px solid #fff;
  padding-bottom: 10px;
  margin: 0 10px;
 }

 .sozoku_main_ti {
  margin: 50px 0 20px;
 }

 .sozoku_main_ti p {
  color: #fff;
  font-size: 50px;
  line-height: 70px;
  font-weight: bold;
  margin: 0 0 15px;
 }

 .sozoku_main_ti p span {
  font-weight: bold;
  font-size: 70px;
 }

 .sozoku_main_ti span {
  font-size: 25px;
  line-height: 30px;
  font-weight: bold;
  color: #fff;
  margin-top: 20px;
 }

 .sozoku_main_inner ul {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
 }

 .sozoku_main_inner ul li {
  width: 215px;
  background: #7f0608;
  color: #fff;
  line-height: 56px;
  border-radius: 10px;
  font-size: 20px;
  letter-spacing: 0.1em;
  font-weight: bold;
 }

 .sozoku_main_inner ul li:first-child {
  margin-right: 10px;
 }

 /*--------------------/main----------------------*/

 /*--------------------nayami----------------------*/
 .sozoku_nayami_wrap {
  width: 1100px;
  margin: 80px auto;
 }

 .sozoku_nayami_wrap ul {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
 }

 .sozoku_nayami_wrap ul::after {
  content: "";
  display: block;
  background: url(../img/nayami_icon.png);
  width: 239px;
  height: 256px;
  position: absolute;
  bottom: 0px;
  left: 420px;
  z-index: -1;
 }

 .sozoku_nayami_wrap ul li {
  border: 1px solid #ccc;
  border-radius: 10px;
  padding: 20px 30px;
  font-size: 20px;
  font-weight: bold;
  line-height: 30px;
  position: relative;
  text-align: center;
  margin-bottom: 30px;
  background: #fff;
 }

 .sozoku_nayami_wrap ul li:nth-child(2) {
  margin: 0 35px 30px;
 }

 .sozoku_nayami_wrap ul li:nth-child(4) {
  margin: 0px 0 30px 410px;
 }

 .sozoku_nayami_wrap ul li:nth-child(6) {
  margin: 0 0 30px 300px;
 }

 .sozoku_nayami_wrap ul li span {
  font-weight: bold;
  background: linear-gradient(transparent 60%, #ffdbde 60%);
 }

 .sozoku_nayami_wrap ul li::before {
  content: "";
  border-left: 16px solid transparent;
  border-top: 16px solid #ccc;
  position: absolute;
  right: 35px;
  bottom: -16px;
  transform: rotate(-90deg);
 }

 .sozoku_nayami_wrap ul li::after {
  content: "";
  border-left: 15px solid transparent;
  border-top: 15px solid white;
  position: absolute;
  right: 35px;
  bottom: -14px;
  transform: rotate(-90deg);
 }


 .sozoku_nayami_wrap ul li:nth-child(3)::before {
  top: 56px;
  right: -16px;
  bottom: auto;
 }

 .sozoku_nayami_wrap ul li:nth-child(3)::after {
  top: 57px;
  right: -14px;
  bottom: auto;
 }

 .sozoku_nayami_wrap ul li:nth-child(4)::before {
  top: 36px;
  left: -16px;
  right: auto;
  bottom: auto;
  transform: none;
 }

 .sozoku_nayami_wrap ul li:nth-child(4)::after {
  top: 37px;
  left: -14px;
  right: auto;
  bottom: auto;
  transform: none;
 }

 .sozoku_nayami_wrap ul li:nth-child(5)::before,
 .sozoku_nayami_wrap ul li:nth-child(6)::before {
  top: -16px;
  right: 35px;
  bottom: auto;
  transform: rotate(-180deg);
 }

 .sozoku_nayami_wrap ul li:nth-child(5)::after,
 .sozoku_nayami_wrap ul li:nth-child(6)::after {
  top: -14px;
  right: 35px;
  bottom: auto;
  transform: rotate(-180deg);
 }

 /*--------------------/nayami----------------------*/

 /*--------------------about----------------------*/
 .sozoku_about_wrap {
  background: #f5f5f5;
  padding: 80px 0;
 }

 .sozoku_about_inner {
  width: 1100px;
  margin: 0 auto;
 }

 .sozoku_about_point {
  border: 3px solid #7f0608;
  background: #fff;
  box-sizing: border-box;
  border-radius: 5px;
  padding: 50px 40px;
  position: relative;
  margin-bottom: 90px;
 }

 .sozoku_about_point h3 {
  color: #7f0608;
  font-size: 40px;
  line-height: 40px;
  font-weight: bold;
  letter-spacing: 0.05em;
  margin: 0;
 }

 .sozoku_about_point p {
  font-size: 25px;
  font-weight: bold;
  line-height: 25px;
  color: #000;
  letter-spacing: 0.18em;
  margin: 40px 0;
 }

 .sozoku_about_point ul li {
  position: relative;
  padding-left: 40px;
  font-size: 18px;
  color: #ff5050;
  font-weight: 500;
  line-height: 25px;
  margin-bottom: 10px;
 }

 .sozoku_about_point ul li::before {
  content: "";
  display: block;
  background: url(../img/check_icon.png);
  width: 25px;
  height: 25px;
  position: absolute;
  top: 0;
  left: 0;
 }

 .sozoku_about_point img {
  position: absolute;
  right: 40px;
  bottom: -15px;
  z-index: 5;
 }

 .sozoku_problem_wrap {
  width: 1100px;
  margin: 0 auto;
 }

 .sozoku_problem_wrap h2 {
  color: #7f0608;
 }

 .sozoku_problem_top {
  position: relative;
  margin-top: 200px;
 }

 .sozoku_problem_top::before {
  content: "";
  display: block;
  background: url(../img/s_icon_01.png);
  width: 629px;
  height: 236px;
  position: absolute;
  left: 20px;
  top: -140px;
  z-index: 5;
 }

 .sozoku_problem_top p {
  font-size: 25px;
  font-weight: bold;
  line-height: 40px;
  text-align: center;
  letter-spacing: 0.18em;
  margin: 0;
 }

 .sozoku_problem_top ul {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 40px 0;
 }

 .sozoku_problem_top ul li {
  margin-bottom: 20px;
  background: #fff;
  width: 350px;
  height: 130px;
  box-sizing: border-box;
  border: 1px solid #ccc;
  border-radius: 5px;
  text-align: center;
  padding: 20px 0;
 }

 .sozoku_problem_top ul li span {
  display: block;
  text-align: center;
  font-size: 25px;
  line-height: 30px;
  color: #000;
  font-weight: bold;
 }

 .sozoku_problem_top ul li p {
  color: #0d73a2;
  font-size: 18px;
  line-height: 30px;
  letter-spacing: 0.05em;
  margin: 0;
  height: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 5px;
 }

 .sozoku_problem_con ul li {
  background: #fff;
  padding: 20px;
  border-radius: 10px;
  margin-bottom: 30px;
 }

 .sozoku_problem_con ul li h3 {
  background: #f5f5f5;
  line-height: 60px;
  border-radius: 10px;
  text-align: left;
  padding-left: 20px;
  color: #7f0608;
  font-size: 35px;
  font-weight: bold;
  letter-spacing: 0.1em;
  margin: 0 0 30px;
 }

 .sozoku_problem_flex {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
 }

 .sozoku_problem_txt {
  width: 630px;
  margin-left: 20px;
 }

 .sozoku_problem_txt h4 {
  font-size: 25px;
  font-weight: bold;
  line-height: 30px;
  margin: 0 0 15px;
 }

 .sozoku_problem_txt p {
  font-size: 18px;
  font-weight: 500;
  line-height: 35px;
  margin: 0;
 }

 /*--------------------/about----------------------*/

 /*--------------------point----------------------*/
 .sozoku_point_wrap {
  width: 1100px;
  margin: 100px auto;
 }

 .sozoku_point_wrap h2 {
  position: relative;
 }

 .sozoku_point_wrap h2::after {
  content: "";
  display: block;
  background: url(../img/s_icon_02.png);
  width: 147px;
  height: 168px;
  position: absolute;
  right: 60px;
  top: -40px
 }

 .sozoku_point_wrap ul {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: 90px;
  overflow: inherit;
 }

 .sozoku_point_wrap ul li {
  width: 530px;
  height: 570px;
  box-sizing: border-box;
  border: 3px solid #7f0608;
  border-radius: 10px;
  background: #fff;
  padding: 70px 15px 0;
  text-align: center;
  margin-bottom: 60px;
  position: relative;
 }

 .sozoku_point_wrap ul li:last-child {
  width: 1100px;
  height: 380px;
  padding: 40px 15px;
  margin: 0;
 }

 .sozoku_point_wrap ul li h3 {
  width: 490px;
  text-align: center;
  background: #7f0608;
  border-radius: 10px;
  font-size: 24px;
  font-weight: bold;
  line-height: 36px;
  letter-spacing: 0.05em;
  padding: 10px 0;
  position: absolute;
  left: 17px;
  top: -40px;
  z-index: 5;
  margin: 0;
  color: #fff;
 }


 .sozoku_point_wrap ul li p {
  color: #000;
  font-size: 18px;
  line-height: 30px;
  margin: 15px 0 0;
  text-align: left;
 }

 .sozoku_point_wrap ul li p span {
  font-weight: bold;
  color: #f00;
 }

 .sozoku_point_wrap ul li:last-child p {
  width: 690px;
 }

 .sozoku_point_wrap ul li:first-child img {
  margin: 14px 0;
 }

 .sozoku_point_wrap ul li:last-child h3 {
  top: -30px;
 }

 .sozoku_point_wrap ul li:last-child img {
  position: absolute;
  right: 15px;
  top: 15px;
 }


 /*--------------------/point----------------------*/

 /*--------------------qa----------------------*/
 .sozoku_qa_wrap {
  background: #f6f6f6;
  padding: 80px 0;
 }

 .sozoku_qa_inner {
  width: 1050px;
  margin: 0 auto;
 }

 .sozoku_qa_ti h2 {
  margin: 0;
 }

 .sozoku_qa_ti span {
  display: block;
  text-align: center;
  color: #7f0608;
  font-size: 24px;
  font-weight: bold;
  letter-spacing: 0.05em;
  margin-bottom: 50px;
 }

 .sozoku_qa_ti span::before {
  content: "";
  display: block;
  background: #dadada;
  width: 25px;
  height: 4px;
  margin: 15px auto;
 }

 .sozoku_qa_con {
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
 }

 .sozoku_qa_con dt {
  background: #fff;
  padding: 0 20px;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  align-items: center;
  font-size: 25px;
  line-height: 100px;
  font-weight: bold;
  color: #000;
 }

 .sozoku_qa_con dt::before {
  content: "";
  display: block;
  background: url(../img/q_icon.png);
  width: 31px;
  height: 33px;
  margin-right: 20px;
 }

 .sozoku_qa_con dd {
  background: #f6eded;
  padding: 20px;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  font-size: 22px;
  line-height: 40px;
  font-weight: bold;
  color: #000;
  min-height: 140px;
  box-sizing: border-box;
  margin: 0 0 40px;
 }

 .sozoku_qa_con dd::before {
  content: "";
  display: block;
  background: url(../img/a_icon.png);
  width: 27px;
  height: 29px;
  margin-right: 20px;
 }


 /*--------------------/qa----------------------*/

 /*--------------------advisor----------------------*/
 .advisor_wrap {
  width: 1160px;
  margin: 120px auto;
 }

 .advisor_inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
 }

 .advisor_con {}

 .advisor_ti span {
  font-size: 15px;
  letter-spacing: 0.05em;
  margin-bottom: 15px;
  display: block;
 }

 .advisor_ti h3 {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.05em;
  margin: 0;
 }

 .advisor_ti h3 b {
  font-size: 26px;
 }

 .advisor_con ul {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  margin: 20px 0;
 }

 .advisor_con ul li {
  display: inline-block;
  background: #7f0608;
  color: #fff;
  line-height: 35px;
  font-size: 15px;
  font-weight: bold;
  letter-spacing: 0.05em;
  border-radius: 5px;
  margin-right: 5px;
  padding: 0 10px;
 }

 .advisor_con h4 {
  font-size: 18px;
  color: #7f0608;
  margin: 20px 0 0;
  padding-left: 70px;
  position: relative;
 }

 .advisor_con h4::before {
  content: "";
  display: block;
  width: 60px;
  height: 1px;
  background: #7f0608;
  position: absolute;
  left: 0;
  top: 9px;
 }

 .advisor_con p {
  font-size: 15px;
  line-height: 28px;
  margin-top: 5px;
 }

 /*--------------------/advisor----------------------*/

 /*--------------------column----------------------*/
 .sozoku_column_wrap {
  background: #f5f5f5;
  padding: 60px 0;
 }

 .sozoku_column_inner {
  width: 1100px;
  margin: 0 auto;
 }

 .sozoku_column_top {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 30px;
 }

 .sozoku_column_top a {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.1em;
  text-decoration: underline;
  letter-spacing: 0.1em;
  color: #000;
 }

 .sozoku_column_top .sozoku_ti {
  display: flex;
  align-items: flex-end;
  margin: 0;
 }

 .sozoku_column_top .sozoku_ti h2 {
  margin: 0 15px 0 0;
  font-size: 35px;
 }

 .sozoku_column_inner iframe {
  display: block;
  width: 1000px;
  height: 320px;
  padding: 30px 50px;
  background: #fff;
 }

 /*--------------------/column----------------------*/


 /*--------------------/media screen----------------------*/
}
