@charset "utf-8";
/* ========================
   bootstrap reset
   ======================== */
/* common */
@media (max-width:1200px) {
}
@media (max-width:991px) {
}
@media (max-width:767px) {
}

body{
  line-height: 1.5em;
  font-family:'Noto Sans JP',"Noto Sans Japanese", "ヒラギノ角ゴ ProN W3", Meiryo, sans-serif !important;
  color:#333;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.1em;
}

.alpha {
  -webkit-transition: 0.4s ease;
  transition: 0.4s ease;
}
.alpha:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
  -webkit-transition: 0.4s ease;
  transition: 0.4s ease;
}
a.alpha {
  display: inline-block;
  width: 100%;
}
a{
  color:#333;
}
.Page-top {
    position: fixed;
    right: 0;
    bottom: 5%;
    right: 1%;
}
img.img-responsive {
    display: inline-block;
}
.en{
  font-family: 'ColfaxWeb',Sans-Serif;
  font-weight: bold;
}
@media (max-width:767px) {
  .sp-pt-10{
    padding-top: 10px;
  }
    .sp-mt-10{
    margin-top: 10px;
  }
}
/* mv */
#mv{
  position: relative;
}
#mv a{
    position: absolute;
    top: 7%;
    left: 20%;
}
@media (max-width:1200px) {
  #mv a {
    position: absolute;
    top: 7%;
    left: 8%;
}
}
@media (max-width:767px) {
  body{
  font-size: 14px;
}
}
/* timer */
#timer{
  background-color: #b80e04;
  color:#fff;
}
.yycountdown-box {
    display: inline-block;
}
.yyc-day, .yyc-hou, .yyc-min, .yyc-sec{
  font-family:'Oswald', sans-serif;
  font-size:120%;
}
#count{
  font-size: 140%;
}
@media (max-width:767px) {
  .timer h2{
    font-size: 25px;
  }
  }

/* about */
.about_banner{
  padding: 50px 0;
  background-color: #000000;
}

/* コロナ */
.korona{
  padding: 50px 0px;
}
.korona h2{
  background-color: #b80e04;
  color:#fff;
  margin-top: 0px;
  margin-bottom: 0px;
  font-size: 27px;
  padding: 15px 0px;
}
.korona-box{
border: 2px solid #b80e04;
}
.korona-box p{
  padding: 10px 15px;
}
@media (max-width:767px) {
  .korona{
  padding: 30px 0px;
}
.korona h2{
  font-size: 18px;
  padding: 10px 0px;
}
}
/* cta */
.cta{
  background: #000;
}
.cta-box{
  padding:50px 0px;
}
@media (max-width:767px) {
  .cta-box{
  padding:30px 0px;
}
}
/* content01 */
.content01{
  background: #000;
}
.content01 .container{
  padding: 70px 0px;
}
.ytp-large-play-button-bg {
    -moz-transition: fill .1s cubic-bezier(0.4,0.0,1,1),fill-opacity .1s cubic-bezier(0.4,0.0,1,1);
    -webkit-transition: fill .1s cubic-bezier(0.4,0.0,1,1),fill-opacity .1s cubic-bezier(0.4,0.0,1,1);
    transition: fill .1s cubic-bezier(0.4,0.0,1,1),fill-opacity .1s cubic-bezier(0.4,0.0,1,1);
    fill: #b80e04 !important;
    fill-opacity: .8;
}
@media (max-width:767px) {
  .content01 .container{
  padding: 50px 5px;
}
}

/* content02 */
.content02{
  background: #000;
}
.content02 .container{
  padding:0 0 70px;
}
@media (max-width:767px) {
  .content02 .container{
  padding:0 0 50px;
}
}
/* content03 */
.content03{
  background: #b80e04;
}
.content03 .container{
  padding:70px 0;
}
@media (max-width:767px) {
  .content03 .container{
  padding:50px 5px;
}
}
/* content04 */
.content04{
  background:url('../images/content04_bg.jpg');
}
.content04 .container{
  padding:70px 0;
}
@media (max-width:767px) {
  .content04 .container{
  padding:50px 5px;
}
.content04 {
    background-position: center;
}
.content04_07_sp{
  width: 70%;
  margin: 0 auto;
}
}

/* media */
.media{
  background: #000;
  margin-top: 0;
}
.media .container{
  padding:70px 0;
}
@media (max-width:767px) {
  .media .container{
  padding:0 0 50px;
}
}

/* content05 */
.content05{
  background: #000;
}
.content05 .container{
  padding:70px 0;
}
@media (max-width:767px) {
  .content05 .container{
  padding:50px 5px;
}
}
/* content06 */
.content06{
  background: #b80e04;
}
.content06 .container{
  padding:70px 0;
}
.content06 h3 {
    background: #fff;
    color: #b80e04;
    font-size: 21px;
    font-weight: bold;
    padding: 10px;
}
.content06 p{
  color: #fff;
  padding-left: 10px;
}
@media (max-width:767px) {
  .content06 .container{
  padding:50px 5px;
}
.content06 h3 {
    padding: 10px 5px;
    margin-left: 10px;
    font-size: 18px;
}
}
/* content07 */
.content07 .container{
  padding:70px 0;
}
.content07 .border{
  border-bottom:2px solid #cdcdcd;
}
@media (max-width:767px) {
.content07 .col-xs-4{
  padding-left: 5px;
  padding-right: 5px;
  }
  .content07 .container{
  padding:50px 5px;
}
}
/* form */
.form h2 {
    background: #b80e04;
    color: #fff;
    margin: 0px;
    padding: 30px 10px 15px;
    font-weight: bold;
}
select {
    width: 20%;
    font-size: 84%;
    height:45px;
}

.form .text01{
  font-size: 105%;
  font-weight: bold;
}

#contact_form{
  background:#000;
  padding:0px 0 50px 0;
}
.radio02-input{
  display: none;
}
.radio02-input + label{
  padding-left: 20px;
  position:relative;
  margin-right: 20px;
}
.radio02-input + label::before{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 16px;
  height: 16px;
  border: 1px solid #999;
  border-radius: 50%;
}
.radio02-input:checked + label{
  color: #3977cf;
}
.radio02-input:checked + label::after{
  content: "";
  display: block;
  position: absolute;
  top: 3px;
  left: 3px;
  width: 11px;
  height: 11px;
  background: #3977cf;
  border-radius: 50%;
}

#contact_form .input_item dl {
    width: 100%;
}
#contact_form .step{
  background-color: #fff;
}
#contact_form .input_item dl dt {
    float: left;
    width: 37%;
    font-size: 104%;
    line-height: 30px;
    height: 30px;
    padding: 30px 0 0px 30px;
    letter-spacing: 1px;
}

#contact_form .input_item dl dt span {
    font-size: 14px;
    margin: 0 10px 0 0;
    display: inline;
    line-height: 20px;
    padding: 3px 10px;
    color: #fff;
    height: 18px;
    letter-spacing: 1px;
}

#contact_form .input_item dl dt span.req {
    background: #b80e04;
}
#contact_form .input_item dl dt span.req02 {
    background: #333;
}

#contact_form .input_item dl dt span.any {
    background: #333;
}

#contact_form .input_item dl dd {
    margin-left: 27%;
    padding: 25px 0 10px 10px;
}

#contact_form .input_item dl dd li {
    display: inline-block;
    margin: 0 15px 0 0;
    line-height: 30px;
    height: 30px;
    padding: 3px 0;
}

#contact_form .input_item dl dd p.mail_caution {
    font-size: 12px;
    line-height: 19px;
    color: #333;
    margin: 5px 0 0 0;
}

#contact_form .input_item dl dd input[type="text"],
#contact_form .input_item dl dd input[type="number"],
#contact_form .input_item dl dd input[type="email"],
#contact_form .input_item dl dd input[type="tel"]{
    width:60%;
    font-size: 18px;
    height:50px;
    padding: 3px 0 3px 10px;
    margin:0;
    border: 1px solid #b3b3b3;
    background-color: #fff;
}

#contact_form .input_item .transmission input[type="submit"]{
    border: 3px double #FFFFFF;
    background: #333;
    font-size: 150%;
    text-shadow: none;
    color: #ffffff;
    width:60%;
    padding: 30px 0;
    margin: 25px 0;
    display: block;
    opacity: 1.0;
    -webkit-transition: 0.5s;
    -moz-transition: 0.5s;
    -o-transition: 0.5s;
    -ms-transition: 0.5s;
    transition: 0.5s;
    margin: 0 auto;
}

#contact_form .input_item .transmission input[type="submit"]:hover{
    opacity:0.5;
    -webkit-transition: 0.5s;
    -moz-transition: 0.5s;
    -o-transition: 0.5s;
    -ms-transition: 0.5s;
    transition: 0.5s;
}

#contact_form .input_item dl dd input[type="text"].inp_error,
#contact_form .input_item dl dd input[type="number"].inp_error,
#contact_form .input_item dl dd input[type="tel"].inp_error,
#contact_form .input_item dl dd textarea.inp_error {
    border: 1px solid #F88A8A;
    background: #F4D4D4;
}

#contact_form .input_item dl dd textarea {
    width: 80%;
    padding: 10px 3px 10px 10px;
    border: 1px solid #b3b3b3;
    background-color: #fff;
}

#energy_contact #send_status{
    padding: 5px 0 25px;
    text-align: center;
}

span.error_m {
    font-size: 15px;
    font-weight: normal;
    color: #FF4040;
    display: block;
    margin: 0;
}
form dt {
    clear: left;
    float: left;
    width: 27%;
    padding-left: 30px;
    font-size: 15px;
    padding-top: 10px;
}
button {
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    appearance: none;
}
::-webkit-input-placeholder {
    color:#b3b3b3;
    font-size:84%;
}
@media (max-width:1200px) {
  #contact_form .input_item dl dt {
    font-size: 94%;
}
}
@media (max-width:991px) {
}
@media screen and (max-width: 767px) {
  #contact_form .input_item .transmission input[type="submit"] {
    width: 100%;
}
#contact_form .input_item dl dt {
    width: 100%;
}
#contact_form .input_item dl dd {
    width: 100%;
    padding-top:20px;
}
#contact_form .input_item dl dt {
    line-height: 30px;
    height: 80px;
}
#contact_form .input_item dl dd {
    margin-left:0px;
}
#contact_form .input_item dl dd input[type="text"], #contact_form .input_item dl dd input[type="number"], #contact_form .input_item dl dd input[type="email"], #contact_form .input_item dl dd input[type="tel"] {
    width: 95%;
}
.formError {
    position: absolute;
    top: 300px;
    left: 200px !important;
}
#contact_form .input_item dl dd textarea {
    width: 97%;
}
#contact_form .input_item dl dd input[type="text"], #contact_form .input_item dl dd input[type="number"], #contact_form .input_item dl dd input[type="email"], #contact_form .input_item dl dd input[type="tel"] {
    font-size: 14px;
}
#contact_form .input_item dl dt {
    padding: 30px 0 0px 15px;
}
button {
    padding: 0 15px;
}
#contact_form {
    background: #fba101;
    padding: 50px 0 50px 0;
}
  .fix_navi {
    background: rgba(0,0,0,0.4);
    padding: 9px 0 10px 0;
    position: fixed;
    z-index: 9999;
    bottom: 0;
    width: 100%;
}
.fix_navi .container {
    padding-left: 5px;
    padding-right: 5px;
}
.fix_navi .col-xs-5, .fix_navi .col-xs-2 {
    padding-left: 5px;
    padding-right: 5px;
}
.sp-width-80 {
    width: 80%;
}
#contact_form {
    background: #b80e04;
    padding: 0px 0 50px 0;
}
#contact_form .pt-30{
  padding-top: 10px !important;
}
}
/* footer */
footer{
  background: #000;
  color: #fff;
  padding:15px 0 75px;
}
footer p {
    margin: 0 0 0px;
}
/*固定バナー */
.fix_navi {
    position: fixed;
    top: 15%;
    right: 0%;
    text-align: right;
}
@media (max-width:767px) {
.fix_navi {
    background: rgba(0,0,0,0.4);
    padding: 9px 0 10px 0;
    position: fixed;
    z-index: 9999;
    bottom: 0;
    width: 100%;
    top: auto;
}
}