/*====================
content
====================*/
#content {
  clear: both;
  padding-top: 27px;
  padding-bottom: 27px;
}

#content h2 {
  font-size: 22px;
  font-weight: bold;
  color: #7A2D52;
  line-height: 26px;
  padding-left: 8px;
  border-left: 4px solid #B46185;
}

.section {
  background: #ECF0F8;
  padding: 10px;
  box-sizing: border-box;
  margin-top: 16px;
}

.item_number {
  display: none;
}

#content .kakomi {
  padding: 0px;
  width: 470px;
  float: left;
  margin: 0px 20px 0px 0;
  border: none;
  position: relative;
}

#content .kakomi.last {
  margin: 0px 0px 0 0;
}

.shirobg {
  background: #FFF;
}

.ueake {
  margin-top: 10px;
}

#content .kakomi .nuri {
  background: #4D629A;
  padding-top: 9px;
  padding-bottom: 12px;
  text-align: center;
}

#content .kakomi .nuri h3 {
  font-size: 1.8rem;
  line-height: 23px;
  color: #fff;
  text-align: center;
}

.kaisetsu {
  padding: 30px;
}

.kaisetsu h3 {
  text-align: center;
  font-size: 1.6rem;
  color: #3f3f3f;
  text-shadow: none;
  padding-left: 15px;
}

h4 {
  font-size: 1.3rem;
  color: #3f3f3f;
}

.page-summary {
  font-size: 16px;
}

.domain_content {
  display: flex;
  justify-content: center;
  border: 4px dashed #ECF0F8;
  align-items: center;
  padding: 10px;
  width: 70rem;
}

.contact_content {
  padding: 10px;
}

.description {
  font-size: 0.9rem;
}

.description dt {
  margin-top: 10px;
  color: #7B2E53;
  font-weight: bold;
}

.description dd {
  text-align: justify;
  font-size: 14px;
  line-height: 1.4;
  padding-left: 14px;
}

.list {
  list-style-type: disc;
  list-style-position: inside;
}

.step {
  list-style-type: decimal;
  list-style-position: inside;
  margin-bottom: 5px;
}

.step li {
  margin-top: 10px;
}

.step img {
  margin-top: 5px;
  display: block;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.4);
  width: 50%;
}

.step .note {
  display: block;
  font-size: 12px;
  color: #d31b00;
  line-height: inherit;
}

.input-form {
  display: block;
  line-height: 2;
  margin: 5px 0;
}

div.input-form {
  text-align: center;
}

div.input-form input[type="button"] {
  margin: 10px;
}

div.notice {
  margin-top: 15px;
}

.section_title {
  display: inline-flex;
  align-items: end;
}

.bold {
  font-weight: bold;
  color: #3f3f3f;
  /* font-size: large; */
}

.border {
  border-bottom: 1px solid #3f3f3f;
}

.size-large {
  font-size: larger;
}

.size-small {
  font-size: smaller;
}

.margin-bottom-5 {
  margin-bottom: 5px;
}

.mail_section {
  display: flex;
  border: 2px solid #3f3f3f;
  width: 100%;
  margin: 1rem 0 1.2rem 0;
}

.qr_item {
  /* border-right: 2px; */
  border-right: 2px solid #3f3f3f;
}

.ql_item_header {
  background: #ECF0F8;
  padding: 10px;
  text-align: center;
  border-bottom: 2px solid #979797;
}

.ql_item_header p {
  font-size: 13px;
}

.ql_item_content {
  display: flex;
  justify-content: space-evenly;
}

.ql_item_content p {
  font-size: 14px;
  padding-top: 6px;
}

.ql_item_content h4 {
  width: 70%;
  text-align: center;
  line-height: 2.5;
}

p.qr_item_title {
  background: #3d3d3d;
  font-size: 1rem;
  text-align: center;
  font-weight: bold;
  /* line-height: 1.5; */
  /* vertical-align: middle; */
  color: #ebebeb;
}

.supplement {
  font-size: 0.9rem;
  margin-top: 1rem;
}

.flex_box_row {
  display: flex;
  justify-content: space-between;
}

.qr_item_list {
  display: flex;
  justify-content: space-around;
  width: 18rem;
  /* height: 7rem; */
  padding: 10px;
  border: 7px dashed #ECF0F8;
}
.ql_item_description {
  width: 100%;
  overflow: hidden;
}

.icon_list {
  display: flex;
  gap: 6px 10px;
  margin-top: 1.5rem;
}

.text_box {
  /* width: 200px; */
  position: relative;
  font-size: 0.8rem;
  padding: 20px 10px 10px 10px;
}

.item_box {
  display: flex;
  /* width: 5rem; */
  flex-direction: column;
  font-size: 0.7rem;
  text-align: center;
}

.img_box{
  width: 200px;
  position: relative;
  flex: 1;
}

.icon_1:after {
  position: absolute;
  content: "1";
  top: -10px;
  left: -15px;
  background: #AE5681;
  border-radius: 50%;
  color: #fff;
  padding: 5px 12px;
}

.icon_2:after {
  position: absolute;
  content: "2";
  top: -10px;
  left: -15px;
  background: #AE5681;
  border-radius: 50%;
  color: #fff;
  padding: 5px 12px;
}

.icon_3:after {
  position: absolute;
  content: "3";
  top: -10px;
  left: -15px;
  background: #AE5681;
  border-radius: 50%;
  color: #fff;
  padding: 5px 12px;
}

.icon_4:after {
  position: absolute;
  content: "4";
  top: -10px;
  left: -15px;
  background: #AE5681;
  border-radius: 50%;
  color: #fff;
  padding: 5px 12px;
}

.icon_5:after {
  position: absolute;
  content: "5";
  top: -10px;
  left: -15px;
  background: #AE5681;
  border-radius: 50%;
  color: #fff;
  padding: 5px 12px;
}

.img_box img {
  width: 12rem;
  overflow: hidden;
}

.operation {
  width: 100%;
  text-align: center;
}

.operation img {
  width: 30rem;
  /* text-align: center; */
  margin: 0 auto;
}

.container {
  display: flex;
  justify-content: space-between;
  gap: 5px 50px;
}

ol {
  margin: 0;
  padding: 0;
  list-style: none; 
  counter-reset: li;
  margin: 20px 0 30px 0;
}

ol li {
  position: relative;
  font-size: 0.9rem;
  padding-left: 1.6rem;
  line-height: 1.5;
}

ol li:not(:first-child) {
  margin-top: 0.5em;
}

ol li::before {
  counter-increment: li;
  content: counter(li);
  position: absolute;
  left: 0;
  top: 2px; /* 数字のY軸線上の位置を調整 */
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background-color: #8289ab;
  font-size: 12px;
  color: #fff;
  line-height: 20px;
  text-align: center;
}

@media screen and (max-width: 768px) {

  /*====================
  content
  ====================*/
  #content {
    clear:both;
    padding-top:20px;
    padding-bottom:20px;
  }
  
  #content h2 {
    font-size:18px;
    font-weight:bold;
    color:#7A2D52;
    line-height:22px;
    padding-left:7px;
    border-left:3px solid #B46185;
  }
  #content p.tyuui {
    font-size:11px;
    line-height:14px;
    margin-top:6px;
  }
  .item_number{
    display: none;
  }


  /* ======================
  section
  ====================== */

  ol li {
    font-size: 0.8rem;
    padding-left: initial;
    line-height: 1.5;
  }

  .section_title img {
    width: 1.3rem;
  }

  .kaisetsu {
    padding: 15px;
  }
  
  .kaisetsu h3 {
    font-size: 1.1rem;
    padding-left: 3px;
    line-height: 1;
  }

  .instruct {
    display: none;
  }

  .flex_box_row {
    display: initial;
  }

  h4 {
    font-size: 0.9rem;
    color: #3f3f3f;
  }

  .mail_section p{
    font-size: 10px;
  }

  .qr_item {
    text-align: center;
    border-right: 1px solid #979797;
  }

  .ql_item_header {
    background: #ECF0F8;
    text-align: left;
    border-bottom: 1px solid #979797;
  }
  
  .ql_item_content {
    display: block;
    padding: 10px;
  }

  .qr_item img {
    margin-top: 2.3rem;
  }

  .ql_item_content h4 {
    width: initial;
    text-align: center;
    line-height: initial;
  }

  .ql_item_content p {
    padding-top: 1px;
  }

  .icon_list {
    overflow-y: overlay;
    padding: 10px;
  }

  .img_box img {
    width: 10rem;
  }

  .operation img {
    width: 19rem;
  }

  .container {
    display: block;
    gap: 5px 50px;
  }

  .domain_content {
    display: block;
    padding: 10px;
    width: initial;
  }
  
  p.margin-bottom-5a {
    font-size: 0.8rem;
    margin-bottom: 0.2rem;
  }

  .size-small {
    font-size: 0.65rem;
  }

  .icon_1:after {
    left: -8px;
    padding: 1px 8px;
  }

  .icon_2:after {
    left: -8px;
    padding: 1px 8px;
  }

  .icon_3:after {
    left: -8px;
    padding: 1px 8px;
  }

  .icon_4:after {
    left: -8px;
    padding: 1px 8px;
  }
  
  .icon_5:after {
    left: -8px;
    padding: 1px 8px;
  }

  .item_number{
    display: initial;
  }

  ol li::before {
    display: none;
  }
  
}