.subtitle {
	padding: 20px 0;
	margin: 20px 0 0 0;
}
form.contact {
	font-size: 12px;
}
form.contact table {
	font-size: 12px;
}
form.contact p {
	padding: 10px 0 20px 5px;
}
form.contact .school label,
form.contact .person label,
form.contact .job label,
form.contact .ad label {
	float: left;
	display: block;
	padding: 0 20px 0 0;
}
form.contact textarea {
	width: 95%;
	height: 10em;
}
table.vertical th {
	padding-right: 15px;
	background: #FBFBFB;
}
span.note {
	font-size: 10px;
	padding: 0 0 0 0;
	display: block;
}
span.need {
	color: #FF9900;
}
.about_policy {
	text-align: center;
	padding: 20px 0 0 0;
}
#vs_side {
	margin: 15px 0 0 0;
}
#vs_side .vs_logo {
	float: left;
	padding: 0 0 0 50px;
}
#vs_side .vs_text {
	float: left;
	padding: 30px 0 0 15px;
}
.gotop {
	padding: 40px 0 0 0;
	text-align: center;
}
form.contact p.selected-title{
	padding: 15px 0 0 !important;
}

#grade_other{
  display: none;
}

/* 240527 追記 */
html {
	font-size: 62.5%;
}
body {
	font-size: 1.6rem;
	line-height: 1.6;
}
.main {
	padding-top: 80px !important;
	padding: 0 10px;
}
.contact_title {
	font-size: 2rem;
	position: relative;
	padding-left: 16px;
  }
  .contact_title::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 3px;
	background: #006600;
  }
  
  .border-top {
	border-top: dotted 1px #999999;
  }
  
  .contact_h3 {
	background: #198B43;
	color: #fff;
	padding: 5px;
	position: relative;
  }
  
  form.contact p {
	font-size: 1.4rem;
	padding-left: 0;
  }
  
  table.vertical {
	border-collapse: collapse;
	box-sizing: border-box;
	border-bottom: 1px solid #c9c9c9;
  }
  table.vertical tr {
	display: flex;
	flex-direction: column;
  }
  table.vertical th, table.vertical td {
	padding: 10px 5px;
	border: 1px solid #c9c9c9;
	border-collapse: collapse;
  }
  table.vertical th {
	padding-right: 0;
	text-align: left;
	font-size: 1.6rem;
	background: #f5f5f5;
  }
  table.vertical td {
	border-top: none;
	border-bottom: none;
  }
  table.vertical td input {
	font-size: 1.6rem;
	border: 1px solid #c9c9c9;
	padding: 10px 5px;
  }
  table.vertical td input#zip {
	width: 40%;
  }
  table.vertical td input.btn_add {
	font-size: 1.2rem;
	margin-top: 0;
  }
  table.vertical td select {
	appearance: none;
    width: 100%;
    border: 1px solid #E6E6E6;
    padding: 13px 16px;
    font-size: 1.5rem;
	position: relative;
  }
  table.vertical td .select_wrap {
	position: relative;
}
  table.vertical td .select_wrap::before {
	content: "";
    position: absolute;
    display: inline-block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 8px 6px 0 6px;
    border-color: #033333 transparent transparent transparent;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 15px;
    z-index: 1;
  }
  table.vertical td input[type=text] {
	width: calc(100% - 16px);
  }
  table.vertical td #school_name_input {
	margin-bottom: 6px;
  }
  
  .btn_add {
	margin-top: 6px;
  }
  
form.contact .school label,
form.contact .person label,
form.contact .job label,
form.contact .ad label,
form.contact .title label {
	font-size: 1.5rem;
	float: none;
	padding: 0 0 10px 0;
    display: block;
  }
tr.title_attention {
	margin-top: -25px;
}
  
  .submit {
	text-align: center;
  }
  
  .vs_text {
	font-size: 1.2rem;
  }

  .submit {
	text-align: center;
	padding: 20px 0 0 0;
  }

  .formErrorContent {
    position: absolute;  /* 必要に応じてrelativeやfixedなどに変更 */
    bottom: 33px;
    left: -90px;         /* 左からの距離を指定。必要に応じて調整 */
    transform: translateX(-50%);  /* 水平方向に中央揃え */
    background-color: red;  /* 背景色を指定 */
    color: white;       /* 文字色を指定 */
    padding: 10px;      /* パディングを指定 */
    border-radius: 5px; /* 角を丸くする */
    z-index: 1000;      /* 他の要素より前に表示されるようにする */
}

.formError {
	width: 0;
}

.tel-area {
	padding: 0;
}

.visually-hidden {
	position: absolute;
	white-space: nowrap;
	width: 1px;
	height: 1px;
	overflow: hidden;
	border: 0;
	padding: 0;
	clip: rect(0 0 0 0);
	clip-path: inset(50%); 
	margin: -1px;
}

form.contact .radio span {
	padding-left: 36px;
	padding-bottom: 0;
	position: relative;
	margin-bottom: 6px;
    display: block;
}

.radio span::before,
.radio span::after {
  content: "";
  display: block; 
  border-radius: 50%;
  position: absolute;
  transform: translateY(-50%);
  top: 50%;
}

.radio span::before {
	background-color: #fff;
	border: 1px solid #ddd;
	border-radius: 50%;
	width: 20px;
	height: 20px;
	left: 5px;
  }
  
  .radio span::after {
	background-color: #00895F;
	border-radius: 50%;
	opacity: 0;
    width: 14px;
    height: 14px;
    left: 9px;
  }
  
.radio label input:checked + span::after {
	opacity: 1;
}

.submit input.button {
	appearance: none;
	font-weight: medium;
	width: 100%;
    max-width: 240px;
	border: none;
	display       : inline-block;
	border-radius : 999px;          /* 角丸       */
	font-size     : 16px;        /* 文字サイズ */
	text-align    : center;      /* 文字位置   */
	cursor        : pointer;     /* カーソル   */
	padding       : 16px 40px;   /* 余白       */
	background    : #00895f;     /* 背景色     */
	color         : #ffffff;     /* 文字色     */
	line-height   : 1em;         /* 1行の高さ  */       /* なめらか変化 */
  }