@charset "shift_jis";

html, body {
    width: 100%;
	height: 100%;
	margin: 0px;
	padding: 0px;
	font-size:100%;
}

ul {
	margin: 0px;
}

/*メニュー
-------------------------------------------------------*/

#menu {
    text-align: center;
    margin-right: auto;
    margin-left: auto;
    clear: both;
    justify-content: center;
    display:flex;
    background: #fff;
    max-width: 920px;
    min-width: 550px;
    height:75px;
    position: relative;
}

.menu_left{
    position:absolute;
    top: 0; 
    left: 0;
    text-align: left;
    background: #fff;
    min-width: 200px;
}

.menu_right{
    position:absolute;
    top: 10px; 
    right: 10px;
    text-align: right;
    background: #fff;
    margin: auto;
    white-space: nowrap;
}

.logo-image{
    width: 192px; 
    height:72px;
    border:0px;
}

.menu_link {
    font-size: 12pt;
    margin:15pt 10pt 10pt 10pt; /*上右下左*/
    display: inline-block;
  }

.menu_link {}
.menu_link a{
	display: inline-block;
	color:#2e8b57;
	font-size:120%;
	text-decoration:none;
	position: relative;
	transition: .3s;
}
.menu_link a::after{
	position: absolute;
	bottom: 0;
	left: 50%;
	content: '';
	width: 0;
	height: 1px;
	background-color: #2e8b57;
	transition: .3s;
	transform: translateX(-50%);
}
.menu_link a:hover::after{
	width: 100%;
}

/*ヘッダー
-------------------------------------------------------*/
#header {
    text-align: center;
    margin-right: auto;
    margin-left: auto;
    clear: both;
    justify-content: center;
    display:flex;
    background: #fff;
    width: 950px;
}

@keyframes open-keyanime1{  /* アニメーションの動き */
  0% { 
    opacity:0; /* 完全に透明 */
 } 
  100% {
    opacity:1; /* 透明度無し、通常表示 */
  }
}

.resizeimage{ 
   text-align: center;
   min-width:940px;

   position: relative;/*相対配置*/
   animation-name: open-keyanime1 ; 
   animation-duration: 2s; /* 5秒間で表示 */ 
   animation-fill-mode: both;
   animation-iteration-count: 1; /* 1回実行させています */
}

.resizeimage img {
    width: 100%; 
    height:100%;
    margin: auto;
    }

.resizeimage p{
    position: absolute; /* 要素の配置方法を指定 */
    color: #fff;
    font-size:26pt;
    font-family: Arial, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

/*文字フェードイン 左から右*/
.faderight {
    animation-name: faderight;
    animation-duration: 2s;       /*アニメーション時間*/
    animation-iteration-count: 1; /*繰り返し回数*/
    animation-direction: normal; /*往復処理をするかどうか*/
    animation-fill-mode: forwards; /*アニメーション後のスタイルをどうするか*/
    margin:5px 350px 350px 5px;   /*上右下左*/
}
@keyframes faderight {
from {
    opacity: 0;
    transform: translateX(0);
}
to {
    opacity: 1;
    transform: translateX(20px);
}
}

/*文字フェードイン 右から左*/
.fadeleft {
    animation-name: fadeleft;
    animation-duration: 2s;
    animation-iteration-count: 1;
    margin:280px 5px 5px 350px;
}
@keyframes fadeleft {
from {
    opacity: 0;
     transform: translateX(50px);
}
to {
    opacity: 1;
    transform: translateX(0);
}
}

/* 内容
---------------------------------------------------- */
#box{
    min-width: 940px;
}

.flexbox{
    margin-right: auto;
    margin-left: auto;
    clear: both;
    justify-content: center;
    display:flex;
}


.anime{
   animation-name: open-keyanime1 ; 
   animation-duration: 3s; /* 5秒間で表示 */ 
   animation-fill-mode: both;
   animation-iteration-count: 1; /* 1回実行させています */
}

/* 表示方法 */
.fade {
  transition: all 2000ms;
  opacity: 0;
  visibility: hidden;
  transform: translate(0px, 50px);
}

.fadein {
  opacity: 1;
  visibility: visible;
  transform: translate(0px, 0px);
} 

.flexbox_image{
 margin:15px 0 15px 0;
}

div.flexbox_left{
  padding: 15px 15pt 0 15pt; /*上右下左*/
  width: 500px;
  min-width: 290px;
  height: 285px;
  background: #fff;
  float: left;
}

div.flexbox_right{
  padding: 15px 15pt 0pt 15pt;
  width: 500px;
  min-width: 290px;
  height: 285px;
  background: #fff;
  float: right;
}

.flexbox_right a:link,
.flexbox_right a:visited { 
   color: #444444; 
   text-decoration: underline;
}

.flexbox_right a:hover,
.flexbox_right a:active { 
   color: #66cdaa; 
   text-decoration: underline;
}

/*開発実績*/
.achievements {font-size:smaller}



/* sec
---------------------------------------------------- */

p {
  margin: 0;
  padding:5px 5px 5px 5px;
  text-align: left;
  line-height: 1.6;
  font-size:100%;
}

#to_toiawae {
  margin: 10px 0 10px 0;
  text-align: center;
}
#to_toiawae img {
  margin: 0 15px 0 15px;
}

/* sitemap
--------------------------------------------------------------*/
.sitemap {
	text-align:left;
	padding:0 0 20px 100px;
	color: #333333;
	font-size:12px;
}
.sitemap th {
	text-align:left;
	font-weight:normal;
	padding: 0 10px 0 0;
}
.sitemap td {
	text-align:left;
}

/* フッター
---------------------------------------------------- */
#div_footer{
 background-color:#66cdaa;
 color: #000000;
 font-size:13px;
 width: 100%;
 height: 15%;
 padding: 10px 0px 0px 0;
 text-align: center;
}

#div_footer div{
 margin-top:20px;
}

#div_footer a:link,
#div_footer a:visited { 
	color: #000000; 
	text-decoration: none;
}

#div_footer a:hover,
#div_footer a:active { 
	color: #66cdaa; 
	text-decoration: underline;
}

/* 文字消去
---------------------------------------------------- */
.moji{
	display:block;
	width:0;
	height:0;
	overflow:hidden;
	position:relative;
}

/*スマホ用*/
@media screen and (max-width:480px) {
#menu {
    text-align: center;
    margin-right: auto;
    margin-left: auto;
    clear: both;
    justify-content: center;
    display:flex;
    background: #fff;
    width: 100%;
    height:75px;
    position: relative;
}

.menu_left{
    position:absolute;
    top: 10px; 
    left: 0;
    text-align: left;
    background: #fff;
    width: 50%;
}

.menu_right{
    position:absolute;
    top: 10px;
    left: 5px;
    text-align: right;
    background: #fff;
    width: 180px;
    margin: auto;
    white-space: nowrap;
}

.logo-image{
    width: 50%; 
    height:50%;
    border:0px;
}

.menu_link {
    font-size: 10pt;
    margin:15pt 5pt 10pt 5pt; /*上右下左*/
    display: inline-block;
  }


}
