@charset "UTF-8";
/*----------------------------------------------------------------------------------------
rest.scss
----------------------------------------------------------------------------------------*/
*,
::before,
::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 0;
  padding: 0;
  list-style: none;
  text-decoration: none;
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

body {
  /*margin: 0;*/
}

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  /*margin: 0;*/
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  /*margin: 0;*/
}

/*ul,
ol {
    margin: 0;
    padding: 0;
    list-style: none;
}

dt {
    font-weight: bold;
}

dd {
    margin-left: 0;
}*/
hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  height: 0;
  overflow: visible;
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

pre {
  font-family: monospace, monospace;
  font-size: inherit;
}

address {
  font-style: inherit;
}

a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: inherit;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img,
embed,
object,
iframe {
  vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}

[type=checkbox] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
       appearance: checkbox;
}

[type=radio] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
       appearance: radio;
}

button,
input {
  overflow: visible;
  border: none;
}

button,
select {
  text-transform: none;
}

button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

button[disabled],
[type=button][disabled],
[type=reset][disabled],
[type=submit][disabled] {
  cursor: default;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

select::-ms-expand {
  display: none;
}

option {
  padding: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[contenteditable] {
  outline: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

* {
  margin: 0;
  padding: 0;
  list-style: none;
  text-decoration: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html {
  font-weight: 500;
  font-size: 62.5%;
}

body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  color: #313131;
  background: #f7f7f7;
  overflow-x: hidden;
}

.mincho {
  font-family: "Hiragino Mincho Pro", "游明朝", "Yu Mincho", YuMincho, serif;
}

a {
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

a, span {
  display: inline-block;
}

img {
  max-width: -webkit-max-content;
  max-width: -moz-max-content;
  max-width: max-content;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

iframe {
  aspect-ratio: 16/9;
  max-width: 100%;
}

video {
  width: 100%;
}

select {
  -moz-appearance: menulist;
  -webkit-appearance: menulist;
}

input,
select,
textarea {
  background-color: #fff;
  border: 1px solid #d3d3d3;
  /*border-radius: 5px;*/
  padding: 5px 10px;
  -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16) inset;
          box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16) inset;
  margin: 1% auto;
  max-width: 100%;
}

input::-webkit-input-placeholder {
  color: #BCBCBC;
}

input::-moz-placeholder {
  color: #BCBCBC;
}

input:-ms-input-placeholder {
  color: #BCBCBC;
}

input::-ms-input-placeholder {
  color: #BCBCBC;
}

input::placeholder {
  color: #BCBCBC;
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  opacity: 1;
}

label {
  font-weight: 600;
}

summary {
  list-style: none;
  background: #dedede;
  padding: 5px 1rem;
}

summary::-webkit-details-marker,
summary::marker {
  display: none;
}

/*----------------------------------------------------------------------------------------
header.scss
----------------------------------------------------------------------------------------*/
.l-header {
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 990;
  height: auto;
  background: #fff;
  height: 89px;
  border-radius: 0 0 40px 40px;
  -webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 3px rgba(0, 0, 0, 0.16);
  isolation: isolate;
}
.l-header .bdr_line {
  height: 9px;
  width: 100%;
  background: -webkit-gradient(linear, left top, right top, color-stop(50%, #172147), color-stop(50%, #d40014));
  background: linear-gradient(to right, #172147 50%, #d40014 50%);
}
.l-header__inner {
  width: 96%;
  margin: 0 auto;
  padding: 15px 0;
}
.l-header__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.l-header__logo {
  width: 20%;
  max-width: 173px;
}
.l-header #g-nav {
  width: 80%;
}
.l-header #g-nav-list {
  position: relative;
  /*top: 50%;
  transform: translateY(-50%);*/
  width: 100%;
}
.l-header #g-nav-list .menu {
  width: 100%;
}
.l-header #g-nav ul {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
}
.l-header #g-nav ul li {
  position: relative;
  font-size: clamp(1.4rem, 0.174vw + 1.267rem, 1.6rem);
  font-weight: 600;
}
.l-header #g-nav ul li a {
  display: block;
  padding: 2px 0.8em;
}
.l-header #g-nav ul li:last-child {
  border-left: 1px solid #5A5957;
  width: 46px;
}
.l-header #g-nav ul li:last-child a {
  padding: 2px 0 2px 10px;
}
.l-header #g-nav ul li:last-child img {
  width: 36px;
}
.l-header #g-nav ul li::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 40px;
  width: 100%;
}
.l-header #g-nav ul li:hover::after {
  display: block;
}
.l-header #g-nav ul .megamenu {
  display: none;
  position: fixed;
  top: 89px;
  left: 0;
  right: 0;
  width: 100%;
  -webkit-transform: none;
          transform: none;
  margin: 0;
  background: #fff;
  z-index: 1;
  padding: 20px;
  border-bottom: 1px solid rgba(112, 112, 112, 0.5);
}
.l-header #g-nav ul .megamenu::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: calc(100% - 60px);
  border-top: 2px solid rgba(0, 0, 0, 0.16);
}
.l-header #g-nav ul li:hover > .megamenu {
  display: block;
}
.l-header #g-nav ul .megamenu__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.l-header #g-nav ul .megamenu__title {
  width: 37.5%;
  padding-right: 2.5%;
  border-right: 1px solid #707070;
}
.l-header #g-nav ul .megamenu__title-box {
  background: #9AAEB9;
  border-radius: 8px;
  padding: 5% 5% 5%;
  line-height: 1.5;
  text-align: left;
  font-size: 1.3rem;
  max-width: 224px;
  /*height: 144px;*/
  margin: 0 0 0 auto;
}
.l-header #g-nav ul .megamenu__title-box p {
  color: #fff;
  margin-bottom: 20px;
}
.l-header #g-nav ul .megamenu__title-box a {
  color: #fff;
  padding: 0 !important;
  text-align: right;
}
.l-header #g-nav ul .megamenu__title-box img {
  width: auto !important;
  vertical-align: baseline;
}
.l-header #g-nav ul .megamenu ul {
  width: 62.5%;
  padding-left: 2.5%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.l-header #g-nav ul .megamenu ul li {
  width: auto;
  max-width: 23%;
  margin: 0 2.2% 0 0;
  font-size: 1.3rem;
}
.l-header #g-nav ul .megamenu ul li:hover::after {
  display: none;
}
.l-header #g-nav ul .megamenu ul li:last-child {
  border: none;
  width: auto;
}
.l-header #g-nav ul .megamenu ul li:last-child img {
  width: 100%;
}
.l-header #g-nav ul .megamenu ul li a {
  padding: 0;
  text-align: left;
}
.l-header #g-nav ul .megamenu ul li a .img {
  width: 100%;
  margin: 0 0 5px 0;
  border-radius: 8px;
  overflow: hidden;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.l-header #g-nav ul .megamenu ul li a:hover img {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.l-header #g-nav ul .megamenu ul.list02 {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 auto;
  width: 90%;
}
.l-header #g-nav ul .megamenu ul.list02 li {
  min-width: 20%;
  max-width: 20%;
  margin: 0 auto;
}
.l-header #g-nav ul .megamenu ul.list02 li a {
  text-align: center;
  padding: 20px 0;
}
.l-header #g-nav ul .megamenu ul.list02 li a .img {
  margin-bottom: 10px;
}
.l-header #g-nav ul .megamenu ul.list02 li a .img img {
  width: auto;
  max-width: 160px;
  height: 50px;
  margin-bottom: 10px;
}

@media screen and (max-width: 1040px) {
  .l-header {
    border-radius: 0;
    height: 80px;
  }
  .l-header__inner {
    width: 90%;
    margin: 0 auto;
    padding: 14px 0;
  }
  .l-header__logo {
    width: 50%;
    max-width: 173px;
  }
  .l-header #g-nav {
    position: fixed;
    z-index: 999;
    top: 9px;
    right: -375px;
    left: auto;
    width: 375px;
    height: auto;
    padding: 60px 30px 50px;
    -webkit-transition: all 0.6s;
    transition: all 0.6s;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    background: #fff;
    -webkit-box-shadow: 1px 3px 3px rgba(0, 0, 0, 0.19);
            box-shadow: 1px 3px 3px rgba(0, 0, 0, 0.19);
  }
  .l-header #g-nav.panelactive {
    right: 0;
  }
  .l-header #g-nav-list {
    position: relative;
    top: 0;
    -webkit-transform: none;
            transform: none;
    width: 100%;
  }
  .l-header #g-nav-list .menu {
    width: 100%;
  }
  .l-header #g-nav-list .menu ul {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .l-header #g-nav-list .menu ul li {
    width: 100%;
    font-size: 1.6rem;
    margin-bottom: 0;
    border-bottom: 1px solid #dedede;
    line-height: 1.6;
  }
  .l-header #g-nav-list .menu ul li a {
    width: 100%;
    padding: 5px 10px;
    font-size: 1.8rem;
    text-align: left;
  }
  .l-header #g-nav-list .menu ul li a br {
    display: none;
  }
  .l-header #g-nav-list .menu ul li:last-child {
    display: none;
  }
  .l-header #g-nav-list .menu ul li::after {
    display: none;
  }
  .l-header #g-nav-list .menu ul li:hover::after {
    display: none;
  }
  .l-header #g-nav-list .menu ul .megamenu {
    display: block;
    position: relative;
    top: auto;
    padding: 0;
    border-bottom: none;
  }
  .l-header #g-nav-list .menu ul .megamenu::before {
    display: none;
  }
  .l-header #g-nav-list .menu ul .megamenu__title {
    display: none;
  }
  .l-header #g-nav-list .menu ul .megamenu ul {
    width: 100%;
    padding-left: 1em;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .l-header #g-nav-list .menu ul .megamenu ul li {
    width: 100%;
    max-width: 100%;
    border: none;
  }
  .l-header #g-nav-list .menu ul .megamenu ul li:last-child {
    display: block;
  }
  .l-header #g-nav-list .menu ul .megamenu ul li a {
    padding: 5px 10px;
    font-size: 1.7rem;
  }
  .l-header #g-nav-list .menu ul .megamenu ul li a .img {
    display: none;
  }
  .l-header #g-nav-list .menu ul {
    /*ul {
    		position: relative;
    		background: #fff;
    		top: auto;
    		padding: 0 0 0 10px;
    		width: auto;
    		display: block;

    		li {
    			width: 100%;
    			padding: 0;
    			margin-bottom: 0;
    			border-bottom: none;

    			a {
    				width: 100%;
    				padding: 10px;
    				font-size: 1.6rem;

    			}

    			&:last-child {
    				display: block;
    				width: 100%;
    				padding: 0;
    				margin-bottom: 10px;

    				a {
    					width: 100%;
    					padding: 10px;

    				}
    			}
    		}
    	}

    	&:last-child {
    		ul {
    			top: 30px;
    			left: auto;
    			right: -20px;
    			width: 300px;
    		}
    	}*/
  }
  .l-header {
    /*========= ボタンのためのCSS ===============*/
  }
  .l-header .openbtn {
    display: block;
    position: absolute;
    z-index: 9999;
    /*ボタンを最前面に*/
    top: 9px;
    right: 0;
    cursor: pointer;
    width: 82px;
    height: 72px;
    background: #3B3835;
  }
  .l-header {
    /*×に変化*/
  }
  .l-header .openbtn span {
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    position: absolute;
    left: 21px;
    right: 21px;
    height: 2px;
    width: 40px;
    background: #fff;
  }
  .l-header .openbtn span:nth-of-type(1) {
    top: 27px;
  }
  .l-header .openbtn span:nth-of-type(2) {
    top: 45px;
  }
  .l-header .openbtn.is-active span:nth-of-type(1) {
    top: 27px;
    -webkit-transform: translateY(7px) rotate(-225deg);
            transform: translateY(7px) rotate(-225deg);
  }
  .l-header .openbtn.is-active span:nth-of-type(2) {
    top: 47px;
    -webkit-transform: translateY(-14px) rotate(45deg);
            transform: translateY(-14px) rotate(45deg);
  }
}
@media screen and (max-width: 480px) {
  .l-header {
    height: 60px;
  }
  .l-header__inner {
    padding: 5px 0;
  }
  .l-header__logo {
    width: 50%;
    max-width: 150px;
  }
  .l-header {
    /*========= ボタンのためのCSS ===============*/
  }
  .l-header .openbtn {
    width: 61px;
    height: 51px;
  }
  .l-header {
    /*×に変化*/
  }
  .l-header .openbtn span {
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    position: absolute;
    left: 10px;
    right: 10px;
    height: 2px;
    width: 41px;
    background: #fff;
  }
  .l-header .openbtn span:nth-of-type(1) {
    top: 18px;
  }
  .l-header .openbtn span:nth-of-type(2) {
    top: 33px;
  }
  .l-header .openbtn.is-active span:nth-of-type(1) {
    top: 18px;
    -webkit-transform: translateY(7px) rotate(-225deg);
            transform: translateY(7px) rotate(-225deg);
  }
  .l-header .openbtn.is-active span:nth-of-type(2) {
    top: 39px;
    -webkit-transform: translateY(-14px) rotate(45deg);
            transform: translateY(-14px) rotate(45deg);
  }
}
.hover-button {
  position: relative;
  width: 100px;
  height: 20px;
}
.hover-button span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  white-space: nowrap;
}
.hover-button .text-default {
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  opacity: 1;
}
.hover-button .text-hover {
  opacity: 0;
}
.hover-button:hover .text-default {
  opacity: 0;
}
.hover-button:hover .text-hover {
  top: 0%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  opacity: 1;
}

.hover-button02 {
  position: relative;
  width: 100%;
  height: 20px;
}
.hover-button02 span {
  display: block;
  position: absolute;
  top: 50%;
  left: 10px;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  white-space: nowrap;
}
.hover-button02 span.sp {
  display: none;
}
.hover-button02 .text-default {
  top: 50%;
  left: 10px;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  opacity: 1;
}
.hover-button02 .text-hover {
  opacity: 0;
}
.hover-button02:hover .text-default {
  opacity: 0;
  top: 20%;
  left: 10px;
}
.hover-button02:hover .text-hover {
  top: 20%;
  left: 10px;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  opacity: 1;
}

@media screen and (max-width: 1040px) {
  .hover-button {
    position: relative;
    width: auto;
    height: auto;
  }
  .hover-button span {
    position: relative;
    top: auto;
    left: auto;
    -webkit-transform: none;
            transform: none;
  }
  .hover-button .text-default {
    display: none;
  }
  .hover-button .text-hover {
    top: auto;
    opacity: 1;
  }
  .hover-button:hover .text-default {
    opacity: 0;
  }
  .hover-button:hover .text-hover {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
  .hover-button02 {
    position: relative;
    width: auto;
    height: auto;
  }
  .hover-button02 span {
    position: relative;
    top: auto;
    -webkit-transform: none;
            transform: none;
  }
  .hover-button02 span.sp {
    display: inline-block;
    position: relative;
    top: auto;
    left: 0;
  }
  .hover-button02 .text-default {
    display: none;
  }
  .hover-button02 .text-hover {
    top: auto;
    opacity: 1;
  }
  .hover-button02:hover .text-default {
    opacity: 0;
  }
  .hover-button02:hover .text-hover {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
  }
}
/*----------------------------------------------------------------------------------------
footer.scss
----------------------------------------------------------------------------------------*/
.l-footer {
  position: relative;
  background: #F7F7F7;
  text-align: center;
  z-index: 9;
  /*width: 100%;
  max-width: 100%;*/
}
.l-footer .bg_04 {
  position: absolute;
  top: -60px;
  height: 152px;
  width: 100%;
  background-image: url(../images/lower/bg_02.png);
  background-repeat: repeat-x;
  display: none;
}
.l-footer__bg {
  position: relative;
  background: #000;
  border-radius: 40px 40px 0 0;
  padding: 50px 0 1px;
  margin-top: -50px;
  z-index: 2;
}
.l-footer__flex {
  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;
}
.l-footer__flex-box {
  text-align: left;
  width: auto;
  padding: 10px 1.5em 0;
  margin-bottom: 60px;
}
.l-footer__flex-box:nth-of-type(3), .l-footer__flex-box:last-child {
  border-left: 1px solid rgba(112, 112, 112, 0.5);
}
.l-footer__flex-box ul li {
  color: #fff;
  font-size: 1.4rem;
  line-height: 2;
  font-weight: 400;
  padding-left: 1em;
}
.l-footer__flex-box ul li:first-child {
  font-size: 1.5rem;
  font-weight: 500;
  padding-left: 0;
  margin-bottom: 10px;
}
.l-footer__flex-box ul li:last-child {
  margin-bottom: 20px;
}
.l-footer__flex-box ul li img {
  vertical-align: text-top;
  width: 21px;
}
.l-footer__flex-box ul.sns {
  padding: 5px 0;
  border-bottom: 1px solid rgba(112, 112, 112, 0.5);
}
.l-footer__flex-box ul.sns li {
  font-size: 1.4rem;
  line-height: 2;
  font-weight: 400;
  padding-left: 0;
  margin: 5px 0;
}
.l-footer__name {
  width: 90%;
  max-width: 1040px;
  margin: 20px auto 20px;
}
.l-footer__add {
  background: #fff;
  padding: 20px 0 10px;
}
.l-footer__add-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 98%;
  margin: 0 auto 0 2%;
}
.l-footer__add-logo {
  width: 210px;
  margin-right: 40px;
}
.l-footer__add-address {
  text-align: left;
  font-size: 1.5rem;
  font-weight: 400;
}
.l-footer__add-flex02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 95%;
  margin: 0 2% 0 auto;
}
.l-footer__add-flex02 a {
  font-size: 1.4rem;
  color: #3B3835;
  padding: 0 1em;
  border-left: 1px solid #3B3835;
  border-right: 1px solid #3B3835;
}
.l-footer__add-flex02 p {
  font-size: 1.4rem;
  color: #9F9F9F;
  margin-left: 2%;
}
.l-footer .bdr_line {
  height: 9px;
  width: 100%;
  background: -webkit-gradient(linear, left top, right top, color-stop(50%, #172147), color-stop(50%, #d40014));
  background: linear-gradient(to right, #172147 50%, #d40014 50%);
}

.totop {
  position: fixed;
  bottom: 10%;
  z-index: 99;
  right: 1%;
  width: 20%;
  max-width: 100px;
  display: none;
}
.totop.is-show {
  display: block;
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
  -webkit-transform: scale(0.7);
          transform: scale(0.7);
}
.totop.is-show:hover {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
  -webkit-transform: scale(1);
          transform: scale(1);
}

body.top .l-footer .bg_04 {
  display: block;
  background-image: none;
  background: #ddd;
}

body.strength .l-footer .bg_04,
body.business .l-footer .bg_04,
body.employ .l-footer .bg_04,
body.support .l-footer .bg_04,
body.program .l-footer .bg_04,
body.guidance .l-footer .bg_04,
body.system .l-footer .bg_04,
body.merit .l-footer .bg_04,
body.flow .l-footer .bg_04 {
  display: block;
}

@media screen and (max-width: 768px) {
  .l-footer__flex-box {
    width: 50%;
    padding: 10px 1.5em 0;
    margin-bottom: 30px;
    /*&:nth-of-type(3) {
    	width: 50%;
    }

    &:last-child {
    	width: 50%;
    }*/
  }
}
@media screen and (max-width: 480px) {
  .l-footer__flex-box {
    width: 90%;
    padding: 10px 1.5em 0;
    margin: 0 auto;
    /*&:nth-of-type(3) {
    	width: 90%;
    }

    &:last-child {
    	width: 90%;
    	border-left: none;
    	border-top: 1px solid #707070;
    }*/
  }
  .l-footer__flex-box:nth-of-type(3), .l-footer__flex-box:last-child {
    border-left: none;
    border-top: 1px solid rgba(112, 112, 112, 0.5);
    padding: 20px 0;
  }
  .l-footer__add-flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 0 auto 0 5%;
  }
  .l-footer__add-logo {
    width: 180px;
    margin-right: 20px;
  }
  .l-footer__add-address {
    margin: 10px 0;
  }
  .l-footer__add-flex02 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 20px auto 0;
  }
  .l-footer__add-flex02 p {
    margin: 10px auto 0;
  }
}
.hover-button03 {
  position: relative;
  width: 100%;
  height: 20px;
}
.hover-button03 span {
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  white-space: nowrap;
}
.hover-button03 .text-default {
  top: 50%;
  left: 0;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  opacity: 1;
}
.hover-button03 .text-hover {
  opacity: 0;
}
.hover-button03:hover .text-default {
  opacity: 0;
  top: 20%;
  left: 0;
}
.hover-button03:hover .text-hover {
  top: 20%;
  left: 0;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  opacity: 1;
}

.underline-ltr {
  position: relative;
  display: inline-block;
  text-decoration: none;
}

.underline-ltr::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  /* 初期は幅0 */
  height: 1px;
  background: currentColor;
  -webkit-transition: width 0.25s ease;
  transition: width 0.25s ease;
}

/* hover：左から右へ伸びる */
.underline-ltr:hover::after,
.underline-ltr:focus-visible::after {
  width: 100%;
}

/* hoverアウト：左端が右へ移動して消える */
.underline-ltr:not(:hover)::after {
  left: 100%;
  width: 0;
  -webkit-transition: left 0.25s ease, width 0.25s ease;
  transition: left 0.25s ease, width 0.25s ease;
}

/*----------------------------------------------------------------------------------------
container.scss
----------------------------------------------------------------------------------------*/
.l-inner {
  position: relative;
  width: 100%;
  max-width: 1920px;
  margin: 0 auto;
}

.l-inner02 {
  position: relative;
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
}

.l-inner03 {
  position: relative;
  width: 96%;
  max-width: 1160px;
  margin: 0 auto;
}

.l-inner04 {
  position: relative;
  width: 96%;
  max-width: 780px;
  margin: 0 0 0 auto;
}

.l-inner05 {
  position: relative;
  width: 96%;
  max-width: 780px;
  margin: 0 auto 0 0;
}

.l-inner06 {
  position: relative;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto 0;
}

.l-inner07 {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
}

@media screen and (max-width: 480px) {
  .l-inner {
    position: relative;
    width: 100%;
    margin: 0 auto;
  }
  .l-inner02 {
    position: relative;
    width: 96%;
    margin: 0 auto;
  }
  .l-inner03 {
    position: relative;
    width: 96%;
    margin: 0 auto;
  }
}
/*----------------------------------------------------------------------------------------
project.scss
----------------------------------------------------------------------------------------*/
main {
  position: relative;
}
main.low_bg {
  background: #f7f7f7;
  margin-bottom: 50px;
}

.p-low__mv {
  position: relative;
  background-image: url(../images/lower/bg.png);
  background-repeat: repeat-x;
  background-size: auto 100%;
  max-height: 220px;
}
.p-low__mv-box {
  position: relative;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  padding-top: 90px;
}
.p-low__mv-txt {
  position: relative;
  background: rgba(35, 32, 30, 0.75);
  width: 90%;
  margin: 2% auto 0 0;
  padding: 3% 2.5% 1% 2.5%;
  border-radius: 0 140px 140px 0;
  max-height: 100px;
}
.p-low__mv-txt .l-inner03 {
  margin: 0 0 0 auto;
}
.p-low__mv-txt h1 {
  font-size: 2rem;
  font-size: clamp(1.4rem, 0.893vw + 0.714rem, 2rem);
  color: #fff;
}
.p-low__mv-txt h1 img {
  margin-right: 1em;
}
.p-low__mv-txt h1.title_company img {
  width: 24.3269230769%;
  max-width: 253px;
}
.p-low__mv-txt h1.title_privacy img {
  width: 37.4038461538%;
  max-width: 389px;
}
.p-low__mv-txt h1.title_qanda img {
  width: 13.75%;
  max-width: 143px;
}
.p-low__mv-txt h1.title_news img {
  width: 32.5%;
  max-width: 338px;
}
.p-low__mv-txt h1.title_contact img {
  width: 22.6923076923%;
  max-width: 236px;
}
.p-low__mv-icon {
  position: absolute;
  width: 18%;
  max-width: 250px;
  right: 6%;
  bottom: 0;
}
.p-low__mv-icon-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 2% auto 4%;
  /*&.flex02 {
  	justify-content: space-between;
  }*/
}
.p-low__mv-icon .on_img_01 {
  width: 20.2%;
  margin: 0 auto;
}
.p-low__mv-icon .on_img_02 {
  width: 17.2%;
  margin: 0 auto;
}
.p-low__mv-icon .on_img_03 {
  width: 16.5%;
  margin: 0 auto;
}
.p-low__mv-icon .on_img_04 {
  width: 18.76%;
  margin: 0 8%;
}
.p-low__mv-icon .on_img_05 {
  width: 20.9%;
  margin: 0 8%;
}

.p-low__mv-02 {
  position: relative;
  background-repeat: no-repeat;
  background-size: cover;
  max-height: 240px;
}
.p-low__mv-02.bg_strength {
  background-image: url(../images/strength/main_visual.png);
}
.p-low__mv-02.bg_business {
  background-image: url(../images/business/mv_01.png);
}
.p-low__mv-02.bg_guidance {
  background-image: url(../images/guidance/mv_01.png);
}
.p-low__mv-02-box {
  position: relative;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  padding-top: 90px;
}
.p-low__mv-02-txt {
  position: relative;
  background: #f7f7f7;
  width: 47%;
  margin: 2% auto 0 0;
  padding: 2% 2.5% 1% 13%;
  border-radius: 0 100px 0 0;
  max-height: 120px;
  z-index: 2;
}
.p-low__mv-02-txt h1 {
  font-size: 2rem;
  font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);
  line-height: 2;
}
.p-low__mv-02-txt h1.title_strength img {
  width: 54.2%;
  max-width: 240px;
}
.p-low__mv-02-txt h1.title_business img {
  width: 49.8%;
  max-width: 223px;
}
.p-low__mv-02-txt h1.title_guidance img {
  width: 57.2%;
  max-width: 257px;
}
.p-low__mv-02-icon {
  position: absolute;
  width: 55%;
  right: 0;
  bottom: 0;
  z-index: 1;
}
.p-low__mv-02-icon dotlottie-player {
  max-width: 1000px;
}
.p-low__mv-02-icon {
  /*&-flex{
  	display: flex;
  	justify-content: space-between;
  }

  .on_img_01 {
  	width: calc((43/312) * 100%);
  }

  .on_img_02 {
  	width: calc((51/312) * 100%);
  }

  .on_img_03 {
  	width: calc((51/312) * 100%);
  }

  .on_img_04 {
  	width: calc((42/312) * 100%);
  }

  .on_img_05 {
  	width: calc((52/312) * 100%);
  }*/
}

.p-low__mv-03 {
  position: relative;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: bottom;
  max-height: 200px;
}
.p-low__mv-03.bg_employ {
  background-image: url(../images/business/mv_02.png);
}
.p-low__mv-03.bg_support {
  background-image: url(../images/business/mv_03.png);
}
.p-low__mv-03.bg_program {
  background-image: url(../images/business/mv_04.png);
}
.p-low__mv-03.bg_system {
  background-image: url(../images/guidance/mv_02.png);
}
.p-low__mv-03.bg_merit {
  background-image: url(../images/guidance/mv_03.png);
}
.p-low__mv-03.bg_flow {
  background-image: url(../images/guidance/mv_04.png);
}
.p-low__mv-03-box {
  position: relative;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  padding-top: 0px;
}
.p-low__mv-03-txt {
  position: relative;
  background: #f7f7f7;
  width: 35%;
  margin: 0 auto 4% 0;
  padding: 105px 2.5% 1% 13%;
  border-radius: 0 0 64px 0;
  max-height: 150px;
}
.p-low__mv-03-txt h1 {
  /*font-size: 2rem;
  font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);
  line-height: 2;*/
}
.p-low__mv-03-txt h1.title_business img {
  width: 50%;
  max-width: 138px;
}
.p-low__mv-03-txt h1.title_guidance img {
  width: 56%;
  max-width: 154px;
}
.p-low__mv-03-icon {
  position: absolute;
  position: absolute;
  width: 55%;
  max-height: 150px;
  right: 0;
  bottom: -10%;
  z-index: 1;
}
.p-low__mv-03-icon dotlottie-player {
  max-width: 1000px;
}
.p-low__mv-03-icon {
  /*&-flex{
  	display: flex;
  	justify-content: space-between;
  }

  .on_img_01 {
  	width: calc((43/312) * 100%);
  }

  .on_img_02 {
  	width: calc((51/312) * 100%);
  }

  .on_img_03 {
  	width: calc((51/312) * 100%);
  }

  .on_img_04 {
  	width: calc((42/312) * 100%);
  }

  .on_img_05 {
  	width: calc((52/312) * 100%);
  }*/
}

@media screen and (min-width: 1441px) {
  .p-low__mv {
    height: 276px;
  }
  .p-low__mv .l-inner03 {
    margin: 0 auto;
  }
  .p-low__mv-txt {
    max-width: calc((100% - 1440px) / 2 + 90%);
    margin-top: 28.5px;
    padding: 42.75px 2.5% 14.25px 13%;
    height: 100px;
  }
  .p-low__mv-02 {
    height: 240px;
  }
  .p-low__mv-02-txt {
    max-width: calc((100% - 1440px) / 2 + 47%);
    margin-top: 28.5px;
    padding: 28.5px 2.5% 14.25px 13%;
    height: 120px;
  }
  .p-low__mv-02-icon {
    bottom: -10%;
    z-index: 1;
  }
  .p-low__mv-03-txt {
    max-width: calc((100% - 1440px) / 2 + 35%);
    margin: 0 auto 57px 0;
    padding: 105px 2.5% 14.188px 13%;
  }
  .p-low__mv-03-icon {
    bottom: -13%;
    z-index: 1;
  }
}
@media screen and (max-width: 768px) {
  .p-low__mv-txt {
    padding: 5.6% 2.5% 2% 2%;
  }
  .p-low__mv-icon {
    width: 25%;
    right: 1%;
  }
  .p-low__mv-02-txt {
    width: 50%;
    padding: 2% 2.5% 0.7% 5%;
  }
  .p-low__mv-02 {
    /*&-icon {
    	right: 5%;
    }*/
  }
  .p-low__mv-03-txt {
    width: 40%;
    margin: 0 auto 4% 0;
    padding: 100px 2.5% 1.3% 5%;
  }
  .p-low__mv-03 {
    /*&-icon {
    	right: 5%;
    }*/
  }
}
@media screen and (max-width: 480px) {
  .p-low__mv-box {
    padding-top: 70px;
  }
  .p-low__mv-txt {
    padding: 3% 2.5% 2% 0;
  }
  .p-low__mv-txt h1 {
    height: 35px;
  }
  .p-low__mv-txt h1 img {
    height: 20px;
    width: auto !important;
  }
  .p-low__mv-icon {
    width: 30%;
  }
  .p-low__mv-02-box {
    padding-top: 70px;
  }
  .p-low__mv-02-txt {
    border-radius: 0 80px 0 0;
    width: 60%;
    padding: 1.2% 2.5% 0.6% 5%;
  }
  .p-low__mv-02-txt h1 {
    line-height: 1.4;
  }
  .p-low__mv-02-txt h1 img {
    height: 18px;
    width: auto !important;
  }
  .p-low__mv-02 {
    /*&-icon {
    	width: 30%;	
    }*/
  }
  .p-low__mv-03-txt {
    border-radius: 0 0 32px 0;
    width: 50%;
    margin: 0 auto 4% 0;
    padding: 70px 2.5% 1.3% 5%;
  }
  .p-low__mv-03-txt h1 img {
    height: 18px;
    width: auto !important;
  }
  .p-low__mv-03 {
    /*&-icon {
    	width: 30%;	
    }*/
  }
}
body.strength .icon_area,
body.employ .icon_area,
body.program .icon_area,
body.support .icon_area,
body.guidance .icon_area,
body.flow .icon_area,
body.merit .icon_area,
body.system .icon_area,
body.news .icon_area,
body.qanda .icon_area,
body.company .icon_area,
body.contact .icon_area {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  z-index: 1;
}
body.strength .left-icon,
body.employ .left-icon,
body.program .left-icon,
body.support .left-icon,
body.guidance .left-icon,
body.flow .left-icon,
body.merit .left-icon,
body.system .left-icon,
body.news .left-icon,
body.qanda .left-icon,
body.company .left-icon,
body.contact .left-icon {
  position: absolute;
  left: 0;
  top: 38%;
  width: 181px;
  z-index: 3;
  opacity: 0.5;
}
body.strength .left-icon .on_left_01,
body.employ .left-icon .on_left_01,
body.program .left-icon .on_left_01,
body.support .left-icon .on_left_01,
body.guidance .left-icon .on_left_01,
body.flow .left-icon .on_left_01,
body.merit .left-icon .on_left_01,
body.system .left-icon .on_left_01,
body.news .left-icon .on_left_01,
body.qanda .left-icon .on_left_01,
body.company .left-icon .on_left_01,
body.contact .left-icon .on_left_01 {
  position: relative;
  left: 10%;
}
body.strength .left-icon .on_left_02,
body.employ .left-icon .on_left_02,
body.program .left-icon .on_left_02,
body.support .left-icon .on_left_02,
body.guidance .left-icon .on_left_02,
body.flow .left-icon .on_left_02,
body.merit .left-icon .on_left_02,
body.system .left-icon .on_left_02,
body.news .left-icon .on_left_02,
body.qanda .left-icon .on_left_02,
body.company .left-icon .on_left_02,
body.contact .left-icon .on_left_02 {
  position: relative;
  left: 60%;
}
body.strength .left-icon .on_left_03,
body.employ .left-icon .on_left_03,
body.program .left-icon .on_left_03,
body.support .left-icon .on_left_03,
body.guidance .left-icon .on_left_03,
body.flow .left-icon .on_left_03,
body.merit .left-icon .on_left_03,
body.system .left-icon .on_left_03,
body.news .left-icon .on_left_03,
body.qanda .left-icon .on_left_03,
body.company .left-icon .on_left_03,
body.contact .left-icon .on_left_03 {
  position: relative;
  left: 10%;
}
body.strength .right-icon,
body.employ .right-icon,
body.program .right-icon,
body.support .right-icon,
body.guidance .right-icon,
body.flow .right-icon,
body.merit .right-icon,
body.system .right-icon,
body.news .right-icon,
body.qanda .right-icon,
body.company .right-icon,
body.contact .right-icon {
  position: absolute;
  /*right: 5%;*/
  right: 0;
  top: 65%;
  width: 180px;
  z-index: 3;
  opacity: 0.5;
}
body.strength .right-icon .on_right_01,
body.employ .right-icon .on_right_01,
body.program .right-icon .on_right_01,
body.support .right-icon .on_right_01,
body.guidance .right-icon .on_right_01,
body.flow .right-icon .on_right_01,
body.merit .right-icon .on_right_01,
body.system .right-icon .on_right_01,
body.news .right-icon .on_right_01,
body.qanda .right-icon .on_right_01,
body.company .right-icon .on_right_01,
body.contact .right-icon .on_right_01 {
  position: relative;
  left: 60%;
  top: 0;
}
body.strength .right-icon .on_right_02,
body.employ .right-icon .on_right_02,
body.program .right-icon .on_right_02,
body.support .right-icon .on_right_02,
body.guidance .right-icon .on_right_02,
body.flow .right-icon .on_right_02,
body.merit .right-icon .on_right_02,
body.system .right-icon .on_right_02,
body.news .right-icon .on_right_02,
body.qanda .right-icon .on_right_02,
body.company .right-icon .on_right_02,
body.contact .right-icon .on_right_02 {
  position: relative;
  left: 0;
}
body.strength .right-icon .on_right_03,
body.employ .right-icon .on_right_03,
body.program .right-icon .on_right_03,
body.support .right-icon .on_right_03,
body.guidance .right-icon .on_right_03,
body.flow .right-icon .on_right_03,
body.merit .right-icon .on_right_03,
body.system .right-icon .on_right_03,
body.news .right-icon .on_right_03,
body.qanda .right-icon .on_right_03,
body.company .right-icon .on_right_03,
body.contact .right-icon .on_right_03 {
  position: relative;
  left: 50%;
}

@media screen and (max-width: 768px) {
  body.strength .left-icon,
  body.employ .left-icon,
  body.program .left-icon,
  body.support .left-icon,
  body.guidance .left-icon,
  body.flow .left-icon,
  body.merit .left-icon,
  body.system .left-icon,
  body.news .left-icon,
  body.qanda .left-icon,
  body.company .left-icon,
  body.contact .left-icon {
    top: 50%;
  }
}
@media screen and (max-width: 480px) {
  body.strength .left-icon,
  body.strength .right-icon,
  body.employ .left-icon,
  body.employ .right-icon,
  body.program .left-icon,
  body.program .right-icon,
  body.support .left-icon,
  body.support .right-icon,
  body.guidance .left-icon,
  body.guidance .right-icon,
  body.flow .left-icon,
  body.flow .right-icon,
  body.merit .left-icon,
  body.merit .right-icon,
  body.system .left-icon,
  body.system .right-icon,
  body.news .left-icon,
  body.news .right-icon,
  body.qanda .left-icon,
  body.qanda .right-icon,
  body.company .left-icon,
  body.company .right-icon,
  body.contact .left-icon,
  body.contact .right-icon {
    display: none;
  }
}
/*----------------------------------------------------------------------------------------
top.scss
----------------------------------------------------------------------------------------*/
.p-top {
  position: relative;
}
.p-top__mv {
  position: relative;
  max-height: 1000px;
  padding-top: 90px;
}
.p-top__mv .lottie-container {
  position: relative;
  width: 100%;
  height: 100%;
  max-height: 910px;
}
.p-top__mv dotlottie-player {
  position: relative;
  width: auto;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
.p-top__mv-box {
  width: 35%;
  max-width: 480px;
  background: #fff;
  position: absolute;
  top: 90px;
  bottom: 0;
  height: 100%;
  height: calc(100% - 90px);
}
.p-top__mv-box-posi {
  position: absolute;
  top: auto;
  bottom: 0;
}
.p-top__mv-txt {
  width: 80%;
  text-align: center;
  padding-top: 0;
  margin: auto;
  position: relative;
  top: 50%;
  left: 40%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.p-top__mv-txt p {
  text-align: left;
  font-size: 3.2rem;
  font-size: clamp(2rem, 1.786vw + 0.629rem, 3.2rem);
  font-weight: 700;
  border-bottom: 1px solid #707070;
  line-height: 1.5;
  padding-bottom: 4%;
  margin-bottom: 10%;
}
.p-top__mv-txt img {
  width: 90%;
  max-width: 342px;
}
.p-top__mv-txt02 {
  width: 100%;
  background: #3B3835;
  padding: 10% 10%;
  margin: 0 auto;
}
.p-top__mv-txt02 p {
  font-size: 2rem;
  font-size: clamp(1.5rem, 0.744vw + 0.929rem, 2rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.8;
}
.p-top__slide {
  background: #3B3835;
  background-image: url(../images/top/bg_01.png);
  background-repeat: repeat-x;
  background-size: auto 300px;
  padding: 180px 0 20px;
  text-align: center;
  overflow-x: hidden;
}
.p-top__slide li {
  padding: 10px;
}
.p-top__slide li img {
  width: 88%;
}
.p-top__slide img.txt {
  margin: 20px auto;
  max-width: 254px;
}
.p-top__slide02 {
  margin: 50px auto 80px;
  overflow-x: hidden;
}
.p-top__slide02 li {
  padding: 0 100px;
}
.p-top__leave {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, #ffffff), color-stop(60%, #f7f7f7));
  background: linear-gradient(180deg, #ffffff 60%, #f7f7f7 60%);
  margin: 0 auto;
  padding: 100px 0 60px;
  border-radius: 0 0 160px 0;
}
.p-top__leave-bg {
  background-image: url(../images/top/bg_02.png);
  background-position: 35% 55%;
  background-repeat: no-repeat;
  background-size: 114% auto;
}
.p-top__leave .on_img_01 {
  position: absolute;
  left: 0;
  top: -8%;
  width: 24%;
}
.p-top__leave h2 {
  font-size: 4.8rem;
  font-size: clamp(3.2rem, 2.381vw + 1.371rem, 4.8rem);
  line-height: 1.3958333333;
  font-weight: 700;
  width: 88%;
  margin: 0 auto;
}
.p-top__leave img.mascot01 {
  display: block;
  width: 100px;
  margin: 40px auto 0 20%;
}
.p-top__leave-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 88%;
  margin: 40px auto;
}
.p-top__leave-txt {
  position: relative;
  width: 60%;
  margin-bottom: 60px;
}
.p-top__leave-txt p {
  font-size: 1.8rem;
  font-size: clamp(1.6rem, 0.298vw + 1.371rem, 1.8rem);
  line-height: 1.8;
  font-weight: 700;
}
.p-top__leave-img {
  position: relative;
  width: 50%;
  margin-left: 0;
  margin-right: 5%;
  margin-top: -60px;
}
.p-top__leave-img-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.p-top__leave-img-flex img {
  max-width: -webkit-max-content;
  max-width: -moz-max-content;
  max-width: max-content;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.p-top__leave-img-flex img:nth-child(1) {
  margin: 10px 0;
}
.p-top__leave-img-flex div {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
}
.p-top__leave-img-flex div.img_01 {
  margin: 10px 0;
}
.p-top__leave-img-flex div.img_01 img {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
}
.p-top__leave-img-flex div.img_02 {
  width: 40%;
}
.p-top__leave-img-flex div.img_02 img {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
}
.p-top__leave-img-flex div.img_03 {
  width: 40%;
  margin: 10px 0 0 5%;
}
.p-top__leave-img-flex div.img_03 img {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
}
.p-top__leave-img-flex div.img_04 {
  width: 40%;
  margin: 10px 10% 0 auto;
}
.p-top__leave-img-flex div.img_04 img {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
}
.p-top__leave-img-flex:hover div img {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.p-top__merit {
  position: relative;
  max-width: 100%;
  overflow-x: hidden;
  margin: 50px auto 0;
}
.p-top__merit-block {
  background: #fff;
  -webkit-box-shadow: 0 6px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 6px 10px rgba(0, 0, 0, 0.15);
  width: 100%;
  border-radius: 0 224px 224px 0;
  padding: 40px;
  margin: 20px auto 20px -14%;
  width: 100%;
  min-width: 900px;
}
.p-top__merit-block.block02 {
  border-radius: 224px 0 0 224px;
  margin: 20px -14% 20px auto;
}
.p-top__merit-flex {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.p-top__merit-flex-img {
  position: relative;
  width: 33%;
  border-radius: 16px;
  max-width: 280px;
}
.p-top__merit-flex-img img {
  width: 100%;
}
.p-top__merit-flex-img .on_img_07 {
  position: absolute;
  top: 0;
  left: 0;
}
.p-top__merit-flex-img .base {
  position: relative;
  width: 100%;
  border-radius: 16px;
  max-width: 280px;
  overflow: hidden;
}
.p-top__merit-flex-img img.big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
  overflow: hidden;
}
.p-top__merit-flex-img:hover img.big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.p-top__merit-flex-txt {
  width: 55%;
  padding: 0 3%;
  margin-bottom: 2%;
}
.p-top__merit-flex-txt h3 {
  font-size: 3rem;
  font-size: clamp(2rem, 1.488vw + 0.857rem, 3rem);
  font-weight: 700;
  line-height: 1.6;
  margin-bottom: 10px;
}
.p-top__merit-flex-txt h3 img {
  width: 46px;
}
.p-top__merit-flex-txt p {
  font-size: 1.6rem;
  margin-bottom: 10px;
  line-height: 1.4285714286;
}
.p-top__merit-flex-txt p.bold {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
}
.p-top__merit-txt {
  text-align: center;
  margin: 50px auto 0;
}
.p-top__merit-txt img {
  max-width: 438px;
  width: 90%;
}
.p-top__business {
  position: relative;
  text-align: center;
  height: auto;
  padding-top: 200px;
  margin-top: -200px;
}
.p-top__business__clip {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 100%;
  height: auto;
  clip-path: inset(0);
  z-index: -1;
}
.p-top__business .bg_03 {
  width: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  position: fixed;
  background: #B6B9BC;
  background-size: cover;
}
.p-top__business .bg_03 .on_img_08 {
  position: absolute;
  top: 500px;
  left: 12%;
  width: 21%;
}
.p-top__business .bg_03 .on_img_09 {
  position: absolute;
  top: 350px;
  left: 45%;
  width: 20%;
}
.p-top__business .bg_03 .on_img_10 {
  position: absolute;
  top: 450px;
  right: 5%;
  width: 18%;
}
.p-top__business__title {
  position: relative;
  text-align: center;
  padding: 150px 0 50px;
}
.p-top__business__title h2 {
  color: #fff;
  font-size: 2rem;
  font-size: clamp(1.8rem, 0.298vw + 1.571rem, 2rem);
  line-height: 1.6;
  margin: 0 auto;
  width: 67.6%;
  max-width: 338px;
}
.p-top__business__cnts {
  position: relative;
  height: auto;
  margin: 0 auto;
}
.p-top__business__cnts-sticky {
  position: relative;
  background: #fff;
  /*top: 80px;*/
  width: 100%;
  height: auto;
  padding: 50px 0;
}
.p-top__business__cnts-sticky.bg {
  background: #F7F7F7;
}
.p-top__business__cnts-flex {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.p-top__business__cnts-flex img.big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
}
.p-top__business__cnts-flex:hover img.big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.p-top__business__cnts-num {
  width: 10%;
  margin-top: 100px;
  padding-right: 2%;
}
.p-top__business__cnts-img {
  width: 40%;
  overflow: hidden;
}
.p-top__business__cnts-img img {
  max-width: 424px;
  width: 100%;
}
.p-top__business__cnts-txt {
  width: 50%;
  padding: 5% 5% 3% 5%;
}
.p-top__business__cnts-txt h3 {
  font-size: 3rem;
  font-size: clamp(2rem, 1.488vw + 0.857rem, 3rem);
  font-weight: 700;
  line-height: 1.6;
  margin-bottom: 20px;
}
.p-top__business__cnts-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
}
.p-top__business__cnts-txt a {
  margin: 50px 0;
}
.p-top__business__cnts-txt a .img-btn {
  display: block;
}
.p-top__news {
  position: relative;
  background: -webkit-gradient(linear, left top, left bottom, from(#f7f7f7), to(#fff));
  background: linear-gradient(180deg, #f7f7f7, #fff);
  z-index: 3;
}
.p-top__news img.mascot02 {
  position: absolute;
  top: 50px;
  right: 4%;
  width: 120px;
}
.p-top__news-bg01 {
  position: relative;
  background-image: url(../images/top/bg_03.png);
  background-position: top;
  background-repeat: repeat-x;
  background-size: contain;
  padding-top: 150px;
}
.p-top__news-bg02 {
  position: relative;
  background-image: url(../images/top/bg_05.png);
  background-position: 19% 10%;
  background-repeat: no-repeat;
}
.p-top__news-bg03 {
  position: relative;
  background-image: url(../images/top/bg_04.png);
  background-position: top;
  background-repeat: repeat-x;
  background-size: contain;
  padding: 130px 0 100px;
}
.p-top__news-title {
  position: relative;
  text-align: center;
  margin-bottom: 30px;
}
.p-top__news-title h2 {
  color: #fff;
  font-size: 2rem;
  line-height: 1.6;
  margin: 0 auto;
}
.p-top__news-title h2 img {
  width: 96.8%;
  max-width: 484px;
}
.p-top__news-box {
  background: #fff;
  border-radius: 40px;
  margin: 30px auto;
  padding: 20px;
}
.p-top__news-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-top__news-menu ul {
  width: 144px;
}
.p-top__news-menu ul li {
  background: #3B3835;
  border: 1px solid #3B3835;
  border-radius: 30px;
  margin: 10px 0;
  text-align: center;
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
}
.p-top__news-menu ul li a {
  width: 100%;
  height: 100%;
  padding: 10px;
}
.p-top__news-menu ul li:hover {
  background: #fff;
  color: #3B3835;
}
.p-top__news-menu ul li.active {
  background: #fff;
  color: #3B3835;
}
.p-top__news-list {
  width: calc(100% - 180px);
}
.p-top__news-list-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 30px;
}
.p-top__news-list-box {
  width: 33%;
  text-align: center;
  padding: 0 20px 30px;
  margin: 0 auto;
  border-right: 1px solid #3B3835;
}
.p-top__news-list-box:last-child {
  border-right: none;
}
.p-top__news-list-box a .image {
  width: 100%;
  max-width: 296px;
  margin: 0 auto;
  border-radius: 20px;
  overflow: hidden;
}
.p-top__news-list-box a:hover img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  -webkit-transition: all 0.6s ease;
  transition: all 0.6s ease;
}
.p-top__news-list-box a:hover p.news-txt {
  text-decoration: underline;
}
.p-top__news-list-box p {
  font-size: 1.6rem;
  line-height: 1.7142857143;
  font-weight: 400;
  text-align: left;
}
.p-top__news-list-box p.news-cat {
  text-align: center;
  padding: 0;
  background: #DDDDDD;
  width: 72px;
  font-size: 1.1rem;
  line-height: 2;
  margin: 5px 0 0 auto;
  font-weight: 700;
}
.p-top__news-list-box p.news-date {
  font-weight: 700;
}
.p-top__news-list .news-more {
  margin: 30px 2% 10px auto;
  text-align: right;
}
.p-top__about {
  position: relative;
  z-index: 2;
  margin: 0 auto;
  padding: 100px 0 50px;
  background: #fff;
  border-radius: 0 0 0 160px;
}
.p-top__about-title {
  position: relative;
  text-align: center;
  margin-bottom: 50px;
}
.p-top__about-title h2 {
  color: #3B3835;
  font-size: 2rem;
  line-height: 1.6;
  margin: 0 auto;
}
.p-top__about-title h2 img {
  width: 72.4%;
  max-width: 362px;
}
.p-top__about h3 {
  font-size: 3rem;
  font-size: clamp(2rem, 1.488vw + 0.857rem, 3rem);
  font-weight: 700;
  line-height: 1.6;
}
.p-top__about-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  margin: 20px auto;
}
.p-top__about-txt {
  position: relative;
  width: 50%;
}
.p-top__about-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
}
.p-top__about-txt p.bold {
  font-weight: 700;
  font-size: 2rem;
  margin-bottom: 10px;
}
.p-top__about-txt a {
  margin: 50px 0;
}
.p-top__about-img {
  position: relative;
  width: 50%;
  right: -3%;
}
.p-top__about-img img.big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
}
.p-top__about-img:hover img.big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.p-top__about-on_img {
  position: absolute;
  top: 40%;
  left: -10%;
  right: 40%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-top__service {
  position: relative;
  background: #ddd;
  text-align: center;
  margin-top: -160px;
  z-index: 1;
}
.p-top__service-bg {
  position: relative;
  background-image: url(../images/top/bg_06.png);
  background-position: top center;
  background-size: auto 100%;
  padding-top: 260px;
  padding-bottom: 150px;
  z-index: -1;
}
.p-top__service-title {
  position: relative;
  text-align: center;
  margin-bottom: 80px;
}
.p-top__service-title h2 {
  color: #fff;
  font-size: 2rem;
  line-height: 1.6;
  margin: 0 auto;
}
.p-top__service-title h2 img {
  width: 76.8%;
  max-width: 384px;
}
.p-top__service-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  margin: 50px auto;
}
.p-top__service-flex img.big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
}
.p-top__service-flex:hover img.big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.p-top__service-txt {
  position: relative;
  text-align: left;
  width: 55%;
  padding-left: 5%;
}
.p-top__service-txt h3 {
  color: #fff;
  font-size: 3rem;
  font-size: clamp(2rem, 1.488vw + 0.857rem, 3rem);
  font-weight: 700;
  line-height: 1.6;
  margin-bottom: 20px;
}
.p-top__service-txt p {
  color: #fff;
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
}
.p-top__service-txt a {
  margin: 20px auto;
}
.p-top__service-img {
  position: relative;
  border-radius: 16px;
  width: 45%;
  max-width: 400px;
}
.p-top__service-img .on_img_11 {
  position: absolute;
  top: -5%;
  right: 15%;
  width: 15%;
}
.p-top__service-img .on_img_12 {
  position: absolute;
  top: 8%;
  left: 5%;
  width: 16%;
}
.p-top__service-img .on_img_13 {
  position: absolute;
  top: 12%;
  left: 35%;
  width: 23%;
}
.p-top__link {
  position: relative;
  z-index: 2;
  background: #ddd;
  padding-bottom: 30px;
}
.p-top__link-flex {
  position: relative;
  top: -100px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.p-top__link-flex-box {
  background: #fff;
  border-radius: 40px;
  width: 50%;
  -webkit-box-shadow: 0 6px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 6px 10px rgba(0, 0, 0, 0.15);
  text-align: center;
  padding: 40px 50px 50px;
}
.p-top__link-flex-box .img .big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
}
.p-top__link-flex-box .img:hover .big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.p-top__link-flex-cnts {
  width: 100%;
  max-width: 450px;
  margin: 0 auto;
}
.p-top__link-flex-cnts img {
  margin: 10px auto 10px;
}
.p-top__link-flex-cnts img.tel {
  margin: 0 auto;
}
.p-top__link-flex-cnts p {
  font-size: 1.6rem;
  line-height: 1.5;
  margin: 20px auto;
}
.p-top__link-flex-cnts p.time {
  font-size: 1.4rem;
  margin: 0 auto;
}
.p-top__link-flex-cnts p.fax {
  font-size: 2rem;
  font-weight: 700;
  margin: 0 auto;
}
.p-top__link-flex-cnts a {
  text-align: center;
  margin: 20px auto 0;
}
.p-top__link-flex-cnts a img {
  margin: 0;
}

@media screen and (max-width: 1440px) {
  .p-top__mv-txt {
    top: 0;
    left: 0;
    -webkit-transform: none;
            transform: none;
    margin: auto auto 20%;
  }
}
@media screen and (max-width: 1280px) {
  .p-top__mv-txt {
    top: 0;
    left: 0;
    margin: auto auto 10%;
  }
}
@media screen and (max-width: 768px) {
  .p-top__mv-txt {
    width: 80%;
    text-align: center;
    margin: 10% auto 5%;
  }
  .p-top__mv-txt p {
    padding-bottom: 10px;
    margin-bottom: 20px;
  }
  .p-top__mv-txt02 {
    padding: 8% 7%;
  }
  .p-top__slide {
    background-size: contain;
    padding: 50px 0 20px;
  }
  .p-top__slide li {
    width: 250px;
  }
  .p-top__slide02 {
    margin: 50px auto 50px;
  }
  .p-top__slide02 li img {
    height: 70px;
  }
  .p-top__leave {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #ffffff), color-stop(50%, #f7f7f7));
    background: linear-gradient(180deg, #ffffff 50%, #f7f7f7 50%);
    padding: 100px 0 50px;
  }
  .p-top__leave-bg {
    background-position: 35% 45%;
  }
  .p-top__leave .on_img_01 {
    position: absolute;
    left: 0;
    top: -8%;
    width: 24%;
  }
  .p-top__leave-flex {
    width: 96%;
  }
  .p-top__leave-txt {
    width: 60%;
  }
  .p-top__leave-img {
    width: 38%;
    margin-left: 2%;
    margin-right: 0;
  }
  .p-top__leave-img img:nth-child(2) {
    margin: 10px 0;
  }
  .p-top__leave-img .on_img_03 {
    right: -10%;
  }
  .p-top__leave-img .on_img_04 {
    right: 5%;
  }
  .p-top__merit {
    margin: 20px auto;
    overflow-x: hidden;
  }
  .p-top__merit-block {
    padding: 20px;
    margin: 20px auto 20px 0;
    min-width: 100%;
  }
  .p-top__merit-block.block02 {
    margin: 20px 0 20px auto;
  }
  .p-top__merit-flex-img {
    width: 40%;
  }
  .p-top__merit-flex-img img {
    width: 100%;
  }
  .p-top__merit-flex-txt {
    width: 52%;
    padding: 0 3%;
    margin-bottom: 2%;
  }
  .p-top__merit-txt {
    width: 80%;
    margin: 40px auto 0;
  }
  .p-top__business .bg_03 .on_img_08 {
    top: 500px;
    left: 10%;
  }
  .p-top__business .bg_03 .on_img_09 {
    top: 250px;
    left: 45%;
  }
  .p-top__business .bg_03 .on_img_10 {
    top: 400px;
    right: 5%;
  }
  .p-top__business__title {
    padding: 150px 0 50px;
  }
  .p-top__business__cnts-img {
    width: 40%;
  }
  .p-top__business__cnts-txt {
    width: 50%;
    padding: 5%;
  }
  .p-top__business__cnts-txt p {
    line-height: 1.6;
  }
  .p-top__news-bg01 {
    padding-top: 150px;
  }
  .p-top__news-bg03 {
    padding: 150px 0 80px;
  }
  .p-top__news-flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-top__news-menu {
    width: 100%;
  }
  .p-top__news-menu ul {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    /*justify-content: center;*/
    margin: 0 auto 20px;
  }
  .p-top__news-menu ul li {
    width: 18%;
    margin: 1%;
  }
  .p-top__news-list {
    width: 100%;
  }
  .p-top__news-list-box {
    padding: 0 10px 10px;
  }
  .p-top__news-list-box p.news-txt {
    line-height: 1.6;
  }
  .p-top__news-list .news-more {
    margin: 30px 2% 10px auto;
    text-align: right;
  }
  .p-top__about {
    padding: 100px 0 50px;
  }
  .p-top__about-flex {
    margin: 30px auto;
  }
  .p-top__about-txt {
    position: relative;
    width: 60%;
  }
  .p-top__about-img {
    position: relative;
    width: 45%;
    margin-left: -5%;
    margin-top: 0;
  }
  .p-top__about-on_img {
    width: 100%;
  }
  .p-top__about-on_img img {
    height: 40px;
  }
  .p-top__service {
    margin-top: -250px;
  }
  .p-top__service-bg {
    padding-top: 350px;
    padding-bottom: 80px;
  }
  .p-top__service-flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    margin: 50px auto;
  }
  .p-top__service-txt {
    margin-top: 30px;
  }
  .p-top__service-img {
    position: relative;
    width: 45%;
  }
  .p-top__service-img .on_img_11 {
    top: -5%;
  }
  .p-top__service-img .on_img_12 {
    top: 5%;
  }
  .p-top__service-img .on_img_13 {
    top: 7%;
  }
  .p-top__link-flex-box {
    padding: 20px;
  }
  .p-top__link-flex-cnts {
    width: 100%;
    margin: 0 auto;
  }
  .p-top__link-flex-cnts img {
    margin: 20px auto 0;
  }
  .p-top__link-flex-cnts img.title {
    height: 50px;
  }
  .p-top__link-flex-cnts p {
    margin: 20px auto;
  }
  .p-top__link-flex-cnts a {
    text-align: center;
  }
  .p-top__link-flex-cnts a.mt00 {
    margin-top: 0;
  }
}
@media screen and (max-width: 480px) {
  .p-top__mv {
    padding-top: 60px;
  }
  .p-top__mv .lottie-container {
    position: relative;
    width: 100%;
    height: 40vh;
    overflow: hidden;
  }
  .p-top__mv dotlottie-player {
    position: relative;
    width: 150%;
    height: 150%;
    -o-object-fit: cover;
       object-fit: cover;
    top: 50%;
    left: 35%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  .p-top__mv-box {
    position: relative;
    width: 100%;
    padding-top: 20px;
    height: auto;
    top: 0;
  }
  .p-top__mv-box-posi {
    position: relative;
    bottom: auto;
  }
  .p-top__mv-txt {
    width: 75%;
    text-align: center;
    margin: 0 auto 20px;
  }
  .p-top__mv-txt p {
    text-align: center;
    font-size: 1.8rem;
  }
  .p-top__mv-txt img {
    width: 70%;
  }
  .p-top__mv-txt02 {
    padding: 15px 20px;
  }
  .p-top__mv-txt02 p {
    line-height: 1.6;
  }
  .p-top__slide {
    background-size: auto 60%;
    padding: 50px 0 10px;
  }
  .p-top__slide li {
    padding: 10px;
    width: 150px;
  }
  .p-top__slide img.txt {
    margin: 10px auto;
  }
  .p-top__slide02 {
    margin: 50px auto 50px;
    overflow-x: hidden;
  }
  .p-top__slide02 li {
    padding: 0 50px;
  }
  .p-top__slide02 li img {
    height: 50px;
  }
  .p-top__leave {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(33%, #ffffff), color-stop(33%, #f7f7f7));
    background: linear-gradient(180deg, #ffffff 33%, #f7f7f7 33%);
    border-radius: 0 0 100px 0;
    padding: 80px 0 50px;
  }
  .p-top__leave-bg {
    background-position: 60% 30%;
    background-size: 150% auto;
  }
  .p-top__leave .on_img_01 {
    top: -5%;
    width: 30%;
  }
  .p-top__leave h2 {
    width: 100%;
  }
  .p-top__leave img.mascot01 {
    margin: 20px auto 0;
    width: 60px;
  }
  .p-top__leave-flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 50px auto;
  }
  .p-top__leave-txt {
    width: 100%;
    margin-bottom: 0;
  }
  .p-top__leave-img {
    width: 80%;
    margin: 20px auto;
  }
  .p-top__leave-img img:nth-child(1) {
    width: 70%;
  }
  .p-top__leave-img .on_img_03 {
    right: -10%;
  }
  .p-top__leave-img .on_img_04 {
    right: 5%;
  }
  .p-top__merit-block {
    border-radius: 0 50px 50px 0;
    padding: 20px;
  }
  .p-top__merit-block.block02 {
    border-radius: 50px 0 0 50px;
  }
  .p-top__merit-flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-top__merit-flex-img {
    width: 50%;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    margin: 0 0 0 auto;
  }
  .p-top__merit-flex-img.block02_sp {
    margin: 0 auto 0 0;
  }
  .p-top__merit-flex-txt {
    width: 100%;
    padding: 0 0 20px;
    margin: 0 auto;
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
  }
  .p-top__merit-txt {
    width: 100%;
    margin: 30px auto 0;
  }
  .p-top__business {
    padding-top: 100px;
    margin-top: -100px;
  }
  .p-top__business .bg_03 .on_img_08 {
    top: 500px;
    left: 10%;
  }
  .p-top__business .bg_03 .on_img_09 {
    top: 250px;
    left: 45%;
  }
  .p-top__business .bg_03 .on_img_10 {
    top: 400px;
    right: 5%;
  }
  .p-top__business__title {
    padding: 50px 0 50px;
  }
  .p-top__business__cnts-flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .p-top__business__cnts-num {
    width: 15%;
    margin: 20px 20px 0 0;
  }
  .p-top__business__cnts-img {
    width: 50%;
    margin: 0;
  }
  .p-top__business__cnts-txt {
    width: 100%;
    padding: 20px 20px 50px;
  }
  .p-top__business__cnts-txt p {
    line-height: 1.6;
  }
  .p-top__business__cnts-txt a {
    display: block;
    width: 240px;
    margin: 30px auto;
  }
  .p-top__news img.mascot02 {
    position: absolute;
    top: 80px;
    right: 4%;
    width: 80px;
  }
  .p-top__news-bg01 {
    background-size: auto 10%;
    padding-top: 100px;
  }
  .p-top__news-bg02 {
    background-size: 50%;
    background-position: 15% 3%;
  }
  .p-top__news-bg03 {
    background-size: cover;
    padding: 80px 0 40px;
  }
  .p-top__news-box {
    margin: 50px auto;
  }
  .p-top__news-flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-top__news-menu {
    width: 100%;
  }
  .p-top__news-menu ul {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-top__news-menu ul li {
    width: 48%;
    margin: 1%;
  }
  .p-top__news-list {
    width: 100%;
  }
  .p-top__news-list-flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-top__news-list-box {
    width: 100%;
    padding: 30px 0;
    border-right: none;
    border-bottom: 1px solid #3B3835;
  }
  .p-top__news-list-box:last-child {
    border: none;
  }
  .p-top__news-list-box a .image {
    max-width: 250px;
  }
  .p-top__about {
    padding: 50px 0 50px;
    border-radius: 0 0 0 100px;
  }
  .p-top__about-flex {
    margin: 20px auto;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-top__about-txt {
    width: 100%;
  }
  .p-top__about-txt a {
    display: block;
    width: 240px;
    margin: 30px auto;
  }
  .p-top__about-img {
    position: relative;
    width: 90%;
    margin: 20px auto 20px 8%;
  }
  .p-top__about-on_img {
    width: 100%;
  }
  .p-top__about-on_img img {
    height: 40px;
  }
  .p-top__service {
    margin-top: -150px;
  }
  .p-top__service-bg {
    padding-top: 200px;
    padding-bottom: 100px;
  }
  .p-top__service-title {
    margin-bottom: 30px;
  }
  .p-top__service-flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 20px auto;
  }
  .p-top__service-txt {
    width: 100%;
    margin-top: 0;
    margin-bottom: 20px;
    padding: 10px;
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
  }
  .p-top__service-txt a {
    display: block;
    width: 240px;
    margin: 20px auto;
  }
  .p-top__service-img {
    width: 100%;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .p-top__service-img .on_img_11 {
    top: -5%;
  }
  .p-top__service-img .on_img_12 {
    top: 5%;
  }
  .p-top__service-img .on_img_13 {
    top: 7%;
  }
  .p-top__link {
    padding-bottom: 10px;
  }
  .p-top__link-flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-top__link-flex-box {
    border-radius: 40px;
    padding: 20px;
    width: 100%;
    margin: 20px auto;
  }
  .p-top__link-flex-cnts {
    width: 100%;
    margin: 0 auto;
  }
  .p-top__link-flex-cnts img {
    margin: 20px auto 0;
  }
  .p-top__link-flex-cnts img.title {
    height: 50px;
  }
  .p-top__link-flex-cnts p {
    margin: 20px auto;
  }
}
/*----------------------------------------------------------------------------------------
company.scss
----------------------------------------------------------------------------------------*/
.p-company .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat-x;
  background-position: 50% 0;
}
.p-company h2 {
  font-size: 2rem;
  line-height: 1.8;
  border: 1px solid #9F9F9F;
  background: #fff;
  font-weight: 700;
  border-radius: 8px;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  padding: 12px 5.5%;
}
.p-company h2 span {
  font-size: 1.6rem;
  padding-left: 1em;
  margin-left: 1em;
  border-left: 1px solid #707070;
}
.p-company__profile {
  padding: 40px 0;
  position: relative;
  z-index: 3;
}
.p-company__profile-box {
  background: #fff;
  border-radius: 16px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  padding: 30px 50px 40px;
  margin: 20px auto;
}
.p-company__profile table {
  table-layout: fixed;
  width: 100%;
  line-height: 1.8;
  border-top: 1px solid #5A5957;
  margin: 20px auto;
}
.p-company__profile table th {
  font-size: 1.6rem;
  font-weight: 500;
  color: #3B3835;
  border-bottom: 1px solid #5A5957;
  vertical-align: middle;
  padding: 20px 10px;
  width: 24%;
  /*height: 80px;*/
}
.p-company__profile table td {
  font-size: 1.6rem;
  border-bottom: 1px solid #5A5957;
  vertical-align: middle;
  padding: 20px 10px;
  width: 76%;
}
.p-company__profile-btn {
  width: 80%;
  max-width: 520px;
  margin: 30px auto;
  position: relative;
  z-index: 9;
  /*background: rgba(154, 174, 185, 0.5);*/
  border-radius: 16px;
}
.p-company__profile-btn p.blink {
  position: absolute;
  font-family: "Kalam", cursive;
  font-size: 3rem;
  top: -15px;
  right: -5px;
  color: #000;
  -webkit-transform: rotate(8deg);
          transform: rotate(8deg);
  -webkit-animation: blink 1s ease infinite;
          animation: blink 1s ease infinite;
}
@-webkit-keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.p-company__profile-btn div {
  background: rgba(154, 174, 185, 0.8);
  border-radius: 16px;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1.6rem;
  padding: 20px 30px 20px;
}
.p-company__profile-btn div img {
  width: 33%;
  max-width: 167px;
}
.p-company__profile-btn a.btn {
  border-radius: 16px;
  position: relative;
  font-weight: 700;
  top: 2px;
}
.p-company__profile-btn a.btn div {
  color: #9aaeb9;
  background: #fff;
  padding: 10px 30px;
}
.p-company__location {
  padding: 0 0 40px 0;
  position: relative;
  z-index: 2;
}
.p-company__location-box {
  background: #fff;
  border-radius: 16px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  padding: 30px 50px 40px;
  margin: 20px auto;
}
.p-company__location-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 30px auto 30px;
}
.p-company__location-txt {
  width: 65.4%;
  margin-right: 4.6%;
}
.p-company__location-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
}
.p-company__location-txt p.root {
  font-weight: 400;
}
.p-company__location-txt .bdr {
  border-bottom: 1px solid #9F9F9F;
  margin: 10px 0 20px;
}
.p-company__location-txt h3 {
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 10px;
}
.p-company__location-img {
  width: 22%;
}
.p-company__location-map {
  text-align: center;
  margin: 30px auto;
}
.p-company__location-map a {
  font-size: 1.6rem;
}
.p-company__group {
  padding-bottom: 100px;
  position: relative;
  z-index: 2;
}
.p-company__group-box {
  background: #fff;
  border-radius: 16px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  padding: 30px 50px 40px;
  margin: 20px auto;
}
.p-company__group-flex {
  width: 100%;
  padding: 10px 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: 1px dotted #5A5957;
  min-height: 90px;
}
.p-company__group-logo {
  width: 18%;
  text-align: center;
}
.p-company__group-name {
  width: 66%;
  padding: 0 5%;
}
.p-company__group-name p {
  font-size: 1.6rem;
  font-weight: 700;
}
.p-company__group-link {
  width: 125px;
}

#profile,
#access {
  padding-top: 200px;
  margin-top: -200px;
  position: relative;
  z-index: -1;
}

/*body.company {

	.icon_area {
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		max-width: 1440px;
		margin: 0 auto;
		z-index: 1;
	}

	.right-icon {
		position: relative;
		left: 80%;
		top: 15%;
		width: 20%;
		max-width: 200px;
		height: auto;

		.on_right_01 {
			position: relative;
		}
	}
}*/
@media screen and (max-width: 480px) {
  .p-company h2 {
    padding: 10px;
    text-align: center;
  }
  .p-company h2 span {
    padding-left: 0;
    border-left: none;
  }
  .p-company__profile {
    padding: 40px 0;
  }
  .p-company__profile-box {
    padding: 10px;
  }
  .p-company__profile table th {
    width: 30%;
  }
  .p-company__profile table td {
    width: 70%;
  }
  .p-company__profile-btn {
    margin: 20px auto;
  }
  .p-company__profile-btn div {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    padding: 10px;
  }
  .p-company__profile-btn div img {
    width: 100%;
    margin-bottom: 10px;
  }
  .p-company__profile-btn a.btn {
    font-size: 1.4rem;
  }
  .p-company__profile-btn a.btn div {
    padding: 5px 20px;
  }
  .p-company__location {
    padding: 0 0 40px 0;
  }
  .p-company__location-box {
    padding: 10px;
  }
  .p-company__location-flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-company__location-txt {
    width: 90%;
    margin: 0 auto;
  }
  .p-company__location-img {
    width: 60%;
    text-align: center;
    margin: 20px auto;
  }
  .p-company__location iframe {
    height: 400px;
  }
  .p-company__group {
    padding-bottom: 40px;
  }
  .p-company__group-box {
    padding: 10px;
  }
  .p-company__group-flex {
    padding: 10px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-company__group-logo {
    width: 40%;
    text-align: center;
  }
  .p-company__group-name {
    width: 60%;
    padding: 0 10px;
  }
  .p-company__group-name p {
    font-size: 1.4rem;
  }
  .p-company__group-link {
    width: 100%;
    text-align: right;
  }
  .p-company__group-link img {
    width: 120px;
  }
  /*body.company {
  	.right-icon,
  	.left-icon {
  		display: none;
  	}		
  }*/
}
/*----------------------------------------------------------------------------------------
privacy.scss
----------------------------------------------------------------------------------------*/
.p-privacy {
  padding: 1px 0;
}
.p-privacy h2 {
  font-size: 2rem;
  line-height: 1.5;
  border: 1px solid #9F9F9F;
  font-weight: 700;
  border-radius: 8px;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  padding: 12px 5.5%;
  margin-bottom: 20px;
}
.p-privacy__block {
  margin: 40px auto;
}
.p-privacy__block h3 {
  font-size: 1.8rem;
  color: #3B3835;
  font-weight: 700;
  line-height: 1.8;
}
.p-privacy__block h4 {
  font-size: 1.5rem;
  color: #3B3835;
  font-weight: 700;
  line-height: 1.8;
}
.p-privacy__block p {
  font-size: 1.5rem;
  line-height: 1.5;
  font-weight: 400;
  margin-bottom: 20px;
}
.p-privacy__block p a {
  word-break: break-all;
}

@media screen and (max-width: 480px) {
  .p-privacy h2 {
    padding: 10px;
    text-align: center;
  }
  .p-privacy__block h3 {
    font-size: 1.6rem;
  }
  .p-privacy__block h4 {
    font-size: 1.4rem;
  }
  .p-privacy__block p {
    font-size: 1.4rem;
  }
}
/*----------------------------------------------------------------------------------------
qanda.scss
----------------------------------------------------------------------------------------*/
.p-qanda {
  padding: 40px 0 150px;
}
.p-qanda .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat;
  background-position: 50% 0;
}
.p-qanda__block {
  background: #fff;
  border-radius: 16px;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  padding: 20px 30px 20px;
  margin: 0 auto 20px;
  position: relative;
  z-index: 3;
}
.p-qanda__block dl {
  border-radius: 8px;
}
.p-qanda__block dl dt {
  position: relative;
  background: rgba(154, 174, 185, 0.2);
  padding: 1.8% 50px 1.8% 7%;
}
.p-qanda__block dl dt::after {
  position: absolute;
  display: block;
  content: "+";
  top: 50%;
  font-size: 30px;
  right: 10px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.p-qanda__block dl dt.close::after {
  font-size: 30px;
  content: "－";
}
.p-qanda__block dl dt img {
  position: absolute;
  bottom: 10px;
  left: -3%;
  width: 8%;
}
.p-qanda__block dl dt p {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
}
.p-qanda__block dl dd {
  padding: 20px 0 0;
}
.p-qanda__block dl dd .flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.p-qanda__block dl dd .img {
  width: 6%;
  text-align: center;
}
.p-qanda__block dl dd .img img {
  width: 41%;
}
.p-qanda__block dl dd .txt {
  width: 94%;
  border-left: 1px solid #A5A8AC;
  padding: 0 0 0 2%;
  min-height: 72px;
}
.p-qanda__block dl dd .txt p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.8;
}

body.qanda .icon_area02 {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  z-index: 0;
}
body.qanda .bottom-icon {
  position: absolute;
  left: 5%;
  bottom: 0;
  width: 20%;
  max-width: 100px;
  height: auto;
}
body.qanda .bottom-icon .on_bottom_01 {
  position: relative;
}

@media screen and (max-width: 768px) {
  .p-qanda__block {
    padding: 20px;
  }
}
@media screen and (max-width: 480px) {
  .p-qanda {
    padding-bottom: 120px;
  }
  .p-qanda__block dl dt::after {
    font-size: 2.4rem;
  }
  .p-qanda__block dl dt img {
    bottom: auto;
    top: auto;
  }
  .p-qanda__block dl dt p {
    line-height: 1.6;
  }
  .p-qanda__block dl dd {
    padding: 15px 0 0;
  }
  .p-qanda__block dl dd .img {
    width: 8%;
  }
  .p-qanda__block dl dd .txt {
    width: 92%;
  }
}
/*----------------------------------------------------------------------------------------
contact.scss
----------------------------------------------------------------------------------------*/
.p-contact {
  padding: 40px 0;
}
.p-contact .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat-x;
  background-position: 50% 0;
}
.p-contact__block {
  background: #fff;
  border-radius: 40px;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  padding: 40px 30px;
  margin: 0 auto;
  text-align: center;
  position: relative;
  z-index: 2;
}
.p-contact__block p {
  font-size: 1.6rem;
  line-height: 1.8;
  margin-bottom: 20px;
}
.p-contact__block p.time {
  font-size: 1.6rem;
  margin-bottom: 0;
}
.p-contact__block p.fax {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 0;
}
.p-contact__form {
  background: #fff;
  border-radius: 8px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  padding: 40px 30px 40px;
  margin: 40px auto;
  position: relative;
  z-index: 2;
}
.p-contact__form table {
  table-layout: fixed;
  width: 94%;
  margin: 0 auto;
  font-size: 1.6rem;
}
.p-contact__form table th {
  width: 20%;
  text-align: left;
  padding: 30px 20px;
  vertical-align: top;
  border-bottom: 1px solid #9F9F9F;
}
.p-contact__form table th span {
  background-color: #3B3835;
  color: #fff;
  padding: 5px 20px;
  font-size: 1rem;
  line-height: 1.5;
  float: right;
}
.p-contact__form table td {
  padding: 20px 10px;
  border-bottom: 1px solid #9F9F9F;
}
.p-contact__form table td:nth-of-type(1) {
  width: 55%;
}
.p-contact__form table td:nth-of-type(2) {
  width: 25%;
  vertical-align: middle;
}
.p-contact__form input {
  border: 1px solid #999;
  margin: 5px;
  padding: 10px 5px;
}
.p-contact__form input[type=tel],
.p-contact__form input[type=email] {
  width: 100%;
}
.p-contact__form textarea {
  height: 150px;
  width: 100%;
}
.p-contact__form .form-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  margin: 30px auto;
}
.p-contact__form .form-btn .submit_btn {
  background-color: #000000;
  border: 2px solid #000000;
  border-radius: 50px;
  padding: 10px 30px;
  width: auto;
  max-width: 490px;
  color: #fff;
  font-size: 1.6rem;
  margin: 0 10px;
}
.p-contact__form .policy {
  border-radius: 4px;
  border: 1px solid #9F9F9F;
  padding: 10px 20px;
  height: 200px;
  width: 94%;
  margin: 30px auto;
  overflow-y: scroll;
}
.p-contact__form .policy p {
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 30px;
}
.p-contact__form .policy h3 {
  font-size: 1.6rem;
  line-height: 1.5;
  font-weight: 400;
}

@media screen and (max-width: 768px) {
  .p-contact {
    padding: 40px 0;
  }
  .p-contact__block {
    padding: 30px 30px 20px;
  }
  .p-contact__form {
    padding: 30px 30px 20px;
  }
  .p-contact__form table th {
    display: inline-block;
    width: 100%;
    border: none;
    background-color: #f1f1f1;
  }
  .p-contact__form table td {
    display: inline-block;
    border: none;
  }
  .p-contact__form table td:nth-of-type(1), .p-contact__form table td:nth-of-type(2) {
    width: 100%;
  }
  .p-contact__form input[type=tel],
  .p-contact__form input[type=email] {
    width: 100%;
  }
}
@media screen and (max-width: 480px) {
  .p-contact {
    padding: 20px 0;
  }
  .p-contact__block {
    padding: 20px 20px 20px;
    border-radius: 20px;
  }
  .p-contact__block p {
    text-align: left;
  }
  .p-contact__block p.time {
    margin-right: 0;
    text-align: center;
  }
  .p-contact__block p.fax {
    margin-right: 0;
    text-align: center;
  }
  .p-contact__form {
    padding: 20px 10px 20px;
  }
  .p-contact__form table th {
    padding: 15px 10px;
  }
  .p-contact__form table td {
    padding: 15px 10px;
  }
  .p-contact__form input {
    width: 100%;
  }
  .p-contact__form .form-btn .submit_btn {
    font-size: 1.1rem;
    width: 90%;
  }
  .p-contact__form .policy {
    margin: 20px auto;
    padding: 10px;
    height: 150px;
  }
  .p-contact__form .policy p {
    font-size: 1.4rem;
  }
  .p-contact__form .policy h3 {
    font-size: 1.4rem;
  }
}
/*----------------------------------------------------------------------------------------
news.scss
----------------------------------------------------------------------------------------*/
.p-news {
  padding: 40px 0;
}
.p-news .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat;
  background-position: 50% 0;
}
.p-news__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-news__side-menu {
  width: 184px;
}
.p-news__side-menu ul li {
  width: 144px;
  background: #3B3835;
  border: 1px solid #3B3835;
  border-radius: 30px;
  margin: 10px 0;
  text-align: center;
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
}
.p-news__side-menu ul li a {
  width: 100%;
  height: 100%;
  padding: 10px;
}
.p-news__side-menu ul li:hover {
  background: #fff;
  color: #3B3835;
}
.p-news__side-menu ul li.active {
  background: #fff;
  color: #3B3835;
}
.p-news__side-menu img.mascot01 {
  display: block;
  position: relative;
  width: 100px;
  margin: 10px auto 10px 8%;
}
.p-news__block {
  background: #fff;
  border-radius: 24px;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  padding: 20px;
  width: calc(100% - 184px);
  margin: 0 auto 40px;
}
.p-news__list {
  padding: 10px 0;
  margin: 0 auto;
  border-bottom: 1px dotted #5A5957;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
}
.p-news__list p.p-news__empty {
  font-size: 1.5rem;
}
.p-news__list-txt {
  width: 55%;
}
.p-news__list-txt p {
  font-size: 1.6rem;
  text-align: left;
  line-height: 1.8;
}
.p-news__list-txt p.news-cat {
  text-align: center;
  padding: 5px;
  background: #DDDDDD;
  width: 96px;
  font-size: 1.3rem;
  margin-bottom: 5px;
}
.p-news__list-txt p.news-date {
  font-weight: 700;
  margin-bottom: 10px;
}
.p-news__list-txt .btn {
  display: block;
  /*text-align: right;
  /*font-size: 1.6rem;
  line-height: 2;*/
  margin: 10px 0 0 auto;
  width: 180px;
}
.p-news__list-txt .btn img {
  width: 180px;
}
.p-news__list-img {
  width: 39%;
  overflow: hidden;
}
.p-news__list-img .image {
  width: 100%;
  margin: 0 auto;
  border-radius: 20px;
  overflow: hidden;
  /*&:hover {

  	img {
  		transform: scale(1.1);
  		transition: all .8s ease;
  	}
  }*/
}
.p-news__list-img .image img {
  -webkit-transition: all 0.8s ease;
  transition: all 0.8s ease;
}
.p-news__list:hover img.big {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  -webkit-transition: all 0.8s ease;
  transition: all 0.8s ease;
}
.p-news__cnts {
  width: 100%;
  max-width: 720px;
  padding: 20px 0 0;
  margin: 0 auto;
  font-size: 1.6rem;
  line-height: 1.8;
  text-align: left;
  font-weight: 400;
}
.p-news__cnts-txt {
  width: 100%;
}
.p-news__cnts-txt h3 {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  padding-bottom: 10px;
  border-bottom: 1px dotted #5A5957;
  margin-bottom: 10px;
}
.p-news__cnts-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
  text-align: left;
  font-weight: 400;
  width: 94%;
  margin: 10px auto;
}
.p-news__cnts-txt p.news-cat {
  text-align: center;
  padding: 5px;
  background: #DDDDDD;
  width: 96px;
  font-size: 1.3rem;
  margin: 0;
  font-weight: 500;
}
.p-news__cnts-txt p.news-date {
  margin: 0;
  font-weight: 500;
}
.p-news__cnts-img {
  text-align: center;
  margin: 20px auto;
}
.p-news__cnts-img img {
  width: 30%;
  margin: 10px 1%;
}
.p-news__cnts-btn {
  margin: 50px auto;
  text-align: center;
}
.p-news__pagenation {
  margin: 30px auto 30px;
}
.p-news__pagenation ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-news__pagenation ul li {
  background: #3B3835;
  border: 1px solid #707070;
  border-radius: 50%;
  font-size: 18px;
  line-height: 32px;
  font-size: 1.8rem;
  color: #fff;
  width: 32px;
  margin: 0 2%;
  text-align: center;
}
.p-news__pagenation ul li.js-prev, .p-news__pagenation ul li.js-next {
  background: none;
  border: none;
  width: auto;
  color: #313131;
}
.p-news__pagenation ul li.is-disabled {
  background: none;
  color: #373737;
  pointer-events: none;
  opacity: 0.3;
}
.p-news__pagenation ul li.is-current {
  background: none;
  color: #3B3835;
}
.p-news__pagenation ul li.dots {
  background: none;
  border: none;
  color: #3B3835;
}
.p-news__pagenation ul li:first-child, .p-news__pagenation ul li:last-child {
  background: none;
  border: none;
  color: #3B3835;
}
.p-news__pagenation ul li:hover {
  opacity: 0.5;
}

@media screen and (max-width: 480px) {
  .p-news__flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-news__side-menu {
    position: relative;
    width: 100%;
    margin-bottom: 20px;
  }
  .p-news__side-menu ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-news__side-menu ul li {
    width: 48%;
    margin: 1%;
  }
  .p-news__side-menu img.mascot01 {
    display: block;
    position: absolute;
    width: 60px;
    margin: 0 auto;
    bottom: -20px;
    right: 5%;
  }
  .p-news__block {
    padding: 10px 20px;
    width: 100%;
  }
  .p-news__list {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-news__list-txt {
    width: 100%;
    margin-bottom: 10px;
  }
  .p-news__list-img {
    width: 100%;
    text-align: center;
  }
  .p-news__cnts {
    padding: 15px 0;
  }
  .p-news__pagenation ul li {
    font-size: 1.6rem;
    line-height: 26px;
    width: 26px;
  }
}
/*----------------------------------------------------------------------------------------
strength.scss
----------------------------------------------------------------------------------------*/
.p-strength {
  position: relative;
  padding: 1px 0 50px;
}
.p-strength .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat-x;
  background-position: 50% 0;
  padding: 20px 0;
}
.p-strength .bg_02 {
  position: absolute;
  top: 20%;
  left: -8%;
  overflow-x: hidden;
}
.p-strength .bg_02 img {
  width: 144.44%;
  -o-object-fit: contain;
     object-fit: contain;
}
.p-strength .bg_03 {
  position: absolute;
  top: 67%;
  left: 6%;
  overflow-x: hidden;
}
.p-strength .bg_03 img {
  width: 121.11%;
  -o-object-fit: contain;
     object-fit: contain;
}
.p-strength h2 {
  background: #3B3835;
  border-radius: 16px 16px 0 0;
  font-size: 2.4rem;
  font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);
  line-height: 1.5;
  font-weight: 700;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px;
  padding: 16px;
}
.p-strength h2 img {
  width: 30px;
}
.p-strength__block {
  position: relative;
  z-index: 3;
  margin: 40px auto;
}
.p-strength__block.bg_white {
  background: #fff;
  border-radius: 16px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  padding: 0 0 40px;
}
.p-strength__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-strength__flex-txt {
  width: 50%;
  margin: 0 5%;
}
.p-strength__flex-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
}
.p-strength__flex-img {
  width: 40%;
}
.p-strength__flex02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 40px 0;
  border-bottom: 1px solid #5A5957;
  width: 90%;
  max-width: 1000px;
  margin: 0 auto;
}
.p-strength__flex02-txt {
  width: 55%;
}
.p-strength__flex02-txt h3 {
  width: 120px;
  margin-bottom: 10px;
}
.p-strength__flex02-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
}
.p-strength__flex02-txt p.bold {
  font-weight: 700;
  font-size: 2rem;
  margin-bottom: 10px;
}
.p-strength__flex02-img {
  width: 40%;
}
.p-strength__flex03 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 30px 0 30px;
  width: 90%;
  max-width: 1000px;
  margin: 30px auto;
  border: 1px solid #9AAEB9;
  border-radius: 8px;
}
.p-strength__flex03-img {
  width: 22%;
  text-align: center;
}
.p-strength__flex03-txt {
  width: 77%;
  padding-left: 20px;
  border-left: 1px solid #9AAEB9;
}
.p-strength__flex03-txt p {
  font-size: 1.6rem;
  line-height: 1.6;
}
.p-strength__flex03-txt p.title {
  font-size: 2.2rem;
  font-weight: 900;
  padding-left: 0.5em;
  border-left: 4px solid #d40014;
  line-height: 1;
  margin-bottom: 20px;
}
.p-strength__flex03-txt p.bold {
  font-weight: 700;
  font-size: 1.8rem;
  margin-bottom: 20px;
}
.p-strength__flex03-txt p.mb20 {
  margin-bottom: 20px;
}
.p-strength__txtarea {
  width: 90%;
  max-width: 900px;
  margin: 40px auto;
}
.p-strength__txtarea p {
  font-size: 1.6rem;
  line-height: 1.8;
}
.p-strength__imgarea {
  width: 90%;
  max-width: 1000px;
  margin: 0 auto;
}

@media screen and (max-width: 480px) {
  .p-strength .bg_01 {
    background-size: auto 120px;
  }
  .p-strength h2 {
    padding: 10px;
    text-align: center;
    gap: 10px;
    font-size: 2rem;
  }
  .p-strength h2 img {
    width: 20px;
  }
  .p-strength__block {
    margin: 20px auto;
  }
  .p-strength__flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-strength__flex-txt {
    width: 100%;
    margin-bottom: 20px;
  }
  .p-strength__flex-img {
    width: 80%;
    margin: 0 auto;
  }
  .p-strength__flex02 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    padding: 20px 0;
  }
  .p-strength__flex02-txt {
    width: 100%;
    margin-bottom: 20px;
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
  }
  .p-strength__flex02-txt h3 {
    width: 90px;
    margin-bottom: 10px;
  }
  .p-strength__flex02-img {
    width: 80%;
    margin: 0 auto;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .p-strength__flex03 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-strength__flex03-img {
    width: 80%;
    margin: 0 auto;
  }
  .p-strength__flex03-txt {
    width: 100%;
    padding: 20px;
  }
  .p-strength__flex03-txt p.title {
    font-size: 1.8rem;
  }
  .p-strength__flex03-txt p.bold {
    font-size: 1.6rem;
  }
  .p-strength__imgarea {
    height: 450px;
    overflow-x: scroll;
  }
  .p-strength__imgarea img {
    width: auto;
    height: 400px;
  }
  .p-strength__imgarea p {
    font-size: 1.4rem;
    margin: 20px auto;
    text-align: right;
  }
  body.strength .right-icon,
  body.strength .left-icon {
    display: none;
  }
}
/*----------------------------------------------------------------------------------------
business.scss
----------------------------------------------------------------------------------------*/
.p-business {
  position: relative;
  padding: 1px 0 50px;
  /*overflow-x: hidden;*/
}
.p-business .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat-x;
  background-position: 50% 0;
  padding: 20px 0;
}
.p-business .bg_02 {
  position: absolute;
  top: 35%;
  left: -8%;
  overflow-x: hidden;
}
.p-business .bg_02 img {
  width: 144.44%;
  -o-object-fit: contain;
     object-fit: contain;
}
.p-business h2 {
  font-size: 2.4rem;
  font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);
  line-height: 1.5;
  font-weight: 700;
  margin-bottom: 20px;
}
.p-business__block {
  position: relative;
  z-index: 3;
  margin: 40px auto;
}
.p-business__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-business__flex-txt {
  width: 63%;
}
.p-business__flex-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 700;
}
.p-business__flex-img {
  position: relative;
  width: 37%;
  margin-top: 5%;
  opacity: 0.5;
}
.p-business__flex-img .on_img_01 {
  position: relative;
  left: 20%;
  width: 35.3%;
}
.p-business__flex-img .on_img_02 {
  position: relative;
  left: 68%;
  width: 32.3%;
  top: -25px;
}
.p-business__flex-img .on_img_03 {
  position: relative;
  left: 10%;
  top: -25px;
  width: 35.9%;
}
.p-business__flex02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: 0 auto;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.p-business__flex02-box {
  background: #fff;
  border-radius: 0 16px 16px 16px;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  width: 32.3%;
  max-width: 336px;
  padding-bottom: 20px;
  overflow: hidden;
}
.p-business__flex02-box:nth-of-type(2) {
  margin-top: 70px;
}
.p-business__flex02-box:nth-of-type(3) {
  margin-top: 140px;
}
.p-business__flex02-box .num {
  position: relative;
}
.p-business__flex02-box .num img.base {
  position: relative;
  width: 35.8%;
  max-width: 120px;
}
.p-business__flex02-box .num img.on_num {
  position: absolute;
  top: 50%;
  left: 15%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 12.5%;
}
.p-business__flex02-box h3 {
  font-weight: 700;
  font-size: 1.8rem;
  margin: 10px 20px 15% 20px;
}
.p-business__flex02 .img-area {
  overflow: hidden;
}
.p-business__flex02-btn {
  text-align: right;
  margin: 15% 20px 0 auto;
  width: 120px;
}
.p-business__flex02-btn .img-btn {
  display: inline-block;
  width: 120px;
  height: 32px;
}

@media screen and (max-width: 480px) {
  .p-business .bg_01 {
    background-size: auto 120px;
  }
  .p-business h2 {
    margin-bottom: 20px;
  }
  .p-business__block {
    margin: 20px auto;
  }
  .p-business__flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-business__flex-txt {
    width: 100%;
    margin-bottom: 20px;
  }
  .p-business__flex-txt p {
    font-size: 1.4rem;
  }
  .p-business__flex-img {
    width: 30%;
    margin: 0 auto;
  }
  .p-business__flex02 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    padding: 20px 0;
  }
  .p-business__flex02-box {
    width: 100%;
    margin: 0 auto 20px;
  }
  .p-business__flex02-box:nth-of-type(2) {
    margin-top: 0;
  }
  .p-business__flex02-box:nth-of-type(3) {
    margin-top: 0;
  }
  .p-business__flex02-box h3 {
    margin: 10px 20px 20px 20px;
  }
  .p-business__flex02-btn {
    margin: 20px 20px 0 auto;
  }
}
/*----------------------------------------------------------------------------------------
employ.scss
----------------------------------------------------------------------------------------*/
.p-employ {
  position: relative;
  padding: 1px 0 50px;
  overflow-x: hidden;
}
.p-employ .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat-x;
  background-position: 50% 0;
  padding: 40px 0 0;
}
.p-employ .bg_02 {
  background-image: url(../images/business/bg_03.png);
  background-repeat: no-repeat;
  background-position: center bottom;
  padding-bottom: 200px;
}
.p-employ .bg_03 {
  position: relative;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(20%, transparent), color-stop(20%, #BDCCD4));
  background: linear-gradient(to bottom, transparent 20%, #BDCCD4 20%);
  padding-bottom: 1px;
}
.p-employ .bg_04 {
  position: relative;
  background-image: url(../images/business/bg_04.png);
  background-repeat: repeat-x;
  background-position: top center;
  margin-top: -150px;
  padding-top: 100px;
}
.p-employ .bg_05 {
  position: relative;
  background-image: url(../images/business/bg_05.png);
  background-repeat: repeat-x;
  background-position: top center;
  margin-bottom: 100px;
}
.p-employ .bg_06 {
  position: relative;
  background-image: url(../images/business/bg_04.png);
  background-repeat: repeat-x;
  background-position: center 70%;
}
.p-employ .l-inner03 {
  width: 90%;
}
.p-employ h2 {
  text-align: center;
  color: #5A5957;
  font-size: 4.8rem;
  /*font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);*/
  font-size: clamp(3.2rem, 2.381vw + 1.371rem, 4.8rem);
  line-height: 1.5;
  font-weight: 900;
  margin: 20px auto 60px;
}
.p-employ h2 img {
  margin-right: 0.5em;
  width: 8%;
  max-width: 74px;
  margin-bottom: 0;
}
.p-employ h2.title {
  position: relative;
  color: #fff;
  background: #A5A8AC;
  border-radius: 8px;
  font-size: 3.2rem;
  /*font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);*/
  font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);
  line-height: 1.5;
  font-weight: 700;
  padding: 22px;
  margin: 20px auto;
  z-index: 3;
}
.p-employ h2.title span {
  position: absolute;
  display: block;
  background: #FFFFFF;
  border-radius: 40px 40px 0 0;
  width: 30%;
  height: 6px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
}
.p-employ h3 {
  font-size: 2.4rem;
  font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);
  line-height: 1.5;
  font-weight: 700;
  width: 95%;
  text-align: left;
  margin: 0 auto 40px;
}
.p-employ h3.title02 {
  text-align: center;
  font-size: 4rem;
  font-size: clamp(3rem, 1.488vw + 1.857rem, 4rem);
  margin: 20px auto;
  font-weight: 900;
}
.p-employ__block {
  position: relative;
  z-index: 3;
  margin: 40px auto;
  text-align: center;
}
.p-employ__block.block02 {
  background: #fff;
  border-radius: 16px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  margin: 20px auto 40px;
  padding: 40px;
}
.p-employ__block.block03 {
  background: #F7F7F7;
  border-radius: 16px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  margin: 20px auto 0;
  padding: 40px;
}
.p-employ__block p.txt {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
}
.p-employ__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  margin: 0 auto;
}
.p-employ__flex-txt {
  text-align: left;
  width: 55%;
  margin: 0 2.5%;
  padding-top: 2%;
}
.p-employ__flex-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
}
.p-employ__flex-img {
  width: 40%;
  text-align: center;
}
.p-employ__flex-img img {
  max-width: 390px;
  border-radius: 16px;
}
.p-employ__btn {
  margin: 40px auto 0;
}
.p-employ__btn .img-btn {
  width: 384px;
}
.p-employ__btn {
  /*a {
  	background: #9AAEB9;
  	border-radius: 16px;
  	color: #fff;
  	display: flex;
  	justify-content: space-between;
  	align-items: center;
  	padding: 32px 20px;

  	p {
  		font-size: 1.6rem;
  		line-height: calc(24/16);

  		&.bold {
  			font-size: 2rem;
  			font-size: clamp(1.8rem, 0.298vw + 1.571rem, 2rem);
  			font-weight: 700;
  		}
  	}*/
}
.p-employ__flex02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto 20px;
}
.p-employ__flex02-img {
  width: 20%;
  text-align: center;
}
.p-employ__flex02-txt {
  text-align: left;
  width: 65%;
  margin: 0 2.5%;
}
.p-employ__flex02-txt h4 {
  font-size: 2.4rem;
  font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);
  line-height: 1.5;
  font-weight: 700;
  margin-bottom: 10px;
}
.p-employ__flex02-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
}
.p-employ .bdr {
  width: 100%;
  border-top: 1px dotted #3B3835;
  margin: 20px auto;
}
.p-employ__flex03 {
  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;
  padding: 20px;
}
.p-employ__flex03-box {
  width: 48%;
  max-width: 500px;
  background: #fff;
  padding: 10px 20px 20px;
  margin-bottom: 40px;
}
.p-employ__flex03-box img {
  max-width: 100%;
}
.p-employ__flex03-box p {
  font-size: 1.6rem;
  line-height: 1.7142857143;
  margin-bottom: 5px;
  text-align: left;
  font-weight: 400;
}
.p-employ h5 {
  background: #9AAEB9;
  color: #fff;
  border-radius: 32px;
  text-align: center;
  font-size: 2rem;
  font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);
  line-height: 1.5;
  padding: 9px;
  margin-bottom: 10px;
}
.p-employ__list {
  text-align: left;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 auto;
}
.p-employ__list li {
  width: 50%;
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
  padding: 10px 20px;
}
.p-employ__flex04 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.p-employ__flex04-box {
  /*width: 50%;
  padding: 10px 20px 20px;
  margin-bottom: 20px;*/
  width: 48%;
  max-width: 500px;
  background: #fff;
  padding: 10px 20px 20px;
  margin-bottom: 40px;
}
.p-employ__flex04-box img {
  width: 100%;
  max-width: 100%;
}
.p-employ__flex04-box p {
  font-size: 1.6rem;
  line-height: 1.7142857143;
  margin-bottom: 5px;
  text-align: left;
  font-weight: 400;
}
.p-employ__flex05 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.p-employ__flex05-box {
  padding: 10px;
  text-align: left;
}
.p-employ__flex05-box ul {
  margin: 20px auto;
}
.p-employ__flex05-box ul li {
  font-size: 1.6rem;
  line-height: 1.7142857143;
  margin-bottom: 5px;
}

/*body.employ {

	.icon_area {
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		max-width: 1440px;
		margin: 0 auto;
		z-index: 1;
	}

	.right-icon {
		position: relative;
		left: 88%;
		top: 5%;
		width: 150px;
		height: auto;
		z-index: 3;
		opacity: 0.5;

		.on_right_01 {
			position: relative;
			margin-bottom: 80px;
		}

		.on_right_02 {
			position: relative;
			margin-bottom: 80px;
		}

		.on_right_03 {
			position: relative;
			margin-bottom: 80px;
		}

		.on_right_04 {
			position: relative;
			margin-bottom: 80px;
		}

		.on_right_05 {
			position: relative;
		}
	}

	.bottom-icon {
		position: relative;
		bottom: 0;
		left: 15%;
		width: 560px;
		opacity: 0.5;
		display: flex;
		justify-content: space-between;
		z-index: 10;

		.on_bottom_01 {
			position: relative;
		}

		.on_bottom_02 {
			position: relative;
		}

		.on_bottom_03 {
			position: relative;
		}

		.on_bottom_04 {
			position: relative;
		}

		.on_bottom_05 {
			position: relative;
			left: 10%;
		}
	}
}*/
@media screen and (max-width: 768px) {
  .p-employ__flex {
    width: 100%;
    margin: 0 auto;
  }
  /*body.employ {

  	.left-icon {
  		top: 50%;
  	}
  }*/
}
@media screen and (max-width: 480px) {
  .p-employ .bg_01 {
    background-size: auto 120px;
    padding: 20px 0 0;
  }
  .p-employ .bg_02 {
    padding-bottom: 100px;
  }
  .p-employ .bg_04 {
    margin-top: -100px;
    padding-top: 50px;
  }
  .p-employ .l-inner03 {
    width: 96%;
  }
  .p-employ h2 {
    margin-bottom: 20px;
    font-size: 2.6rem;
  }
  .p-employ h2 img {
    width: 15%;
    height: 35px;
  }
  .p-employ h2.title {
    padding: 10px;
    font-size: 2rem;
  }
  .p-employ h2.title span {
    width: 60%;
    height: 3px;
  }
  .p-employ h3 {
    width: 100%;
    margin: 0 auto 20px;
  }
  .p-employ h3.title02 {
    font-size: 2rem;
  }
  .p-employ__block {
    margin: 20px auto;
  }
  .p-employ__block.block02 {
    padding: 20px;
  }
  .p-employ__block.block03 {
    padding: 20px;
  }
  .p-employ__flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    width: 100%;
  }
  .p-employ__flex-txt {
    width: 100%;
    margin: 0 auto 20px;
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
  }
  .p-employ__flex-txt p {
    font-size: 1.4rem;
  }
  .p-employ__flex-img {
    width: 90%;
    margin: 0 auto;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .p-employ__btn {
    width: 100%;
    max-width: 290px;
    margin: 20px auto;
  }
  .p-employ__btn .img-btn {
    width: 290px;
    height: 36px;
  }
  .p-employ__btn {
    /*a{
    	padding: 10px;
    	flex-wrap: wrap;

    	p{
    		width: 100%;
    		font-size: 1.3rem;

    		&.bold{
    			font-size: 1.6rem;
    		}
    	}
    }*/
  }
  .p-employ__flex02-img {
    width: 32%;
    padding-top: 40px;
  }
  .p-employ__flex02-txt {
    width: 68%;
    margin: 0 0 0 10px;
  }
  .p-employ__flex02-txt p {
    font-size: 1.4rem;
    padding-left: 10px;
  }
  .p-employ__flex03 {
    padding: 20px 0;
  }
  .p-employ__flex03-box {
    width: 100%;
    margin-bottom: 20px;
  }
  .p-employ__flex03 iframe {
    aspect-ratio: 16/9;
    width: 100%;
    height: auto;
  }
  .p-employ h5 {
    padding: 5px;
  }
  .p-employ__list {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-employ__list li {
    width: 100%;
    font-size: 1.4rem;
    padding: 0 10px;
    line-height: 2;
  }
  .p-employ__flex04 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-employ__flex04-box {
    width: 100%;
    padding: 10px 0;
    margin-bottom: 20px;
  }
  .p-employ__flex05 {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .p-employ__flex05-box {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .p-employ__flex05-box ul {
    margin: 0 20px;
  }
  /*body.employ {

  	.right-icon,
  	.left-icon {
  		display: none;
  	}

  	.bottom-icon{
  		width: 80%;
  		left: 0;
  		margin: 0 auto;

  		img{
  			width: 80%;
  		}

  		.on_bottom_05 {
  			left: 5%;
  		}
  	}
  }*/
}
/*----------------------------------------------------------------------------------------
support.scss
----------------------------------------------------------------------------------------*/
.p-support {
  position: relative;
  padding: 1px 0 50px;
}
.p-support .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat-x;
  background-position: 50% 0;
  padding: 40px 0 0;
}
.p-support .bg_02 {
  background-image: url(../images/business/bg_06.png);
  background-repeat: no-repeat;
  background-position: top center;
  padding-bottom: 50px;
}
.p-support .l-inner03 {
  width: 90%;
}
.p-support h2 {
  text-align: center;
  color: #5A5957;
  font-size: 4.8rem;
  /*font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);*/
  font-size: clamp(3.2rem, 2.381vw + 1.371rem, 4.8rem);
  line-height: 1.5;
  font-weight: 900;
  margin: 20px auto 60px;
}
.p-support h2 img {
  margin-right: 0.5em;
  width: 8%;
  max-width: 74px;
  margin-bottom: 0.8%;
}
.p-support__block {
  position: relative;
  z-index: 3;
  margin: 60px auto;
}
.p-support__block.block02 {
  background: #fff;
  border-radius: 16px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  margin: 20px auto 0;
  padding: 40px;
}
.p-support__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.p-support__flex-txt {
  width: 48%;
  margin: 0 2%;
}
.p-support__flex-txt h3 {
  font-size: 2.4rem;
  font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);
  line-height: 1.5;
  font-weight: 700;
  margin-bottom: 20px;
}
.p-support__flex-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 700;
}
.p-support__flex-img {
  position: relative;
  width: 40%;
  text-align: center;
}
.p-support h2.title {
  position: relative;
  color: #fff;
  background: #A5A8AC;
  border-radius: 8px;
  font-size: 3.2rem;
  /*font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);*/
  font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);
  line-height: 1.5;
  font-weight: 700;
  padding: 22px;
  margin: 20px auto;
  z-index: 3;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
.p-support h2.title span {
  position: absolute;
  display: block;
  background: #FFFFFF;
  border-radius: 40px 40px 0 0;
  width: 30%;
  height: 6px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
}
.p-support h4 {
  background: #9AAEB9;
  color: #fff;
  border-radius: 32px;
  text-align: center;
  font-size: 2.4rem;
  /*font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);*/
  font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);
  line-height: 1.5;
  padding: 9px;
}
.p-support__flex02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 20px 0;
  border-bottom: 1px dotted #707070;
}
.p-support__flex02-box {
  width: 50%;
  padding: 10px 20px 0 20px;
}
.p-support__flex02-box:first-child {
  border-right: 1px dotted #707070;
}
.p-support__flex02-box p {
  font-size: 2rem;
  font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);
  font-weight: 700;
}
.p-support__flex03 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 10px auto 0;
}
.p-support__flex03-txt {
  width: 55%;
  padding-left: 20px;
}
.p-support__flex03-txt p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.8;
}
.p-support__flex03-img {
  width: 45%;
  text-align: center;
}

/*body.support {

	.icon_area {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		max-width: 1440px;
		margin: 0 auto;
		z-index: 1;
	}

	.right-icon {
		position: absolute;
		right: 0;
		top: 38%;
		width: 174px;
		z-index: 3;
		opacity: 0.5;

		.on_right_01 {
			position: relative;
			left: 40%;
		}

		.on_right_02 {
			position: relative;
			top: -10px;
		}

		.on_right_03 {
			position: relative;
		}

		.on_right_04 {
			position: relative;
			left: 30%;
			top: -40px;
		}

		.on_right_05 {
			position: relative;
			left: 10%;
		}
	}
}*/
@media screen and (max-width: 768px) {
  .p-support__flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .p-support__flex-txt {
    width: 55%;
    margin: 0%;
  }
  .p-support__flex02-box {
    padding: 10px;
  }
}
@media screen and (max-width: 480px) {
  .p-support .bg_01 {
    background-size: auto 120px;
    padding: 20px 0 0;
  }
  .p-support .l-inner03 {
    width: 96%;
  }
  .p-support h2 {
    margin-bottom: 20px;
    font-size: 2.6rem;
  }
  .p-support h2 img {
    width: 15%;
    height: 35px;
  }
  .p-support__block {
    margin: 40px auto;
  }
  .p-support__block.block02 {
    padding: 20px;
  }
  .p-support__flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-support__flex-txt {
    width: 100%;
    margin-bottom: 20px;
  }
  .p-support__flex-txt p {
    font-size: 1.4rem;
  }
  .p-support__flex-img {
    width: 90%;
    margin: 0 auto;
  }
  .p-support h2.title {
    padding: 10px;
    font-size: 2rem;
  }
  .p-support h2.title span {
    width: 60%;
    height: 3px;
  }
  .p-support h4 {
    padding: 5px;
    font-size: 1.6rem;
  }
  .p-support__flex02 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    padding: 0;
  }
  .p-support__flex02-box {
    width: 100%;
    padding: 10px;
  }
  .p-support__flex02-box:first-child {
    border-right: none;
    border-bottom: 1px dotted #707070;
  }
  .p-support__flex03 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-support__flex03-txt {
    width: 100%;
    padding-left: 16px;
  }
  .p-support__flex03-txt p {
    font-size: 1.4rem;
    margin-bottom: 20px;
  }
  .p-support__flex03-img {
    width: 80%;
    margin: 0 auto;
  }
  /*body.support {

  	.right-icon,
  	.left-icon {
  		display: none;
  	}
  }*/
}
/*----------------------------------------------------------------------------------------
program.scss
----------------------------------------------------------------------------------------*/
.p-program {
  position: relative;
  padding: 1px 0 50px;
}
.p-program .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat-x;
  background-position: 50% 0;
  padding: 40px 0 0;
}
.p-program .bg_02 {
  background-image: url(../images/business/bg_07.png);
  background-repeat: repeat-x;
  background-position: bottom center;
  padding-bottom: 100px;
}
.p-program .l-inner03 {
  width: 90%;
}
.p-program h2 {
  text-align: center;
  color: #5A5957;
  font-size: 4.8rem;
  /*font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);*/
  font-size: clamp(3.2rem, 2.381vw + 1.371rem, 4.8rem);
  line-height: 1.5;
  font-weight: 900;
  margin: 20px auto 60px;
}
.p-program h2 img {
  margin-right: 0.5em;
  width: 8%;
  max-width: 74px;
  margin-bottom: 0.8%;
}
.p-program h3 {
  width: 60%;
  text-align: center;
  margin: 20px auto;
}
.p-program__block {
  position: relative;
  z-index: 3;
  margin: 40px auto;
}
.p-program__block.block02 {
  background: #fff;
  border-radius: 16px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  margin: 20px auto 0;
  padding: 20px;
}
.p-program__block p {
  font-size: 1.8rem;
  line-height: 1.8;
  font-weight: 700;
  text-align: center;
}
.p-program__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 40px auto;
}
.p-program__flex-box {
  width: 48%;
  max-width: 480px;
  margin: 20px auto;
  margin-bottom: 20px;
}
.p-program__flex-box p {
  text-align: left;
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
}
.p-program__flex-box p.title {
  text-align: center;
  background: #5A5957;
  color: #fff;
  border-radius: 8px;
  font-size: 2rem;
  font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);
  font-weight: 700;
  padding: 17px 0;
  margin-bottom: 5px;
}
.p-program__flex-box p.title02 {
  text-align: center;
  background: #5A5957;
  color: #fff;
  border-radius: 8px;
  font-size: 2rem;
  font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);
  line-height: 1.3;
  font-weight: 700;
  padding: 6px 0;
  margin-bottom: 5px;
}
.p-program__flex-box img {
  max-width: 480px;
  margin: 5px auto 10px;
}
.p-program h4 {
  background-image: url(../images/guidance/img_17.png);
  background-repeat: no-repeat;
  background-position: left center;
  border-radius: 12px;
  color: #fff;
  font-size: 2rem;
  font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);
  line-height: 1.5;
  padding: 17px 32px;
  width: 96%;
  margin: 0 auto;
  background-size: cover;
}
.p-program h4.title02 {
  background: none;
  border: 1px solid #000;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  color: #000;
}
.p-program h4 img.mascot01 {
  position: absolute;
  width: 100px;
  right: 4%;
  bottom: 0;
}
.p-program__programimg {
  text-align: center;
  width: 90%;
  max-width: 900px;
  margin: 20px auto;
}
.p-program__programimg p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
  margin: 20px auto;
}

/*body.program {

	.icon_area {
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		max-width: 1440px;
		margin: 0 auto;
		z-index: 1;
	}

	.left-icon {
		position: relative;
		z-index: 3;
		left: 0;
		top: 15%;

		.on_left_01 {
			position: relative;
			margin-bottom: 28%;
			left: 4%;
		}

		.on_left_02 {
			position: relative;
			margin-bottom: 28%;
			left: 4%;
		}

		.on_left_03 {
			position: relative;
			margin-bottom: 28%;
			left: 4%;
		}

		.on_left_04 {
			position: relative;
			left: 4%;
		}

		.on_right_01 {
			position: absolute;
			margin-bottom: 5%;
			top: 14%;
			right: 4%;
		}

		.on_right_02 {
			position: absolute;
			margin-bottom: 5%;
			top: 42%;
			right: 4%;
		}

		.on_right_03 {
			position: absolute;
			margin-bottom: 5%;
			top: 70%;
			right: 4%;
		}
	}
}*/
@media screen and (max-width: 480px) {
  .p-program .bg_01 {
    background-size: auto 120px;
    padding: 20px 0 0;
  }
  .p-program .l-inner03 {
    width: 96%;
  }
  .p-program h2 {
    margin-bottom: 40px;
    font-size: 2.6rem;
  }
  .p-program h2 img {
    width: 15%;
    height: 35px;
  }
  .p-program h2.title {
    padding: 10px;
    font-size: 2rem;
  }
  .p-program h2.title span {
    width: 60%;
    height: 3px;
  }
  .p-program__block {
    margin: 20px auto;
  }
  .p-program__flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 20px auto;
  }
  .p-program__flex-box {
    width: 100%;
    margin-bottom: 20px;
  }
  .p-program__flex-box p {
    font-size: 1.4rem;
  }
  .p-program h4 {
    border-radius: 6px;
    padding: 5px 50px 5px 20px;
  }
  .p-program h4 img.mascot01 {
    position: absolute;
    width: 60px;
    right: 0;
    bottom: 0;
  }
  .p-program__programimg {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    height: 380px;
    overflow-y: scroll;
  }
  .p-program__programimg img {
    height: 300px;
    margin: 0;
    width: auto;
    -o-object-fit: contain;
       object-fit: contain;
  }
  .p-program__programimg p {
    text-align: right;
  }
  /*body.program {

  	.right-icon,
  	.left-icon {
  		display: none;
  	}
  }*/
}
/*----------------------------------------------------------------------------------------
guidance.scss
----------------------------------------------------------------------------------------*/
.p-guidance {
  position: relative;
  padding: 1px 0 50px;
}
.p-guidance .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat-x;
  background-position: 50% 0;
  padding: 20px 0;
}
.p-guidance .bg_02 {
  position: absolute;
  top: 43%;
  left: -8%;
  overflow-x: hidden;
}
.p-guidance .bg_02 img {
  width: 144.44%;
  -o-object-fit: contain;
     object-fit: contain;
}
.p-guidance h2 {
  font-size: 2.4rem;
  font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);
  line-height: 1.5;
  font-weight: 700;
  margin-bottom: 20px;
}
.p-guidance__block {
  position: relative;
  z-index: 3;
  margin: 40px auto;
}
.p-guidance__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-guidance__flex-txt {
  width: 50%;
  margin-left: 5%;
}
.p-guidance__flex-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 700;
}
.p-guidance__flex-img {
  position: relative;
  width: 42%;
  text-align: center;
}
.p-guidance__flex02 {
  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;
  margin: 0 auto;
}
.p-guidance__flex02-box {
  background: #fff;
  border-radius: 16px;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  width: 80%;
  max-width: 720px;
  margin: 20px auto 20px 0;
  overflow: hidden;
}
.p-guidance__flex02-box:nth-of-type(2) {
  margin: 10px 0 10px auto;
}
.p-guidance__flex02-box .img-area {
  width: 92%;
  max-width: 662px;
  border-radius: 0 0 80px 0;
  overflow: hidden;
}
.p-guidance__flex02-box h3 {
  font-weight: 700;
  font-size: 1.8rem;
  margin: 10px 40px 0 50px;
}
.p-guidance__flex02 a {
  width: 100%;
}
.p-guidance__flex02-btn {
  text-align: right;
  margin: -20px 30px 20px auto;
  width: 120px;
}
.p-guidance__flex02-btn .img-btn {
  width: 120px;
  height: 32px;
}

body.guidance .icon_area {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  z-index: 1;
}
body.guidance .left-icon {
  position: absolute;
  left: 0;
  top: 38%;
  width: 181px;
  z-index: 3;
  opacity: 0.5;
}
body.guidance .left-icon .on_left_01 {
  position: relative;
  left: 10%;
}
body.guidance .left-icon .on_left_02 {
  position: relative;
  left: 60%;
}
body.guidance .left-icon .on_left_03 {
  position: relative;
  left: 10%;
}
body.guidance .right-icon {
  position: absolute;
  right: 5%;
  top: 65%;
  width: 180px;
  z-index: 3;
  opacity: 0.5;
}
body.guidance .right-icon .on_right_01 {
  position: relative;
  left: 60%;
  top: 0;
}
body.guidance .right-icon .on_right_02 {
  position: relative;
  left: 0;
}
body.guidance .right-icon .on_right_03 {
  position: relative;
  left: 50%;
}

@media screen and (max-width: 768px) {
  body.guidance .left-icon {
    top: 50%;
  }
}
@media screen and (max-width: 480px) {
  .p-guidance .bg_01 {
    background-size: auto 120px;
  }
  .p-guidance h2 {
    margin-bottom: 20px;
  }
  .p-guidance__block {
    margin: 20px auto;
  }
  .p-guidance__flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-guidance__flex-txt {
    width: 100%;
    margin-bottom: 20px;
  }
  .p-guidance__flex-txt p {
    font-size: 1.4rem;
  }
  .p-guidance__flex-img {
    width: 80%;
    margin: 0 auto;
  }
  .p-guidance__flex02-box {
    width: 100%;
    margin: 10px auto;
  }
  .p-guidance__flex02-box:nth-of-type(2) {
    margin: 10px auto;
  }
  .p-guidance__flex02-box h3 {
    margin: 10px 20px;
  }
  .p-guidance__flex02 .img-area {
    width: 100%;
    border-radius: 0 0 40px 0;
  }
  .p-guidance__flex02-btn {
    /*text-align: right;*/
    margin: 10px 20px 20px auto;
  }
  body.guidance .right-icon,
  body.guidance .left-icon {
    display: none;
  }
}
/*----------------------------------------------------------------------------------------
system.scss
----------------------------------------------------------------------------------------*/
.p-system {
  position: relative;
  padding: 1px 0 50px;
}
.p-system .bg_01 {
  position: relative;
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat-x;
  background-position: 50% 0;
  padding: 20px 0 0;
}
.p-system .bg_02 {
  position: relative;
  z-index: 4;
  background-image: url(../images/guidance/bg_05.png);
  background-repeat: no-repeat;
  background-position: bottom center;
  padding-bottom: 250px;
}
.p-system .bg_03 {
  position: relative;
  background-image: url(../images/guidance/bg_04.png);
  background-repeat: repeat-x;
  background-position: top center;
  background-size: auto 100%;
  margin-top: -150px;
}
.p-system .bg_04 {
  position: relative;
  background-image: url(../images/guidance/bg_03.png);
  background-repeat: no-repeat;
  background-position: center;
  padding: 80px 0;
}
.p-system .bg_05 {
  position: relative;
  background-image: url(../images/guidance/bg_08.png);
  background-repeat: no-repeat;
  background-position: center;
  padding: 50px 0 0;
}
.p-system .bg_06 {
  position: relative;
  z-index: 5;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, transparent), color-stop(50%, #5A5957));
  background: linear-gradient(to bottom, transparent 50%, #5A5957 50%);
  padding-bottom: 50px;
}
.p-system h2 {
  text-align: center;
  color: #5A5957;
  font-size: 4.8rem;
  /*font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);*/
  font-size: clamp(3.2rem, 2.381vw + 1.371rem, 4.8rem);
  line-height: 1.5;
  font-weight: 700;
  margin: 40px auto 60px;
}
.p-system h2 img {
  margin-right: 0.5em;
  width: 8%;
  max-width: 74px;
}
.p-system h2.title {
  position: relative;
  color: #fff;
  background: #A5A8AC;
  border-radius: 8px;
  font-size: 3.2rem;
  /*font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);*/
  font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);
  line-height: 1.5;
  font-weight: 700;
  padding: 22px;
  margin: 20px auto;
  z-index: 3;
}
.p-system h2.title span {
  position: absolute;
  display: block;
  background: #FFFFFF;
  border-radius: 40px 40px 0 0;
  width: 30%;
  height: 6px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
}
.p-system h3 {
  background: #9AAEB9;
  color: #fff;
  border-radius: 32px;
  text-align: center;
  font-size: 2.4rem;
  font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);
  line-height: 1.5;
  padding: 9px;
  margin: 20px auto;
}
.p-system__block {
  position: relative;
  z-index: 3;
  margin: 40px auto;
  text-align: center;
}
.p-system__block.block02 {
  background: #fff;
  border-radius: 16px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  margin: 20px auto 0;
  padding: 40px;
}
.p-system__block.pb200 {
  padding-bottom: 180px;
}
.p-system__block p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
  text-align: left;
}
.p-system__block p.txt {
  font-size: 2.4rem;
  font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);
  line-height: 1.5;
  font-weight: 700;
}
.p-system__block p.txt02 {
  font-size: 2.4rem;
  font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);
  line-height: 1.5;
  font-weight: 700;
  text-align: center;
  margin: 20px auto;
}
.p-system__block p.bold {
  font-size: 2rem;
  font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);
  font-weight: 700;
}
.p-system__block p.ml25 {
  margin-left: 2.5%;
}
.p-system__block p.mb50 {
  margin-bottom: 50px;
}
.p-system__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 20px auto;
}
.p-system__flex-txt {
  width: 60%;
  margin: 0 2.5% 0;
}
.p-system__flex-txt.w100 {
  width: 90%;
  margin: 0 auto;
}
.p-system__flex-img {
  width: 35%;
  text-align: center;
}
.p-system__flex02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  margin: 40px auto 0;
}
.p-system__flex02 a {
  max-width: 48%;
  width: 384px;
}
.p-system__flex02 a .img-btn {
  width: 100%;
  height: auto;
}
.p-system h4 {
  background-image: url(../images/guidance/img_17.png);
  background-repeat: no-repeat;
  background-position: left center;
  border-radius: 12px;
  color: #fff;
  font-size: 2rem;
  font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);
  line-height: 1.5;
  padding: 17px 32px;
  text-align: left;
  /*width: 96%;*/
  margin: 0 auto;
  background-size: cover;
}
.p-system__systemimg {
  text-align: center;
  width: 100%;
  margin: 40px auto;
}
.p-system__systemimg p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
  margin: 20px auto;
}
.p-system__btn {
  width: 80%;
  max-width: 520px;
  margin: 40px auto 0;
  position: relative;
  z-index: 9;
  border-radius: 16px;
}
.p-system__btn.btn02 {
  margin: 80px auto;
}
.p-system__btn p.blink {
  position: absolute;
  font-family: "Kalam", cursive;
  font-size: 3rem;
  top: -15px;
  right: -5px;
  color: #000;
  -webkit-transform: rotate(8deg);
          transform: rotate(8deg);
  -webkit-animation: blink 1s ease infinite;
          animation: blink 1s ease infinite;
  z-index: 10;
}
.p-system__btn p.blink.blink02 {
  color: #fff;
}
.p-system__btn p.bold {
  line-height: 1.5;
  font-size: 2rem;
  font-size: clamp(1.8rem, 0.298vw + 1.571rem, 2rem);
  font-weight: 700;
}
@-webkit-keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.p-system__btn div {
  background: rgba(154, 174, 185, 0.8);
  border-radius: 16px;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1.5rem;
  padding: 20px 30px 20px;
}
.p-system__btn a.btn {
  border-radius: 16px;
  position: relative;
  font-weight: 700;
  top: 2px;
}
.p-system__btn a.btn div {
  color: #9aaeb9;
  background: #fff;
  padding: 10px 20px;
}
.p-system__flex03 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto;
  /*&-left {
  	width: 20%;

  	img {
  		/*margin-top: 8px;
  	}
  }*/
}
.p-system__flex03-right {
  width: 100%;
  margin: 0 auto;
  text-align: center;
}
.p-system__flex03 img.img_02 {
  margin-left: 2%;
}
.p-system__flex03-title {
  position: relative;
  width: 300px;
  margin: 0 auto 30px;
  border-radius: 16px;
  /*background: #fced76;
  padding: 20px 40px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.p-system__flex03-title p {
  font-size: 4rem;
  line-height: 1.5;
  font-weight: 700;
  position: relative;
  color: #fff;
  margin-right: 10px;
}
.p-system__flex03-title img {
  position: absolute;
  width: 80px;
  right: -85px;
}
.p-system__flex03-box {
  width: 70%;
  margin: 0 auto;
}
.p-system__flex03-txt {
  position: relative;
  margin: 10px auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  /*justify-content: center;*/
}
.p-system__flex03-txt img {
  width: 120px;
  margin-right: 40px;
}
.p-system__flex03-txt:nth-child(1), .p-system__flex03-txt:nth-child(3) {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.p-system__flex03-txt:nth-child(1) img, .p-system__flex03-txt:nth-child(3) img {
  width: 120px;
  margin-right: 0;
  margin-left: 40px;
}
.p-system__flex03-txt p {
  font-family: "Kiwi Maru", serif;
  font-weight: 500;
  font-size: 1.6rem;
  line-height: 1.8;
  /*font-weight: 700;*/
  position: relative;
  top: 0;
  bottom: 0;
  background: #fff;
  border-radius: 16px;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  width: 55%;
  padding: 25px;
  letter-spacing: -0.05em;
  z-index: 3;
}
.p-system__flex03-txt p.left::after {
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 15px solid transparent;
  border-bottom: 15px solid transparent;
  border-left: 60px solid #fff;
  border-right: 0;
  position: absolute;
  right: -40px;
  top: 35%;
  display: block;
  content: "";
  -webkit-transform: rotate(10deg);
          transform: rotate(10deg);
  z-index: -1;
}
.p-system__flex03-txt p.right::after {
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 15px solid transparent;
  border-bottom: 15px solid transparent;
  border-right: 60px solid #fff;
  border-left: 0;
  position: absolute;
  left: -40px;
  top: 40%;
  display: block;
  content: "";
  -webkit-transform: rotate(-10deg);
          transform: rotate(-10deg);
  z-index: -1;
}
.p-system h5 {
  background: #9AAEB9;
  border-radius: 8px;
  color: #fff;
  font-size: 2rem;
  font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);
  font-weight: 700;
  text-align: left;
  padding: 16px;
  margin: 20px auto;
}
.p-system__flex04 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: 20px auto;
}
.p-system__flex04-img {
  width: 32%;
  text-align: center;
}
.p-system__flex04-txt {
  width: 66%;
}
.p-system__flex04-txt ul {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
  text-align: left;
}
.p-system .bdr_box {
  /*border: 1px solid #707070;*/
  margin: 0px auto 0;
  text-align: right;
}
.p-system .bdr_box a {
  max-width: 396px;
  width: 90%;
}
.p-system .bdr_box {
  /*p {
  	font-size: 1.5rem;
  	line-height: calc(30/15);
  	font-weight: 700;
  	text-align: center;
  }*/
}

#system01 {
  padding-top: 100px;
  margin-top: -100px;
}

/*body.system {

	.icon_area {
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		max-width: 1440px;
		margin: 0 auto;
		z-index: 1;
	}

	.left-icon {
		position: relative;
		z-index: 3;
		left: 0;
		top: 13%;

		.on_left_01 {
			position: relative;
			margin-bottom: 32%;
			left: 4%;
		}

		.on_left_02 {
			position: relative;
			margin-bottom: 32%;
			left: 4%;
		}

		.on_left_03 {
			position: relative;
			margin-bottom: 32%;
			left: 4%;
		}

		.on_left_04 {
			position: relative;
			left: 4%;
		}

		.on_right_01 {
			position: absolute;
			margin-bottom: 5%;
			top: 14%;
			right: 4%;
		}

		.on_right_02 {
			position: absolute;
			margin-bottom: 5%;
			top: 42%;
			right: 4%;
		}

		.on_right_03 {
			position: absolute;
			margin-bottom: 5%;
			top: 70%;
			right: 4%;
		}
	}

	.right-icon {
		position: absolute;
		right: 0;
		bottom: 8%;
		width: 174px;
		z-index: 3;
		opacity: 0.5;

		.on_right_01 {
			position: relative;
			left: 40%;
		}

		.on_right_02 {
			position: relative;
			top: -10px;
		}

		.on_right_03 {
			position: relative;
		}

		.on_right_04 {
			position: relative;
			left: 30%;
			top: -40px;
		}

		.on_right_05 {
			position: relative;
			left: 10%;
		}
	}
}*/
@media screen and (max-width: 768px) {
  .p-system__flex03-box {
    width: 100%;
  }
  body.system .right-icon,
  body.system .left-icon {
    display: none;
  }
}
@media screen and (max-width: 480px) {
  .p-system .bg_01 {
    background-size: auto 120px;
  }
  .p-system h2 {
    font-size: 2.6rem;
    margin: 20px auto;
  }
  .p-system h2 img {
    width: 15%;
  }
  .p-system h2.title {
    padding: 10px;
    font-size: 2rem;
  }
  .p-system h2.title span {
    width: 60%;
    height: 3px;
  }
  .p-system h3 {
    padding: 5px;
  }
  .p-system__block {
    margin: 20px auto;
  }
  .p-system__block.block02 {
    padding: 20px;
  }
  .p-system__block.pb200 {
    padding-bottom: 180px;
  }
  .p-system__flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 20px auto;
  }
  .p-system__flex-txt {
    width: 100%;
    margin-bottom: 20px;
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
  }
  .p-system__flex-txt p {
    font-size: 1.4rem;
  }
  .p-system__flex-img {
    width: 90%;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .p-system__flex02 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-system__flex02 a {
    width: 100%;
    max-width: 290px;
    margin: 10px auto;
    text-align: center;
  }
  .p-system__flex02 a .img-btn {
    width: auto;
  }
  .p-system h4 {
    border-radius: 6px;
    padding: 5px 20px;
  }
  .p-system__systemimg {
    margin: 20px auto;
  }
  .p-system__systemimg p {
    font-size: 1.4rem;
  }
  .p-system {
    /*&__btn {
    	text-align: center;
    	width: 100%;
    	margin: 20px auto;

    	&.btn02 {
    		width: 90%;
    		margin: 40px auto;
    	}

    	div {
    		padding: 10px !important;
    		flex-wrap: wrap;

    		p {
    			width: 100%;
    			font-size: 1.3rem;
    			text-align: center;

    			&.bold {
    				font-size: 1.6rem;
    			}
    		}
    	}
    }*/
  }
  .p-system__btn {
    width: 100%;
    max-width: 300px;
    margin: 20px auto;
  }
  .p-system__btn.btn02 {
    width: 80%;
    margin: 40px auto;
  }
  .p-system__btn div {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    padding: 10px;
  }
  .p-system__btn div p {
    width: 100%;
    text-align: center;
    margin-bottom: 10px;
  }
  .p-system__btn a.btn {
    font-size: 1.4rem;
  }
  .p-system__btn a.btn div {
    padding: 5px 10px;
    font-size: 1.3rem;
  }
  .p-system__flex03 {
    /*&-left {
    	width: 30%;
    	margin-left: 0;

    	img {
    		margin-top: 20px;
    	}
    }*/
    /*&-right {
    	width: 74%;
    	margin-left: -4%;
    }*/
  }
  .p-system__flex03-title {
    width: 250px;
  }
  .p-system__flex03-title p {
    font-size: 3rem;
  }
  .p-system__flex03-title img {
    width: 60px;
    right: -30px;
  }
  .p-system__flex03-txt {
    padding: 10px;
    margin: 10px auto 10px 0;
  }
  .p-system__flex03-txt img {
    width: 80px;
    margin-right: 30px;
  }
  .p-system__flex03-txt:nth-child(1) img, .p-system__flex03-txt:nth-child(3) img {
    width: 80px;
    margin-right: 0;
    margin-left: 30px;
  }
  .p-system__flex03-txt p {
    font-size: 1.4rem;
    width: 68%;
    padding: 10px;
  }
  .p-system__flex03-txt p.left::after {
    right: -30px;
  }
  .p-system__flex03-txt p.right::after {
    left: -30px;
  }
  .p-system__flex03-txt:nth-of-type(2), .p-system__flex03-txt:nth-of-type(4) {
    margin: 10px 0 10px auto;
  }
  .p-system h5 {
    border-radius: 4px;
    padding: 5px 20px;
  }
  .p-system__flex04 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-system__flex04-img {
    width: 90%;
    margin: 0 auto 20px;
  }
  .p-system__flex04-txt {
    width: 100%;
  }
  .p-system__flex04-txt ul {
    font-size: 1.3rem;
  }
  body.system .right-icon,
  body.system .left-icon {
    display: none;
  }
}
/*----------------------------------------------------------------------------------------
flow.scss
----------------------------------------------------------------------------------------*/
.p-flow {
  position: relative;
  padding: 1px 0 0;
}
.p-flow .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat-x;
  background-position: 50% 0;
  padding: 20px 0 0;
}
.p-flow .bg_02 {
  background-image: url(../images/guidance/bg_09.png);
  background-repeat: no-repeat;
  background-position: bottom center;
  padding-bottom: 100px;
}
.p-flow h2 {
  text-align: center;
  color: #5A5957;
  font-size: 4.8rem;
  /*font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);*/
  font-size: clamp(3.2rem, 2.381vw + 1.371rem, 4.8rem);
  line-height: 1.5;
  font-weight: 700;
  margin: 40px auto 60px;
}
.p-flow h2 img {
  margin-right: 0.5em;
  width: 8%;
  max-width: 74px;
}
.p-flow h3 {
  font-size: 2.4rem;
  font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);
  line-height: 1.5;
  font-weight: 700;
  margin: 0 2.2% 20px;
}
.p-flow__block {
  position: relative;
  z-index: 3;
  margin: 40px auto;
}
.p-flow__block.block02 {
  background: #fff;
  border-radius: 16px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  margin: 20px auto 0;
  padding: 40px;
}
.p-flow__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 40px;
}
.p-flow__flex-txt {
  width: 60%;
  margin: 1% 2.5%;
}
.p-flow__flex-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
}
.p-flow__flex-img {
  position: relative;
  width: 40%;
  text-align: center;
}
.p-flow h2.title {
  position: relative;
  color: #fff;
  background: #A5A8AC;
  border-radius: 8px;
  font-size: 3.2rem;
  /*font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);*/
  font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);
  line-height: 1.5;
  font-weight: 700;
  padding: 22px;
  margin: 20px auto;
  z-index: 3;
}
.p-flow h2.title span {
  position: absolute;
  display: block;
  background: #FFFFFF;
  border-radius: 40px 40px 0 0;
  width: 30%;
  height: 6px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
}
.p-flow h4 {
  background-image: url(../images/guidance/img_17.png);
  background-repeat: no-repeat;
  background-position: left center;
  border-radius: 12px;
  color: #fff;
  font-size: 2rem;
  font-size: clamp(1.6rem, 0.595vw + 1.143rem, 2rem);
  line-height: 1.5;
  padding: 17px 32px;
  width: 96%;
  margin: 0 auto;
  background-size: cover;
}
.p-flow__flowimg {
  width: 90%;
  max-width: 850px;
  margin: 20px auto;
}
.p-flow__flowimg p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
  margin: 20px auto;
}

body.flow {
  /*.icon_area {
  	position: fixed;
  	top: 0;
  	right: 0;
  	bottom: 0;
  	left: 0;
  	width: 100%;
  	max-width: 1440px;
  	margin: 0 auto;
  	z-index: 1;
  }*/
  /*.bottom-icon {
  	position: relative;
  	bottom: 0;
  	left: 15%;
  	width: 560px;
  	opacity: 0.5;
  	display: flex;
  	justify-content: space-between;
  	z-index: 10;

  	.on_bottom_01 {
  		position: relative;
  	}

  	.on_bottom_02 {
  		position: relative;
  	}

  	.on_bottom_03 {
  		position: relative;
  	}

  	.on_bottom_04 {
  		position: relative;
  	}

  	.on_bottom_05 {
  		position: relative;
  		left: 10%;
  	}
  }*/
}

@media screen and (max-width: 480px) {
  .p-flow .bg_01 {
    background-size: auto 120px;
  }
  .p-flow .bg_02 {
    padding-bottom: 50px;
  }
  .p-flow h2 {
    font-size: 2.6rem;
    margin: 20px auto;
  }
  .p-flow h2 img {
    width: 15%;
  }
  .p-flow__block {
    margin: 20px auto;
  }
  .p-flow__block.block02 {
    margin: 20px auto 0;
    padding: 20px;
  }
  .p-flow__flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-flow__flex-txt {
    width: 100%;
    margin-bottom: 20px;
  }
  .p-flow__flex-txt p {
    font-size: 1.4rem;
  }
  .p-flow__flex-img {
    width: 90%;
    margin: 0 auto;
  }
  .p-flow h2.title {
    padding: 10px;
    font-size: 2rem;
  }
  .p-flow h2.title span {
    width: 60%;
    height: 3px;
  }
  .p-flow h4 {
    border-radius: 6px;
    padding: 5px 20px;
  }
  .p-flow {
    /*&__flowimg {
    	box-sizing: border-box;
    	height: 500px;
    	overflow-y: scroll;

    	img{
    		height: 200px;
    		margin: 0;
    		width: auto;
    		object-fit: contain;
    	}

    	p.u-sp-appea{
    		text-align: right;
    	}
    }*/
  }
  body.flow .bottom-icon {
    width: 80%;
    left: 0;
    margin: 0 auto;
  }
  body.flow .bottom-icon img {
    width: 80%;
  }
  body.flow .bottom-icon .on_bottom_05 {
    left: 5%;
  }
}
/*----------------------------------------------------------------------------------------
merit.scss
----------------------------------------------------------------------------------------*/
.p-merit {
  position: relative;
  padding: 1px 0 50px;
}
.p-merit .bg_01 {
  background-image: url(../images/lower/bg_01.png);
  background-repeat: repeat-x;
  background-position: 50% 0;
  padding: 20px 0 0;
}
.p-merit .bg_02 {
  background-image: url(../images/guidance/bg_06.png);
  background-repeat: repeat-x;
  background-position: center bottom;
  padding-bottom: 100px;
}
.p-merit h2 {
  text-align: center;
  color: #5A5957;
  font-size: 4.8rem;
  /*font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);*/
  font-size: clamp(3.2rem, 2.381vw + 1.371rem, 4.8rem);
  line-height: 1.5;
  font-weight: 700;
  margin: 40px auto 60px;
}
.p-merit h2 img {
  margin-right: 0.5em;
  width: 8%;
  max-width: 74px;
}
.p-merit h3 {
  font-size: 2.4rem;
  font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);
  line-height: 1.5;
  font-weight: 700;
  margin: 0 0 20px;
}
.p-merit__block {
  position: relative;
  z-index: 3;
  margin: 40px auto;
}
.p-merit__block.block02 {
  background: #fff;
  border-radius: 16px;
  /*box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);*/
  margin: 20px auto 0;
  padding: 40px;
}
.p-merit__flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.p-merit__flex-txt {
  width: 60%;
  margin: 0 2.5%;
}
.p-merit__flex-txt p {
  font-size: 1.6rem;
  line-height: 1.8;
  font-weight: 400;
}
.p-merit__flex-img {
  position: relative;
  width: 40%;
  text-align: center;
}
.p-merit h2.title {
  position: relative;
  color: #fff;
  background: #A5A8AC;
  border-radius: 8px;
  font-size: 3.2rem;
  /*font-size: clamp(1.8rem, 0.893vw + 1.114rem, 2.4rem);*/
  font-size: clamp(2.4rem, 1.19vw + 1.486rem, 3.2rem);
  line-height: 1.5;
  font-weight: 700;
  padding: 22px;
  margin: 20px auto;
  z-index: 3;
}
.p-merit h2.title span {
  position: absolute;
  display: block;
  background: #FFFFFF;
  border-radius: 40px 40px 0 0;
  width: 30%;
  height: 6px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
}

/*body.merit {

	.icon_area {
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		max-width: 1440px;
		margin: 0 auto;
		z-index: 1;
	}

	.right-icon {
		position: relative;
		left: 88%;
		top: 12%;
		width: 150px;
		height: auto;
		z-index: 3;
		opacity: 0.5;

		.on_right_01 {
			position: relative;
			margin-bottom: 80px;
		}

		.on_right_02 {
			position: relative;
			margin-bottom: 80px;
		}

		.on_right_03 {
			position: relative;
			margin-bottom: 80px;
		}

		.on_right_04 {
			position: relative;
			margin-bottom: 80px;
		}

		.on_right_05 {
			position: relative;
		}
	}
}*/
@media screen and (max-width: 480px) {
  .p-merit .bg_01 {
    background-size: auto 120px;
  }
  .p-merit .bg_02 {
    padding-bottom: 50px;
  }
  .p-merit h2 {
    font-size: 2.6rem;
    margin: 20px auto;
  }
  .p-merit h2 img {
    width: 15%;
  }
  .p-merit__block {
    margin: 20px auto;
  }
  .p-merit__block.block02 {
    padding: 20px;
  }
  .p-merit__flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-merit__flex-txt {
    width: 100%;
    margin-bottom: 20px;
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
  }
  .p-merit__flex-txt p {
    font-size: 1.4rem;
  }
  .p-merit__flex-img {
    width: 90%;
    margin: 0 auto;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .p-merit h2.title {
    padding: 10px;
  }
  .p-merit h2.title span {
    width: 60%;
    height: 3px;
  }
  .p-merit h4 {
    border-radius: 6px;
    padding: 5px 20px;
  }
  body.merit .right-icon,
  body.merit .left-icon {
    display: none;
  }
}
/*----------------------------------------------------------------------------------------
component.scss
----------------------------------------------------------------------------------------*/
a.btn {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  background: repeating-linear-gradient(45deg, transparent, transparent 3px, rgba(0, 0, 0, 0.1) 3px, rgba(0, 0, 0, 0.1) 30px);
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
}
a.btn.btn02 {
  border-radius: 24px;
}
a.btn.btn03 {
  background: none;
}
a.btn div {
  -webkit-transform: translate(-4px, -4px);
          transform: translate(-4px, -4px);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

a.btn:hover {
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
}
a.btn:hover div {
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
}

a img.big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
}

a:hover img.big {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}

.img-btn {
  width: 240px;
  height: 48px;
  /*position: relative;
  /*perspective: 800px;

  /*img {
  	position: absolute;
  	width: 100%;
  	height: 100%;
  	top: 0;
  	left: 0;
  	backface-visibility: hidden;
  	transform-style: preserve-3d;
  	transition: transform 0.6s ease;

  	&.front {
  		opacity: 1;

  	}

  	&.back {
  		opacity: 0;
  	}
  }*/
}

/*a:hover{

	.img-btn img.front {
		opacity: 0;
	}

	.img-btn img.back {
		opacity: 1;
	}
}*/
.js-fadeUp {
  opacity: 0;
  -webkit-transform: translateY(100px);
          transform: translateY(100px);
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
}

/* フェードイン(スクロールした後) */
.js-fadeUp.is-inview {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
}

.js-fadeLeft {
  opacity: 0;
  -webkit-transform: translateX(-100px);
          transform: translateX(-100px);
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
}

/* フェードイン(スクロールした後) */
.js-fadeLeft.is-inview {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
}

.js-fadeRight {
  opacity: 0;
  -webkit-transform: translateX(100px);
          transform: translateX(100px);
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
}

/* フェードイン(スクロールした後) */
.js-fadeRight.is-inview {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
}

.js-fadeLeftout {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
}

/* フェードイン(スクロールした後) */
.js-fadeLeftout.is-inview {
  opacity: 1;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
}

.js-fadeRightout {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
}

/* フェードイン(スクロールした後) */
.js-fadeRightout.is-inview {
  opacity: 1;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
}

.up02.is-inview {
  -webkit-transition-delay: 1s;
          transition-delay: 1s;
}

.up03.is-inview {
  -webkit-transition-delay: 1.5s;
          transition-delay: 1.5s;
}

.up04.is-inview {
  -webkit-transition-delay: 2s;
          transition-delay: 2s;
}

.up05.is-inview {
  -webkit-transition-delay: 2.5s;
          transition-delay: 2.5s;
}

.up06.is-inview {
  -webkit-transition-delay: 3s;
          transition-delay: 3s;
}

.animate__tada {
  -webkit-animation-name: tada;
  animation-name: tada;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-duration: 10S;
          animation-duration: 10S;
}

@-webkit-keyframes tada {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
  87%, 88% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate(-3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate(-3deg);
  }
  89%, 91%, 93%, 95% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate(3deg);
  }
  90%, 92%, 94% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg);
  }
  to {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
}

@keyframes tada {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
  87%, 88% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate(-3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate(-3deg);
  }
  89%, 91%, 93%, 95% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate(3deg);
  }
  90%, 92%, 94% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg);
  }
  to {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
}
.animate__bounceOutUp {
  -webkit-animation-name: bounceOutUp;
  animation-name: bounceOutUp;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-duration: 8S;
          animation-duration: 8S;
}

@-webkit-keyframes bounceOutUp {
  85% {
    -webkit-transform: translate3d(0, -10px, 0) scaleY(0.985);
    transform: translate3d(0, -10px, 0) scaleY(0.985);
  }
  87%, 89% {
    opacity: 1;
    -webkit-transform: translate3d(0, 20px, 0) scaleY(0.9);
    transform: translate3d(0, 20px, 0) scaleY(0.9);
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0) scaleY(3);
    transform: translate3d(0, -2000px, 0) scaleY(3);
  }
}

@keyframes bounceOutUp {
  85% {
    -webkit-transform: translate3d(0, -10px, 0) scaleY(0.985);
    transform: translate3d(0, -10px, 0) scaleY(0.985);
  }
  87%, 89% {
    opacity: 1;
    -webkit-transform: translate3d(0, 20px, 0) scaleY(0.9);
    transform: translate3d(0, 20px, 0) scaleY(0.9);
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0) scaleY(3);
    transform: translate3d(0, -2000px, 0) scaleY(3);
  }
}
.scroll {
  display: none;
}

.scroll.fixed {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}
.scroll.fixed img {
  width: 14.5px;
}

/* 点滅 */
.blinking {
  position: absolute;
  width: 14.5px;
  top: 64%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 99;
  -webkit-animation: blink 0.5s ease-in-out infinite alternate;
  animation: blink 0.5s ease-in-out infinite alternate;
}

@-webkit-keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@media screen and (max-width: 480px) {
  .scroll.fixed {
    height: 100vh;
  }
  /* 点滅 */
  .blinking {
    top: 76vh;
  }
}
/*----------------------------------------------------------------------------------------
utility.scss
----------------------------------------------------------------------------------------*/
.container {
  position: relative;
  display: -ms-grid;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
  gap: 32px 16px;
  margin: 300px auto;
}

.rect {
  display: block;
  position: relative;
}

/*----------------------------------------------------------------------------------------
none.scss
----------------------------------------------------------------------------------------*/
@media (min-width: 769px) {
  .u-tab-appea {
    display: none;
  }
}
@media (max-width: 768px) {
  .u-tab-none {
    display: none;
  }
}
@media (min-width: 481px) {
  .u-sp-appea {
    display: none;
  }
}
@media (max-width: 480px) {
  .u-sp-none {
    display: none;
  }
}
/*# sourceMappingURL=style.css.map */