/*
 * contact.css — styles for the Liên hệ page template.
 *
 * Extracted verbatim from lien-he.html inline <style>, plus additional rules
 * for the new core contact form fields that reuse site.css .field/.input/.btn.
 * Loaded only on is_page_template('page-templates/template-lien-he.php')
 * via inc/enqueue.php. Depends on tokens.css + site.css being loaded first.
 */

/* ── Contact two-column layout ───────────────────────────────────────────── */
.contact-grid { display: grid; gap: 32px; }
@media (min-width: 1024px) { .contact-grid { grid-template-columns: 1.1fr 1fr; gap: 48px; } }

.contact-card {
  background: white; border: 1px solid var(--neutral-100);
  border-radius: var(--radius-lg); padding: 32px;
  box-shadow: var(--shadow-card);
}
@media (min-width: 768px) { .contact-card { padding: 40px; } }
.contact-card h2 { font-size: 22px; margin-bottom: 6px; }
.contact-card .org {
  font-size: 13px; color: var(--brand-accent-700);
  text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600;
}

.contact-list {
  list-style: none; padding: 0; margin: 32px 0 0;
  display: flex; flex-direction: column; gap: 18px;
}
.contact-list li {
  display: flex; gap: 16px; align-items: flex-start;
  padding-bottom: 18px; border-bottom: 1px solid var(--neutral-100);
}
.contact-list li:last-child { border-bottom: none; padding-bottom: 0; }
.contact-list .ico-circle {
  width: 40px; height: 40px; border-radius: 8px;
  background: var(--brand-accent-soft); flex: 0 0 auto;
}
.contact-list .ico-circle .ico { width: 20px; height: 20px; }
.contact-list .body { flex: 1; min-width: 0; }
.contact-list .label {
  font-size: 12px; color: var(--neutral-500);
  text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600;
}
.contact-list .value {
  color: var(--neutral-900); font-size: 16px;
  font-weight: 500; margin-top: 4px; line-height: 1.5;
}
.contact-list a.value { color: var(--brand-primary); }
.contact-list a.value:hover { color: var(--brand-accent-700); }
.contact-list .sub { font-size: 13px; color: var(--neutral-500); margin-top: 4px; }

.contact-actions {
  display: flex; flex-wrap: wrap; gap: 12px;
  margin-top: 32px; padding-top: 28px; border-top: 1px solid var(--neutral-100);
}

/* ── Decorative map ──────────────────────────────────────────────────────── */
.map-wrap {
  background: white; border: 1px solid var(--neutral-100);
  border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column;
}
.map-frame {
  aspect-ratio: 16 / 11; position: relative;
  background:
    radial-gradient(600px 300px at 50% 50%, rgba(11,27,59,0.08), transparent 60%),
    linear-gradient(135deg, #EEF1F6 0%, #DCE2EB 100%);
}
/* Decorative grid lines suggesting a map tile */
.map-frame::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(11,27,59,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(11,27,59,0.06) 1px, transparent 1px);
  background-size: 32px 32px;
}
/* Faux street lines to reinforce map metaphor */
.map-frame::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(75deg, transparent 38%, rgba(11,27,59,0.15) 38%, rgba(11,27,59,0.15) 39%, transparent 39%),
    linear-gradient(-15deg, transparent 28%, rgba(11,27,59,0.15) 28%, rgba(11,27,59,0.15) 28.5%, transparent 28.5%),
    linear-gradient(45deg, transparent 60%, rgba(11,27,59,0.18) 60%, rgba(11,27,59,0.18) 60.6%, transparent 60.6%),
    linear-gradient(135deg, transparent 70%, rgba(11,27,59,0.12) 70%, rgba(11,27,59,0.12) 70.4%, transparent 70.4%);
}

.map-pin {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -100%);
  z-index: 2; pointer-events: none;
}
.map-pin__head {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--brand-accent); border: 4px solid white;
  box-shadow: 0 4px 12px rgba(0,0,0,0.25);
  display: grid; place-items: center; color: var(--brand-primary);
}
.map-pin__head::after {
  content: ""; position: absolute; left: 50%; bottom: -8px;
  transform: translateX(-50%);
  width: 14px; height: 14px; background: var(--brand-accent);
  transform: translateX(-50%) rotate(45deg); top: 38px;
  box-shadow: 4px 4px 8px rgba(0,0,0,0.15);
}
.map-pin__pulse {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 80px; height: 80px; border-radius: 50%;
  background: var(--brand-accent); opacity: 0.25;
  animation: pulse 2.4s ease-out infinite;
}
@keyframes pulse {
  0%   { transform: translate(-50%, -50%) scale(0.6); opacity: 0.4; }
  100% { transform: translate(-50%, -50%) scale(1.6); opacity: 0; }
}

.map-overlay {
  position: absolute; bottom: 16px; left: 16px; right: 16px;
  background: white; border-radius: var(--radius); padding: 16px 20px;
  box-shadow: var(--shadow-card-hover);
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  z-index: 3;
}
.map-overlay strong { color: var(--neutral-900); font-size: 14px; display: block; }
.map-overlay span   { color: var(--neutral-500); font-size: 13px; display: block; margin-top: 2px; }

.map-footer {
  padding: 16px 20px; border-top: 1px solid var(--neutral-100);
  display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  font-size: 13px; color: var(--neutral-500);
}
.map-footer .placeholder-note { display: inline-flex; align-items: center; gap: 6px; }

/* ── FAQ accordion (<details>/<summary>) ─────────────────────────────────── */
.faq-list { display: grid; gap: 12px; max-width: 820px; margin-inline: auto; }
details.faq {
  background: white; border: 1px solid var(--neutral-100);
  border-radius: var(--radius); overflow: hidden;
  transition: border-color var(--t);
}
details.faq[open] { border-color: var(--brand-accent); }
details.faq summary {
  list-style: none; cursor: pointer;
  padding: 20px 24px;
  display: flex; justify-content: space-between; align-items: flex-start; gap: 16px;
  font-weight: 600; color: var(--neutral-900); font-size: 16px;
  user-select: none;
}
details.faq summary::-webkit-details-marker { display: none; }
details.faq summary::after {
  content: ""; flex: 0 0 auto;
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--brand-accent-soft) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230B1B3B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><line x1='12' y1='5' x2='12' y2='19'/><line x1='5' y1='12' x2='19' y2='12'/></svg>") center / 14px no-repeat;
  transition: transform var(--t);
}
details.faq[open] summary::after {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230B1B3B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><line x1='5' y1='12' x2='19' y2='12'/></svg>");
  background-color: var(--brand-accent);
}
details.faq .answer {
  padding: 0 24px 20px; color: var(--neutral-700); font-size: 15px; line-height: 1.7;
  border-top: 1px solid var(--neutral-100); padding-top: 20px; margin-top: -4px;
}
/* Answers come through wpautop(): normalise the wrapping <p> margins */
details.faq .answer p { margin: 0; }
details.faq .answer p + p { margin-top: 12px; }
details.faq .answer a { color: var(--brand-accent-700); text-decoration: underline; }

/* Offset the post-submit jump target so the sticky header never covers it */
#lien-he-form { scroll-margin-top: 100px; }

/* ── Warning banner ──────────────────────────────────────────────────────── */
.warning {
  background: white; border: 1px solid var(--neutral-100);
  border-left: 4px solid var(--warning);
  border-radius: var(--radius); padding: 20px 24px;
  display: flex; gap: 16px; align-items: flex-start;
}
.warning__icon {
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(184,130,23,0.12); color: var(--warning);
  display: grid; place-items: center; flex: 0 0 auto;
}
.warning__body strong { color: var(--neutral-900); display: block; margin-bottom: 4px; font-size: 15px; }
.warning__body p { font-size: 14px; color: var(--neutral-700); }

/* ── Toast (copy-email feedback) ─────────────────────────────────────────── */
.toast {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--neutral-900); color: white;
  padding: 12px 20px; border-radius: var(--radius);
  font-size: 14px; box-shadow: var(--shadow-pop);
  opacity: 0; pointer-events: none;
  transition: opacity var(--t), transform var(--t);
  z-index: 100;
}
.toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ── Contact form fields (reuses site.css .field / .input / .btn) ─────────── */
.contact-form { display: flex; flex-direction: column; gap: 20px; }

/* Label above each input — consistent with field groups elsewhere */
.contact-form .field { display: flex; flex-direction: column; gap: 8px; }
.contact-form .field__label { font-size: 14px; font-weight: 600; color: var(--neutral-900); }

/* Textarea shares the same .input token as text inputs */
.contact-form textarea.input { min-height: 140px; }
