@charset "utf-8";
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html {
  font-size: 62.5%;
  color: #00014B;
}
body {
  background: url("../img/utyu.png")no-repeat fixed center top;
  background-size: cover;
  background-color: #3300cc;
  text-align: center;
  font-size: 1.4rem;
  font-family: "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
  line-height: 1;
}
.title {
  color: #ffffff;
/*  text-shadow: -3px 0px 6px rgba(204, 0, 153, 1),
		        3px 0px 6px rgba(204, 0, 153, 1);*/
  display: inline-block;
  width: 100%;
  font-weight: bold;
  margin: 10% 0 6%;
  font-size: 5rem;
  position: relative;
  z-index: 10;
}

.title:after {
	content: '';
	position: absolute;
	top: 60%;
	left: 10%;
	display: inline-block;
	width: 80%;
	height: 30px;
	background-color: #cc0099;
	z-index: -10;
	background: linear-gradient(-45deg, transparent, #cc0099 50%, #cc0099 50%, transparent);
}

/*ホームロゴのスタイル*/

.header { 
	display: none;
	height: 15%;
	width: 100%;
	background-color: rgba(30, 0, 204, 0.9);
	position: fixed;
	top: 0;
	z-index: 1000;
}

.home {
  width: 13%;
 /* height: 50px;*/
  position: fixed;
  top: 3%;
  left: 2%;
  z-index: 1020;
}
.home img {
  width: 100%;
}
.home .moon {
  width: 30%;
  position: absolute;
  top: 0;
  left: 102%;
  transition: transform 0.4s;
  transition: -webkit-transform 0.4s;
}
.home .moon img {
  width: 100%;
}
.moon:hover {
  transform: rotate(360deg);
  -webkit-transform: rotate(360deg);
}
/*メニュー三本線*/
.menu-icon {
  cursor: pointer;
  position: fixed;
  top: 2%;
  right: 2.5%;
  z-index: 1020;
  width: 3.6%;
}
.menu-icon-line {
  background-color: #fff;
  width: 100%;
  height: 3px;
  margin: 30% 0 0;
}
/*展開メニュー*/
.menu-box {
  position: fixed;
  width: 100%;
  top: 0;
  right: 0;
  z-index: 1010;
}
.menu {
  position: fixed;
  display: none;
  width: 18%;
  height: 160px;
  top: 15%;
  right: 0;
  background: rgba(255, 255, 255, 0.7)
}
.menu .menu-list {
  list-style-type: none;
  margin: 1.2% .8% 1.2%;
}
.menu .menu-list a {
  display: block;
  margin-left: 8%;
  text-align: left;
  padding-top: 10px;
  padding-bottom: 5px;
  color: #000;
  text-decoration: none;
  font-size: 2.4rem;
  border-bottom: 3px dashed transparent;
}
.menu .menu-list a:hover {
  border-bottom: 3px dashed #cc0099;
}
/*現在のページを示すメニュー*/
.now {
  background-color: rgba(0, 0, 0, 0.3);
}
.now a {
  cursor: default;
}
.menu .now a:hover {
  border-bottom: 3px dashed transparent;
}



/********************作品紹介のスタイル*************************/

.wrapper {
	background-color: rgba(255, 255, 255, 0.7);
	margin: 0 auto;
	width: 76%;
}

.works {
	width: 80%;
	height: 100%;
	margin: 0px auto 4%;
	/*border: 1px solid #000;*/
}

@media screen and (max-width: 1200px) {
	.works {
		height: 300px;
	}
}

.works h2 {
	padding: 3%;
	font-size: 3rem;
	text-align: left;
}

.imgbox {
	float: left;
	width: 50%;
}

.absonsive {
	position: relative;
	max-width: 100%;
	/*background-color: #555;*/
	overflow: hidden;
}

@media screen and (max-width: 1920px) {
	.absonsive {
		height: calc(370 / 1920 * 100vw);
		clear: both;
	}
	
	.absonsive .desktop {
		top: calc(29 / 1920 * 100vw);
		left: calc(63 / 1920 * 100vw);
	}
}

@media screen and (max-width: 768px) {
	.absonsive {
		height: calc(442 / 768 * 100vw);
		clear: both;
	}
	
	.absonsive .desktop {
		top: calc(33 / 768 * 100vw);
		left: calc(75 / 768 * 100vw);
	}
	
}

.pc {
	width: 100%;
	height: 100%;
}

.pc img {
	width: 100%;
	height: 100%;
}


.desktop {
	position: absolute;
	top: 25px;
	left: 56px;
	overflow-y: scroll;
	width: 78%;
	height: 78%;
}

.desktop img {
	width: 100%;
	height: 100%;
}

/*制作背景のスタイル*/

.textbox {
	color: #fff;
	float: right;
	width: 46%;
	
	margin-top: 0;
	/*margin-right: 4%;*/
	font-size: 1.6rem;
	background-color: rgba(30, 0, 204, 0.6);
/*	border-radius: 50%;*/
	/*border: 2px dashed #fff;*/
	overflow-y: scroll;
	line-height: 1.4;
	padding: 1%;
	padding-bottom: 3%;
}

.textbox h3 {
	line-height: 2;
	padding: 1% 0 0;
	font-size: 1.8rem;
}

@media screen and (max-width: 1200px) {
	.textbox {
		height: 270px;
		overflow-y: scroll;
	}
}

/*全体のページリンクあり*/

.gotoall a {
	clear: both;
	display: block;
	width: 100%;
/*	height: 20px;*/
	padding: 14px;
	text-decoration: none;
	text-align: center;
	color: #cc0099;
	border: 2px solid #CC0099;
	background-color: rgba(255, 255, 255, 0.5);
	font-size: 1.6rem;
	font-weight: bold;
	margin-top: 4%;
}
.gotoall a:hover {
	box-shadow: -6px 0px 20px rgba(204, 0, 153, 0.7),
		         6px 0px 20px rgba(204, 0, 153, 0.7);
}

/*全体のリンクなし*/

.gotonone {
	display: block;
	width: 100%;
	padding: 10px;
	color: #fff;
	text-decoration: none;
	text-align: center;
	border: 3px solid #cc0099;
	background-color: rgba(0, 0, 0, 0.3);
	margin-top: 4%;
}


/*ポイントのスタイル*/

.point {
	clear: both;
	width: 76%;
	margin: 4% auto;
	overflow: hidden;
}

.point-heading {
	width: 100%;
	padding: 2% 0;
	text-align: center;
	margin: 6% auto 2%;
	border-bottom: 2px dashed #0b2d5d;
	font-size: 3rem;
}

.point p {
	margin: 0;
	/*border: 1px solid #000;*/
	height: 340px;
	overflow: auto;
	line-height: 2;
	font-size: 1.8rem;
	text-align: left;
}

.point p img {
	width: 100%;
}

.point p strong {
	font-size: 2.4rem;
	padding-bottom: 1rem;
}

.point .point_l {
	float: left;
	width: 46%;
	margin-left: 1%;
}

.point .point_r {
	float: right;
	width: 46%;
	margin-right: 1%;
}


/*ルイボスティーのみのスタイル*/
.point .sub_teap {
	height: 100%;
	width: 30%;
	margin-right: 16%;
} 
.point .sub_teap2 {
	height: 100%;
	width: 30%;
	margin-right: 10%;
} 


/*カフェドパリのみのスタイル*/
.point .sub_cp {
	height: 100%;
	width: 30%;
	margin-left: 8%;
} 


/*観光案内のみのスタイル*/
hr {
	clear: both;
	border-top: none;
}

.point .sub08pi {
	width: 46%;
	height: 100%;
}

.point .sub08pb {
	width: 46%;
	height: 100%;
}

.point .sub08pt {
	width: 100%;

	
}

/*ビスくんサイトのみスタイル*/
.point .sub04p {
	height: 100%;
}

.point .sub04pt {
	height: 400px;
}

/*自由研究応援サイトのみのスタイル*/
.point .sub03box {
	height: 250px;
}

.point .sub03box2 {
	height: 200px;
	padding-top: 40px;
}

.point .sub03p {
	width: 100%;
	height: 100%;
}

.point .sub03pt {
	max-height: 200px;
}

.point .sub03p2 {
	/*padding-top: 10px;*/
	width: 100%;
	height: 100%;
}

/*将棋ロボのみのスタイル*/
.roboimg img{
	width: 80%;
	height: 100%;
}

.point .subrp {
	height: 100%;
}


/*サンタのみのスタイル*/
.point .sub06p {
	height: 100%;
}

.desk06 {
	overflow-y: hidden;
}

/*ラビスタンプのみスタイル*/
.point .sub_rabi {
	width: 80%;
	margin: 0 10%;
	height: 100%;
}

/*ボールペンのみのスタイル*/
.point .point_penp {
	height: 100%;
}


/****************************ボタンのスタイル*********************/

.button ul {
	clear: both;
	width: 100%;
	/*margin-left: 15%;*/
	padding-bottom: 20px;
	padding-top: 60px;
}

.button ul li {
	display: inline-block;
	text-align: center;
	/*margin-right: 5%;*/
	list-style-type: none;

}

.button a {
	width: 200px;
	display: block;
	font-weight: bold;
	font-size: 1.6rem;
	text-decoration: none;
	transition: .4s;
	color: #cc0099;
	border: 2px solid #CC0099;
	padding: 20px 0;
	/*margin: 10px auto 4%;*/
	background-color: rgba(255, 255, 255, 0.5);
}
.button a:hover {
	box-shadow: -6px 0px 20px rgba(204, 0, 153, 0.7),
		         6px 0px 20px rgba(204, 0, 153, 0.7);
}

.centerbtn {
	margin: 0 3%;
	background-color: #fff;
}


.footer {
	clear: both;
	height: 80px;
}

.footer p {
	padding-top: 20px;
	font-size: 1.4rem;
	text-align: center;
	color: #fff;
}

/*********************************横幅768pxのスタイル*********************************************/

@media(max-width: 768px) {

  /*横幅768pxのヘッター*/
	.header {
		height: 8%;
		display: block;
	}
	
 .title {
    margin-top: 18%;
    font-size: 2rem;
  }
	
.title:after {
	left: 5%;
	width: 90%;
	height: 12px;
}
	
  .home {
    width: 26%;
    top: 10px;
    left: 4%;
  }
  /*	横幅768pxのメニュー*/
.menu-icon {
		width: 8%;
		top: 0.5%;
	}
  .menu-icon-line {
    height: 2px;
  }
  .menu-box .menu {
    display: none;
    width: 40%;
    height: 120px;
    background-color: rgba(255, 255, 255, 0.8);
    top: 8%;
  }
  .menu .menu-list {
    margin-left: 0;
    height: 30px;
  }
  .menu .menu-list a {
    font-size: 2rem;
    margin: 0 auto;
  }
  /********************横幅768pxの作品******************************/

	.wrapper {
		width: 90%;
	}
	
	.works {
		width: 100%;
	}
	
	.works h2 {
	font-size: 2rem;
	text-align: center;
}
	
	.imgbox {
		clear: both;
		width: 100%;
		margin: 0 auto;
/*		height: 100%;
		overflow: hidden;*/
	}
	
	.gotonone {
		display: none;
	}
	.textbox {
		clear: both;
		width: 90%;
		height: 100%;
		margin: 10px 5%;
		font-size: 1.4rem;
		/*border: 10px solid rgba(30, 0, 204, 0.6);*/
	/*	background-color: rgba(30, 0, 204, 0.2);
		color: #00014B;*/
	}
	
	.textbox h3 {
		font-size: 1.6rem;
	}

	

/*	横幅768pxポイントのスタイル*/
	
	.point {
		width: 90%;
	}
	
.point-heading {
	font-size: 2rem;
	margin-bottom: 20px;
}
	
	.point p {
		height: 100%;
		font-size: 1.4rem;
	}
	
	.point p strong {
	font-size: 1.6rem;
}
	
	.point .point_l {
	clear: both;
	width: 100%;
	margin: 0;
}

.point .point_r {
	clear: both;
	width: 100%;
	margin: 0;
}

/****横幅768pxのカフェドパリのスタイル*****/
.point .sub_cp {
	width: 60%;
	margin: 0 20%;
}
	
	
/****横幅768pxのビスくんのスタイル*****/
.point .sub04pt {
    height: 300px;
	border-top: 1px dotted rgba(30, 0, 204, 0.5);
}	
	
	
/****横幅768pxの自由研究応援サイトのスタイル*****/
.point .sub03box {
    height: 200px;
}
	
.point .sub03box2 {
	height: 120px;
	border-top: 1px dotted rgba(30, 0, 204, 0.5);
	padding-top: 0px;
}
	
	
	
  /*横幅768pxのフッター*/
  .footer {
    height: 50px;
  }
  .copyright {
    font-size: 1.2rem;
    padding-top: 20px;
  }
}
