@charset "UTF-8";
/*  
Theme Name:Original Style - 1column
Version:1.2
*/

.mainimage .logo{float:left;padding:6px;}
.home #contents > .inner {/* トップページ幅 100% */
	width:100%;
	max-width:100%;
}
.topinner {/* コンテンツは1000pxに */
	width:1000px;
	margin:0 auto;
	max-width:98%;
}
.mainimage .topinner {/* コンテンツは1000pxに */
	width:2000px;
	margin:0 auto;
	max-width:100%;
}

/* tinyMCE用に見出しをリセット */
.toppage h3,
.toppage h4,
.toppage h5 {
	background:none;
	border:none;
	color:inherit;
	font-size:inherit;
	line-height:inherit;
	margin:0;
	padding:0;
}
.toppage h3::before,
.toppage h3::after ,
.toppage h4::before,
.toppage h4::after,
.toppage h5::before,
.toppage h5::after {
	display:none;
}


/*==========================
	　mainimage
==========================*/
.mainimage{
    position: relative;
}
.main_copy {
}
.main_copy img {
    max-width: 2000px;
    max-height: 241px;
    position: absolute;
    right: 0;
	left:0;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 100%;
}
/*-- スライダーの時 ------------*/

.slider { }
.slick-slide img { margin:0 auto;}

button.slick-arrow {/* 矢印ボタン */
	background:none;
	border:none;
	position:absolute;
	top:50%;
	margin-top:-20px;
	height:40px;
	width:16px;
	text-indent:-9px;
	z-index:1;
}
button.slick-arrow:hover {
 	cursor:pointer;
	opacity:0.7;
}
button.slick-prev {/* 矢印（前へ）ボタン */
	background:url(img/btn_prev.png) no-repeat;
	left:18%;
	margin-left:-16px;
}
button.slick-next {/* 矢印（次へ）ボタン */
	background:url(img/btn_next.png) no-repeat;
	right:18%;
	margin-right:-16px;
}
@media screen and (max-width: 1650px) {
button.slick-prev {	left:13.7%;}
button.slick-next {	right:13.7%;}
}
@media screen and (max-width: 1400px) {
button.slick-prev {	left:8%;}
button.slick-next {	right:8%;}
}
@media screen and (min-width: 1200px) {
.slick-track {}
.mainimage .slick-slide:not(.slick-center) {/* 前と次の画像を半透明に */
	opacity: 0.4;
	-moz-opacity: 0.4;
	filter: alpha(opacity=40);
}
}


/*==========================
	汎用に使えるボタン
==========================*/
.link_btn ,.btn-style { text-align:center; }
.link_btn a,
.btn-style a {
	background:#e9677d;
	width:280px;
	max-width:100%;
	padding:0.8em 1.2em;
	text-align:center;
	color:#fff;
	display:inline-block;
	text-decoration:none;
	line-height:1.2;
	box-sizing:border-box;
	font-size:16px;
	border-radius:6px;
	position:relative;
}
.link_btn a span,
.btn-style a span{
	display:block;
	font-size:12px;
}
.link_btn a::after,
.btn-style a::after {
    content: '';
    position: absolute;
    top: 50%;
    margin-top: -3px;
    right: 15px;
    width: 6px;
    height: 6px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-transition: .3s;
    transition: .3s;
}
.link_btn a:hover:after,
.btn-style a:hover:after{
	right:13px;
}
.link_btn a:hover,
.btn-style a:hover {
	opacity: 0.7;
	-moz-opacity: 0.7;
	filter: alpha(opacity=70);
 	cursor:pointer;
}
.under .link_btn a,
.under .btn-style a {
	width:auto;
	min-width:280px;
}
/*==========================
	loopSlider　無限ループスライダー
==========================*/
.loopSliderWrap {
    top: 0;
    left: 0;
    height: 200px;
    overflow: hidden;
    position: absolute;
}
 
.loopSlider {
    margin: 0 auto;
    width: 100%;
    height: 200px;
    text-align: left;
    position: relative;
    overflow: hidden;
}
 
.loopSlider ul {
    height: 200px;
    float: left;
    overflow: hidden;
}
 
.loopSlider ul li {
    width: 300px;
    height: 200px;
    float: left;
    display: inline;
    overflow: hidden;
}

/*==========================
	　TOP コンテンツ
==========================*/

.top .mainblock a {
	text-decoration:none;
}
.top .mainblock a:hover {
}
/*-- 新着情報 --------------*/
.sec_news {
    padding: 4em 0;
}
.sec_news .news {
    position: relative;
    box-sizing: border-box;
}
.sec_news .news dl{
	line-height:1.3;
}
.sec_news .news dt {
    float:left;
    clear:left;
    color: #433f3f;
    padding: 15px 0;
}
.sec_news .news dd {
    padding: 15px 0;
}
.news dd a {
    text-decoration: none;
    color: #433f3f;
}
.sec_news .news dd a:hover {
    text-decoration: underline;
}
.sec_news .news .btn a:hover {
    opacity: 0.7;
    -moz-opacity: 0.7;
    -webkit-opacity: 0.7;
}
.sec_news .news h3 {
    font-size: 26px;
    color: #433f3f;
    line-height: 1.5;
    letter-spacing: 0.1em;
    position: relative;
    font-weight: bold;
    padding: 3px 10px 12px 0.5em;
    margin: 0 auto 10px;
    box-sizing: border-box;
	text-align:left;
	border-radius:0;
}
.sec_news .news .btn a {
    position: absolute;
    top: 13px;
    right: 0;
    color: #433f3f;
    font-size: 12px;
    display: table;
    padding: 1px 12px;
	text-decoration:none;
}
.sec_news .news .btn a:after {
    content: " ＞";
    font-weight: bold;
}


/*見出し*/
.top h2{
	font-size: 36px;
    color: #3f464c;
    text-align: center;
    line-height: 1.4;
    letter-spacing: 0.05em;
    margin-bottom: 3%;
    font-weight: bold;
}
.top h3{
    text-align: center;
    line-height: 1.4;
    letter-spacing: 0.05em;
    font-weight: bold;
}
h2 .sub {
    display: block;
    margin-bottom: 2%;
}
/*-- ボックスその他 --------------*/
.sec01 {
	padding:5em 0 0;
}
.sec01 .bg{
}
.sec01 h3{
    font-size: 26px;
    font-weight: bold;
    text-align: left;
    color: #3aa0ff;
    line-height: 1.9;
    margin-bottom: 1.1em;
}
.sec02 {
	padding:5em 0 3em;
}
.sec02 .column{
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 6px 11px 15px #e0e4f4;
    margin-bottom: 5%;
}
.sec02 h3{
    font-size: 22px;
    font-weight: bold;
    color: #2854c6;
    margin-bottom: 0.7em;
    letter-spacing: 0;
}
.sec02 .inner {
    box-sizing: border-box;
    padding: 8%;
}
.sec02 .inner p{
    margin-bottom: 0;
}
.sec_contact{
    background: url(img/contact_bg.jpg) no-repeat center / cover;
    color:#fff;
    padding:7em 0 4em;
}
.sec_contact h2{
    color:#fff;
}
.sec_contact .topinner{
    position: relative;
}
.sec_contact p.ttl {
    position: absolute;
    right: 0;
    top: -40%;
    max-width: 24%;
}
.sec_contact p.p01 {
    font-size: 26px;
    text-align: center;
    font-weight: bold;
    background: url(img/line01.png) no-repeat center top,url(img/line01.png) no-repeat center bottom;
    padding: 1.2em 0 1.1em;
    line-height: 1.3;
}
.sec_contact h3 {
    font-size: 22px;
    margin-bottom: 2%;
}
.sec_contact .btn-wrap {
    width: 920px;
    margin: 0 auto 3%;
    text-align: center;
    font-size:0;
    max-width: 100%;
}
.sec_contact .btn-wrap .btn{
    display: inline-block;
    margin: 0 3%;
    vertical-align: top;
    width: 44%;
}

.sec_contact .tel a {
    font-size: 24px;
    font-weight: bold;
    color: #fff;
}
.sec03{
padding:6em 0 5em;
}
.sec03 h2{
    color:#f3ab2d;
}
.sec03 h3 {
    font-size: 26px;
    background: #f9ecd6;
    padding: 0.4em;
    margin-bottom: 1em;
    margin-top: 1.5em;
}
.sec03 h4 {
    font-size: 18px;
    line-height: 1.3;
    text-align: center;
    font-weight: bold;
    margin-bottom: 0.5em;
}
.sec03 h4.line{
    display: flex;
    align-items: center;
    margin-bottom: 1em;
    font-size: 22px;
}

.sec03 h4.line:before,
.sec03 h4.line:after {
    content: "";
    height: 1px;
    flex-grow: 1;

    border-bottom:1px dashed #c6c7c6;
}

.sec03 h4.line:before {
    margin-right: 5rem;
}

.sec03 h4.line:after {
    margin-left: 5rem;
}
.sec03 h5 {
    font-size: 18px;
    line-height: 1.8;
    font-weight: bold;
    text-align: center;
}
.sec03 .link a{
    font-size:18px;
    font-weight: bold;
    text-decoration: underline;
    color:#3f464c;
}
.sec03 .link a:hover {
    opacity: .6;
}
.sec04 {
    position: relative;
        padding: 5em 0 4em;
}
.sec04:before {
    content: "";
    width: 100%;
    height: 400px;
    background: #e7f3ff;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    z-index: -1;
}
.sec04 .column{
    box-sizing: border-box;
    background: #fff;
    position: relative;
    padding: 5% 5% 2%;
    box-shadow: 6px 11px 15px #e9f1fb;
    border-radius: 14px;
    margin-bottom: 3%;
}
.sec04 .column.col_main{
    background: url(img/line03.png);
    position: relative;
}
.sec04 .column.col_main .inner {
    position: relative;
    z-index: 1;
}
.sec04 .column.col_main:before {
    content: "";
    width: auto;
    height: auto;
    background: #fff;
    position: absolute;
    left: 10px;
    right: 10px;
    top: 10px;
    bottom: 10px;
    border-radius: 4px;
    box-sizing: border-box;
    padding: 10%;
    z-index: 0;
}
.sec04 h4{
    font-size:26px;
    color:#2854c6;
    text-align: center;
    font-weight: bold;
    margin-bottom: 3%;
}
.sec04 .p01{
    font-size:22px;
    line-height: 1.3;
    font-weight: bold;
        margin-bottom: 0.6em;
}
.sec04 .p01 .big{
    color:#3aa0ff;
    font-size:42px;
}
.sec04 .p01 .mini{
    font-size:18px;
}
.sec04 p.ttl {
    position: absolute;
    left: 0;
    right: 0;
        max-width: 90%;
    bottom: 93%;
    margin: auto;
    text-align: center;
    z-index: 1;
}
.sec04 h3.line {
    font-size: 30px;
    color: #2854c6;
        background: url(img/line02.png) no-repeat center top,url(img/line02.png) no-repeat center bottom;
    padding: 0.8em 0;
    margin-bottom: 4%;
        margin-top: 5%;

}
.sec04 .border-table {
    line-height: 1.4;
    margin-bottom: 8%;
}
.sec04 .border-table th{
    font-size:18px;
    padding: 6px;
}
.sec04 .border-table th,
.sec04 .border-table td{
    width:20%;
}
.sec04 .border-table td{
    height: 35px;
}
.sec04 .border-table .mini1 {
    font-size: 15px;
}
.sec04 .border-table .mini2 {
    font-size: 14px;
}
.sec04 h3 {
    font-size: 26px;
    color: #2854c6;
    margin-bottom: 3%;
}
.sec05 {
    background: #f2f4f8;
    padding: 4em 0 12em;
}
.sec05 .column{
    box-sizing: border-box;
    padding: 2% 2% 1px;
    border-top:5px solid #3aa0ff;
    border-radius: 9px;
    background: #fff;
    position: relative;
}
.sec05 p.img {
    text-align: center;
}
.sec05 h3 {
    font-size: 22px;
    color: #3aa0ff;
    line-height: 1.4;
    margin-bottom: 0.5em;
}
.sec05 h3 .mini{
    font-size:16px;
}
.sec05 .column:after{
    content: "";
    width:19px;
    height: 21px;
    background: url(img/flow_arrow.png) no-repeat ;
}
.sec05 .column:not(:last-child):after {
    content: "";
    width: 19px;
    height: 21px;
    background: url(img/flow_arrow.png) no-repeat;
    position: absolute;
    right: -30px;
    top: 0;
    bottom: 0;
    margin: auto;
}
.sec05 .column:nth-of-type(2) {
    border-color:#3792f5;
}
.sec05 .column:nth-of-type(2) h3{
    color:#3792f5;
}
.sec05 .column:nth-of-type(3) {
    border-color:#327ee6;
}
.sec05 .column:nth-of-type(3) h3{
    color:#327ee6;
}
.sec05 .column:nth-of-type(4) {
    border-color:#2c65d3;
}
.sec05 .column:nth-of-type(4) h3{
    color:#2c65d3;
}
.sec05 .column:nth-of-type(5) {
    border-color:#2854c6;
}
.sec05 .column:nth-of-type(5) h3{
    color:#2854c6;
}
.sec05 .no{
    position: absolute;
    left: 6px;
    top: -28px;
}
.sec05 p.sub {
    position: absolute;
    bottom: -7em;
}
.sec05 .column:nth-of-type(5) p.sub {
    bottom: 0em;
}
.sec05 h2 {
    margin-bottom: 7%;
}
.sec06 {
    padding: 4em 0;
}
.sec06 h4{
font-size: 22px;
    font-weight: bold;
    background: #e7f3ff;
    box-sizing: border-box;
    padding: 1.5em 10% 1.4em 11%;
}
.sec06 h4 img {
    margin-right: 3%;
    position: absolute;
    left: 5%;
    top: 1.5em;
}
.sec06 .answer{
    background: #f9f9f9;
}
.qa{
    position: relative;
    margin-bottom: 4%;
}
.qa h4:hover{
    cursor:pointer;
}
.qa:after {
    content: '';
    position: absolute;
    top: 35px;
    right: 5%;
    display: block;
    width: 20px;
    height: 20px;
    border-top: 1px solid #3f464c;
    border-right: 1px solid #3f464c;
    transform: rotate(135deg);
    transition: .3s;
    z-index: 0;
}
.qa.open:after {
    transform: rotate(-45deg);
    transition: .3s;
}
.sec06 .answer:before, .sec06 .answer:after {
    display: none;
}
.sec06 .answer {
    background: #f9f9f9;
    box-sizing: border-box;
    padding: 1.5em 4% 1px;
}
/********************************
	Responsive
*********************************/

@media screen and (min-width: 768px) {/* タブレットまで */

/*================================
	mainimage　が一枚画像の場合
================================*/
 .mainimage{
        background: url(img/mainimage.jpg) no-repeat center / cover;
    height: 1000px;
}
.main_btn {
    background: transparent;
    position: relative;
    top: 0px;
}
    .main_btn .topinner {
        width:100%;
}
    .main_btn .main_txt{
     display: table;
        width:100%;
    }
    .main_btn .topinner .main_txt > span {
		display:none;
    /*display: table-cell;
        width:71%;
        padding: 20px 10px;
        vertical-align: middle;*/
}
.main_btn a {
    display: block;
    vertical-align: middle;
    background: url(img/main_btn_bg.jpg) no-repeat center / cover;
    text-align: center;
    padding:15px 5px 20px 5px;
    width: 20%;
	float:right;
}
/*==========================
	　TOP コンテンツ
==========================*/
/*-- FLEX設定 --------------*/
.columns {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between;
}
.col_wrap{ /*改行して組む場合*/
	flex-wrap: wrap;
	-ms-flex-wrap: wrap; /*IE10*/
	-webkit-flex-wrap: wrap; /* Safari6.1以降 */
}
.columns.reverse{ /*左右反転*/
-webkit-box-direction:reverse;
    -moz-box-direction:reverse;
    -webkit-box-orient:horizontal;
    -moz-box-orient:horizontal;
    -webkit-flex-direction:row-reverse;
    -moz-flex-direction:row-reverse;
    flex-direction:row-reverse;
}
.columns > .column {
    box-sizing: border-box;
    max-width: 100%;
    -webkit-box-flex-basis: 100%;
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
}
.columns.col3{
    -webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}
.columns.col3 > .column {
    max-width: 30%;
    -webkit-box-flex-basis: 30%;
    -webkit-flex-basis: 30%;
    flex-basis: 30%;
    margin-right: 5%;
}
.columns.col3 > .column:nth-of-type(3n){
        margin-right:0!important;
}
    .columns.col4{
    -webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}
.columns.col4 > .column {
    max-width: 23.5%;
    -webkit-box-flex-basis: 23.5%;
    -webkit-flex-basis:23.5%;
    flex-basis:23.5%;
    margin-right: 2%;
}
.columns.col4 > .column:nth-of-type(4n){
        margin-right:0;
}
.col_align{
    -webkit-align-items: center;
 	-ms-align-items    : center;
	align-items        : center;
    }
/*-- ボックスその他 --------------*/
    .sec01 .bg1{
	background:url(img/recommend_bg01.jpg) no-repeat 65% / cover;
        min-height: 425px;
            margin-bottom: 6%;
            margin-top: 3%;
}
    .sec01 .bg2{
	background:url(img/recommend_bg02.jpg) no-repeat 35% / cover;
        min-height: 383px;
            margin-bottom: 3%;
}
    .sec01 .bg3{
	background:url(img/recommend_bg03.jpg) no-repeat 65% / cover;
        min-height: 463px;
}
    
    .sec01 .col_img{
        max-width: 37%;
    -webkit-box-flex-basis: 37%;
    -webkit-flex-basis: 37%;
    flex-basis: 37%;
        margin-left: -3%;
    }
    .sec01 .bg2 .col_img{
        margin-right: -3%;
        margin-left: auto;
    }
    .sec01 .col_txt{
        max-width: 63%;
    -webkit-box-flex-basis: 63%;
    -webkit-flex-basis: 63%;
    flex-basis: 63%;
    }
    .sec01 .bg1 h3{
        margin-top:6%;
    }
    .sec02 .columns.col3 > .column {
    max-width: 31.45%;
    -webkit-box-flex-basis:  31.45%;
    -webkit-flex-basis: 31.45%;
    flex-basis: 31.45%;
    margin-right: 2.825%;
}
    .sec02 .column:nth-of-type(3n-1){
          transform: translateY(10%);
    }
    .sec04 h2 {
    margin-bottom: 7%;
}
    .sec05 .column{
         max-width: 17%;
    -webkit-box-flex-basis: 17%;
    -webkit-flex-basis: 17%;
    flex-basis:  17%;
    margin-right: 3.75%;
    }
    .sec05 .column:last-child{
        margin-right: 0;
    }
}

@media screen and (min-width: 768px)  and (max-width: 1280px) {/* 程よいブラウザサイズでメインイメージを縮小 */
/*.mainimage {
    height: 430px;
}*/
}
@media screen and (min-width: 768px)  and (max-width: 1041px) {
.mainimage {
    height: 510px;
}
    .sec01 .bg1 h3 {
    margin-top: 14%;
}
    .sec01 .bg2 h3 {
    margin-top: 6%;
}
    .sec01 .bg3 h3 {
    margin-top: 10%;
}
    .sec_contact p.ttl {
    top: -39%;
    }
    .sec05 .column {
    padding: 1% 1% 1px;
    }
    .sec05 h3 {
    font-size: 17px;
    }
    .sec05 p.sub {
    bottom: -9em;
}
    .sec05 .column:nth-of-type(5) p.sub {
    bottom: -7.5em;
}
}

@media screen and (max-width: 1041px) {/*コンテンツが横幅いっぱいになったら*/
.sec01 h3 {
    font-size: 20px;
    }
    .sec02 h3 {
    font-size: 20px;
    }
    .sec_contact p.p01 {
    font-size: 21px;
    }
    .sec04 h4 {
    font-size: 23px;
    }
}

@media screen and (max-width: 767px) {/* スマホ */

.topinner {
	width:420px;
	margin:0 auto;
	box-sizing:border-box;
}
.top #contents,
.top #aside{
	margin-bottom:0;
}
/*==========================
	　mainimage
==========================*/
.mainimage, .slider {
    margin-bottom: 0;
}
.mainimage img {
    height: auto;
    max-width: none;
    max-height: none;
    width: 100%;
}
	.logo{max-width:200px!important;display:block;float:none;margin:5px auto;padding:0px;}
    .main_btn .topinner {
    width: 100%;
    max-width: 100%;
}
    .main_btn a {
    background:url(img/main_btn_bg.jpg) no-repeat center / cover;
    display: block;
    text-align: center;
    padding: 20px;
}
    .main_btn a img {
    width: 240px;
}
    .main_copy {
    position: absolute;
    top: 66%;
    right: 7%;
    }
    .mainimage .main_copy img {
    max-width: 303px;
    max-height: 284px;
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 45%;
}
/*==========================
	ボタン
==========================*/


/*==========================
	loop
==========================*/
.loopSlider {    height: 100px;}
.loopSlider ul {    height: 100px;}
.loopSlider ul li {
    width: 150px;
    height: 100px;
}

/*==========================
	　TOP コンテンツ
==========================*/
.sp-columns {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
}
.sp-columns .column {
    box-sizing: border-box;
    max-width: 49%;
    -webkit-box-flex-basis: 49%;
    -webkit-flex-basis: 49%;
    flex-basis: 49%;
        margin-bottom: 2%;
}    
.sec_news .news {
    padding-bottom: 1px;
}
.sec_news .news dt {
    width: 100%;
    padding: 5px 0 0;
}
.sec_news .news + .news{
	margin-top:1.5em;
}
.sec_news .news dd {
    padding: 0 0 5px;
}
    .sec_news .news dl {
    margin-top: 10px;
}
    .sec_news .news .btn a {
    top: 7px;
    }
/*-- 余白・背景 --------------*/
.sec_news {
    padding: 2em 0;
}
    .sec01 {
    padding: 3em 0 0;
}
    .sec02 {
    padding: 3em 0 1em;
}

    .sec_contact {
    padding: 3em 0 1em;
    background-image: url(img/sp_contact_bg.jpg) ;

}
        .sec_contact.sec_contact1{
    padding: 5em 0 1em;
}
    .sec03 {
    padding: 3em 0 2em;
}
    .sec04 {
    padding: 3em 0 2em;
}
    .sec05 {
    padding: 3em 0 2em;
}
    .sec06 {
    padding: 3em 0;
}
/*-- 見出し --------------*/
.sec_news .news h3 {
    font-size: 24px;
}
    .top h2 {
    font-size: 26px;
    }
    .sec06 h4 {
    font-size: 20px;
    }
    .sec04 .p01 .big {
    font-size: 30px;
}
/*-- ボックスその他 --------------*/
    
    .sec01 .bg .topinner {
    width: 100%;
    max-width: 100%;
}
    .sec01 .col_img {
    max-width: 65%;
    margin: 0 auto;
}
    .sec01 h3 {
    box-sizing: border-box;
    padding: 0 3%;
}
    .sec01 .col_txt p {
    background: #e7f3ff;
    box-sizing: border-box;
    padding: 4% 3% 2%;
        position: relative;
}
    .sec01 .col_txt p:before{
    content: "";
    width: 225px;
    height: 198px;
    position: absolute;
    right: 2%;
    bottom: 91%;
    background: url(img/sp_recommend_bg01.png) no-repeat bottom/ 100% auto;
    max-width: 40%;
    z-index: -1;
    }
    .sec01 .bg2 .col_txt p:before{
        background-image: url(img/sp_recommend_bg02.png);
        left:2%;
        right:0;
    }
    .sec01 .bg3 .col_txt p:before{
        background-image: url(img/sp_recommend_bg03.png);
        bottom: 96%;
    }
    .sec02 .inner {
    padding: 6%;
}
    .sec_contact .btn-wrap .btn {
    display: block;
    margin: 0 auto 10px;
    vertical-align: top;
    width: 100%;
}
    .sec_contact p.ttl {
    position: absolute;
    right: -27px;
    top: -29%;
    max-width: 36%;
}
    .column.col_main {
    margin-top: 16%;
        padding-top: 12%;
}
    .sec04 .border-table {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
}
    .sec05 .col_top {
    display: table;
		margin: 10px auto 15px;
}
    .sec05 .img {
    display: table-cell;
    position: relative;
    width: 20%;
    vertical-align: middle;
}
    .sec05 h3 {
    display: table-cell;
    width: 80%;
    box-sizing: border-box;
    text-align: left;
    padding: 0 0 0 5%;
        vertical-align: middle;
}
    .sec05 .column {
    margin-bottom: 50px;
}
    .sec05 .column:not(:last-child):after {
    right: 0;
    left: 0;
    top: auto;
    bottom: -36px;
    margin: auto;
    transform: rotate(90deg);
}
    .sec05 p.sub {
    bottom: -5em;
}
    .sec05 .column:nth-of-type(3) {
    margin-bottom: 90px;
}
    .sec05 .column:nth-of-type(3):after{
        bottom:-80px;
    }
    .sec06 h4 {
    padding: 1.5em 13% 1.4em 65px;
}
    
}

@media screen and (max-width: 480px) {/* スマホ480px */
    .sec_contact p.ttl {
    top: -146px;
    }
    .top h2 {
    font-size: 24px;
        letter-spacing: 0;
}
}

@media screen and (max-width: 320px) {/* スマホ320px */
}




/*グーグルカレンダー設定*/
.cal_wrapper {
 max-width: 900px; /* 最大幅 */
 min-width: 260px; /* 最小幅 */
 margin: 2.0833% auto;
 padding:0 .5em;
}
.googlecal {
 position: relative;
 padding-bottom: 80%; /* 縦横比 */
 height: 0;
 overflow: hidden;
}
.googlecal iframe {
 position: absolute;
 top: 0;
 left: 0;
 width: 100% !important;
 height: 100% !important;
}

.calendar-container {
    position: relative!important;
    padding-bottom: 80%;
    padding-top: 30px;
    height: 0;
}
 
.calendar-container iframe,
.calendar-container object,
.calendar-container embed {
    position: absolute!important;
    top: 0;
    left: 0;
    width: 100%!important;
    height: 100%!important;
}
 
@media screen and (max-width: 460px) {
    .calendar-container {
        padding-bottom: 140%;
    }
}
 
.entry-content img,#content embed,#content object,#content iframe,#content video {
    padding: 6px!important;
    border-radius: 3px;
        box-sizing:border-box;
}

@media screen and (max-width: 767px) {
.cal_wrapper {
    padding: 0!important;
}
    .googlecal {
 padding-bottom: 100%; /* 縦横比 */
}
}