/* =========================================================
   FOODTRUCK1 — 견적·문의 (Contact)
   Page-specific styles. Reuses tokens + shared classes from styles.css.
   ========================================================= */

/* ---------- Page hero ---------- */
.contact-hero { border-bottom: 1px solid var(--ink); }
.contact-hero .container { padding-top: 80px; padding-bottom: 64px; }
.contact-hero .kick { font-size: 11px; color: var(--terra); }
.contact-h1 {
  font: 200 60px/1.14 'Pretendard', sans-serif;
  color: var(--ink);
  letter-spacing: -0.045em;
  margin-top: 24px;
}
.contact-h1 span { font-weight: 500; }
.contact-lead {
  font: 400 18px/1.75 'Pretendard', sans-serif;
  color: var(--body);
  margin-top: 24px;
  max-width: 520px;
}

/* ---------- Form + side layout ---------- */
.contact-form-sec { padding: 80px 0; }
.contact-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 56px;
  align-items: start;
}

/* ---------- Form ---------- */
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.fld-group { display: flex; flex-direction: column; }
.fld-memo { margin-top: 20px; }

.fld {
  width: 100%;
  box-sizing: border-box;
  background: var(--card);
  border: 1px solid var(--line);
  padding: 14px 16px;
  font: 400 16px 'Pretendard', sans-serif;
  color: var(--ink);
  outline: none;
  border-radius: 0;
}
.fld:focus { border-color: var(--ink); }
textarea.fld { resize: vertical; }

.lbl {
  font: 600 14px 'Pretendard', sans-serif;
  color: var(--nav);
  margin-bottom: 8px;
  display: block;
}

/* validation error message */
.error {
  display: none;
  font: 500 12px/1.5 'Pretendard', sans-serif;
  color: var(--terra);
  margin-top: 6px;
}
.error.show { display: block; }
.fld.is-invalid { border-color: var(--terra); }

/* consent checkbox */
.consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 20px;
  font: 400 14px/1.6 'Pretendard', sans-serif;
  color: var(--body);
  cursor: pointer;
}
.consent input[type="checkbox"] {
  margin-top: 2px;
  accent-color: var(--terra);
  flex: 0 0 auto;
}
.consent.is-invalid span { color: var(--terra); }

.submit-btn {
  margin-top: 28px;
  width: 100%;
  padding: 18px;
  font: 600 16px 'Pretendard', sans-serif;
  border-radius: 0;
}
.submit-btn[disabled] { opacity: 0.6; cursor: progress; }

/* submit (network) error — shown above button on failure */
.form-error {
  display: none;
  margin-top: 16px;
  border: 1px solid var(--terra);
  background: var(--card);
  padding: 14px 16px;
  font: 500 14px/1.6 'Pretendard', sans-serif;
  color: var(--terra);
}
.form-error.show { display: block; }

/* ---------- Submitted confirmation ---------- */
.submitted-block {
  border: 1px solid var(--ink);
  background: var(--card);
  padding: 56px 40px;
  text-align: center;
}
.submitted-block .check {
  font: 200 56px 'Inter', sans-serif;
  color: var(--teal);
  line-height: 1;
}
.submitted-block h3 {
  font: 500 26px 'Pretendard', sans-serif;
  color: var(--ink);
  margin-top: 16px;
  letter-spacing: -0.02em;
}
.submitted-block p {
  font: 400 16px/1.7 'Pretendard', sans-serif;
  color: var(--body);
  margin-top: 14px;
}
.submitted-block p b { color: var(--ink); }

/* ---------- Side: quick panel (dark) — phone-first ---------- */
.quick-panel {
  background: var(--ink);
  color: var(--paper);
  padding: 36px;
}
.quick-panel .kick { font-size: 11px; color: var(--ember); }
.quick-panel h3 {
  font: 500 22px 'Pretendard', sans-serif;
  color: var(--paper);
  margin-top: 14px;
  letter-spacing: -0.02em;
}
.quick-phones {
  margin-top: 26px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.quick-phone {
  align-items: center;
  gap: 14px;
  transition: opacity 0.15s ease;
}
.quick-phone:hover { opacity: 0.82; }
.quick-phone-text { display: flex; flex-direction: column; gap: 2px; }
.quick-panel .phone-cap { color: var(--footer-muted); font-size: 14px; }
.quick-hours {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-top: 26px;
  padding-top: 22px;
  border-top: 1px solid rgba(245, 242, 236, 0.16);
  font: 500 15px 'Pretendard', sans-serif;
  color: var(--footer-muted);
}
.quick-hours .lic { width: 18px; height: 18px; color: var(--ember); }

/* ---------- Side: info box ---------- */
.info-box {
  border: 1px solid var(--line);
  padding: 32px;
  margin-top: 24px;
}
.info-box .kick { font-size: 11px; color: var(--muted); }
.info-list {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.info-item { border-bottom: 1px solid var(--line-card); padding-bottom: 18px; }
.info-item:last-child { border-bottom: 0; padding-bottom: 0; }
.info-item .info-t { font: 600 16px 'Pretendard', sans-serif; color: var(--ink); }
.info-item .info-d { font: 400 14px 'Pretendard', sans-serif; color: var(--muted); margin-top: 4px; }

/* ---------- 회사정보 · 오시는 길 ---------- */
.contact-company { border-top: 1px solid var(--ink); background: var(--section-soft); }
.company-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: stretch;
}
.company-info {
  padding: 80px 56px 80px 0;
  border-right: 1px solid var(--line);
}
.company-info .kick { font-size: 11px; color: var(--muted); }
.company-h2 {
  font: 200 38px 'Pretendard', sans-serif;
  color: var(--ink);
  letter-spacing: -0.035em;
  margin-top: 16px;
}
.company-rows {
  margin-top: 28px;
  font: 400 16px/2 'Pretendard', sans-serif;
  color: var(--nav);
}
.company-rows > div { display: flex; gap: 4px; }
.company-key {
  color: var(--muted);
  display: inline-block;
  width: 124px;
  flex: 0 0 124px;
}

.company-map {
  padding: 48px 0;
  display: flex;
  align-items: center;
}
.contact-map {
  width: 100%;
  aspect-ratio: 1087 / 705; /* 약도 이미지 비율과 일치 → 좌우 여백 제거 */
  overflow: hidden;
  border: 1px solid var(--line);
}
.contact-map-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 1080px) {
  .contact-h1 { font-size: 50px; }
}

@media (max-width: 860px) {
  .contact-hero .container { padding-top: 56px; padding-bottom: 44px; }
  .contact-form-sec { padding: 56px 0; }

  /* form + side stack; side panel below the form */
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }

  /* 회사정보 / 지도 stack */
  .company-grid { grid-template-columns: 1fr; }
  .company-info { padding: 56px 0 40px; border-right: 0; border-bottom: 1px solid var(--line); }
  .company-map { padding: 40px 0; }
}

@media (max-width: 560px) {
  .contact-h1 { font-size: 38px; }
  /* form fields stack to single column */
  .form-grid { grid-template-columns: 1fr; }
  /* keep large phone numbers from overflowing the dark panel */
  .quick-panel { padding: 28px; }
  .quick-panel .phone-xl { font-size: 26px; }
  .company-key { width: 104px; flex-basis: 104px; }
}
