/*
----------------------------------------
1600
----------------------------------------
*/

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

	#home .ttl-box .message::before {
		right: 50%;
	}

	#home .ttl-box .message {
		padding-left: 50%;
	}

	#home .ttl-box::after {
		right: 44%;
	}

}


/*
----------------------------------------
1500
----------------------------------------
*/

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

	header .head-menu {
		padding-left: 40%;
	}

	header .g-nav-wrap h1 span {
		width: 40%;
	}

	#g-nav a {
		width: 100px;
		margin-left: 20px;
	}

	.nav-fix #g-nav .contact a {
		padding: 10px 20px;
	}

	#home .ttl-box .message::before {
		right: 55%;
	}

	#home .ttl-box .message {
		padding-left: 45%;
	}

	#home .ttl-box::after {
		right: 48%;
	}
}


/*
----------------------------------------
1250
----------------------------------------
*/

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

	body {
		font-size: 1.4rem;
	}

	#contents {
		padding-bottom: 60px;
	}

	#wrapper > header {
		padding: 20px;
	}

	header .head-menu .datetime {
		margin: 0 20px 0 10px;
	}

	header .g-nav-wrap h1 {
		width: 320px;
	}

	#g-nav a {
		width: 85px;
		margin-left: 10px;
	}

	.nav-fix #g-nav a {
		padding: 5px 0 8px;
	}

	.nav-fix #g-nav .contact a {
		padding: 10px;
	}

	header .g-nav-wrap h1 span {
		left: 20px;
	}

	header .head-menu .tel a {
		letter-spacing: 0;
	}

	header .head-menu .mail a {
		padding: 0 15px;
	}

	footer .footer-menu {
		padding: 40px 0;
	}

	footer .footer-menu .flex > dl {
		width: calc( ( 100% - 40px ) / 3 );
		margin-right: 20px;
	}

	footer .footer-menu dd li {
		width: 100% !important;
	}

	footer .copyright {
		padding: 40px 0;
	}

	footer .copyright figure img {
		width: 300px;
	}

	/* home */

	#home .ttl-box::after {
		top: 380px;
		bottom: 160px;
	}

	#home .ttl-box .main {
		padding: 120px 40px;
		margin-bottom: 80px;
	}

	#home .ttl-box .main h2 {
		font-size: 4rem;
	}

	#home .ttl-box .main::after {
		left: 320px;
	}

	#home .ttl-box .main .en {
		font-size: 1.2rem;
	}

	#home .ttl-box .message .txt {
		padding: 20px 40px 30px 30px;
	}

	#home .ttl-box .message .ttl .en::before {
		width: 30px;
		left: -45px;
	}

	#home .ttl-box .message h3 {
		font-size: 3rem;
	}

	#home .ttl-box {
		margin-bottom: 60px;
	}

	#home .practice-box .ttl-01 {
		padding-bottom: 60px;
	}

	#home .practice-box .ttl-01::after {
		font-size: 12rem;
		line-height: 9rem;
	}

	#home .practice-box h3 {
		font-size: 2rem;
	}

	#home .practice-box .link-list a {
		font-size: 1.4rem;
	}

	#home .feature-box .feature-list .flex {
		padding: 30px 0 20px;
	}

	#home .feature-box .feature-list .feature {
		width: calc( ( 100% - 40px ) / 3 );
		margin: 0 20px 30px 0;
	}

	#home .feature-box .feature-list .txt {
		padding: 30px 15px;
	}

	#home .feature-box .feature-list .ttl {
		margin-bottom: 10px;
	}

	#home .feature-box .feature-list .ttl h3 {
		font-size: 2.2rem;
	}

	#home .feature-box .feature-list .txt .read {
		font-size: 1.4rem;
	}

	#home .contact-box {
		padding: 40px 20px;
	}

	#home .contact-box .read {
		font-size: 1.6rem;
		margin: 20px 0 30px;
	}

	#home .site-box {
		margin: 40px 0;
	}

	#home .site-list {
		margin-top: 30px;
	}

	#home .access-box .map {
		margin: 40px 0 60px;
	}

	#home .access-box .info .flex > figure {
		width: 40%;
		padding-right: 30px;
	}

	#home .access-box .info .flex > .txt {
		width: 60%;
	}

	#home .access-box .info dl.flex dt {
		padding: 10px 0;
	}

	#home .access-box .info dl.flex dd {
		padding: 10px 0;
	}

	/* page */

	#main-contents {
		width: calc( 100% - 260px );
		padding: 0 30px 0 0;
	}

	#sidebar {
		width: 260px;
	}

}


/*
----------------------------------------
1000
----------------------------------------
*/

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

	html[lang=ja] {
		margin-top: 0 !important;
	}

	#wpadminbar {
		display: none;
	}

	body.nav-open {
		position: fixed;
		width: 100vw;
		height: 100vh;
		overflow: hidden;
	}

	#wrapper {
		padding-top: 70px;
	}

	#wrapper > header {
		padding: 0;
		position: absolute;
		top: 0;
		right: 0;
		left: 0;
		background: #fff;
		z-index: 999999;
	}

	body.nav-open #wrapper > header {
		position: fixed;
	}

	header .head-menu {
		display: none;
	}

	header .g-nav-wrap > .flex {
		align-items: center;
		height: 70px;
	}

	header .g-nav-wrap h1 {
		width: calc( 100% - 70px );
		padding: 0 20px;
	}

	header .g-nav-wrap h1 span {
		display: none;
	}

	header .g-nav-wrap h1 img {
		width: 265px;
		vertical-align: middle;
	}

	#g-nav {
		display: none;
	}

	#g-nav-sp {
		display: block;
		position: fixed;
		top: 70px;
		right: 0;
		bottom: 0;
		left: 0;
		background: #fff;
		overflow: auto;
		-webkit-overflow-scrolling: touch;
		opacity: 0;
		visibility: hidden;
		z-index: -999;
		transition: all .2s;
	}

	body.nav-open #g-nav-sp {
		opacity: 1;
		visibility: visible;
		z-index: 999999;
	}

	#g-nav-sp .flex {
		flex-direction: column;
		border-top: solid 1px #e5e5e5;
	}

	#g-nav-sp .flex > li {
		border-bottom: solid 1px #e5e5e5;
	}

	#g-nav-sp .flex a {
		display: block;
		font-size: 1.6rem;
		color: #8dbe54;
		padding: 14px 20px;
		background: url( ../img/common/arrow-01.png ) right 20px center / 10px no-repeat;
	}

	#g-nav-sp .contact-nav {
		padding: 40px;
	}

	#g-nav-sp .contact-nav dl {
		text-align: center;
		border: solid 2px #8dbe54;
		border-radius: 4px;
	}

	#g-nav-sp .contact-nav dt {
		font-size: 1.5rem;
		background: #8dbe54;
		color: #fff;
		padding: 5px;
	}

	#g-nav-sp .contact-nav .tel {
		margin-bottom: 20px;
	}

	#g-nav-sp .contact-nav .tel dd {
		color: #333;
		padding: 15px;
	}

	#g-nav-sp .contact-nav .tel a {
		display: inline-block;
		font-size: 3rem;
		font-weight: bold;
		letter-spacing: 1px;
		line-height: 1.5;
		padding-left: 28px;
		background: url( ../img/common/icon-tel-02.png ) left center / 20px no-repeat;
	}

	#g-nav-sp .contact-nav .tel .note {
		font-size: 1.2rem;
		letter-spacing: 1px;
		color: #333;
	}

	#g-nav-sp .contact-nav .mail {
		border: solid 2px #09b39f;
	}

	#g-nav-sp .contact-nav .mail dt {
		background: #09b39f;
	}

	#g-nav-sp .contact-nav .mail dd {
		padding: 26px 20px;
	}

	#g-nav-sp .contact-nav .mail a {
		display: block;
		text-align: center;
		font-size: 1.4rem;
		font-weight: bold;
		white-space: nowrap;
		line-height: 4.6rem;
		color: #09b39f;
		border: solid 1px #d1d1d1;
		border-radius: 2.3rem;
		padding: 0 10px;
	}

	#g-nav-sp .contact-nav .mail a::before {
		display: inline-block;
		content: url( ../img/common/icon-mail.png );
		margin-right: 10px;
	}
	/* sp-btn */

	#sp-btn {
		display: block;
		width: 70px;
		height: 70px;
		background: #8dbe54;
		color: #fff;
		text-align: center;
		position: fixed;
		right: 0;
		top: 0;
		z-index: 999999;
	}

	#sp-btn > div {
		height: 48px;
		position: relative;
		transition: all .6s;
	}

	#sp-btn span {
		display: inline-block;
		box-sizing: border-box;
		transition: all .5s;
	}

	#sp-btn span {
		position: absolute;
		left: 22px;
		right: 22px;
		height: 2px;
		background: #fff;
	}

	#sp-btn span:nth-of-type(1) {
		top: 16px;
	}

	#sp-btn span:nth-of-type(2) {
		top: 25px;
	}

	#sp-btn span:nth-of-type(3) {
		top: 34px;
	}

	#sp-btn .en {
		font-size: 1.2rem;
		line-height: 1.2rem;
	}

	body.nav-open #sp-btn span:nth-of-type( 1 ) {
		-webkit-transform: translateY( 9px ) rotate( -45deg );
		transform: translateY( 9px ) rotate( -45deg );
	}

	body.nav-open #sp-btn span:nth-of-type( 2 ) {
		opacity: 0;
	}

	body.nav-open #sp-btn span:nth-of-type( 3 ) {
		-webkit-transform: translateY( -9px ) rotate( 45deg );
		transform: translateY( -9px ) rotate(45deg );
	}

	footer .copyright {
		padding-bottom: 100px;
	}

	#home .ttl-box .message h3 {
		font-size: 2.4rem;
	}

	#home .practice-box .link-list li {
		width: calc( ( 100% - 20px ) / 2 );
	}

	#home .practice-box .link-list li:nth-child( even ) {
		margin-right: 0;
	}

	#home .contact-box .flex dt {
		font-size: 1.5rem;
		padding: 8px 10px;
	}

	#home .contact-box .read {
		font-size: 1.3rem;
		margin: 15px 0 25px;
	}

	#home .contact-box .tel a {
		font-size: 3rem;
		padding-left: 28px;
		background: url( ../img/common/icon-tel-02.png ) left center / 20px no-repeat;
	}

	#home .contact-box .mail a {
		display: block;
		text-align: center;
		padding: 0 10px;
	}

	#home .site-list .site {
		width: calc( ( 100% - 20px ) / 2 );
	}

	#home .site-list .site:nth-child( even ) {
		margin-right: 0;
	}

	#home .site-list a {
		border-radius: 10px;
	}

	#home .site-list a .img {
		border-radius: 10px 10px 0 0;
	}

	/* page */

	#contents > .main-wrap {
		flex-direction: column;
	}

	#main-contents {
		width: 100%;
		padding: 0;
	}

	#sidebar {
		width: 100%;
		margin-top: 40px;
	}

	.post-contents table.table-01 td {
		padding: 30px 15px;
	}

	#page .contact table.table-01 td {
		padding-left: 80px;
	}

	#page .contact table.table-01 .req {
		right: -15px;
	}

}


/*
----------------------------------------
750
----------------------------------------
*/

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

	.pc {
		display: none;
	}

	.sp {
		display: block;
	}

	.ttl-01 h2 {
		line-height: 1.6;
		font-weight: bold;
	}

	#contents input[type=checkbox] {
		width: 25px;
		height: 25px;
	}

	#contents {
		padding-bottom: 30px;
	}

	footer .footer-menu {
		padding: 0;
	}

	footer .footer-menu > .flex {
		flex-direction: column;
		padding: 0;
	}

	footer .footer-menu .flex > dl {
		width: 100%;
		margin: 0;
	}

	footer .footer-menu dt {
		font-size: 1.6rem;
		margin: 10px 20px;
		border: none;
	}

	footer .footer-menu dd ul {
		justify-content: space-between;
		border-top: solid 1px #e5e5e5;
	}

	footer .footer-menu dd li {
		background: #f5f5f5;
		padding: 0;
	}

	footer .footer-menu dd .flex > li {
		width: calc( 100% / 2 ) !important;
		border-bottom: solid 1px #e5e5e5;
	}

	footer .footer-menu dd li::before {
		display: none;
	}

	footer .footer-menu dd .flex > li:nth-child( even ) {
		border-left: solid 1px #e5e5e5;
	}

	footer .footer-menu dd li a {
		display: block;
		padding: 15px 0;
		background: #fff;
		letter-spacing: -1px;
		text-align: center;
		position: relative;
	}

	footer .footer-menu dd .flex > li > a::after {
		content: '';
		border: solid 4px transparent;
		border-right: solid 4px #8dbe54;
		border-bottom: solid 4px #8dbe54;
		position: absolute;
		right: 4px;
		bottom: 4px;
		transition: all .2s;
	}

	footer .footer-menu dd .sub-menu li a {
		padding: 5px 0;
		background: #f5f5f5;
	}

	footer .copyright figure img {
		width: 265px;
	}

	#sp-bottom-nav {
		display: block;
		position: fixed;
		right: 0;
		bottom: 0;
		left: 0;
		background: rgba( 255, 255, 255, .9 );
		padding: 10px;
		z-index: 9999;
	}

	#sp-bottom-nav .flex {
		justify-content: space-between;
	}

	#sp-bottom-nav li {
		width: calc( ( 100% - 10px ) / 2 );
	}

	#sp-bottom-nav li a {
		display: block;
		background: #8dbe54;
		color: #fff;
		line-height: 1.5;
		height: 60px;
		padding: 5px 0;
		border-radius: 3px;
		box-shadow: 0 3px 0 #599613;
	}

	#sp-bottom-nav .tel .num {
		display: inline-block;
		font-size: 2rem;
		background: url( ../img/common/icon-tel-wh.png ) left center / 14px no-repeat;
		padding-left: 20px;
	}

	#sp-bottom-nav li .note {
		font-size: 1.1rem;
		font-weight: normal;
	}

	#sp-bottom-nav .mail a {
		background: #09b39f;
		box-shadow: 0 3px 0 #088a7b;
		padding-top: 14px;
		font-weight: bold;
	}

	/* home */

	#home .ttl-box .main {
		padding: 190px 30px 20px;
		margin-bottom: 25px;
	}

	#home .ttl-box .main::after {
		background: url( ../img/home/main-img-sp.png ) top center / contain no-repeat;
		left: 0;
	}

	#home .ttl-box .main h2 {
		font-size: 2.7rem;
		font-weight: bold;
		margin-bottom: 10px;
	}

	#home .ttl-box .main .en {
		font-size: 1rem;
	}

	#home .ttl-box .message {
		padding: 250px 0 0;
	}

	#home .ttl-box .message::before {
		right: 0;
		bottom: auto;
		height: 250px;
	}

	#home .ttl-box .message .txt {
		padding: 20px 30px 20px 40px;
	}

	#home .ttl-box .message .ttl .en {
		font-size: 1.4rem;
	}

	#home .ttl-box .message .ttl .en::before {
		left: -40px;
	}

	#home .ttl-box .message h3 {
		font-size: 2.1rem;
		font-weight: bold;
		text-align: center;
		margin: 15px 0;
	}

	#home .ttl-box .message p {
		text-indent: 1.4rem;
		letter-spacing: 1px;
		line-height: 2;
	}

	#home .ttl-box {
		margin-bottom: 30px;
	}

	#home .ttl-box::after {
		display: none;
	}

	#home .practice-box .ttl-01 {
		padding-bottom: 50px;
	}

	#home .practice-box .ttl-01::after {
		content: 'Practice';
		font-size: 8rem;
		line-height: 6rem;
		bottom: -2px;
	}

	#home .practice-box {
		margin-bottom: 40px;
	}

	#home .practice-box .link-list {
		padding: 0;
	}

	#home .practice-box .link-list .flex {
		flex-direction: column;
	}

	#home .practice-box .link-list li {
		width: 100%;
		margin: 0;
		border-bottom: solid 1px #e5e5e5;
	}

	#home .practice-box .link-list a {
		border: none;
		font-size: 1.6rem;
		text-align: left;
		padding: 14px 20px;
		background: url( ../img/common/arrow-01.png ) right 20px center / 10px no-repeat;
	}

	#home .practice-box .link-list a::after {
		display: none;
	}

	#home .news-box {
		margin-bottom: 60px;
	}

	#home .news-box > .flex {
		flex-direction: column;
		padding: 0 40px;
	}

	#home .news-box .ttl,
	#home .news-box .news-list {
		width: 100%;
		padding: 0;
	}

	#home .news-box .ttl a {
		-js-display: flex;
		display: -ms-flex;
		display: -webkit-flex;
		display: flex;
		align-items: center;
		justify-content: space-between;
	}

	#home .news-box .ttl .more {
		transform: translateY( 5px );
	}

	#home .news-box .news-list > .flex {
		flex-direction: column;
	}

	#home .news-box .news-list .post {
		width: 100%;
		margin: 0;
		padding: 30px 0 20px;
	}

	#home .news-box .news-list .meta {
		margin-bottom: 10px;
	}

	#home .news-box .news-list time {
		font-size: 1.3rem;
	}

	#home .news-box .news-list .post-ttl a {
		font-size: 1.6rem;
		text-decoration: underline;
	}

	#home .feature-box .ttl-01 {
		padding-bottom: 50px;
	}

	#home .feature-box .ttl-01 h2 {
		font-size: 2.5rem;
		line-height: 1.5;
	}

	#home .feature-box .ttl-01::after {
		font-size: 8rem;
		line-height: 6rem;
		bottom: -2px;
	}

	#home .feature-box .feature-list {
		padding: 35px 20px 0;
	}

	#home .feature-box .feature-list .flex {
		padding: 0;
		flex-direction: column;
	}

	#home .feature-box .feature-list .ttl h3 {
		font-weight: bold;
	}

	#home .feature-box .feature-list .feature {
		width: 100%;
		margin: 0 0 35px;
	}

	#home .feature-box .feature-list .feature figure {
		text-align: center;
		background: #fafafa;
	}

	#home .feature-box .feature-list .txt {
		padding: 30px;
	}

	#home .feature-box .feature-list .txt .read {
		font-size: 1.3rem;
		letter-spacing: 0;
	}

	#home .contact-box {
		padding: 40px 0 30px;
		background: url( ../img/home/contact-bg-sp.png ) center center / cover no-repeat;
	}

	#home .contact-box .wrap > .flex {
		flex-direction: column;
		margin: 0 20px;
	}

	#home .contact-box .flex dl {
		width: 100%;
	}

	#home .contact-box .tel {
		margin-bottom: 15px;
	}

	#home .contact-box .tel dd {
		padding: 10px 10px 15px;
	}

	#home .contact-box .mail a {
		font-size: 1.4rem;
	}

	#home .contact-box .mail dd {
		padding: 25px;
	}

	#home .site-box .ttl-01 h2 {
		font-size: 2.5rem;
		letter-spacing: 0;
	}

	#home .site-list {
		margin-top: 25px;
		flex-direction: column;
	}

	#home .site-list a {
		border-radius: 4px;
	}

	#home .site-list a .img {
		border-radius: 4px 4px 0 0;
	}

	#home .site-list .site {
		width: 100%;
		margin: 0 0 25px;
	}

	#home .site-list figcaption {
		font-size: 2.1rem;
		background: url( ../img/common/icon-external.png ) right 16px center / 15px no-repeat;
	}

	#home .site-list figcaption span {
		font-size: 1.6rem;
	}

	#home .access-box .map {
		margin: 25px 0 40px;
		padding-bottom: 250px;
	}

	#home .access-box .info > .flex {
		margin: 0 20px;
		flex-direction: column;
	}

	#home .access-box .info .flex > figure {
		width: 100%;
		padding: 0;
		text-align: center;
	}

	#home .access-box .info .flex > .txt {
		width: 100%;
	}

	#home .access-box .info h3 {
		font-size: 1.9rem;
		text-align: center;
		padding: 15px 0;
		position: relative;
	}

	#home .access-box .info h3::before,
	#home .access-box .info h3::after {
		content: '';
		height: 1px;
		background: #e5e5e5;
		position: absolute;
		right: 0;
		bottom: 0;
		left: 0;
	}

	#home .access-box .info h3::after {
		background: #8dbe54;
		right: auto;
		width: 20%;
	}

	#home .access-box .info dl {
		flex-direction: column;
	}

	#home .access-box .info dl.flex dt {
		width: 100%;
		padding: 20px 0 10px;
		border: none;
	}

	#home .access-box .info dl.flex dt::after {
		display: none;
	}

	#home .access-box .info dl.flex dd {
		width: 100%;
		padding: 0 0 20px;
		border: none;
		position: relative;
	}

	#home .access-box .info dl.flex dd::before,
	#home .access-box .info dl.flex dd::after {
		content: '';
		height: 1px;
		background: #e5e5e5;
		position: absolute;
		right: 0;
		bottom: 0;
		left: 0;
	}

	#home .access-box .info dl.flex dd::after {
		background: #8dbe54;
		right: auto;
		width: 20%;
	}

	/* page */

	#page-ttl {
		padding: 30px 20px;
	}

	#page-ttl .en {
		font-size: 1.6rem;
	}

	#page-ttl h1, #page-ttl h2 {
		font-size: 3rem;
		font-weight: bold;
	}

	.topic-path {
		padding: 10px 0 20px;
		font-size: 1.2rem;
	}

	.archive .post-header,
	.single .post-header {
		margin-bottom: 20px;
	}

	.post-header .ttl h1,
	.post-header .ttl h2 a {
		font-size: 2rem;
	}

	#ez-toc-container {
		padding: 20px 20px 10px;
		margin-bottom: 20px;
	}

	#ez-toc-container.counter-flat ul,
	#ez-toc-container.counter-hierarchy ul,
	.ez-toc-widget-container.counter-flat ul,
	.ez-toc-widget-container.counter-hierarchy ul {
		margin: 0 0 10px 10px;
	}

	#news .post-contents h2 {
		font-size: 1.8rem;
		text-align: left;
		margin: 30px 0 20px;
		padding: 10px 15px;
	}

	#news .post-contents h3 {
		font-size: 1.8rem;
		padding-bottom: 10px;
		margin: 30px 0 20px;
	}

	.post-contents h4 {
		font-size: 1.6rem;
		padding: 10px 20px;
		margin: 30px 0 20px;
	}

	.post-contents h5 {
		font-size: 1.6rem;
		padding: 2px 0 2px 20px;
		margin: 30px 0 20px;
	}

	.post-contents p {
		margin-bottom: 20px;
	}

	.post-contents ul,
	.post-contents ol {
		margin-bottom: 20px;
	}

	.post-contents ul li::before {
		top: 10px;
	}

	.post-contents blockquote {
		padding: 30px 20px 10px;
		margin: 30px 0 20px;
	}

	.post-contents blockquote::before {
		left: 20px;
	}

	.post-contents table {
		margin: 0 0 20px;
	}

	.post-contents table th {
		padding: 10px;
		font-size: 1.4rem;
	}

	.post-contents table td {
		padding: 10px;
		font-size: 1.4rem;
	}

	.author-box {
		padding: 20px;
		background: #fafafa url( ../img/page/writer-bg.png ) right top / 160px no-repeat;
	}

	.author-box h3 {
		text-align: center;
		font-size: 1.8rem;
	}

	.author-box > .flex {
		flex-direction: column;
	}

	.author-box > .flex > figure {
		width: 100%;
		text-align: center;
		padding: 0;
		margin-bottom: 10px;
	}

	.author-box > .flex > .txt {
		width: 100%;
	}

	.author-box .txt .info {
		justify-content: center;
	}

	.author-box .txt h4 {
		font-size: 1.8rem;
	}

	.author-box .txt .more-link {
		margin-top: 10px;
	}

	.author-box .txt .more-link a {
		display: block;
		padding: 10px;
		background: url( ../img/common/arrow-02.png ) right 10px center no-repeat;
		font-size: 1.4rem;
		text-align: center;
	}

	.post-nav {
		margin: 20px 0;
		flex-direction: column;
		border-top: solid 1px #dbdbdb;
	}

	.post-nav .prev,
	.post-nav .next {
		width: 100%;
		border-bottom: solid 1px #dbdbdb;
	}

	.post-nav .prev a {
		padding: 20px 0 20px 35px;
	}

	.post-nav .next a {
		padding: 20px 35px 20px 0;
	}

	.post-nav .back-link {
		width: 100%;
		order: 3;
		padding: 0;
		margin-top: 20px;
	}

	.relation-post h3 {
		margin-bottom: 20px;
	}

	.relation-post .relation-list {
		flex-direction: column;
	}

	.relation-post .flex .post {
		width: 100%;
		margin: 0 0 20px;
		padding-bottom: 20px;
		border-bottom: solid 1px #dbdbdb;
	}

	#sidebar {
		margin-top: 20px;
	}

	#sidebar .menu-list a {
		padding: 15px 10px 15px 30px;
	}

	#sidebar .menu-list > ul {
		margin-bottom: 30px;
	}

	#page .post-contents h2 {
		font-size: 2.5rem;
		font-weight: bold;
		font-weight: bold;
		margin-bottom: 30px;
	}

	#page .post-contents > .wrap > .flex {
		flex-direction: column;
	}

	#page .post-contents > .wrap > .flex figure,
	#page .post-contents > .wrap > .flex.reverce figure {
		width: 100%;
		padding: 0;
		margin-bottom: 20px;
		text-align: center;
	}

	#page .post-contents > .wrap > .flex .txt {
		width: 100%;
	}

	#page .post-contents .flex .txt ul,
	#page .post-contents .flex .txt ol {
		margin-left: 0;
	}

	#page .post-contents > figure {
		margin: 30px 0;
	}

	#page .post-contents h3 {
		margin: 30px 0 20px;
		font-size: 1.8rem;
	}

	#page .post-contents table th,
	#page .post-contents table.table-01 th,
	#page .post-contents table td {
		font-size: 1.4rem;
	}

	.post-contents table.table-01 th {
		padding: 20px 10px 20px 0;
		white-space: nowrap;
	}

	#page .post-contents table.table-01 td {
		padding: 20px 0 20px 10px;
	}

	.post-list .post-contents a {
		flex-direction: column;
	}

	.post-list .post-contents figure {
		width: 100%;
		padding: 0;
		text-align: center;
	}

	.post-list .post-contents .txt {
		width: 100%;
	}

	.post-list .post-contents .txt p {
		margin-top: 20px;
	}

	/* contact */

	input[type=text],
	input[type=search],
	input[type=tel],
	input[type=number],
	input[type=url],
	input[type=email],
	input[type=password],
	input[type=date],
	textarea,
	select {
		width: 100%;
	}

	input[type=submit],
	input[type=button] {
		display: block;
		width: 100%;
		text-align: center;
		line-height: 56px;
		border-radius: 30px;
		padding: 0;
	}

	#page .contact {
		margin-top: 40px;
	}

	#page .contact .read {
		text-align: left;
	}

	#page .form-step {
		margin: 40px 0;
	}

	#page .contact table {
		margin-bottom: 0;
	}

	#page .contact table tr {
		-js-display: flex;
		display: -ms-flex;
		display: -webkit-flex;
		display: flex;
		flex-direction: column;
		position: relative;
	}

	#page .contact table.table-01 th {
		width: 100%;
		padding: 10px 0;
		border-top: solid 1px #8dbe54;
		border-bottom: none;
	}

	#page .contact table.table-01 .req {
		position: relative;
		right: auto;
		top: 0;
		transform: translate( 0, 0 );
		margin-left: 10px;
	}

	#page .contact table.table-01 td {
		border: none;
		padding: 0 0 20px;
	}

	#page .contact input[name=your-name],
	#page .contact input[name=your-name-kana],
	#page .contact input[name=your-email],
	#page .contact input[name=your-zip],
	#page .contact input[name=your-address],
	#page .contact input[name=your-tel],
	#page .contact input[name=your-fax] {
		width: 100%;
	}

	#page .send-wrap .flex > p {
		width: 100%;
		margin: 15px 0 0;
	}

	#page .send-wrap .flex > p:first-child {
		order: 2;
	}

	/* thanks */

	.thanks .contact-tel dt {
		font-size: 1.5rem;
		padding: 8px 10px;
	}

	.thanks .contact-tel dd {
		padding: 10px 10px 15px;
	}

	.thanks .contact-tel a {
		font-size: 3rem;
		padding-left: 28px;
		background: url( ../img/common/icon-tel-02.png ) left center / 20px no-repeat;
	}

}

/*
* お客様の声機能追加
*/

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

	#voice .voice-tabs__tab {
		font-size: 2rem;
	}

	#voice .voice-item__anchor {
		top: -76px;
	}

	#voice .voice-item h2 {
		font-size: 2.2rem;
	}

}

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

	#voice .voice-item__anchor {
		top: 0;
	}

	#home .voice-box .voice-item {
		padding: 20px 25px 13px;
	}

	#voice .voice-item__images {
		flex: 0 0 40%;
		padding: 0 30px 0 0;
	}

	#voice .voice-item__texts {
		flex: 0 0 60%;
	}

	#home .voice-box .voice-item__photo {
		width: 100%;
		margin: 0 auto;
	}

	#home .voice-box .voice-item__tax {
		width: 100%;
		padding: 10px 0 0;
	}

}

@media screen and (max-width: 750px) {
	#voice .contents {
		padding-bottom: 30px;
	}

	#voice .voice-tabs {
		height: 40px;
	}

	#voice .voice-tabs__tab {
		font-size: 1.6rem;
		letter-spacing: 0;
	}

	#voice .voice-list {
		padding-bottom: 30px;
	}

	#voice .voice-item {
		display: block;
		padding: 20px 0;
	}

	#voice .voice-item__images {
		flex: 0 0 25%;
		padding: 0;
	}

	#voice .voice-item__photo img {
		max-width: 100%;
		margin-bottom: 15px;
	}

	#voice .voice-item__texts .voice-item__header {
		padding: 0 0 0 15px;
		min-height: initial;
	}

	#voice .voice-item__texts .voice-item__header .voice-item__enquete {
		margin: 0 auto 30px;
		padding: 0;
	}

	#voice .voice-item__enquete {
		position: relative;
		right: 0;
		text-align: center;
	}

	#voice .voice-item__enquete a {
		width: 80px;
		height: 80px;
	}

	#voice .voice-item__enquete a::after {
		bottom: -5px;
		right: -5px;
		width: 25px;
		height: 25px;
		background: #8dbe54 url( ../img/voice/loupe.png ) center center / 16px no-repeat;
	}

	#voice .voice-item .voice-cat {
		margin-right: 5px;
	}

	#voice .voice-item .voice-cat a {
		width: 90px;
		font-size: 1.3rem;
	}

	#voice .voice-item .voice-tag {
		font-size: 1.3rem;
	}

	#voice .voice-item .comment-wrap {
		letter-spacing: 0;
		line-height: 1.8;
		padding-left: 15px;
	}

	#voice .voice-item .comment-wrap br {
		display: none;
	}

	#voice .detail-wrap {
		padding: 0;
	}

	#voice p.detail-btn {
		text-align: center;
		margin-top: 1rem;
		padding: 5px;
		border: solid 1px #eee;
	}

	#voice p.detail-txt {
		padding-top: 1rem;
	}

	#voice .voice-item__texts {
		flex: 0 0 75%;
		padding-right: 0;
	}

	#voice .voice-item__texts .voice-item__header > .flex {
		flex-direction: column-reverse;
	}

	#voice .voice-item h2 {
		font-size: 1.6rem;
		line-height: 1.6;
		margin: 5px 0 10px;
	}

	#voice .voice-notfound {
		padding: 20px 15px 30px;
	}

	#home .voice-box {
		padding: 30px 0;
	}

	#home .voice-box .ttl-01 h2 {
		margin-bottom: 10px;
	}

	#home .voice-box .voice-list {
		display: block;
	}

	#home .voice-box .voice-item {
		width: 100%;
		margin-bottom: 20px;
		padding: 15px 15px 8px;
	}

	#home .voice-box .voice-item__photo {
		width: 50%;
	}

	#home .voice-box .voice-item__tax {
		width: calc(100% - 153px);
		padding: 0 0 0 20px;
	}

	#home .voice-box .voice-item__ttl {
		font-size: 1.6rem;
	}

	#home .voice-box .view-all a {
		height: 60px;
	}
}

/* 2021.05.19 iframe レスポンシブ */
@media screen and (max-width:600px){
	.jc_iframe-outer{
		text-align: center;
	}
	.jc_iframe-outer iframe{
		width: 100%;
		max-width: 300px;
		height: 168.75px;
	}
}

/* -------------2021.05.13 ジェイクール修正------------- */

/* お客様の声画面幅調整 */
.jc_pagination_sp{
	width: 100%;
}
.jc_pagination_sp .pagination{
	max-width: 100%;
}
.jc_pagination_sp .page-numbers li{
	margin: 0 2px;
}

@media screen and (max-width: 449px){
	.jc_pagination_sp .page-numbers a,
	.jc_pagination_sp .page-numbers span{
		width: 30px;
	}
	.jc_pagination_sp .page-numbers li{
		width: 30px;
	}
}

/* 事務所紹介ページ　事務所沿革　テーブル修正 */
@media screen and (max-width: 550px){
	.jc_office-history-term{
		width: 25%;
	}
}