@charset "UTF-8";
/* /////// search_共通  /////// */

.pagetitle {
  background-image: url(../images/common/bg_company.jpg);
  background-size: cover;
  background-position: center center;
}

/* branch */

.branch_unit {
  margin-top: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.branch_unit li {
  width: 48.5%;
  margin-bottom: 20px;
}

@media screen and (max-width: 540px) {
  .branch_unit li {
    width: 100%;
    margin-bottom: 10px;
  }
}

@media screen and (max-width: 520px) {
  .branch_unit li {
    width: 100%;
  }
}

.branch_unit li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-radius: 7px;
  border: 1px solid #f0e9db;
  position: relative;
  overflow: hidden;
  color: #000;
}

.branch_unit li a h3 {
  width: 55%;
  margin-left: -5%;
  margin-right: -5%;
  font-size: 20px;
  background-color: #f0e9db;
  -webkit-transform: skew(-12deg, 0deg);
  -ms-transform: skew(-12deg, 0deg);
  transform: skew(-12deg, 0deg);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
}

.branch_unit li a h3 span {
  display: block;
  margin: auto;
  -webkit-transform: skew(12deg, 0deg);
  -ms-transform: skew(12deg, 0deg);
  transform: skew(12deg, 0deg);
}

.branch_unit li a h3 span .fas {
  display: block;
  padding-top: 10px;
  -webkit-transform: skew(0deg, 0deg);
  -ms-transform: skew(0deg, 0deg);
  transform: skew(0deg, 0deg);
}

.branch_unit li a figure {
  width: 65%;
  min-height: 220px;
  overflow: hidden;
}

.branch_unit li a figure img {
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

/* overview */

.formation .btn {
  width: 15em;
}

/* video */
.mainArea .moviwp {
  width: 100%;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}
.mainArea .movie {
  width: 100%;
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}
.mainArea .movie video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
figure.flex {
  display: flex;
}
figure.flex img {
  width: 50%;
}

/* idea */

.idea_cont {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.idea_cont figure {
  width: 100%;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 30px;
  text-align: center;
}

.idea_cont figure > img:first-of-type {
  width: 90%;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
  /*   margin-bottom: 25px;
 */
}

.idea_cont div {
  /*  width: 67%;*/
  width: 100%;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  font-size: 18px;
  line-height: 1.8;
  margin-bottom: 30px;
  text-align: center;
}

.idea_cont h5 {
  width: 100%;
  text-align: center;
  font-size: 28px;
  /*font-family: serif;
    margin-bottom: 30px;*/
}

.idea_cont2 span.messe {
  display: block;
  line-height: 1;
  font-size: 36px;
  padding-bottom: 10px;
  font-weight: bold;
  font-weight: 700;
  color: #da8e00;
  background: linear-gradient(-45deg, #f7de05, #da8e00, #edac06, #f7de05, #ecb802, #daaf08, #b67b03, #da8e00, #edac06, #f7de05, #ecb802, #edac06);
  background: -webkit-linear-gradient(-45deg, #f7de05, #da8e00, #edac06, #f7de05, #ecb802, #daaf08, #b67b03, #da8e00, #edac06, #f7de05, #ecb802, #edac06);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.idea_cont2 span.messe {
  font-size: 45px;
}

.idea_cont2 {
  width: 100%;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  font-size: 18px;
  line-height: 1.8;
}

.idea_cont2 dl dt {
  margin-top: 30px;
  padding-top: 20px;
  padding-bottom: 1em;
  text-align: center;
  border-top: 1px solid #d8bc00;
}

.idea_cont2 dl dd {
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}

.idea_cont2 dl dd ul li {
  position: relative;
  font-weight: bold;
  font-weight: 700;
}

.idea_cont2 dl dd ul li::before {
  content: "★";
  color: #d8bc00;
}

.idea_cont .only_640,
.idea_cont2 .only_640 {
  display: none;
}

@media screen and (max-width: 640px) {
  .idea_cont div {
    text-align: left;
  }

  .idea_cont h5 {
    font-size: 26px;
  }

  .idea_cont2 dl dd {
    text-align: left;
  }

  .idea_cont2 dl dd ul li {
    margin-left: 1em;
  }

  .idea_cont2 dl dd ul li::before {
    position: absolute;
    left: -1em;
    top: 0;
  }

  .idea_cont .only_640,
  .idea_cont2 .only_640,
  .idea_cont2 .only_440 {
    display: block;
  }
}

@media screen and (max-width: 440px) {
  .idea_cont2 .only_440 {
    display: block;
  }
}

/* /// president_cont ////*/

.president_cont {
  font-family: serif;
  line-height: 2;
  font-size: 18px;
}

.president_cont figure:first-of-type {
  position: relative;
  /* padding: 30px 0 0; */
  text-align: center;
  z-index: 1;
  /* background-image: url(../images/company/bg_img_president01.jpg);
  background-size: cover;
  background-position: center center;
  overflow: hidden; */
}
/*
.president_cont figure:first-of-type:after {
  content: "";
  background: inherit;
  -webkit-filter: blur(2px);
  -moz-filter: blur(2px);
  -o-filter: blur(2px);
  -ms-filter: blur(2px);
  filter: blur(2px);
  position: absolute;
  top: -3px;
  left: -3px;
  right: -3px;
  bottom: -3px;
  z-index: -1;
} */

.president_cont figure:first-of-type img {
  position: relative;
  text-align: center;
  /* max-width: 862px; */
  z-index: 10;
}

.president_cont figure:last-of-type {
  margin-top: 30px;
  /* text-align: right; */
}

.president_cont figure:last-of-type img {
  width: auto;
}

/* /// newsrelease ////*/

.newsrelease .pagelinks li {
  width: 7.6em;
  padding-right: 0.5em;
  margin-bottom: 5px;
}

.newsrelease .pagelinks li .btn {
  padding-left: 5px;
}

.newsrelease_list li {
  margin-top: 15px;
  padding-bottom: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  border-bottom: 1px solid #f0e9db;
}

@media screen and (max-width: 640px) {
  .newsrelease_list li {
    display: block;
  }
}

.newsrelease_list li dl {
  -ms-flex-negative: 2;
  flex-shrink: 2;
}

.newsrelease_list li dl dt {
  font-weight: bold;
  font-size: 18px;
}

.newsrelease_list li dl dt {
  font-weight: bold;
}

.newsrelease_list li div {
  width: 20%;
  min-width: 12em;
  -ms-flex-negative: 1;
  flex-shrink: 1;
  -ms-flex-item-align: end;
  align-self: flex-end;
}

@media screen and (max-width: 640px) {
  .newsrelease_list li div {
    width: 40%;
    min-width: 12em;
    margin: 10px auto 0;
  }
}

.newsrelease_list li .btn {
  min-height: 2.5em;
  white-space: nowrap;
}

/* /// faq ////*/

.faq .pagetitle {
  background-image: url(../images/common/bg_faq.jpg);
  background-size: cover;
  background-position: center center;
}

.faq .txt_right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  margin-top: 15px;
}

.faq .txt_right .gradationBtn {
  width: 18em;
  min-height: 2.5em;
}

/* /// history ////*/

.history .container .head {
  border-bottom: 2px solid #ffe800;
}

.history .container .head dt {
  background-color: #d8bc00;
}

.history .container .head dd {
  font-weight: bold;
  background-color: #d8bc00;
  border-left: 1px solid #fff;
}

.history .container .unit_table dt {
  width: 15%;
}

.history .container .unit_table dd {
  width: 85%;
}

.history .container .unit_table h3 {
  font-size: 20px;
  width: 100%;
  border-bottom: 1px solid #d8bc00;
  margin-bottom: 10px;
}

.history .container .unit_table p + h3 {
  margin-top: 20px;
}

.history .container .unit_table h4 {
  width: 100%;
}

.history .container .unit_table h5 {
  width: 100%;
  position: relative;
  padding-left: 26px;
}

.history .container .unit_table h5::before {
  font-family: "lionicon";
  position: absolute;
  left: 0px;
  content: "\e900";
  opacity: 1;
  color: #d8bc00;
  font-weight: normal;
}

.history .container .unit_table h5.situation {
  font-size: 16px;
  color: #d8bc00;
}

.history .container .unit_table dd p + h4,
.history .container .unit_table dd p + h5,
.history .container .unit_table dd figure + h5,
.history .container .unit_table dd h5 + figure,
.history .container .unit_table p + figure,
.history .container .unit_table dd h5 + div {
  margin-top: 20px;
}

.history .container .unit_table .u_flex p + figure {
  margin-top: 0px;
}

.history .container .unit_table .u_flex figure + figure {
  margin-left: 3%;
}

.history .container .unit_table figure figcaption {
  margin-bottom: 15px;
}

.history .container .unit_table dd.u_flex {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.history .container .unit_table dd.u_flex figure {
  width: 35%;
  margin-left: 3%;
}

.history .container .unit_table dd.u_flex figure img {
  width: 100%;
}

.history .container .unit_table dd.u_flex p {
  width: 62%;
}

.history .container .unit_table dd .img_fst {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.history .container .unit_table dd .img_fst p + p {
  margin-top: 20px;
}

.history .container .unit_table dd .img_fst div {
  width: 58%;
}

.history .container .unit_table dd .img_fst figure {
  width: 40%;
}

.history .container .unit_table dd .highlight {
  background-color: #f9f5ee;
  border: #d8bc00 1px solid;
  padding: 15px;
  margin-top: 15px;
}

.history .container .unit_table dd .highlight h4 {
  color: #d8bc00;
  padding-bottom: 5px;
}

@media screen and (max-width: 520px) {
  .history .container .unit_table dd .img_fst {
    display: block !important;
  }

  .history .container .unit_table dd .img_fst div {
    width: 100%;
  }

  .history .container .unit_table dd .img_fst figure {
    width: 80%;
    margin-top: 10px;
    margin-left: 10%;
    margin-right: 10%;
  }

  .history .container .unit_table dd.u_flex {
    display: block !important;
  }

  .history .container .unit_table dd.u_flex p {
    width: 100%;
  }

  .history .container .unit_table dd.u_flex figure {
    width: 80%;
    margin-top: 10px;
    margin-left: 10%;
    margin-right: 10%;
  }
}

/* リスト系ページ */

.news_posts .post_List li {
  margin: 30px 0;
  padding-bottom: 30px;
  border-bottom: 1px solid #f0e9db;
}

.news_posts .post_List li dl dt {
  font-weight: bold;
  font-size: 18px;
  padding-bottom: 5px;
  padding-left: 25px;
  position: relative;
}

.news_posts .post_List li dl dt:before {
  font-family: "lionicon";
  position: absolute;
  left: 0;
  content: "\f005";
  color: #ffe800;
  font-weight: normal;
}

.news_posts .post_List li dl dt {
  font-weight: bold;
}

/* sitemap */

.sitemaplist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 4em;
}

.sitemaplist ul {
  width: 30%;
  margin-left: 1.5%;
  margin-right: 1.5%;
  padding-top: 1em;
  position: relative;
  font-size: 18px;
  border-top: dotted 1px #f7de05;
}

.sitemaplist ul li {
  margin-bottom: 1em;
  padding-left: 1.3em;
  padding-bottom: 1em;
  border-bottom: dotted 1px #f7de05;
}

.sitemaplist ul li:before {
  position: absolute;
  left: 0;
  font-family: "lionicon";
  content: "\f005";
  color: #f7de05;
}

.sitemaplist ul li a {
  color: #000;
  font-weight: bold;
}

.sitemaplist ul ul {
  width: 100%;
  margin-top: 5px;
  font-size: 14px;
  padding-left: 1em;
  padding-top: 0em;
  border-top: none;
  border-left: #f7de05 1px solid;
}

.sitemaplist ul ul li {
  margin-bottom: 0em;
  padding-left: 0em;
  padding-bottom: 0px;
  border-bottom: none;
}

.sitemaplist ul ul li:before {
  display: none;
}

@media screen and (max-width: 767px) {
  .sitemaplist ul {
    width: 47%;
  }
}

@media screen and (max-width: 520px) {
  .sitemaplist ul {
    width: 100%;
    margin-left: 0%;
    margin-right: 0%;
  }
}

/* agentpage */

.agentpage {
  text-align: center;
  padding: 100px 0;
  font-weight: bold;
}

.agentpage p {
  font-weight: bold;
  line-height: 2;
  font-size: 20px;
}

.agentpage .link {
  margin-top: 3em;
  margin-left: 0%;
  margin-right: 0%;
  display: inline-block;
}

.agentpage .link a {
  display: block;
  padding: 0.75em 3em;
  max-width: 20em;
  background-color: #f7de05;
  color: #000;
  border-radius: 100px;
  word-break: break-all;
}

.agentpage a.link-for-agent {
  background-image: url(/images/agent-html/link-for-agent-banner.jpg);
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center;
  color: #000;
  font-size: 1.3rem;
  font-weight: 700;
  display: block;
  padding: 30px 80px;
  border-radius: 55px;
  margin-top: 40px;
  margin-left: auto;
  margin-right: auto;
  text-shadow: 0 0 8px #fff493;
  max-width: 550px;
  position: relative;
}

.agentpage a.link-for-agent:before {
  font-family: "lionicon";
  position: absolute;
  right: 25px;
  top: 31%;
  content: "\f105";
  opacity: 1;
  font-weight: normal !important;
}

@media screen and (max-width: 520px) {
  .agentpage a.link-for-agent {
    padding: 20px 60px;
  }
}

/* sustainability */
.sustainability_cont table {
  margin-top: 1.5em;
}
.sustainability_cont table thead tr > th {
  font-weight: 700;
  text-align: center;
  width: 45%;
  background-color: #ecb802;
  border: 1px solid #ecb802;
}
.sustainability_cont table thead tr > th:first-of-type {
  width: 55%;
  border-right: #f0e9db 1px solid;
}
.sustainability_cont table tbody tr > td {
  border: 1px solid #f2ebd5;
}
.sustainability_cont table tbody tr > td:first-of-type div {
  display: flex;
  height: 100%;
}
.sustainability_cont table tbody tr > td div p {
  width: 45%;
}
.sustainability_cont table tbody tr > td div p:first-of-type {
  font-weight: 700;
  width: 55%;
}

.sustainability_cont table .icons img {
  width: 25%;
  max-width: 110px;
  margin-right: 5px;
}

@media screen and (max-width: 640px) {
  .sustainability_cont table tbody tr > td:first-of-type div {
    display: block;
  }
  .sustainability_cont table tbody tr > td div p,
  .sustainability_cont table tbody tr > td div p:first-of-type {
    width: 100%;
  }
}

.sustainability_cont .other_links {
  display: flex;
  justify-content: center;
  margin-top: 45px;
  gap: 10px;
}

.sustainability_cont .other_links li {
  width: 45%;
  margin-top: 15px;
}
@media screen and (max-width: 640px) {
  .sustainability_cont .other_links {
    display: block;
  }

  .sustainability_cont .other_links li {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
}

.sustainability_cont .other_links li a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 100%;
  color: #000;
  flex-direction: column;
  border: 1px solid #d8bc00;
  border-radius: 15px;
  padding: 25px 10px;
  position: relative;
}

.sustainability_cont .other_links li a:hover {
  background-color: #f0e9db;
}
.sustainability_cont .other_links li a:before {
  font-family: "lionicon";
  position: absolute;
  right: 25px;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  content: "\f105";
  opacity: 1;
  font-weight: normal !important;
  color: #d8bc00;
}
.sustainability_cont .other_links li a p {
  font-weight: 700;
  font-size: 125%;
}

.sustainability_cont .other_links li a span {
  font-size: 77%;
}
