@charset "UTF-8";
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
	font-size: 1em;
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, main {
	display: block;
}

* {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}
html {
	font-size: 62.5%;
}
body {
	font-family: "游ゴシック体", 'Yu Gothic', "YuGothic", "メイリオ", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", ;
	font-size: 1.4rem;
}

ol, ul {
	list-style: none;
}
img {
	vertical-align: top;
}

a:link {
	color: #231815;
	text-decoration: none;
}

a:visited {
	color: #231815;
	text-decoration: none;
}

a:hover {
	color: #231815;
	text-decoration: underline;
}

a:hover img {
	opacity: 0.6;
}

a:active {
	color: #231815;
	text-decoration: underline;
}

/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/

#main {
	margin: 0 auto;
	width: 100%;
}

/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/


#header_lp {
	padding-top: 20px;
	background: #fff;
	position: relative;
	box-sizing: border-box;
}


header {
    width: 100%;
    display: block;
    position: fixed;
    max-height: 120px;
    background-color: white;
    top: 0; /* 固定する位置 */
    left: 0; /* 固定する位置 */
    right: 0;  /* 固定する位置 */
    overflow: hidden;
    text-align: center;
    padding: 10px 0;
    margin: 0 auto;
    z-index: 100;
}

ul img {
    float:left;
    width: auto;
}
ul .logo img{
    padding:0;
    max-width: 350px;
}
ul .cv_button{
    padding:0;
    margin: 0 0 0 58%;
    width:80%;
}
ul .cv_button img{
    padding:0;
    max-width:387px;
    margin: auto;
}
#main {
    padding-top: 120px;
}
#main img {
	vertical-align: top;
    margin:auto;
    width:100%;
}
.campaign {
    padding-top:30px;
    width: 100%;
}
.box {
    position: relative !important;
    width: 92%;
    z-index: 99;
    margin: 0 auto;
    padding-bottom: 100px;
}

.box_2 {
    position: relative !important;
    width: 100%;
    z-index: 99;
    margin: 0 auto;
}

.traial_box {
    padding: 30px 0 45px;
}

#account_btn {
    position:absolute !important;
    width:85%;
    top:280px;
    right:0;
    left:0;
    bottom:auto;
    margin: 108% auto!important;
}
#account_btn_2 {
    position:absolute !important;
    width:81%;
    top:320px;
    right:0;
    left:0;
    bottom:auto;
    margin: 109% auto!important;
}

#account_btn_sakae {
    position:absolute !important;
    width:85%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: -56% auto!important;
}

#account_btn_sakae_2 {
    position:absolute !important;
    width:81%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: 145% auto!important;
}
#attention {
    font-size: 2rem;
    position:absolute !important;
    width:85%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: 34% auto!important;
}
#attention_2 {
    font-size: 2rem;
    position:absolute !important;
    width:85%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: 180% auto!important;
}
#attention_lp09{
    font-size: 2rem;
    position:absolute !important;
    width:85%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: 35% auto!important;
}

#attention_km {
    font-size: 2rem;
    position:absolute !important;
    width:85%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: 214% auto!important;
	text-align: center;
}

.video {
    position:relative;
    width:100%;
    padding-top:56.25%;
}

.video iframe {
    position:absolute;
    top:0;
    right:0;
    width:100%;
    height:100%;
}
.sizedown {
    padding-top: 30px;
}

.access  {
    padding-top: 50px;
}


.access .gooogle_map {
    width: 61%;
    margin: auto;
    padding: 15px 0 63px;
}

.address {
	margin:0 auto;
    width:100%;
    padding: 2% 10%;
    font-size:2rem;
}

.google_map{
    margin:0 4% 0 0;
}

@media only screen and (min-width: 768px) {
    #main {
    max-width: 960px;
    }   
}

@media only screen and (max-width: 767px) {

header {
    width: 100%;
    display: block;
    position: fixed;
    max-height: 70px;
    background-color: white;
    top: 0; /* 固定する位置 */
    left: 0; /* 固定する位置 */
    right: 0;  /* 固定する位置 */
    overflow: hidden;
    text-align: center;
    padding: 8px;
    padding-right: -15x;
    margin: 0 auto;
}
    
#account_btn {
    position:absolute !important;
    width:85%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: 138% auto!important;
}
    
#account_btn_2 {
    position:absolute !important;
    width:85%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: 147% auto!important;
}
    
#attention {
    font-size: 1rem;
    position:absolute !important;
    width:92%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: 34% auto!important;
}
#attention_2 {
    font-size: 1rem;
    position:absolute !important;
    width:85%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: 176% auto!important;
}
#attention_lp09{
    font-size: 1rem;
    position:absolute !important;
    width:85%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: 40% auto!important;
}
ul img{
    float:left;
    width:auto;
}

ul .logo img{
    max-width:70%;
    padding: 0;
} 
ul .cv_button{
    padding:0;
    margin: 0 0 0 45%;
}
ul .cv_button img{
    max-width: 30%;
    padding: 0;
    margin: 0 auto;
}

 #main {
    padding-top: 65px;
	margin: 0 auto;
	width: 100%;
}


.address {
	margin:0 auto;
    width:100%;
    padding: 2% 10%;
    font-size:12px;
}
    

    
}
@media only screen and (max-width: 320px) {
header {
    width: 100%;
    display: block;
    position: fixed;
    max-height: 50px;
    background-color: white;
    top: 0; /* 固定する位置 */
    left: 0; /* 固定する位置 */
    right: 0;  /* 固定する位置 */
    overflow: hidden;
    text-align: center;
    padding: 6px;
    margin: 0 auto;
}
ul img{
    float:left;
    width:auto;
}
ul .logo img{
    max-width:120px;
    padding: 0;
}
ul .cv_button img{
    max-width: 154px;
    padding: 0;
}

#main {
    padding-top: 50px;
	margin: 0 auto;
	width: 100%;
}

}

.cv_box_main {
    position: relative !important;
    width: 100%;
    z-index: 99;
}

#yoyaku_btn_1 {
    position:absolute !important;
    width:88%;
    top:0;
    right:0;
    left:0;
    bottom:auto;
    margin: -68% auto!important;
}


/*ボックス全体*/
.accbox {
    margin: 0em 0;
    padding: 0;
    width: 100%;
}

/*ラベル*/
.accbox label {
    display: block;
    margin: 1.5px 0;
    padding : 11px 12px;
    color :#2f8fcf;
    font-weight: bold;
    cursor :pointer;
    transition: all 0.5s;
}

.accbox .voice label {
    display: block;
    margin: 0px;
    padding : 0px;
    color: #2f8fcf;
    font-weight: bold;
    cursor: pointer;
    transition: all 0.5s;
}


/*チェックは隠す*/
.accbox input {
    display: none;
}


/*中身を非表示にしておく*/
.accbox .accshow {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
}

/*クリックで中身表示*/
.cssacc:checked + .accshow {
    height: auto;
    padding: 5px;
    opacity: 1;
}


@keyframes tonext {
  75% {
    left: 0;
  }
  95% {
    left: 100%;
  }
  98% {
    left: 100%;
  }
  99% {
    left: 0;
  }
}

* {
  box-sizing: border-box;
}

.slider2 {
  width: 100%;
  text-align: center;
  overflow: hidden;
  margin: 30px 0;
}

.slides2 {
  display: flex;
  
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  
  
  
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  
  /*
  scroll-snap-points-x: repeat(300px);
  scroll-snap-type: mandatory;
  */
}
.slides2::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
.slides2::-webkit-scrollbar-thumb {
  background: black;
  border-radius: 10px;
}
.slides2::-webkit-scrollbar-track {
  background: transparent;
}
.slides2 > div {
  scroll-snap-align: start;
  flex-shrink: 0;
  width: 100%;
  margin-right: 50px;
  border-radius: 10px;
  background: #eee;
  transform-origin: center center;
  transform: scale(1);
  transition: transform 0.5s;
  position: relative;
  
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 100px;
}
.slides2 > div:target {
/*   transform: scale(0.8); */
}
.author-info2 {
  background: rgba(0, 0, 0, 0.75);
  color: white;
  padding: 0.75rem;
  text-align: center;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  margin: 0;
}
.author-info2 a {
  color: white;
}
img2 {
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.slider2 > a {
  display:none;
  width: 1.5rem;
  height: 1.5rem;
  background: white;
  text-decoration: none;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  margin: 0 0 0.5rem 0;
  position: relative;
}
.slider2 > a:active {
  top: 1px;
}
.slider2 > a:focus {
  background: #000;
}

/* Don't need button navigation */
@supports (scroll-snap-type) {
  .slider2 > a {
    display: none;
  }
}






