/* ----------------------------------------------------------
   Ishikawa Alumni — Contact Form (CF7) CSS (My Page aligned)
   Goal: match mypage-card design system.
   Scope: only inside .ishikawa-contact-form.
---------------------------------------------------------- */

:root{
  --ia-text:#0f172a;
  --ia-muted:#475569;

  /* match mypage-card */
  --ia-card-bg:#fff;
  --ia-card-border: rgba(15,23,42,.08);
  --ia-card-shadow: 0 14px 40px rgba(15,23,42,.06);
  --ia-card-radius: 18px;

  /* match mypage focus */
  --ia-focus-border: rgba(37,99,235,.65);
  --ia-focus-ring: rgba(37,99,235,.18);

  /* primary button (same tone as your ACF) */
  --ia-btn-bg:#0b1a3a;
  --ia-btn-shadow: 0 12px 28px rgba(15,23,42,.10);

  --ia-danger:#b91c1c;
}

/* ============ Wrapper / Card ============ */
.ishikawa-contact-form{
  background: var(--ia-card-bg);
  border: 1px solid var(--ia-card-border);
  border-radius: var(--ia-card-radius);
  box-shadow: var(--ia-card-shadow);
  padding: 22px 24px; /* match .mypage-card */
  color: var(--ia-text);
  line-height: 1.75;

  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "palt";
  box-sizing: border-box;
}
.ishikawa-contact-form *{ box-sizing:border-box; }

.ishikawa-contact-intro{
  margin: 0 0 14px;
  color: var(--ia-muted);
  line-height: 1.9;
}

/* ============ CF7 Normalization ============ */
.ishikawa-contact-form br{ display:none !important; }

/* CF7の<p>が多重になりがちなので、フォーム内だけ安定化 */
.ishikawa-contact-form p{ margin: 0 0 12px; }
.ishikawa-contact-form .ishikawa-field > p{ margin: 0; }

.ishikawa-contact-form .wpcf7-form-control-wrap{ display:block; }

/* ============ Fields / Labels ============ */
.ishikawa-field{ margin: 12px 0; }

.ishikawa-label{
  display:block;
  font-size: 12.5px;  /* match mypage label */
  font-weight: 600;
  color: var(--ia-muted);
  margin-bottom: 6px;
  letter-spacing: 0;
}

.ishikawa-required{
  margin-left: .25rem;
  color: var(--ia-danger);
  font-weight: 700;
}

/* ============ Inputs (match mypage-card input) ============ */
.ishikawa-contact-form input[type="text"],
.ishikawa-contact-form input[type="email"],
.ishikawa-contact-form input[type="url"],
.ishikawa-contact-form input[type="tel"],
.ishikawa-contact-form select{
  width: 100%;
  height: 44px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.18);
  background: #fff;
  font-size: 15px;
  color: var(--ia-text);
  transition: border-color .14s ease, box-shadow .14s ease, transform .12s ease;
}

.ishikawa-contact-form textarea{
  width: 100%;
  min-height: 160px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.18);
  background: #fff;
  font-size: 15px;
  color: var(--ia-text);
  line-height: 1.6;
  resize: vertical;
  transition: border-color .14s ease, box-shadow .14s ease, transform .12s ease;
}

.ishikawa-contact-form input:focus,
.ishikawa-contact-form select:focus,
.ishikawa-contact-form textarea:focus{
  outline: none;
  border-color: var(--ia-focus-border);
  box-shadow: 0 0 0 4px var(--ia-focus-ring);
}

.ishikawa-contact-form ::placeholder{
  color: rgba(71,85,105,.65);
}

/* ============ Submit (left + compact, mypage tone) ============ */
.ishikawa-submit-wrap{
  margin-top: 14px;
  display:flex;
  justify-content:flex-start; /* ← 左寄せ */
  align-items:center;
  gap: 10px;
}

.ishikawa-contact-form input[type="submit"],
.ishikawa-submit{
  appearance:none;
  border: 0;
  cursor: pointer;

  width: auto;
  min-width: 160px;
  height: 40px;
  padding: 0 16px;

  border-radius: 9999px;
  background: var(--ia-btn-bg);
  color: #fff;

  font-weight: 800;
  letter-spacing: .02em;
  line-height: 40px;

  box-shadow: var(--ia-btn-shadow);
  transition: transform .12s ease, box-shadow .14s ease, filter .2s ease;
}

.ishikawa-contact-form input[type="submit"]:hover,
.ishikawa-submit:hover{
  transform: translateY(-1px);
  box-shadow: 0 16px 34px rgba(15,23,42,.14);
  filter: saturate(1.03);
}

.ishikawa-contact-form input[type="submit"]:focus,
.ishikawa-submit:focus{
  outline: none;
  box-shadow: 0 0 0 4px var(--ia-focus-ring), var(--ia-btn-shadow);
}

.ishikawa-contact-form input[type="submit"][disabled]{
  opacity: .65;
  cursor: not-allowed;
  transform: none;
  filter: none;
}

/* CF7 spinner（ボタン右に自然に） */
.ishikawa-contact-form .wpcf7-spinner{
  margin: 0;
  width: 16px;
  height: 16px;
  opacity: .75;
}

/* ============ CF7 Validation / Messages ============ */
.wpcf7 form .wpcf7-not-valid-tip{
  font-size: 12.5px;
  margin-top: 6px;
  color: var(--ia-danger);
}

.wpcf7 form .wpcf7-response-output{
  margin: 12px 0 0;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(15,23,42,.04);
  font-size: 13px;
  border: 1px solid rgba(15,23,42,.08);
  color: #334155;
}

/* ============ Responsive ============ */
@media (max-width: 767px){
  .ishikawa-contact-form{
    padding: 18px 16px; /* match mypage mobile */
  }
  .ishikawa-submit-wrap{
    justify-content: stretch;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .ishikawa-contact-form input[type="submit"],
  .ishikawa-submit{
    width: 100%;
    min-width: 0;
  }
  .ishikawa-contact-form .wpcf7-spinner{
    align-self: center;
  }
}

/* ============ Reduced motion ============ */
@media (prefers-reduced-motion: reduce){
  .ishikawa-contact-form input,
  .ishikawa-contact-form textarea,
  .ishikawa-contact-form select,
  .ishikawa-contact-form input[type="submit"],
  .ishikawa-submit{
    transition: none !important;
  }
}
