@charset "utf-8";

html,body {
  background: var(--white);
}

main {
margin-top: 125px;
}

main.plain {
margin-top: 60px;
}

.contents_inner {
  width: 100%;
  max-width: 960px;
  background: var(--white);
  margin: 0 auto;
  padding: 15px 15px 70px;
  overflow: hidden;
}

.contents_inner.bg2 {
  max-width: 1280px;
  padding: 0 15px 70px;
  background: var(--light-gray);
}

h2 {
  width: 100%;
  text-align: center;
  font-size: 22px;
  margin: 10px 0 20px;
}

p {
  line-height: 1.5;
}

.select_wrap {
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
  position: relative;
  text-align: center;
}

.select_wrap::before {
  position: absolute;
  top: 20px;
  right: 13px;
  content: '';
  width: 12px;
  height: 8px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background-color: var(--dark-gray);
  pointer-events: none;
}

.select_wrap #select_type {
  width: 100%;
  height: 45px;
  background: var(--white);
  border: 1px solid;
  border-radius: 25px;
  border-color: var(--medium-gray);
  font-size: var(--font14-16);
  padding-left: 20px;
  line-height: 45px;
}

.contents_inner.bg2 .tab_switch,
.contents_inner .tab_switch {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 100vw;
  overflow: hidden;
  margin: 0 0 0 -15px;
}

.contents_inner.bg2 .tab_switch {
  max-width: 1280px;
}

.contents_inner .tab_switch {
  max-width: 960px;
}

.tab_switch label.tab_menu {
  width: 100%;
  padding: 30px 0 8px;
  background: var(--white);
  cursor: pointer;
  order: -1;
  text-align: center;
  color: var(--black);
  display: flex;
  align-items: center;
  justify-content: center;
}

.tab_menu_wrap {
  width: 50%;
  border-bottom: 1px solid var(--medium-gray);
  order: 1;
}

.tab_menu_wrap input {
  display: none;
}

.tab_outer {
  display: none;
  width: 100%;
  padding: 20px 10px;
  order: 2;
}

.tab_inner {
  width: calc(100% - 10px);
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: space-between;
  max-width: 820px;
  margin: 0 auto;
}

.tab_menu_wrap label:has(:checked) {
  color: var(--orange);
  font-weight: 700;
  border-bottom: 3px solid var(--orange);
}

.tab_menu_wrap:has(input[name="contents_tab"]:checked) + .tab_outer {
  display: block;
}

.tab_switch .tbc::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background: url("../images/exm.svg") no-repeat;
  background-size: contain;
  filter: invert(36%) sepia(96%) saturate(4249%) hue-rotate(345deg) brightness(112%) contrast(108%);
  margin-left: 5px;
}

.btn_disabled {
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
}

.btn_disabled button,
.btn_disabled button:hover {
  display: flex;
  width: 100%;
  height: 50px;
  cursor: default;
  font-weight: 700;
  font-size: var(--font14-16);
  border-radius: 8px;
  text-align: center;
  border: none;
  justify-content: center;
  align-items: center;
}

.btn_disabled button {
  transition: var(--transition);
  background: var(--medium-gray);
  color: var(--dark-gray);
}

.btn_disabled button:disabled {
  cursor: inherit;
}

p.hint {
  color: #888;
  font-size: 11px;
  margin-top: 4px;
}

@media screen and (min-width: 360px) {
  main {
    margin-top: 105px;
  }
}

@media screen and (min-width: 430px) {
  .tab_switch label.tab_menu {
    width: 100%;
    padding: 30px 0 8px;
    background: var(--white);
    cursor: pointer;
    order: -1;
    text-align: center;
    color: var(--black);
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

@media screen and (min-width: 1024px) {
  html,body {
    background: var(--light-gray);
  }

  .contents_inner {
    border-radius: 20px;
    margin: 30px auto;
    padding: 30px 50px 80px 50px;
  }

  .contents_inner .tab_switch {
    margin: 0 0 0 -50px;
  }

  .tab_switch label.tab_menu {
    padding: 30px 0 15px;
  }

  .tab_outer {
    padding: 30px 10px;
  }
}

@media screen and (min-width: 1280px) {
  .contents_inner.bg2 {
    background: var(--white);
  }

  .tab_outer {
    padding: 30px 40px;
  }

  .contents_inner.bg2 .tab_switch .tab_inner {
    width: 100%;
    max-width: 1240px;
    column-gap: 20px;
  }
}
