/* ================================================== */
@charset "utf-8";


.barh2 {
    padding:0 .4em .2em;
    border-bottom: 3px solid var(--002-color);
	font-size: 2.5rem;
}
.barh3 {
    padding:0 .4em .2em;
    border-bottom: 3px dashed var(--primary-color);
	color: var(--pickup-font-color);
}

/*========= news ===============*/
.topnews {
	float: left;
	margin: 0;
	padding: 0;
	display: block;
}
.topnews dl {
	width: 100%;
	border-bottom: 1px #000 dotted;
	line-height: 180%;
	margin: 5px 0;
	padding: 10px 0;
	float: left;
	display: block;
}
.topnews dt {
	width: 20%;
	float: left;
	margin: 0;
	padding: 0;
	display: block;
	text-align: left;
}
.topnews dt a {
	text-decoration: none;
}
.topnews dd {
	width: 79%;
	float: right;
	margin: 0;
	padding: 0 0 0 15px;
	display: block;
	text-align: left;
}
.topnews dd a {
	text-decoration: none;
}
a.anchor {
    display: block;
    padding-top: 70px;
    margin-top: -70px;
}
@media(max-width: 768px){
.topnews dt {
	width: 100%;
	float: left;
	margin: 0;
	padding: 0;
	display: block;
}
.topnews dd {
	width: 109%;
	float: left;
	margin: 0;
	padding: 0;
	display: block;
}
}
.new-pdf {
	display:inline-block;
	background: var(--sub2-color);
	padding:10px 30px;
	text-align:center;
	color: var(--white-color);
	margin:5px;
	border:1px solid;
	cursor:pointer;
    font-weight: 600;
    font-size: 1.25em;
    border: none;
    border-radius: 5px;
	line-height: 200%;
	width: 150px;
}
.new-pdf span {
	line-height: 180%;
    font-size: 1em;
}
.new-pdf a:hover {
    background-color: var(--sub3-color);
    color: var(--standard-color);
}
.new-link {
	display:inline-block;
	background: var(--sub4-color);
	padding:10px 30px;
	text-align:center;
	color: var(--white-color);
	margin:5px;
	border:1px solid;
	cursor:pointer;
    font-weight: 600;
    font-size: 1.25em;
    border: none;
    border-radius: 5px;
	line-height: 200%;
	width: 150px;
}
.new-link span {
	line-height: 180%;
    font-size: 1em;
}
.new-link:hover {
    background-color: var(--sub5-color);
    color: var(--standard-color);
}


.card img {
    max-width: 320px;  /* 画像の最大幅 */
    height: auto;  /* 縦横比を維持したまま高さ調整 */
    object-fit: contain; /* 画像のトリミングを防ぐ */
}




/* table001 */
.table.company-info-table {
    max-width: 100%;
    margin: 0 auto;
    border-collapse: collapse;
    background-color: #fff;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    overflow: hidden;
}

.table.company-info-table th {
    background-color: var(--bg-dark-2);
    color: #fff;
    font-weight: bold;
    text-align: left;
    padding: 12px 15px;
    width: 35%;
}


.table.company-info-table td {
    padding: 12px 15px;
    border-bottom: 1px solid #ddd;
}


.table.company-info-table tr:last-child td {
    border-bottom: none;
}


@media (max-width: 768px) {
    .table.company-info-table th, 
    .table.company-info-table td {
        display: block;
        width: 100%;
        text-align: left;
        padding: 10px;
    }
    .table.company-info-table th {
        background-color: #e11360;
    }
}


/* table002 */
.table.history-table {
    max-width: 100%;
    margin: 0 auto;
    border-collapse: collapse;
    font-size: 1rem;
    background-color: #fff;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    overflow: hidden;
}


.table.history-table th {
    background-color: #e11360;
    color: #fff;
    font-weight: bold;
    text-align: center;
    padding: 12px 15px;
    width: 30%;
}


.table.history-table td {
    padding: 12px 15px;
    border-bottom: 1px solid #e11360;
}


.table.history-table tr:last-child td {
    border-bottom: none;
}


.table.history-table td:first-child {
    font-weight: bold;
    color: #e11360;
    text-align: center;
}


@media (max-width: 768px) {
    .table.history-table th, 
    .table.history-table td {
        display: block;
        width: 100%;
        text-align: left;
        padding: 10px;
    }
    .table.history-table td:first-child {
        text-align: left;
    }
}

.result-box {
  background-color: #f6f6f6;
  padding: 12px 15px;
  border-radius: 6px;
  font-size: 14px;
  text-align: center;
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

.result-box.alt {
  background-color: #e8fce6;
}

.custom-btn {
  display: inline-block;
  padding: 0.375rem 0.75rem;
  font-size: 0.875rem;
  font-weight: 500;
  border-radius: 0.25rem;
  text-decoration: none;
  transition: background-color 0.2s, color 0.2s, border-color 0.2s;
  cursor: pointer;
  outline: none;
  box-shadow: none;
  transform: none;
  border: 1px solid transparent;
}

/* Primary（青） */
.btn-primary {
  color: #0d6efd;
  background-color: transparent;
  border-color: #0d6efd;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
  background-color: #0d6efd;
  color: #fff;
  border-color: #0d6efd;
  box-shadow: none;
  transform: none;
}

/* Success（緑） */
.btn-success {
  color: #198754;
  background-color: transparent;
  border-color: #198754;
}

.btn-success:hover,
.btn-success:focus,
.btn-success:active {
  background-color: #198754;
  color: #fff;
  border-color: #198754;
  box-shadow: none;
  transform: none;
}

  .list-group-item {
    background-color: transparent;
    border: none;
    padding-left: 0;
    padding-right: 0;
  }


.qa-1 {
    max-width: 100%;
    margin-bottom: 7px;
    border: 1px solid #d6dde3;
    border-radius: 5px;
}

.qa-1 summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    padding: 1em 2em 1em 3em;
    color: #333333;
    font-weight: 600;
    cursor: pointer;
}

.qa-1 summary::before,
.qa-1 p::before {
    position: absolute;
    left: 1em;
    font-weight: 600;
    font-size: 1.3em;
}

.qa-1 summary::before {
    color: #75bbff;
    content: "Q";
}

.qa-1 summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 7px;
    height: 7px;
    margin-left: 10px;
    border-bottom: 3px solid #333333b3;
    border-right: 3px solid #333333b3;
    content: '';
    transition: transform .5s;
}

.qa-1[open] summary::after {
    transform: rotate(225deg);
}

.qa-1 p {
    position: relative;
    transform: translateY(-10px);
    opacity: 0;
    margin: 0;
    padding: .3em 3em 1.5em;
    color: #333;
    transition: transform .5s, opacity .5s;
}

.qa-1[open] p {
    transform: none;
    opacity: 1;
}

.qa-1 p::before {
    color: #ff8d8d;
    line-height: 1.2;
    content: "A";
}


.job-info-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 1rem;
  color: #333;
  background-color: transparent;
  border-spacing: 0;
}

.job-info-table th,
.job-info-table td {
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid #ccc;
  vertical-align: top;
}

.job-info-table th {
  width: 30%;
  font-weight: 600;
  color: #222;
  background-color: transparent;
}

/* モバイル対応 */
@media (max-width: 600px) {
  .job-info-table th,
  .job-info-table td {
    display: block;
    width: 100%;
    padding: 10px;
  }

  .job-info-table th {
    background-color: #f9f9f9;
    border-bottom: none;
    margin-top: 10px;
  }

  .job-info-table td {
    border-bottom: 1px solid #ddd;
  }
}