@import "base.css";
/* 
------------------------------------------------------------ */
html { font-size: 62.5%; } 
a {  color: #0078ff;  text-decoration: underline;}
a img {
   /*firefox*/
   -webkit-backface-visibility: hidden;
   backface-visibility: hidden;
   overflow: hidden;
   box-shadow: #000 0 0 0;
   /*background-color:#ffffff;*/
}
/*画像をウインドウサイズに合わせて可変*/
img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
  width /***/ : auto; /*IE8のみ適用*/
  -webkit-backface-visibility: hidden;
}
body {
  color: #324664;
  margin: 0;
  padding: 0;
  font-size: 1.6rem; 
  font-family: "Klee One";
  -webkit-font-smoothing: antialiased;
  font-feature-settings : "palt";
  line-height: 1.8;
  background-color: #fff;
  position: relative;
  box-sizing: border-box;
}
.noto-sans-jp {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

#main-wrapper {  position: relative;}

/* ローダー
--------------------------------------------*/
.bound { animation: bound 1.0s linear infinite;}
.bound img {  display: block;  margin-bottom: 10px;}
@keyframes bound {
   0% {
      transform: translateY(0);
   }
   50% {
      transform: translateY(-40px);
   }
   100% {
      transform: translateY(0px) scaleY(1);
   }
}
.loader-wrap {
   position: fixed;
   display: flex;
   align-items: center;
   justify-content: center;
   width: 100%;
   height: 100%;
   background: #333;
   z-index: 10000000;
}
.loader p {
   text-indent: -9999px;
   background: url("../../images/loading.png") center center no-repeat;
   background-size: 300px auto;
   width: 480px;
   height: 220px;
}
/* ヘッダー 
--------------------------------------------*/
#header { position: absolute; z-index: 200;}
#header-inner { display: inline-block; background-color: rgba(50, 70, 100, 0.8); padding: 1rem 3rem;}
#header-inner h1 { text-align: center; }
#header-inner h1 img { vertical-align: middle;}
#header-inner h1 span { display: inline-block; width: 84px; padding-right: 2rem;}
#header-inner h1 p { display: inline-block; color: #fff; font-size: 2.2rem; margin-top: 1rem;}

/* フッター 
--------------------------------------------*/
#footer { background-color: #ddd; }
#footer .content-inner { display: flex; flex-wrap: wrap; justify-content:space-between; align-items:center;}
#footer .footer-btn { width: 40%; }
#footer .footer-copy { width: 60%; font-family: "Noto Sans JP", sans-serif;}
#footer .footer-btn .btn-web a {
  display: block;
  text-decoration: none;
  background-color: rgba(90,180,0,1);
  color: #fff;
  padding: 40px 50px;
  text-align: center;
  line-height: 160%;
}
#footer .footer-btn .btn-web a p {
  display: inline-block;
  padding-bottom: 8px;
  margin-bottom: 8px;
  border-bottom: solid #dcdcdc 1px;
}
#footer .footer-btn .btn-web a span { display: block; font-size: 1.4rem; }
#footer ul.footer-copy-flex { display: flex; flex-wrap: wrap; justify-content: space-between; list-style: none; align-items: center; margin-left: 2rem; margin-right: 8rem; }
#footer ul.footer-copy-flex li.logo { width: 30%; }
#footer ul.footer-copy-flex li.address { width: 65%;}
#footer ul.footer-copy-flex li.address p { font-size: 1.3rem;}
#footer .copy {
  font-size: 1.3rem;
  text-align: right;
  margin-top: 15px;
  margin-right: 3rem;
}


/* FLEX
--------------------------------------------*/
ul.flex_box { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center;}





/* FPVエリア
--------------------------------------------*/
#fpv { background: #333; }

/* About FPV
--------------------------------------------*/
#about_fpv {border: 1px solid #999; border-radius: 12px; padding: 3rem;}
.about_fpv { color:#fff; }
.fpv_spec { color:#fff; }

table.table01 {
 border-collapse: collapse;
 border: 1px solid #999;
 margin-bottom: 1rem;
}
table.table01 th {
 margin: 0px;
 padding: 1.5rem 3rem;
 font-weight: normal;
 border: 1px solid #999;
 text-align: left;
 vertical-align: middle;
}
table.table01 td {
 margin: 0px;
 padding: 1.5rem 3rem;
 border: 1px solid #999;
}


dl{
 display: -webkit-flex;
 display: -moz-flex;
 display: flex;
	flex-wrap: wrap;
	align-items: stretch;	
	width: 100%;
}
dt{	padding: 5px;}
dd{	padding: 5px; box-sizing: border-box; width: 80%;}


/* About
--------------------------------------------*/
#about { background-image: url(../../images/about_image.jpg);}
#about {
  background-position: 100% 50%;
  background-size: cover;
  text-align: justify;
}
#about .txtbox { display: inline-block; background-color: #666; padding: 6rem 3rem 6rem 6rem; color:#fff;}
#about .txt { line-height: 1.8;}


.Estimate_btn {text-align: center;}
.Estimate_btn a { background: #324664; color:#fff; font-size: 1.8rem; padding: 3rem 6rem; text-decoration: none; }


/* DJI mini4 Pro
--------------------------------------------*/
#drone_area { background: #fff; padding: 8rem 6rem; }
#drone_area .drone { color:#324664!important;}
.frame {border:1px solid #666; border-radius: 12px; padding: 3rem;}


/* About Logo
--------------------------------------------*/
#aboutlogo { background: #fff; padding: 4rem 20rem; }
#aboutlogo .logo { width: 40%; margin: 0 auto; margin-bottom: 4rem;}
#aboutlogo ul li p { margin-left: 2rem;}


/* Profile
--------------------------------------------*/
#profile { max-width: 1200px; margin: 0 auto; padding: 6rem; background: #333; color:#fff; }
ul.flex_box li.txt { margin-bottom: 6rem; }
ul.flex_box li p.ttl { font-size: 1.8rem; font-weight: bold; padding: 2rem 0 2rem 0; }
ul.flex_box li p.ttl span { font-size: 1.6rem; color: #ccc; display: block; }

/* movie clips
--------------------------------------------*/
ul.flex-movie {display: flex; flex-wrap: wrap; justify-content: space-between; list-style: none;}
ul.flex-movie li {}


/* ボタン 
--------------------------------------------*/
.btn-youtube {
   display: inline-block;
   line-height: 100%;
   margin-left: 8px;
}
.btn-youtube a {
   display: inline-block;
   padding: 2rem 6rem;
   text-align: center;
   text-decoration: none;
   border: solid #dadada 1px;
   cursor: pointer;
   background-color: #f8f8f8;
}
.btn-youtube a span {
   display: block;
   background: url("../../images/btn_youtube.png") right center no-repeat;
   background-size: auto 20px;
   padding: 10px 50px 10px 0px;
   color:#324664;
}


/* タイトル
--------------------------------------------*/
h2,h3 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}
h3 { font-size: 2rem; font-weight: bold; margin-bottom: 1.2rem;}
h4 { font-size: 2rem; font-weight: bold; margin-bottom: 1rem; border-bottom:1px solid #ccc;}
.small {font-size:1.3rem;}
h4.icon::before {
 content: "";
 display: inline-block;
 background: url("../../images/icon_drone.svg") no-repeat;
 background-size: contain;
 position:relative;
 top:0.3rem;
 width: 2rem;
 height: 2rem;
 margin-right: 1rem;
}

.title {
  color:#fff;
  font-size: 2.8rem;;
  line-height: 160%;
  letter-spacing: 0.1em;
  font-weight: bold;
}
.title_bk {
  font-size: 2.8rem;;
  line-height: 160%;
  letter-spacing: 0.1em;
  font-weight: bold;
}
.sub-title {
  font-size: 2rem;
  display: block;
  margin-top: 10px;
  color: #8da0be;
  line-height: 160%;
  letter-spacing: 0.2em;
  font-weight: 200;
}

/* Clip Page logo */
div.clip_logo {
padding: 10rem 0;
background:  url("../../images/clip_header_back.jpg") no-repeat center;
background-size: cover;
}
div.clip_logo h2 { width: 30%; margin: 0 auto;}



ul.disc {list-style:disc; margin-left: 2rem;}


/**/
.thum-img {
   position: relative;
}
.thum-img .over:after {
   content: '';
   display: block;
   width: 100%;
   height: 100%;
   position: absolute;
   background-color: rgba(0, 0, 0, 0.20);
   top: 0;
   left: 0;
   z-index: 10;
}
.thum-img .icon-day {
   position: absolute;
   bottom: 8px;
   right: 8px;
   display: inline-block;
   font-size: 12px;
   line-height: 110%;
   color: #fff;
   border: solid #fff 1px;
   padding: 3px 12px;
   z-index: 20;
}
.thum-img .icon-new {
   position: absolute;
   top: -20px;
   left: -20px;
   z-index: 30;
   display: table;
   width: 80px;
   height: 80px;
   border-radius: 40px;
   -webkit-border-radius: 40px;
   -moz-border-radius: 40px;
   background-color: #0d87b5;
}
.thum-img .icon-new span {
   display: table-cell;
   vertical-align: middle;
   text-align: center;
   color: #fff;
   letter-spacing: 0.1em;
}
.thum-img .icon-cat {
   position: absolute;
   z-index: 35;
   top: 8px;
   right: 8px;
   display: inline-block;
   font-size: 13px;
   letter-spacing: 0.1em;
   line-height: 100%;
   min-width: 80px;
   text-align: center;
   background-color: rgba(0, 0, 0, 0.80);
   color: #fff;
   font-weight: normal;
   padding: 5px 15px;
   letter-spacing: 0.15em;
}
/**/
.movie-item .movie-modal-btn .thum-img {
   position: relative;
}
.movie-item .movie-modal-btn .thum-img:after {
   content: '';
   display: block;
   width: 100%;
   height: 100%;
   position: absolute;
   top: 0;
   left: 0;
   z-index: 40;
   background: url("../../images/btn_movie.png") center center no-repeat;
   background-size: auto 50px;
   cursor: pointer;
}
.movie-item a {
   display: block;
   text-decoration: none;
}
.movie-item .txtbox { padding-top: 15px;text-align: left;}
.movie-item .txtbox h3 {
   display: inline-block;
   background-color: #323232;
   color: #fff;
   font-weight: normal;
   line-height: 100%;
   padding: 5px 15px;
   letter-spacing: 0.15em;
}
.movie-item .txtbox p {
   font-size: 1.4rem;
   letter-spacing: 0.1em;
   margin-top: 10px;
   line-height: 150%;
}
/**/
.archive-area .movie-item {
   padding-bottom: 40px;
}
.archive-area .movie-item .txtbox {
   padding-top: 10px;
}
.archive-area .movie-item .txtbox h3 {
  display: block;
  background-color: transparent;
  font-weight: 400;
  font-style: normal;
  font-size: 1.8rem;
  color:#324664;
  line-height: 150%;
  padding: 0px 0px 10px 0;
  border-bottom: solid #d2d2d2 1px;
}
.archive-area .movie-item .txtbox p {
  margin-top: 10px;
  font-size: 1.4rem;
  color:#324664;
}
/**/
.archive-area-inner {
   display: none;
}
.archive-area-inner.first-archive {
   display: block;
}
.archive-area-inner.current {
   /*display: block;*/
}
.end-btn {
   text-align: center;
   padding: 3rem;
   margin-top: 40px;
   margin-bottom: 40px;
   border: solid #d2d2d2 1px;
   background-color: #fff;
}
.end-btn p {
}
.archive-area .btn-youtube {
   display: inline-block;
   text-align: center;
   line-height: 100%;
   margin-left: 0px;
   margin-top: 30px;
   margin-bottom: 30px;
}

/* 
--------------------------------------------*/
.movie-area { padding: 6rem; }
.bg-color {
  background-color: #f8f8f8;
  border-bottom: solid #ededed 1px;
  border-top: solid #ededed 1px;
}
.movie-area-head { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center;}
.movie-area-head .movie-area-title {
  width: 40%;
  vertical-align: middle;
}
.movie-area-head .movie-area-read {
  width: 50%;
  vertical-align: middle;
  padding: 3rem 0 3rem 6rem;
  border-left: solid #d2d2d2 1px;
  color:#fff;
  line-height: 220%;
}
.movie-area-head .movie-area-title .sub-title {
   margin-top: 15px;
}
.movie-slide-wrapp {
   margin-top: 60px;
}
/* 
--------------------------------------------*/
.archive-area {
   padding: 6rem;
   background-color: #f8f8f8;
}
.archive-area .title {
  font-size: 3rem;
  padding-bottom: 3rem;
  text-align: center;
  color:#324664;
}
/* メインムービー 
--------------------------------------------*/
.mv-area-wrapp {
   position: relative;
}
.mv-area-wrapp .mv-title {
   position: absolute;
   top: 50%; left: 50%; transform: translate(-50%, -50%);
   margin: auto;
   z-index: 100;
}
.mv-area-wrapp .mv-title h2 {
   width: 300px;
   padding: 2rem;
}
.mv-area {
   position: relative;
   overflow: hidden;
   max-height: 800px;
}
.mv-area-inner {
   margin-left: -5%;
}
.mv-area .mv-title.fixed {
   position: fixed;
}
.btn-scroll {
   position: absolute;
   z-index: 200;
   width: 100%;
   left: 0;
   bottom: 0;
   text-align: center;
}
.btn-scroll.fixed {
   position: fixed;
}
.mv {
   position: relative;
   overflow: hidden;
   z-index: 10;
}
.mv video {
   width: 100%;
   height: auto;
   vertical-align: bottom;
}
.mv .content {
   width: 110%;
   height: auto;
   position: absolute;
   z-index: 1;
   color: #fff;
   font-size: 200%;
   top: 50%;
   transform: translateY(-50%);
   overflow: hidden;
}
.mv:after {
   content: '';
   display: block;
   width: 100%;
   height: 100%;
   background: url("../../images/mv_over.png") center center repeat;
   position: absolute;
   top: 0;
   left: 0;
   z-index: 100;
}

/* お問い合わせ
-------------------- */
#contact { background: #ddeaf2; }
#contact .contact_inner { width: 50%; margin: 0 auto; padding:4rem; }
.form-fieldset { margin-bottom: 2rem;}
.form-fieldset > legend,
.form-fieldset_radio > legend {
   color: #424242;
   font-size: 1.6rem;
   font-weight: bold;
   word-break: break-word;
   padding-bottom: 0.5rem;
}
.form-fieldset > legend:after,
.form-fieldset_radio > legend:after {
    content: "必須";
    background: #e53935;
    color: #ffffff;
    padding: 0.25rem 0.4rem;
    border-radius: 0.4rem;
    font-size: 1.4rem;
    margin-left: 0.5rem;
    white-space: nowrap;
}
.form-fieldset.not > legend:after {
    content: "任意";
    background: rgba(158, 158, 158, 0.25);
    color: #9e9e9e;
    padding: 0.25rem 0.35rem;
    border-radius: 0.4rem;
    font-size: 1.4rem;
    margin-left: 0.5rem;
    white-space: nowrap;
}
.form-fieldset input {
    padding: 0.75rem 1rem;
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 1.5;
    color: #424242;
    background-color: #ffffff;
    background-clip: padding-box;
    border: 1px solid rgba(189, 189, 189, 0.75);
    appearance: none;
    border-radius: 0.5rem;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
input.form-address-zip1 { width: 5.5rem !important;}
input.form-address-zip2 { width: 6.5rem !important;}
select.form-select {
    display: inline-block;
    max-width: 100%;
    width: auto;
}
.form-select {
    display: block;
    width: 100%;
    padding: 0.5rem 3.25rem 0.5rem 0.75rem;
    -moz-padding-start: calc(0.75rem - 3px);
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 1.5;
    color: #424242;
    background-color: #ffffff;
    background-image: url('../../images/arrow.svg');
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 16px 12px;
    border: 1px solid rgba(189, 189, 189, 0.75);
    border-radius: 0.5rem;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    appearance: none;
}
.form-fieldset input.company,
.form-fieldset input.mail,
.form-fieldset input.city,
.form-fieldset input.block,
.form-fieldset input.building { width: 85% !important;}
.form-fieldset input.form-phone-number { max-width: 6rem !important;}
textarea {
    width: auto;
    width: 100%;
    border: 1px solid #ccc;
    border-radius: 10px;
    padding: 1rem;
}
textarea { min-height: calc(1.5em + 1rem + 2px);}

.form-label-radio-checkbox input[type=radio]:not(.form-matrix-option), .form-check-input input[type=checkbox]:not(.form-matrix-option) {
    display: inline-block;
    height: 22px;
    min-height: 22px;
    width: 22px;
    min-width: 22px;
    overflow: hidden;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: transparent;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    border-width: 2px;
    transition: 0.2s ease-in-out;
    transition-property: background-color, border;
}

.form-btn-submit {
    font-size: 1.6rem;
    padding: 1rem 4rem;
}
.form_btn {
 display: block;
 color:#fff;
 background-color: rgba(50, 70, 100, 1);
 margin: 0 auto;
 padding: 0.75rem 3rem;
 font-size: 1.6rem;  
 border: 1px solid #43a047;
 border-radius: 10px;
 transition: 0.5s;
}
.form_btn:hover { background: #fff; color:rgba(50, 70, 100, 1); border: 1px solid rgba(50, 70, 100, 1);}
.pwed { text-align: center; font-size: 1rem; }
.pwed a {color: #95C963!important;}
.link {text-decoration: none;}


/* アコーディオン
-------------------- */
.trigger {
  position: relative;
  width: 100%;
  padding: 2rem;
  background-color: rgba(50, 70, 100, 1);
  border: none;
  transition: .4s;
  font-size: 1.8rem;
  color:#fff;
}
.trigger:hover {
  cursor: pointer;
  opacity: 0.6;
  transition: .4s;
}
.trigger[aria-expanded="false"] {
  border-radius: 15px;
}
.trigger[aria-expanded="true"] {
  border-radius: 15px 15px 0 0;
}
.accordion_contents {
  background-color: #fff;
  border-right: 2px solid #324664;
  border-bottom: 2px solid #324664;
  border-left: 2px solid #324664;
  border-radius: 0 0 15px 15px;
}
.accordion_contents[aria-hidden="true"] {
  height: 0;
  padding: 0 40px;
  overflow: hidden;
  visibility: hidden;
  opacity: 0;
  transition: .5s;
}
.accordion_contents[aria-hidden="false"] {
  height: auto;
  min-height: 100px;
  padding: 40px;
  visibility: visible;
  opacity: 1;
  transition: .5s;
}
.accordion_contents__title {
  margin: 0 0 40px 0;
  font-size: 25px;
}
.accordion_contents p + .accordion_contents p {
  margin-top: 20px;
}
.ac_icon {
  display: block;
  position: absolute;
  right: 20px;
  top: 50%;
  width: 24px;
  margin-left: 6px;
  flex-shrink: 0;
  transform-origin: center 43%;
  transition: transform 0.5s;
}
/* アイコンの三角矢印 */
.ac_icon::before,
.ac_icon::after {
  content: "";
  position: absolute;
  display: block;
  width: 15px;
  height: 3px;
  background-color: #ccc;
}
.ac_icon::before {
  left: 0;
  transform: rotate(45deg);
}
.ac_icon::after {
  right: 0;
  transform: rotate(-45deg);
}
/* アコーディオン表示の際に回転する */
.accordion_contents[aria-expanded] .ac_icon {
  transform: rotate(180deg);
}
