@charset "utf-8";
*{
	box-sizing: border-box;	
	font-size: 16px;
}


html {
  /* 1rem = 100pxと定義 */
  font-size: 100px;
}

body {
  /*　基本のフォントサイズは.16rem */
  font-size: 0.16rem;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  line-height: 1.8;
}

header{

}

header h1 {
  width: 170px;
}

header .logo{
	margin-bottom: 20px;
}

header .inner{
  padding: 30px 2%;
}

.inner{
    width: 1200px;
    margin: auto;
    padding: 30px 3%;
    max-width: 100%;
}

h2{
	font-size: 0.35rem;
	line-height: 1.8;
	margin-bottom: 30px;
	font-weight: bold;
}

.content_box{
  padding: 24px 0 28px;
  margin-bottom: 47px;
}

.content_box h3{
	font-weight: bold;
	font-size: 1.1em;
}

section{
	margin-bottom: 30px;
}

.content_box .text{
  padding: 13px 4.66% 0; 
}

.content_box .box_wrap{
  display: flex;
  justify-content: space-between;
  padding: 20px 0;
}

.content_box .box{
  width: 30%;
  box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
  box-sizing: border-box;
  position: relative;
}

.content_box.inner.mail{
	padding: 13px 2% 28px;
	margin: 60px auto 0;
	display: flex;
	flex-wrap: wrap;
}

.content_box main{
	max-width: calc(100% - 420px);
	width: 100%;
}

.content_box .side{
	max-width: 380px;
    width: 100%;
    margin-left: 36px;
    position: relative;
}

.content_box .box:before {
    color: #0a62cf;
    content: ;
    font-size: 0.55rem;
    font-weight: 700;
    left: 6px;
    letter-spacing: .6px;
    position: absolute;
    top: -0.40rem;
}

.content_box .box a{
  display: flex;
  align-items: center;
}
.content_box .img_box{
  width: 150px;
  height: 150px;
  margin-right: 10px;
  display: flex;
  align-items: center;
}

.content_box .img_box img{
  border-radius: 100px;
}

.content_box .tit{
  font-size: 0.18rem;
  letter-spacing: 1.6px;
  font-weight: 700;
}

.tit02{
 display: flex;
 align-items: center;
 padding: 20px 0 10px;
 font-size: 0.18rem;
 font-weight: 700;
 border-bottom: 1px solid #0a62cf;
 margin-bottom: 10px;
 margin-top: 15px;
}

.p-top-sec4__number{
    color: #0a62cf !important;
    font-size: 0.45rem !important;
    letter-spacing: 2px !important;
    line-height: 1 !important;
    margin-top: -16px !important;
    top: -2px !important;
    font-weight: 700 !important;
    margin-right: 10px !important;
    display: block !important;
}

.hosoku{
  background: #ebf5fb;
  padding: 20px 3%;
  margin-top: 20px;
}

.red_box{
  background: #ff0000;
  color: #fff;
  font-weight: bold;
  padding: 2px 5px;
  display: inline-block;
  margin-left: 10px;
}

footer{
	position: relative;
}
.footer{
	position: absolute;
	top: 0;
	width: 100%;
	padding: 20px 0;
	z-index: 3;
	background:#282828; 
}

.footer_flex {
  display: flex;
  justify-content: center;
  margin-bottom: 20px;
}

.footer_flex{
	display: flex;
	justify-content: center;
	margin-bottom: 20px;
}
.footer_flex li{
	padding: 0 10px;
	border-right: solid 1px #616161;
}
.footer_flex li:last-child{
	border-right: none;
}
.footer_flex li a{
	color: #fff;
	text-decoration: none;
}
footer small{
	display: block;
	text-align: center;
	color: #fff;
	opacity: 0.3;
}


/* ----------------------------------------------------------------------
 Contactform - お問い合わせフォーム
---------------------------------------------------------------------- */
.wpcf7 { width:100%; margin:0 0 2.5em !important; padding:0; font-size:14px; }
.wpcf7 form { margin:1.0em 0 0; }
.wpcf7 p { margin-bottom:1em; font-size:16px; }
.wpcf7 input, .wpcf7 textarea { -webkit-box-sizing:border-box; box-sizing:border-box; width:100%; padding:8px; border:1px solid #ccc; line-height:1.2; }
.wpcf7 select, .wpcf7 input[type=checkbox], .wpcf7 input[type=radio] { width:auto; max-width:97%; padding:8px; border:1px solid #ccc; }
.wpcf7 select, .wpcf7 .wpcf7-list-item-label { font-size:17px; line-height:1.2; }
.wpcf7 .wpcf7-list-item { display:block; }
.wpcf7 textarea { height:300px; }
.wpcf7 input:focus, .wpcf7 textarea:focus { border:1px solid #bbb; outline:none; }
.wpcf7 .wpcf7-submit, .wpcf7 .wpcf7-previous { -webkit-transition:all .3s; -webkit-box-sizing:border-box; box-sizing:border-box; display:block; position:relative; width:225px; height:48px; margin:30px auto 0; border:none !important; outline:none; background-color:#333333; color:#fff; font-size:14px; line-height:1.5; text-align:center; text-decoration:none; cursor:pointer; transition:all .3s; }
.wpcf7 .wpcf7-submit:before, .wpcf7 .wpcf7-submit:after { -webkit-box-sizing:border-box; box-sizing:border-box; }
.wpcf7 .wpcf7-submit:hover, .wpcf7 .wpcf7-previous:hover { background-color:#666666; }
.wpcf7 .wpcf7-submit .wpcf7-not-valid { background:pink; }
.wpcf7 .wpcf7-submit .wpcf7-response-output { -webkit-border-radius:4px; -moz-border-radius:4px; margin:10px 0 0; padding:8px 35px 8px 14px; border-radius:4px; }
.wpcf7 .wpcf7-submit .wpcf7-validation-errors { border:1px solid #EED3D7; background-color:#F2DEDE; color:#B94A48; }
.wpcf7 .wpcf7-submit .wpcf7-mail-sent-ok { border:1px solid #BCE8F1; background-color:#D9EDF7; color:#3A87AD; }
.wpcf7 .wpcf7-previous + br { display: none; }
.wpcf7 form .wpcf7-response-output{ margin: 2em 0.5em 2em; padding:0; border: none; text-align:center; }
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output{ color:#dc3232; font-size: 1em; }

label{
	position: relative;
}

/* Style for DIVA dark ver. */
.wpcf7 { color:#000; }
.label-hissu, .label-nini {
  line-height: 18px;
}

  .label-hissu {
    color: #e5412b;
    border: solid 2px #e5412b;
}

.label-hissu, .label-nini {
  padding: 0 8px;
  display: inline-block;
  /* position: absolute; */
  right: 25px;
  top: 50%;
  margin-top: -10px;
  font-weight: 600;
  border-radius: 5px;
  background-color: #fff;
}

.label {
  display: inline-block;
  padding: 0.2em 0.6em 0.3em;
  font-size: 75%;
  font-weight: 700;
  line-height: 1;
  color: #ff0000;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: 0.25em;
  margin: 0 0 5px 10px;
}

.wpcf7 .screen-reader-response {
	position: absolute;
	overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	margin: -1px;
	padding: 0;
	border: 0;
	word-wrap: normal !important;
}

.wpcf7 form .wpcf7-response-output {
	margin: 2em 0.5em 1em;
	padding: 0.2em 1em;
	border: 2px solid #00a0d2; /* Blue */
}

.wpcf7 form.init .wpcf7-response-output,
.wpcf7 form.resetting .wpcf7-response-output,
.wpcf7 form.submitting .wpcf7-response-output {
	display: none;
}

.wpcf7 form.sent .wpcf7-response-output {
	border-color: #46b450; /* Green */
}

.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
	border-color: #dc3232; /* Red */
}

.wpcf7 form.spam .wpcf7-response-output {
	border-color: #f56e28; /* Orange */
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
	border-color: #ffb900; /* Yellow */
}

.wpcf7-form-control-wrap {
	position: relative;
}

.wpcf7-not-valid-tip {
	color: #dc3232; /* Red */
	font-size: 1em;
	font-weight: normal;
	display: block;
}

.use-floating-validation-tip .wpcf7-not-valid-tip {
	position: relative;
	top: -2ex;
	left: 1em;
	z-index: 100;
	border: 1px solid #dc3232;
	background: #fff;
	padding: .2em .8em;
	width: 24em;
}

.wpcf7-list-item {
	display: inline-block;
	margin: 0 0 0 1em;
}

.wpcf7-list-item-label::before,
.wpcf7-list-item-label::after {
	content: " ";
}

.wpcf7-spinner {
	visibility: hidden;
	display: inline-block;
	background-color: #23282d; /* Dark Gray 800 */
	opacity: 0.75;
	width: 24px;
	height: 24px;
	border: none;
	border-radius: 100%;
	padding: 0;
	margin: 0 24px;
	position: relative;
}

form.submitting .wpcf7-spinner {
	visibility: visible;
}

.wpcf7-spinner::before {
	content: '';
	position: absolute;
	background-color: #fbfbfc; /* Light Gray 100 */
	top: 4px;
	left: 4px;
	width: 6px;
	height: 6px;
	border: none;
	border-radius: 100%;
	transform-origin: 8px 8px;
	animation-name: spin;
	animation-duration: 1000ms;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
}

form a{
	color:#0a62cf
}

.wpcf7-acceptance{
	text-align: center;
}

@media (prefers-reduced-motion: reduce) {
	.wpcf7-spinner::before {
		animation-name: blink;
		animation-duration: 2000ms;
	}
}

@keyframes spin {
	from {
		transform: rotate(0deg);
	}

	to {
		transform: rotate(360deg);
	}
}

@keyframes blink {
	from {
		opacity: 0;
	}

	50% {
		opacity: 1;
	}

	to {
		opacity: 0;
	}
}

.wpcf7 input[type="file"] {
	cursor: pointer;
}

.wpcf7 input[type="file"]:disabled {
	cursor: default;
}

.wpcf7 .wpcf7-submit:disabled {
	cursor: not-allowed;
}

.wpcf7 input[type="url"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"] {
	direction: ltr;
}

.wpcf7-reflection > output {
	display: list-item;
	list-style: none;
}

.pc_none{
	display: none;
}

input[type=color], input[type=date], input[type=datetime-local], input[type=datetime], input[type=email], input[type=file], input[type=month], input[type=number], input[type=range], input[type=search], input[type=tel], input[type=text], input[type=time], input[type=url], input[type=week], select, textarea{
	font-size: 16px !important;
}

header{
	border-bottom: 1px solid #efefef;
}