/*=========================================
ホームページ制作
==========================================*/
.planListArea {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.planList {
  width: 42%;
  margin: 30px 0 0;
}

.planList p.plan_name {
  text-align: center;
  color: #fff;
  background: #b86e55;
  padding: 10px 0;
  border-radius: 6px;
  font-weight: bold;
}

.planList ul.site_name {
  margin: 10px auto;
  display: flex;
  justify-content: space-between;
}

.planList ul.site_name li {
  width: 48%;
  text-align: center;
  gap: 0 20px;
  padding: 10px 5px 14px;
  font-weight: bold;
  border-bottom: 2px solid #b86e55;
}
@media (max-width: 1010px) {
}

.planList .price_box {
  display: flex;
}

.service_list_box {
  display: flex;
  justify-content: space-between;
}

.service_list_box ul {
  width: 50%;
  text-align: center;
  font-weight: bold;
  margin: 20px auto 0;
}
.plan-note {
  padding-block: 20px;
}
ul.service_list li {
  margin: 0px auto 10px;
  text-align: center;
  border-bottom: 2px dashed #f9f5f0;
  padding: 0px 0 10px;
  font-size: 20px;
  color: #b86e55;
}
ul.service_list.list_txt {
  width: 447px;
  margin: 0 5px;
  position: relative;
  bottom: -13px;
}
ul.service_list.list_txt li {
  position: relative;
  bottom: 5px;
}

ul.service_list.list_txt li {
  font-size: 14px;
  border: none;
  background: #f9f5f0;
  color: inherit;
  border-radius: 6px;
  padding: 10px;
  margin: 12px 0;
}

ul.service_list.list_txt li:nth-child(5) {
  line-height: 16px;
}

.planList .price_txt {
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  margin: 0px auto;
  color: #b86e55;
}
@media (max-width: 1010px) {
  .planList .price_txt {
    font-size: 23px;
  }
}
.planList .price_txt span.zeikomi {
  font-size: 18px;
}
@media (max-width: 1010px) {
  .planList .price_txt span.zeikomi {
    font-size: 16px;
  }
}
.type_box .type_inner .price_txt span.kome {
  font-size: 18px;
}

@media (max-width: 1010px) {
}
.compare-table {
  width: 100%;
  border-collapse: collapse;
  text-align: center;
  background-color: #fff;
  margin: 10px 0;
}
.compare-table td:not(:first-child){
     color: #b86e55;
    font-weight: bold; 
}
.compare-table th,
.compare-table td {
  border: 1px solid #eee7e0;
  padding: 8px 6px;
  white-space: nowrap;
  vertical-align: middle;
}
.compare-table th{
  padding: 8px 0;
}
.compare-table thead tr:first-child th:first-child,
.compare-table tbody td:first-child,
.compare-table tbody th:first-child {
  position: sticky;
  left: 0;
}

/* 1列目は幅を自動または固定 */
.compare-table td:first-child,
.compare-table th:first-child {
  left: 0;
  width: auto; /* 必要なら固定幅にしてもOK（例：160px） */
}

/* 2列目以降を均等幅に */
.compare-table td:not(:first-child),
.compare-table th:not(:first-child) {
  width: 75px; /* 必要に応じて調整 */
  min-width: 75px;
  max-width: 75px;
}

.compare-table thead th {
  background-color: #b86e55;
  color: #fff;
  font-weight: bold;
}

.compare-table td:first-child {
  text-align: left;
  font-weight: bold;
  background: #f9f5f0;
}

.text-orange {
  font-weight: 500;
}

/* スクロール対応 */
.table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
/*=========================================
保守・更新
==========================================*/
.hosyu .planList {
  width: 48%;
}
@media (max-width: 1010px) {
  .planListArea {
    flex-wrap: wrap;
  }
  .hosyu .planList {
    width: 100%;
  }
  .planList {
    width: 100%;
    position: relative;
  }
  .planList:last-child {
    margin-top: 10px !important;
  }
  .planList ul.site_name {
    display: block;
  }

  .planList ul.site_name li {
    width: 100%;
    text-align: left;
    position: relative;
    border-bottom: none;
  }

  .planList ul.site_name li:after {
    content: "";
    width: 100px;
    height: 1px;
    margin-left: 10px;
    border: 1px dashed #eee7e0;
    position: absolute;
    margin: auto;
    top: 22px;
    z-index: 0;
  }

  .planList .price_box {
    display: block;
    position: absolute;
    top: 53px;
    right: 10px;
    background: #fff;
    padding-left: 10px;
  }
}
.maintenanceList {
  list-style-type: disc;
  padding-left: 20px;
  margin-bottom: 10px;
}

/*=========================================
オプション料金・スポット対応
==========================================*/
.op_price {
  background: #fff;
  border-radius: 6px;
  padding: 30px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0 30px;
  margin-top: 30px;
}

.op_price ul {
  width: 47%;
}

@media (max-width: 767px) {
  .op_price ul {
    width: 100%;
  }
}

.op_price ul li {
  position: relative;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  padding-bottom: 8px;
}

.op_price ul li::before {
  content: "";
  width: 100%;
  height: 1px;
  border: 1px dashed #eee7e0;
  position: absolute;
  margin: auto;
  top: 12px;
  z-index: 0;
}
.op_price ul li span {
  position: relative;
  background: #fff;
}
.op_price ul li span.name_op {
  padding: 0 10px 0 0;
}
.op_price ul li span.kingaku {
  font-size: 1.4rem;
  padding: 0 0 0 10px;
  font-weight: bold;
}
@media (max-width: 1010px) {
  .spot {
    margin-bottom: 50px;
  }
}



.step { display: none; opacity: 0; transform: translateX(50px); transition: 0.5s; }
.step.active { display: block; opacity: 1; transform: translateX(0); }

.cards { display: flex; gap: 15px; overflow-x: auto; padding-bottom: 10px; position: relative; }
.card {
  background: #fff;
  border: 2px solid #ccc;
  border-radius: 12px;
  padding: 20px;
  cursor: pointer;
  flex: 0 0 200px;
  text-align: center;
  transition: 0.3s;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
  position: relative;
}
.card:hover { transform: scale(1.05); }
.card.selected { border-color: #007bff; background: #e0f0ff; box-shadow: 0 4px 15px rgba(0,123,255,0.3); }

button { margin-top: 15px; padding: 10px 20px; border:none; border-radius:5px; background:#007bff; color:#fff; cursor:pointer; }
button:disabled { background:#ccc; cursor: not-allowed; }

.summary { background:#fff; padding:15px; border-radius:10px; margin-top:20px; box-shadow:0 2px 5px rgba(0,0,0,0.1); position:relative; min-height:60px;}
.summary-item { margin-bottom:8px; }

@media(max-width:600px){
  .card { flex: 0 0 150px; padding:15px; font-size:14px; }
}