@charset "UTF-8";

/*------------------------------------------------------------------------------
	Kamiike car school - Structure CSS
	URL: https://www.kamiike.co.jp/
	Date: 2017-06-23
	Copyright (C) 2017 Kamiike car school. All Rights Rreserved.
------------------------------------------------------------------------------*/

/* #wrapper */
article#wrapper{
	position:relative;
	width:100%;
	margin:0 auto;
}
.wrapperInner {
    width: 100%;
    margin: 0 auto;
	overflow: hidden;
}
.innerWrap {
	width:1200px;
	margin:0 auto;
}
#wrapper h2 {
	text-align:center;
	margin-bottom:30px;
}
/* #skip */
ul#skip{
	position:absolute;
	top:0;
	left:0;
	overflow:hidden;
	height:0;
}
.cf:before,
.cf:after {
    content: " ";
    display: table;
}
.cf:after {
    clear: both;
}
.cf {
    *zoom: 1;
}

/*==============================================================
	header : ヘッダ
===============================================================*/

header {
	width:100%;
}
header #hdInner {
	
	display: -webkit-flex;
    display: flex;
	flex-wrap: nowrap ;
	justify-content: flex-end;
	align-items:center;
	height: 9vh;
	position:relative;
	background:#fff;
	z-index:9999;
}
header h1#siteTitle,
header p#siteTitle{
	margin-right:auto;
	margin-left:20px;
	box-sizing: border-box;
}
header h1#siteTitle img,
header p#siteTitle img {
	width:100%;
	height:auto;
}
header a {
	font-size:16px;
	font-size:1.6rem;
	text-align:center;
    display:block;
}
header #hdNavArea {
	display: -webkit-flex;
    display: flex;
	flex-wrap: nowrap ;
	justify-content: space-between;
	align-items:center;
	width: 72%;
}
header #hdNavArea #hdLink {
	width:15%;
}
header #hdNavArea #hdLink a {
    text-align: center;
	box-sizing:border-box;
	background:#fff32b;
	height: 6.7vh;
	line-height: 6.7vh;
}
header #globalNav {
	width:100%;
}
header #globalNav ul {
	width:100%;
	display: table;
	text-transform: uppercase;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all 0.35s ease;
	transition: all 0.35s ease;
}
header #globalNav li {
	display:table-cell;
	width: 16.6%;
	width: -webkit-calc(100% / 7);
	width: -moz-calc(100% / 7);
	width: calc(100% / 7);  
}
header #globalNav li a {
	display:block;
	position: relative;
	padding: 15px 0;
}
header #globalNav li a:before,
header #globalNav li a:after {
	height: 14px;
	width: 14px;
	position: absolute;
	content: '';
	-webkit-transition: all 0.35s ease;
	transition: all 0.35s ease;
	opacity: 0;
}
header #globalNav li a:before {
	left: 0;
	top: 0;
	border-left: 3px solid #eb5313;
	border-top: 3px solid #eb5313;
	-webkit-transform: translate(100%, 50%);
	transform: translate(100%, 50%);
}
header #globalNav li a:after {
  right: 0;
  bottom: 0;
  border-right: 3px solid #eb5313;
  border-bottom: 3px solid #eb5313;
  -webkit-transform: translate(-100%, -50%);
  transform: translate(-100%, -50%);
}
header #globalNav li a:hover {
	color: #eb5313;
}
header #globalNav li a:hover:before,
header #globalNav li a:hover:after {
  -webkit-transform: translate(0%, 0%);
  transform: translate(0%, 0%);
  opacity: 1;
}
header #globalNav .localNav {
	display: none;
}
#navBtn {
	display:none;
}
header #subNav {
	width:100%;
	height:9vh;
	overflow: hidden;
}
header #subNav ul {
	width: 100%;
	
	display: -webkit-flex;
	display: flex;
}
header #subNav li {
	width: 23%;
	height: 9vh;
}
#home header #subNav li#phone {
	width: 31%;
}
#home header #subNav li.home_none{
    display: none;
}
header #subNav li a {
	transition:all .4s;
	line-height:9vh;
	color:#fff;
}
header #subNav li a span {
	display:inline-block;
}
header #subNav li:first-child a {
	background: #88cc11;
}
header #subNav li:first-child a span {
	padding-left: 40px;
	background: url(../img/icon/ico_subNav_01.png) no-repeat left center;
}
header #subNav li:nth-child(2) a {
	background:#eb5313;
}
header #subNav li:nth-child(2) a span {
	padding-left: 30px;
	background: url(../img/icon/ico_subNav_02.png) no-repeat left center;
}
header #subNav li:nth-child(4) a {
	background:#49addf;
}
header #subNav li:nth-child(4) a span {
	padding-left: 35px;
	background: url(../img/icon/ico_subNav_03.png) no-repeat left center;
}
header #subNav li#phone {
	border-top:solid 1px #e2e2e2;
	border-bottom:solid 1px #e2e2e2;
	box-sizing:border-box;
	text-align: center;
	vertical-align: middle;
}
#home header #subNav li#phone {
	padding-top: 1.5vh;
	border-top:none;
}
header #subNav li#phone span#tel {
	display: inline-block;
	font-size:33px;
	font-size:3.3rem;
	margin-bottom:7px;
	padding-left: 36px;
	line-height:0.8;
	color:#eb5313;
	text-align:center;
	background:url(../img/icon/ico_free.png) no-repeat left center;
}
header #subNav li#phone span {
	font-size:12px;
	font-size:1.2rem;
	display:block;
}
#headline {
	position:relative;
	height: 450px;
	overflow: hidden;
}
#headline::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background: rgba(0,0,0,0.3);
	z-index: -1;
}
#headline #pageTitle {
	margin-top:125px;
	padding-top: 45px;
    font-size: 38px;
    font-size: 3.8rem;
    text-align: center;
	opacity: 0;
    transform: translate3D(0, 40px, 0);
    -webkit-transform: translate3D(0, 40px, 0);
    transition: all .3s ease;
	background:url(../img/icon/ico_h1.png) no-repeat top center;
}
#headline #pageTitle.loadedTtl {
    transform: translate3D(0, 0, 0) !important;
    -webkit-transform: translate3D(0, 0, 0) !important;
    opacity: 1 !important;
}
#headline #pageTitle a {
	font-weight:bold;
	color:#fff;
	letter-spacing:5px;
	font-feature-settings : "palt";
}
#headline #pageTitle span {
    display: block;
    color: #fff;
    font-size: 18px;
	font-size:1.8rem;
    margin-top: 10px;
	letter-spacing:4px;
	text-transform:uppercase;
}
#headline #titleImg {
	text-align: -webkit-center;
	position: absolute;
	top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
	z-index: -1;
	overflow:hidden;
}
#headline #titleImg img {
    display: block;
	width: 100%;
	height: 450px;
	transform: scale(1.1);
	transition: all .7s ease;
	object-fit: cover;
}
#headline .loadedImg {
	transform: scale(1.0);
}

/*==============================================================
	#pan : パンクズ
===============================================================*/

.pan {
	width:100%;
	margin-bottom:100px;
	padding: 15px;
	box-sizing: border-box;
	background:rgba(255,255,255,0.6);
}
.pan a {
	transition:all .5s;
}
.pan a:hover {
	color: #eb5313;
}
.pan strong {
}
ol.pan {
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	margin-left: 0;
}
ol.pan li {
	list-style: none;
}
ol.pan li:nth-child(n+2) {
	margin-left: 8px;
}


/*==============================================================
	#main : 主コンテンツ
===============================================================*/

section{
	padding:45px 0;
}
#contents {
	position: relative;
}
#main {
	width:100%;
	margin:0 auto;
	position: relative;
}
.plan #main #bnrList,
#home #main #bnrList {
	overflow:hidden;
	margin-bottom:0;
	
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.plan #main #bnrList li,
#home #main #bnrList li {
	width:48.8%;
	margin-bottom:30px;
}
.plan #main #bnrList li a,
#home #main #bnrList li a {
	margin-left: 0;
}
.plan #main #bnrList li a::before,
#home #main #bnrList li a::before {
	display: none;
}
.plan #main #bnrList li img,
#home #main #bnrList li img {
	width:100%;
	height:auto;
}
#preparation {
	padding-bottom: 80px;
}
#preparation p {
	padding: 30px 0 !important;
	border: solid 5px #eb5313;
	font-size: 20px;
	font-size: 2.0rem;
	margin-bottom: 0 !important;
	font-weight: bold;
	text-align: center;
	color: #eb5313;
}

/*==============================================================
	#sub : 副コンテンツ
===============================================================*/

.navigation {
	position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 1200px;
    margin: 0 auto;
}
#localNav {
	display:flex;
	flex-wrap:nowrap;
	overflow:hidden;
	background:rgba(255,255,255,0.8);
}
#localNav li {
	line-height:1.4;
}
#localNav a {
	transition:all .4s;
	display:block;
	padding:25px 0;
	color:#333;
	text-align:center;
	font-weight:bold;
}
#localNav .current a,
#localNav a:hover {
	color:#fff;
	background:#eb5313;
}
body.charm #localNav li {
    width: 50%;
}
body.student #localNav li {
	width: calc(100% / 3);
}
body.school #localNav li {
    width: 25%;
}
body.license #localNav li,
body.recruit #localNav li {
	width: 20%;
}
body.plan #localNav {
	justify-content:space-between;
}
body.plan #localNav li {
    width: 11.1%;
    width: -webkit-calc(100% / 9);
    width: -moz-calc(100% / 9);
    width: calc(100% / 9);
}
body.plan #localNav li a {
	width:100%;
	height: 90px;
	padding:0;
	
	display: -webkit-flex;
	display: flex;
	justify-content: center;
	align-items:center;
}
body.plan #localNav li small {
	font-size: 12px;
	font-size: 1.2rem;
}

/*==============================================================
	footer : フッタ
===============================================================*/

#toTop {
	transition: all .5s;
	position: absolute;
    bottom: -30px;
    right: 15px;
}
#toTop:hover {
	bottom: -20px;
}
#contactArea {
	position: relative;
	background:#fff555;
}
#contactArea .innerWrap {
	
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
	padding:30px;
	box-sizing: border-box;
	border-radius:10px;
	background:#fff;
}
#contactArea h2 {
	flex: 0 0 100%;
	font-size:20px;
	font-size:2.0rem;
	font-weight: bold;
	color:#fea218;
	padding:20px 0;
	border:solid 4px #fea218;
	box-sizing: border-box;
	text-align: center;
}
#contactArea h3 {
	text-align:center;
	font-size:18px;
	font-size:1.8rem;
	font-weight: bold;
	margin-bottom:20px;
}
#contactArea h3 span {
	display:inline-block;
	padding:10px 0 10px 45px;
}
#contactArea #telBox {
	width: 50%;
	padding: 0 2%;
	border-right:solid 1px #ededed;
	box-sizing:border-box;
}
#contactArea #telBox h3 span {
	background:url(../img/icon/ico_tel.png) no-repeat left center;
}
#contactArea #webBox h3 span {
	background:url(../img/icon/ico_web.png) no-repeat left center;
}
#contactArea #telBox p {
	color:#eb5313;
	font-size:65px;
	font-size:6.5rem;
	text-align:center;
	margin-bottom: 20px;
    line-height: 1;
}
#contactArea #telBox p span {
	display:inline-block;
	padding-left:70px;
	background:url(../img/icon/ico_free_large.png) no-repeat left center;
}
#contactArea #telBox p span.spTxt {
	display:none;
}
#contactArea #telBox ul {
	
    display: -webkit-flex;
    display: flex;
    flex-wrap: nowrap;
	justify-content: space-between;
}
#contactArea #telBox li {
	width:48%;
	text-align:center;
	font-size:16px;
	font-size:1.6rem;
	line-height: 1.5;
}
#contactArea #telBox li span {
	display:block;
	margin-bottom:10px;
	padding:10px 0;
	border-radius:7px;
	background:#d7e1e3;
	line-height: 1;
}
#contactArea #webBox {
	width: 50%;
}
#contactArea #webBox ul {
	width:340px;
	margin:0 auto;
}
/*
#contactArea #webBox li {
	margin-bottom:30px;
}
*/
#contactArea #webBox li {
	height:70px;
	border:3px solid #83c60e;
	text-align:center;
	position:relative;
	box-sizing:border-box;
	overflow:hidden;
	margin-bottom:30px;
}
#contactArea #webBox li:last-child {
	border:3px solid #eb5313;
}
div[class^="conBtn"] {
  width:340px;
  height:70px;
  position:absolute;
  transition:all .5s ease;
  z-index:1;
  box-sizing:border-box;
}
.conBtn01 {
	border:70px solid #83c60e;
}
.conBtn02 {
	border:70px solid #eb5313;
}
/*
#contactArea #webBox li a {
	display:block;
	width:340px;
	color:#fff;
	font-size:18px;
	font-size:1.8rem;
	text-align:center;
	padding:22px 0;
	background:#83c60e;
}
*/
#contactArea #webBox li a {
	display:block;
	font-size:18px;
	font-size:1.8rem;
	font-weight: bold;
	line-height: 67px;
	color:#fff;
	text-decoration:none;
	transition:all .5s ease;
	z-index:2;
	position:relative;
}
#contactArea #webBox li:hover .conBtn01 {
	border:0px solid #83c60e;
}
#contactArea #webBox li:hover .conBtn02 {
	border:0px solid #eb5313;
}
#contactArea #webBox li:first-child:hover a {
	color: #83c60e;
}
#contactArea #webBox li:last-child:hover a {
	color: #eb5313;
}
#contactArea #webBox li:last-child {
	margin-bottom:0;
}
#contactArea + #bnrArea {
	display: none;
}

#slider {
	width:1050px;
	margin:0 auto;
}
#bnrArea #slider .slick-slide {
	width: 192px;
	margin: 0 9px;
}
#bnrArea #slider .slick-prev,
#bnrArea #slider .slick-next {
	width: 36px;
    height: 36px;
	top: 0;
    bottom: 0;
	margin:auto;
	z-index: 99;
}
#bnrArea #slider .slick-prev {
	left: -50px;
	background:url(../img/icon/ico_arrow_prev.png) no-repeat left center;
}
#bnrArea #slider .slick-next {
	right: -50px;
	background:url(../img/icon/ico_arrow_next.png) no-repeat left center;
}
.slick-prev:before,
.slick-next:before {
    display:none !important;
}

#bnrArea .bnrList {
	display: -webkit-flex;
	display: flex;
	justify-content: center;
}
#bnrArea .bnrList li {
	margin: 0 10px;
}

footer {
	display: -webkit-flex;
    display: flex;
	flex-wrap: wrap;
}
footer #mapArea {
	flex: 0 0 50%;
	padding:0;
}
footer #mapArea iframe {
	width: 100%;
	vertical-align: bottom;
}
footer #map_canvas {
	width:100%;
	height:450px;
}
footer #ftInner {
	flex: 0 0 50%;
	align-items: stretch;
	background:#fff555;
	padding-top: 50px;
}
footer #ftInner img {
    display: block;
    margin: 0 auto 15px;
}
footer address {
	text-align:center;
	margin-bottom:30px;
}
footer #tagline {
	text-align: center;
	font-weight: normal;
	margin-bottom: 20px;
}
footer #ftNav {
	width:340px;
	margin: auto;
	margin-bottom:20px;
	
	display: -webkit-flex;
    display: flex;
	flex-wrap: wrap;
	justify-content:center;
}
footer #ftNav li {
	margin:0 10px 20px;
}
footer #snsList {
	
	display: -webkit-flex;
    display: flex;
	flex-wrap: nowrap;
	justify-content:center;
}
footer #snsList li {
	margin:0 10px;
}
footer #snsList li a {
	width: 53px;
	height: 53px;
	background: #fff;
	border-radius: 50%;
	display: block;
}
footer #snsList li img {
	margin-bottom: 0;
	transition: all .7s;
}
footer #snsList li a:hover img {
	-webkit-transform: rotateX(360deg);
	transform: rotateX(360deg);
}
footer #copyright{
	font-size:14px;
	font-size:1.4rem;
	flex: 0 0 100%;
	text-align:center;
	padding:15px 0;
	background:#f8ec24;
	font-family: 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}




@media all and (-ms-high-contrast:none){
	
	header h1#siteTitle,
	header p#siteTitle {
		width: 23%;
		margin: 20px;
	}
	header h1#siteTitle,
	header p#siteTitle img {
		width: auto;
	}
	header #hdNavArea {
		margin: 10px 0;
	}
	header #globalNav li {
		width: 16%;
		float: left;
		display: block;
	}
}
@media screen and (max-width: 1200px) and (-ms-high-contrast:none) {
	header h1#siteTitle,
	header p#siteTitle {
		margin-right: 40%;

	}
}
@media screen and (max-width: 768px) and (-ms-high-contrast:none) {
	header h1#siteTitle,
	header p#siteTitle {
		margin-right: 5%;

	}
}

/*--EOF-----------------------------------------------------------------------*/
