/* ============================================================
   IYOSUI Theme - Contact group
   (contact / recruit / compliance / privacy)
   ============================================================ */

/* ---- Contact info cards ---------------------------------- */
.contact-info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-md);
}

.contact-info-card {
  text-align: center;
  padding: var(--sp-md);
  background: var(--color-bg);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
}

.contact-info-card__label {
  display: inline-block;
  font-family: var(--font-en);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .14em;
  color: var(--color-primary);
  margin-bottom: .6em;
}

.contact-info-card__value {
  font-size: 1.4rem;
  font-weight: 700;
  font-family: var(--font-en);
  margin-bottom: .4em;
  line-height: 1.3;
}

.contact-info-card__value a:hover { color: var(--color-primary); }

.contact-info-card__sub {
  font-size: .8rem;
  color: var(--color-text-sub);
  line-height: 1.6;
}

/* ---- Form ------------------------------------------------ */
.contact-form { margin-top: var(--sp-md); }

.form-group { margin-bottom: var(--sp-md); }

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-md);
}

.form-label {
  display: block;
  font-size: .9rem;
  font-weight: 700;
  margin-bottom: .5em;
}

/* カンプ準拠: 赤文字「※必須」 */
.req {
  margin-left: .6em;
  font-size: .8rem;
  font-weight: 500;
  color: #E0492F;
}

.req::before { content: '※'; }

.form-control {
  width: 100%;
  padding: .75em 1em;
  font-size: .95rem;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  transition: border-color var(--transition), box-shadow var(--transition);
}

.form-control:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(0,128,172,.12);
}

textarea.form-control { resize: vertical; min-height: 8em; line-height: 1.8; }

.form-radio-group {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem 1.5rem;
}

.form-radio,
.form-check {
  display: inline-flex;
  align-items: center;
  gap: .5em;
  font-size: .9rem;
  cursor: pointer;
}

.form-radio input,
.form-check input { accent-color: var(--color-primary); width: 1.1em; height: 1.1em; }

.form-check a { color: var(--color-primary); text-decoration: underline; }

.form-message {
  margin-top: var(--sp-md);
  font-size: .9rem;
  text-align: center;
}

.form-message.is-error   { color: #c0392b; }
.form-message.is-success { color: var(--color-accent-green); }

/* ---- Recruit: value cards (circles) ---------------------- */
.value-card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-md);
  justify-items: center;
}

.value-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: .35rem;
  width: 100%;
  max-width: 280px;
  aspect-ratio: 1/1;
  padding: var(--sp-md);
  border-radius: 50%;
}

/* カンプ準拠: グレージュ / グリーン / ゴールドの淡いサークル */
.value-card:nth-child(1) { background: rgba(122,140,134,.20); }
.value-card:nth-child(2) { background: rgba(122,150,96,.22); }
.value-card:nth-child(3) { background: rgba(196,164,110,.26); }

.value-card__keyword {
  font-family: var(--font-en);
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: .04em;
}

.value-card:nth-child(1) .value-card__keyword { color: #5F7268; }
.value-card:nth-child(2) .value-card__keyword { color: #5E7E47; }
.value-card:nth-child(3) .value-card__keyword { color: #9A7B3F; }

.value-card__ja { font-size: .9rem; font-weight: 700; }

.value-card__title {
  font-size: .72rem;
  color: var(--color-text-sub);
  letter-spacing: .02em;
}

.value-card__desc {
  font-size: .8rem;
  line-height: 1.8;
  color: var(--color-text-sub);
  margin-top: .3rem;
}

/* ---- Recruit: desired profile ---------------------------- */
.recruit-points {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-sm);
}

.recruit-point {
  position: relative;
  padding: 1rem 1.25rem 1rem 2.75rem;
  background: var(--color-bg-light);
  border-radius: var(--radius);
  font-size: .92rem;
  font-weight: 500;
}

.recruit-point::before {
  content: '✓';
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-primary);
  font-weight: 700;
}

/* ---- Recruit: job table ---------------------------------- */
.recruit-table { width: 100%; font-size: .9rem; }

.recruit-table th,
.recruit-table td {
  padding: 1em 1.25em;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid var(--color-border-light);
  line-height: 1.8;
}

.recruit-table th {
  width: 11em;
  font-weight: 700;
  color: var(--color-primary-dark);
  background: var(--color-bg);
  white-space: nowrap;
}

/* ---- FAQ ------------------------------------------------- */
.faq-list { display: flex; flex-direction: column; gap: var(--sp-sm); }

.faq-item {
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.faq-item dt {
  position: relative;
  padding: 1.1em 1.5em 1.1em 3em;
  background: var(--color-bg-light);
  font-weight: 700;
  font-size: .95rem;
}

.faq-item dt::before {
  content: 'Q';
  position: absolute;
  left: 1.25em;
  color: var(--color-primary);
  font-family: var(--font-en);
  font-weight: 800;
}

.faq-item dd {
  position: relative;
  padding: 1.1em 1.5em 1.1em 3em;
  font-size: .9rem;
  line-height: 1.9;
  color: var(--color-text-sub);
}

.faq-item dd::before {
  content: 'A';
  position: absolute;
  left: 1.25em;
  color: var(--color-accent-warm);
  font-family: var(--font-en);
  font-weight: 800;
}

/* ---- Compliance / Privacy prose -------------------------- */
.compliance-list { display: flex; flex-direction: column; gap: 1.25rem; margin-block: var(--sp-md); }

.compliance-list dt {
  font-weight: 700;
  font-size: 1rem;
  color: var(--color-primary-dark);
  padding-left: .75em;
  border-left: 4px solid var(--color-primary);
  margin-bottom: .4em;
}

.compliance-list dd { font-size: .92rem; line-height: 1.9; color: var(--color-text-sub); padding-left: 1em; }

.prose-section h2 {
  font-size: 1.3rem;
  margin-top: 2em;
  margin-bottom: .75em;
  padding-left: .75em;
  border-left: 4px solid var(--color-primary);
}

.prose-section p { line-height: 1.95; color: var(--color-text-sub); }

/* ---- Responsive ------------------------------------------ */
@media (max-width: 760px) {
  .contact-info-grid,
  .value-card-grid { grid-template-columns: 1fr; }
  .value-card { max-width: 240px; }
  .form-row,
  .recruit-points { grid-template-columns: 1fr; }
}
