@charset "utf-8";
/* CSS Document */
* { 
    margin: 0;
    padding: 0;
    /*box-sizing: border-box;*/
}
body{
	/*background: #ffffff;*/
	font-family:Hannari,"游明朝",Yu Mincho,YuMincho,Hiragino Mincho ProN,"ヒラギノ明朝 ProN W3",serif;
	font: #2D579A;
	font-size: 24px;
	line-height: 1.5em;
	/*padding-top: 90px;*/
	width: 100%;
    margin: auto;
    /*background-color: rgba(204,204,204,0.5);*/
}
/*キャッチコピーの設定*/
.copy{
	position: absolute;
	color: #2D579A;
	z-index: 4;
	top: 70%;
	left: 20%;
	transform: translate(-50%, -50%);
	/*text-align: center;*/
	font-size:180%;
	letter-spacing: 0.25em;
	/*margin: 50px;*/
    writing-mode: vertical-rl;    
    font-weight:900;
}
/*navの設定*/
header{
	width: 100%;
	margin-top: 0.5%;
	position: fixed;
	z-index: 10;
}
#header_area{
	width: 100%;
	height: 150px;
	margin: 10px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	/*justify-content:flex-end;*/
}
#logo{
	padding-top: 0.5%;
	text-align: center;
}
header ul {
	display: flex;
	text-align: right;
	justify-content:flex-end;
	/*display: inline-block;
    width: 120%;  項目の幅を指定 */
}
#nav li{
	/*border: 1px solid #eae6e3;
    background: linear-gradient(transparent 10%, yellow 10%);*/
    color: #2D579A;
    writing-mode: vertical-rl;
}
#nav ul li::after{
	padding-left: 20px; /* li要素のwidthと調整 */	
}
 
#nav ul li a {
    color: #2D579A;
    background: linear-gradient(transparent 10%, #E5D64C 20%);
    text-decoration: underline;
}
#nav ul li a:hover{
    color: #2D579A;
    background: linear-gradient(transparent 10%, #BAD7B6 20%);
    text-decoration: underline;
}
header ul li {
	padding: 25px;
	display:block;
	font-size: 125%;
	background: rgba(255,255,255,0.7);
}
body a[href="#"] {
  opacity: 0.5;
}
/*トップ画像背景設定*/
/*.green_haikei{
    width: 100%;
    height: auto;
    background: url("../image/intro_haikei_2.jpg") repeat-y;
    background-position: center;
    position: relative;
}*/
.haikei{
    background: url(../image/top_haikei_t.png) no-repeat;
    margin-top: 5px;
    width: 110%;
    height: 120vh;
    /*position: relative;*/
    background-size: cover;
	background-position: center center;
}
.slider-5{
    top:10px;
    right:0px;
	width: 100%;
	height: 100vh;
	position: absolute;
	/*background-size: cover;
	background-position: center;*/
}
.slider5-wrap {
  width: 100%;
  margin: 0 auto;
  /*position: relative;*/
}
.slider-5 .slick-slide {
    width: 100%;
    height: 100vh;
    overflow: hidden;
}
.slider-5 .slick-slide img {
    position:absolute; 
    display: block;
    width: 60%;
    height: 68%;
    object-fit: fill;
    right: 5%;
    top: 13%;
}
.dots-5 .slick-dots {
  text-align: center;
    margin-top:10px; 
}
.dots-5 .slick-dots li {
  display: inline-block;
  width: 100px;
  height: 6px;
  /*margin-top: 30px;*/
  background: #eaeaea;
  cursor: pointer;
    text-decoration: none;
    list-style: none;
}
.dots-5 .slick-dots button {
  display: block;
  width: 0%;
  height: 6px;
  margin: 0;
  font-size: 0;
  padding: 0;
  border: 0;
  opacity: 0;
  outline: none;
  background: #0f8c44;
  cursor: pointer;
}
.dots-5 .slick-dots .slick-active button {
  background: #0a467d;
  opacity: 1;
}
.slick-dots li button:before {
  content:'';
　background: #E0E0E0;
　opacity: 1;
}
/*textの設定*/
h1{
	font-size: 100%;	
}
h2{
	font-size: 140%;
	margin-bottom: 30px;
	border-radius: 5px 0 0 5px;
	color: #2D579A;
    background: url("../image/h2_sen.png") repeat-x;
    /*background: url("../image/h2_sen.png") repeat-x,
        linear-gradient(transparent 80%, #E5D64C 20%);*/
    font-weight:500;
    background-position: center bottom;
}
.page-title{
    margin-top: 100px;
    clear: both;
    z-index: 8;
}

.white{
    color: #eae6e3;
}
h3{
	font-size: 125%;
    margin: 10px;
	color: #2D579A;
    font-weight:450;
}
p{
    color: #2D579A;
}
dd{
    color: #2D579A;
}
dt{
    color: #2D579A;
}
li{
    color: #2D579A;
    list-style: none;
}
strong{
	font-size: 113%;
}
/*コンテンツの設定*/
#contents p{
	font-size: 115%;
	margin: 3px;
    color: #2D579A;
}
#contents{
	/*padding: 10px 40px;*/
    width: 80%;
	margin: auto;
    /*background-color: rgba(15,140,68,0.3);*/
    height: auto;
}
/*#contents ul{
     width: 100%;
}*/
/*回り込み設定*/
.imgL{
	float: left;
	margin-right: 2%; 
    width: 30%;
    margin: 10px;
    padding: 10px;
    /*clear: both;*/
}
.imgR{
	float: right;
	margin-left: 2%;
    width: 30%;
    margin: 5px;
    padding: 10px;
    /*clear: both;*/
}
.imgS{
	float: left;
	margin-right: 2%; 
    width: 10%;
    margin: 1px;
    padding: 1px;
    /*clear: both;*/
}
.clear{
	clear: both;
}
.clear::after{
	content:"";
	display: block;
	clear: both;
}
/*セクションの全体の設定*/
section{
	margin: 0 auto;
	padding: 50px;
    width: 90%;
    height: auto;    
}
section::after{
    content:"";
	display: block;
	clear: both;
}
/*イントロの設定*/
#intro{
    /*background: url("../image/rokuro_koushi_1280.jpg") no-repeat;*/
    /*background-color: rgba(255,255,255,0.8);
    background-blend-mode:lighten;*/
    background: url("../image/haikei_green_ume.jpg") no-repeat; 
    background-size: cover; 
    background-position:center bottom;
    margin-top: -50px;
    padding: 50px;
    text-align: center;
}
#intro p{
    text-align: center;
    width: auto;
    height: 0 auto;
    margin: 50px 20px;
    /*display: inline-block;
    column-count: 2;
    column-width: 600px; 
    margin: 80px;
    padding: 100px;
    line-break: normal; 
    line-height: 2em;*/
}
/*courseInfoの設定*/
#courseInfo{
    /*height: 105vh;*/
    background: url("../image/top_haikei_t.png") no-repeat;
    /*background-color: rgba(255,255,255,0.9);
    background-blend-mode:lighten;*/
    background-size: cover;
    background-position:center center;
}
#courseInfo::after{
    content:"";
	display: block;
	clear: both;
}
#courseInfo img{
    background-color:#ffffff;
    width: 33%;
    height:auto; 
}
/*koushiの設定*/
#koushi{
    /*height: 65vh;*/
    background: url("../image/haikei_green_ume.jpg") no-repeat;
    /*background-color: rgba(255,255,255,0.8);
    background-blend-mode:lighten;*/
    background-size: cover;
    background-position:center bottom;
    /*background-attachment: fixed;*/
}
#koushi img{
    width: 30%;
    height: auto; 
}
.keireki{
    display: flex;
    margin: 0 auto;
    padding: 80px;
}
.keireki ul{
    /*width: 500px;*/
    margin: 0 auto;
    font-size: 2rem;
    padding: 40px 0;
     width: 100%;
}
.keireki li{
    width: 500px;
}
/*accessの設定*/
#access{
    width: 90%;
    /*background: url("../image/top_haikei2.png") no-repeat;*/
    background: url("../image/top_haikei_t.png") no-repeat;
    /*background-color: rgba(255,255,255,0.8);
    background-blend-mode:lighten;*/
    background-size: cover;
    background-position:center top;
}
#access img{
    width: 50%;
    height: auto; 
}
.access{
    width: 60%;
    display: block;
    color: #2D579A;
    margin: 18px;
    font-size: 1,125rem;
    padding: 3px;
    background-color: rgba(255,255,255,0.8);
    border-width: 1px 0;
}
tr{
    border: solid #BAD7B6;
    border-width: 1px 0;
}
td{
    /*text-align: right;*/
    display: table-cell;
    padding:0.4rem;
}
td:after{
    display: inline-block;
    content: "";
    width: 1em;
    font-size: 1em;
}
/*cafeの設定*/
#cafe{
    width: 90%;
    background: url("../image/haikei_green_ume.jpg") no-repeat;
    /*background-color: rgba(255,255,255,0.8);
    background-blend-mode:lighten;*/
    background-size: cover;
    background-position:center bottom;
}
#cafe img{
    width: 30%;
    height: auto;
}
/*shadowの設定*/
.bs01{
    box-shadow:2px 2px 5px rgba(0, 0, 0, 0.7);
}
/*menuの設定*/
.menu{
    width: 60%;
    /*max-width: 600px;*/
    height: auto;
    margin: 18px;
    font-size: 1,125rem;
    padding: 3px;
    background-color: rgba(255,255,255,0.8);
}
.menu dl {
    display: table;
    width: 100%;
    border: solid #BAD7B6;
    border-width: 1px 0;
    padding: 1px;
}
.menu dt{
    display: table-cell;
    padding:0.4rem;
}
.menu dd{
    text-align: right;
    display: table-cell;
    padding:0.4rem;
}
.menu dd:after{
    display: inline-block;
    content: "";
    width: 1em;
    font-size: 1em;
}
/*.menu dd.from:after {
    content: "〜";
}*/
.notes{
    font-size: 1rem;
    font-family:"Yu Mincho", "YuMincho";
}
.notes p{
    margin: 5px;
}
/*footer*/
footer{
	clear: both;
	width: 100%;
	max-width: 1920px;
	height: 200px;
	margin: 0 auto;
	text-align:center; 
	position: absolute;/*②絶対位置*/
	bottom: 0; /*下に固定*/
	background:url("../image/footer.png") no-repeat;
	padding-top: 50px;
}
.footer_area {/*親div*/
	position: relative;/*相対配置*/
	/*margin-top:50px;*/
	margin-bottom: 0px;
	padding:30px;
  }
strong{
	color: #2D579A;
	font-size: 135%;
}
.copyright{
	margin-bottom: 0;
	padding-bottom: 0;
}
/*梅の装飾画像*/
.ume{
    background: url(../image/ume_t.png) no-repeat;
    /*background-color: #E5D64C;*/
    position: absolute;
    top: 150%;
    left: 20%;
    width: 50%;
    height: 50px;
   background-position: center center;
   /* margin-top: 30px; 
    margin-bottom: 30px;
    padding: 10px;
    clear: both;*/
    z-index: 6;
}
/*.line{
    background: url(../image/line.png) repeat-x;
    background-color: #E5D64C;
    width: 100%;
    height: 100px;
   background-position: center center;
    margin-top: 30px; 
    margin-bottom: 30px;
    padding: 10px;
    clear: both;
    z-index: 6;
    opacity: 0.6;
}
.line::before{
    content: "";
　display: block;
　clear: both;
}
.line::after{
    content: "";
　display: block;
　clear: both;
}
.line_sub{
    background: url(../image/line.png) repeat-x;
    background-color: #E5D64C;
    width: 100%;
    height: 100px;
    background-position: center center;
    margin-top: 10px; 
    margin-bottom: 50px;
    padding: 10px;
    clear: both;
    z-index: 6;
    position: relative;
    opacity: 0.3;
}*/
/*subpageの設定*/
.subpage_haikei{
     background: url(../image/top_haikei_t.png) no-repeat;
    /*margin-top: 50px;*/
    width: 100%;
    height: 22vh;
   /* position: relative;*/
    background-size: cover;
	background-position: center center;
    /*opacity: 0.5;*/    
}
.subpage_top_wrap{
	width: 100%;
	height: 20vh;
	position: absolute;
    margin-bottom: 50px;
	/*background-size: cover;
	background-position: center;*/
}
/*.subpage_top_wrap img {
    position:absolute; 
    display: block;
    width: 55%;
    height: 65%;
    object-fit: fill;
    right: 13%;
    top: 15%;
}*/
.subpage_top_title{
	position: absolute;
	color: #2D579A;
	/*z-index: 4;*/
    text-align: center;
	top: 70%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size:170%;
	letter-spacing: 2em;
	margin: 5px; 
    font-weight:900;
}
/*各section_subの設定*/
#courseInfo_sub{
    width: 100%;
    height: auto;
    margin-top: 10px;
}
#courseInfo_sub img{
    background-color:#ffffff;
}
#koushi_sub{
    width: 100%;
    height: auto;
    margin-top: 10px;
}
#koushi_sub img{
    width: 23%;
}
/*予約フォーム*/
#resrvation_sub{
  /*font-size: 100%;*/
    width: 100%;
    height: auto;
    color: #2D579A;
    padding: 20px;
    margin-top: 15px;
}
/*h1 {
  font-size: 24px;
  margin-top: 0;
}*/
#entryForm{
    margin: 50px;
}
form {
  width: 500px;
  margin: 0 auto;
}
label {
  display: block;
  margin-top: 25px;
}
input {
  width: 100%;
  padding: 15px;
  border: 1px solid #ccc;
  border-radius: 5px;
}
select {
  width: 100%;
  padding: 15px;
  border: 1px solid #ccc;
  border-radius: 5px;
}
input[type="submit"] {
  background-color: #2D579A;
  color: #fff;
  padding: 20px 20px;
  border: 1px solid #000;
  border-radius: 5px;
  cursor: pointer;
}
/*ボタンの設定*/
.entryBtns{
	text-align: center;
	margin: 40px;
}
/*下層P講習中の様子イメージ画像*/
.yousu1{
    width: 25%;
    height: auto;
    position: absolute;
    top: 50%;
    right: 30%;
}
.yousu2{
    width: 20%;
    height: auto;
    position: absolute;
    top: 100%;
    right: 30%;
}
.yousu3{
    width: 22%;
    height: auto;
    position: absolute;
    top: 55%;
    right: 5%;
}
.burger{
    width: 15%;
    height: auto;
    position: absolute;
    top: 40%;
    right: 35%;
}
.machaSet{
    width: 25%;
    height: auto;
    position: absolute;
    top: 70%;
    right: 30%;
}
.cafeLatte{
    width: 20%;
    height: auto;
    position: absolute;
    top: 50%;
    right: 5%;
}
/*menu_subの設定*/
.menu-title{
    margin-top: 200px;
}
.menu_sub{
    width: 35%;
    height: 300px;
    margin-top: 0 auto;
    font-size: 1,125rem;
    padding: 0 auto;
}
.menu_sub dl {
    display: table;
    width: 100%;
    border: solid #BAD7B6;
    border-width: 1px 0;
}
.menu_sub dt{
    display: table-cell;
    padding:0.4rem;
}
.menu_sub dd{
    text-align: right;
    display: table-cell;
    padding:0.4rem;
}
.menu_sub dd:after{
    display: inline-block;
    content: "";
    width: 1em;
    font-size: 1em;
}
/*.menu dd.from:after {
    content: "〜";
}*/
.notes{
    font-size: 1rem;
    font-family:"Yu Mincho", "YuMincho";
}
.notes p{
    margin: 5px;
}
.page-title_sub{
    margin-top: 200px;
    clear: both;
    z-index: 8;
}
/*タブレットタイプCSS記述*/
@media screen and (min-width:768px) and (max-width:1000px){
	body{
        /*background: #000000;*/
        float: none;
}
	#contents{
        width: 100%;/*	カラム落ちを発生させたい*/
        height: auto;
	    flex-wrap:wrap;
        text-align: center;
        box-sizing: border-box;
        margin: 40px auto;
        padding: 4% 8%;
        position: initial;
}
    #contents img{
        width: 100%;
        height: auto;
        position: initial;
    }
	p{
    width: 48%;
}
    .menu li{
        display: block;
        width: 60%;
        margin: 0 auto 10px;
    }
    img{
        max-width: 100%;
        height: auto;
    }
    .imgR .imgL .imgS{
        float: none;
        width: 60%;
    }
    h1{
        width: 200px;
        font-size: 200%;
    }
     .map iframe{
        width: 100%;
    }
    .menu{
        width: 80%;
        display: block;
    }
    .access{
    width: 80%;
    display: block;
    color: #2D579A;
    margin: 18px;
    font-size: 1,125rem;
    padding: 3px;
    background-color: rgba(255,255,255,0.8);
    border-width: 1px 0;
}
}
/*スマートフォンタイプCSS記述*/
@media screen and (max-width:767px){
	body{
        /*background: #617974;*/
        float: none;
}
	#contents{
        width: 100%;/*	カラム落ちを発生させたい*/
	    flex-wrap:wrap;
        text-align: center;
        box-sizing: border-box;
        margin: 40px auto;
        padding: 4% 8%;
        height: auto;
        position: static;
}
    #contents img{
        width: 100%;
        height: auto;
        float: none;
        position: static;
    }
	p{
    width: 48%;
}
    .menu li{
        display: block;
        width: 60%;
        margin: 0 auto 10px;
    }
    img{
        max-width: 100%;
        height: auto;
        float: none;
    }
    .imgR .imgL .imgS{
        float: none;
        width: 60%;
    }
    h1{
        width: 200px;
        font-size: 200%;
    }
     .map iframe{
        width: 100%;
    }
    .menu{
        width: 100%;
        display: block;
    }
    .keireki{
        width: 100%;
    }
    .access{
    width: 80%;
    display: block;
    color: #2D579A;
    margin: 18px;
    font-size: 1,125rem;
    padding: 3px;
    background-color: rgba(255,255,255,0.8);
    border-width: 1px 0;
}
}