/* ============================================================
   JAPAN TALENT MATCHING — CONTACT PAGE v15 (Enterprise Blue-Gray)
============================================================= */

/* ─────────── ROOT TOKENS ─────────── */
:root {
  --ink: #0b1320;
  --muted: #6b7280;
  --accent: #2563eb;
  --accent-soft: rgba(37,99,235,0.08);
  --accent-glow: rgba(37,99,235,0.18);
  --bg-glass: rgba(255,255,255,0.85);
  --border: rgba(37,99,235,0.25);
  --radius: 18px;
  --blur: 14px;
  --shadow: 0 12px 36px rgba(15,23,42,0.12);
}

/* ─────────── GLOBAL PAGE ─────────── */
body.page-template-contact {
  font-family: "Poppins","Inter",system-ui,sans-serif;
  background: #f7f9fc;
  color: var(--ink);
  overflow-x: hidden;
}

/* ============================================================
   HERO SECTION
============================================================= */
section.relative.text-center {
  position: relative;
  text-align: center;
  padding: 6rem 1.5rem 7rem;
  background: #ffffff;
  overflow: hidden;
}

section.relative.text-center::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(37,99,235,0.06) 0%, transparent 70%);
  z-index: 0;
}

section.relative.text-center h1 {
  position: relative;
  font-size: 3rem;
  font-weight: 800;
  color: #0f1c2e;
  letter-spacing: -0.02em;
  z-index: 1;
}

section.relative.text-center p {
  position: relative;
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1.75;
  margin-top: 1rem;
  z-index: 1;
}

/* ============================================================
   CONTACT CONTAINER (Info + Form)
============================================================= */
main.container.mx-auto {
  max-width: 1180px;
  margin: 0 auto;
  padding: 4rem 1.5rem 6rem;
}

main.container .grid.md\:grid-cols-2 {
  display: grid;
  grid-template-columns: 38% 62%;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--bg-glass);
  backdrop-filter: blur(var(--blur));
  box-shadow: var(--shadow);
  transition: box-shadow 0.35s ease;
}

main.container .grid.md\:grid-cols-2:hover {
  box-shadow: 0 16px 42px rgba(15,23,42,0.18);
}

/* ============================================================
   LEFT PANEL — Contact Info
============================================================= */
main.container aside.bg-gradient-to-br {
  background: #162844;
  color: #ffffff;
  padding: 2.75rem 2.25rem;
}

main.container aside.bg-gradient-to-br h2 {
  font-size: 1.45rem;
  font-weight: 700;
  margin-bottom: 1.8rem;
}

main.container aside.bg-gradient-to-br .space-y-8 > div + div {
  margin-top: 1.8rem;
}

main.container aside.bg-gradient-to-br .flex.items-start.gap-4 {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

main.container aside.bg-gradient-to-br .flex.items-start.gap-4 > div:first-child {
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  transition: all 0.25s ease;
}

main.container aside.bg-gradient-to-br .flex.items-start.gap-4 > div:first-child:hover {
  transform: scale(1.06);
  background: rgba(255,255,255,0.22);
}

main.container aside.bg-gradient-to-br p {
  color: rgba(255,255,255,0.9);
  line-height: 1.6;
  font-size: 0.95rem;
}

/* ============================================================
   RIGHT PANEL — Form
============================================================= */
main.container section.bg-white\/80 {
  background: rgba(255,255,255,0.95);
  padding: 3rem 2.5rem 3.25rem;
  border-radius: 0;
}

main.container section.bg-white\/80 h2 {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 0.4rem;
}

main.container section.bg-white\/80 > p {
  color: var(--muted);
  font-size: 0.96rem;
  line-height: 1.65;
  margin-bottom: 1.8rem;
}
/* ============================================================
   FORM FIELDS
============================================================= */
main.container input,
main.container textarea {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #ffffff;
  color: var(--ink);
  font-size: 0.95rem;
  padding: 0.9rem 1rem;
  transition: all 0.25s ease;
}

main.container input:focus,
main.container textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37,99,235,0.18);
  outline: none;
}

/* Button */
main.container button[type="submit"] {
  background: #2563eb;
  color: #ffffff;
  font-weight: 600;
  font-size: 0.96rem;
  padding: 0.85rem 2rem;
  border-radius: 9999px;
  border: none;
  cursor: pointer;
  box-shadow: 0 8px 22px rgba(37,99,235,0.25);
  transition: all 0.25s ease;
}

main.container button[type="submit"]:hover {
  background: #1e40af;
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(37,99,235,0.35);
}

/* Inline success message */
body.page-template-contact .faq-success-msg {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 10px;
  color: #1e40af;
  padding: 0.55rem 1rem;
  font-size: 0.9rem;
  font-weight: 500;
  animation: fadeIn 0.4s ease, fadeOut 0.5s ease 2.3s forwards;
  box-shadow: 0 6px 18px rgba(15,23,42,0.12);
}

/* ============================================================
   MAP + CTA SECTIONS
============================================================= */
main.container section.mt-12 {
  margin-top: 5rem !important;
  border-radius: var(--radius);
  box-shadow: 0 12px 32px rgba(15,23,42,0.12);
  background: #ffffff;
}

main.container iframe {
  width: 100%;
  height: 400px;
  border: 0;
  display: block;
}

main.container section.text-center.mt-20 {
  text-align: center;
  margin-top: 6rem !important;
}

main.container section.text-center.mt-20 h3 {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 0.8rem;
}

main.container section.text-center.mt-20 p {
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.7;
}

/* ============================================================
   RESPONSIVE
============================================================= */
@media (max-width: 992px) {
  main.container .grid.md\:grid-cols-2 {
    grid-template-columns: 1fr;
  }
  main.container section.bg-white\/80 {
    padding: 2rem 1.25rem;
  }
  main.container button[type="submit"] {
    width: 100%;
    margin-top: 0.5rem;
  }
}

/* ============================================================
   DARK MODE
============================================================= */
[data-theme="dark"] body.page-template-contact {
  background: #0b1320;
  color: #f1f5f9;
}

[data-theme="dark"] main.container .grid.md\:grid-cols-2 {
  background: rgba(17,24,39,0.7);
}

[data-theme="dark"] aside.bg-gradient-to-br {
  background: #0f1c2e;
}

[data-theme="dark"] section.bg-white\/80 {
  background: rgba(17,24,39,0.65);
}

[data-theme="dark"] input,
[data-theme="dark"] textarea {
  background: rgba(255,255,255,0.08);
  color: #f1f5f9;
  border-color: rgba(255,255,255,0.15);
}

[data-theme="dark"] button[type="submit"] {
  background: #3b82f6;
}

/* ============================================================
   REMOVE ROUNDED CARD ON NAME/EMAIL ROW
============================================================= */
main.container section.bg-white\/80 form .grid.md\:grid-cols-2,
main.container section.bg-white\/80 form .grid.md\:grid-cols-2 > div {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

main.container section.bg-white\/80 form .grid.md\:grid-cols-2 input {
  background: #ffffff !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
}
