@charset "utf-8";
/* CSS Document */

*{
margin: 0px;
padding: 0px;
}

body{
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
  font-weight: 400;
  font-style: normal;
	background:#fff;
    line-height: 1.8;
    color:#333;
    font-size:18px;
    font-size-adjust: none;
    -webkit-font-size-adjust: none;
    position: relative;
	overflow-x: hidden;
}

@media only screen and (max-width: 1024px) {

body{

	overflow-x: hidden;
}
    
}

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

body{
    font-size:16px;
	overflow-x: hidden;
}
    
}

.en-min{
    font-family: "Times New Roman", Times, "serif";
}

.fw-b{
	font-family: 'Anton', sans-serif;
	font-family: 'Roboto Condensed', sans-serif;
	font-weight: 700;
}

.en-thin {
  font-family: "Libre Baskerville", serif;
  font-weight: 400;
  font-style: normal;
}

.en {
  font-family: "Libre Baskerville", serif;
  font-weight: 700;
  font-style: normal;
}

.min{
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}


.fs-italic{
    font-style: italic;
}

/*==================================================
material-icons-outlined
================================================== */


.material-symbols-outlined {
  font-variation-settings:
  'FILL' 0,
  'wght' 400,
  'GRAD' 0,
  'opsz' 24
}


.material-icons-outlined,
.material-symbols-outlined{
    font-size: 20px !important;
    vertical-align: middle !important;
}

.icn-16{
    font-size: 16px !important;
}

.icn-18{
    font-size: 18px !important;
}

.icn-20{
    font-size: 20px !important;
}




@media only screen and (max-width: 599px) {
	html{overflow-x: hidden;}
body{
    overflow: hidden;
    min-width: initial;
	max-width: 100%;
}


}

img{
	border:0;
	outline:none;
	image-rendering: -webkit-optimize-contrast;
	max-width: 100%;
}

.img-hover-big{
	display: block;
    overflow: hidden;
}

.img-hover-big img{
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    transition: 0.5s;
}

.img-hover-big:hover img{
    transform: scale(1.2);
}

a{
    transition: all 0.3s ease;
}

a:hover img.hover-alp{
filter: alpha(opacity=70); -moz-opacity:0.70; opacity:0.70;
    transition: .5s;
}

a:link, a:visited{color:#333; text-decoration: none;}
a:hover{color:#000; text-decoration:underline;}

a.a-underline{
    text-decoration: underline !important;
}



.clearfix:after{
content: ".";
display: block;
clear: both;
height: 0;
visibility: hidden;
}

.clearfix {
min-height: 1px;
}

* html .clearfix{
height: 1px;
/*\*//*/
height: auto;
overflow: hidden;
/**/
}

p{margin:0 0 15px; }

.cb{clear:both;}


/*==================================================
page-top
================================================== */

#page-top{position:fixed; bottom:20px; right:20px; z-index: 50;}

#page-top a{
    background: #fff;
    display: inline-block;
    width:78px;
    height: 78px;
    border-radius: 50%;
    transition: 0.5s;
    text-decoration: none !important;
    color: #aeb8ca !important;
    cursor: pointer;
    border: 1px solid #aeb8ca;
	text-align: center;
}

#page-top a:hover{
    background: #aeb8ca;
}

/*@keyframes slideyy{
  from {height: 31px; bottom: 58px;}
  50% {height: 75px; bottom: 7px; }
  to {height: 20px; }
}*/

#page-top a::before{
    /*animation-name: slideyy;
    animation-duration: 1s;*/
    content: "";
    position: absolute;
    bottom: 7px;
    left: 40px;
    margin: auto;
    width: 1px;
    height: 26px;
    background: #aeb8ca;
    transition: .4s;
}

@keyframes slidey{
  from {height: 20px; bottom: 7px;}
  50% {height: 75px; bottom: 7px; }
  to {height: 29px; }
}

#page-top a:hover::before{
    animation-name: slidey;
    animation-duration: 1s;
    background: #fff;
    bottom: 58px;
    height: 29px;
}

/*@keyframes slideyyy{
  from {bottom: 79px;}
  50% {bottom: 79px; }
  to {bottom: 25px; }
}*/

#page-top a::after{
    /*animation-name: slideyyy;
    animation-duration: 1s;*/
    content: "";
    display: block;
    position: absolute;
    bottom: 25px;
    left: 37px;
    margin: auto;
    width: 6px;
    height: 6px;
    border-left: 1px solid #aeb8ca;
    transform: rotate(135deg);
    transition: .4s;
}

#page-top a:hover::after{
    bottom: 79px;
    border-left: 1px solid #fff;
}


@media only screen and (max-width: 1024px) {

#page-top a:hover{
    background: #fff;
}

#page-top a:hover::before{
    animation:none;
    background: #aeb8ca;
    bottom: 7px;
    left: 40px;
    height: 26px;
}
	
	#page-top a::after{
		bottom: 26px;
	}

#page-top a:hover::after{
    bottom: 26px;
    border-left: 1px solid #aeb8ca;
}	
	
}




@media only screen and (max-width: 768px) {
    
#page-top{bottom:20px; right:15px; }


#page-top a{
    width:58px;
    height: 58px;
}

#page-top a:hover{
    background: #fff;
}

#page-top a::before{
    animation: none;
    left: 30px !important;
    height: 24px !important;
    background-color: #aeb8ca !important;
}

#page-top a:hover::before{
    left: 30px;
    height: 24px;
}

#page-top a::after{
    animation: none;
    bottom: 24px;
    left: 27px;
    width: 6px;
    height: 6px;
}

#page-top a:hover::after{
    bottom: 24px;
}	
    
    
}






img{
border:0;
outline:none;
}


.sp-only{display: none !important ;}
@media only screen and (max-width: 480px) {
.sp-only{display: inline !important;}
.pc-only{display: none !important ;}
}
.br-tab {
	display: none;
}

  .br-pc { display:block; }
  .br-sp { display:none; }

@media screen and (max-width: 768px){	
  .br-pc { display:none; }
  .br-tab { display:block; }
}
@media screen and (max-width: 480px){	
  .br-tab { display:none; }
  .br-sp { display:block; }
}

/*==================================================
ボタン
================================================== */

.btn-area{
    text-align: center;
	padding: 35px 0 ;
}


.btn{
    background: #102f56;
    color: #fff !important;
    cursor: pointer;
    height: 60px;
    line-height: 58px;
    display: inline-block;
    min-width: 320px;
	transition: 0.5s;
    text-decoration: none !important;
    position: relative;
    border-radius: 60px;
    text-align: left;
    padding: 0 20px;
    box-sizing: border-box;
    box-shadow: 0px 0px 15px -5px #777777;
}

.btn.btn-small{
    min-width: 180px;
    height: 42px;
    line-height: 40px;
    padding: 0 20px;
    font-size: 90%;
}

.btn img.icn-arrow-right{
    position: absolute;
    right: 20px;
    top: 50%;
    margin-top: -12px;
}

.btn img{
    filter: brightness(0) invert(1);
}

.btn:hover{
    background: #637da1;
    box-shadow: 0px 0px 15px -5px #777777;
}

.btn.btn-blue{
    background-color: #637da1;
}

.btn.btn-blue:hover{
    background-color: #102f56;
}

.btn-area1btn{
    text-align: center;
}

.btn-area1btn .btn{
    width: 80%;
}

.btn-area2btn{
    text-align: center;
    display: flex;
    padding: 35px 0;
}

.btn-area2btn .btn{
    width: 50%;
    min-width: auto;
}
.btn-area2btn .btn:first-child{
    margin-right: 3%;
}



@media only screen and (max-width: 1024px) {


.btn{

}


    
}



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

.btn{

	font-size: 15px;
}   

.btn-y{
    font-size: 15px;
}

.btn.btn-small{
    min-width: 150px;
}


	
}


@media only screen and (max-width: 599px) {

.btn-area{
	padding: 35px 0 25px;
}

.btn{
	font-size: 14px;
}
    
.btn::before,
.btn::after{
    display: none;
}

.btn-area1btn .btn{
    width: 94%;
}

.btn-area2btn{
    display: block;
    padding: 25px 0;
}

.btn-area2btn .btn{
    width: 100%;
    margin: 8px 0;
}
.btn-area2btn .btn:first-child{
    margin-right: 0;
}

.btn.btn-small{
    min-width: 60%;
}

	
}

/*==================================================
全体コンテンツエリア
================================================== */

.contents-area{
    width: 1200px; 
    margin-left: auto; 
    margin-right: auto; 
    position: relative;
}

.contents-area-small{
    width: 800px; 
    margin-left: auto; 
    margin-right: auto; 
    position: relative;
}

.sec{
	padding-top: 100px;
}

.bg-w{
	background: #fff;
}

.sec-grey{
	background: #e8e8e8;
    padding: 65px 0;
}

.sec-blue{
    background-color:#f3f7f9;
    padding:65px 0;
}


.contents-sec{
	width: 1060px;
	vertical-align: top;
}

.page-contents{
	margin-top: 85px;
}

.box-w{
    background-color: #fff;
    padding: 20px;
    box-sizing: border-box;
}

.box-w-alpha{
    background-color: rgba(255,255,255,0.8);
    padding: 30px 50px;
    box-sizing: border-box;
}

.box-shadow{
    box-shadow: 0px 0px 15px -5px #777777;
}

.contents-page{
    padding: 80px 0 100px;
    position: relative;
    background: url("../images/bg01.webp") top left no-repeat;
    background-size: 50%;
    border-bottom:1px solid #ddd;
}

.box-blue{
    background-color: #f3f7f9;
    padding: 30px;
    box-sizing: border-box;
}

@media only screen and (max-width: 1200px) {

.contents-area{
    width: 90%; 
}

.contents-area-small{
    width: 90%;
}

.sec{
	padding-top: 80px;
}

.sec-blue{
    padding:50px 0;
}
	
}


@media only screen and (max-width: 768px) {
    
.sec{
	padding-top: 65px;
}

.page-contents{
	margin-top: 70px;
}

.contents-page{
    padding: 50px 0 70px;
    position: relative;
    background: url("../images/bg01.webp") top left no-repeat;
    background-size: 80%;
}



	
}

@media (max-width: 599px) {

.sec{
	padding-top: 50px;
}

.sec-grey{
    padding: 35px 0;
}

.contents-page{
    padding: 35px 0 50px;
    position: relative;
    background: url("../images/bg01.webp") top left no-repeat;
    background-size: 90%;
}

.box-blue{
    padding: 20px;
}
  
}


/*==================================================
タイトル
================================================== */

.title-contents{
    display: block;
	font-size: 42px;
	line-height: 1.5;
	position: relative;
    letter-spacing: 0.04em;
}

.title-contents strong{
    font-style: italic;
    font-weight: 700;
}

.title-contents small{
	font-size: 18px;
	font-weight: normal;
    padding-left: 5px;
}

.title-contents.title-mb{
    margin-bottom:50px;
}

p.title-en{
    margin: 15px 0 0;
    position: relative;
    font-size: 15px;
    padding-left: 5px;
}

p.title-en span{
    position: absolute;
    left: 5px;
    top: -8px;
    width: 40px;
    height: 1px;
    border-top: 1px solid #cd63a8;
}

.box-tate-scroll-line{
    height: 48px;
    position: relative;
    margin: 10px 0;
}

.title-basic{
    display: block;
    border-left: 7px solid #007193;
    font-size: 24px;
    margin-bottom: 25px;
    font-weight: 600;
    line-height: 1.5;
    padding: 6px 0 6px 15px;
}

.title-basic small{
    padding-left: 12px;
    font-size: 60%;
}

.title-basic-sub{
    display: block;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.5;
}


.title-underline{
    display: block;
    font-size: 21px;
    margin-bottom: 35px;
    border-bottom: 1px solid #007193;
    line-height: 2.0;
    font-weight: 600;
    padding: 0 0 3px 2px;
}

.title-underline small{
    padding-left: 12px;
    font-size: 65%;
}

.title-border-right{
    display: flex;
    margin: 45px 0 20px;
    font-size: 18px;
    font-weight: normal;
    text-align: left;
}

.title-border-right strong{
    font-weight: normal;
     white-space: nowrap;
    margin-right: 0.6em;
}
.title-border-right.fs-big{
    font-size: 32px;
}

.title-border-right span{
    flex-grow: 1;
    position: relative;
    content: "";
    height: 1px;
    border-top: 1px solid;
    top: 18px;
}
.title-border-right.fs-big span{
    top: 28px;
}
.title-border-right.fs-big strong small{
    font-size: 18px;
}

.title-border-left{
    position: relative;
    display: block;
    font-size: 28px;
    padding-left: 80px;
    margin-bottom: 35px;
}

.title-border-left::before{
    content: '';
    width: 60px;
    border-top: 1px solid #333;
    height: 1px;
    position: absolute;
    left: 0;
    top: 26px;
}

.title-line{
    display: block;
    font-size: 21px;
    position: relative;
    text-align: center;
    margin-bottom: 20px;
}

.title-line span{
    display: block;
    width: 70px;
    margin: 10px auto 0;
    height: 1px;
    border-top: 1px solid #000;
}

.strong-ttl{
    display: block;
}


@media only screen and (max-width: 768px) {
	
.title-contents{
	font-size: 32px;
}

.title-basic{
    font-size: 20px;
    margin-bottom: 25px;
    padding: 3px 0 3px 12px;
}

.box-tate-scroll-line{
    height: 38px;
    margin: 7px 0;
}

.title-line{
    font-size: 18px;
}


.title-underline{
    font-size: 18px;
}

.title-underline.expand span::before{
    width: 200px;
}

.title-border-right{
    margin: 30px 0 20px;
}
    

.title-border-right.fs-big{
    font-size: 24px;
} 
.title-border-right.fs-big span{
    top: 21px;
} 
.title-border-right.fs-big strong small{
    font-size: 15px;
}

.title-border-left{
    font-size: 24px;
    padding-left: 54px;
    margin-bottom: 25px;
}

.title-border-left::before{
    width: 40px;
    top: 22px;
}
  


	
}


@media only screen and (max-width: 599px) {
	
.title-contents{
	font-size: 9vw;
}
    
    .title-contents strong{
        line-height:1.3;
        display:block;
        margin-bottom:12px;
    }
    
.title-contents small{
    display: block;
    padding-left: 0;
    font-size: 4vw;
}

.title-contents.title-mb{
    margin-bottom:30px;
}

p.title-en{
    font-size: 13px;
}

.box-tate-scroll-line{
    height: 32px;
    margin: 5px 0;
}

.title-basic{
    font-size: 5.0vw;
    margin-bottom: 20px;
}


.title-underline{
    font-size: 16px;
}


.title-line{
    font-size: 4.8vw;
}


.title-underline{
    font-size: 5vw;
}

.title-border-right{
    margin: 30px 0 10px;
}
    

.title-border-right.fs-big{
    font-size: 5vw;
} 
.title-border-right.fs-big span{
    top: 18px;
} 
.title-border-right.fs-big strong small{
    font-size: 13px;
}  

.title-border-left{
    font-size: 6vw;
    padding-left: 44px;
    margin-bottom: 25px;
    line-height: 1.4;
}

.title-border-left::before{
    width: 30px;
    top: 22px;
}
	
}


/*------------
  contents-ttl
------------*/

.contents-ttl {
  overflow: hidden;
  position: relative;
  /*padding: 30px 0;*/
}
.contents-ttl::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 1px;
  background: #49BBBA;
  transition: width 2.5s;
}
.contents-ttl::after {
  content: '';
  position: absolute;
  bottom: 0;
  right: 0;
  width: 0;
  height: 1px;
  background: #49BBBA;
  transition: width 2.5s;
}
.contents-ttl._in::before {
  width: 100%;
}
.contents-ttl._in::after {
  width: 100%;
}
.contents-ttl .ttl-wrapper {
  display: flex;
  color: #49BBBA
  /*align-items: center;*/
}
.contents-ttl .ttl-main {
  padding: 30px 0 30px 35px;
  font-size: 48px;
  font-weight: 600;
  transform: translateY(15px);
  opacity: 0;
  transition: opacity 1.5s, transform 1.5s;
  transition-delay: 2s;
}
.contents-ttl._in .ttl-main {
  transform: translateY(0);
  opacity: 1;
}
.contents-ttl .ttl-separator {
  overflow: hidden;
  width: 1px;
  transform: skewX(-15deg);
}
.contents-ttl .ttl-separator::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 0;
  background: #49BBBA;
  transition: height 1.5s;
  transition-delay: 1.5s;
}
.contents-ttl._in .ttl-separator::before {
  height: 100%;
}
.contents-ttl .ttl-sub {
  display: flex;
  align-items: center;
  margin: 0;
  padding-right: 35px;
  font-size: 14px;
}
.contents-ttl .ttl-sub span {
  transform: translateY(-15px);
  opacity: 0;
  transition: opacity 1.5s, transform 1.5s;
  transition-delay: 2s;
}
.contents-ttl._in .ttl-sub span {
  transform: translateY(0);
  opacity: 1;
}

@media only screen and (max-width: 800px) {
.contents-ttl .ttl-main {
  font-size: 4.5vw;
  padding: 20px 0 20px 35px;
}
    
}

@media only screen and (max-width: 480px) {
.contents-ttl .ttl-main {
  font-size: 4.5vw;
  padding: 16px 0 16px 20px;
}
.contents-ttl .ttl-sub {
  padding-right: 25px;
  font-size: 13px;
}
    
}


/*==================================================
パンクズリスト
================================================== */

.breadcrumbs{font-size: 14px; padding: 12px 0; background: #f4f4f4;}
.breadcrumbs ul{list-style: none;}
.breadcrumbs ul li{display: inline-block; padding-right: 5px;}
.breadcrumbs ul li:after{content: ">"; padding-left: 10px;}
.breadcrumbs ul li:last-child:after{content: none; padding-left: 0;}
.breadcrumbs ul li.active-page:after{content: none;}
.breadcrumbs ul li a{
    text-decoration:underline;
}

@media only screen and (max-width: 1024px) {
.breadcrumbs{font-size: 13px; padding: 3px; }    
}

/*==================================================
fontawesome
================================================== */

i.fas{
    font-weight: 900;
}

/*==================================================
icn
================================================== */

.icn{
    vertical-align: middle;
    width: 20px;
}

.icn-l{
    margin-right: 6px;
}

.icn-r{
    margin-left: 6px;
}

.c-w{
    filter: brightness(0) invert(1);
}

a:hover .c-w{
    filter: none;
}

/*==================================================
header
================================================== */

header{
	width: 100%;
	height: 60px;
	z-index: 99999;
	position: fixed;
	top: 0;
    background-color: #fff;
}

h1#site-title{
    display: block;
    height: 60px;
    margin: 0;
    padding: 0;
}

#site-title img{height: 36px; margin: 0; vertical-align: middle;}


.header-contents{
	position: absolute;
	top: 15px;
	right: 0;
	display: flex;
}

.header-inner{
    width: 1200px;
    margin: 0 auto;
    position: relative;
}

.header-contents ul{
    list-style: none;
    display: flex;
}


.header-contents ul li{
    display: flex;
	width : auto;
    position: relative;
    vertical-align: top;
	margin-left: 15px;
}

.header-contents ul li a{
    font-size: 16px;
    align-items: center;
    display: flex;
    justify-content: center;
    color: #333;
}

.header-contents ul li a img{
    vertical-align: middle;
    margin-right: 4px;
    width: 20px;
}


@media only screen and (max-width: 1200px) {



.header-inner{
    width: 98%;
}   
    
}

@media only screen and (max-width: 1024px) {
    
.header-contents{
	right: 70px;
}    
    
}

@media only screen and (max-width: 940px) {
    
    .header-contents{
        display: none;
    }    
    
    #site-title img{height: 30px; }
    
}


@media (max-width: 599px) {
    #site-title img{height: 28px;  }
    
     
 

}

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

footer{
	clear: both;
    font-size: 16px;
}

#footer-bottom{
    background: #fff;
    padding: 30px 0;
    text-align: center;
    font-size: 13px;
    letter-spacing: 0.08em;
}

.logo-footer{
    width: 320px;
    vertical-align: bottom;
    margin-bottom: 10px;
}



@media (max-width: 768px) {


	
}

@media (max-width: 599px) {

#footer-bottom{
    padding: 25px 0;
    font-size: 12px;
}

.logo-footer{
    width: 70%;
}
	
	
}

/*==================================================
all-menu
================================================== */

.all-menu{
    background-color: #f3f7f9;
    padding: 35px;
    display: flex;
}

.col-all-menu{
    width: calc(100%/4);
    margin-right: 35px;
}

.all-menu > div:last-child{
    margin-right: 0;
}

.all-menu a,
dl.accordion dt{
    display: block;
    border-bottom: 1px solid #333;
    padding: 12px 10px;
    position: relative;
    font-size: 16px;
    background: url("../images/google_icons/arrow_right.svg") no-repeat right center;
    background-size: 16px;
}

.all-menu a:hover{
    background-color: #fff;
}

.all-menu03 a{
    display: flex;
}

.all-menu03 a img{
    width: 28px;
    height: 28px;
    object-fit: cover;
    margin-right: 10px;
    border-radius: 4px;
}

.all-menu03 a span{
    display: flex;
    align-items: center;
}

@media only screen and (max-width: 1250px) {
    
.all-menu a,
    dl.accordion dt{
        font-size: 14px;
    }
    
}

@media only screen and (max-width: 1024px) {

.all-menu{
    padding: 30px;
    flex-wrap: wrap;
}

.col-all-menu{
    width: calc(100%/2 - 15px);
    margin-right: 30px;
}
.all-menu > div:nth-child(2),
.all-menu > div:last-child{
    margin-right: 0;
}
    
    .all-menu01,
    .all-menu02{
        margin-bottom: 35px;
    }  
    
}

@media only screen and (max-width: 599px) {

.all-menu{
    padding: 15px 20px 30px;
    display: block;
}

.col-all-menu{
    width: 100%;
    margin:  0 auto;
}
.all-menu > div:nth-child(2),
.all-menu > div:last-child{
    margin-right: auto;
}
    
    .all-menu01,
    .all-menu02{
        margin-bottom: 0;
    }
    
    .all-menu01{
        margin-bottom: 0;
    }
    
dl.accordion dt{
    background: url("../images/google_icons/arrow_down.svg") no-repeat right center;
    /*background-color: #e5e9eb;*/
    background-size: 16px;
}  
    
dl.accordion dt.open{
    background: url("../images/google_icons/arrow_up.svg") no-repeat right center;
    background-color: #e5e9eb;
    background-size: 16px;
}  
    
    #sidebarMenu .all-menu{
        margin-bottom: 100px;
    }
    
}



/*==================================================
accordion
================================================== */



dl.accordion dd a{
    border-bottom: 1px solid #ddd !important;
    padding-left: 10px !important;
}

@media only screen and (max-width: 599px) {

dl.accordion dt{
    cursor:pointer;
}

dl.accordion dt.open{
}

dl.accordion dt:hover{
    cursor:pointer;
}


dl.accordion dt:after{
}

dl.accordion dt.open:after{
}

 
dl.accordion dd {
    display:none; 
}
    
   

	
	
}


/*==================================================
テーブル
================================================== */

.table{
    border-collapse:collapse;  
    box-sizing:border-box; 
    margin: 0 auto; 
	width: 100%;
	background-color: #fff;
	border: 1px solid #ddd;
}


.table th{  
    padding: 20px; 
	vertical-align: middle;
    text-align: center;
	font-weight: 600;
	letter-spacing: 0.08em;
    border: 1px solid #ddd;
    background-color: #f3f7f9;
    line-height: 1.4;
}

.table td{
    font-weight:normal; 
    padding: 20px; 
    text-align: center;
	vertical-align: middle;
    border: 1px solid #ddd;
    line-height: 1.4;
}

.table-line{
    border-collapse: collapse;
    width: 100%;
    background-color: #fff;
    border-bottom: 1px solid #ddd;
}

.table-line tr{
    border-top: 1px solid #ddd;
}

.table-line th{
    text-align: left;
    vertical-align: middle;
    font-weight: 600;
    padding: 20px;
    width: 30%;
}

.table-line td{
    text-align: left;
    vertical-align: middle;
    padding: 20px;
}

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


.table th{  
    padding: 15px 10px; 
}

.table td{
    padding: 15px 10px; 
}

    
}


@media only screen and (max-width: 599px) {

.table-line th{
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding: 12px 10px;
}

.table-line td{
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding: 0 20px 12px;
}
    


}



/*==================================================
list
================================================== */

.ul-3cols,
.ul-4cols{
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	list-style: none;
}

.ul-3cols li{
	width: calc(100%/3);
}

.ul-4cols li{
	width: calc(100%/4);
}


.ul-check{
    list-style: none;
}

.ul-check li{
    background:url("../images/icn_check.svg") no-repeat center left;
    background-size: 28px;
    padding: 5px 0 5px 38px;
    margin-bottom: 10px;
    font-size: 21px;
    line-height: 1;
}

.ul-basic{
    margin-left: 18px;
}


.ul-basic{
    list-style: disc;
}


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

.ul-check li{
    background-size: 24px;
    padding: 5px 0 5px 38px;
    margin-bottom: 10px;
    font-size: 18px;
}
    
}



@media only screen and (max-width: 599px) {

ul.ul-3cols,
ul.ul-4cols{
	display: block;
}

ul.ul-3cols li,
ul.ul-4cols li{
	width: 100%;
}

.ul-check li{
    background-size: 20px;
    padding: 5px 0 5px 28px;
    margin-bottom: 6px;
    font-size: 15px;
    line-height: 1.5;
}
	
	
}

/*==================================================
text-align
================================================== */

.ta-c{text-align: center !important;}
.ta-l{text-align: left !important;}
.ta-r{text-align: right !important;}
.ta-j{text-align: justify-all !important;}

/*==================================================
fc
================================================== */


.fc-blue{color: #007193 !important;}
.fc-navy{color: #102f56 !important;}

/*==================================================
underline
================================================== */

.underline-y{
    border-bottom: 5px solid #fdf4ac;
    padding: 0 3px 2px;
}

.underline-red{
    border-bottom: 5px solid #e8aaaa;
    padding: 0 3px 2px;
}



/*==================================================
txt-slider 追加
================================================== */

.txt-slider {
	overflow: hidden;
	position: relative;
}
.txt-slider strong {
	display: inline-block;
	position: relative;
	transition: opacity 0.5s ease-out;
}
.txt-slider strong::before {
	content: '';
	position: absolute;
	z-index: 99;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #ffffff;
}
.txt-slider strong.active::before {
	width: 0;
	left: 100%;
	transition: left 1.5s 1.5s ease-out, width 1.5s 1.5s ease-out;
}


/*==================================================
Padding Valiation
================================================== */

.p0{padding:0 !important;}
.p5{padding:5px !important;}
.p10{padding:10px !important;}
.p15{padding:15px !important;}
.p20{padding:20px !important;}
.p25{padding:25px !important;}
.p30{padding:30px !important;}
.p40{padding:40px !important;}
.p50{padding:50px !important;}

.p1per{padding:1% !important;}
.p2per{padding:2% !important;}
.p3per{padding:3% !important;}
.p4per{padding:4% !important;}
.p5per{padding:5% !important;}

.pr0{padding-right:0px !important;}
.pr5{padding-right:5px !important;}
.pr10{padding-right:10px !important;}
.pr15{padding-right:15px !important;}
.pr20{padding-right:20px !important;}
.pr25{padding-right:25px !important;}
.pr30{padding-right:30px !important;}
.pr40{padding-right:40px !important;}
.pr50{padding-right:50px !important;}

.pr1per{padding-right:1% !important;}
.pr2per{padding-right:2% !important;}
.pr3per{padding-right:3% !important;}
.pr4per{padding-right:4% !important;}
.pr5per{padding-right:5% !important;}

.pt0{padding-top:0px !important;}
.pt5{padding-top:5px !important;}
.pt10{padding-top:10px !important;}
.pt15{padding-top:15px !important;}
.pt20{padding-top:20px !important;}
.pt25{padding-top:25px !important;}
.pt30{padding-top:30px !important;}
.pt40{padding-top:40px !important;}
.pt50{padding-top:50px !important;}

.pb0{padding-bottom:0px !important;}
.pb5{padding-bottom:5px !important;}
.pb10{padding-bottom:10px !important;}
.pb15{padding-bottom:15px !important;}
.pb20{padding-bottom:20px !important;}
.pb25{padding-bottom:25px !important;}
.pb30{padding-bottom:30px !important;}
.pb40{padding-bottom:40px !important;}
.pb50{padding-bottom:50px !important;}

.pl0{padding-left:0px !important;}
.pl5{padding-left:5px !important;}
.pl10{padding-left:10px !important;}
.pl15{padding-left:15px !important;}
.pl20{padding-left:20px !important;}
.pl25{padding-left:25px !important;}
.pl30{padding-left:30px !important;}
.pl40{padding-left:40px !important;}
.pl50{padding-left:50px !important;}

.pl1per{padding-left:1% !important;}
.pl2per{padding-left:2% !important;}
.pl3per{padding-left:3% !important;}
.pl4per{padding-left:4% !important;}
.pl5per{padding-left:5% !important;}

.p0a{padding-right:auto; padding-left:auto !important;}
.plr10{padding-left:10px; padding-right:10px !important;}
.plr15{padding-left:15px; padding-right:15px !important;}
.plr20{padding-left:20px; padding-right:20px !important;}
.plr25{padding-left:25px; padding-right:25px !important;}
.plr30{padding-left:30px; padding-right:30px !important;}
.plr40{padding-left:40px; padding-right:40px !important;}
.plr50{padding-left:50px; padding-right:50px !important;}

.plr1per{padding-left:1%; padding-right:1% !important;}
.plr2per{padding-left:2%; padding-right:2% !important;}
.plr3per{padding-left:3%; padding-right:3% !important;}
.plr4per{padding-left:4%; padding-right:4% !important;}
.plr5per{padding-left:5%; padding-right:5% !important;}



/*==================================================
Margin Valiation
================================================== */

.m0{margin:0 !important;}
.m5{margin:5px !important;}
.m10{margin:10px !important;}
.m15{margin:15px !important;}
.m20{margin:20px !important;}
.m25{margin:25px !important;}
.m30{margin:30px !important;}
.m40{margin:40px !important;}
.m50{margin:50px !important;}

.m1per{margin:1% !important;}
.m2per{margin:2% !important;}
.m3per{margin:3% !important;}
.m4per{margin:4% !important;}
.m5per{margin:5% !important;}

.mr0{margin-right:0px !important;}
.mr5{margin-right:5px !important;}
.mr10{margin-right:10px !important;}
.mr15{margin-right:15px !important;}
.mr20{margin-right:20px !important;}
.mr25{margin-right:25px !important;}
.mr30{margin-right:30px !important;}
.mr40{margin-right:40px !important;}
.mr50{margin-right:50px !important;}

.mr1per{margin-right:1% !important;}
.mr2per{margin-right:2% !important;}
.mr3per{margin-right:3% !important;}
.mr4per{margin-right:4% !important;}
.mr5per{margin-right:5% !important;}

.mt0{margin-top:0px !important;}
.mt5{margin-top:5px !important;}
.mt10{margin-top:10px !important;}
.mt15{margin-top:15px !important;}
.mt20{margin-top:20px !important;}
.mt25{margin-top:25px !important;}
.mt30{margin-top:30px !important;}
.mt40{margin-top:40px !important;}
.mt50{margin-top:50px !important;}

.mb0{margin-bottom:0px !important;}
.mb5{margin-bottom:5px !important;}
.mb10{margin-bottom:10px !important;}
.mb15{margin-bottom:15px !important;}
.mb20{margin-bottom:20px !important;}
.mb25{margin-bottom:25px !important;}
.mb30{margin-bottom:30px !important;}
.mb40{margin-bottom:40px !important;}
.mb50{margin-bottom:50px !important;}

.ml0{margin-left:0px !important;}
.ml5{margin-left:5px !important;}
.ml10{margin-left:10px !important;}
.ml15{margin-left:15px !important;}
.ml20{margin-left:20px !important;}
.ml25{margin-left:25px !important;}
.ml30{margin-left:30px !important;}
.ml40{margin-left:40px !important;}
.ml50{margin-left:50px !important;}

.ml1per{margin-left:1% !important;}
.ml2per{margin-left:2% !important;}
.ml3per{margin-left:3% !important;}
.ml4per{margin-left:4% !important;}
.ml5per{margin-left:5% !important;}

.m0a{margin-right:auto; margin-left:auto !important;}
.mlr10{margin-left:10px; margin-right:10px !important;}
.mlr15{margin-left:15px; margin-right:15px !important;}
.mlr20{margin-left:20px; margin-right:20px !important;}
.mlr25{margin-left:25px; margin-right:25px !important;}
.mlr30{margin-left:30px; margin-right:30px !important;}
.mlr40{margin-left:40px; margin-right:40px !important;}
.mlr50{margin-left:50px; margin-right:50px !important;}

.mlr1per{margin-left:1%; margin-right:1% !important;}
.mlr2per{margin-left:2%; margin-right:2% !important;}
.mlr3per{margin-left:3%; margin-right:3% !important;}
.mlr4per{margin-left:4%; margin-right:4% !important;}
.mlr5per{margin-left:5%; margin-right:5% !important;}

/*==================================================
Width Valiation
================================================== */

.w5per{width:5% !important;}
.w10per{width:10% !important;}
.w15per{width:15% !important;}
.w20per{width:20% !important;}
.w25per{width:25% !important;}
.w30per{width:30% !important;}
.w35per{width:35% !important;}
.w40per{width:40% !important;}
.w45per{width:45% !important;}
.w50per{width:50% !important;}
.w55per{width:55% !important;}
.w60per{width:60% !important;}
.w65per{width:65% !important;}
.w70per{width:70% !important;}
.w75per{width:75% !important;}
.w80per{width:80% !important;}
.w85per{width:85% !important;}
.w90per{width:90% !important;}
.w95per{width:95% !important;}
.w100per{width:100% !important;}
.w110per{width:110% !important;}
.w120per{width:120% !important;}
.w130per{width:130% !important;}
.w140per{width:140% !important;}
.w150per{width:150% !important;}
.w160per{width:160% !important;}
.w170per{width:170% !important;}
.w180per{width:180% !important;}
.w190per{width:190% !important;}
.w200per{width:200% !important;}




