@charset "utf-8";

/* font
======================================================================*/

@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:100,300,400,500,700,900&display=swap');
/*@import url('https://fonts.googleapis.com/css?family=Roboto:100,100i,300,300i,400,400i,500,500i,700,700i,900,900i&display=swap');*/s

/* reset
======================================================================*/

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, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
outline: 0;
font-size: 100%;
background: transparent;
}
body {
line-height: 1;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
display: block;
}
nav ul {
list-style: none;
}
blockquote, q {
quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
content: '';
content: none;
}
a {
margin: 0;
padding: 0;
font-size: 100%;
vertical-align: baseline;
background: transparent;
}
/* change colours to suit your needs */
ins {
background-color: #ff9;
color: #000;
text-decoration: none;
}
/* change colours to suit your needs */
mark {
background-color: #ff9;
color: #000;
font-style: italic;
font-weight: bold;
}
del {
text-decoration: line-through;
}
abbr[title], dfn[title] {
border-bottom: 1px dotted;
cursor: help;
}
table {
border-collapse: collapse;
border-spacing: 0;
}
/* change border colour to suit your needs */
hr {
display: block;
height: 1px;
border: 0;
border-top: 1px solid #cccccc;
margin: 1em 0;
padding: 0;
}
input, select {
vertical-align: middle;
}
li {
list-style: none;
}
h1, h2, h3, h4, h5, h6 {
font-weight: normal;
}

/* common
======================================================================*/

html * {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

*, *:after, *:before {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

body, html {
    /* important */
    height: 100%;
    background-color: #FFFFFF;
    scroll-behavior: smooth;
}

body {
    font-family: 'Noto Sans JP', 'Roboto', "Helvetica Neue", "游ゴシック Medium", YuGothic, YuGothicM, "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, sans-serif;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.8;
    color: #000000;
	}

a{
    color: #000000;
    text-decoration: none;
}

a:hover{
	color: #6499ae;
	text-decoration: none;
}

/***** base *****/

a img {
    -webkit-transition: opacity 0.2s linear;
    -moz-transition: opacity 0.2s linear;
    -ms-transition: opacity 0.2s linear;
    transition: opacity 0.2s linear;
}

a:hover img {
    opacity: 0.5;
    -webkit-opacity: 0.5;
    -moz-opacity: 0.5;
    filter: alpha(opacity=50);
    -ms-filter: "alpha(opacity=50)";
}

/* basic
======================================================================*/

.sp {
	display: none !important;
}

.pc {
	display: block !important;
}

/* マージン設定 */

.mbSS{
	margin-bottom:0.5em !important;}

.mbS{
	margin-bottom:1em !important;}

.mbM{
	margin-bottom:2em !important;}

.mbL{
	margin-bottom:3em !important;}

.mbLL{
	margin-bottom:4em !important;}

.mtLL{
	margin-top:4em !important;}

.mtSS{
	margin-top:0.5em !important;}

.mtS{
	margin-top:1em !important;}

.mtM{
	margin-top:2em !important;}

.mtL{
	margin-top:2em !important;}

.mtLL{
	margin-top:3em !important;}


/* contents
======================================================================*/

#contents {
    width: 100%;
	background-color: #FFFFFF;
}

#contents img {
	height: auto;
	max-width: 100%;
	}

#contents .inner{
    width: 100%;
    max-width: 980px; /*940px*/
    margin: 0 auto;
    padding: 0 20px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

/* MainVisual
==================================*/

.MainVisual {
    width: 100%;
    text-align: center;
    overflow: hidden;
    position: relative;
}

.MainVisual h1{
	width: 100%;
	max-width: 940px;
	height: 60px;
	text-align: center;
	font-size: 30px;
	font-weight: 700;
	line-height: 60px;
	color: #FFFFFF;
	background-color: #1d3552;
	margin: 0 auto;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.MainVisual h1{
	height: 40px;
	font-size: 20px;
	line-height: 40px;
}
}
@media only screen and (min-width:1px) and (max-width: 480px){
.MainVisual h1{
	height: 40px;
	font-size: 14px;
	line-height: 40px;
}
}

.MVinner{
    width: 100%;
    max-width: 980px; /*940*/
    margin: 0 auto;
    padding: 80px 20px 60px;
    position: relative;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.MVinner{
    padding: 40px 20px 30px;
}
}

.MVinner h2{
    text-align: center;
	margin: 60px auto 0;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.MVinner h2{
	margin: 30px auto 0;
}
}

.MVinner h2 img{
    max-width: 100%;
    height: auto;
}

/* information
==================================*/

.information {
    width: 100%;
	max-width: 940px;
	margin: 0 auto;
	position: relative;
	background-color: #1d3552;
}

.information .inside{
    max-width: 846px;
	margin: 0 auto;
	padding: 40px 15px;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.information .inside{
	padding: 20px 15px;
}
}

.information h3{
    font-size: 37px;
	font-weight: 700;
	line-height: 1.7;
	color: #FFFFFF;
	text-align: center;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.information h3{
    font-size: 24px;
}
}
@media only screen and (min-width:1px) and (max-width: 480px){
.information h3{
    font-size: 19px;
}
}

.information span.delta{
    display: block;
	font-size: 60px;
	font-weight: 900;
	line-height: 1.7;
	color: #ff0000;
	text-align: center;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.information span.delta{
	font-size: 30px;
}
}

.information p.lead{
    font-size: 31px;
	font-weight: 900;
	line-height: 1.7;
	color: #FFFFFF;
	text-align: center;
	margin-bottom: 1em;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.information p.lead{
    font-size: 20px;
}
}
@media only screen and (min-width:1px) and (max-width: 480px){
.information p.lead{
    font-size: 18px;
}
}

.information p.sum{
    font-size: 34px;
	font-weight: 900;
	line-height: 1.6;
	letter-spacing: -0.05em;
	color: #FFFFFF;
	text-align: center;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.information p.sum{
    font-size: 22px;
}
}
@media only screen and (min-width:1px) and (max-width: 480px){
.information p.sum{
    font-size: 19px;
}
}

.btn_form{
	width: 100%;
	max-width: 747px;
	margin: 40px auto;
}

.btn_form a{
	width: 100%;
	padding: 30px;
	background-color: #999999;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	transition: all 0.3s linear;
}

.btn_form a:hover{
	opacity: 0.6;
}

@media only screen and (min-width:1px) and (max-width: 768px){
.btn_form{
	margin: 20px auto;
}
.btn_form a{
	padding: 15px;
}
}

.btn_form a .copy{
	width: calc(100% - 140px);
	font-size: 48px;
	font-weight: 900;
	line-height: 1.3;
	color: #FFFFFF;
	text-align: center;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.btn_form a .copy{
	font-size: 22px;
}
}
@media only screen and (min-width:1px) and (max-width: 480px){
.btn_form a .copy{
	width: calc(100% - 120px);
	font-size: 22px;
}
}

.btn_form img{
	width: 125px;
	vertical-align: middle;
}
@media only screen and (min-width:1px) and (max-width: 480px){
.btn_form img{
	width: 100px;
	height: auto;
}
}


/* line_up
==================================*/

.line_up {
	overflow: hidden;
    padding: 60px 0 60px;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.line_up {
    padding: 30px 0 30px;
}
}

.line_up ul{
    display: flex;
	flex-wrap: wrap;
}

.line_up li{
    width: 100%;
    margin-bottom: 20px;
}

@media only screen and (min-width:1px) and (max-width: 768px){
.line_up li{
    margin-bottom: 0px;
}
}

.line_up li .photo{
    position: relative;
    text-align: center;
}
/*
.line_up li .photo p.cap{
    font-size: 11px;
    text-align: right;
    position: absolute;
    bottom: 20px;
    right: 0;
}
*/
.line_up h3.name{
    font-size: 72px;
	font-weight: 900;
	line-height: 1.4;
	text-align: center;
	color: #333332;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.line_up h3.name{
    font-size: 32px;
}
}

.line_up li p.price{
    font-size: 24px;
    font-weight: 500;
    text-align: left;
    line-height: 1.4;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.line_up li p.price{
    font-size: 16px;
	margin-bottom: 10px;
}
}

.line_up li p.price span{
    font-size: 32px;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.line_up li p.price span{
    font-size: 20px;
}
}

.line_up li p.caution{
    font-size: 18px;
    font-weight: 500;
    text-align: left;
    line-height: 1.4;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.line_up li p.caution{
    font-size: 14px;
	margin-bottom: 30px;
}
}

.line_up p.point{
    font-size: 41px;
    font-weight: 900;
    text-align: center;
    line-height: 1.4;
    margin-bottom: 20px;
    color: #666666;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.line_up p.point{
    font-size: 20px;
}
}

.line_up p.point span{
    font-size: 64px;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.line_up p.point span{
    font-size: 24px;
}
}

.line_up .detail{
	width: 100%;
	text-align: center;
	margin-top: 30px;
	margin-bottom: 30px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.line_up .detail{
	margin-top: 20px;
	margin-bottom: 20px;
	padding-left: 6%;
}
}

.line_up .detail img{
	margin-left: 94px;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.line_up .detail img{
	max-width: 100%;
	height: auto;
	margin-left: 0;
}
}

.line_up p.caption{
    font-size: 16px;
	font-weight: 500;
	margin-top: 60px;
	line-height: 1.6;
	text-align: justify;
}
@media only screen and (min-width:1px) and (max-width: 768px){
.line_up p.caption{
    font-size: 12px;
	margin-top: 30px;
}	
}

.line_up p.caption span{
	text-decoration: underline;
}


/* youtube
==================================*/

.youtube {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
	z-index: 11;
}

.youtube iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
	border-radius: 10px;
}

@media only screen and (min-width:1px) and (max-width: 768px){
.youtube.mbLL {
	margin-bottom: 2em!important;
}
}


/* footer
======================================================================*/

footer{
    background-color: #eeeeee;
    overflow-y: hidden;
    position: relative;
}

footer img{
	max-width: 100%;
	height: auto;
}

footer .inner{
    padding-top: 30px;
	padding-bottom: 0;
}

footer p.copyright{
    font-size: 12px;
	text-align: center;
	color: #FFFFFF;
}
@media only screen and (min-width:1px) and (max-width: 768px){
footer p.copyright{
    font-size: 11px;
}
}

footer p.copyright span{
    font-weight: 700;
}

footer p.copyright a{
    color: #FFFFFF;
}

footer p.copyright a:hover{
	color: #FFFFFF;
	text-decoration: underline;
}

footer p.obi{
    font-size: 23px;
    font-weight: 700;
	line-height: 1.5;
    text-align: center;
    color: #FFFFFF;
    background-color: #1d3552;
    padding: 10px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
@media only screen and (min-width:1px) and (max-width: 768px){
footer p.obi{
    font-size: 16px;
	padding: 5px;
}
}

footer h4{
	font-family: "poppins", sans-serif;
	font-weight: 700;
    font-size: 24px;
    font-weight: 700;
	text-align: center;
	margin-bottom: 26px;
	letter-spacing: 0.1em;
}
@media only screen and (min-width:1px) and (max-width: 768px){
footer h4{
    font-size: 16px;
}
}

footer h4 span{
    display: block;
    font-size: 14px;
    font-weight: 400;
}
@media only screen and (min-width:1px) and (max-width: 768px){
footer h4 span{
    font-size: 12px;
}
}

footer ul{
    width: 100%;
    max-width: 940px;
    margin: 0 auto;
    font-size: 0;
    text-align: center;
    padding-bottom: 40px;
    overflow-y: hidden;
}

footer li{
    width: 100%;
    display: flex;
	flex-wrap: wrap;
	justify-content: space-between; 
    color: #000000;
    /*background-color: #efefef;*/
    background-color: #FFFFFF;
    margin: 6px 0;
    font-size: 12px;
    text-align: left;
    padding: 10px 10px 10px 30px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

/* add */
footer li div.add a{
    display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
    align-items: center;
}

footer li p.name{
    min-width: 220px;
    font-size: 19px;
    font-weight: 700;
}

footer li p.name span{
    font-size: 12px;
    color: #02A4AC;
    margin-left: 5px;
}

footer li p{
    font-size: 14px;
}

/* tel */
footer li div.tel a{
    display: flex;
	justify-content: center;
    align-items: center;
    font-size: 18px;
	font-weight: 700;
    color: #FFFFFF;
    background-color: #1d3552;
    width: 220px;
    height: 30px;
    transition: all 0.3s linear;
    pointer-events: none!important;
}

footer li div.tel a:hover{
    opacity: 0.6;
}

.remarks{
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
    padding: 0 20px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    margin-bottom: 60px;
}

.remarks p{
    font-size: 12px;
    margin-bottom: 20px;
}

@media only screen and (min-width:1px) and (max-width: 768px){
.remarks p{
    font-size: 11px;
}
}

.attention{
    width: 100%;
    background-color: #1d3552;
    overflow: hidden;
    padding: 25px 0;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
/*
.attention p {
    text-align: justify;
    font-size: 12px;
    max-width: 980px;
    margin: 0 auto;
	color: #FFFFFF;
}
*/


/* @media - 640px
======================================================================*/

@media only screen and (min-width:1px) and (max-width: 768px){

/* common
======================================================================*/

.sp {
	display: block !important;
}

.pc {
	display: none !important;
}
  

/* footer
======================================================================*/

footer h3{
    font-size: 20px;
    line-height: 1.3;
    padding: 20px;
}

footer .inner{
    padding-top: 40px;
}

footer ul{
    width: 90%;
    margin: 0 auto;
    padding-bottom: 20px;
}

footer li{
    padding: 10px;
}

footer li p{
    font-size: 12px;
}

footer li p.name{
    font-size: 14px;
    font-weight: 700;
}

/* tel */
footer li div.tel {
    width: 100%;
    margin-top: 5px;
}
    
footer li div.tel a{
    font-size: 14px;
    color: #FFFFFF;
    width: 100%;
    height: 30px;
    pointer-events: auto!important;
}

.attention{
    width: 100%;
    padding: 30px 0;
}

.attention p {
    width: 90%;
    margin: 0 auto;
    font-size: 10px;
}

} /*@mediaEnd*/