/*
Theme Name: ネクストイノベーション
Version: 1.1
*/

html,
body {
    width: 100%;
}

body {
   font-family: "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-size: 16px;
    line-height: 2em;
    color: #111;
    margin: 0;
    -webkit-text-size-adjust: none;
}

.clearfix:after {
    visibility: hidden;
    display: block;
    font-size: 0;
    content: " ";
    clear: both;
    height: 0;
}

.clearfix {
    display: inline-block;
}

.clearfix {
    display: block;
}

div.clear {
    clear: both;
}

div.clear hr {
    display: none;
}

.breadcrumbs {
    padding: 1em 0 2em 0;
}

img{
	vertical-align:top;
}

a {
	color: #0056b5;
}

a:hover {
	text-decoration: none;
}


span.wpcf7-list-item { display: block; }

/* ----------------------------------------------
	PageNavi
------------------------------------------------*/

#pnavi {
	display: block;
	width: 100%;
	margin: 2em auto;
	padding-bottom: 3em;
}
.nav-previous a,.nav-next a { width:120px; background: #08690b; color: #fff; display: block; padding: .5em 1em; text-decoration: none; -webkit-transition: 0.5s; transition: 0.5s; text-align: center;}
.nav-previous a:hover,.nav-next a:hover { background: #2da631; color: #fff;}

#page-navi {
    width: 100%;
    margin: 3em 0;
    display: block;
    clear: both;
}

.wp-pagenavi {
    font-size: 14px;
}

.wp-pagenavi span.pages {
    width: 100px;
    display: block;
    margin: 0 auto 1em auto;
    padding: text-align: center;
    border: none;
}

.wp-pagenavi {
    display: block;
    text-align: center;
}

.smaller,
.larger {
    background:  #08690b;
}

.wp-pagenavi a {
    color: #fff;
    border: none;
    padding: 1em;
    text-decoration: none;
}

.wp-pagenavi a:hover {
    background: #2da631;
    color: #fff;
}

.current {
    background: #08690b;
    color: #fff;
    border: none;
 border: solid 1px #fff;
}

.previouspostslink,
.nextpostslink,
.wp-pagenavi .first,
.wp-pagenavi .last {
    background: #08690b;
border: solid 1px #fff;    
}

.wp-pagenavi a,
.wp-pagenavi span {
    padding: 12px;
}

.cont-menu-wp {
	margin: 3em 0 4em 0;
}


/*------------------------
	 フォーム
-------------------------*/

input[type="text"],
textarea {
    vertical-align: middle;
    max-width: 90%;
    line-height: 30px;
    height: 30px;
    padding: 1px 5px;
    border: 1px solid #d4d4d7;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    font-size: 100%;
    color: #555;
    background: #fcfcfc;
    margin: 1%;
}

input[type="text"].readonly {
    font-weight: bold;
    vertical-align: middle;
    width: 100%;
    line-height: 20px;
    height: 20px;
    padding: 1px 0;
    border: none;
    font-size: 100%;
    color: #555;
    background: #fff;
    margin: 1%;
}

input[type="tel"],
textarea {
    vertical-align: middle;
    max-width: 90%;
    line-height: 30px;
    height: 30px;
    padding: 1px 5px;
    border: 1px solid #d4d4d7;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    font-size: 100%;
    color: #555;
    background: #fcfcfc;
    margin: 1%;
}

input[type="email"],
textarea {
    vertical-align: middle;
    max-width: 90%;
    line-height: 30px;
    height: 30px;
    padding: 1px 5px;
    border: 1px solid #d4d4d7;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    font-size: 100%;
    color: #555;
    background: #fcfcfc;
    margin: 1%;
}

select {padding: 5px; margin: 1%;}

textarea {
    height: auto;
    line-height: 1.5;
    margin: 1%;
}

input[type="submit"],
input[type="reset"],
input[type="button"] {
    padding: .5em 3em;
    background: #007c1a;
    background: -moz-linear-gradient(top, #1549aa 0%, #1549aa 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #1549aa), color-stop(100%, #1549aa));
    background: -webkit-linear-gradient(top, #1549aa7 0%, #1549aa 100%);
    background: -o-linear-gradient(top, #1549aa 0%, #1549aa 100%);
    background: linear-gradient(to bottom, #1549aa 0%, #1549aa 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1549aa', endColorstr='#1549aa', GradientType=0);
    border: 0;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    line-height: 1.5;
    font-size: 16px;
    color: #fff;
}

input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover {
    background: #212121;
    background: -moz-linear-gradient(top, #212121 0%, #212121 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #212121), color-stop(100%, #212121));
    background: -webkit-linear-gradient(top, #212121 0%, #212121 100%);
    background: -o-linear-gradient(top, #212121 0%, #212121 100%);
    background: linear-gradient(to bottom, #212121 0%, #212121 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#212121', endColorstr='#212121', GradientType=0);
    cursor: pointer;
    -webkit-transition: all .8s;
    transition: all .8s;
}


*:first-child+html input[type="submit"] {
    padding: 3px;
}

#search {
    background: #e2e2e2;
    margin: 0;
    padding: 1em .5em;
    text-align: center;
}

.sp-cont { display: none;}
.mgtx{ font-weight: bold;position: relative;  right:.5em; font-size:18px;}
.mgim img { width: 70px; height: auto;position: relative; top:.3em; mix-blend-mode: Multiply;}
#vi{
position: relative;
position: 1;
   display: block;
    background: url(images/vi.jpg) 50% 50% / cover repeat scroll padding-box border-box rgba(0, 0, 0, 0);
    width: 100%;
    height:100vh;
    border-width: 0px;
    border-style: none;
}
#top-wrap-inner { display: block; background: #e7edf0;}
#spc-inner {display: flex; justify-content: space-between; align-items: center; width: 90%;}
#logo { display: block; text-align: left; }
#logo-inner { display: flex; align-items: center; padding: 1em;}
#logo h1 { margin: 0 0 0 1em; padding: 0 0 0 0; line-height: 1; font-size:20px;}
#logo h1 span { display: block; font-size:16px; font-weight: normal; padding-top:.6em;}
#logo img { width: 200px; height: auto; mix-blend-mode: Multiply;}
a.home-link { color: #000; text-decoration: none;}
#vi h2 { font-family:Ryumin Medium KL; text-align: center; margin: auto; display: block; line-height: 1; font-size: 40px; position: relative; top:35%; bottom:35%;}

#footer { background: #e7edf0;display: block;}
#footer-inner { display: flex; justify-content: space-between; margin: auto; padding:4em 0; width: 95%;}
#footer-inner section.fd01 {flex-basis: 200px;}
#footer-inner section.fd01 img { mix-blend-mode: Multiply; }
#footer-inner section.fd02 {margin-left: 30px;}
#footer-inner section.fd02 { font-size: 14px; line-height: 1.8;}
#footer-inner section.fd02 h3 { font-size: 24px; margin: 0 0 .3em 0; padding:0; line-height: 1;}
#footer-inner section.fd02 #ad {margin-top: 1em;}
#footer-inner section.fd03 { flex:1;}
.fd03{position: relative; }
.fd03 ul { position: absolute; right: 0; list-style: none; margin: 0; padding: 0;}
.fd03 ul a { color: #222;}
#copyright { display: block; width: 95%; text-align: right; font-size: 14px; line-height: 1; padding: 3em 0;}
#content { display: block; margin: 0; padding: 0; border-top: solid 1px #000;}
#cont { max-width: 1100px; width: 95%; display: block; margin: auto; padding:1em 0 3em 0;}
#cont h2 { font-size: 32px; border-bottom: solid 4px #25b; margin: 0 0 1em 0; padding: 0 0 .3em 0;}
#cap { display: block; text-align: center; margin-bottom: 3em;}
#cont h3 { font-size: 28px; line-height: 1.4;  margin: 0 0 1.4em 0; }
#cap h3 { display: inline-block; padding: .6em 2em; font-size: 26px; border: solid 1px #333; margin: auto;}
#cont dl { border-top: dotted 1px #333; padding-top: 2em; margin-bottom: 3em; }
#cont dt { font-size: 20px; padding-left: 1em;}
#cont dd { margin: -4em 0 2em 0; padding: 2em 0 2em 15em; border-bottom: dotted 1px #333;}
#cont h4 { font-size: 22px; line-height: 1.4;}
.cap2 {border-bottom: dotted 1px #222; margin: 0 0 1em 0; padding: 0 0 .3em 0;}
#map { display: flex; justify-content: center;}
#map section { flex: 1; margin: 2%; text-align: center;}
.txb { font-size: 20px; line-height: 1; font-weight: bold; margin: 0; padding: 0; display: block;}
.mapin { height: 400px; margin-bottom: 1em;}
#sol { background: url(images/bkg.png) #000 no-repeat bottom center; background-size: cover;display: block; margin-bottom: 3em;}
#solin {padding: 3em;}
#sl-tit { display: flex; justify-content: center; align-items: baseline; color: #fff; margin-bottom: 1em;}
#sl-tit section { margin: 0 1%;}
#solin h3 { text-align: center; color: #fff;}
.solt {
 font-family: "Libre Baskerville", serif;
 font-size: 40px;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;}
  #gb { display: block; text-align: center; border-top: solid 1px #222; padding-top:3em; }
#gb-tit {
 font-family: "Libre Baskerville", serif;
 font-size: 40px;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;}
  #case { display: flex; flex-wrap: wrap; }
  #case section { flex-basis: 30%; margin: 16px; text-align: center; line-height: 1.4;}
  #case section a { text-decoration: none; color:#222;}
 #case img {
    width:300px;
    height: 300px;
    object-fit: contain;
    border-radius: 10px;
  }
p {
    margin-bottom: 1.5em;
}

#content ul {
    margin: 0 0 3em 2em;
    padding: 0;
}

#content ul li {
    margin: 0 0 1em 0;
    padding: 0;
    list-style-position: outside;
}


#content ol {
    margin: 0 0 3em 0;
    padding: 0 0 0 1em;
}

#content ol li {
    list-style: decimal;
    margin: 0 0 2em 0;
    padding: 0;
}

blockquote {
    clear: both;
    padding: 10px 0 10px 15px;
    margin: 10px 0 25px 30px;
    border-left: 5px solid #ccc;
}

blockquote p {
    padding: 5px 0;
}

table {
    border: 1px #dddddd solid;
    border-collapse: collapse;
    border-spacing: 0;
    margin: 10px 0 2em 0;
    width: 100%;
}

table th {
    padding: 1em;
    border: 1px #dddddd solid;
    border-width: 0 0 1px 1px;
    font-weight: normal;
    background: #f2f2f2;
    vertical-align: middle;
}

table th:first-child {
	width: 30%;
}

table th span {
    color: red;
}

table td {
    padding: 1em;
    border: 1px #dddddd solid;
    border-width: 0 0 1px 1px;
    background: #fff;
    vertical-align: middle;
}

table td.txc {
	text-align: center;
}

table p {
    margin: 0;
    padding: 0;
}

dl {
    margin: 0;
}

dt {
    font-weight: bold;
}

dd {
    padding-bottom: 10px;
}

img {
    max-width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
}

img.aligncenter {
    display: block;
    margin: 0 auto 1em auto;
}

img.alignright {
    margin: 0 0 1em 1em;
    display: inline;
}

img.alignleft {
    margin: 0 1em 1em 0;
}

.alignright {
	margin: 0 0 1em 1em;
    float: right;
}

.alignleft {
	margin: 0 1em 1em 0;
    float: left;
}

.red {
    color: #ff0000;
}

.br-sp { display: none;}
#cont .wpcf7-spinner { display: block;}

@media only screen and (max-width: 1000px) {
.pc-cont { display:none;}
.sp-cont { display: block;}
#partner24m { display: flex; justify-content: center; align-items: center; padding: 2em 0; font-size: 12px; font-weight: bold; line-height: 1;}
#partner24m section { margin: 0 .3em;}
}
@media only screen and (max-width: 850px) {
   #footer-inner { display:block; text-align: center;}
   #footer-inner section.fd01 { width: 180px; display: block; margin: 0 auto 2em auto;}
#footer-inner section.fd02 h3 { font-size: 18px;}
.fd03 ul { position: relative; margin: 3em 0 0 0;}
.fd03 ul li { display: inline-block; margin: 0 .5em;}
#footer-inner section.fd02 {margin-left: 0px;}
.br-sp { display: block;}
#copyright { text-align: center;}
#map { display: block; }
}

@media only screen and (max-width: 644px) {
#copyright { width: 90%; display: block; margin: auto; text-align: left;font-size: 12px; line-height: 1.6;}
#logo-inner { padding: 1em; display: block;}
#logo h1 { margin: .5em; 0 0 0; padding: 0 0 0 0; line-height: 1; font-size:9px;}
#logo h1 span {display: none;}
#logo img { width: 140px; height: auto;}
#vi h2 { font-size: 24px; top:30%; }

#cont dl { border-top: dotted 1px #333; padding-top: 1em; }
#cont dt { font-size: 18px; line-height: 1.4; padding-left: 1em; padding-top: .6em;}
#cont dd { margin: 0em 0 1em 0; padding: .8em 0 1.5em 2.5em; border-bottom: dotted 1px #333;}
#solin {padding: 2em 1em;}
#sl-tit { display: block; margin-bottom: 1em;}
#sl-tit section { margin: 0 1%; text-align: center;}
#solin h3 { font-size: 18px; }
.solt { font-size: 24px;}
  #gb { display: block; text-align: center; }
#gb-tit {font-size: 24px;}
#cont h2 { font-size: 26px; border-bottom: solid 4px #25b; margin: 0 0 1em 0; padding: 0 0 .3em 0;}
#cont h3 { font-size: 18px; line-height: 1.4;  margin: 0 0 1.4em 0; }
#cap h3 { display: inline-block; padding: .6em 2em; font-size: 18px; border: solid 1px #333; margin: auto;}
#cont h4 { font-size: 18px; line-height: 1.4;}
  #case section { flex-basis: 30%; margin: 5px;}
 #case img {
  width:120px;
  height: 120px;
  object-fit: contain;
  border-radius: 10px;
}

.alignright {
	margin: 0 0 1em 0;
    float: none;
}

.alignleft {
	margin: 0 0 1em 0;
    float: none;
}
.spb {display: block;}
    span.wpcf7-list-item {
        display: block;
        padding: .6em 0;
    }
    textarea {
        height: auto;
        line-height: 1.5;
        width: 90%;
    }
    input[type="text"]{
        width: 80%;
    }
    input[type="tel"] {
        width: 70%;
    }
    input[type="email"] {
        width: 70%;
    }
    input[type="url"] {
        width: 70%;
    }
}