@charset "UTF-8";

@import url(base.css);

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

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

.sp {
	display: none !important;}

p {
    font-size: 93%;
    line-height: 1.6em;
    padding: 0;}

/*-------------------------------------------------
	++ container
-------------------------------------------------*/
#container {
	margin:0 auto;
	text-align: center;
	position:relative;}
.cInner {
	display:block;
	clear:both;
    width: 100%;
	max-width:1000px;
    padding: 40px 0;
	margin:0 auto;
	text-align: left;}
.cInner2 {
	display:block;
	clear:both;
	width:1100px;
    padding: 40px 0;
	margin:0 auto;
	text-align: left;}

/*@media screen and (max-width: 1250px)  {
	#container,
	.cInner,
	.cInner2 {
		width:98%;
		margin: 0 auto;}
}*/

/*-------------------------------------------------
	++ HEADER
-------------------------------------------------*/
#header {
	position: fixed;
	top:0;
	left:0;
	width:100%;
	z-index: 9999;
	height:75px;
    background-color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: row;}

#logo {
	flex-grow: 1;
    margin-left: 2%;}
#snsArea {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    margin-right: 1%;}
#snsArea ul {
	display: flex;
	flex-wrap: wrap;
    align-items: flex-end;
    justify-content: flex-end;
    position: relative;}
#snsArea li {
	text-align: center;
	margin: 0 15px 0 0;
    font-size: 110%;
    line-height: 30px;
	display: inline-block;
	vertical-align: middle;}
#snsArea li.tel {
    width: 30px;
    margin: 0 8px 0 0;}
.Twitter,
.Instagram {
	width: 40px;
    margin-right: 1%;}
.snsTxt {
    font-size: 85%;
    padding-bottom: 0.3em;}
.telTxt {
    font-size: 130% !important;}

@media screen and (max-width: 910px)  {
#logo {
    width: 25%;}
#snsArea li {
    font-size: 100%;}
#snsArea li.tel {
    width: 20px;
    margin: 0 5px 0 0;}
.Twitter {
    width: 30px;}

.snsTxt {
    top: -15px;
    font-size: 80%;}
.telTxt {
    font-size: 110% !important;}
}
@media screen and (max-width: 720px)  {
#logo {
    width: 25%;}
#snsArea li {
    font-size: 80%;}
.telTxt {
    font-size: 90% !important;}
}

#fullscreenmenu {
    width: 80px;
    height: 75px;
    background-color: #1F3D8F;}
#nav-toggle {
    position: fixed;
    top: 20px;
    right: 15px;
    height: 50px;
    width: 50px;
    cursor: pointer;}
#nav-toggle > div {
    position: relative;
    width: 50px;}
#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: 15px;}
#nav-toggle span:nth-child(3) {
    top: 30px;}

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

#gloval-nav {
    position: fixed;
    top: 75px;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 5% 7%;
    font-size: 20px;
    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: 10px 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: 42%;
    margin: 0 2%;
    display: inline-block;
    vertical-align: top;
    text-align: left;
    opacity: 1;}
.sub_list {
    width: 100%;
    margin: 0;}
.sub_list a {
    font-size: 80%;
    letter-spacing: 0.1em;
    padding: 5px 0 5px 20px !important;
    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: 2em 0 5px 0;
    font-size: 110%;
    color: #FFF;
    letter-spacing: 0.1em;
    border-bottom: 2px #FFF solid;}
.sub_listmarginT {
    margin-top: 68px;}
.sub_listmarginT2 {
    margin: 2em 2% 0 2% !important;}

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

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

/*-------------------------------------------------
	++ 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: 200%;
    line-height: 100px;}
.Ttlpayroll {
    color: #2a3d8d;
    background-color: #ffc71a;}
.Ttlagency {
    color: #FFFFFF;
    background-color: #68ac00;}

h3 {
    display: block;
    color: #2A3D8D;
    text-align: left;
    margin: 0 0 10px 0;
    padding: 0 0 3px 0;
    font-size: 200%;
    font-weight: bold;
    line-height: 1.5em;
    border-bottom: 1px #2A3D8D solid;}
h3 span {
    color: #282828;
    display: inline-block;
    font-size: 50%;
    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: 180%;
    font-weight: bold;
    line-height: 1.5em;
    border-bottom: none;}
h3.Worries span {
    color: #C00000;
    display: inline-block;
    font-size: 100%;
    padding-left: 0;
    font-weight: bold;}

h4 {
    color: #2A3D8D;
    font-size: 105%;
    line-height: 1.5em;
    padding: 5px 0 0.5em 35px;}
h4 span {
    color: #C00000;}
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: 110%;
    text-align: center;
    line-height: 1.5em;
    padding: 0;}
h4.QATtl {
    color: #2A3D8D;
    font-size: 110%;
    text-align: center;
    line-height: 1.5em;
    padding: 0 0 0.5em 0;}
h4.AccessTtl {
    color: #282828;
    font-size: 110%;
    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: 15%;
    color: #c00000;
    font-size: 120%;
    margin: 0;
    padding: 0;
    border-bottom: none;
    font-weight: bold;}
.InformationBoxDetail {
    width: 83%;}
.InformationBoxDetail dl {
    display: table;
    width: 100%;
    padding: 12px 0 10px;
    border-bottom: 1px solid #ababab;}
.InformationBoxDetail dl:first-child {
    padding-top: 0;}
.InformationBoxDetail dl dt,
.InformationBoxDetail dl dd {
    display: table-cell;
    vertical-align: top;}
.InformationBoxDetail dl dt {
    width: 135px;
    white-space: nowrap;
    padding-right: 20px;}
.InformationBoxDetail dl dd {
     line-height: 160%;}

.AboutusBox {
    display: flex;
    justify-content: flex-end;}
.AboutusBoxDetail {
    width: 83%;}
.AboutusBoxImgList {
    display: flex;
    justify-content: space-between;
    justify-content: center;
    width: 100%;
    margin: 15px auto 0 auto;}
.bgAboutus {
    background: #ffffff url(../img/Clover.svg) no-repeat 5% 20px/ 350px;}

.ServiceBox {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;}
.ServiceBoxDetail {
    width: 55%;}
.ServiceBoxDetail p {
    margin-left:30px;
    margin-top: -8px;
    padding-bottom: 1em;}
.ServiceBoxImg {
    width: 40%;}

.bgPayrollR {
    background: #FFF6D6 url(../img/CloverY.svg) no-repeat 95% 20px/ 250px;
    margin-bottom: 50px;}
.bgPayrollL {
    background: #FFF6D6 url(../img/CloverY.svg) no-repeat 5% 20px/ 250px;}
.bgEntryR {
    background: #EEFFDE url(../img/CloverG.svg) no-repeat 95% 20px/ 250px;
    padding-bottom: 100px;
    margin-bottom: 100px;}
.bgEntryL {
    background: #EEFFDE url(../img/CloverG.svg) no-repeat 95% 20px/ 250px;}

.WorriesBox {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;}
.WorriesBoxImg {
    width: 55%;
    position: relative;}
.WorriesBoxImgPhoto {
    position: absolute;
    left: 0;
    top: 30px;}
.WorriesBoxDetail,
.WorriesBoxDetail2 {
    width: 35%;}
.WorriesBoxDetail li,
.WorriesBoxDetail2 li {
    position: relative;}
.WorriesBoxDetail li::after {
    content: '';
    display: block;
    position: absolute;
    top: .8em;
    left: -1.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: .8em;
    left: -1.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: 80%;
    margin: 10px auto;
    display: flex;
    flex-direction: row;
    align-items: stretch;
    border-radius: 10px;
    border: 1px #2A3D8D solid;}
.SupportBoxTtl {
    width: 20%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 5px;
    color: #FFFFFF;
    text-align: center;
    background-color: #2A3D8D;
    border-top-left-radius: 8px;
    border-bottom-left-radius: 8px;}
.SupportBoxDetail {
    width: 80%;
    padding: 10px 15px;}
.SupportBoxDetail dt {
    float: left;
	clear: left;
	margin-right: 0.5em;
	width: 120px;}
.SupportBoxDetail dd {
	float: left;
	margin-left: 1em;}

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

.ConsultationBox {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-top: 1.5em;}
.ConsultationBoxImg {
    width: 35%;}
.ConsultationBoxDetail {
    width: 60%;}
.ConsultationBoxDetail p {
    margin-left: 30px;
    margin-top: -8px;
    padding-bottom: 1em;}

.PayrollQA dl,
.EntryQA dl {
	margin: 25px 0 0 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: 140%;}
.PayrollQA dd::before,
.EntryQA dd::before {
	margin: 0 0.5em 0 -2em;
	padding: 0.2em 0.4em;
	content: 'A';
	color: #FFD700;
    font-size: 140%;}
.PayrollQAList {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    margin-top: -30px;}
.PayrollQAListDetail {
    width: 19%;
    border: 1px #2A3D8D solid;
    border-radius: 10px;
    color: #282828;
    padding: 10px 8px;
    font-size: 85%;
    line-height: 1.3em;
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;}
.PayrollQAListArrow {
    width: 3%;
    display: flex;
    justify-content: center;}
.PayrollQAListArrow img {
    width: 50%;}

.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: 90%;
	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;}
.ProfileBoxImg {
     width: 35%;}
.ProfileBoxDetail {
     width: 60%;}
.ProfileList dl {
	margin: 25px 0 0 0;}
.ProfileList dt {
	float: left;
    clear: left;
	margin-right: 0.5em;
    margin-bottom: 1em;
	width: 150px;
    background-color: #E8F4FF;
    border-radius: 30px;
    text-align: center;
    line-height: 2em;}
.ProfileList dd {
	float: left;
	margin-left: 1em;}

.AccessBox {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;}
.AccessBoxMap {
     width: 55%;}
.AccessBoxDetail {
     width: 40%;
     margin-top: 60px;}

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

/*-------------------------------------------------
	++ FOOTER
-------------------------------------------------*/
#footer{
    margin: 0;
	padding: 4% 0;
    border-top: 12px #ffc71a solid;
    background-color: #2a3d8d;}
#footer p {
	font-size:90%;
    line-height: 1.5em;
	color: #FFFFFF;
	text-align: center;}
#footer p span {
    display: block;
	font-size:150%;
    padding-bottom: 2em;}
#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;}

a[href^="tel:"] {
	color: #000;
    text-decoration: none !important;
    pointer-events: none;}

#pageTop {
  	position: fixed;
  	bottom: 10px;
  	right: 10px;
	z-index: 98;}
#pageTop img {
	display:block;}






