@charset "UTF-8";
/*
Theme Name: companycyber
Theme URI: https://www.cyber-nt.co.jp/
Author: kobayashi
Description: This theme is designed for company web site.
*/
/*マップの設定*/
/*mixin設定*/
/*変数*/
/*font-family-name*/
/*#676c77*/
/*
ブラウザ毎デフォルトスタイルのリセット　
-------------------------------------------------------------------------------*/
a,
abbr,
address,
article,
aside,
audio,
b,
blockquote,
body,
button,
canvas,
caption,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
input,
ins,
kbd,
label,
legend,
li,
main,
mark,
menu,
nav,
object,
ol,
p,
pre,
q,
samp,
section,
select,
small,
span,
strong,
sub,
summary,
sup,
table,
tbody,
td,
textarea,
tfoot,
th,
thead,
time,
tr,
ul,
var,
video {
  color: #000000;
  margin: 0;
  padding: 0;
  border: 0;
  list-style: none;
  line-height: 1;
  text-decoration: none;
  -webkit-font-smoothing: antialiased;
  box-sizing: border-box;
  word-spacing: 1px;
}

html {
  overflow-y: scroll;
}

article,
aside,
canvas,
details,
figcaption,
figure,
header,
footer,
hgroup,
menu,
nav,
section,
summary {
  display: block;
}

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
pre,
form,
fieldset,
input,
textarea,
p,
blockquote,
th,
td {
  margin: 0;
  padding: 0;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
}

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

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: normal;
  font-size: 100%;
  margin: 0;
  padding: 0;
}

p {
  line-height: 1.8;
}

a {
  text-decoration: none;
  outline: none;
  cursor: pointer;
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

img,
abbr,
acronym,
fieldset,
a img {
  border: none;
}

img,
li,
dt,
dd {
  vertical-align: bottom;
}

* html li,
*:first-child + html li {
  vertical-align: baseline;
}

q:before,
q:after {
  content: "";
}

object,
embed {
  vertical-align: top;
}

ul {
  list-style-type: none;
}

ol {
  list-style-type: decimal;
}

ol,
ul,
dl {
  margin-bottom: 1em;
}

dd {
  margin-left: 3em;
}

/*------------------------------------------------------------------------------
	基本スタイル　
-------------------------------------------------------------------------------*/
body {
  background-color: #ffffff;
  color: #000000;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 0.85em;
  font-size: 16px;
}

/*------------------------------------------------------------------------------
	リンクカラー
-------------------------------------------------------------------------------*/
a:hover img {
  opacity: 0.8;
  filter: alpha(opacity=80);
}

.navigation a:hover {
  opacity: 1;
}

a:hover .hover-line {
  opacity: 1;
  transform: scale(1, 1);
}

a.link-underline {
  text-decoration: underline;
}

a.link-web {
  color: #0b318f;
}
a.link-web::after {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background-image: url(../images/icon-link-web.png);
  background-size: contain;
  background-repeat: no-repeat;
}

/*------------------------------------------------------------------------------
	見出し
-------------------------------------------------------------------------------*/
h1,
h2,
h3,
h4,
h5,
h6 {
  clear: both;
}

h1.pagetitle {
  font-size: large;
  font-weight: bold;
  line-height: 60px;
  height: 60px;
  padding: 5px 15px;
  border: 5px solid #acc798;
  background-color: #dee9d6;
}

.post h1 {
  font-size: large;
  font-weight: bold;
  line-height: 2;
  padding-left: 1em;
  border-bottom: 5px solid #acc798;
  background-color: #dee9d6;
}

h2.posttitle {
  /* 投稿のタイトル */
  line-height: 1.4;
  padding: 10px;
  background-color: #fff;
}

h4 {
  font-size: 1.1em;
  font-weight: bold;
  line-height: 1.8;
}

h5,
h6 {
  font-size: 1em;
  font-weight: bold;
  line-height: 1.8;
  /*	padding-left: 1em;
  margin: 1em 2em 1em 0;*/
}

.text-right {
  text-align: right !important;
}

.text-center {
  text-align: center !important;
}

.text-left {
  text-align: left !important;
}

.hd-text {
  font-size: 1rem;
}

.blue-text {
  color: #0e89e5 !important;
}

.green-text {
  color: #039e54 !important;
}

.under-line {
  background: linear-gradient(transparent 50%, #f6fc63 50%);
  line-height: 1.8;
}

/*------------------------------------------------------------------------------
	fonts
-------------------------------------------------------------------------------*/
.font-en {
  font-family: "Roboto Flex", sans-serif;
  font-weight: 300;
}

.font-headline {
  font-family: "Roboto Flex", sans-serif;
  font-weight: 100;
}

.font-thin {
  font-weight: 100;
}

/*------------------------------------------------------------------------------
	レイアウトボックス
-------------------------------------------------------------------------------*/
.center {
  text-align: center;
}

.right {
  text-align: right;
}

.left {
  text-align: left;
}

.flex-center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.inline-block {
  display: inline-block;
}

.disabled-link {
  pointer-events: none;
}

.row {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
}

.flex-column {
  display: flex;
  flex-direction: column;
}

.w-full {
  width: 100%;
}

.w-100 {
  width: 100%;
}

.max-w-100 {
  max-width: 100%;
}

.h-100 {
  height: 100%;
}

.wh-auto {
  width: auto;
  height: auto;
}

/* ===============================================
	header
=============================================== */
.header {
  align-content: center;
  align-items: center;
  background: rgb(255, 255, 255);
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  height: auto;
  justify-content: space-between;
  left: 0px;
  margin: 0 0 0 0;
  padding: 0px 3% 0px 3%;
  position: fixed;
  top: 0px;
  width: 100%;
  z-index: 20;
  max-width: 100%;
  height: 100px;
}
.header .logo {
  width: 212px;
  height: 43px;
}
@media screen and (max-width: 992px) {
  .header .logo {
    height: 30px;
  }
}
@media screen and (max-width: 992px) {
  .header {
    padding-left: 1vw;
    height: 55px;
  }
}

header .menu-nav-container {
  display: flex;
  align-content: flex-start;
  align-items: flex-start;
  background: rgba(0, 0, 0, 0);
  flex: none;
  flex-direction: row;
  flex-wrap: nowrap;
  height: auto;
  justify-content: flex-start;
  width: auto;
  max-width: 100%;
  transition-property: none;
}
header .menu-nav-container ul {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  margin: 0;
}

.header .menu-nav-container li {
  align-content: center;
  align-items: center;
  background: rgba(0, 0, 0, 0);
  flex: none;
  flex-direction: column;
  flex-wrap: nowrap;
  height: auto;
  justify-content: flex-start;
  margin: 0px;
  width: auto;
  display: inline-block;
}
.header .menu-nav-container li:last-child {
  width: 222px;
  height: 42px;
  border-radius: 50px;
  background-color: #fa630e;
  display: flex;
  justify-content: center;
  align-items: center;
}
.header .menu-nav-container li:last-child a {
  color: #ffffff;
  display: flex;
  align-items: center;
  flex-direction: row;
  line-height: 100%;
}
.header .menu-nav-container li:last-child:hover {
  background-color: rgb(233.6524390244, 87.256097561, 4.8475609756);
}

.header .main-navigation > li > a {
  display: flex;
  padding: 0 1.5vw;
  position: relative;
  font-size: 17px;
  font-weight: 500;
  line-height: 49px;
  text-align: left;
  white-space: nowrap;
  letter-spacing: 0.13px;
}

.header .main-navigation > li:not(:last-child) > a:hover {
  color: #035dfb;
}

@media screen and (max-width: 992px) {
  .header {
    padding: 5px 20px;
    height: 70px;
  }
  .header .logo img {
    height: 100%;
  }
  .header .menu-nav-container {
    position: fixed;
    z-index: 20;
    top: 55px;
    left: 100%;
    background: #ffffff;
    text-align: center;
    width: 100%;
    height: 100vh;
    opacity: 1;
    flex-direction: column;
    flex-wrap: wrap;
    align-content: start;
    transition: all 0.6s;
  }
  .header .menu-nav-container ul {
    flex-direction: column;
  }
  .header .menu-nav-container li {
    /*first-child:トップlink*/
    display: block;
    list-style-type: none;
    padding: 0;
    width: 100%;
    transition: 0.4s all;
    margin: 0;
    max-width: 100%;
    text-align: center;
  }
  .header .menu-nav-container li:last-child {
    margin-top: 8px;
  }
  .header .menu-nav-container li:hover {
    background: rgb(221, 221, 221);
    z-index: 20;
    opacity: 1;
  }
  .header .menu-nav-container li a {
    text-align: center;
    font-size: 24px;
    padding: 8px 5% 8px;
    color: #000;
    display: block;
  }
  .header .menu-nav-container.active {
    opacity: 1;
    display: block;
    left: 0;
    text-align: left;
    padding: 8px 20px;
  }
  .header .menu-nav-container.active ul {
    border: 3px solid;
    border-radius: 50px;
    max-width: 600px;
    margin: 20px auto 0;
    padding: 2rem 1rem 5rem;
  }
}
.nav-mobile {
  display: none;
}
@media screen and (max-width: 992px) {
  .nav-mobile {
    display: flex;
    align-content: center;
    align-items: center;
    border-radius: 50%;
    flex-direction: column;
    flex-wrap: nowrap;
    height: 56px;
    justify-content: center;
    margin: 0 0 0 0;
    position: fixed;
    right: 32px;
    width: 56px;
    z-index: 25;
    max-width: 100%;
    top: 15px;
    right: 20px;
    width: 40px;
    height: 40px;
    background-color: #000;
  }
  .nav-mobile span {
    display: block;
    position: absolute;
    left: 11px;
    width: 18px;
    height: 4px;
    border-radius: 4px;
    background: #ffffff;
    transition: 0.3s ease-in-out;
  }
  .nav-mobile span:nth-child(1) {
    top: 14px;
  }
  .nav-mobile span:nth-child(2) {
    top: 24px;
  }
}

.nav-mobile.active span:nth-child(1) {
  top: 18px;
  left: 11px;
  transform: rotate(-45deg);
}
.nav-mobile.active span:nth-child(2) {
  top: 18px;
  left: 11px;
  transform: rotate(45deg);
}

.main-container {
  overflow: hidden;
}

.main-container,
.main-container * {
  box-sizing: border-box;
}

input,
select,
textarea,
button {
  outline: 0;
}

.main-container {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 0 auto;
  background: #ffffff;
  overflow: hidden;
  padding: 100px 0 0 0;
}
@media screen and (max-width: 992px) {
  .main-container {
    padding-top: 70px;
  }
}

.section {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  align-content: flex-start;
  align-self: flex-start;
  width: 100%;
}

.section1 {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin: 0;
  overflow: hidden;
  background-color: #005efe;
  background-image: url(../images/bg-clowd.svg);
  background-size: cover;
  background-position: center;
}
.section1 .hero-container {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 3%;
  width: 100%;
}

#about01 {
  padding-top: 100px;
  margin-top: -100px;
}
@media screen and (max-width: 992px) {
  #about01 {
    padding-top: 70px;
    margin-top: -70px;
  }
}

.section2 {
  position: relative;
  background-color: #cfe1ff;
  padding-top: 217px;
  margin-top: -217px;
  padding-bottom: 100px;
}
@media screen and (max-width: 992px) {
  .section2 {
    padding-top: 290px;
    margin-top: -385px;
  }
}
.section2::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 30%;
  max-width: 500px;
  height: 100%;
  background: url(../images/bg-sec2-left.svg) no-repeat;
  background-size: cover;
  z-index: 2;
  overflow: hidden;
  background-position: right bottom;
}
.section2::after {
  position: absolute;
  top: 0;
  right: 0;
  content: "";
  width: 30%;
  max-width: 500px;
  height: 100%;
  background: url(../images/bg-sec2-right.svg) no-repeat;
  background-size: cover;
  z-index: 2;
  overflow: hidden;
}

.like-rule {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  margin: 10px auto 10px;
  color: #000000;
  font-size: clamp(22px, 3vw, 30px);
  font-weight: 900;
  line-height: 86px;
  text-align: left;
  white-space: nowrap;
  letter-spacing: 0.47px;
}

.copy-row {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  max-width: 720px;
  width: 100%;
  margin: 0 -10px 10px;
}

.top-main-img {
  padding: 0 1%;
}
.top-main-img img {
  max-width: 100%;
}

.copy-span {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  color: #000000;
  font-size: clamp(14px, 2.5vw, 28px);
  font-weight: 900;
  text-align: left;
  line-height: 1.5;
  white-space: nowrap;
}

.copy-span-01 {
  letter-spacing: -0.44px;
}

.copy-span-02 {
  letter-spacing: 0.11px;
}

.copy-span-04 {
  letter-spacing: 0.11px;
}

.matching-system {
  font-size: clamp(18px, 1.8vw, 20px);
  font-weight: 700;
  line-height: 2.2;
  letter-spacing: -0.04px;
  margin-top: 50px;
  margin-bottom: 150px;
  text-align: center;
}

.area-link-contact {
  width: 100%;
  max-width: 1098px;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  position: relative;
  top: -126px;
  z-index: 4;
  margin: 0 auto;
}
@media screen and (max-width: 992px) {
  .area-link-contact {
    flex-direction: column;
  }
}
.area-link-contact .area-left,
.area-link-contact .area-right {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
}

.register-date {
  font-size: 24px;
  font-weight: 700;
  line-height: 69px;
  text-align: left;
  white-space: nowrap;
  letter-spacing: 0.15rem !important;
}

.copy-hall,
.copy-writer {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
}
.copy-hall span,
.copy-writer span {
  height: 100%;
  font-size: 24px;
  font-size: clamp(16px, 1vw, 24px);
  font-weight: 700;
  line-height: 69px;
  text-align: left;
  white-space: nowrap;
  font-feature-settings: "palt";
  letter-spacing: 0.1rem;
}

.vector-line-1 {
  width: 27px;
  height: 29px;
  background: url(../images/vector-line-l.svg);
  background-size: 100% 100%;
  margin-right: 8px;
}

.vector-line-2 {
  width: 27px;
  height: 29px;
  background: url(../images/vector-line-r.svg);
  background-size: 100% 100%;
  margin-left: 5px;
}

.btn-hall {
  cursor: pointer;
  position: relative;
  width: 90%;
  max-width: 470px;
  height: 148px;
  background-color: #ffa600;
  border-radius: 35px;
  border: 3px solid #000000;
}
.btn-hall a {
  width: 100%;
  height: 100%;
  padding: 32px 127px 32px 8%;
  display: flex;
  flex-direction: column;
}
.btn-hall div.text {
  display: flex;
  flex-direction: row;
  align-items: center;
}
.btn-hall span {
  color: #ffffff;
  font-size: 26px;
  font-weight: 900;
  line-height: 1.5;
  text-align: left;
  white-space: nowrap;
  letter-spacing: 0.1px;
}
.btn-hall span.click-here {
  position: relative;
  font-size: 18px;
  font-weight: 900;
  line-height: 2;
  text-align: left;
  white-space: nowrap;
  letter-spacing: 0.28px;
  margin-left: 5px;
}
.btn-hall:hover {
  background-color: rgb(239.7, 156.04, 0);
}

.btn-writer {
  cursor: pointer;
  position: relative;
  width: 90%;
  max-width: 470px;
  height: 148px;
  background-color: #035dfb;
  border-radius: 35px;
  border: 3px solid #000000;
}
.btn-writer a {
  width: 100%;
  height: 100%;
  padding: 32px 127px 32px 8%;
  display: flex;
  flex-direction: column;
}
.btn-writer div.text {
  display: flex;
  flex-direction: row;
  align-items: center;
}
.btn-writer span {
  color: #ffffff;
  font-size: 26px;
  font-weight: 900;
  line-height: 1.5;
  text-align: left;
  white-space: nowrap;
  letter-spacing: 0.1px;
  font-feature-settings: "palt";
}
.btn-writer span.click-here {
  position: relative;
  font-size: 18px;
  font-weight: 900;
  line-height: 2;
  text-align: left;
  white-space: nowrap;
  letter-spacing: 0.28px;
  margin-left: 5px;
}
.btn-writer:hover {
  background-color: rgb(2.8192913386, 87.3980314961, 235.8807086614);
}

@media screen and (max-width: 992px) {
  .btn-hall,
  .btn-writer {
    height: auto;
  }
  .btn-hall a,
  .btn-writer a {
    padding: 20px 127px 20px 8%;
  }
  .btn-hall span,
  .btn-writer span {
    font-size: clamp(23px, 1vw, 26px);
  }
}

.btn-hall--large,
.btn-writer--large {
  width: 90%;
  max-width: 703px;
  max-height: 102px;
  border-radius: 50px;
  justify-content: center;
}
.btn-hall--large a,
.btn-writer--large a {
  padding: 24px 127px 24px 54px;
}

@media screen and (max-width: 576px) {
  .btn-hall--large a,
  .btn-writer--large a {
    padding: 20px 10% 20px 5%;
  }
}
@media screen and (max-width: 576px) {
  .btn-hall--large div.text,
  .btn-writer--large div.text {
    flex-direction: column;
  }
}
@media screen and (max-width: 992px) {
  .btn-hall--large div.text span,
  .btn-writer--large div.text span {
    font-size: clamp(16px, 2.4vw, 20px);
  }
}

/*
.click-here {
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	position: absolute;
	height: 35.22%;
	top: 44.35%;
	left: 65.99%;
	color: #ffffff;
	font-size: 18px;
	font-weight: 900;
	line-height: 52px;
	text-align: left;
	white-space: nowrap;
	letter-spacing: 0.28px;
	z-index: 4;
}*/
.arrow-btn {
  position: absolute;
  width: 3.84%;
  height: 22.36%;
  top: 38.01%;
  left: 90.64%;
  background: url(../images/arrow-btn.svg) no-repeat center;
  background-size: 100% 100%;
}

.section-ttl {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 2rem;
}
.section-ttl span {
  font-size: clamp(25px, 3.5vw, 40px);
  font-weight: 700;
  line-height: 115px;
  white-space: nowrap;
  letter-spacing: 0.47px;
  font-feature-settings: "palt";
}
.section-ttl .under-wave {
  width: 100%;
  max-width: 620px;
  height: 12px;
  background: url(../images/wave01.svg) no-repeat center;
  background-size: contain;
}

.lead {
  text-align: center;
}
.lead .lg-column {
  align-items: center;
  text-align: center;
}
@media screen and (min-width: 992px) {
  .lead .lg-column .lead-span01 {
    display: block;
    text-align: center;
  }
}

.lead-span01 {
  font-size: clamp(15px, 2vw, 18px);
  font-weight: 700;
  line-height: 2.4;
  text-align: left;
  letter-spacing: 0.07px;
}
@media screen and (min-width: 992px) {
  .lead-span01 {
    display: inline;
  }
}

.lead-span01--2 {
  letter-spacing: 0.14px;
}

.lead-span01--3 {
  letter-spacing: 0.56px;
}

.lead-span02 {
  font-size: clamp(20px, 1.8vw, 24px);
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.38px;
  display: block;
  text-align: center;
}
@media screen and (min-width: 992px) {
  .lead-span02 {
    display: inline;
    text-align: left;
  }
}

.lead-span02--2 {
  letter-spacing: 0.05px;
}

.container {
  position: relative;
  width: 100%;
  max-width: 980px;
  padding: 0 16px;
  margin: 0 auto;
}
.container .main-img {
  margin-top: 60px;
  text-align: center;
}
.container .main-img img {
  max-width: 100%;
}

.section-ttl {
  position: relative;
}

.section-ttl .under-wave--2 {
  background-image: url(../images/wave02.svg);
}

.section-func-ttl {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: center;
  background: url(../images/under-line.svg) no-repeat bottom center;
  padding-bottom: 5px;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 50px;
}

.ttl-mod {
  font-size: clamp(23px, 2vw, 27px);
  font-weight: 700;
  line-height: 1;
  text-align: left;
  white-space: nowrap;
  letter-spacing: 0.42px;
}

.ttl-num {
  font-size: clamp(60px, 6vw, 80px);
  font-weight: 700;
  line-height: 1;
  text-align: left;
  white-space: nowrap;
  margin-bottom: -5px;
}

.ttl-head {
  font-size: clamp(30px, 3vw, 48px);
  font-weight: 700;
  line-height: 1;
  text-align: left;
  white-space: nowrap;
  letter-spacing: 0.19px;
}

.copy-large {
  text-align: center;
}
.copy-large span {
  font-size: 40px;
  font-size: clamp(20px, 2.4vw, 40px);
  font-weight: 700;
  line-height: 1.8;
  text-align: center;
  white-space: nowrap;
}

ul.func-list {
  display: flex;
  flex-direction: column;
  gap: 27px;
}
ul.func-list li {
  position: relative;
  background-color: #ffffff;
  border-radius: 30px;
  width: 80%;
  max-width: 724px;
  flex-grow: 1;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  padding: 52px 40px 40px;
}
@media screen and (max-width: 992px) {
  ul.func-list li {
    flex-direction: column;
    width: 90%;
    gap: 16px;
  }
}
ul.func-list li:nth-of-type(even) {
  margin-left: auto;
}
ul.func-list li:nth-of-type(even) .img-func-num {
  left: unset;
  right: 49px;
}
@media screen and (max-width: 576px) {
  ul.func-list li:nth-of-type(even) .img-func-num {
    right: 10%;
  }
}
ul.func-list li:nth-of-type(even) .text-area {
  max-width: 350px;
}
ul.func-list li .text-area p {
  min-height: 7rem;
}

.text-area {
  display: flex;
  flex-direction: column;
  max-width: 350px;
}
.text-area h3 {
  font-size: 27px;
  font-size: clamp(18px, 1.6vw, 27px);
  font-weight: 700;
  line-height: 1.7;
  text-align: left;
  text-overflow: initial;
  white-space: nowrap;
  letter-spacing: 0.11px;
  z-index: 18;
}
.text-area p {
  font-size: 16px;
  font-weight: 350;
  line-height: 1.8;
  text-align: left;
  letter-spacing: -0.59px;
  z-index: 17;
}
@media screen and (max-width: 992px) {
  .text-area p {
    font-size: 14px;
  }
}

.img-func-num {
  position: absolute;
  left: 70px;
  top: -30px;
}
@media screen and (max-width: 576px) {
  .img-func-num {
    left: 10%;
    top: -20px;
    width: 100px;
    height: 70px;
  }
  .img-func-num img {
    height: 100%;
  }
}

.img-func {
  width: 200px;
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.section3 {
  background-color: #ffcc00;
  padding: 50px 0 110px;
  scroll-margin-top: 100px;
}
@media screen and (max-width: 992px) {
  .section3 {
    scroll-margin-top: 70px;
  }
}

.section4 {
  background: #f7e6c6;
  padding: 50px 0 110px;
  background-repeat: repeat;
  --DOTS_COLOR: #f5cf86;
  --DOTS_SIZE: 24px;
  --DOTS_POSITION: 10%;
  background-image: radial-gradient(var(--DOTS_COLOR) var(--DOTS_POSITION), transparent var(--DOTS_POSITION)), radial-gradient(var(--DOTS_COLOR) var(--DOTS_POSITION), transparent var(--DOTS_POSITION));
  background-size: var(--DOTS_SIZE) var(--DOTS_SIZE);
  background-position: 0 0, calc(var(--DOTS_SIZE) / 2) calc(var(--DOTS_SIZE) / 2);
}

.section5 {
  background-color: #78a7f4;
  padding: 50px 0 110px;
  scroll-margin-top: 100px;
}
@media screen and (max-width: 992px) {
  .section5 {
    scroll-margin-top: 70px;
  }
}

.section6 {
  background: #ebf0f7;
  padding: 50px 0 110px;
  background-repeat: repeat;
  --DOTS_COLOR: #c4ddff;
  --DOTS_SIZE: 24px;
  --DOTS_POSITION: 10%;
  background-image: radial-gradient(var(--DOTS_COLOR) var(--DOTS_POSITION), transparent var(--DOTS_POSITION)), radial-gradient(var(--DOTS_COLOR) var(--DOTS_POSITION), transparent var(--DOTS_POSITION));
  background-size: var(--DOTS_SIZE) var(--DOTS_SIZE);
  background-position: 0 0, calc(var(--DOTS_SIZE) / 2) calc(var(--DOTS_SIZE) / 2);
}

ul.step-list {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 16px;
  margin-bottom: 60px;
}
ul.step-list li {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  background-color: #ffffff;
  border-radius: 30px;
  border: 3px solid #000;
  padding: 30px;
  width: 80%;
  max-width: 916px;
}
@media screen and (max-width: 992px) {
  ul.step-list li {
    flex-direction: column;
    gap: 8px;
  }
}
ul.step-list li .img-step {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 200px;
}
@media screen and (max-width: 992px) {
  ul.step-list li .img-step {
    margin: 0 auto;
  }
}
ul.step-list li .text-area {
  display: flex;
  flex-direction: column;
  max-width: 620px;
  flex-grow: 1;
}
ul.step-list li .text-area div {
  display: flex;
  flex-direction: row;
  gap: 10px;
  margin-bottom: 5px;
}
ul.step-list li .text-area div span {
  width: 51px;
  height: 32px;
}
ul.step-list li .text-area div span img {
  width: 100%;
}
ul.step-list li .text-area div h3 {
  font-size: clamp(20px, 1.6vw, 24px);
}
ul.step-list .icon-step-arrow {
  margin: 20px auto;
}

/* ===============================================
	contact
=============================================== */
.contact-form {
  background-color: #78a7f4;
  padding: 20px 0 50px;
}

.board {
  position: relative;
  background-color: #ffffff;
  padding: 1px;
  border-radius: 30px;
  max-width: 1024px;
  margin: 0 auto 50px;
  padding: 30px 10% 70px;
}

.hd-text {
  margin: 2rem 1rem;
}

.contact-form-input input,
.contact-form-input textarea,
.contact-form-input select {
  width: 100%;
  display: block;
  padding: 10px 2%;
  font-size: 1em;
  border: 2px solid rgba(66, 66, 66, 0.3);
  border-radius: 4px;
  background-color: #fff;
  font-family: inherit;
  box-sizing: border-box;
  line-height: 1.5;
}

.contact-form-item {
  margin-bottom: 0.8rem;
  text-align: left;
}

.contact-form-item:after {
  content: "";
  clear: both;
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

.contact-form-item label {
  box-sizing: border-box;
  line-height: 40px;
  display: inline-block;
  padding: 0;
  font-weight: 600;
}

.contact-form-item .contact-form-label {
  margin: 0;
}

.contact-form-item .contact-form-input {
  /*   float: left;
      width: 65%;*/
  box-sizing: border-box;
  padding: 0;
  margin: 0;
}

span.required {
  margin-left: 5px;
  font-size: 0.7rem;
  padding: 1px 8px;
  color: #fff;
  background-color: #ff8c00;
}

section.contact-form input[type=submit],
section.contact-form input[type=button],
section.contact-form .btn-submit {
  display: block;
  position: relative;
  font-weight: 700;
  padding: 20px 0;
  width: 100%;
  border-radius: 4px;
  cursor: pointer;
  border: 0;
  font-size: 1rem;
  /*margin: 0 auto;*/
  transition: all 0.5s ease;
  border-radius: 30px;
  padding: 0;
  transition-duration: 800ms;
  transition-timing-function: cubic-bezier(0, 0.7, 0.22, 1);
  font-size: 23px;
  letter-spacing: 0.1em;
  height: 60px;
  line-height: 60px;
  max-width: 286px;
}

section.contact-form input[type=button] {
  background-color: #ffffff;
  color: #ff8c00;
}
section.contact-form input[type=button]:hover {
  background-color: rgb(229.5, 229.5, 229.5);
}

section.contact-form input[type=submit],
section.contact-form .btn-submit,
section.contact-form input[type=button].btn-submit {
  background-color: #ff8c00;
  color: #ffffff;
}
section.contact-form input[type=submit]:hover,
section.contact-form .btn-submit:hover,
section.contact-form input[type=button].btn-submit:hover {
  background-color: rgb(229.5, 126, 0);
}

.step-area {
  display: flex;
  flex-direction: row;
  gap: 30px;
  padding: 50px 5% 20px;
}
.step-area div {
  flex-grow: 1;
  background-color: #005efe;
  position: relative;
  border-radius: 30px;
}
.step-area div p {
  color: #ffffff;
  padding: 1rem;
  text-align: center;
  line-height: 1.5;
  font-size: clamp(12px, 1.8vw, 16px);
}
.step-area div::after {
  content: "";
  width: 20px;
  height: 20px;
  background-image: url(../images/right-arrow.svg);
  background-size: contain;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: -25px;
}
.step-area div:last-child::after {
  display: none;
}
.step-area div.next {
  background-color: #9498a0;
}

.form-confirm .contact-form-input span {
  padding: 5px 2%;
}

.form-btn-p {
  display: flex;
  flex-direction: row;
  gap: 30px;
  justify-content: center;
  align-items: center;
}

.form-thanks h3 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 1em;
  margin-top: 30px;
}

.form-thanks .attention {
  margin-top: 1rem;
  color: red;
  font-size: smaller;
}

footer {
  padding: 1em;
  text-align: center;
}

.privacy-info {
  padding: 1em 1em 2em;
  line-height: 1.5;
  text-align: center;
}/*# sourceMappingURL=style.css.map */