:root {
  --cnt-width: 520px;
}

@media (min-width: 769px) {
  :root {
    --cnt-width: 1000px;
  }
}
.o-stepForm {
  margin: auto;
  max-width: 520px;
  padding-top: 48px;
}

@media (min-width: 769px) {
  .o-stepForm {
    padding-top: 56px;
    max-width: 100%;
  }
}
.o-stepContents {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  justify-content: flex-start;
  align-self: stretch;
  flex-shrink: 0;
  position: relative;
}

.o-stepContents + .o-stepContents {
  margin-top: 48px;
}

@media (min-width: 769px) {
  .o-stepContents + .o-stepContents {
    margin-top: 56px;
  }
}
.o-stepContents .m-stepHeading {
  position: relative;
}

.o-stepContents .ttl2 {
  background: var(--keyblack, #222222);
  padding: 0px 12px 0px 66px;
  display: flex;
  flex-direction: row;
  gap: 10px;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 280px;
  height: 40px;
  position: relative;
  color: var(--key_white, #ffffff);
  text-align: center;
  font-size: 1.125rem;
  line-height: 140%;
  font-weight: 600;
  position: relative;
  flex: 1;
}

@media (min-width: 769px) {
  .o-stepContents .ttl2 {
    font-size: 1.375rem;
    width: 320px;
  }
}
.o-stepContents .ttl-step {
  display: flex;
  flex-direction: column;
  gap: 0px;
  align-items: flex-start;
  justify-content: center;
  flex-shrink: 0;
  position: absolute;
  left: 10px;
  top: -6px;
}

.o-stepContents .ttl3 {
  background: var(--key_red, #df0012);
  padding: 7px 10px 0px 10px;
  display: flex;
  flex-direction: column;
  gap: 0px;
  align-items: center;
  justify-content: flex-start;
  flex-shrink: 0;
  width: 50px;
  height: 50px;
  border-radius: 50px;
  position: relative;
}

.o-stepContents .step {
  color: var(--key_white, #ffffff);
  text-align: center;
  font-family: "Helvetica Neue", Arial, sans-serif;
  font-size: 11px;
  line-height: 100%;
  font-weight: 400;
  position: relative;
}

.o-stepContents ._1 {
  color: var(--key_white, #ffffff);
  text-align: center;
  font-family: "Helvetica Neue", Arial, sans-serif;
  font-size: 26px;
  line-height: 100%;
  font-weight: 700;
  position: relative;
}

.o-stepContents .m-stepContent {
  display: grid;
  grid-template-columns: repeat(2, minmax(160px, 1fr));
  gap: 8px;
  align-items: flex-start;
  justify-content: center;
  align-content: flex-start;
  flex-shrink: 0;
  position: relative;
  width: 100%;
  max-width: 1000px;
}
.o-stepContents .m-stepContent .js-checked small {
  color: var(--key_white, #ffffff);
}
.o-stepContents .m-stepContent small {
  color: var(--keyblack, #222222);
  text-align: center;
  font-size: 0.75rem;
  line-height: 120%;
  font-weight: 600;
  position: relative;
  align-self: stretch;
  margin-top: 6px;
  letter-spacing: normal;
}
@media (min-width: 769px) {
  .o-stepContents .m-stepContent small {
    font-size: 0.875rem;
  }
}

.o-stepContents .m-stepContent input {
  display: none;
}

.o-stepContents .m-stepContent.-step2 .a-stepItem:nth-child(1) {
  grid-area: 1/1/2/2;
}
.o-stepContents .m-stepContent.-step2 .a-stepItem:nth-child(2) {
  grid-area: 1/2/2/3;
}
.o-stepContents .m-stepContent.-step2 .a-stepItem:nth-child(3) {
  justify-self: center;
  width: calc(50% - 4px);
  grid-area: 2/1/3/3;
}
@media (min-width: 971px) {
  .o-stepContents .m-stepContent.-step2 .a-stepItem:nth-child(1) {
    grid-area: 1/1/2/2;
  }
  .o-stepContents .m-stepContent.-step2 .a-stepItem:nth-child(2) {
    grid-area: 1/2/2/3;
  }
  .o-stepContents .m-stepContent.-step2 .a-stepItem:nth-child(3) {
    width: 100%;
    grid-area: 1/3/2/4;
  }
}

@media (min-width: 768px) {
  .o-stepContents .m-stepContent {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  }
}
@media (min-width: 769px) {
  .o-stepContents .m-stepContent {
    grid-template-columns: repeat(auto-fill, minmax(242px, 1fr));
    gap: 10px;
  }
  .o-stepContents .m-stepContent.-col-3 {
    grid-template-columns: repeat(auto-fill, 280px);
  }
  .o-stepContents .m-stepContent.-col-4 {
    max-width: 798px;
    grid-template-columns: repeat(auto-fill, 192px);
  }
}
.o-stepContents .a-stepItem {
  cursor: pointer;
  background: var(--key_white, #ffffff);
  border-radius: 8px;
  border-style: solid;
  border-color: var(--key_red, #df0012);
  border-width: 2px;
  padding: 8px 8px 6px 8px;
  display: flex;
  flex-direction: column;
  gap: 0px;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 100%;
  height: 88px;
  position: relative;
}

.o-stepContents .a-stepItem.js-checked {
  background: var(--key_red, #df0012);
  color: var(--key_white, #ffffff);
}

@media (min-width: 769px) {
  .o-stepContents .a-stepItem {
    border-width: 3px;
    height: 80px;
  }
}
.o-stepContents .a-educationItem {
  color: var(--key_red, #df0012);
  text-align: center;
  font-size: 1.1875rem;
  line-height: 120%;
  font-weight: 600;
  position: relative;
  align-self: stretch;
}

.o-stepContents .a-educationItem:nth-child(1),
.o-stepContents .a-educationItem:nth-child(3) {
  letter-spacing: 4px;
}

@media (min-width: 769px) {
  .o-stepContents .a-educationItem {
    font-size: 20px;
  }
}
.o-stepContents .a-fieldItem {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  flex-shrink: 0;
  padding: 8px;
  position: relative;
  color: var(--key_red, #df0012);
  text-align: left;
  font-size: 0.9375rem;
  line-height: 140%;
  font-weight: 600;
  position: relative;
  flex: 1;
  height: 100%;
}

@media (min-width: 768px) {
  .o-stepContents .a-fieldItem {
    padding: 10px 12px;
    font-size: 1.125rem;
    min-height: 80px;
    flex-direction: row;
  }
}
.o-stepContents .a-fieldItem .ttl {
  display: flex;
  flex-direction: row;
  gap: 6px;
  align-items: center;
  justify-content: flex-start;
  align-self: stretch;
  flex-shrink: 0;
  position: relative;
  width: 100%;
}
@media (min-width: 768px) {
  .o-stepContents .a-fieldItem .ttl {
    gap: 12px;
  }
}

.o-stepContents .a-fieldItem .a-fieldItemIcon {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  position: relative;
  background: var(--graydfdfdf, #dfdfdf);
}

.o-stepContents .a-fieldItem .a-fieldItemIcon .icon-on {
  display: none;
}

@media (min-width: 769px) {
  .o-stepContents .a-fieldItem .a-fieldItemIcon {
    width: 54px;
    height: 54px;
  }
}
.o-stepContents .a-fieldItem.js-checked .a-fieldItemIcon .icon {
  display: none;
}

.o-stepContents .a-fieldItem.js-checked .a-fieldItemIcon .icon-on {
  display: block;
}

.o-stepContents .a-fieldItem .-tag {
  display: flex;
  flex-direction: row;
  gap: 2px;
  align-items: flex-start;
  justify-content: flex-start;
  flex-wrap: wrap;
  align-content: flex-start;
  position: relative;
  width: 100%;
}

.o-stepContents .a-fieldItem .-tag li {
  background: var(--keygrayf1f1f1, #f1f1f1);
  display: flex;
  flex-direction: row;
  gap: 0px;
  align-items: center;
  justify-content: center;
  flex: 0 0 calc(50% - 2px);
  width: 86px;
  height: 15px;
  position: relative;
  color: var(--keyblack, #222222);
  text-align: center;
  font-size: 0.625rem;
  line-height: 120%;
  font-weight: 600;
  position: relative;
}

@media (min-width: 769px) {
  .o-stepContents .a-fieldItem .-tag li {
    font-size: 0.6875rem;
    height: 18px;
  }
}
.o-stepContents .a-locationItem {
  color: var(--key_red, #df0012);
  text-align: center;
  font-size: 1.1875rem;
  line-height: 100%;
  letter-spacing: 0.2em;
  font-weight: 600;
  position: relative;
  height: 64px;
}
.o-stepContents .a-locationItem small {
  padding-top: 0;
}

.o-stepContents .a-locationItem .-sub {
  color: var(--keyblack, #222222);
  text-align: center;
  font-size: 0.875rem;
  line-height: 120%;
  font-weight: 600;
  letter-spacing: 0;
  position: relative;
  align-self: stretch;
}

.o-stepContents .a-locationItem .-small {
  font-size: 0.6875rem;
}

@media (min-width: 769px) {
  .o-stepContents .a-locationItem .-small {
    font-size: 0.875rem;
  }
}
.o-stepContents .a-locationItem.js-checked .-sub {
  color: var(--key_white, #ffffff);
}

@media (min-width: 769px) {
  .o-stepContents .a-locationItem {
    line-height: 120%;
    height: 80px;
  }
  .o-stepContents .a-locationItem .-small {
    font-size: 0.875rem;
  }
}
.o-formArea {
  background: var(--key_red, #df0012);
  position: relative;
  padding-top: 64px;
  padding-bottom: 88px;
}

@media (min-width: 769px) {
  .o-formArea {
    padding-top: 72px;
  }
}
.o-formArea::after {
  content: "";
  display: block;
  position: absolute;
  top: -32px;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 32px;
  background: var(--key_red, #df0012);
  clip-path: polygon(100% 0, 0% 100%, 100% 100%);
  z-index: 1;
}

@media (min-width: 769px) {
  .o-formArea::after {
    height: 110px;
    top: -109px;
  }
}
.o-formArea::before {
  content: "";
  display: block;
  position: absolute;
  top: -22px;
  left: 0;
  right: 0;
  margin: auto;
  width: 70px;
  height: 44px;
  background: #fff;
  aspect-ratio: 1/0.8660254038;
  clip-path: polygon(50% 100%, 100% 0, 0 0);
  z-index: 2;
}

@media (min-width: 769px) {
  .o-formArea::before {
    width: 120px;
    height: 70px;
    top: -70px;
  }
}
.o-formArea .o-formArea-inner {
  max-width: 520px;
  margin: auto;
}

@media (min-width: 769px) {
  .o-formArea .o-formArea-inner {
    max-width: 880px;
    background: #fff;
    padding: 80px;
    border-radius: 20px;
  }
}
.o-formArea .o-formArea-inner .m-stepResult {
  background: #fff;
  border-style: solid;
  border-color: var(--key_red, #df0012);
  border-width: 1px;
  padding: 16px 14px;
  display: flex;
  flex-direction: row;
  gap: 12px;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  flex-shrink: 0;
  position: relative;
  border-radius: 16px;
}

.o-formArea .o-formArea-inner .m-stepResult .pamph {
  width: 72px;
}

@media (min-width: 769px) {
  .o-formArea .o-formArea-inner .m-stepResult {
    border-width: 2px;
    padding: 10px;
  }
}
.o-formArea .o-formArea-inner .m-stepResult-text {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-start;
  justify-content: flex-start;
  flex: 1;
  position: relative;
}

.o-formArea .o-formArea-inner .heading {
  color: var(--keyblack, #222222);
  text-align: left;
  font-size: 0.875rem;
  line-height: 140%;
  font-weight: 600;
  position: relative;
  align-self: stretch;
}

@media (min-width: 769px) {
  .o-formArea .o-formArea-inner .heading {
    font-size: 1.125rem;
  }
}
.o-formArea .o-formArea-inner .tag {
  display: flex;
  flex-direction: row;
  gap: 4px;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  align-content: center;
  align-self: stretch;
  flex-shrink: 0;
  height: 23px;
  position: relative;
}

.o-formArea .o-formArea-inner .tag li {
  background: var(--key_red, #df0012);
  padding: 4px 8px 4px 8px;
  display: flex;
  flex-direction: row;
  gap: 10px;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
  color: var(--key_white, #ffffff);
  text-align: center;
  font-size: 0.9375rem;
  line-height: 100%;
  font-weight: 600;
  position: relative;
}

.o-formArea .o-formArea-inner .schoolName {
  color: var(--keyblack, #222222);
  text-align: left;
  font-size: 1.125rem;
  line-height: 120%;
  font-weight: 600;
  position: relative;
  align-self: stretch;
}

@media (min-width: 769px) {
  .o-formArea .o-formArea-inner .schoolName {
    font-size: 1.25rem;
  }
}
.o-formArea .m-formArea-wrap {
  border-radius: 16px;
  background: var(--key_white, #fff);
  padding: 40px 16px;
  margin-top: 24px;
}

@media (min-width: 769px) {
  .o-formArea .m-formArea-wrap {
    margin-top: 40px;
    padding: 0;
  }
} /*# sourceMappingURL=form.css.map */