@charset "utf-8";

/*--------------------------------------------------------------------------------------------------

   sp

--------------------------------------------------------------------------------------------------*/

@media all and (max-width: 1179px) {


/*reset-------------------------------------------------*/
img {
	max-width: 100%;
	height: auto;
}
/*-------------------------------------------------reset*/


/*common-------------------------------------------------*/
body {
	-webkit-text-size-adjust: 100%;
}

.alignleft, .alignright, .aligncenter {
	display: block;
	margin: 0 auto 20px;
}

.sp {
	display: block;
}

/*-------------------------------------------------common*/


/*------------------------------------------------------------------------------------------------
  header
--------------------------------------------------------------------------------------------------*/

#header .wrap {
	width: 100%;
	margin: 0 auto;
	padding: 10px 0 0;
	display: block;
}

#header .wrap .spheader {
	position: relative;
	margin: 0 0 20px;
}

#header .wrap h1 {
	padding: 20px 0 0 10px;
}

#header .wrap h1 img {
	width: 240px;
	height: auto;
}

#header .wrap nav {
	display: none;
}

.menubt {
    z-index: 3;
    width: 50px;
    height: 50px;
    display: block;
    right: 10px;
    top: 10px;
    position: absolute;
    background: #1d56c5;
    background-size: contain;
				cursor: pointer;
}
  
.menubt span {
    width: 40px;
    height: 4px;
    display: block;
    background: #fff;
    border-radius: 0;
    position: absolute;
    right: 5px;
    top: 17px;
    transition: all 0.4s;
    transform: rotate(0deg);
}
  
.menubt .top {
    -webkit-transform: translateY(-250%);
    -ms-transform: translateY(-250%);
    transform: translateY(-250%);
 }
  
.menubt .bottom {
    -webkit-transform: translateY(250%);
    -ms-transform: translateY(250%);
    transform: translateY(250%);
}
  
.menubt .menuclick1 {
    transform: rotate(-215deg);
}
  
.menubt .menuclick2 {
    background-color: rgba(255,255,255,0);
 }
  
.menubt .menuclick3 {
    transform: rotate(215deg);
}
		
.menubt .text-menu {
    color: #fff;
    font-size: 10px;
				position: absolute;
				bottom: 0;
				left: 4px;
}

#header .wrap nav ul {
	display: block;
	margin: 0;
	background-color: #d3e9f2;
}

#header .wrap nav ul li {
	margin: 0;
	padding: 5px 10px;
}

#header .wrap nav ul li:first-child {
	padding: 12px 10px 5px;
}

#header .wrap nav ul li:last-child {
	padding: 5px 10px 25px;
}

#header .wrap nav ul li a {
	transition: none;
	padding: 8px;
	background: url(../image/arrow-04.png) no-repeat 96% 46%;
	background-size: 30px;
}

#header .wrap nav ul li a:hover {
	transform: none;
}

#header .wrap nav ul li:nth-child(4) a {
	color: #d8190b;
}

/*------------------------------------------------------------------------------------------------
  footer
--------------------------------------------------------------------------------------------------*/
#footer {
	width: 100%;
	display: block;
}

#footer .logo {
	width: 96%;
	margin: 0 auto;
}

#footer .logo img {
	width: 240px;
	height: auto;
}

#footer ul {
	width: 98%;
	margin: 30px auto 0;
	flex-wrap: wrap;
	justify-content: start;
}

#footer ul li {
	margin: 0 1%;
	width: 48%;
}

#footer ul li a {
	padding: 8px;
	display: block;
	border-bottom: 1px solid #CCC;
}

#footer ul li:last-child {
	text-align: left;
	margin-top: 20px;
}

/*------------------------------------------------------------------------------------------------
  second
--------------------------------------------------------------------------------------------------*/
.secondTitle .tit {
	width: 100%;
}

.secondTitle h2 {
	width: 90%;
	font-size: 24px;
}

#second .cont h2 {
	font-size: 24px;
}


/*------------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------------*/
#slide {
	height: 300px;
}

#slide p {
	top: unset;
	bottom: 10px;
	width: 100%;
	height: 40px;
	font-size: 20px;
}

#tProfile .inner {
	width: 94%;
	margin: 0 auto;
}

#tProfile .inner .waku {
	display: block;
	padding: 20px;
}

#tProfile .inner .waku div:nth-child(1) {
	margin-bottom: 20px;
}

#tProfile .inner .waku .photo {
	margin: 0;
	text-align: center;
}

#tProfile .inner .waku:before {
	right: 0;
	z-index: 10;
	background-size: 62px;
	width: 62px;
	height: 114px;
}

.tJob .item {
	width: 100%;
}

.tJob .item:nth-child(2n) {
	margin: 0 0 40px;
}

#tVoice::before {
	width: 50%;
	left: 80%;
	display: none;
}

#tVoice .inner h2 {
	width: 94%;
	margin: 0 auto 20px;
}

#tVoice::after {
	left: unset;
	right: 20px;
	background-size: 139px;
	width: 139px;
	height: 160px;
	top: -60px;
}

.swiper-button-prev, .swiper-rtl .swiper-button-next {
	left: -20px;
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
	right: -20px;
}

#tVoice .inner {
	width: 100%;
}

#tVoice .inner .swiper {
	width: 240px;
	margin: 0 auto;
}

.swiper-slide img {
	max-width: 100%;
	width: auto;
}

#req .inner {
	width: 94%;
 margin: 0 auto;
}

#req .inner ul {
	display: block;
	margin: 0 30px;
}

#req .inner ul li {
	width: 100%;
	margin-bottom: 20px;
}

#req .inner ul li:last-child {
	margin-bottom: 0;
}

#req .inner .btns:before {
	background-size: 92px;
	width: 91px;
	height: 111px;
	bottom: unset;
	top: 10px;
	left: -10px;
	z-index: 2;
}

#req .inner .btns:after {
	background-size: 66px;
	width: 66px;
	height: 110px;
	bottom: -30px;
	right: -10px;
	z-index: 2;
}

#fEntry {
	background-color: #FFF;
	border-top: 4px solid #d8190b;
	border-bottom: 4px solid #d8190b;
}

#fEntry .inner {
	width: 96%;
	margin: 0 auto;
}

#fEntry::before {
	width: 90%;
	left: 0%;
	height: 101%;
	display: none;
}

.btn2 {
	width: 100%;
}

.btn02 {
	width: 100%;
	padding: 20px 0;
	font-size: 24px;
}

.card02 {
	width: 100%;
}


/*------------------------------------------------------------------------------------------------
  profile
--------------------------------------------------------------------------------------------------*/
#second.profile .secondTitle h2:after {
	font-size: 50px;
	right: -40px;
	bottom: -50px;
}

#second.profile .lead dl {
	width: 90%;
	margin: 0 auto;
}

#second.profile .lead dt {
	font-size: 26px;
}

#second.profile .lead dd {
	font-size: 16px;
	text-align: left;
}

.work .item .info .photo:before {
	left: 0;
}

.work {
	width: 94%;
	margin: 0 auto;
}

#second .cont .submenu {
	flex-wrap: wrap;
	font-size: 18px;
	margin-bottom: 30px;
}

#second .cont .submenu li {
	width: 46%;
	margin: 0 2% 10px;
}

.work .item .info {
	position: static;
}

.work .item .text {
	position: static;
	bottom: unset;
	left: -1%;
}

.work .item .key {
	display: block;
}

.work .item .key dt {
	width: 100%;
	text-align: center;
	margin-left: -20px;
	margin-bottom: 10px;
}

.work .item .key dd {
	width: 100%;
}

.work .item .key dd ul {
	display: flex;
	flex-wrap: wrap;
}

.work .item .key dd ul li {
	width: 46%;
	margin: 0 2% 2%;
}

#second.profile .about .inner {
	width: 96%;
	margin: 0 auto;
}

#second.profile .about .inner table th {
	display: block;
	width: 100%;
}

#second.profile .about .inner table td {
	display: block;
	width: 100%;
}

#second.profile .about .inner table td .skill {
	display: block;
}

#second.profile .about .inner table td .skill div {
	width: 100%;
}

#second.profile .about .inner table td .skill div:nth-child(1) {
	margin-bottom: 20px;
}

#second.profile .list {
	width: 96%;
	margin: 0 auto;
}

#second.profile .list .box {
	display: block;
}

#second.profile .list dl {
	width: 100%;
	margin-bottom: 30px;
}

/*------------------------------------------------------------------------------------------------
  voice
--------------------------------------------------------------------------------------------------*/
#second.voice .secondTitle h2:after {
	font-size: 50px;
	right: -40px;
	bottom: -50px;
}

#second.voice .lead {
	font-size: 16px;
}

#second.voice .voiceList {
	padding-bottom: 30px;
}

#second.voice .voiceList:after {
	top: -60px;
	left: 2%;
	background-size: 84px;
	width: 84px;
	height: 139px;
}

#second.voice .voiceList ul {
	width: 90%;
	margin: 0 auto;
	display: block;
}

#second.voice .voiceList ul li {
	width: 100%;
	margin-bottom: 60px;
}

#second.voice .voiceList ul li:nth-child(5) {
	margin-bottom: 60px;
}

#second.voice .voiceList ul li:nth-child(6) {
	margin-bottom: 0;
}

.voiceWrap.voice01:after,
.voiceWrap.voice02:after,
.voiceWrap.voice03:after,
.voiceWrap.voice04:after,
.voiceWrap.voice05:after,
.voiceWrap.voice06:after {
	font-size: 50px;
}

.voiceWrap .info {
	width: 100%;
	position: static;
}

.voiceWrap .info .text {
	position: static;
	width: 70%;
	margin: 0 0 0 auto;
}

.cont2 {
	display: block;
}

.cont2 .photo {
	margin: 0 0 10px;
	text-align: center;
}

.cont2 a {
	margin: 0 auto;
}

.voiceWrap .comment {
	width: 100%;
}

.cont2r {
	width: 96%;
	margin: 0 auto;
	display: block;
}

.cont2r .text p {
	margin: 0 10px 40px !important;
}

.cont2r .photo {
	margin: 0 0 60px;
	text-align: center;
}

.voiceWrap .schedule {
	width: 96%;
	margin: 0 auto;
}

.voiceWrap .schedule .time {
	margin: 0 20px;
}

.voiceWrap .schedule .time dl:before {
	width: 10px;
	right: 10px;
}

.voiceWrap .schedule .time dl dd {
	padding-right: 30px;
	line-height: 1.6;
	font-size: 16px;
}

#second.voice .voiceList ul li a div dd {
	font-size: 20px;
}

.btn03 {
	width: 100%;
}

/*------------------------------------------------------------------------------------------------
  requirements
--------------------------------------------------------------------------------------------------*/
#second.requirements .secondTitle h2:after {
	font-size: 42px;
	right: -40px;
	bottom: -50px;
}

#req {
	padding: 40px 0 80px;
}

#second.requirements .lead {
	margin-bottom: 0;
}

#second.requirements #new .inner {
	width: 100%;
}

#second.requirements table.rec {
	width: 94%;
	margin: 0 auto 20px;
}

#second.requirements table.rec th {
	display: block;
	width: 100%;
	text-align: left;
	padding: 8px;
}

#second.requirements table.rec td {
	display: block;
	width: 100%;
	padding: 8px;
}

.btn4 {
	width: 100%;
}

.btn4 a {
	display: block;
	margin: 0 auto 20px;
}

.btn3, .btn5 {
	margin-bottom: 40px;
}

#second.requirements #mid .inner {
	width: 100%;
}

#second.requirements #faq {
	width: 94%;
	margin: 0 auto;
}

#second.requirements #flow .inner {
	width: 94%;
	margin: 0 auto;
}

#second.requirements #flow .inner .info {
	display: block;
	width: 90%;
	margin: 0 auto;
}

#second.requirements #flow .inner .info li {
	width: 100%;
	margin-bottom: 40px; 
}


#second.requirements #flow .inner .info li::after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  right: unset;
		left: calc( 50% - 10px);
  top: unset;
		bottom: -55px;
  transform: translateY(-50%);
  border-left: 10px solid transparent;
  border-right: 10px solid transparent; 
  border-top: 20px solid #000; 
}

.qaList2 .answer-text {
	padding-right: 20px;
}



/*------------------------------------------------------------------------------------------------
  entry
--------------------------------------------------------------------------------------------------*/
#second.entry .secondTitle h2:after {
	font-size: 42px;
	right: -40px;
	bottom: -50px;
}

#second.entry .entryForm .inner {
	width: 94%;
	margin: 0 auto;
}

#second.entry .entryForm .inner table {
	font-size: 16px;
}

#second.entry .entryForm .inner table th {
	display: block;
	width: 100%;
	padding: 8px;
	line-height: normal;
	background-color: #DDD;
}

#second.entry .entryForm .inner table td {
	display: block;
	width: 100%;
	padding: 8px;
	margin-bottom: 20px;
	border-bottom: none;
}

#second.entry .entryForm .inner table td input.m[type="text"] {
	width: 100%;
}

input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
		color: #000;
		display: block;
		margin: 0 auto 20px !important;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}




}





@media only screen and (min-width: 800px) and (max-width: 1179px) {

/*------------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------------*/
#slide h2 img {
	width: 700px;
	height: auto;
}


}
