@charset "utf-8";

@media screen and (max-width: 768px) {
    #wrapper {
        min-width: auto;
    }
    .inner {
        width: 100%;
    }
    .gridWrap {
        padding: 32px 0;
        background: url("../images/common/bg_border.png") 50% 0 repeat-y,
            url("../images/common/bg_border.png") calc(100% - 16px) 0 repeat-y,
            url("../images/common/bg_border.png") 16px 0 repeat-y,
            url("../images/common/bg_border.png") 0 100% repeat-x;
        background-size: 1px 1px;
    }
    .gridWrapBottom {
        padding: 32px 0 48px;
        background: url("../images/common/bg_border.png") 50% 0 repeat-y,
            url("../images/common/bg_border.png") calc(100% - 16px) 0 repeat-y,
            url("../images/common/bg_border.png") 16px 0 repeat-y,
            url("../images/common/bg_border.png") 0 calc(100% - 16px) repeat-x,
            url("../images/common/bg_border.png") 0 100% repeat-x;
        background-size: 1px 1px;
    }
    .gridWrapFull {
        padding: 48px 0;
        background: url("../images/common/bg_border.png") 50% 0 repeat-y,
            url("../images/common/bg_border.png") calc(100% - 16px) 0 repeat-y,
            url("../images/common/bg_border.png") 16px 0 repeat-y,
            url("../images/common/bg_border.png") 0 calc(100% - 16px) repeat-x,
            url("../images/common/bg_border.png") 0 100% repeat-x,
            url("../images/common/bg_border.png") 0 16px repeat-x;
        background-size: 1px 1px;
    }
	.page2Column{
		padding-top: 80px;
		 background: url("../images/common/bg_border.png") calc(100% - 16px) 0 repeat-y,
            url("../images/common/bg_border.png") 16px 0 repeat-y,
            url("../images/common/bg_border.png") 0 calc(100% - 16px) repeat-x,
            url("../images/common/bg_border.png") 0 100% repeat-x,
            url("../images/common/bg_border.png") 0 16px repeat-x;
        background-size: 1px 1px;
	}
    .pc_hide {
        display: block !important;
    }

    .sp_hide {
        display: none !important;
    }

    .caution {
        font-size: 14px;
    }
    /* ---------------------------------------------------------------------------------------------------*/
    /* header */
    /* ---------------------------------------------------------------------------------------------------*/
    #campaignHeader {
        min-width: auto;
    }

    #campaignHeader i {
        margin-right: 8px;
        font-size: 18px;
    }

    /* ---------------------------------------------------------------------------------------------------*/
    header {
        padding: 0 16px;
        height: 80px;
        min-width: auto;
    }

    header .spNav {
        margin-left: auto;
        display: block;
        width: 40px;
        height: 40px;
    }

    header .spNav i {
        display: block;
        text-align: center;
        line-height: 40px;
        color: #FFF;
        font-size: 24px;
    }

    header .nav {
        display: none;
    }

    .spMenu {
        position: fixed;
        top: 80px;
        z-index: 9998;
        width: 100%;
        height: calc(100% - 80px);
        background: #FFF;
    }

    .spMenu li {
        border-bottom: 1px solid #DDD;
    }

    .spMenu li a {
        display: block;
        width: 100%;
        padding: 0 24px;
        position: relative;
        font-weight: bold;
        line-height: 60px;
        color: #222;
        text-decoration: none;
        transition: all 0.2s ease-out;
    }

    .spMenu li.app a {
        background: #0377ee;
        color: #FFF;
    }

    .spMenu li a i {
        margin-left: auto;
        display: block;
        position: absolute;
        font-size: 20px;
        top: calc(50% - 0.5em);
        right: 22px;
        transition: all 0.2s ease-out;
    }

    .spMenu li.app a i {
        color: #FFF;
    }

    .spMenu li a:hover,
    .spMenu li a.hover {
        color: #0377ee;
    }

    .spMenu li.app a:hover,
    .spMenu li.app a.hover {
        color: #FFF;
        background: #15a6bc;
    }

    .spMenu li a:hover i,
    .spMenu li a.hover i {
        right: 14px;
    }

    /* ---------------------------------------------------------------------------------------------------*/
    /* backTopButton */
    /* ---------------------------------------------------------------------------------------------------*/
    .backTopButton a {
        display: block;
        width: 56px;
        height: 56px;
        border: 1px solid #0377ee;
    }

    .backTopButton a i {
        font-size: 18px;
        line-height: 52px;
    }

    .backTopButton a:hover,
    .backTopButton a.hover {
        box-shadow: 0 0 0 1px #FFF inset;
    }

    .backTopButton a:hover i {
        line-height: 46px;
    }

    /* ---------------------------------------------------------------------------------------------------*/
    /* footer */
    /* ---------------------------------------------------------------------------------------------------*/
    footer .inner {
        padding: 24px 32px;
    }

    footer .copy {
        font-size: 11px;
        line-height: 32px;
    }
	/* ---------------------------------------------------------------------------------------------------*/
    /* blockButton */
    /* ---------------------------------------------------------------------------------------------------*/
    .blockButton {
		width: 100%;
    }
	/* ---------------------------------------------------------------------------------------------------*/
	/* 下層ページテンプレート */
	/* ---------------------------------------------------------------------------------------------------*/
	.singleColumn{
		padding-top: 80px;
	}
	.singleColumn .inner {
		padding: 0 32px;
	}
	/* 404 */
	.big404{
		font-size: 40px;
	}
	/* ---------------------------------------------------------------------------------------------------*/
    /* breadlist */
    /* ---------------------------------------------------------------------------------------------------*/
    .breadlist {
        padding: 12px 24px;
        min-width: auto;
    }

    .breadlist ol {
        width: 100%;
        flex-wrap: nowrap;
        overflow-y: hidden;
        overflow-x: scroll;
        overflow-scrolling: touch;
		white-space: nowrap;
    }
	/* ---------------------------------------------------------------------------------------------------*/
	/* contact */
	/* ---------------------------------------------------------------------------------------------------*/
	#contact h1{
		font-size: 24px;
	}
	#contact h1 + p{
		text-align: justify;
	}
	#contact .thanksMessage{
	}
	#contact .thanksMessage p{
		text-align: justify;
	}
	.singleColumn #contact .form{
		padding: 0 16px;
		margin: 24px -15px 0;
	}
	.form .form_row{
		padding: 16px 0;
		flex-direction: column;
	}
	.form .form_row br{
		display: none;
	}
	.form .form_row > label{
		padding-right: 0;
		padding-bottom: 12px;
		width: 100%;
		flex-direction: row;
		justify-content: space-between;
		align-items: flex-start;
	}
	.form .form_row > label span{
		margin-top: 0;
		margin-left: 8px;
		flex-shrink: 0;
	}
	.form input[type="submit"] {
		margin: 0;
		width: 100%;
	}
	input[type="submit"][name="submitBack"]{
		margin-bottom: 8px;
		line-height: 48px;
	}
	/* ---------------------------------------------------------------------------------------------------*/
	.columnBody{
		width: 100%;
		min-height: auto;
		flex-direction: column;
	}
	.columnBody .mainContent{
		padding: 32px;
		background: url("../images/common/bg_border.png") 0 100% repeat-x,
			url("../images/common/bg_border.png") 0 calc(100% - 16px) repeat-x,
			url("../images/common/bg_border.png") 0 16px repeat-x;
        background-size: 1px 1px;
	}
	.columnBody .sideContent{
		padding: 24px 17px 40px;
		width: 100%;
	}
	/* ---------------------------------------------------------------------------------------------------*/
	.trainerCard .trainerName{
		font-size: 18px;
	}
	/* ---------------------------------------------------------------------------------------------------*/
	.page2Column .pageTitle{
		margin: 0 -15px;
		font-size: 20px;
	}
	.page2Column .blogList{
		margin: 0 -15px;
	}
	.blogList .trainerCard .trainerThumb{
		margin-right: 16px;
		width: 88px;
		height: 88px;
	}
	.blogList .trainerCard{
		flex-wrap: wrap;
	}
	.blogList .trainerArchive{
		margin-top: 8px;
		width: 100%;
	}
	/* ---------------------------------------------------------------------------------------------------*/
	.templateSingle .mainContent .trainerCard{
		margin: 0 -15px;
		background: transparent;
		flex-direction: column;
	}
	.templateSingle .mainContent .trainerCard .trainerThumb{
		margin: 0 auto;
	}
	.templateSingle .mainContent .trainerCard .trainerInfo{
		padding: 0 16px 24px;
		border-bottom: 3px double #CCC;
	}
	.templateSingle .mainContent h1{
		margin-top: 16px;
	}
	.templateSingle .mainContent h2{
	    font-size: 20px;
	}
	.templateSingle .mainContent h3{
		font-size: 20px;
	}
	.templateSingle .mainContent h4{
		font-size: 18px;
	}
	.templateSingle dl.trainerArchive{
		margin-top: 16px;
	}
}