@charset"UTF-8";

/*
Theme Name: colorpresents
Description: designed by B&C.Design
Author:B&C.Design
Version: 1.0
License: 2025B&C.Design All rights reserve.
*/

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%;
    vertical-align: baseline;
    background: transparent;
}

* {
   -webkit-appearance: none;
	color:#473c38;
}

body{
	font-family: 'Noto Sans JP', sans-serif ,'Noto Sans Mono', monospace;
	font-weight:normal;
	position:relative;
	min-height:100vh;
}

.no-scroll {
  overflow: hidden;
  height: 100%;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

section {
	width:100%;
	margin:0 auto;
	overflow:hidden;
}

ul{
  padding-left:1rem;
}

li{
    color:#000;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none;
}

a {
  text-decoration:none;
	
}


a:hover{
  text-decoration:underline;
}

div{
  font-size:16px;
	line-height:1.5em;
}

#breadcrumb ul{
  padding:20px 30px;
  display:flex;
  justify-content:center
}

#breadcrumb li{
  margin:0 10px 5px 0;
  flex-shrink:0;
  margin-bottom:0;
  list-style:none;
  color:#32373c;
	font-size:12px;
}

#breadcrumb li a{
  color:#eb361c;
}

#breadcrumb li i{
  margin-right:10px;
}

.margin-bottom0{
	margin:0 !important;
}


/* 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;
	background-color:#fff;
  font-size:12px;
}

table td:first-child{
  width:150px;
  min-width:150px;
}

table td{
  min-width:200px;
}


/* 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;
}


body,
html {
    /* important */
    font-size: 16px;
    margin: 0;
    line-height:1.5em;
    background-color:#ffff;
}

* {
    box-sizing: border-box;
}

h1 {
	color:#473c38;
	font-family: ten-mincho, serif;
}

h2 {
	color:#473c38;
	font-family: ten-mincho, serif;
	line-height:1.2em;

}


h3 {
  color:#473c38;
	font-family: ten-mincho, serif;
	line-height:1.2em;
 
}

h4 {
	color:#473c38;
	font-family: ten-mincho, serif;
}

h5 {
	color:#473c38;
	font-family: ten-mincho, serif;
}


body img {
    height:auto;
    display:block;
}

p {
    font-size:1rem;
    color:#473c38;
    font-weight:normal;
    margin: 0;
    margin-bottom:20px;
    line-height:1.7em;
}

strong {
    font-weight: bold;
    font-size: 1em;
}

ul {
    font-size:0;
    margin-bottom:30px;
}

li{
  font-size:1rem;
}

.container {
    width: 100%;
    position:relative;
}

.cf:before,
.cf:after {
    display: table;
    content: "";
}

.cf:after {
    clear: both;
}

#toTop{
  position:fixed;
  bottom:-40px;
  right:3%;
  z-index:8;
  box-shadow:0 3px 5px rgba(0,0,0,.4);
	background-color:#32373c;
	transform:rotate(-45deg);
	height:100px;
}

#toTop i{
  line-height:52px;
  padding-bottom:8px;
  width:60px;
  text-align:center;
  font-size:30px;
  color:#fff;
	transform:rotate(45deg);
	transition:.4s;
}

#toTop a{
	display:block;
}

#toTop a:hover i{
	color:#ffcb3b;
}

.sec_inner{
  padding:0 10%;
}

ol{
  padding-left:20px;
  margin-bottom:20px;
}

ol li ol{
  margin-top:10px;
}

.inner{
	max-width:1500px;
	margin:0 auto;
	padding:0 50px;
}

.mobileonly{
	display:none !important;
}

/* wp */

main{
  position:relative;
  margin:0 auto;
}

.bg_wh{
  background-color:#fff;
}

.container{
  margin:0 auto;
}

/* layout */

.the_content{
	padding-bottom:100px;
}

.wp-block-button__link{
  transition:.2s;
  min-width:250px;
}

.wp-block-button__link:hover{
  opacity:.7;
  text-decoration:none;
}

.wp-block-separator{
  margin:50px auto;
	color:#ccc;
}

/* header */

header{
	top:30px;
}

.header-nav{
	width: 100vw;
	height: 100vh;
	position:fixed;
	background-color:#fff;
	left:0;
	right:0;
	z-index:88;
	display:none;
}

.header-nav_inner{
	max-width:1500px;
	margin:0 auto;
	padding:150px 5%;
	display:flex;
}

.nav_part{
	width:calc(100% / 3);
	padding:20px;
}

.nav_part h3{
	font-size:1.2em;
	line-height:1.2em;
	margin-bottom:10px;
}

.nav_part a{
	transition:.3s;
}

.nav_part a:hover{
	text-decoration:none;
	color:#fabec0;
}

.nav_part:nth-child(2), .nav_part:nth-child(3){
	border-left:1px solid #ccc;
}

.header-nav_inner ul{
	list-style:none;
}

.header-nav_inner ul li ul{
	display:block;
}

.header-nav_inner ul li ul li{
	display:flex;
	align-items:flex-start;
}

.header-nav_inner ul li ul li:before{
	content:"-";
	margin-right:8px;
}

.menu-open{
	transition:.3s;
    display:block;
    background-color:#61c6de;
    height:60px;
    width:60px;
	position:relative;
	border-radius:6px;
	margin-right:20px;
  }

.menu-open:hover{
	opacity:.7;
	cursor:pointer;
}

  .menu-open .t,.menu-open .m,.menu-open .b{
    display:block;
    height:2px;
    width:34px;
    background-color:#fff;
    position:absolute;
    left:12.5px;
    transition:.2s;
    
  }

  .menu-open .t{
    top:20px;
  }

  .menu-open .m{
    top:29px;
    
  }

  .menu-open .b{
    bottom:20px;
    
  }

.menu-open.open{
	background-color:#000;
}


  .menu-open.open .t{
    transform:rotate(45deg);
    top:28px;
	  background-color:#fff;
  }

  .menu-open.open .m{
    left:20px;
    opacity:0;
	   background-color:#fff;
  }

  .menu-open.open .b{
    transform:rotate(-45deg);
    bottom:28px;
	   background-color:#fff;
  }

header{
  margin:auto;
	background-color:#fff;
	position:fixed;
	z-index:99;
	background-color:#fff;
	border-radius:10px;
	box-shadow:0 0 10px rgba(0,0,0,.4);
	left:5%;
}

.header-inner{
	max-width:1500px;
  display:flex;
  align-items:center;
	margin:0 auto;
	padding:10px 20px;
}

.header-brand{
  display:block;
  width:150px;
	flex-shrink:0;
}

.header-brand:hover{
	opacity:.7;
	text-decoration:none;
}

.header-brand img{
  display:block;
  width:100%;
  height:100%;
}

.header-brand span{
	font-size:10px;
	color:#000;
	line-height:1em;
}


.fixed_contact{
	position:fixed;
	right:5%;
	z-index:999;
	top:30px;
	display:flex;
	align-items:center;
	border-radius:10px;
	box-shadow:0 0 10px rgba(0,0,0,.4);
	overflow:hidden;
	background-color:#fff;
	height:80px;
}

.fixed_contact p{
	margin:0;
}

.fixed_contact_mail{
	background-color:#61c6de;
}

.fixed_contact_tel p{
	display:block;
	font-size:24px;
	padding:10px 13px 0;
	font-family: ten-mincho, serif;
}

.fixed_contact_tel p a{
	color:#000;
}

.fixed_contact_tel p i{
	color:#61c6de;
	margin-right:8px;
}


.fixed_contact_tel p span{
	display:block;
	font-size:12px;
	line-height:1em;
}

.fixed_contact_mail p a{
	color:#fff;
	padding:10px;
	display:block;
	text-align:center;
	height:80px;
	font-family: ten-mincho, serif;
	line-height:1em;
	display:flex;
	align-items:center;
	flex-wrap:wrap;
	justify-content:center;
}

.fixed_contact_mail p a span{
		display:block;
	width:100%;
}

.fixed_contact_mail p a i{
	text-align:center;
	font-size:23px;
	color:#fff;
}

.fixed_contact a{
	transition:.3s;
}

.fixed_contact a:hover{
	text-decoration:none;
}

.fixed_contact_mail p a:hover{
	background-color:#fabec0;
}

.fixed_contact_tel p a:hover{
	color:#fabec0;
}

/* footer */

footer img{
	width:100%;
}

.footer_brand{
	display:block;
	width:200px;
	margin:0 auto 0px;
}

.foonter_qiock_contact{
	margin-bottom:100px;
}

.foonter_qiock_contact ul{
	display:flex;
	justify-content:center;
	flex-wrap:wrap;
	padding:0;
	margin-bottom:10px;
}

.foonter_qiock_contact p{
	text-align:center;
}

.foonter_qiock_contact ul li:nth-child(2){
	width:100%;
}

.foonter_qiock_contact ul li.pconly{
	margin-bottom:0px;
	line-height:1em;
	height:50px;
}

.foonter_qiock_contact ul li.pconly i{
	background-color:inherit;
	color:#61c6de;
	margin-right:10px;
	width:auto;
	font-size:24px;
}

.foonter_qiock_contact ul li{
	display:flex;
	justify-content:center;
	align-items:center;
	margin:0 10px;
}

.foonter_qiock_contact ul li a{
	font-size:24px;
	font-family: ten-mincho, serif;
	color:#473d38;
	line-height:1em;
}

.foonter_qiock_contact ul li a:hover{
	text-decoration:none;
}

.foonter_qiock_contact ul li i{
	display:flex;
	width:60px;
	height:60px;
	font-size:30px;
	color:#fff;
	background-color:#473c38;
	justify-content:center;
	align-items:center;
	border-radius:100px;
}

footer hr{
	margin-bottom:80px;
}

.footer_info{
	display:flex;
	align-items:flex-start;
	margin-top:50px;
}

.footer_bnr{
	display:flex;
	flex-wrap:wrap;
	width:465px;
	flex-shrink:0;
	padding-right:50px;
}

.footer_bnr a{
	width:200px;
	display:block;
	height:auto;
	margin-bottom:10px;
	border:1px solid #ccc;
}

.footer_bnr a:nth-child(odd){
	margin-right:15px;
}

.footer_info{
	border-top:1px solid #ccc;
	padding:50px 0;
}

.footer_info ul{
	display:flex;
	flex-wrap:wrap;
	padding:0;
	margin:0 0 30px;
}

.footer_info ul li{
	display:flex;
}

.footer_info ul li a{
	transition:.3s;
	text-decoration:none;
}

.footer_info ul li a:hover{
	color:#61c6de;
}

.footer_info ul li:after{
	content:"/";
	margin:0 10px;
}

.footer_info h4{
	font-size:20px;
	font-weight:bold;
	color:#473d38;
	margin-bottom:10px;
}

.copyright{
	background-color:rgb(71 61 56);
}

.copyright .inner{
	max-width:1440px;
	margin:0 auto;
	padding:0 50px;
	display:flex;
	color:#fff;
	justify-content:center;
}

.copyright .inner p{
	color:#fff;
	font-size:13px;
	margin-right:20px;
}

.copyright .inner a{
	color:#fff;
}

.copyright .inner a i{
	color:#fff;
}

#footer_contact{
	padding:50px 0;
}

.footer-content{
	border:1px solid #fff;
	padding:2em;
}

.footer-content h2{
	color:#fff;
	font-size:1.8em;
	border-bottom:1px solid #fff;
	padding:0 0 10px;
	text-align:center;
}

.footer-content p{
	color:#fff;
	margin-bottom:0;
	text-align:center;
}

.footer-content p a{
	border:2px solid #fff;
	display:block;
	max-width:350px;
	text-align:center;
	margin:30px auto 0;
	background-color:#fff;
	color:#61c6de;
	font-size:1.1em;
	padding:10px;
	font-weight:bold;
	transition:.3s;
}

.footer-content p a:hover{
	text-decoration:none;
	background-color:inherit;
	color:#fff;
}


/* contact form */

.wpcf7{
  margin:0 auto 50px;
  background-color:#fff;
  padding:30px;
}

.wpcf7 table{
	width:100%;
	max-width:800px;
	margin:0 auto 20px;
	border:none !important;
}

.privacy-check br{
	display:none;
}

.privacy-check{
	background-color:#f7f7f7;
	padding:10px;
	display:flex;
	justify-content:center;
}

.privacy-check a{
	color:#ff989b;
}

.wpcf7 th{
	border:none !important;
	padding:10px;
	text-align:left;
	width:180px;
	max-width:180px;
	border-bottom:1px solid #61c6de !important;
}

.wpcf7 td{
	border:none !important;
	padding:10px;
	vertical-align:top;
	border-bottom:1px solid #ccc  !important;
}

.wpcf7 select {
  appearance: none; /* iOS/Safari対策 */
  -webkit-appearance: none;
  -moz-appearance: none;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  padding: 10px;
  font-size: 16px;
  color: #333;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg viewBox='0 0 140 140' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20,50 70,100 120,50' stroke='%23666' stroke-width='20' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 12px;
}

.wpcf7 select:focus {
  outline: none;
  border-color: #666;
  box-shadow: 0 0 0 2px rgba(100, 100, 100, 0.2);
}

.wpcf7 td p{
	margin:0 !important;
}

.wpcf7 th p{
	margin:0;
}

.order-item{
	margin-bottom:10px;
}

.order-item p{
	display:flex;
	border-bottom:1px solid #ccc;
	justify-content:space-between;
	padding-bottom:10px;
}

.order-item p input{
	width:60px !important;
	flex-shrink:0;
}

.wpcf7 td input{
  width:100%;
  display:block;
  font-size:1rem;
  padding:.5em;
	border:none;
	background-color:#d6f0f6;
	border-radius:6px;
	margin-left:auto;
}

.wpcf7 td textarea{
  width:100%;
  display:block;
  font-size:1rem;
  padding:.5em;
	border:none;
	background-color:#d6f0f6;
	border-radius:6px;
	margin-left:auto;
}

.wpcf7 th span{
  font-size:10px;
  padding:2px 5px;
  line-height:13px;
  display:block;
  color:#fff;
  border-radius:5px;
  margin-right:8px;
	width:35px;
}

.wpcf7 th span.small{
  font-size:12px;
  padding:0;
  line-height:1.3em;
  display:block;
  color:#473c38;
  border-radius:5px;
  margin-right:8px;
	width:100%;
	background-color:#f7f7f7;
	padding:10px;
}

.wpcf7 th span{
  background-color:#cf2e2e;
}

.wpcf7 th span.opt{
  background-color:#007cba;
}

input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}

input[type="submit"],
input[type="button"] {
  background-color:#2ea816;
  padding:.5em 2em;
  font-size:18px;
  color:#fff;
  border:2px solid #3cb371;
  border-radius:5px;
  display:block;
  width:100%;
	max-width:500px;
	margin:0 auto;
	font-size:24px;
}

input[type="submit"]:hover,
input[type="button"] :hover{
opacity:.7;
}

.wpcf7-not-valid-tip{
  background-color:#cf2e2e;
  font-size:13px;
  color:#fff;
  padding:0 10px;
  box-shadow:0 2px 5px inset rgba(0,0,0,.4);
}

span.ajax-loader{
  display:block !important;
  width:20px;
  text-align:center !important;
  margin:10px auto !important;
}

.wpcf7-response-output{
  background-color:#324453;
  color:#fff;
  text-shadow:0 0 3px #000;
  text-align:center;
}

.privacy{
	background-color:#f7f7f7;
	padding:2%;
	height:130px;
	overflow:scroll;
	max-width:800px;
	margin:0 auto;
	border:1px solid #ccc;
}

.privacy_text p{
	font-size:13px;
	line-height:1.5em;
}

.privacy_text h4{
	margin-bottom:10px;
}

.agree_box p{
	margin:10px auto 20px;
	padding:2%;
	background-color:#f7f7f7;
	max-width:800px;
	border:1px solid #ccc;
	
}

.wpcf7-form-control-wrap {
  display: block;
}
.wpcf7-form-control.wpcf7-checkbox {
  display: flex;
  flex-wrap: wrap;
}
span.wpcf7-list-item {
  position: relative;
	width:100%;
	margin-left:0;
}
.wpcf7-list-item-label {
	color: #473c38;
  cursor: pointer;
  font-size: 16px;
}
input[type="checkbox"] {
  position: absolute;
  opacity: 0;
}
.wpcf7-list-item-label:before {
	content: '';
  border: 2px solid #473c38;
	background-color:#fff;
  display: inline-block;
  width: 20px;
  height: 20px;
  position: relative;
  top: -3px;
  margin-right: 8px;
  vertical-align: middle;
  cursor: pointer;
  text-align: center;
}
input[type="checkbox"]:checked + .wpcf7-list-item-label:after {
	content: "\f00c";
	font-family:forkawesome;
  display: block;
  position: absolute;
	font-size:22px;
	line-height:20px;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  background-size: contain;
	color:#00aa63;
	
}

#total-price{
	background-color:inherit !important;
	font-size:20px;
}

.accept{
	display:flex;
	justify-content:center;
	align-items:center;
	padding:20px;
	margin-top:5px;
	background-color:#ececec;
	margin-bottom:10px;
}

.accept span{
	margin:0 !important;
}

.accept p{
	margin-bottom:0;
	font-family: "ten-mincho", serif;
}

/* Front */

#hero_container{
	height:100vh;
	max-height:800px;
	margin-bottom:80px;
}

#hero_container .inner{
	display:flex;
	padding:0;
}

.main_text{
	width:40%;
	display:flex;
	align-items:center;
	padding-left:5%;
}

.hero_image{
	width:60%;
	height:100%;
}

.hero_slide{
	height:100vh;
	max-height:800px;
	margin:0;
	padding:0;
	border-radius:200px 0 200px 0;
	overflow:hidden;
}

.hero_image li{
	height:100vh;
	max-height:800px;
	background-position:center;
	background-size:cover;
} 

p.main_catch{
	font-size:50px;
	font-family: ten-mincho, serif;
}

#service{
	margin-bottom:80px;
}

#service .inner ul{
	display:flex;
	justify-content:space-between;
	flex-wrap:wrap;
	padding:0;
	margin:0;
}

#service .inner ul li{
	display:block;
	border-radius:15px;
	background-position:center;
	background-size:cover;
	min-height:230px;
}

#service .inner ul li a{
	display:block;
	padding:30px;
	position:relative;
	height:100%;
}

#service .inner ul li a .service_more{
	position:absolute;
	right:30px;
	bottom:30px;
	background-color:#61c6de;
	border:1px solid #61c6de;
	color:#fff;
	padding:5px 10px;
	transition:.3s;
	
}

#service .inner ul li a:hover{
	text-decoration:none;
}

#service .inner ul li a:hover h2,#service .inner ul li a:hover h3{
	color:#9bd4e4;
	text-shadow:0 0 5px rgba(0,0,0,.5);
}

#service .inner ul li a:hover h2{
	border-color:#fabec0;
}

#service .inner ul li a:hover .service_more{
	background-color:inherit;
	color:#9bd4e4;
}

#service .inner ul li a p{
	color:#fff;
	text-shadow:0 0 5px rgba(0,0,5px,.5);
	margin:0;
	transition:.3s;
}

#service .inner ul li h2{
	padding-bottom:5px;
	margin-bottom:5px;
	border-bottom:2px solid #9bd4e4;
	text-shadow:0 0 10px rgba(0,0,0,.4);
}

#service .inner ul li h2, #service .inner ul li h3{
	text-shadow:0 0 5px rgba(0,0,5px,.5);
	color:#fff;
	transition:.3s;
	text-shadow:0 0 10px rgba(0,0,0,.4);
}

#service .inner ul li h3{
	text-align:center;
}

#service .inner ul li h2, #service .inner ul li h3{
	color:#fff;
	font-size:2em;
}

#service .inner ul li.w50{
	width:calc(50% - 10px);
	margin-bottom:20px;
}

#service .inner ul li.w50 p{
	font-size:1.2em;
	text-shadow:0 0 10px rgba(0,0,0,.4);
}

#service .inner ul li.w50 a{
	padding-bottom:60px;
}

#service .inner ul li.w30{
	width:calc(100% / 4 - 20px);
	min-height:100px;
}

#service .inner ul li.w30 a{
	display:flex;
	justify-content:center;
	align-items:center;
}

#service .inner ul li.w30 a h3{
	font-size:1.5rem;
}

#about{
	background-color:#fffced;
	margin-bottom:100px;
}

#about .inner{
	display:flex;
}

.about_bg{
	width:100%;
	background-position:center;
	background-size:cover;
}

.about_txt{
	width:60%;
	flex-shrink:0;
	padding:80px 0 80px 80px;
}

.about_txt a{
	display:block;
	background-color:#fff;
	width:150px;
	text-align:center;
	padding:10px 20px;
	overflow:hidden;
	position:relative;
	transition:.3s;
	
}

.about_txt a:before{
	transition:.3s;
	content:'';
	position:absolute;
	width:100%;
	height:100%;
	background-color:#fabec0;
	right:-110px;
	top:0;
	transform:rotate(45deg);
}

.about_txt a:hover{
	text-decoration:none;
	background-color:#fabec0;
	color:#fff;
}

#news .inner{
	padding-right:0;
	position:relative;
}

#news .inner:after{
	content:"";
	background-color:#f7f7f7;
	width:50%;
	height:100%;
	position:absolute;
	right:-20%;
	top:0;
	border-radius:100px;
}

.post_slide{
	z-index:2;
	position:relative;
}

.news_thumb{
	aspect-ratio:16/9;
	background-size:cover;
	background-position:center;
}

.post_slide li a time{
	padding:10px 20px;
	display:block;
	font-size:14px;
}

.post_slide li a h3{
	padding:0 20px 10px;
	font-weight:bold;
	font-size:18px;
	font-family: 'Noto Sans JP', sans-serif ,'Noto Sans Mono', monospace;
}

.post_slide li a p{
	padding:0 20px 20px;
	font-size:14px;
	margin:0;
}

.post_slide li{
	padding:20px 0 20px 40px;
}

.post_slide li a{
	transition:.3s;
	background-color:#fff;
	display:block;
	box-shadow:0 0 0px rgba(0,0,0,.4);
}

.post_slide li a:hover{
	text-decoration:none;
	box-shadow:0 0 20px rgba(0,0,0,.4);
	color:#61c6de;
}

.post_slide li a h3, .post_slide li a p{
	transition:.3s;
}

.post_slide li a:hover h3, .post_slide li a:hover p{
	color:#61c6de;
}

button.slick-next{
	display:block;
  right: 0px;
  z-index: 10;
  background-size: contain;
  width: 120px;
  height: 120px;
  border: none;
  outline: none;
	background-color:#473d38 !important;
	border-radius:100px;
}

button.slick-next:before{
	content:"\f105";
	line-height:1em;
	font-size:100px;
	font-family:forkawesome;
}

button.slick-next:hover{
	opacity:.7;
	background-color:#473d38;
}

h2.contents_h{
	font-size:2.5em;
	margin-bottom:30px;
	line-height:1em;
}

h2.contents_h span{
	display:inline-block;
	background-color:#61c6de;
	color:#fff;
	padding:5px 10px;
	font-size:1rem;
	line-height:1em;
}

h2.contents_h:first-letter{
	font-size:1.5em;
	color:#61c6de;
}

a.link_btn_txt{
	transition:.3s;
}

a.link_btn_txt i{
	color:#fabec0;
	margin-left:10px;
}

a.link_btn_txt:hover{
	text-decoration:none;
	color:#61c6de;
}

#news{
	margin-bottom:100px;
}

#sns p{
	text-align:center;
}

#sns h2.contents_h{
	text-align:center;
}

#sns{
	margin-bottom:100px;
}

#sns img{
	width:100%;
}

#achievements{
	background-color:#f7f7f7;
	padding:80px 0;
	margin-bottom:100px;
}

#achievements h2.contents_h{
	text-align:center;
}

#achievements h3{
	font-size:24px;
	margin-bottom:10px;
}

#achievements .bg_wh{
	max-width:1100px;
	margin:0 auto;
	padding:50px;
	position:relative;
	border-radius:30px;
}

#achievements a{
	position:absolute;
	bottom:0;
	display:block;
	background-color:#61c6de;
	color:#fff;
	padding:10px 20px;
	margin:0 auto;
	left:0;
	right:0;
	width:200px;
	text-align:center;
	text-decoration:none;
	transition:.3s;
}

#achievements a:hover{
	background-color:#fabec0;
}

#achievements .bg_wh ul{
	display:flex;
	flex-wrap:wrap;
	padding:0;
}

#achievements .bg_wh ul li{
	display:block;
	color:#473c38;
}

#achievements .bg_wh ul li:after{
	content:'/';
	margin:0 10px;
	color:#ccc;
}

#sns ul li{
	display:block;
	margin:0 20px;
	width:calc(100% / 4 - 40px);
}

#sns ul{
	display:flex;
	max-width:800px;
	margin:0 auto;
	padding:0;
	justify-content:center;
	align-items:center;
}

.trainings_card .news_thumb{
	margin-bottom:10px;
	aspect-ratio:4 / 3;
}

.post_slide li.trainings_card a h3{
	padding:0 20px 20px;
}

#recommend .inner{
	padding-right:0;
	position:relative;
	padding-top:50px;
	padding-bottom:50px;
}

#recommend .inner:after{
	content:"";
	background-color:#ebfbff;
	width:70%;
	height:100%;
	position:absolute;
	left:-20%;
	top:0;
	border-radius:100px;
}

#recommend .inner h2.contents_h{
	position:relative;
	z-index:1;
}

#recommend .inner .link_btn_txt{
	position:relative;
	z-index:1;
}

/* page single */

.page-header{
	padding-top:200px;
	background-position:right bottom;
	background-size:cover;
	padding-bottom:100px;
	border-radius:0 0 30px 30px;
}

.page-header h2{
	font-size:3em;
	text-align:center;
	line-height:1.2em;
	max-width:1000px;
	margin:0 auto;
}

.logged_in_ttl{
	font-size:2em;
	margin-bottom:20px;
}

.download a{
	display:block;
	background-color:#61c6de;
	color:#fff !important;
	padding:10px;
	border-radius:10px;
	width:300px;
	text-align:center;
	transition:.3s;
}

.download a:hover{
	opacity:.7;
	text-decoration:none;
}

#loginform label{
	display:block;
}

#loginform{
	border:1px solid #ccc;
	padding:30px;
	border-radius:30px;
	width:400px;
	margin:0 auto;
}

#loginform input{
	display:block;
	width:100%;
	font-size:20px;
	padding:10px;
	border:none;
	background-color:#f4f4ec;
	margin:0;
}

#loginform #wp-submit{
	background-color:#007cba;
}

p.login-remember{
	display:none;
}

.width_single{
	max-width:1000px;
	margin:0 auto;
}

.user_form_toggle h2{
	font-size:24px !important;
	padding:10px !important;
	border-bottom:1px solid #ccc !important;
	margin-bottom:20px !important;
	border-top:none !important;
	margin-top:0 !important;
}

.user_form_toggle h2:hover{
	cursor:pointer !important;
}

.user_form_toggle h2 i{
	transition:.3s !important;
	color:rgb(255,105,0) !important;
	margin-left:10px !important;
}

.user_form_toggle h2.formopen i{
	transform:rotate(180deg) !important;
	color:#808080 !important;
}

.user_form{
	display:none;
}

.loginuser_action{
	margin-bottom:80px;
}

.post_archive_list{
	padding:0;
	margin:0;
}

.post_archive_list li{
	display:block;
	border-bottom:1px solid #ccc;
	margin-bottom:30px;
}

.post_archive_list li a:hover{
	text-decoration:none;
}

.post_archive_list li a:hover h3{
	text-decoration:none;
	color:#61c6de;
}

.post_archive_list li a:hover p{
	text-decoration:none;
	color:#61c6de;
}

.post_archive_list li time{
	display:block;
	font-size:13px;
	margin-botttom:5px;
}

.post_archive_list li a h3{
	font-size:20px;
	margin-bottom:5px;
	transition:.3s;
}

.post_archive_list li a p{
	transition:.3s;
}

.pager{
	display:flex;
	justify-content:center;
	max-width:1000px;
	margin:0 auto;
	border-top:1px solid #ccc;
	margin-top:80px;
	padding-top:30px;
}

.the_content .pager a{
	display:flex;
	align-items:center;
	text-decoration:none;
	transition:.3s;
	color:#473d38;
}

.pager a i{
	transition:.3s;
}

.pager a:hover{
	color:#61c6de;
}

.pager a:hover i{
	color:#61c6de;
}

.next a i{
	margin-right:20px;
	flex-shrink:0;
	font-size:1.5em;
}

.prev a i{
	margin-left:20px;
	flex-shrink:0;
	font-size:1.5em;
}

.pager .next, .pager .prev{
	width:calc(50% - 1px);
}

.v-bar{
	height:auto;
	width:2px;
	background-color:#ccc;
	margin:0 20px;
}

.flex_trainings .wp-block-column{
	border:1px solid #ccc;
	border-radius:10px;
	overflow:hidden;
	padding-bottom:60px;
	position:relative;
}

.width_single .wp-block-columns.flex_trainings{
	margin-bottom:20px;
	align-items:stretch !important;
}

.flex_trainings p{
	padding:10px;
	margin:0 !important;
}

.flex_trainings p:last-child{
	padding:0;
}

.flex_trainings a{
	display:block;
	text-align:center;
	background-color:#61c6de;
	color:#fff !important;
	padding:10px;
	border-radius:10px;
	position:absolute;
	bottom:10px;
	width:calc(100% - 20px);
	left:10px;
}

.flex_trainings .wp-block-image{
	margin:0;
}

/* single_content */

.single_content {
  font-size: 16px;
  color: #333;
  line-height: 1.8;
}

/* リンク装飾 */
.single_content a {
  transition: 0.3s;
  color: #ff8d90;
  text-decoration: none;
}
.single_content a:hover {
  opacity: 0.7;
}

/* 最初の見出しと段落には上マージンをつけない */
.single_content > *:first-child{
  margin-top: 0;
}

/* 見出し */
.single_content h1, .single_content h2, .single_content h3,
.single_content h4, .single_content h5, .single_content h6 {
  font-weight: bold;
  line-height: 1.4;
  margin-top: 2em;
  margin-bottom: 1em;
}
.single_content h1 { font-size: 2em; }
.single_content h2 
{ font-size: 1.75em;
 border-top:3px solid #61c6de;
 border-bottom:2px solid #61c6de;
 padding:30px 0;
}
.single_content h3 {
  font-size: 1.5em;
  background-color: #f7f7f7;
  padding: 20px;
  border-left: 3px solid #61c6de;
}
.single_content h4 {
	font-size: 1.25em;
	border-bottom:1px solid #61c6de;
	padding-bottom:30px;
}
.single_content h5 { font-size: 1.1em;
					display:flex;
					align-items:center;
				   }
.single_content h5:before{
	content:"";
	width:.5em;
	height:1em;
	border:5px solid #61c6de;
	margin-right:10px;
	flex-shrink:0;
	transform:rotate(10deg);
}
.single_content h6 { font-size: 1em; }

.wp-block-separator{
	width:80% !important;
	margin:5em auto;
}

/* 段落・リスト */
.single_content p {
  margin-top: 1.5em;
  margin-bottom: 1.5em;
  line-height: 1.7em;
}
.single_content ul,
.single_content ol {
  margin: 0 0 1.5em 1.5em;
}
.single_content li {
  margin-bottom: 0.5em;
}

/* Gutenberg ブロック余白調整 */
.single_content .wp-block {
  margin-top: 1.5em;
  margin-bottom: 1.5em;
}

/* 引用ブロック */
.single_content blockquote {
  margin: 2em 0;
  padding: 1em 1.5em;
  background: #f9f9f9;
  border-left: 5px solid #ccc;
  color: #555;
  font-style: italic;
}

/* テーブル */
.single_content table {
  width: 100%;
  border-collapse: collapse;
  margin: 2em 0;
}
.single_content table th,
.single_content table td {
  border: 1px solid #ccc;
  padding: 0.75em;
	width:auto;
}

/* Gutenberg ボタン */
.single_content .wp-block-button__link {
  background: #0073aa;
  color: #fff;
  padding: 0.75em 1.5em;
  text-decoration: none;
  border-radius: 3px;
  display: inline-block;
  transition: background 0.3s;
}
.single_content .wp-block-button__link:hover {
  background: #005a87;
}

/* 画像とfigure */
.single_content img,
.single_content figure img {
  max-width: 100%;
  height: auto;
  display: inline-block;
}
.single_content img[style*="width"] {
  width: auto;
}
.single_content figure {
  margin: 2em 0;
  text-align: center;
}
.single_content figcaption {
  font-size: 0.9em;
  color: #777;
  margin-top: 0.5em;
}

/* YouTubeやiframe対応 */
.single_content iframe {
  max-width: 100%;
}

/* 画像配置（旧エディター＆Gutenberg共通） */
.single_content .alignnone {
  display: block;
  margin: 1.5em 0;
}
.single_content .aligncenter,
.single_content figure.aligncenter {
  display: table;
  margin-left: auto;
  margin-right: auto;
  margin-top: 1.5em;
  margin-bottom: 1.5em;
}
.single_content .alignleft,
.single_content figure.alignleft {
  float: left;
  margin: 0 1.5em 1em 0;
}
.single_content .alignright,
.single_content figure.alignright {
  float: right;
  margin: 0 0 1em 1.5em;
}

/* clearfix */
.single_content::after {
  content: "";
  display: block;
  clear: both;
}

.single_content ul,.single_content ol{
	background-color:#fafaec;
	padding:20px 20px 20px 40px;
	margin-left:0;
}

.single_content ol{
	background-color:inherit;
	padding:0;
}

.single_content ol li{
	border-bottom:1px dashed #473d38;
	list-style-position: inside;
	padding-left:1.4em;
	text-indent:-1.4em;
	padding-bottom:10px;
}

.single_content ol li::marker{
	font-weight: bold;
  color: #ff8d90;
  font-family: 'Georgia', serif;
  font-size: 1.2em;
}

.single_content ul li p, .single_content ol li p{
	margin-bottom:0;
}

.single_content table td{
	vertical-align:top
}

.single_content table p{
	font-size:1em;
}

.width_single iframe{
	display:block;
	width:100%;
	max-width:800px;
	height:auto;
	aspect-ratio:16 / 9;
	margin:0 auto;
}

.width_single .wp-block-columns {
  display: flex !important;
  align-items: flex-start !important;
  gap: 2em; /* 任意でカラム間の余白を調整 */
}

.width_single .wp-block-column {
  margin-top: 0 !important;
}

.width_single .wp-block-column img{
display:block;
}

.width_single .wp-block-columns p{
	margin-top:0;
}

.flex_nowrap{
	flex-wrap:nowrap !important;
}
.flex_nowrap .wp-block-image{
	margin-bottom:20px;
}

.wp-block-image{
	margin-top:0 !important;
}

.width_single table{
	font-size:1em;
}

table.has-fixed-layout{
	margin:0;
}

ul.check_list{
	background-color:inherit;
	border:3px solid #fabec0;
	padding:20px;
	border-radius:20px;
}

ul.check_list li{
	display:flex;
	border-bottom:1px dashed #ccc;
	padding-bottom:5px;
}

ul.check_list li:before{
	content:"\f00c";
	font-family:forkawesome;
	margin-right:8px;
	color:#ffb764;
}

.advance_free ul{
	background-color:inherit;
	display:flex;
	padding:0;
	flex-wrap:wrap;
	justify-content:center;
}

.advance_free ul li{
	display:block;
	padding:0;
	width:calc(100% / 7);
}

.advance_free ul li:hover{
	transition:.3s;
	opacity:.7;
	cursor:pointer;
}

/* 表示中にbodyスクロールを禁止 */
.no-scroll {
  overflow: hidden;
  height: 100%;
}

/* 各color_result要素をポップアップ風に */
.color_result {
  display: none;
  position: fixed;
  top: 100px;
	bottom:0;
	right:0;
  left: 0;
  z-index: 10;
	margin:auto;
  width: 80%;
	max-width:1440px;
	padding:100px 50px;
	height:80vh;
  overflow-y: auto;
	background-color:#fff;
  padding: 2rem;
  box-sizing: border-box;
	box-shadow:0 0 10px rgba(0,0,0,.4);
	border-radius:30px;
	/* スクロールバーを非表示にする */
  scrollbar-width: none;        /* Firefox */
  -ms-overflow-style: none;     /* IE/Edge */
}
.color_result::-webkit-scrollbar {
  display: none;                /* Chrome, Safari */
}

.color_result h3{
	margin-top:0;
	background-color:inherit;
	border:none;
	padding:0;
}
.close_pop i {
  font-size: 32px;
  color: #333;
  transition: 0.2s;
}
.close_pop:hover i {
  color: #888;
  transform: scale(1.1);
}

.close_pop {
  position: absolute;
  top: 20px;
  right: 20px;
  cursor: pointer;
  z-index: 20;
}

.color_result p a{
	color:#fff;
	text-align:center;
	display:block;
	background-color:#61c6de;
	border-radius:10px;
	padding:10px;
	font-weight:bold;
}

.color_result p a:hover{
	opacity:.7;
}

.color_result h3 span{
	font-size:1.5em;
}

#c1 h3 span {
  color: #e60033;
}

/* オレンジ */
#c2 h3 span {
  color: #f39800;
}

/* 黄色 */
#c3 h3 span {
  color: #fff100;
}

/* 緑 */
#c4 h3 span {
  color: #00a859;
}

/* 青 */
#c5 h3 span {
  color: #0068b7;
}

/* インディゴ（藍色） */
#c6 h3 span {
  color: #274a78;
}

/* バイオレット */
#c7 h3 span {
  color: #884898;
}

/* ピンク */
#c8 h3 span {
  color: #e95295;
}

/* 白（見えなくならないよう薄グレー） */
#c9 h3 span {
  color: #fff;
  text-shadow: 0 0 2px #000;
}

/* 黒 */
#c10 h3 span {
  color: #000000;
}

/* コーラル */
#c11 h3 span {
  color: #f86b6b;
}

/* 黄緑 */
#c12 h3 span {
  color: #aacf53;
}

/* ターコイズ */
#c13 h3 span {
  color: #00c1c1;
}

/* マゼンタ */
#c14 h3 span {
  color: #e4007f;
}

/* 茶色 */
#c15 h3 span {
  color: #8b572a;
}

/* シルバー（グレー） */
#c16 h3 span {
  color: #999999;
}

/* ゴールド */
#c17 h3 span {
  color: #d4af37;
}

/* 赤 */
#c1 a {
  background-color: #e60033;
  color: #fff;
}

/* オレンジ */
#c2 a {
  background-color: #f39800;
  color: #fff;
}

/* 黄色 */
#c3 a {
  background-color: #fff100;
  color: #000;
}

/* 緑 */
#c4 a {
  background-color: #00a859;
  color: #fff;
}

/* 青 */
#c5 a {
  background-color: #0068b7;
  color: #fff;
}

/* インディゴ（藍色） */
#c6 a {
  background-color: #274a78;
  color: #fff;
}

/* バイオレット */
#c7 a {
  background-color: #884898;
  color: #fff;
}

/* ピンク */
#c8 a {
  background-color: #e95295;
  color: #fff;
}

/* 白 */
#c9 a {
  background-color: #fff;
  color: #000;
  border: 1px solid #ddd; /* 白背景で見えなくならないよう枠線を追加推奨 */
}

/* 黒 */
#c10 a {
  background-color: #000000;
  color: #fff;
}

/* コーラル */
#c11 a {
  background-color: #f86b6b;
  color: #fff;
}

/* 黄緑 */
#c12 a {
  background-color: #aacf53;
  color: #fff;
}

/* ターコイズ */
#c13 a {
  background-color: #00c1c1;
  color: #fff;
}

/* マゼンタ */
#c14 a {
  background-color: #e4007f;
  color: #fff;
}

/* 茶色 */
#c15 a {
  background-color: #8b572a;
  color: #fff;
}

/* シルバー（グレー） */
#c16 a {
  background-color: #999999;
  color: #fff;
}

/* ゴールド */
#c17 a {
  background-color: #d4af37;
  color: #fff;
}

#s {
	display:block;
	width:100%;
	padding:10px;
	border-radius:10px;
	border:none;
	background-color:#daf7ff;
	margin-bottom:20px;
	font-size:20px;
	
}

.sitemap-col ul{
	background-color:inherit !important;
}


/* training */

div{
	line-height:1.8em;
}

.training_catch{
	font-size:1.75rem;
	font-family: ten-mincho, serif;
	background-color:#fffced;
	padding:30px;
	border-radius:20px;
	margin-bottom:1em;
}

.training_under:after{
	content:"";
	clear:both;
	display:block;
}

.training_under{
	margin-bottom:1.75em;
}

.training_img{
	float:left;
	width:40%;
	aspect-ratio:4 / 3;
	margin-right:20px;
	background-position:center;
	background-size:cover;
}

.training_under_catch{
	padding-bottom:1.75em;
}

.training_nayami{
	margin-bottom:1.75em;
}

.training_nayami ul{
	background-color:#f7f7f7;
	padding:30px;
	border-radius:20px;
}

.training_nayami ul li{
	display:flex;
	border-bottom:dashed #ccc;
	padding-bottom:5px;
}

.training_nayami ul li:before{
	content:"\f00c";
	font-family:forkawesome;
	margin-right:5px;
	color:#bb0909;
	font-size:1.5em;
}

.training_seika{
	margin-bottom:1.75em;
}

.training_seika ul{
	background-color:#f7f7f7;
	padding:30px;
	border-radius:20px;
	position:relative;
}

.training_seika h2{
	position:relative;
	text-align:center;
	background-color:#61c6de;
	color:#fff;
	border-radius:20px;
}

.training_seika h2:before{
	content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 50px 10vw 0 10vw;
  border-color: #61c6de transparent transparent transparent;
  position: absolute;
  bottom:-40px;
	z-index:2;
  left: 0;
  right: 0;
	margin:auto;
}

.training_seika ul li{
	display:flex;
	border-bottom:dashed #ccc;
	padding-bottom:5px;
}

.training_seika ul li:before{
	content:"\f0eb";
	font-family:forkawesome;
	margin-right:5px;
	color:rgb(255 163 99);
	font-size:1.5em;
}

/* archive */

.archive_contents ul.archive_post_list{
	padding:0;
	margin:0;
}

.archive_contents ul.archive_post_list li{
	display:block;
	border-bottom:1px solid #ccc;
	margin-bottom:30px;
	padding-bottom:20px;
}

.archive_contents ul.archive_post_list li a{
	display:flex;
	text-decoration:none;
}

.archive_contents ul.archive_post_list li a h4{
	font-size:20px;
	margin-bottom:5px;
	transition:.3s;
}

.archive_contents ul.archive_post_list li a p{
	transition:.3s;
	margin:0;
}

.archive_contents ul.archive_post_list li a time{
	display:block;
	margin-bottom:5px;
}

.archive_contents ul.archive_post_list li a .post_categories{
	padding:0;
	margin:0 0 5px 0;
	display:flex;
}

.archive_contents ul.archive_post_list li a .post_categories li{
	padding:0;
	margin:0;
	display:flex;
	border:none;
	margin-right:5px;
	font-size:12px;
	line-height:1em;
	background-color:#8d8d8d;
	padding:5px 10px;
	border-radius:5px;
	color:#fff;
	transition:.3s;
}

.archive_contents ul.archive_post_list li a:hover h4{
	color:#61c6de;
}

.archive_contents ul.archive_post_list li a:hover p{
	color:#61c6de;
}

.archive_contents ul.archive_post_list li a:hover .post_categories li{
	background-color:#fabec0;
}

.archive_thumb{
	width:200px;
	background-size:cover;
	background-position:center;
	flex-shrink:0;
	margin-right:20px;
	min-height:180px;
}

/* pagination*/

.pagination {
    list-style-type: none;
    padding-left: 0;
    margin: 30px 0;
}

ul.pagination{
  margin:0;
}

.pagination,
.pagination li a {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    font-size:16px;
    font-weight:800;
	border-radius:5px;
}

.pagination a {
    transition: .2s;
    padding-top: 1px;
    min-width: 36px;
    min-height: 36px;
    line-height:36px;
}

.pagination li a:hover{
  text-decoration:none;
  opacity:.7;
	color:#61c6de;
}

.pagination li:not([class*="current"]) a:hover {
    
}

.pagination li:first-of-type a {
    border-left-width: 1px;
}

.pagination li.first span,
.pagination li.last span,
.pagination li.previous span,
.pagination li.next span {
    /* screen readers only */
    position: absolute;
    top: -9999px;
    left: -9999px;
}

.pagination li.first a::before,
.pagination li.last a::after,
.pagination li.previous a::before,
.pagination li.next a::after {
    display:block;
    font-family: 'FontAwesome';
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    transform: translate(0, 0);
}

.pagination li.first a::before {
    content: "|<";
}

.pagination li.last a::after {
    content: ">|";
}

.pagination li.previous a::before {
    content: "<";
}

.pagination li.next a::after {
    content: ">";
}

.pagination li.current a {
    font-size:16px;
    cursor: default;
    font-weight: bold;
    color: #fff;
    background-color:#61c6de;
    pointer-events: none;
    font-weight:800;
}

@media only screen and ( max-width: 680px) {
    .pagination li.first,
    .pagination li.last {
        /* screen readers only */
        position: absolute;
        top: -9999px;
        left: -9999px;
    }
    .pagination li.previous a {
        border-left-width: 1px;
    }
}

@media only screen and ( max-width: 500px) {
    .pagination li {
        /* screen readers only */
        position: absolute;
        top: -9999px;
        left: -9999px;
    }
    .pagination li.current,
    .pagination li.first,
    .pagination li.last,
    .pagination li.previous,
    .pagination li.next {
        position: initial;
        top: initial;
        left: initial;
    }
    .pagination li.previous a {
        border-left-width: 0;
    }

}

@media only screen and ( max-width: 400px) {
    .pagination li.first,
    .pagination li.last {
        /* screen readers only */
        position: absolute;
        top: -9999px;
        left: -9999px;
    }
    .pagination li.previous a {
        border-left-width: 1px;
    }
}

@media screen and ( max-width: 785px) {
	
	.wpcf7{
		padding:20px !important;
	}

	.sec_inner{
		padding:0;
	}

#wpadminbar{
  display:none;
}

	header{
		top:0;
		left:0;
		border-radius:0  0 10px 0;
	}

  .mobileonly{
    display:block !important;
  }

	.pconly{
		display:none !important;
	}

  .header-nav{
    position:fixed;
    top:0;
    z-index:9;
    right:0;
    width:100%;
	  
  }

  .header-nav ul{
    display:block;
  }

  body.no-scroll:before{
    content:"";
    position:absolute;
    top:0;
    width:100%;
    height:100vh;
    background-color:rgba(0,0,0,.8);
    z-index:9;
  }
	
	.wpcf7{
		padding:0 !important;
	}

	.wpcf7 tr{
		display:block;
		margin-bottom:20px;
		border:none;
		border-bottom:1px solid #cccc;
	}

	.wpcf7 th, .wpcf7 td{
		display:block;
		border:none !important;
		padding:0 0 10px 0;

	}

	.wpcf7-list-item{
		width:100%;
	}
	
	.wpcf7 table{
		margin-bottom:0;
	}

	.service_img_list{
		display:block;
	}

	.service_img_list_item{
		width:100%;
		margin:0 0 10px;
	}

	.footer_contact_wrap{
		padding:50px 0;
	}

	#home_map{
		aspect-ratio:16 / 9;
	}

	.company_table th{
		width:80px;
		padding:10px;
	}

	.company_table td{
		padding:10px;
	}

	.company_syatyou{
		margin:0 auto;
	}

	p.name{
		text-align:center;
	}

	.inner{
		padding:0 5%;
	}

	.footer_info{
		display:block;
	}

	.footer_bnr{
		width:100%;
	}

	.footer_bnr{
		width:100%;
		padding:0;
	}

	.footer_bnr a{
		width:100%;
		margin:0 0 10px 0;
	}

	.footer_nav{
		margin-top:30px;
	}

	.fixed_contact{
		bottom:0;
		top:auto;
		left:5%;
		right:5%;
	}

	.fixed_contact{
		bottom:0;
		top:auto;
		left:5%;
		right:5%;
	}

	.fixed_contact_mail{
		width:50%;
	}

	.fixed_contact_mail p a{
		font-size:13px ;
	}

	.fixed_contact_mail p a i{
		font-size:24px;
	}

	.fixed_contact_tel i{
		font-size:20px;
		margin-right:5px !important;
	}

	.fixed_contact_tel p a{
		font-size:16px ;
	}

	.fixed_contact_tel{
		width:50%;
	}

	.fixed_contact_tel span{
		font-size:10px !important;
	}

	.page-header{
		padding-top:130px;
		padding-left:5%;
		padding-right:5%;
		padding-bottom:30px;
	}

	.page-header{
		padding-top:130px;
	}

	.page-header h2{
		font-size:2rem;
		text-align:left;
	}

	.header-nav_inner{
		display:block;
		overflow-y: auto;
	}

	.nav_part{
		width:100%;
		padding:0;
		border:none !important;
	}

	.header-nav{
		overflow-y: auto;
	}

	#hero_container .inner{
		display:block;
	}

	.main_text{
		width:100%;
		padding-top:100px;
	}

	p.main_catch{
		font-size:2rem;
	}

	.hero_image{
		width:100%;
		border-radius:50px;
	}

	.hero_slide{
		border-radius:50px 0 50px 0;
		height:100vw;
	}

	.service_menu li.w50{
		width:100% !important;
	}

	.service_menu li.w30{
		width:100% !important;
		margin-bottom:10px;
	}

	#service .inner ul li.w30 a h3{
		font-size:20px !important;
	}

	#service .inner ul li.w30 a h3 br{
		display:none;
	}

	#service{
		margin-bottom:30px;
	}

	.about_bg{
		position:absolute;
		right:0;
		bottom:10px;
		display:block;
		width:50% !important;
		aspect-ratio:1/1;
	}

	.about_txt{
		width:100%;
		padding:30px 0;
		position:relative;
		z-index:1;
	}

	#about .inner{
		position:relative;
		padding-bottom:150px;
	}

	#news .inner{
		padding:0 5%;
	}

	.post_slide li{
		padding:0;
	}

	.post_slide {
		padding:0;
	}

	button.slick-next{
  width: 40px;
  height:100px;
	border-radius:100px 0 0 100px;
}

button.slick-next:before{
	font-size:50px;
}

	ul.sns_list{
		display:block !important;
	}

	ul.sns_list li{
		width:150px !important;
		margin:0 auto 20px !important;
	}

	#sns{
		padding:30px 0;
		margin-bottom:30px;
	}

	#achievements .bg_wh{
		padding:5%;
	}

	.archive_post_list h4{
		font-size:16px !important;
		line-height:1.3em;
	}
	
	.archive_thumb{
		width:100px;
		height:100px;
		min-height:auto;
	}

		#breadcrumb ul{
			display:flex;
			overflow:scroll;
			justify-content:flex-start;
		}

	.training_catch{
		font-size:1.5em;
		padding:20px;
	}

	.training_under{
		display:block;
	}

	.training_img{
		margin:0;
		width:100%;
		float:none;
	}

	.footer-content{
		padding:20px;
	}

	.download a{
		margin:0 auto 30px;
	}

	.footer_bnr a{
		margin-right:0 !important;
	}
}

p span.footer_tel{
	font-size:32px !important;
	line-height:1.5em !important;
	font-weight:bold;
}

p span.footer_tel a{
	color:#fff !important;
}


.grecaptcha-badge { visibility: hidden; }
.recaptcha_policy p{font-size:10px;padding:10px 2%;margin:0;text-align:center;}