@charset "UTF-8";
.richStateSelect {
  position: absolute;
  width: 100%;
  z-index: 1;
  overflow: hidden;
  line-height: 10px;
  color: transparent; }

.richState {
  display: none;
  position: absolute;
  z-index: 999;
  border: 2px solid #004CD4;
  border-radius: 10px;
  padding: 0 10px;
  background-color: #fff;
  margin-right: 2%;
  width: 620px; }
  .richState .areaRow {
    display: flex;
    border-bottom: 1px solid #79B8FF;
    padding: 8px 0; }
    .richState .areaRow label {
      width: 100px;
      color: #004CD4; }
    .richState .areaRow .values {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      flex: 1; }
      .richState .areaRow .values a {
        display: inline-block;
        padding: 2px 10px;
        background: #79B8FF;
        color: #ffffff;
        border-radius: 20px;
        transition: background .2s linear;
        font-size: 1.4rem; }
        .richState .areaRow .values a:hover {
          background: #004CD4; }

input::placeholder {
  color: #79B8FF;
  opacity: 1; }

input[type="text"] {
  border: 1px solid #79B8FF;
  border-radius: 4px;
  padding: 10px 12px;
  font-size: 1.6rem;
  line-height: 1.4; }
  input[type="text"]:focus {
    border-color: primary;
    outline: none; }

.form a {
  color: #004CD4; }
.form .validError {
  position: absolute;
  font-size: 1.2rem;
  background: #D4004C;
  border-radius: 20px;
  padding: 0 12px;
  color: #ffffff; }

.alert.alert-danger li {
  margin: 10px 0;
  font-weight: bold;
  color: #D4004C;
}

.form__cont {
  padding: 30px 0; }
  .form__cont p.point {
    line-height: 200%; }
.form .table {
  font-size: 1.6rem;
  width: 100%; }
  .form .table tr th {
    background: #79B8FF;
    color: #ffffff;
    width: 310px;
    padding: 36px 20px;
    text-align: left;
    border: 1px solid #ffffff; }
    .form .table tr th h2.hRequired {
      position: relative; }
      .form .table tr th h2.hRequired::after {
        position: absolute;
        content: "必須";
        color: #ffffff;
        background: #D4004C;
        font-size: 1.2rem;
        font-weight: 700;
        padding: 2px 12px;
        border-radius: 20px;
        right: 0;
        top: 0; }
  .form .table tr td {
    background: #F0F4FA;
    padding: 36px 20px;
    border: 1px solid #ffffff; }
    .form .table tr td .flexlayout {
      display: flex;
      gap: 30px;
      align-items: center;
      position: relative; }
      .form .table tr td .flexlayout.gap10 {
        gap: 10px; }
      .form .table tr td .flexlayout label {
        display: flex;
        gap: 10px; }
        .form .table tr td .flexlayout label input[type="radio"] {
          opacity: 0;
          position: absolute;
          left: -9999px; }
          .form .table tr td .flexlayout label input[type="radio"]:checked + .radio-mark::after {
            opacity: 1; }
        .form .table tr td .flexlayout label .radio-mark {
          width: 24px;
          height: 24px;
          border: 1px solid #79B8FF;
          border-radius: 50%;
          background: #ffffff;
          position: relative;
          transition: border-color 0.2s ease; }
          .form .table tr td .flexlayout label .radio-mark::after {
            content: "";
            position: absolute;
            top: 50%;
            left: 50%;
            width: 10px;
            height: 10px;
            background-color: #004CD4;
            border-radius: 50%;
            transform: translate(-50%, -50%) scale(1);
            opacity: 0;
            transition: all 0.2s ease; }
        .form .table tr td .flexlayout label.namewidth {
          width: 36px; }
          .form .table tr td .flexlayout label.namewidth--wide {
            width: 90px; }
    .form .table tr td .flexlayoutcolumn {
      display: flex;
      flex-direction: column;
      gap: 16px; }
      .form .table tr td .flexlayoutcolumn__checkbox:not(:last-of-type) {
        margin-bottom: 16px; }
    .form .table tr td .name input {
      width: 180px; }
    .form .table tr td .name .validError {
      position: absolute; }
    .form .table tr td .companystatus input {
      width: 100%; }
    .form .table tr td .address .flexlayout .required {
      width: 70px; }
    .form .table tr td .address .postcode__question {
      padding-left: 80px;
      font-size: 1.4rem; }
    .form .table tr td .address .postcode input {
      width: 100px; }
    .form .table tr td .address .postcode button {
      background: #004CD4;
      border: none;
      border-radius: 4px;
      color: white;
      padding: 8px 10px;
      font-weight: 700;
      transition: background .2s linear; }
      .form .table tr td .address .postcode button:hover {
        background: #79B8FF; }
    .form .table tr td .address .address-1 select {
      padding: 12px 8px;
      border-radius: 6px;
      border: 1px solid #79B8FF;
      background-color: white;
      font-size: 1.6rem;
      width: 226px; }
    .form .table tr td .address .address-2 input {
      width: 226px; }
    .form .table tr td .address .address-3 input {
      width: 226px; }
    .form .table tr td .address .address-4 .textAddrField {
      width: 226px;
      flex: 1; }
      .form .table tr td .address .address-4 .textAddrField input {
        width: 100%; }
    .form .table tr td .contact .required {
      width: 130px; }
    .form .table tr td .contact .dialnumber input {
      width: 90px; }
    .form .table tr td .contact .dialnumber__caption {
      padding-left: 140px;
      font-size: 1.4rem; }
    .form .table tr td .contact select {
      padding: 12px 8px;
      border-radius: 6px;
      border: 1px solid #79B8FF;
      background-color: white;
      font-size: 1.6rem;
      width: 226px; }
    .form .table tr td .mailaddress .required {
      width: 130px; }
    .form .table tr td .mailaddress .textAddField {
      flex: 1; }
      .form .table tr td .mailaddress .textAddField input {
        width: 100%; }
    .form .table tr td .kubun select {
      padding: 12px 8px;
      border-radius: 6px;
      border: 1px solid #79B8FF;
      background-color: white;
      font-size: 1.6rem;
      width: 270px; }
    .form .table tr td .kubun__select {
      position: relative; }
    .form .table tr td .kubun__result {
      position: relative; }
      .form .table tr td .kubun__result .result {
        overflow: hidden;
        height: 0;
        opacity: 0;
        transition: height 0.3s ease, opacity 0.3s ease; }
        .form .table tr td .kubun__result .result.is-active {
          height:auto;
          opacity: 1; }
        .form .table tr td .kubun__result .result .inner {
          border-radius: 3px;
          background: #D5DFEE;
          display: flex;
          flex-direction: column;
          gap: 20px;
          padding: 30px 20px; }
        .form .table tr td .kubun__result .result__title .title {
          color: #004CD4;
          position: relative;
          align-items: center;
          display: flex;
          gap: 8px; }
          .form .table tr td .kubun__result .result__title .title::after {
            content: "任意";
            color: #ffffff;
            font-size: 1.2rem;
            font-weight: 700;
            padding: 2px 12px;
            border-radius: 20px;
            background: #79B8FF; }
        .form .table tr td .kubun__result .result__title .caption {
          font-size: 1.4rem;
          padding-top: 8px; }
        .form .table tr td .kubun__result .result__text {
          font-size: 1.4rem; }
        .form .table tr td .kubun__result .result input {
          border: 1px solid #79B8FF;
          border-radius: 4px;
          padding: 10px 12px;
          font-size: 1.6rem;
          line-height: 1.4; }
    .form .table tr td .freeform__area textarea {
      width: 100%;
      height: 150px;
      border: 1px solid #79B8FF;
      border-radius: 4px; }
      .form .table tr td .freeform__area textarea::placeholder {
        color: #79B8FF;
        opacity: 1; }
.form .checklist {
  margin-top: 60px; }
  .form .checklist__title {
    background: #004CD4;
    text-align: center;
    color: #ffffff;
    padding: 20px 0; }
  .form .checklist .required--size14 {
    font-size: 1.4rem; }
  .form .checklist__input {
    position: relative; }
.form .submitbtn {
  text-align: center;
  margin: 80px 0 50px; }
  .form .submitbtn button {
    text-decoration: none;
    color: white;
    font-size: 1.6rem;
    position: relative;
    z-index: 0;
    display: flex;
    border-radius: 80px;
    overflow: hidden;
    justify-content: center;
    align-items: center;
    font-weight: 700;
    margin: 0 auto;
    border: none;
    padding: 30px 0;
    transition: opacity .2s ease-in;
    cursor: pointer; }
    .form .submitbtn button.submit {
      width: 56%;
      background: linear-gradient(302.15deg, #E6A500 0%, #F54E6C 103.68%); }
    .form .submitbtn button:hover {
      opacity: 0.5; }
  .form .submitbtn__list {
    display: flex;
    gap: 20px;
    justify-content: center;
    padding: 0 150px; }
    .form .submitbtn__list .submit {
      flex: 2;
      width: auto;
      background: linear-gradient(302.15deg, #E6A500 0%, #F54E6C 103.68%); }
    .form .submitbtn__list .prev {
      flex: 1;
      width: auto;
      background: #79B8FF; }

.form .priceMessage {
  margin-top: 10px;
  margin-bottom: 20px; }
  .form .priceMessage ul li {
    font-size: 1.4rem;
    position: relative;
    padding-left: 20px; }
    .form .priceMessage ul li::before {
      position: absolute;
      content: "※";
      top: 0;
      left: 0; }
.form .confirmName {
  display: flex;
  align-items: center; }
  .form .confirmName__label {
    padding-right: 20px;
    margin-right: 20px;
    border-right: 1px solid black; }
    .form .confirmName__label.style01 {
      width: 90px; }
    .form .confirmName__label.style02 {
      width: 156px; }
    .form .confirmName__label.style03 {
      width: 350px;
      border-right: 0px; }
.form .submitText {
  margin-top: 30px; }

.formComplate__layout {
  display: flex;
  flex-direction: column;
  gap: 30px;
  padding: 30px 0 60px; }
.formComplate__title {
  font-size: 2.4rem;
  text-align: center;
  color: #004CD4;
  font-weight: 700; }
.formComplate__text {
  line-height: 200%; }

.formError__layout {
  display: flex;
  flex-direction: column;
  gap: 30px;
  padding: 30px 0; }
.formError__title {
  font-size: 2.4rem;
  text-align: center;
  color: #004CD4;
  font-weight: 700; }

.dialinfo {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 90px; }
  .dialinfo__title {
    font-size: 2rem;
    background: #004CD4;
    width: 316px;
    text-align: center;
    color: #ffffff;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center; }
  .dialinfo__content {
    display: flex;
    gap: 10px;
    flex: 1;
    padding: 0 30px;
    align-items: center;
    background: #F0F4FA;
    height: 100%; }
    .dialinfo__content .freedial_number {
      color: #004CD4;
      font-size: 3.8rem;
      font-weight: 700; }

/* sp */
@media screen and (max-width: 768px) {
  input[type="text"] {
    padding: 6px 8px;
    font-size: 1.4rem; }

  .form .validError {
    font-size: 1.2rem;
    padding: 0 6px;
    line-height: 1.6; }
  .form .table {
    font-size: 1.4rem;
    line-height: 175%; }
    .form .table tr th {
      width: 100px;
      padding: 16px 10px; }
      .form .table tr th h2.hRequired::after {
        position: relative;
        display: table-cell;
        top: 2px;
        padding: 0px 12px; }
    .form .table tr td {
      padding: 16px 10px; }
      .form .table tr td .flexlayout {
        gap: 15px;
        flex-direction: column;
        align-items: flex-start; }
        .form .table tr td .flexlayout.flex {
          flex-direction: row;
          align-items: center; }
        .form .table tr td .flexlayout label {
          display: flex;
          gap: 10px; }
          .form .table tr td .flexlayout label.namewidth--wide {
            width: 90px; }
        .form .table tr td .flexlayout.gap10 {
          gap: 5px; }
      .form .table tr td .name input {
        width: 120px; }
      .form .table tr td .address .postcode__question {
        padding-left: 0;
        font-size: 1.2rem; }
      .form .table tr td .address .postcode button {
        margin-top: 10px; }
      .form .table tr td .address .address-1 select {
        padding: 6px 8px;
        width: 140px;
        font-size: 1.4rem; }
      .form .table tr td .address .textAddrField .address-2 input {
        width: 100%; }
      .form .table tr td .address .textAddrField .address-3 input {
        width: 100%; }
      .form .table tr td .contact .required {
        width: auto; }
      .form .table tr td .contact .dialnumber input {
        width: 65px; }
      .form .table tr td .contact .dialnumber__caption {
        padding-left: 0; }
      .form .table tr td .contact select {
        padding: 6px 8px;
        width: 226px;
        font-size: 1.4rem; }
      .form .table tr td .mailaddress .required {
        width: auto; }
      .form .table tr td .mailaddress .textAddField {
        width: 100%; }
      .form .table tr td .kubun select {
        padding: 6px 8px;
        width: 270px;
        font-size: 1.4rem; }
      .form .table tr td .kubun__select {
        position: relative; }
      .form .table tr td .kubun__result {
        position: relative; }
        .form .table tr td .kubun__result .result {
          overflow: hidden;
          height: 0;
          opacity: 0;
          transition: height 0.3s ease, opacity 0.3s ease; }
          .form .table tr td .kubun__result .result.is-active {
            opacity: 1; }
          .form .table tr td .kubun__result .result .inner {
            border-radius: 3px;
            background: #D5DFEE;
            display: flex;
            flex-direction: column;
            gap: 20px;
            padding: 30px 20px; }
          .form .table tr td .kubun__result .result__title .title {
            color: #004CD4;
            position: relative;
            align-items: center;
            display: flex;
            gap: 8px; }
            .form .table tr td .kubun__result .result__title .title::after {
              content: "任意";
              color: #ffffff;
              font-size: 1.2rem;
              font-weight: 700;
              padding: 2px 12px;
              border-radius: 20px;
              background: #79B8FF; }
          .form .table tr td .kubun__result .result__title .caption {
            font-size: 1.4rem;
            padding-top: 8px; }
          .form .table tr td .kubun__result .result__text {
            font-size: 1.4rem; }
          .form .table tr td .kubun__result .result input {
            border: 1px solid #79B8FF;
            border-radius: 4px;
            padding: 10px 12px;
            font-size: 1.6rem;
            line-height: 1.4; }
  .form .submitbtn {
    margin: 60px 0 25px; }
    .form .submitbtn button {
      width: 80%; }

  .form .submitbtn__list {
    padding: 0;
    gap: 10px; }
    .form .submitbtn__list .submit {
      width: 70%; }
    .form .submitbtn__list .prev {
      width: 30%; }

  .formComplate__layout {
    padding: 16px 0 30px; }
  .formComplate__title {
    font-size: 2rem; }

  .dialinfo {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: auto; }
    .dialinfo__title {
      font-size: 1.6rem;
      width: 100%;
      padding: 10px; }
    .dialinfo__content {
      flex-wrap: wrap;
      padding: 16px;
      justify-content: center; }
      .dialinfo__content .freedial_number {
        color: #004CD4;
        font-size: 3.8rem;
        font-weight: 700; }

  .formError__layout {
    padding: 16px 0; }
  .formError__title {
    font-size: 2rem; } }

/*# sourceMappingURL=dtihikari_form.css.map */
