@charset "UTF-8";

/*LED導入シミュレーション*/
.Sim {
    width:100%;
    max-width:calc(1050vw / 12.8);
    margin: 90px auto 0;
    background:#cde8f9;
    border:1px solid #959595;
    border-radius:calc(15vw / 9.6);
    padding:55px 0 55px;
  }
  .Sim .sp {
    display: none;
  }
  .Sim .radiusTl {
    border-top-left-radius: 5px;
  }
  .Sim .radiusBl {
    border-bottom-left-radius: 5px;
  }
  .Sim h3 {
    position: relative;
    display: inline-block;
    left: 50%;
    transform: translateX(-50%);
    margin:0 auto 10px;
    padding: .2em 1em .5em;
    font-size:3.6rem;
    background: #b1ce77;
    border: 1px solid #959595;
    border-radius: 5px;
    text-align:center;
  }
  .Sim h3::before {
    content: "";
    position: absolute;
    bottom: -24px;
    left: 50%;
    margin-left: -15px;
    border: 12px solid transparent;
    border-top: 12px solid #b1ce77;
    z-index: 1;
  }
  .Sim h3::after {
    content: "";
    position: absolute;
    bottom: -25px;
    left: 50%;
    margin-left: -15px;
    border: 12px solid transparent;
    border-top: 12px solid #959595;
  }
  .Sim h3 span {
    background: linear-gradient(transparent 80%, #fffac3 80%);
    font-size: 3rem;
    font-weight:600;
  }
  .Sim .tab .sim-guide {
    max-width: 100%;
    width: 100%;
    margin: 0 0 10px 0;
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 1.6;
    text-align: left;
    background: none !important;
    border: none !important;
    border-radius: 0 !important;
    height: auto !important;
    letter-spacing: normal;
    box-shadow: none;
  }
  .Sim .tab .sim-guide-step1 {
    margin-bottom: 5px;
  }
  .Sim .tab .sim-guide-step2 {
    margin-top: 5px;
    margin-bottom: 5px;
  }
  .Sim dl {
    box-shadow: none;
  }
  .Sim .tab {
    max-width: 90%;
    margin: 0 auto;
  }
  .Sim .tab ul {
    display: flex;
    justify-content: space-between;
    text-align: center;
  }
  .Sim .tab li {
    width: 32%;
    margin: 5px 0 5px;
    padding: 1em;
    border: 1px solid #959595;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
    word-wrap: break-all;
    cursor: pointer;
    background: #f2f2f2;
  }
  .Sim .tab li.active {
    background: #fffac3;
  }
  .Sim .tab li span {
    display: block;
    margin-bottom: 5px;
    font-weight: bold;
    font-size: 1.2em;
  }
  .Sim .tab .tabContent {
    position: relative;
  }
  .Sim .tab .tabContent dl {
    position: absolute;
    width: 100%;
    opacity: 0;
    visibility: hidden;
    transition: opacity .4s ease;
  }
  .Sim .tab .tabContent dl.show {
    position: relative;
    display: flex;
    opacity: 1;
    visibility: visible;
  }
  .Sim .tabContent dl {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    margin: 0 auto 55px;
    padding: 0;
    background: none;
  }
  .Sim .tabContent dt {
    display: flex;
    align-items: center;
    width: 20em;
    margin: 0;
    padding: 10px 20px;
    background: #fff;
  }
  .Sim .tabContent dd {
    display: block;
    width: calc(100% - 20em);
    margin: 0;
    padding: 10px 20px;
  }
  .Sim .tabContent dd input {
    width: calc(100% - 3em);
    max-width: 400px;
    margin-right: 5px;
    padding: .5em;
  }
  .Sim .tabContent .underline {
    border-bottom: 1px dashed #959595;
  }
  .Sim .BtnSim {
    margin: 0 auto 55px;
    text-align: center;
  }
  .Sim .BtnSim a {
    padding: .5em 2em;
    background: #b1ce77;
    border: 1px solid #959595;
    border-radius: 100px;
    cursor: pointer;
  }
  .Sim .resultsSim {
    display: none; /* 初期状態では非表示（ボタン押下後に表示） */
    flex-wrap: wrap;
    align-items: stretch;
    max-width: 90%;
    margin: 0 auto;
    padding: 0;
    background: none;
  }
  .Sim .resultsSim.is-visible {
    display: flex;
  }
  .Sim .resultsSim dt {
    display: flex;
    align-items: center;
    width: 20em;
    margin: 0;
    padding: 10px 20px;
    background: #b1ce77;
  }
  .Sim .resultsSim dd {
    display: flex;
    align-items: center;
    width: calc(100% - 20em);
    margin: 0;
    padding: 10px 20px;
    background: #fff;
  }
  .Sim .resultsSim .underline {
    border-bottom: 1px dashed #959595;
  }
  .Sim .tabContent dd .error {
    display: block;
    margin-top: 4px;
    color: #c00;
    font-size: 0.9em;
  }
  .Sim .sim-note-led {
    display: none;
    max-width: 90%;
    margin: 15px auto 0;
    font-size: 1.4rem;
    line-height: 1.8;
    text-align: left;
    background: none !important;
    border: none !important;
    border-radius: 0 !important;
    height: auto !important;
    letter-spacing: normal;
    box-shadow: none;
  }

  /*for SP*/
@media screen and (min-width:0) and (max-width:960px) {
    .Sim {
        border:none;
        width:100%;
        max-width:100%;
        margin: 145px auto 0;
      }
      .Sim .sp {
        display: block;
      }
      .Sim h3 {
        padding: 0 1em .5em;
      }
      .Sim h3 span {
        font-size:calc(3.5rem / 1.7);
      }
      .Sim .resultsSim dt, .Sim .tabContent dt {
        width: 10em;
      }
      .Sim .resultsSim dd, .Sim .tabContent dd {
        width: calc(100% - 10em);
      }
      .Sim h3 {
        margin-bottom: 5px;
      }
      .Sim .tab .sim-guide {
        margin-bottom: 2px;
      }
      .Sim .tab li {
        margin-top: 0;
      }
      .Sim .tab .sim-guide-step2 {
        margin-top: 5px;
        margin-bottom: 2px;
      }
}
