@charset "UTF-8";
/* -------------- config -------------- */
@font-face {
  font-family: "SourceHanSansJP-Medium";
  src: url(../fonts/SourceHanSansJP-Medium-min.otf);
  font-display: swap;
}
@font-face {
  font-family: "SourceHanSansJP-Heavy";
  src: url(../fonts/SourceHanSansJP-Heavy-min.otf);
  font-display: swap;
}
@font-face {
  font-family: "APJapanesefontT";
  src: url(../fonts/APJapanesefontT-min.woff) format("woff");
  font-display: swap;
}
@font-face {
  font-family: "M PLUS Rounded 1c";
  src: url(../fonts/MPLUSRounded1c-Regular.ttf) format("truetype");
  font-display: swap;
}
@font-face {
  font-family: "M PLUS Rounded 1c";
  src: url(../fonts/MPLUSRounded1c-Medium.ttf) format("truetype");
  font-display: swap;
}
/* -------------- body -------------- */
body {
  background: url(../img/background.png) repeat;
}

#container {
  overflow-x: hidden;
  min-height: calc(100vh - 80px);
  display: flex;
  flex-direction: column;
}

/* -------------- general -------------- */
h3.w100 {
  display: flex;
  width: 100vw;
  margin-left: calc( ( 100% - 100vw ) / 2 );
  margin-bottom: 20px;
}
h3.w100 p {
  max-width: 750px;
  width: calc(100% - 60px);
  min-height: 154px;
  font-size: 3.5rem;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 0 30px;
  background: url(../img/h3_ribbon_front.png) no-repeat center top;
  background-size: 100% 100%;
}
h3.w100 .ribbonL {
  flex: 1;
  min-height: 46px;
  margin-right: -74px;
  background: url(../img/h3_ribbon_back.png) no-repeat bottom;
}
h3.w100 .ribbonR {
  flex: 1;
  min-height: 46px;
  margin-left: -74px;
  background: url(../img/h3_ribbon_back.png) no-repeat bottom;
}

.stroke {
  color: #3E3A39;
  -webkit-text-stroke-width: 6px;
  position: relative;
  margin: 0;
}

.hemming {
  -webkit-text-stroke: 1px #3E3A39;
  position: absolute;
}

.yellow {
  -webkit-text-stroke-color: #FCD234;
}

.white {
  -webkit-text-stroke-color: #FFF;
}

/* -------------- header -------------- */
header {
  width: 100%;
  background: #FFF;
  position: sticky;
  top: 0;
  box-shadow: 0 0 5px 1px rgba(0, 0, 0, 0.3);
  z-index: 1000;
}
header #header_bar {
  width: 100%;
  height: 16px;
}
header #header_bar img {
  width: 100%;
  height: 100%;
  display: block;
}
header #headerWrap {
  max-width: 1300px;
  height: 80px;
  margin: 0 auto;
  padding: 0 15px;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  font-family: "M PLUS Rounded 1c", sans-serif;
}
header #headerWrap #hamburger {
  display: none;
}
header #headerWrap #hamburger #icon li {
  width: 100%;
  transform-origin: left center 0;
  transition: 0.5s;
}
header #headerWrap h1 {
  max-width: 340px;
}
@media(max-width:991px) {
  header #headerWrap h1 {
    max-width: 270px;
  }
}
header #headerWrap h1 a {
  display: block;
}
header #headerWrap h1 a img {
  width: 100%;
}
header #headerWrap #header_nav {
  flex: 1;
}
header #headerWrap #header_nav ul {
  display: flex;
  flex-wrap: nowrap;
}
header #headerWrap #header_nav ul li {
  flex: 1;
}
header #headerWrap #header_nav ul li a {
  font-size: 1.4rem;
  color: #3E3A39;
  display: block;
}
header #headerWrap #header_nav ul li a ruby {
  ruby-position: under;
  display: block;
  text-align: center;
}
header #headerWrap #header_nav ul li a ruby rt {
  font-size: 1.2rem;
  color: #569C29;
  transform: translateY(0.2em);
}

#menu {
  width: 100%;
  height: 100vh;
  position: fixed;
  top: -100vh;
  left: 0;
  background: rgba(86, 156, 41, 0.95);
  background-image: url(/img/menu_bg.png);
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: 100%;
  z-index: 500;
  transition: 0.3s;
}
#menu.active {
  display: block;
  top: 0;
  transition: 0.3s;
}
#menu.active ul {
  max-width: 350px;
  margin: 180px auto 0;
}
#menu.active ul li {
  margin-bottom: 30px;
  text-align: center;
}
#menu.active ul li a {
  width: 100%;
  text-align: center;
  font-size: 2rem;
  color: #FFF;
}

/* -------------- main -------------- */
main {
  max-width: 1300px;
  width: 100%;
  margin: 0 auto;
  flex-grow: 1;
}

#hero {
  padding: 15px 30px 45px;
  font-family: "SourceHanSansJP-Heavy";
}
#hero #heroBox {
  background: url(../img/green_bg.png) no-repeat;
  background-size: 100% 100%;
  padding: 15px 0;
}
#hero #heroBox h2 {
  width: 100vw;
  margin-left: calc( ( 100% - 100vw ) / 2 );
  text-align: center;
  color: #FFF;
  background: url(../img/h2.png) no-repeat;
  background-size: cover;
  padding: 16px 0;
  margin-bottom: 16px;
}
#hero #heroBox h2 .textUp {
  font-size: 2.9rem;
}
#hero #heroBox h2 p {
  font-size: 3.6rem;
}
#hero #heroBox #heroWrap p {
  font-size: 5.4rem;
  padding: 10px 30px 25px;
  background: url(../img/hero_head.png) no-repeat;
  background-size: 100% 100%;
  width: calc(100% + 20px);
  margin-left: -10px;
}
#hero #heroBox #heroWrap #heroText {
  position: relative;
}
#hero #heroBox #heroWrap #heroText #textImage {
  max-width: 765px;
  padding-left: 30px;
  position: relative;
}
#hero #heroBox #heroWrap #heroText #figureFlex {
  max-width: 420px;
  position: absolute;
  bottom: 0;
  right: 10px;
  display: flex;
}
#hero #heroBox #heroWrap #heroText #figureFlex figure {
  position: relative;
}
#hero #heroBox #heroWrap #heroText #figureFlex figure:nth-child(1) {
  max-width: 185px;
  position: absolute;
  top: 120px;
  left: -40px;
  z-index: 100;
}
#hero #heroBox #heroWrap #heroText #figureFlex figure:nth-child(2) {
  max-width: 427px;
}

#trouble {
  background: url(../img/trouble_bg.png) no-repeat;
  background-size: 100%;
  position: relative;
}
#trouble h3 {
  font-size: 0;
}
#trouble #troubleList {
  display: flex;
  max-width: 1224px;
  margin: 12% auto 0;
  position: relative;
}
#trouble #troubleList li {
  margin: 15px;
  position: relative;
}
#trouble #troubleList li p:nth-child(1) {
  position: absolute;
  transform: rotate(-5deg);
  text-align: center;
  width: 100%;
  font-family: "SourceHanSansJP-Heavy";
  font-size: 4rem;
}
#trouble #troubleList li p.exposition {
  background: url(../img/trouble_list.png) no-repeat center center;
  background-size: 100%;
  font-family: "APJapanesefontT";
  font-size: 3.3rem;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 254px;
  margin-top: -70px;
  position: relative;
  line-height: 1;
}
#trouble #troubleList::before {
  content: "";
  background: url(../img/ranger_red.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 109px;
  height: 160px;
  position: absolute;
  left: 0;
  top: 160px;
  z-index: 100;
}
#trouble #troubleList::after {
  content: "";
  background: url(../img/ranger_yellow.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 118px;
  height: 156px;
  position: absolute;
  right: 0;
  top: 160px;
  z-index: 100;
}

#solution {
  background: url(../img/green_bg.png) no-repeat;
  background-size: 100% 100%;
  padding: 60px 30px 15px;
  margin: 30px 0;
  position: relative;
}
#solution::before {
  content: "";
  background: url(../img/arrow.png);
  background-size: 100%;
  display: block;
  position: absolute;
  width: 97px;
  height: 137px;
  top: -70px;
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: 200;
}
#solution h3 {
  font-size: 0;
}
#solution #solutionText {
  text-align: center;
}
#solution #solutionText figure img {
  width: auto;
  height: 60px;
  display: inline-block;
}
#solution #features {
  display: flex;
  justify-content: space-around;
  margin-bottom: 30px;
}
#solution #features #reason {
  max-width: 446px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  flex: 1;
  position: relative;
}
#solution #features #staff {
  max-width: 774px;
  flex: 1;
  position: relative;
}
#solution #features #voiceSP {
  display: none;
}
#solution #voice {
  width: 100%;
  display: flex;
  justify-content: center;
}
#solution #voice dt img {
  max-width: 180px;
}
#solution #voice dd img {
  max-width: 700px;
}

#point h3 {
  font-size: 0;
}
#point #pointWrap {
  width: 100%;
  display: flex;
  justify-content: center;
}
#point #pointWrap li {
  flex: 1;
}
#point #pointWrap li img {
  width: 100%;
}

#frogRanger {
  margin: 0 auto 50px;
}
#frogRanger h3 {
  font-size: 0;
}
#frogRanger #frogRangerWrap {
  position: relative;
}
#frogRanger #frogRangerWrap figure {
  margin: 0 auto;
}
#frogRanger #frogRangerWrap p {
  background: url(../img/frogRanger_frame.png) no-repeat;
  background-size: 100% 100%;
  text-align: center;
  font-family: "SourceHanSansJP-Heavy";
  font-size: 3.6rem;
  margin: 0 auto;
  padding: 100px 0;
  max-width: 900px;
  line-height: 1.8em;
}

#manga {
  margin: 0 0 30px;
}
#manga h3 p {
  position: relative;
}
#manga h3 p:before {
  content: "";
  background: url(../img/ribbon_01.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 50px;
  height: 89px;
  position: absolute;
  top: 10px;
  left: 45px;
}
#manga h3 p:after {
  content: "";
  background: url(../img/ribbon_02.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 73px;
  height: 127px;
  position: absolute;
  top: 10px;
  right: 45px;
}
#manga figure {
  margin: 0 auto;
}

#campaign {
  margin: 0 auto 30px;
}
#campaign #campaignWrap {
  background: url(../img/green_bg.png) no-repeat;
  background-size: 100% 100%;
  padding: 50px 30px 50px;
}
#campaign #campaignWrap ul {
  display: grid;
  grid-template-columns: minmax(170px, 312px);
  justify-content: center;
  gap: 15px;
  max-width: 970px;
  margin: 0 auto;
}
#campaign #campaignWrap ul li {
  width: 100%;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
}
#campaign #campaignWrap ul li a {
  display: block;
  width: 100%;
}
#campaign #campaignWrap ul li a .cardHead {
  position: relative;
}
#campaign #campaignWrap ul li a .cardHead img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: 4px 4px 0 0;
}
#campaign #campaignWrap ul li a .cardBody {
  padding: 15px;
  background: #FFF;
  border-radius: 0 0 4px 4px;
}
#campaign #campaignWrap ul li a .cardBody p {
  font-size: 1.6rem;
  color: #3E3A39;
}
#campaign #campaignWrap ul li a .cardBtn {
  margin-top: 10px;
  text-align: center;
}
#campaign #campaignWrap ul li a .cardBtn p {
  background: #FFD900;
  color: #FFF;
  font-size: 1.4rem;
  font-weight: 900;
  border-radius: 8px;
  display: inline-block;
  padding: 1em 3.5em;
  position: relative;
  text-shadow: 0 0 2px rgba(0, 0, 0, 0.3);
}
#campaign figure {
  max-width: 720px;
  margin: 0 auto 30px;
}

#comparison {
  background: url(../img/comparison_bg.png) no-repeat center top;
  background-size: 100% 100%;
  margin: 0 auto 50px;
  padding: 8px;
}
#comparison h3 {
  font-size: 0;
}
#comparison #comparisonWrap {
  border: solid 2px #FFF;
  padding: 0 15px;
}
#comparison #comparisonWrap #topText, #comparison #comparisonWrap #underText {
  font-family: "SourceHanSansJP-Medium";
  font-size: 3.6rem;
  text-align: center;
  margin: 80px 0 50px;
  line-height: 1.8em;
}
#comparison #comparisonWrap #topText span, #comparison #comparisonWrap #underText span {
  display: inline-block;
}
#comparison #comparisonWrap #underText {
  line-height: 1.3em;
}
#comparison #comparisonWrap ul {
  margin: 0 auto;
  max-width: 980px;
}
#comparison #comparisonWrap ul li {
  background: url(../img/comparison_frame.png) no-repeat center center;
  background-size: 100% 100%;
  font-size: 2rem;
  margin-bottom: 15px;
  padding: 80px 30px;
  position: relative;
}
#comparison #comparisonWrap ul li:nth-child(1)::before {
  content: "";
  background: url(../img/ranger_red.png) no-repeat;
  background-size: 100%;
  display: block;
  position: absolute;
  right: -10px;
  bottom: 20px;
  width: 170px;
  height: 249px;
}
#comparison #comparisonWrap ul li:nth-child(2)::before {
  content: "";
  background: url(../img/ranger_yellow.png) no-repeat;
  background-size: 100%;
  display: block;
  position: absolute;
  right: -20px;
  bottom: 20px;
  width: 189px;
  height: 249px;
}
#comparison #comparisonWrap ul li h4 {
  font-size: 3.6rem;
  text-align: center;
  background: url(../img/comparison_line01.png) no-repeat center bottom;
  margin-bottom: 30px;
  line-height: 1em;
  font-family: "SourceHanSansJP-Heavy";
}
#comparison #comparisonWrap ul li h4 small {
  font-size: 1.4rem;
  font-family: "SourceHanSansJP-Medium";
}
#comparison #comparisonWrap ul li .price {
  background: url(../img/comparison_line02.png) no-repeat center bottom;
  font-size: 3.2rem;
  line-height: 1em;
  font-family: "SourceHanSansJP-Heavy";
  margin-bottom: 10px;
  text-align: center;
}
#comparison #comparisonWrap ul li .price small {
  font-size: 1.4rem;
  font-family: "SourceHanSansJP-Medium";
}
#comparison #comparisonWrap ul li .text {
  font-family: "SourceHanSansJP-Medium";
  font-size: 2.8rem;
  text-align: left;
  max-width: 580px;
  margin: 50px auto;
  padding: 0 3em 0 0;
}
#comparison #comparisonWrap ul li#iwa {
  background: url(../img/comparison_frame_red.png) no-repeat;
  background-size: 100% 100%;
}
#comparison #comparisonWrap ul li#iwa::before {
  content: "";
  background: url(../img/ranger_blue.png) no-repeat;
  background-size: 100%;
  display: block;
  position: absolute;
  right: -30px;
  bottom: -35px;
  width: 250px;
  height: 354px;
}
#comparison #comparisonWrap ul li#iwa h4 {
  font-size: 5rem;
  line-height: 1.4em;
  letter-spacing: 0.3em;
}
#comparison #comparisonWrap ul li#iwa .price {
  color: #E03B57;
  font-size: 4rem;
  line-height: 1;
}
#comparison #comparisonWrap ul li#iwa .price small {
  font-size: 1.7rem;
}
#comparison #comparisonWrap ul li#iwa .price span {
  font-size: 0.8rem;
}
#comparison #comparisonWrap ul li#iwa .text {
  font-family: "SourceHanSansJP-Heavy";
  font-size: 3.8rem;
  max-width: 600px;
  padding: 0;
  line-height: 1.8em;
}

.call {
  margin: 0 auto 50px;
}
.call h3 {
  font-size: 0;
}
.call address div {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
.call address div p:nth-child(1) {
  background: url(../img/call_bg.png) no-repeat left bottom;
  background-size: 100%;
  font-family: "SourceHanSansJP-Medium";
  font-size: 3.8rem;
  text-align: center;
  line-height: 1.2em;
  padding: 0 50px 50px;
}
.call address div p:nth-child(1) span {
  display: block;
  font-family: "SourceHanSansJP-Heavy";
  font-size: 3.9rem;
  color: #E03B57;
}
.call address div p:nth-child(2) {
  font-family: "SourceHanSansJP-Heavy";
  font-size: 3.8rem;
  padding: 0 50px 50px;
}
.call address div p:nth-child(2) time {
  font-family: "SourceHanSansJP-Medium";
  font-size: 1.4rem;
  display: block;
}
.call address .tel {
  font-family: "SourceHanSansJP-Heavy";
  font-size: 6.4rem;
  background: #FFD900;
  border-radius: 8px;
  text-align: center;
  margin-top: -15px;
  padding: 10px 0;
  color: #FFF;
  display: flex;
  justify-content: center;
  align-items: center;
}
.call address .tel img {
  display: inline-block;
  margin-right: 5px;
  width: 64px;
}
.call address .tel a {
  color: #FFF;
}
.call address .open {
  font-family: "SourceHanSansJP-Medium";
  font-size: 3.2rem;
  text-align: center;
  margin-top: 5px;
}
.call address .open span {
  font-family: "SourceHanSansJP-Heavy";
  color: #569C29;
}

#profile {
  margin: 0 auto 50px;
  background: url(../img/profile_frame.png) no-repeat;
  background-size: 100% 100%;
  padding: 150px 30px 150px;
  position: relative;
}
#profile::before {
  content: "";
  background: url(../img/profile_ribbon_top.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 230px;
  height: 243px;
  position: absolute;
  top: 0;
  right: -30px;
}
#profile::after {
  content: "";
  background: url(../img/profile_ribbon_bottom.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 148px;
  height: 168px;
  position: absolute;
  bottom: 0;
  left: -5px;
}
#profile h3 {
  margin-bottom: 40px;
}
#profile h3 p {
  font-family: "APJapanesefontT";
  font-weight: normal;
  font-size: 5.6rem;
  text-align: center;
}
#profile figure {
  max-width: 1210px;
  margin: 0 auto 40px;
}
#profile p {
  font-family: "APJapanesefontT";
  font-size: 3.6rem;
  padding: 0 40px;
  line-height: 1.3em;
}
#profile p:not(:last-child) {
  margin-bottom: 40px;
}
#profile p.impressed {
  font-size: 5.6rem;
  text-align: center;
  color: #569C29;
  margin: 80px 0;
}

#promise {
  margin: 0 auto 50px;
  background: url(../img/green_bg.png) no-repeat center top;
  background-size: 100% 100%;
}
#promise h3 {
  text-align: center;
  padding: 50px 15px;
  max-width: 100%;
}
#promise h3 img {
  max-width: 100%;
}
#promise ul {
  padding: 0 50px 80px;
  position: relative;
}
#promise ul li {
  font-size: 3.2rem;
  display: flex;
  margin-bottom: 50px;
}
#promise ul li span {
  font-family: "SourceHanSansJP-Heavy";
  font-size: 3.2rem;
  background: url(../img/promise_no.png) no-repeat;
  background-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 72px;
  height: 72px;
  line-height: 1;
}
#promise ul li p {
  flex: 1;
  margin-left: 10px;
  font-family: "SourceHanSansJP-Heavy";
  line-height: 1.8em;
}
#promise ul::before {
  content: "";
  background: url(../img/ranger_green.png) no-repeat;
  background-size: 100%;
  width: 196px;
  height: 254px;
  position: absolute;
  bottom: -20px;
  right: 0;
}

#faq {
  margin: 0 auto 30px;
}
#faq h3 p {
  position: relative;
}
#faq h3 p:before {
  content: "";
  background: url(../img/ribbon_03.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 104px;
  height: 144px;
  position: absolute;
  top: -10px;
  left: 0;
}
#faq h3 p:after {
  content: "";
  background: url(../img/ribbon_04.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 165px;
  height: 157px;
  position: absolute;
  top: -40px;
  right: 0;
}
#faq dl {
  max-width: 1024px;
  margin: 0 auto;
}
#faq dl dt {
  font-family: "SourceHanSansJP-Heavy";
  font-size: 2.8rem;
  display: flex;
  align-items: center;
}
#faq dl dt span {
  font-family: "APJapanesefontT";
  font-size: 6.3rem;
  color: #569C29;
  line-height: 1;
}
#faq dl dt p {
  line-height: 2em;
}
#faq dl dd {
  font-family: "SourceHanSansJP-Medium";
  font-size: 2.8rem;
  display: flex;
  margin-bottom: 40px;
}
#faq dl dd span {
  font-family: "APJapanesefontT";
  font-size: 6.3rem;
  color: #E03B57;
  line-height: 1;
}
#faq dl dd p {
  line-height: 2em;
}

#performance {
  margin: 0 auto 50px;
  padding: 40px 0;
  background: url(../img/performance_bg.png) no-repeat center center;
  background-size: 100% 100%;
}
#performance h3 {
  font-size: 0;
}
#performance p {
  position: relative;
  font-family: "SourceHanSansJP-Medium";
  font-size: 3.6rem;
  text-align: center;
  line-height: 1.8em;
}
#performance p span {
  display: inline-block;
  white-space: nowrap;
}
#performance p span .hemming {
  white-space: nowrap;
}
#performance p .emphasis {
  font-family: "SourceHanSansJP-Heavy";
}
#performance p::before {
  content: "";
  background: url(../img/performance01.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 66px;
  height: 88px;
  top: 0;
  left: 15px;
  position: absolute;
}
#performance p::after {
  content: "";
  background: url(../img/performance02.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 84px;
  height: 157px;
  bottom: 0;
  right: 15px;
  position: absolute;
}

#casestudy {
  margin: 0 auto 50px;
}
#casestudy #casestudyWrap {
  background: url(../img/green_bg.png) no-repeat;
  background-size: 100% 100%;
  padding: 50px 30px 50px;
}
#casestudy #casestudyWrap ul {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 312px));
  justify-content: center;
  gap: 15px;
  max-width: 970px;
  margin: 0 auto;
}
#casestudy #casestudyWrap ul li {
  width: 100%;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
}
#casestudy #casestudyWrap ul li a {
  display: block;
  width: 100%;
}
#casestudy #casestudyWrap ul li a .cardHead {
  position: relative;
}
#casestudy #casestudyWrap ul li a .cardHead img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: 4px 4px 0 0;
}
#casestudy #casestudyWrap ul li a .cardBody {
  padding: 15px;
  background: #FFF;
  border-radius: 0 0 4px 4px;
}
#casestudy #casestudyWrap ul li a .cardBody p {
  font-size: 1.6rem;
  color: #3E3A39;
}
#casestudy #casestudyWrap ul li a .cardBtn {
  margin-top: 10px;
  text-align: center;
}
#casestudy #casestudyWrap ul li a .cardBtn p {
  background: #FFD900;
  color: #FFF;
  font-size: 1.4rem;
  font-weight: 900;
  border-radius: 8px;
  display: inline-block;
  padding: 1em 3.5em;
  position: relative;
  text-shadow: 0 0 2px rgba(0, 0, 0, 0.3);
}

#access {
  margin: 0 auto 30px;
}
#access h3 p {
  position: relative;
}
#access h3 p:before {
  content: "";
  background: url(../img/ribbon_06.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 106px;
  height: 114px;
  position: absolute;
  top: 0;
  left: 0;
}
#access h3 p:after {
  content: "";
  background: url(../img/ribbon_07.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 98px;
  height: 114px;
  position: absolute;
  top: 0;
  right: 0;
}
#access ul {
  max-width: 1024px;
  margin: 0 auto;
}
#access ul li {
  display: flex;
  flex-wrap: nowrap;
  font-size: 1.6rem;
  border-top: solid 1px #3E3A39;
  padding: 1.5em 0;
}
#access ul li p:nth-child(1) {
  width: 200px;
  font-family: "SourceHanSansJP-Heavy";
}
#access ul li p:nth-child(2) {
  flex: 1;
  font-family: "SourceHanSansJP-Medium";
}
#access ul li p:nth-child(2) address {
  line-height: 1.8em;
}
#access address {
  text-align: center;
  font-size: 1.6rem;
  margin: 5rem 0;
}
#access #map {
  width: 100vw;
  margin-left: calc( ( 100% - 100vw ) / 2 );
}
#access #map iframe {
  width: 100%;
}
#access #map iframe #mapDiv {
  background: #fed;
}
#access #map iframe #mapDiv > div {
  background: #fed;
}

#contact {
  margin: 0 auto;
}
#contact .pl2 {
  font-size: 16px;
  padding-bottom: 100px;
}
#contact .pl2 form#mail_form {
  font-family: "SourceHanSansJP-Medium";
  margin: 0 auto;
  padding: 0;
  background: none;
  border: none;
  box-shadow: none;
  font-size: 1.6rem;
  line-height: 1.8;
}
#contact .pl2 form#mail_form dl dt span {
  font-size: 1.6rem;
  color: #0061AA;
}
#contact .pl2 form#mail_form dl dt span.required, #contact .pl2 form#mail_form dl dt span.optional {
  color: #FFF;
  font-size: 1.2rem;
  padding: 3px 10px;
  border: none;
  border-radius: 0;
}
#contact .pl2 form#mail_form dl dd {
  box-sizing: content-box;
}

#job {
  max-width: 640px;
  margin: 50px auto 100px;
  text-align: center;
}
#job a {
  font-size: 1.8rem;
  color: #FFF;
  background: #28c3d4;
  padding: 1em 2em;
  border-radius: 5px;
}

#link_interview {
  max-width: 640px;
  margin: 50px auto 100px;
  text-align: center;
}
#link_interview a {
  font-size: 1.8rem;
  color: #FFF;
  background: #28c3d4;
  padding: 1em 2em;
  border-radius: 5px;
}

#thanks {
  max-width: 1280px;
  margin: 20px auto 0;
}
#thanks #message {
  max-width: 580px;
  margin: 50px auto;
  font-family: "SourceHanSansJP-Medium";
  font-size: 2.2rem;
}
#thanks #message p {
  margin-bottom: 20px;
}

#returnTop {
  text-align: center;
}
#returnTop a {
  font-size: 1.8rem;
  color: #FFF;
  background: #569c29;
  padding: 0.5em 2em;
  border-radius: 5px;
}

#page_top {
  width: 50px;
  height: 50px;
  position: fixed;
  right: 5px;
  bottom: 5px;
  background: #FFF;
  border-radius: 50%;
  box-shadow: 0 0 8px 1px rgba(0, 0, 0, 0.3);
}

#page_top a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  padding: 10px;
  text-decoration: none;
}
#page_top a img {
  width: 100%;
}

#fixedNav {
  width: 68px;
  position: fixed;
  right: 0;
  top: 380px;
  z-index: 500;
  background: #FFF;
}
#fixedNav ul li a {
  height: 54px;
  color: #FFF;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-family: "SourceHanSansJP-Medium";
}
#fixedNav ul li a figure {
  width: 20px;
}
#fixedNav ul li a .mobile {
  display: none;
}
#fixedNav ul li:nth-child(1) {
  background: #E03B57;
}
#fixedNav ul li:nth-child(2) {
  background: #569C29;
  margin: 1px 0;
}
#fixedNav ul li:nth-child(3) {
  background: #EE6F21;
}

#breadcrumb {
  background: #efefef;
}
#breadcrumb ul {
  display: flex;
  flex-wrap: wrap;
  padding: 5px 15px;
}
#breadcrumb ul li a {
  color: #525252;
}
#breadcrumb ul li a:hover {
  text-decoration: underline;
}
#breadcrumb ul li:not(:last-child)::after {
  content: ">";
  color: #525252;
  margin: 0 1em;
}

#casestudy_detail {
  margin: 30px auto 0;
}
#casestudy_detail h3 {
  margin-bottom: 50px;
}
#casestudy_detail h3 p::before {
  content: "";
  background: url(../img/ribbon_01.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 50px;
  height: 89px;
  position: absolute;
  top: 10px;
  left: 45px;
}
#casestudy_detail h3 p::after {
  content: "";
  background: url(../img/ribbon_02.png) no-repeat;
  background-size: 100%;
  display: block;
  width: 73px;
  height: 127px;
  position: absolute;
  top: 10px;
  right: 45px;
}
#casestudy_detail h4 {
  font-size: 3.2rem;
  text-align: center;
  margin-bottom: 20px;
  white-space: nowrap;
  background: url(../img/comparison_line01.png) no-repeat center bottom;
}
#casestudy_detail h4 .small {
  font-size: 1.8rem;
}
#casestudy_detail #eyecatch figure {
  border: solid 8px #fff;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
}
#casestudy_detail section {
  max-width: 1024px;
  margin: 0 auto 100px;
}
#casestudy_detail section h5 {
  font-size: 2.4rem;
  text-align: center;
  position: relative;
  padding: 1rem 2rem calc(1rem + 10px);
  background: #299c47;
  margin-bottom: 20px;
  color: #FFF;
}
#casestudy_detail section h5::before {
  position: absolute;
  top: -7px;
  left: -7px;
  width: 100%;
  height: 100%;
  content: "";
  border: 4px solid #000;
}
#casestudy_detail #info table {
  width: 100%;
  border-collapse: collapse;
}
#casestudy_detail #info table th, #casestudy_detail #info table td {
  border: solid 1px #525252;
  font-size: 1.8rem;
  padding: 0.4em 1em;
}
#casestudy_detail #info table th {
  width: 25%;
  text-align: center;
  background: #e8f5d4;
}
#casestudy_detail #info table tr.cpt th, #casestudy_detail #info table tr.cpt td {
  text-align: center;
  background: #38af42;
  color: #FFF;
}
#casestudy_detail #info #order {
  background: url(../img/green_bg.png) no-repeat;
  background-size: 100% 100%;
  padding: 50px;
  margin-top: 30px;
}
#casestudy_detail #info #order dl {
  margin-bottom: 30px;
}
#casestudy_detail #info #order dl dt {
  font-size: 2.4rem;
  margin-bottom: 20px;
  white-space: nowrap;
  background: url(../img/comparison_line02.png) no-repeat center bottom;
  display: inline-block;
  padding: 0 0.5em 0.2em;
}
#casestudy_detail #info #order dl dd {
  font-size: 2rem;
  margin-bottom: 40px;
  padding-left: 3em;
}
#casestudy_detail .process ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
#casestudy_detail .process ul li {
  max-width: 334px;
  margin: 5px 3px;
  display: flex;
  align-items: center;
  background: #ddd;
}
#casestudy_detail .process ul li:nth-child(4) {
  margin-right: auto;
}
#casestudy_detail .process ul li a {
  display: block;
  width: 100%;
}
#casestudy_detail .process ul li a img {
  width: 100%;
}
#casestudy_detail .process.beforeAfter ul {
  grid-template-columns: 1fr 1fr;
}
#casestudy_detail #youtube {
  width: 100%;
  height: 0;
  position: relative;
  margin-bottom: 30px;
  padding-bottom: 56.25%;
  overflow: hidden;
}
#casestudy_detail #youtube iframe {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}

.lity-container .lity-content {
  max-width: 780px;
}

/************************************
** 評価グラフ
************************************/
.pb-rating-graph {
  box-shadow: 0 3px 5px rgba(0, 0, 0, 0.07);
  max-width: 700px;
  margin: 0 auto 2em !important;
  padding: 2.5em 2em !important;
  color: #333;
  background: #fafafa;
}

.pb-rating-graph ul {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}

.pb-rating-graph #voice {
  width: 100%;
  margin-top: 20px;
}
.pb-rating-graph #voice a {
  display: block;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
  position: relative;
}
.pb-rating-graph #voice a img {
  width: 100%;
}

.pb-rating-graph ul li {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.pb-rating-graph ul li:before {
  content: unset !important;
}

.pb-rating-graph__label {
  background: #71828A;
  color: #fff;
  display: inline-block;
  padding: 6px 15px;
  font-weight: 600;
  font-size: 14px;
  line-height: 1.2;
}

.pb-rating-graph__wrap {
  display: flex;
  margin: 20px 0;
}

.pb-rating-graph__wrap .text {
  font-size: 16px;
  color: #71828A;
  font-weight: 600;
}

.pb-rating-graph__wrap .text p, .pb-rating-graph__wrap .text ol {
  margin-bottom: 1em;
}

.pb-rating-graph__wrap .text ol li {
  list-style-type: decimal !important;
  list-style-position: inside !important;
  margin-bottom: 1em !important;
}

.pb-rating-graph li:last-child .pb-rating-graph__wrap {
  margin: 20px 0 0;
}

.pb-rating-graph__axis {
  width: 70%;
  margin-top: 10px;
  position: relative;
  display: flex;
  justify-content: space-between;
}

.pb-rating-graph__axis:before {
  content: "";
  display: inline-block;
  height: 5px;
  background: #E3E6E7;
  width: 100%;
  position: absolute;
}

.pb-rating-graph__basis {
  width: 15%;
  color: #71828A;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.5;
}

.pb-rating-graph__basis-inner {
  display: inline-block;
  text-align: left;
}

.pb-rating-graph__wrap .pb-rating-graph__basis:first-of-type {
  text-align: right;
  padding-right: 15px;
}

.pb-rating-graph__wrap .pb-rating-graph__basis:last-of-type {
  text-align: left;
  padding-left: 15px;
}

.pb-rating-graph__scale {
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 1;
  width: 20px;
  margin-top: 0 !important;
}

.pb-rating-graph__scale:before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  margin-top: -7px;
  margin-bottom: 10px;
  background: #E3E6E7;
}

.pb-rating-graph__axis:after, .pb-rating-graph__scale:after {
  content: unset !important;
}

.pb-rating-graph .pb-rating-graph__scale .pb-rating-graph__item {
  width: 42px;
  display: block;
  font-weight: 600;
  font-size: 14px;
  color: #777;
  text-align: center;
  padding-top: 5px;
  margin-top: -10px !important;
}

@media screen and (max-width: 600px) {
  .pb-rating-graph {
    padding: 2em 1em !important;
  }

  .pb-rating-graph__axis {
    width: 60%;
  }

  .pb-rating-graph__basis {
    width: 20%;
    font-size: 13px;
    letter-spacing: 0px;
    line-height: 1.8;
  }

  .pb-rating-graph__wrap .pb-rating-graph__basis:first-of-type {
    padding-right: 7px;
  }

  .pb-rating-graph__wrap .pb-rating-graph__basis:last-of-type {
    padding-left: 7px;
  }

  .pb-rating-graph__scale {
    width: 16px;
  }

  .pb-rating-graph__scale:before {
    width: 16px;
    height: 16px;
  }

  .pb-rating-graph .pb-rating-graph__scale .pb-rating-graph__item {
    font-size: 12px;
  }

  .pb-rating-graph__scale[data-check=true]:before {
    font-size: 20px;
  }
}
.pb-rating-graph__scale[data-check=true]:before {
  background: #ee8f81;
}

/************************************
** 動画コメント
************************************/
#movieTalk .talking {
  margin-bottom: 50px;
  display: flex;
  flex-wrap: nowrap;
}
#movieTalk .talking figure, #movieTalk .talking .space {
  max-width: 120px;
  width: 100%;
}
#movieTalk .talking figure img, #movieTalk .talking .space img {
  border-radius: 50%;
}
#movieTalk .talking figure figcaption, #movieTalk .talking .space figcaption {
  text-align: center;
  font-size: 1.4rem;
  margin-top: 0.3em;
}
#movieTalk .talking .talkingBody {
  flex: 1;
  margin: 0 5em;
  padding: 2em 3em;
  border-radius: 10px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  position: relative;
}
#movieTalk .talking .talkingBody::before {
  content: "";
  display: block;
  position: absolute;
  top: 1em;
}
#movieTalk .talking .talkingBody p {
  font-size: 2rem;
}
#movieTalk .talking .talkingBody p:not(:last-child) {
  margin-bottom: 1em;
}
#movieTalk .talkingleft {
  flex-direction: row;
}
#movieTalk .talkingleft .talkingBody {
  background: #a9da95;
}
#movieTalk .talkingleft .talkingBody::before {
  left: -1.5em;
  border-top: 0.7em solid transparent;
  border-right: 1.5em solid #a9da95;
  border-bottom: 0.7em solid transparent;
}
#movieTalk .talkingRight {
  flex-direction: row-reverse;
}
#movieTalk .talkingRight .talkingBody {
  background: #bcdef5;
}
#movieTalk .talkingRight .talkingBody::before {
  right: -1.5em;
  border-top: 0.7em solid transparent;
  border-left: 1.5em solid #bcdef5;
  border-bottom: 0.7em solid transparent;
}

/* -------------- webp -------------- */
.webp body {
  background: url(../img/background.webp) repeat;
}
.webp #menu {
  background: rgba(86, 156, 41, 0.95);
  background-image: url(/img/menu_bg.webp);
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: 100%;
}
.webp h3.w100 p {
  background: url(../img/h3_ribbon_front.webp) no-repeat center top;
  background-size: 100% 100%;
}
.webp h3.w100 .ribbonL {
  background: url(../img/h3_ribbon_back.webp) no-repeat bottom;
}
.webp h3.w100 .ribbonR {
  background: url(../img/h3_ribbon_back.webp) no-repeat bottom;
}
.webp #hero #heroBox {
  background: url(../img/green_bg.webp) no-repeat;
}
.webp #hero #heroBox h2 {
  background: url(../img/h2.webp) no-repeat;
}
.webp #hero #heroBox #heroWrap p {
  background: url(../img/hero_head.webp) no-repeat;
  background-size: 100% 100%;
}
.webp #trouble {
  background: url(../img/trouble_bg.webp) no-repeat;
  background-size: 100%;
}
.webp #trouble #troubleList li p.exposition {
  background: url(../img/trouble_list.webp) no-repeat center center;
  background-size: 100%;
}
.webp #trouble #troubleList::before {
  background: url(../img/ranger_red.webp) no-repeat;
  background-size: 100%;
}
.webp #trouble #troubleList::after {
  background: url(../img/ranger_yellow.webp) no-repeat;
  background-size: 100%;
}
.webp #solution {
  background: url(../img/green_bg.webp) no-repeat;
  background-size: 100% 100%;
}
.webp #solution::before {
  background: url(../img/arrow.webp);
  background-size: 100%;
}
.webp #frogRanger #frogRangerWrap p {
  background: url(../img/frogRanger_frame.webp) no-repeat;
  background-size: 100% 100%;
}
.webp #campaign #campaignWrap {
  background: url(../img/green_bg.webp) no-repeat;
  background-size: 100% 100%;
}
.webp #comparison {
  background: url(../img/comparison_bg.webp) no-repeat center top;
  background-size: 100% 100%;
}
.webp #comparison #comparisonWrap ul li:nth-child(1)::before {
  background: url(../img/ranger_red.webp) no-repeat;
  background-size: 100%;
}
.webp #comparison #comparisonWrap ul li:nth-child(2)::before {
  background: url(../img/ranger_yellow.webp) no-repeat;
  background-size: 100%;
}
.webp #comparison #comparisonWrap ul li h4 {
  background: url(../img/comparison_line01.webp) no-repeat center bottom;
}
.webp #comparison #comparisonWrap ul li#iwa::before {
  background: url(../img/ranger_blue.webp) no-repeat;
  background-size: 100%;
}
.webp #profile {
  background: url(../img/profile_frame.webp) no-repeat;
  background-size: 100% 100%;
}
.webp #promise {
  background: url(../img/green_bg.webp) no-repeat center top;
  background-size: 100% 100%;
}
.webp #promise ul::before {
  background: url(../img/ranger_green.webp) no-repeat;
  background-size: 100%;
}
.webp #performance {
  background: url(../img/performance_bg.webp) no-repeat center center;
  background-size: 100% 100%;
}
.webp #casestudy #casestudyWrap {
  background: url(../img/green_bg.webp) no-repeat;
  background-size: 100% 100%;
}
.webp #access {
  margin: 0 auto 30px;
}
.webp #casestudy_detail h4 {
  background: url(../img/comparison_line01.webp) no-repeat center bottom;
}
.webp #casestudy_detail #info #order {
  background: url(../img/green_bg.webp) no-repeat;
}
