/*!
 * Start Bootstrap - Grayscale Bootstrap Theme (http://startbootstrap.com)
 * Code licensed under the Apache License v2.0.
 * For details, see http://www.apache.org/licenses/LICENSE-2.0.
 */

body {
    width: 100%;
    height: 100%;
    font-family: Lora,"Helvetica Neue",Helvetica,Arial,sans-serif ;
    color: #fff;
}

html {
    width: 100%;
    height: 100%;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    margin: 0 0 35px;
    font-family: Montserrat,"Helvetica Neue",Helvetica,Arial,sans-serif;
    font-weight: 700;
    letter-spacing: 1px;
}
h4 {
    line-height: 1.5;
    
}

p {
    margin: 0 0 25px;
    font-size: 16px;
    line-height: 1.5;
}


a {
    color: #fff;
    -webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
}

a:hover,
a:focus {
    text-decoration: none;
    color: #555;
}

.light {
    font-weight: 400;
}

.navbar-custom {
    padding: 5px 10px 10px 10px;
    margin-bottom: 0;
    border-bottom: 1px solid rgba(255,255,255,.3);
    text-transform: uppercase;
    font-family: Montserrat,"Helvetica Neue",Helvetica,Arial,sans-serif;
    background-color: #7cb778;
    display:inline;
    height: auto;
}

.navbar-custom .navbar-brand {
    font-weight: 700;
}

.navbar-custom .navbar-brand:focus {
    outline: 0;
}

.navbar-custom .navbar-brand .navbar-toggle {
    padding: 4px 6px;
    font-size: 16px;
    color: #fff;
}

.navbar-custom .navbar-brand .navbar-toggle:focus,
.navbar-custom .navbar-brand .navbar-toggle:active {
    outline: 0;
}

.navbar-custom a {
    color: #fff;
}

.navbar-custom .nav li a {
    -webkit-transition: background .3s ease-in-out;
    -moz-transition: background .3s ease-in-out;
    transition: background .3s ease-in-out;
}

.navbar-custom .nav li a:hover {
    outline: 0;
    color: rgba(255,255,255,.8);
    background-color: transparent;
}

.navbar-custom .nav li a:focus,
.navbar-custom .nav li a:active {
    outline: 0;
    background-color: transparent;
}

.navbar-custom .nav li.active {
    outline: 0;
}

.navbar-custom .nav li.active a {
    background-color: rgba(255,255,255,.3);
}

.navbar-custom .nav li.active a:hover {
    color: #fff;
}



.intro {
    display: table;
    width: 100%;
    height: auto;
    padding: 100px 0;
    text-align: center;
    color: #2f2f2f;
    background: url(../img/greenpower_topimage.jpg) no-repeat bottom center scroll;
    background-color: #000;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
}

.intro .intro-body {
    display: table-cell;
    vertical-align: middle;
}

.intro .intro-body .brand-heading {
      color: #fff;
    font-size: 30px;
}
.brand-heading2 {
        color: #fff;
    font-size: 22px;
}

.intro .intro-body .intro-text {
    font-size: 18px;
        font-weight: 600;
}


/*    横幅600ピクセル以上に適用    */

@media(min-width:600px) {
    p {
        margin: 0 0 35px;
        font-size: 16px;
        line-height: 1.6;
    }

    .navbar-custom {
        padding: 20px 0;
        border-bottom: 0;
        letter-spacing: 1px;
        background: 0 0;
        -webkit-transition: background .5s ease-in-out,padding .5s ease-in-out;
        -moz-transition: background .5s ease-in-out,padding .5s ease-in-out;
        transition: background .5s ease-in-out,padding .5s ease-in-out;
    }

    .navbar-custom.top-nav-collapse {
        padding: 0;
        border-bottom: 1px solid rgba(255,255,255,.3);
        background: #7cb778;
        height: auto;
    }

    .intro {
        height: 100%;
        padding: 120px 20px 120px 20px;
    }

    .intro .intro-body .brand-heading {
        font-size: 50px;
    }

    .brand-heading2 {
        font-size: 24px;
    }

    .intro .intro-body .intro-text {
        font-size: 20px;
    }

    .css_btn_class {
      	font-size:22px;
    }



  .box2 {
        background: linear-gradient(#7cb778, #68a764);
        border-radius: 3px;
        box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
        padding: 50px 50px;
        text-align: right;
        display: block;
        margin-top: 0px;
        margin-bottom: 20px;
        max-width: 1000px;
        margin: 0 auto;

    }

}


/*    横幅1100ピクセル以上に適用    */

@media(min-width: 1100px) {
    .intro .intro-body .brand-heading {
        font-size: 90px;
	}

    .brand-heading2 {
        font-size: 40px;
    }

    .intro .intro-body .intro-text {
        font-size: 26px;
    }
}


/*    横幅600ピクセル以下に適用    */

@media(max-width:600px) {
    .css_btn_class {
      	font-size:15px;
    }



    .box2 {
/*         background: linear-gradient(#7cb778, #68a764);*/
        padding: 50px 0px;
        text-align: right;
        display: block;
        margin-top: 0px;
        margin-bottom: 20px;
    }

    .row2{
      background: linear-gradient(#7cb778, #68a764);

    }
}

/*    横幅320ピクセル以下に適用    */

@media(max-width:320px) {
    .css_btn_class {
      	font-size:12px;
    }
}

@-webkit-keyframes pulse {
    0% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    50% {
        -webkit-transform: scale(1.2);
        transform: scale(1.2);
    }

    100% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }
}

@-moz-keyframes pulse {
    0% {
        -moz-transform: scale(1);
        transform: scale(1);
    }

    50% {
        -moz-transform: scale(1.2);
        transform: scale(1.2);
    }

    100% {
        -moz-transform: scale(1);
        transform: scale(1);
    }
}

.btn-circle {
    width: 70px;
    height: 70px;
    margin-top: 15px;
    padding: 7px 16px;
    border: 2px solid #fff;
    border-radius: 100%!important;
    font-size: 40px;
    color: #fff;
    background: 0 0;
    -webkit-transition: background .3s ease-in-out;
    -moz-transition: background .3s ease-in-out;
    transition: background .3s ease-in-out;
}

.btn-circle:hover,
.btn-circle:focus {
    outline: 0;
    color: #fff;
    background: rgba(255,255,255,.1);
}

.btn-circle i.animated {
    -webkit-transition-property: -webkit-transform;
    -webkit-transition-duration: 1s;
    -moz-transition-property: -moz-transform;
    -moz-transition-duration: 1s;
}

.btn-circle:hover i.animated {
    -webkit-animation-name: pulse;
    -moz-animation-name: pulse;
    -webkit-animation-duration: 1.5s;
    -moz-animation-duration: 1.5s;
    -webkit-animation-iteration-count: infinite;
    -moz-animation-iteration-count: infinite;
    -webkit-animation-timing-function: linear;
    -moz-animation-timing-function: linear;
}



.content-section,
.content-section-company {
    padding-top: 100px;
    padding-bottom: 100px;
}




.btn {
	padding:20px 30px;
    border-radius: 0;
    text-transform: uppercase;
    font-family: Montserrat,"Helvetica Neue",Helvetica,Arial,sans-serif;
    font-weight: 400;
    -webkit-transition: all .3s ease-in-out;
    -moz-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
}

.btn-default {
    border: 4px solid #ffff00;
    color: #000;
    background-color: #ffff00;
}

.btn-default:hover,
.btn-default:focus {
    border: 4px solid #ffffbc;
    outline: 0;
    color: #000;
    background-color: #ffffbc;
}

ul.banner-social-buttons {
    margin-top: 0;
}


footer {
    padding: 50px 0;
    background: linear-gradient(#333, #222);

}

footer p {
    margin: 0;
}

::-moz-selection {
    text-shadow: none;
    background: #fcfcfc;
    background: rgba(255,255,255,.2);
}

::selection {
    text-shadow: none;
    background: #fcfcfc;
    background: rgba(255,255,255,.2);
}

img::selection {
    background: 0 0;
}

img::-moz-selection {
    background: 0 0;
}

body {
    webkit-tap-highlight-color: rgba(255,255,255,.2);
}

.wid100per {
	width: 100%;
    background-color: #fff;
    text-shadow: 1px 1px 1 rgba(0,0,0,99);
	color: #000;
}

.wid100perelectro {
	width: 100%;
    background: linear-gradient(#7cb778, #68a764);
    text-shadow: 1px 1px 1 rgba(0,0,0,99);
	color: #fff;
}


.wid100pergreen {
	width: 100%;
    height: auto;
    background: url(../img/greenpower_topimage_green2.jpg) no-repeat bottom center scroll;
  	background-size:100% auto;
    background-color: #004900;
    text-shadow: 1px 1px 1 rgba(0,0,0,99);

	color: #fff;
      -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    -o-background-size: cover;
}

/**/
 .navimg {
	margin:0 5px 0 0;
	float:left;
}



.iconmargin{
	margin-bottom:20px;
}

.marginbottom{
	margin-bottom:80px;
}


.copyright {
	font-size:10pt;
    color: #ffffff;
}

.btn img{
  opacity: 1;
  transition: 0.3s;
}

.btn:hover img{
  opacity: .6;
}

.gplogo {
	margin:0px;
	padding:5px
  ;
}

.myhidden {
	visibility:hidden;
}

.imgcenter {
 text-align: center;
}


.topshadow {
text-shadow: 1px 1px 2px rgba(0,0,0,2);
}

.topshadow2 {
text-shadow: 1px 1px 3px rgba(255,255,255,8);
}

/**/
.h4bottom {
  margin-bottom:10px;
}

.bar2 {
  width: 70%;
  opacity:0.3;
	border-top: 1px dashed #bbb;
	border-bottom: 1px dashed #fff;
}

.elecfree {
	color:#004900;
	background-color:#ecffe3;
	padding:50px 10px;
	margin:100px 0 0 0;
	border: 5px double #004900;
}

.wrap div {
  display: table-cell;
  width: ;
  padding: 0 5px 0 0;
}
.wrap p {
  display: table-cell;
  vertical-align: middle;
  line-height: 1.2;
}

.box {
    background-color: #fff;
    border-radius: 3px;
    box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
    padding: 10px 25px;
    text-align: right;
    display: block;
    margin-top: 90px;
    margin-bottom: 60px;
}


.box-icon {
    background-color: #7cb778;
    border-radius: 50%;
    display: table;
    height: 60px;
    margin: 0 auto;
    width: 60px;
    margin-top: -41px;
}

.box-icon2 {
    display: table;
    height: 40px;
    margin: 0 auto;
    width: 40px;
}

.box-icon span {
    color: #fff;
    display: table-cell;
    text-align: center;
    vertical-align: middle;
}

.info h4 {
    font-size: 26px;
    letter-spacing: 2px;
    margin-top: 20px;
    text-transform: uppercase;
}
.info > p {
    color: #717171;
    font-size: 16px;
    padding-top: 10px;
    text-align: justify;
}
.info > a {
    background-color: #03a9f4;
    border-radius: 2px;
    box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
    color: #fff;
    transition: all 0.5s ease 0s;
}
.info > a:hover {
    background-color: #0288d1;
    box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.16), 0 2px 5px 0 rgba(0, 0, 0, 0.12);
    color: #fff;
    transition: all 0.5s ease 0s;
}

.linkbox {
    background-color: rgba(255,255,255,0.12);
    border-radius: 4px;
    box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
    padding: 30px 0px;
    text-align: center;
    display: block;
    margin-top: 20px;
    margin-bottom: 20px;
}


.info2 h4 {
    color: #fff;
    font-size: 26px;
    letter-spacing: 2px;
    margin-top: 20px;
    text-transform: uppercase;
}
.info2 > p {
    color: #fff;
    font-size: 16px;
    padding-top: 10px;
    text-align: justify;
}
.info2 > a {
    background-color: #03a9f4;
    border-radius: 2px;
    box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
    color: #fff;
    transition: all 0.5s ease 0s;
}
.info2 > a:hover {
    background-color: #0288d1;
    box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.16), 0 2px 5px 0 rgba(0, 0, 0, 0.12);
    color: #fff;
    transition: all 0.5s ease 0s;
}

.linkbox {
    background-color: rgba(255,255,255,0.12);
    border-radius: 4px;
    box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
    padding: 30px 0px;
    text-align: center;
    display: block;
    margin-top: 20px;
    margin-bottom: 20px;
}

.css_btn_class {
	font-family:Arial;
	font-weight:bold;
	-moz-border-radius:8px;
	-webkit-border-radius:8px;
	border-radius:8px;
	border:1px solid #dcdcdc;
	padding:9px 18px;
	text-decoration:none;
	background:-moz-linear-gradient( center top, #f9f9f9 5%, #e9e9e9 100% );
	background:-ms-linear-gradient( top, #f9f9f9 5%, #e9e9e9 100% );
	filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f9f9f9', endColorstr='#e9e9e9');
	background:-webkit-gradient( linear, left top, left bottom, color-stop(5%, #f9f9f9), color-stop(100%, #e9e9e9) );
	background-color:#f9f9f9;
	color:#666666;
	display:inline-block;
	text-shadow:1px 1px 0px #ffffff;
 	-webkit-box-shadow:inset 1px -1px 0px 0px #ffffff;
 	-moz-box-shadow:inset 1px -1px 0px 0px #ffffff;
 	box-shadow:inset 1px -1px 0px 0px #ffffff;
}

.css_btn_class:hover {
	background:-moz-linear-gradient( center top, #d2d2d2 5%, #ccc 100% );
	background:-ms-linear-gradient( top, #d2d2d2 5%, #ccc 100% );
	filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#d2d2d2', endColorstr='#ccc');
	background:-webkit-gradient( linear, left top, left bottom, color-stop(5%, #d2d2d2), color-stop(100%, #ccc) );
	background-color:#e9e9e9;
}


.css_btn_class:active {
	position:relative;
	top:1px;
}

.info {
color: #717171;
}

.btn_ennet {
	margin: 0 auto;
	padding: 0;
}

.btn_ennet a img {
  opacity: 1;
  transition: 0.2s;
  margin-bottom: 1.0em;
  width: 600px;
}

.btn_ennet a img:hover {
    opacity: 0.8;
    filter: alpha(opacity=80);
}

@media screen and (max-width: 1100px) {
.btn_ennet {
    margin: 0 auto 1em auto;
	}
}

.sp-only {
  display: none;
}
.pc-only {
  display: block;
}

/*    横幅600ピクセル以下に適用    */
@media screen and (max-width: 600px) {
  .sp-only {
    display: block;
  }
  .pc-only {
  display: none;
  }
.btn_ennet a img {
  opacity: 1;
  transition: 0.2s;
  margin-bottom: 1.0em;
  max-width: 360px;
  width: 90%;
}
h1,
h2,
h3 {
    margin-bottom: 0.5em !important;
}
}

/* 260206追加TJグループ 高さ揃え */
/* TJグループ 見出し */
.tj-group h3 {
  width: 100%;
  text-align: center;
  margin-bottom: 40px;
}

/* 全体を中央揃え */
.tj-group {
  display: flex;
  flex-wrap: wrap;
  justify-content: center; /* ← これが重要 */
}

/* 各カラムをflex化して高さ揃え */
.tj-group > [class*="col-"] {
  display: flex;
}

/* box内レイアウト */
.tj-group .linkbox {
  width: 100%;
  display: flex;
  flex-direction: column;
  padding: 40px 10px 20px;
}

/* バナー余白を詰める */
.tj-group .linkbox img {
  display: block;
  margin: 10px auto 0;
}

/* 上段と下段の間に余白 */
.tj-group > .col-lg-4:nth-of-type(n+4) {
  margin-top: 0px;
}

p.mb_10 {
   margin-bottom: 10px !important; 
}
.mb_60 {
 margin-bottom: 60px !important; 
}
