@charset "UTF-8";

/*! サイトベース */
.cl {
  display: inline-block;
  min-height: 1%;
  display: block;
  *zoom: 1;
}
.cl:after {
  content: " ";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  font-size: 0;
}
* html .cl {
  height: 1%;
}

.cl {
  display: inline-block;
  min-height: 1%;
  display: block;
  *zoom: 1;
}

.cl:after {
  content: " ";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  font-size: 0;
}

* html .cl {
  height: 1%;
}

/*----------------------------------
reset
----------------------------------*/
dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote {
  margin: 0;
  padding: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

address, caption, cite, code, dfn, em, strong, th, var {
  font-style: normal;
  font-weight: normal;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
}

fieldset, img {
  border: 0;
  vertical-align: top;
}

ol, ul {
  list-style: none;
}

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

abbr, acronym {
  border: 0;
}

a:link {
  color: #00b8ee;
  text-decoration: underline;
}

a:visited {
  color: #00b8ee;
  text-decoration: underline;
}

a:hover {
  color: #00b8ee;
  text-decoration: underline;
  cursor: pointer;
}

a:active {
  color: #00b8ee;
  text-decoration: underline;
}

a:active, a:focus {
  outline: none;
}

/*  */
li img,
dt img,
dd img {
  vertical-align: top;
}

.clear {
  clear: both;
  height: 0;
  line-height: 0;
}

/* IE7 Zoom対策 */
* {
  letter-spacing: 0;
}

/* mediabox対策 */
* {
  margin: 0;
  padding: 0;
}

body {
  font: 14px/1.8 Verdana, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  color: #4d4d4d;
  margin: 0;
  padding: 0;
  text-align: center;
  min-width: 320px;
  background: url(../images/advance/bg-base.gif);
  background-size: 7px auto;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
}

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

img {
  max-width: 100%;
  height: auto;
}

input[type="button"], input[type="submit"] {
  -webkit-appearance: none;
}

/*----------------------------------
wrapper
----------------------------------*/
#wrapper {
  position: relative;
  max-width: 640px;
  margin: 0 auto;
  padding: 40px 3.125% 60px;
  text-align: left;
  font-size: 100%;
}

/*----------------------------------
footer
----------------------------------*/
footer {
  padding: 20px 0;
  background: #4d4d4d;
  color: #fff;
  text-align: center;
}

/*----------------------------------
loader
----------------------------------*/
.loader {
  padding: 20px 0 !important;
  background: #fff !important;
}
.loader div {
	width: 20px;
	height: 20px;
  margin: 0 auto;
	border-radius: 50%;
	border: 4px solid #3cb8ee;
	border-right-color: transparent;
  -moz-animation: spin 1s linear infinite;
  -webkit-animation: spin 1s linear infinite;
  animation: spin 1s linear infinite;
}
@-webkit-keyframes spin
{
	0% {
    -moz-transform: rotate(0deg);   opacity: .2;
    -webkit-transform: rotate(0deg);   opacity: .2;
    transform: rotate(0deg);   opacity: .2;
  }
	50% {
    -moz-transform: rotate(180deg); opacity: 1.0;
    -webkit-transform: rotate(180deg); opacity: 1.0;
    transform: rotate(180deg); opacity: 1.0;
  }
	100% {
    -moz-transform: rotate(360deg); opacity: .2;
    -webkit-transform: rotate(360deg); opacity: .2;
    transform: rotate(360deg); opacity: .2;
  }
}

/*! インデクッス */
.cl, #input-wrap .type-radio {
  display: inline-block;
  min-height: 1%;
  display: block;
  *zoom: 1;
}
.cl:after, #input-wrap .type-radio:after {
  content: " ";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  font-size: 0;
}
* html .cl, * html #input-wrap .type-radio, #input-wrap * html .type-radio {
  height: 1%;
}

/*----------------------------------
header
----------------------------------*/
header h1 + p {
  margin-top: 20px;
}
header p {
  max-width: 640px;
  margin: 5px auto 0;
  padding: 0 3.125%;
  text-align: left;
}
header p span {
  color: #00b8ee;
}
header p em {
  color: #ff0000;
}

/*----------------------------------
form
----------------------------------*/
#input-wrap dl {
  margin-top: 20px;
  padding: 4%;
  border: 1px solid #e6e6e6;
  background: #fff;
  -moz-border-radius: 8px;
  -webkit-border-radius: 8px;
  border-radius: 8px;
}
#input-wrap dl:first-child {
  margin-top: 0;
}
#input-wrap dt {
  margin-bottom: 10px;
  font-weight: bold;
}
#input-wrap dt span {
  margin-left: 5px;
  color: #ff0000;
}
#input-wrap dt em {
  display: block;
  color: #ff0000;
}
#input-wrap small {
  display: block;
  margin-top: 5px;
  color: #00b8ee;
  font-size: 90%;
  font-weight: normal;
}
#input-wrap input[type=text], #input-wrap input[type=email], #input-wrap input[type=tel] {
  width: 100%;
  height: 40px;
  padding: 0 2%;
  border: 1px solid #b6b3b2;
  box-sizing: border-box;
  -moz-border-radius: 6px;
  -webkit-border-radius: 6px;
  border-radius: 6px;
}
#input-wrap input[type=radio], #input-wrap input[type=checkbox] {
  position: relative;
  top: -2px;
  vertical-align: middle;
  /*top:-2px;
  top:1\9;*/
  margin-right: 5px;
}
.select-wrap {
  display: inline-block;
  position: relative;
}
.select-wrap::after {
  position: absolute;
  top: 50%;
  right: 20px;
  margin-top: -5px;
  width: 15px;
  height: 10px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 319.9 206.6'%3E%3Cpath d='m143.05 199.55-136-136c-9.4-9.4-9.4-24.6 0-33.9l22.6-22.6c9.4-9.4 24.6-9.4 33.9 0l96.4 96.4 96.4-96.4c9.4-9.4 24.6-9.4 33.9 0l22.6 22.6c9.4 9.4 9.4 24.6 0 33.9l-136 136c-9.2 9.4-24.4 9.4-33.8 0Z' fill='%23d5d5d5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  pointer-events: none;
  content: "";
}
.select-wrap select {
  height: 60px;
  padding: 0 45px 0 30px;
  font-size: 18px;
  border-radius: 12px;
  background-color: #fff;
  border: 2px solid #e1e1e1;
  font-family: "Noto Sans JP", sans-serif;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}
@media screen and (max-width: 768px) {
  .select-wrap select {
    padding: 0 45px 0 10px;
  }
}
.radio-container {
	overflow: hidden;
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}
.radio-container input {
  position: absolute;
  visibility: hidden;
  opacity: 0;
}
.radio-container label {
  position: relative;
  display: inline-flex;
  align-items: center;
  text-align: left;
  gap: 15px;
  font-size: 18px;
  font-family: "Noto Sans JP", sans-serif;
  cursor: pointer;
}
.radio-container label::before {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border: 2px solid #e1e1e1;
  border-radius: 50%;
  box-sizing: border-box;
  content: "";
}
.radio-container label:has(input[type="radio"]:checked)::before {
  border: 3px solid #ff7fc6;
  background-color: #ffecfb;
}
.radio-container label:has(input[type="radio"]:checked)::after {
  position: absolute;
  top: 50%;
  left: 8px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background-color: #f653ad;
  transform: translateY(-50%);
  box-sizing: border-box;
  content: "";
}
.input.date {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  column-gap: 20px;  
}
@media screen and (max-width: 768px) {
  .input.date {
    column-gap: 10px;  
  }
}
.input.date > label {
  width: 100%;
}
.wrap-input-zip,
.wrap-input-telephone {
  display: flex;
  align-items: center;
  column-gap: 20px;  
}
@media screen and (max-width: 768px) {
  .wrap-input-zip,
  .wrap-input-telephone {
    column-gap: 10px;
  }
}

#input-wrap .type-check dd {
  padding: 2%;
}
#input-wrap .type-check dd:nth-child(even) {
  background: #f9f9f9;
}
#input-wrap .type-radio label, #input-wrap .type-check label {
  display: block;
}
#input-wrap .type-check label {
  padding-left: 1.5em;
  text-indent: -1.5em;
}
#input-wrap #btn-send,
.submit-container {
  margin-top: 30px;
  text-align: center;
}
.submit-container {
  display: flex;
  gap: 20px;
}
#input-wrap #btn-send p {
  width: 43.75%;
  margin: 0 auto;
}
#input-wrap #btn-send li {
  display: inline-block;
  vertical-align: top;
  letter-spacing: normal;
  width: 43.75%;
  padding: 0 2%;
}
#input-wrap #float-button.is-fixed {
  position: fixed;
  bottom: 0;
  left: 50%;
  max-width: 730px;
  width: 100%;
  margin: 0;
  padding: 10px 3.125%;  
  transform: translateX(-50%);
  box-sizing: border-box;
}



#input-wrap #btn-send input,
#input-wrap #btn-send button,
.submit-container button,
#input-wrap .type-selector a {
  display: inline-block;
  width: 100%;
  padding: 15px 0;
  background: #00b8ee;
  color: #fff;
  font-weight: bold;
  font-size: 100%;
  border: none;
  -moz-border-radius: 6px;
  -webkit-border-radius: 6px;
  border-radius: 6px;
  *display: inline;
  *zoom: 1;
  
  cursor: pointer;
}
.submit-container button.back {
  color: rgba(18, 41, 61, 0.6);
  background: #fff;
  border: 3px solid #e1e1e1;
}



#input-wrap .type-selector {
  display: flex;
  padding: 0 10px;
  gap: 8px;
	overflow: hidden;
	margin-bottom: 20px;
  border-bottom: 2px solid #00b8ee;
}
#type-selector {
  height: 56px;
}
#input-wrap .is-fixed .type-selector {
  position: fixed;
  top: 0;
  left: 50%;
  max-width: 640px;
  width: 93.75%;
  margin: 0 auto;
  transform: translateX(-50%);
  box-sizing: border-box;
  background-color: #fff;
  z-index: 10;
}
#input-wrap .type-selector li {
  flex: 1;
}

#input-wrap .type-selector a {
	width: 100%;
	text-align: center;
  border-radius: 6px 6px 0 0;
  text-decoration: none;
	float: left;
}
#input-wrap .type-selector a:not(.current) {  
  background: #bbb;
}
#input-wrap .type-selector a:hover {
	text-decoration: none;
}




#thanks-wrap {
  padding: 4%;
  border: 1px solid #e6e6e6;
  background: #fff;
  -moz-border-radius: 8px;
  -webkit-border-radius: 8px;
  border-radius: 8px;
}
#thanks-wrap p:first-child {
  margin-bottom: 20px;
}
#input-wrap .school-box {
	clear: both;
	margin-top: 20px;
	margin-bottom: 20px;
}

#input-wrap .school-box h2 {
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	margin-top: 40px;
	margin-bottom: 0px;
	background-color: #eee;
	
}




#input-wrap .error {
	font-size: 16px;
	color: #f60;
	font-weight: bold;
}





#input-wrap #btn-back {
  margin-top: 30px;
  text-align: center;
}

#input-wrap #btn-back input {
  display: inline-block;
  width: 120px;
  padding: 15px 0;
  background: #666;
  color: #fff;
  font-size: 100%;
  border: none;
  -moz-border-radius: 6px;
  -webkit-border-radius: 6px;
  border-radius: 6px;
  *display: inline;
  *zoom: 1;
  
  cursor: pointer;
}

/* form */
.input {
	  padding: 0 4% 30px 4%;
    background: #fff;
    text-align: left;
    font-size: 18px;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.38;
}
#school-selector + .input {
  padding-top: 30px;
}
.input > label {
  display: inline-block;
	margin-bottom: 15px;
}
.required > label {
  display: flex;
    align-items: center;
    gap: 10px;
    font-size: 18px;    
}
.required > label::after {
  padding: 3px 8px;
  color: #fff;
  font-size: 13px;
  background-color: #f653ad;
  content: "必須";
}
.input input[type=text], .input input[type=email], .input input[type=tel] {
    width: 100%;
    height: 60px;
    padding: 0 20px;
    font-size: 18px;
    border-radius: 12px;
    border: 2px solid #e1e1e1;
    box-sizing: border-box;
    font-family: "Noto Sans JP", sans-serif;
}
@media screen and (max-width: 768px) {
  .input input[type=text], .input input[type=email], .input input[type=tel] {
    padding: 0 10px;
  }
}
.wrap-input-fullname {
  display: flex;
  align-items: center;
  gap: 20px;
}
.wrap-input-fullname input[type="text"] {
	width: 48%;
}
#input_zip01 {width: 80px;}
#input_zip02 {width: 120px;}
#input_tel01,#input_tel02,#input_tel03 {width: 140px;}
@media screen and (max-width: 768px) {
  #input_tel01,#input_tel02,#input_tel03 {width: 30%;}
}

/* check */
#school-selector li {
  margin-bottom: 10px;
  font-size: 20px;
}
#school-selector li:last-child {
  margin-bottom: 0;
}
#school-selector input[type='checkbox'] {
  display: none;
}
#school-selector input[type='checkbox'] + label {
  position: relative;
  display: inline-flex;
  align-items: center;
  text-align: left;
  gap: 19px;  
  cursor: pointer;
}
#school-selector input[type='checkbox'] + label::before {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border: 2px solid #e1e1e1;
  border-radius: 6px;
  box-sizing: border-box;
  content: "";
}
#school-selector input[type='checkbox']:checked + label::before {
  border: 3px solid #ff7fc6;
  background-color: #ffecfb;
}
#school-selector input[type='checkbox']:checked + label::after {
  position: absolute;
  top: 50%;
  left: 7px;
  width: 17px;
  height: 12px;
  transform: translateY(-50%);
  background: url(../images/common/icon_check.svg) no-repeat center center/contain;
  filter: brightness(0) saturate(100%) invert(74%) sepia(52%) saturate(7216%) hue-rotate(297deg) brightness(97%) contrast(100%);
  box-sizing: border-box;
  content: "";
}

.confirm .input {
    display: flex;
    gap: 60px;
    padding: 20px 0;    
    border-bottom: 1px solid #e1e1e1;
}
@media screen and (max-width: 768px) {
  .confirm .input {
    gap: 30px;
    font-size: 16px;
  }
  .confirm #school-selector li {
    font-size: 16px;
  }
}
.confirm .input > label {
  flex-shrink: 0;
  margin: 0;  
}
@media screen and (max-width: 768px) {
  .confirm .input > label {
    font-size: 16px;
  }
}
.confirm .input.date > label {
  width: auto;
}
fieldset:not(:first-of-type) {
  margin-top: 50px;
}
fieldset legend {
  margin-bottom: 30px;
  font-size: 24px;
  font-weight: 700;
  text-align: center;  
}
@media screen and (max-width: 768px) {
  fieldset legend {
    font-size: 20px;
    margin-bottom: 15px;
  }
}
.complete-text {
  font-size: 24px;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .complete-text {
    font-size: 20px;
  }
}

.submit-container button:disabled {
  opacity: 0.2;
  pointer-events: none;
}

.note-privacy {
  padding-top: 25px;
  text-align: center;
}
.note-privacy .link {
  display: inline-block;
}
.note-privacy .link::after {
  content: '';
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 0 0 0 10px;
  vertical-align: bottom;
  background: url(../images/common/btn_slideNext.png) no-repeat;
  background-size: contain;
}
.note-privacy-input > label {
  cursor: pointer;
}
