@charset "UTF-8";

@import url(base.css);

img {
	display: inline-block;
	max-width:100%;
	max-height: 100%;}

html {
    scroll-padding-top: 18vh; /* 固定ヘッダの高さ分 */}

p {
	font-size: 3.5vw;
    line-height: 1.6em;}

.pc,.pc845 {
	display: none !important;}

.img100 {
	width: 100%;
	height: auto;}
.img90 {
	width: 90%;
	height: auto;}
.img80 {
	width: 80%;
	height: auto;}
.img70 {
	width: 70%;
	height: auto;}

/*-------------------------------------------------
	++ BANNER
-------------------------------------------------*/
.Top_Banner {
	display: none;}

/*-------------------------------------------------
	++ OUTER
-------------------------------------------------*/
#container {
	margin:0 auto;
	text-align: center;
	position:relative;
	min-width:100%;}
.cInner,
.cInner2 {
	display:block;
	clear:both;
	margin:0 auto;
	text-align: left;
	position:relative;
	padding:6vw 2vw;}

/*-------------------------------------------------
	++ HEADER
-------------------------------------------------*/
#header {
	position:fixed;
	top:0;
	left:0;
	z-index:9999;
	width:100%;
	height: 17vh;
	-webkit-overflow-scrolling : touch;
    background-color: #ffffff;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-direction: row;
    flex-wrap: wrap;}

#logo {
    order: 1;
    width: 55%;
    margin: 0.5vw 0 0 1vw;}
#snsArea {
    order: 3;
    width: 100%;
    margin: 0 1%;}
#snsArea ul {
	display: flex;
    align-items: stretch;
    flex-direction: row;}
#snsArea li {
	text-align: center;
	margin: 0 15px 0 0;
    font-size: 3.6vw;
    line-height: 2em;
	display: inline-block;
	vertical-align: middle;}

#snsArea li.tel {
    width: 8vw;
    height: 8vw;
    margin: 0 8px 0 0;}
.Twitter,
.Instagram {
    order: 2;
    width: 10%;
    margin: 3vw 1vw 0 0;}
.snsTxt {
    font-size: 3.5vw;
    padding-bottom: 0.2em;}
.telTxt {
    font-size: 4.2vw !important;}

#fullscreenmenu {
    order: 2;
    width: 20vw;
    height: 15vw;
    background-color: #1F3D8F;}
#nav-toggle {
    position: fixed;
    top: 4vw;
    right: 5vw;
    height: 10vw;
    width: 10vw;
    cursor: pointer;}
#nav-toggle > div {
    position: relative;
    width: 10vw;}
#nav-toggle span {
    width: 100%;
    height: 1px;
    left: 0;
    display: block;
    background: #FFFFFF;
    position: absolute;
    transition: transform 0.6s ease-in-out, top 0.5s ease;}
#nav-toggle span:nth-child(1) {
    top: 0;}
#nav-toggle span:nth-child(2) {
    top: 13px;}
#nav-toggle span:nth-child(3) {
    top: 27px;}

.open #nav-toggle span {
    background: #FFFFFF;}
.open #nav-toggle span:nth-child(1) {
    top: 13px;
    transform: rotate(45deg);}
.open #nav-toggle span:nth-child(2) {
    top: 14px;
    width: 0;
    left: 50%;}
.open #nav-toggle span:nth-child(3) {
    top: 13px;
    transform: rotate(-45deg);}

#gloval-nav {
    position: fixed;
    top: 17vh;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 3% 3% 10% 3%;
    font-size: 5vw;
    background-color: #1F3D8F;
    transform: translateX(-100%);
    transition: opacity 0.6s ease, visibility 0.6s ease;
    overflow: hidden;
    overflow-y: scroll;}
#gloval-nav a {
    display: block;
    color: #fff;
    padding: 8px 0;
    transition: color 0.6s ease;}
#gloval-nav ul li {
    opacity: 0;
    transform: translateX(0px);
    transition: transform 0.6s ease, opacity 0.2s ease;}

/* open */
.open {
    overflow: hidden;}
.open #gloval-nav {
    visibility: visible;
    transform: translateX(0);
    transition: transform 0.6s;}
.open #gloval-nav li {
    width: 100%;
    margin: 0;
    display: inline-block;
    vertical-align: top;
    text-align: left;
    opacity: 1;}
.sub_list {
    width: 100%;
    margin: 0;}
.sub_list a {
    font-size: 3.5vw;
    letter-spacing: 0.1em;
    padding: 5px 0 5px 15px !important;
    color: #fff;
    padding: 0;
    background: url("../img/icon_arrowW.svg") no-repeat left center;
    background-size: 2%;}
.sub_list a:link,.sub_list a:visited {color:#ffffff;text-decoration:none;}
.sub_list a:hover,.sub_list a:active {color:#ffffff;text-decoration:none;}
.sub_list2 {
    width: 100%;
    display: block;
    margin: 0 0 0.5em 0;
    padding: 1.5em 0 5px 0;
    font-size: 4vw;
    color: #FFF;
    letter-spacing: 0.1em;
    border-bottom: 1px #FFF solid;}
.sub_listmarginT {
    margin-top: 0;}
.sub_listmarginT2 {
    margin: 1.5em 0 0 0 !important;}

#nav-toggle {
    z-index: 101;}
#gloval-nav {
    z-index: 100;}

/*-------------------------------------------------
	++ main
-------------------------------------------------*/
#main {
	width: 100%;
    height: 45vh;
    padding-bottom: 15%;
    position: relative;
    background: url(../img/main.jpg) no-repeat center top/ cover;}
.mainYBox {
    position: absolute;
    left: 0;
    bottom: 20%;
    background-color: #ffc71a;
    padding: 10px;
    color: #000;
    font-size: 3.5vw;
    text-align: left;
    width: 90%;}
.mainBBox {
    position: absolute;
    right: 0;
    bottom: 3%;
    background-color: #1f3d8f;
    padding: 10px;
    color: #FFF;
    font-size: 3.5vw;
    text-align: left;
    width: 90%;}

/*-------------------------------------------------
	++ fade
-------------------------------------------------*/
.element {
  /* 最初は非表示 */
  opacity: 0;
  visibility: hidden;
  transform: translateY(30px);
  transition: opacity 1s, visibility 1s, transform 1s;}
/* フェードイン時に入るクラス */
.is-fadein {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);}

/*-------------------------------------------------
	++ title
-------------------------------------------------*/
h2 {
    width: 100%;
    text-align: center;
    margin: 0 auto;
    padding: 0;
    font-size: 6vw;
    line-height: 80px;}
.Ttlpayroll {
    color: #2a3d8d;
    background-color: #ffc71a;}
.Ttlagency {
    color: #FFFFFF;
    background-color: #68ac00;}

h3 {
    color: #2A3D8D;
    text-align: left;
    margin: 0 0 10px 0;
    padding: 0 0 3px 0;
    font-size: 6.5vw;
    font-weight: bold;
    line-height: 1.5em;
    width: 100%;
    border-bottom: 1px #2A3D8D solid;}
h3 span {
    color: #282828;
    display: inline-block;
    font-size: 3.5vw;
    padding-left: 1em;
    font-weight: normal;
    line-height: 1.5em;}
h3.Worries {
    display: block;
    color: #2A3D8D;
    text-align: center;
    margin: 0 0 10px 0;
    padding: 0 0 3px 0;
    font-size: 4.2vw;
    font-weight: bold;
    line-height: 1.5em;
    border-bottom: none;}
h3.Worries span {
    color: #C00000;
    display: inline-block;
    font-size: 4.2vw;
    padding-left: 0;
    font-weight: bold;}

h4 {
    color: #2A3D8D;
    font-size: 3.8vw;
    line-height: 2em;
    padding-left: 30px;}
h4.goodB {
    background: url(../img/icon_goodB.svg) no-repeat left top/ 25px;}
h4.goodY {
    background: url(../img/icon_goodY.svg) no-repeat left top/ 25px;}

h4.FlowTtl {
    color: #2A3D8D;
    font-size: 4vw;
    text-align: center;
    line-height: 1.5em;
    padding: 0;}
h4.QATtl {
    color: #2A3D8D;
    font-size: 4vw;
    text-align: center;
    line-height: 1.5em;
    padding: 0 0 0.5em 0;}

h4.AccessTtl {
    color: #282828;
    font-size: 4vw;
    text-align: left;
    line-height: 1.5em;
    padding: 1em 0 0.2em 0;}

/*-------------------------------------------------
	++ others
-------------------------------------------------*/
.InformationBox {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;}
h3.InformationBoxTtl {
    width: 100%;
    color: #c00000;
    font-size: 5vw;
    font-weight: bold;}
.InformationBoxDetail {
    width: 100%;}
.InformationBoxDetail dl {
    display: table;
    width: 100%;
    padding: 12px 0 10px;
    border-bottom: 1px solid #ababab;}
.InformationBoxDetail dl dt,
.InformationBoxDetail dl dd {
    display: block;
    vertical-align: top;}
.InformationBoxDetail dl dt {
    width: 135px;
    white-space: nowrap;
    padding-right: 20px;}
.InformationBoxDetail dl dd {
     line-height: 160%;}

.AboutusBox {
    background: url("../img/Clover.svg") no-repeat left top;
    background-size: 100%;
    background-color:rgba(255,255,255,0.6);
    background-blend-mode:lighten;
    display: flex;
    justify-content: flex-end;}
.AboutusBoxDetail {
    width: 100%;}
.AboutusBoxImgList {
    display: flex;
    justify-content: center;
    width: 100%;
    margin: 15px auto 0 auto;}

.ServiceBox {
    display: flex;
    flex-direction: column;}
.ServiceBoxDetail {
    width: 100%;}
.ServiceBoxDetail p {
    margin-left:30px;
    padding-bottom: 1em;}
.ServiceBoxImg {
    width: 100%;
    margin: 0 auto;
    text-align: center;}

.bgPayrollR {
    background: #FFF6D6 url(../img/CloverY.svg) no-repeat right 2%/ 40%;}
.bgPayrollL {
    background: #FFF6D6 url(../img/CloverY.svg) no-repeat left top/ 100%;}
.bgEntryR {
    background: #EEFFDE url(../img/CloverG.svg) no-repeat right 2%/ 40%;}
.bgEntryL {
    background: #EEFFDE url(../img/CloverG.svg) no-repeat left top/ 100%;}

.WorriesBox {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: column;}
.WorriesBoxImg {
    order: 2;
    width: 100%;
    margin: 5% auto 0 auto;
    text-align: center;
    position: relative;}
.WorriesBoxImgPhoto {
    position: none;}
.WorriesBoxDetail,
.WorriesBoxDetail2 {
    order: 1;
    width: 100%;}
.WorriesBoxDetail li,
.WorriesBoxDetail2 li {
    position: relative;
    padding-left: 3.2em;}
.WorriesBoxDetail li::after {
    content: '';
    display: block;
    position: absolute;
    top: .6em;
    left: 2.0em;
    height: 10px;
    width: 100px;
    border-bottom: 4px solid #ffc71a;
    border-left: 8px solid #ffc71a;
    transform: rotate(-45deg) perspective(30px) rotateY(60deg);
    transform-origin: 0 50%;}
.WorriesBoxDetail2 li::after {
    content: '';
    display: block;
    position: absolute;
    top: .6em;
    left: 2.0em;
    height: 10px;
    width: 100px;
    border-bottom: 4px solid #68ac00;
    border-left: 8px solid #68ac00;
    transform: rotate(-45deg) perspective(30px) rotateY(60deg);
    transform-origin: 0 50%;}

.SupportBox {
    width: 100%;
    margin: 10px auto;
    display: flex;
    flex-direction: row;
    align-items: stretch;
    border-radius: 10px;
    border: 1px #2A3D8D solid;}
.SupportBoxTtl {
    width: 25%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 5px 3px;
    color: #FFFFFF;
    text-align: center;
    background-color: #2A3D8D;
    border-top-left-radius: 8px;
    border-bottom-left-radius: 8px;}
.SupportBoxDetail {
    width: 75%;
    padding: 10px 5px;}
.SupportBoxDetail dt {
	clear: left;
	margin-right: 0.5em;}
.SupportBoxDetail dd {
	float: left;
	margin-left: 1em;
    margin-bottom: 0.5em;}

.FlowBox {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    margin-top: 1.5em;
    flex-direction: column;}
.FlowBoxItem {
    width: 100%;
    background-color: #FFFFFF;
    border-radius: 10px;
    padding: 15px 25px;
    display: flex;
    flex-direction: column;
    align-items: center;}
.FlowBoxItem img {
    width: 30%;
    margin: 10px auto;
    text-align: center;}
.FlowBoxArrow {
    width: 100%;
    margin: 10px auto;
    display: flex;
    justify-content: center;}
.FlowBoxArrow img {
    width: 15%;}

.ConsultationBox {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-direction: column;
    margin-top: 1.5em;}
.ConsultationBoxImg {
    order: 2;
    width: 100%;
    margin: 2% auto 0 auto;
    text-align: center;}
.ConsultationBoxDetail {
    order: 1;
    width: 100%;}
.ConsultationBoxDetail p {
    margin-left: 30px;
    margin-top: -8px;
    padding-bottom: 1em;}

.PayrollQA dl,
.EntryQA dl {
	margin: 0;}
.PayrollQA dt {
	margin-bottom: 0.5em;
	padding: 0.2em 0.5em 0.5em 2em;
	background: #FFF6D6;}
.EntryQA dt {
	margin-bottom: 0.5em;
	padding: 0.2em 0.5em 0.5em 2em;
	background: #EEFFDE;}
.PayrollQA dd,
.EntryQA dd {
	margin-bottom: 1em;
	margin-left: 0;
	padding: 0.5em 1em 1.5em 3em;}
.PayrollQA dd:last-child,
.EntryQA dd:last-child {
	margin-bottom: 0;
    padding-bottom: 0;}
.PayrollQA dt::before,
.EntryQA dt::before {
	margin: 0.3em 0.3em 0 -1em;
	content: 'Q';
	color: #2A3D8D;
    font-size: 5vw;}
.PayrollQA dd::before,
.EntryQA dd::before {
	margin: 0 0.5em 0 -2em;
	padding: 0.2em 0.4em;
	content: 'A';
	color: #FFD700;
    font-size: 5vw;}
.PayrollQAList {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-direction: column;
    margin-top: -30px;}
.PayrollQAListDetail {
    width: 100%;
    border: 1px #2A3D8D solid;
    border-radius: 10px;
    color: #282828;
    padding: 10px 8px;
    font-size: 3.5vw;
    line-height: 1.3em;
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;}
.PayrollQAListArrow {
    width: 100%;
    margin: 10px auto;
    display: flex;
    justify-content: center;}
.PayrollQAListArrow img {
    width: 10%;}

.listDisc {
	margin:0.8em 0;}
.listDisc2 {
	margin:-30px 0 0 0;}
.listDisc3 {
	margin:0 0 1em 0;}
.listDisc li,
.listDisc2 li {
	text-align: left;
	line-height: 1.5em;
	list-style-type:none;
	padding: 0 0 0 1.0em;
	text-indent: -1.0em;}
.listDisc3 li {
    font-size: 3.5vw;
	text-align: left;
	line-height: 1.5em;
	list-style-type:none;
	padding: 0 0 0 1.0em;
	text-indent: -1.0em;}

.ProfileBox {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-direction: column;}
.ProfileBoxImg {
    order: 2;
    width: 100%;
    margin: 0 auto;
    text-align: center;}
.ProfileBoxDetail {
    order: 1;
    width: 100%;}
.ProfileList dl {
	margin: 15px 0 0 0;}
.ProfileList dt {
	float: left;
    clear: left;
	margin-right: 0.5em;
    margin-bottom: 1.5em;
	width: 30%;
    background-color: #E8F4FF;
    border-radius: 30px;
    text-align: center;
    line-height: 2em;}
.ProfileList dd {
	float: left;
	margin-left: 1em;
    margin-bottom: 1em;}

.AccessBox {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-direction: column;}
.AccessBoxMap {
    order: 1;
    width: 100%;}
.AccessBoxDetail {
    order: 2;
    width: 100%;
    margin-top: 10px;}

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

/*-------------------------------------------------
	++ FOOTER
-------------------------------------------------*/
#footer{
    margin: 0px;
	padding: 7vw 0;
    border-top: 12px #ffc71a solid;
    background-color: #2a3d8d;}
#footer p {
	font-size:3.5vw;
    line-height: 1.8em;
	color: #FFFFFF;
	text-align: center;}
#footer p span {
    display: block;
	font-size:5vw;
    padding-bottom: 1.5em;}
#footer p a:link,#footer p a:visited {color:#ffffff;text-decoration:underline;}
#footer p a:hover,#footer p a:active {color:#ffffff;text-decoration:none;}

#pageTop {
	position: fixed;
	bottom: 2vw;
  	right: 2vw;
  	width: 15%;
	z-index:98;}
#pageTop img {
	display:block;}









