@charset "UTF-8";

@font-face {
   font-family: 'Noto Sans Japanese';
   font-style: normal;
   font-weight: 400;
   src: local('NotoSansJP-Regular.otf'),
        url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Regular.woff2) format('woff2'),
        url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Regular.woff) format('woff'),
        url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Regular.otf) format('opentype');
 }
 @font-face {
   font-family: 'Noto Sans Japanese';
   font-style:normal;
   font-weight: 700;
   src: url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Bold.woff2) format('woff2'),
        url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Bold.woff) format('woff'),
        url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Bold.otf) format('opentype');
 }
.noto400 {
	font-family: "Noto Sans Japanese", sans-serif;
	font-weight: 400;
}
.noto700 {
	font-family: "Noto Sans Japanese", sans-serif;
	font-weight: 700;
}
body {
	font-family: "Noto Sans Japanese", sans-serif;
	background-color: #FFF;
}

@import url('https://fonts.googleapis.com/css?family=Lato:700');

.lato {
	font-family: 'Lato', sans-serif;
}
img{
max-width: 100%;
height: auto;
width /***/:auto;
vertical-align:bottom;　
}
p {
	font-size: 14px;
}
.box_link {
	position:relative;
}
.box_link a {
	position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    text-indent:-9999px;
}
.box_link a:hover{
    background-color:#FFF;
    filter:alpha(opacity=50);
    -moz-opacity: 0.5;
    opacity: 0.5;
}
a:link {
	color: #D34E6F;
	text-decoration: none;
}
a:visited {
	color: #D34E6F;
}
a:hover {
	color: #D38A9C;
	text-decoration: none;
}

a:hover img.over{
	opacity: 0.6;
	filter: alpha(opacity=60);
	-ms-filter: "alpha( opacity=60 )";
}

/* clearfix */	

.clearfix:after {
  content: "";
  /* new clearfix */
  visibility: hidden;
  display: block;
  font-size: 0;
  content: " ";
  clear: both;
  height: 0;
}
 * html .clearfix {
  zoom: 1;
}
/* IE6 */
 *:first-child + html .clearfix {
  zoom: 1;
  display: inline-block;
}
/* IE7 */
.clearfix {
  display: block;
  *zoom: 1;
}
.clearfix:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.container {
	width: 100%;
	max-width: 960px;
	margin-left: auto;
	margin-right: auto;
}
.center {
	text-align: center;
}
.pc {
	display: block;
}
.mob {
	display: none;
}

.float {
	position: fixed;
	bottom: 50px;
	right: 0px;
}
.float .btn {
	padding: 20px;
	color: #fff;
	text-align: center;
	border-radius: 5px;
	margin-bottom: 10px;
}
.float .btn.counseling {
	background-color: #D34E6F;
}
.float .btn.seminar {
	background-color: #9AD426;
}
.float .btn.info {
	background-color: #D10A0B;
	line-height: 140%;
}
.float .btn.info span {
	color: #FDF827;
	font-weight: bold
}


/* header
---------------------------------------------*/

header {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	padding-top: 1%;
	padding-bottom: 1%;
}
header .container {
	width: 100%;
	max-width: 98%;
	padding: 1%;
}
header .container img.logo {
	float:left;
	width: 100%;
	max-width: 400px;
}
header .container img.catch {
	float: right;
	margin-top: 20px;
}

h1 {
	font-size: 4vw;
	font-weight: bold;
	line-height: 130%;
}
h1 span {
	font-size: 3vw;
	color: #DA3F65;
}


/* main_visual
---------------------------------------------*/
.main_visual {
	height: 0;
	/* 表示画像の高さ ÷ 表示画像の幅 × 100 */
    padding-top: 60.44%;
	background-image: url(images/2019/main.jpg);
	background-repeat: no-repeat;
	background-size: contain;
	position: relative;
	
}
.main_visual .container {
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	text-align: center;
	height: 100%;
}
.main_hos {
	right: 0px;
	position: absolute;
	top: 10%;
}
.main_tit {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	-webkit- transform: translateY(-50%) translateX(-50%);
}
.main_mar {
	left: 0px;
	position: absolute;
	bottom: 10%;
}


/* summary
---------------------------------------------*/
.summary {
    padding-top: 5%;
    padding-bottom: 5%;
    background-color: #F8DC2B;
    color: #000;
    margin-top: -3px;
}
.summary .txt_box {
	float: left;
	width: 63%;
}
.summary .intern {
	float: right;
}
.summary .txt_box p {
	line-height: 160%;
}
.summary .txt_box h2 {
	font-size: 2vw;
	font-weight: bold;
	margin-bottom: 10px;
}


/* 1st
---------------------------------------------*/

#first {
	background-color: #E8E8E8;
	padding-top: 8%;
	padding-bottom: 8%;
}
#first h2 {
	background: linear-gradient(transparent 75%, #F8DC2B 75%);
	display:inline-block;
	font-size: 3.5vw;
	font-weight: bold;
	letter-spacing: .1em;
	padding-bottom: 0px;
	margin-bottom: 1%;
	line-height: 140%;
}
#first h3 {
	font-weight: bold;
	margin-bottom: 3%;
	font-size: 3vw;
	line-height: 140%;
}
#first .center p {
	line-height: 150%;
	margin: 10px 0px 30px 0px;
	font-size: 14px;
}
#first .block {
	width: 90%;
	max-width: 440px;
	background-color: #fff;
	border: solid #3A0613 3px;
	margin-left: auto;
	margin-right: auto;
	padding: 3% 5% 3% 5%;
	position: relative;
}
#first .block h3 {
	text-align: center;
	font-size: 3vw;
	font-weight: bold;
	color: #3A0613;
	margin-bottom: 30px;
}
#first .block ol {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
	margin-bottom: 30px;
}
 
#first .block li {
  margin-bottom: 10px;
  padding-left: 35px;
  position: relative;
	line-height: 25px;
}
#first .block li:before {
  content: counter(my-counter);
  counter-increment: my-counter;
  background-color: #3A0613;
  color: #fff;
  display: block;
  float: left;
  line-height: 27px;
  margin-left: -35px;
  text-align: center;
  height: 25px;
  width: 25px;
  border-radius: 50%;
}
#first .block .marketing li:before {
  background-color: #1F4829;
}
#first .block .hospitality li:before {
  background-color: #7D1021;
}
#first .block h4 {
	font-size: 2vw;
	margin-bottom: 20px;
	font-weight: bold;
}
#first .block .marketing h4 {
	color: #1F4829;
}
#first .block .hospitality h4 {
	color: #7D1021;
}
#first .block .mark {
	position: absolute;
	bottom: -30px;
	right: -130px;
}
#first .fig {
	margin-top: 60px;
}

#first .grid {
	display: grid;
	grid-gap: 20px;
	grid-template-columns: 1fr 1fr 1fr;
	margin-bottom: 50px;
}
#first .grid_child {
	margin-bottom: 20px;
	border: solid #000 5px;
	padding: 20px;
	background-color: #fff;
}
#first .grid_child h3 {
	background: linear-gradient(transparent 80%, #F8DC2B 80%);
	display:inline-block;
	text-align: center;
	font-weight: bold;
	font-size: 18px;
	margin-bottom: 20px;
	margin-left: auto;
	margin-right: auto;
}
#first .grid_child p {
	line-height: 150%;
}

/* 2nd
---------------------------------------------*/

#second {
	background-color: #fff;
	padding-top: 5%;
	padding-bottom: 1%;
}
#second h2 {
	background: linear-gradient(transparent 75%, #F8DC2B 75%);
	display:inline-block;
	font-size: 4vw;
	font-weight: bold;
	letter-spacing: .1em;
	padding-bottom: 8px;
	margin-bottom: 5%;
}
/*
#second h2 {
	display:inline-block;
	font-size: 4vw;
	font-weight: bold;
	margin-bottom: 5%;
	line-height: 170%;
}
#second h2 span {
	background: linear-gradient(transparent 75%, #D34E6F 75%);
	padding-bottom: 7px;
}
*/
#second .grid {
	display: grid;
	grid-gap: 20px;
	grid-template-columns: 1fr 1fr 1fr;
	margin-bottom: 50px;
}
#second .grid_child {
	margin-bottom: 20px;
	border: solid #000 5px;
	padding-bottom: 10px;
}
#second .grid_child h3 {
	text-align: center;
	padding: 10px;
	background-color: #1C9AD6;
	color: #fff;
	font-size: 24px;
	font-weight: bold;
}
#second .grid_child h4 {
	text-align: center;
	padding: 10px;
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 8px;
}
#second .grid_child img {
	margin-bottom: 10px;
}
#second .grid_child p {
	margin-left: 3%;
	margin-right: 3%;
	line-height: 150%;
}
#second .seminar {
	width: 100%;
	max-width: 650px;
	margin-left: auto;
	margin-right: auto;
	padding-top: 30px;
	margin-bottom: 30px;
}
#second .seminar ul {
	font-size: 16px;
	margin-left: 2em;
}
#second .seminar ul li {
	margin-bottom: 10px;
	list-style: disc;
	line-height: 130%;
}

/* 3rd
---------------------------------------------*/

#third {
	padding-bottom: 5%;
	padding-top: 5%;
	background-image: url(images/3rd_back.png);
	background-repeat: repeat;
}
#third p {
	font-size: 14px;
	line-height: 150%;
	margin-left: 3%;
	margin-right: 3%
}
#third .grid {
	display: grid;
	grid-gap: 30px;
	grid-template-columns: 1fr 1fr;
}
#third .grid_child {
	border: solid #000 5px;
	background-color: #fff;
	padding-bottom: 3%;
}

#third .grid_child:nth-child(1) {
	grid-column:1/3;
	grid-row:1/2;
}
#third .grid_child:nth-child(2) {
	grid-column:1/3;
	grid-row:3/4;
}
#third .grid_child:nth-child(3) {
	grid-column:1/3;
	grid-row:5/6;
}
#third .grid_child:nth-child(4) {
	grid-column:1/3;
	grid-row:7/8;
}
#third .grid_child:nth-child(5) {
	grid-column:1/3;
	grid-row:9/10;
}
#third h3 {
	font-size: 3vw;
	font-weight: bold;
	color: #fff;
	background-color: #1F99D6;
	text-align: center;
	padding: 20px;
	border-bottom: solid #000 5px;
	margin-bottom: 3%;
}
#third ul {
	margin-left: 3%;
	margin-right: 3%;
}
#third ul li {
	text-indent: -1em;
	padding-left: 1em;
	list-style-type: none;
	margin-bottom: 10px;
	line-height: 150%;
	font-size: 14px;
}
#third .grid_child:nth-child(5) .grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-gap: 30px;
}
#third .grid .step ol {
	margin-left: 5%;
	margin-right: 3%;
}
#third .grid .step ol li {
	list-style-type: decimal;
	margin-bottom: 10px;
	line-height: 150%;
	font-size: 14px;
	margin-left: 1em;
}
#third h4 {
	font-size: 16px;
	margin-left: 3%;
	margin-right: 3%;
	margin-bottom: 10px;
	font-weight: bold;
	color: #3A0513;
}
#third .marketing h4 {
	color: #1F4829;
}
#third .hospitality h4 {
	color: #7D1021;
}
#third .grid .step  {
	margin-bottom: 30px;
	margin-left: 3%
}
#third table {
	margin-left: 3%;
	margin-right: 3%;
	width: 94%;
	table-layout: fixed;
}
#third table th {
	font-size: 16px;
	font-weight: bold;
	padding: 10px;
	color: #fff;
	border-bottom: solid #fff 3px;
	border-right: solid #fff 1px;
}
#third table td {
	font-size: 14px;
	line-height: 140%;
	text-align: left;
	background-color: #ccc;
	border-bottom: solid #fff 1px;
	border-right: solid #fff 1px;
	padding: 5px;
}
#third .marketing th {
	background-color: #1F4829;
}
#third .marketing tr.before td {
	background-color: #9BD4A9;
}
#third .marketing tr.after td {
	background-color: #5EB974;
}

#third .hospitality th {
	background-color: #7D1021;
}
#third .hospitality tr.before td {
	background-color: #F196A4;
}
#third .hospitality tr.after td {
	background-color: #E75168;
}

/* 4th
---------------------------------------------*/

#fourth {
	padding-top: 5%;
	padding-bottom: 5%;
	background-color: #1F99D6;
	color: #fff;
	margin-top: -3px;
}
#fourth p {
	font-size: 14px;
	line-height: 150%;
}
#fourth h2 {
	background: linear-gradient(transparent 80%, #F8DC29 80%);
	display:inline-block;
	font-size: 4vw;
	font-weight: bold;
	letter-spacing: .1em;
	padding-bottom: 8px;
	margin-bottom: 5%;
}
#fourth .container {
	max-width: 640px;
}
#fourth ul {

}
#fourth ul li {
	text-indent: -1em;
	padding-left: 1em;
	list-style-type: none;
	margin-bottom: 10px;
	line-height: 150%;
	font-size: 14px;
}
#fourth ul li a {
	color: #F7DD29;
	font-weight: bold;
}
#fourth ul li a:hover {
	color: #FF9A2B;
}
/* footer
---------------------------------------------*/

footer {
	padding-top: 5%;
	padding-bottom: 5%;
	background-color: #fff;
	text-align: center;
	font-size: 13px;
}


/* font
---------------------------------------------*/

@media screen and (min-width: 480px) {
#first h3 {
	font-size: calc(1rem + ((1vw - 4.8px) * 3));
}
#first .block h3 {
	font-size: calc(1rem + ((1vw - 4.8px) * 3));
}
#first .block h4 {
	font-size: calc(1rem + ((1vw - 4.8px) * 3));
}
#second h3 {
	font-size: 18px;;
}
#third h3 {
	font-size: calc(1rem + ((1vw - 4.8px) * 3));
}
.summary .txt_box h2 {
	font-size: 18px;
}
}

@media screen and (min-width: 960px) {
h1 {
	font-size: 38px;
}
h1 span {
	font-size: 30px;
}
.summary .txt_box h2 {
	font-size: 24px;
}
#first h2 {
	font-size: 34px;
}
#first h3 {
	font-size: 30px;
}
#first .block h3 {
	font-size: 30px;
}
#first .block h4 {
	font-size: 24px;
}
#second h2 {
	font-size: 43px;
}
#second h3 {
	font-size: 28px;
}
#third h3 {
	font-size: 28px;
}
#fourth h2 {
	font-size: 43px;
}
}



/* TEL
---------------------------------------------*/

@media screen and (min-width: 601px) {
	a[href^="tel:"] {
		pointer-events: none;
	}
}



/* layout
---------------------------------------------*/

@media (max-width: 960px) {

.container {
	width: 96%;
	margin-left: 2%;
	margin-right: 2%;
}
header .container {
	width: 96%;
}
}


@media (max-width: 600px) {
.pc {
	display: none;
}
.mob {
	display: block;
}
.main_hos {
	top: 3%;
	width: 50%;
}
.main_tit {
	width: 60%;
}
.main_mar {
	bottom: 3%;
	width: 50%;
}
.float {
	bottom: 0px;
	right: 0px;
	width: 100%;
}
.float .btn {
	padding: 5%;
	border-radius: 0px;
	margin-bottom: 0px;
	width: 40%;
	float: left;
	font-size: 14px;
}
.float .btn.info {
	float: none;
	width: 100%;
	padding: 15px 0px 15px 0px;
}
header .container img.logo {
	width: 40%;
	max-width: 100%;
}
header .container img.catch {
	width: 40%;
	margin-top: 10px;
}
/* summary
---------------------------------------------*/
.summary .txt_box {
	float: none;
	width: 100%;
}
.summary .intern {
	float: none;
	width: 100%;
}
.summary .txt_box p {
	margin-bottom: 20px;
}
	
/* 1st
---------------------------------------------*/

#first h2 {
	padding-bottom: 5px;	
}
#first .block {
	width: 80%;
}
#first .block .mark {
	bottom: 0px;
	right: 0px;
	width: 30%;
}
#first .fig {
	margin-left: 5%;
	margin-right: 5%;
}
#first .grid {
	grid-template-columns: 1fr;
	margin-bottom: 30px;
}
	
/* 2nd
---------------------------------------------*/

#second h2 {
	margin-bottom: 2%;
}
#second h2 span {
	padding-bottom: 5px;
}
#second .grid {
	grid-template-columns: 1fr;
}
#second h3 {
	padding-bottom: 5px;
}
#second .seminar ul {
	font-size: 14px;
}

	
/* 3rd
---------------------------------------------*/
#third .grid {
	grid-template-columns: 1fr;
	grid-template-rows: auto;
}
#third .grid_child:nth-child(-n + 6) {
	grid-column: 1;
    grid-row: auto;
}
#third .grid_child:nth-child(5) .grid{
	grid-template-columns: 1fr;
}
#third .grid .step  {
	margin-left: 0%
}
#third table th {
	font-size: 14px;
}
#third table td {
	font-size: 13px;
}
}
	
	
	
	

@media (max-width: 480px){

}
