@charset "utf-8";

/*===============================================
●画面の横幅が769px以上
===============================================*/
@media screen and (min-width : 769px ){
#pc------------------------------------------- {
}
header .innerpc nav ul:first-child li:nth-of-type(4) a::before {
  position: absolute;
  bottom: -2px;
  left: 0;
  content: '';
  width: 100%;
  height: 1px;
  background: #000;
  transform-origin: left top;
}
main .ttl {
	font-size: 36px;
	text-align: center;
	font-weight: bold;
	margin-left: auto;
    margin-right: auto;
	position: relative;
	z-index: 1;
}
main .ttl span {
	background-image: url("../../images/literasu/planning/ttl_fig.png");
	background-repeat: no-repeat;
	background-position: center left;
	background-size: contain;
	padding-left: 20px;
	padding-top: 5px;
}
#iot .bg {
	background-image: url("../../images/literasu/iot/m_bg.png");
	height: 650px;
	background-position: top center;
	background-size: cover;
	margin-top: -31px;
}
#iot .bg h2 {
	font-size: 36px;
	padding-top: 70px;
	font-weight: bold;
	letter-spacing: 0.1em;
	color: #fff;
}
#iot .bg h2 span {
	display: block;
	font-size: 14px;
	margin-top: 10px;
	font-weight: 500;
	letter-spacing: 0.05em;
}
#iot .bg p img {
	max-width: 1189px;
	min-width: 800px;
	width: 80%;
	height: auto;
	margin-left: auto;
	margin-right: auto;
	margin-top: -10px;
}





#house {
	padding-top: 50px;
}
#house .ttl {
	line-height: 1.2em;
	margin-bottom: 20px;
}
#house .ttl span {
	background-position: center left 44px;
}
#house .ttl+p {
	font-size: 16px;
	line-height: 1.9em;
	margin-bottom: 100px;
}
#house .flex {
	height: 500px;
	margin-bottom: 70px;
	display: flex;
	width: 1100px;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
#house .flex .photo {
	margin-left: -130px;
}
#house .flex div {
	margin-left: 60px;
}
#house .flex div figure+p {
	font-size: 21px;
	margin-top: 40px;
	margin-bottom: 40px;
}
#house .flex div h3 {
	font-size: 21px;
	font-weight: bold;
	margin-bottom: 30px;
	line-height: 1.4em;
	white-space: nowrap;
}
#house .flex div h3+p {
	line-height: 1.9em;
	white-space: nowrap;
}
#house .flex:nth-child(even) {
	flex-direction: row-reverse;
}
#house .flex:nth-child(even) .photo {
	margin-left: auto;
	margin-right: -130px;
}
#house .flex:nth-child(even) div {
	margin-left: auto;
	margin-right : 60px;
}





#setsubi {
	padding-top: 120px;
}
#setsubi .ttl {
	margin-bottom: 70px;
}
#setsubi h3 {
	width: 1100px;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	font-weight: bold;
	font-size: 28px;
	margin-bottom: 25px;
}
#setsubi h3 span {
	color: #F4D70F;
}
#setsubi .flex,
#setsubi .flex2,
#setsubi .flex3
{
	display: flex;
	display: -webkit-flex; /* Safari */ 　
    display: -ms-flexbox;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 1100px;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	margin-bottom: 80px;
}
#setsubi .flex3 .box {
	width: 355px;
	display: flex;
	display: -webkit-flex; /* Safari */ 　
    display: -ms-flexbox;
	flex-wrap: wrap;
	margin-bottom: 40px;
}
#setsubi .flex3 .box figure span {
	display: block;
	font-size: 11px;
}
#setsubi .flex3 .box div {
	width: 165px;
	letter-spacing: -0.01em;
	margin-left: 10px;
}
#setsubi .flex div {
	width: 528px;
}
#setsubi .flex2 div {
	width: 344px;
}
#setsubi .flex div h4,
#setsubi .flex2 div h4,
#setsubi .flex3 div h4
{
	font-weight: bold;
	font-size: 18px;
	margin-top: 15px;
	margin-bottom: 10px;
}
#setsubi .flex div p,
#setsubi .flex2 div p,
#setsubi .flex3 div p
{
	font-size: 14px;
	line-height: 1.6em;
}
}





/*===============================================
●画面の横幅が1300pxまで
===============================================*/
@media screen and (min-width:769px) and (max-width:1300px) {
#pc1300------------------------------------------- {
}

}



/*===============================================
●画面の横幅が768pxまで
===============================================*/
@media screen and (max-width:768px){
	
/*===============================================
●sp-tablet
===============================================*/
#sptablet------------------------------------------- {
}
main .ttl {
	font-size: 6vw;
	text-align: center;
	font-weight: bold;
	margin-left: auto;
    margin-right: auto;
	position: relative;
	z-index: 1;
}
main .ttl span {
	background-image: url("../../images/literasu/planning/ttl_fig.png");
	background-repeat: no-repeat;
	background-position: center left;
	background-size: contain;
	padding-left: 20px;
	padding-top: 5px;
}
main .ttl img {
	position: relative;
	width: 20vw; 
	top: -5vw;
	right: 0px;
	position: absolute;
}
#iot .bg {
	background-image: url("../../images/literasu/iot/m_bg.png");
	height: 80vw;
	background-position: top center;
	background-size: cover;
	padding-top: 10vw;
}
#iot .bg h2 {
	font-size: 6vw;
	color: #fff;
	line-height: 1.2em;
	padding-top: 10vw;
	font-weight: bold;
	letter-spacing: 0.1em;
}
#iot .bg h2 span {
	display: block;
	font-size: 3vw;
	margin-top: 1vw;
	font-weight: 500;
	letter-spacing: 0.05em;
}





#house {
	padding-top: 10vw;
}
#house .ttl {
	line-height: 1.2em;
	margin-bottom: 5vw;
}
#house .ttl span {
	background-position: center left 10vw;
}
#house .ttl+p {
	line-height: 1.9em;
	margin-bottom: 10vw;
	width: 90%;
	margin-left: auto;
	margin-right: auto;
}
#house .flex {
	margin-bottom: 10vw;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
#house .flex .photo {
}
#house .flex div {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
}
#house .flex div figure {
	width: 20vw;
	margin-top: 3vw;
}
#house .flex div figure+p {
	font-size: 4.5vw;
	margin-top: 5vw;
	margin-bottom: 5vw;
}
#house .flex div h3 {
	font-size: 5vw;
	font-weight: bold;
	margin-bottom: 5vw;
	line-height: 1.4em;
}
#house .flex div h3+p {
	line-height: 1.9em;
}
#house .flex:last-child div figure {
	width: 80vw;
}






#setsubi {
	padding-top: 15vw;
}
#setsubi .ttl {
	margin-bottom: 10vw;
}
#setsubi h3 {
	margin-left: auto;
	margin-right: auto;
	width: 90%;
	text-align: left;
	font-weight: bold;
	font-size: 5vw;
	margin-bottom: 5vw;
}
#setsubi h3 span {
	color: #F4D70F;
}
#setsubi .flex,
#setsubi .flex2,
#setsubi .flex3
{
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	margin-bottom: 10vw;
}
#setsubi .flex div,
#setsubi .flex2 div
{
	margin-bottom: 8vw;
}
#setsubi .flex2 div figure img {
	width: 100%;
}
#setsubi .flex3 .box {
	display: flex;
	display: -webkit-flex; /* Safari */ 　
    display: -ms-flexbox;
	flex-wrap: wrap;
	margin-bottom: 8vw;
}
#setsubi .flex3 .box figure {
	width: 45%;
}
#setsubi .flex3 .box figure span {
	display: block;
	font-size: 3vw;
	line-height: 1.6em;
}
#setsubi .flex3 .box div {
	width: 45%;
	letter-spacing: -0.01em;
	margin-left: 10px;
}
#setsubi .flex div h4,
#setsubi .flex2 div h4,
#setsubi .flex3 div h4
{
	font-weight: bold;
	font-size: 4vw;
	margin-top: 2vw;
	margin-bottom: 1vw;
}
#setsubi .flex div p,
#setsubi .flex2 div p,
#setsubi .flex3 div p
{
	font-size: 3.5vw;
	line-height: 1.6em;
}
}



/*===============================================
●画面の横幅が400pxまで
===============================================*/
@media screen and (max-width:400px){
/*===============================================
●sp400
===============================================*/
#sp400------------------------------------------- {
}
}



/*===============================================
●画面の横幅が320pxまで
===============================================*/
@media screen and (max-width:320px){
/*===============================================
●sp320
===============================================*/
#sp320------------------------------------------- {
}
}



/*===============================================
●画面の横幅が481pxから768pxまで
===============================================*/
@media screen and (min-width:481px) and (max-width:768px) {
/*===============================================
●tablet
===============================================*/
#tab------------------------------------------- {
}
}
