/* ════════════════════════════════════════════════════════════
   pages/contact.css — Forms, map placeholder, FAQ accordion
   Shared by contact.html and order-a-map.html
   ════════════════════════════════════════════════════════════ */

/* ─── FORM SYSTEM ────────────────────────────────────────── */
.form-card{background:var(--card);border:1.5px solid var(--card-border);border-radius:16px;padding:36px 38px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-group{display:flex;flex-direction:column;margin-bottom:18px}
.form-group.full{grid-column:1 / -1}
.form-label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:7px}
.form-label .req{color:var(--cta)}
.form-input,.form-select,.form-textarea{
  font-family:inherit;font-size:14px;color:var(--text);
  background:var(--bg);border:1.5px solid var(--border);
  border-radius:8px;padding:11px 14px;outline:none;transition:all .15s;width:100%;
}
.form-textarea{resize:vertical;min-height:120px;line-height:1.6}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}
.form-input.invalid,.form-select.invalid,.form-textarea.invalid{border-color:var(--cta)}
.form-error{font-size:12px;color:var(--cta);margin-top:6px;display:none}
.form-error.show{display:block}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px;padding-right:40px}
.form-submit{margin-top:6px;border:none;font-family:inherit}
.form-success{
  display:none;align-items:center;gap:12px;
  background:var(--accent2-light);border:1.5px solid var(--accent2);
  border-radius:10px;padding:16px 18px;margin-top:18px;
  font-size:14.5px;font-weight:600;color:var(--accent2);
}
.form-success.show{display:flex}
.form-success svg{width:22px;height:22px;stroke:var(--accent2);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}

/* ─── AOI MAP (Order a Map) ──────────────────────────────── */
.aoi-help{font-size:12.5px;color:var(--text-muted);line-height:1.55;margin-bottom:10px}
.aoi-map{height:340px;width:100%;border:1.5px solid var(--border);border-radius:10px;overflow:hidden;background:#0a1a2f}
.aoi-map .leaflet-container{height:100%;width:100%;font-family:inherit}
.aoi-map--failed{height:auto;min-height:0;background:none;border-style:dashed;padding:18px;text-align:center;color:var(--text-muted);font-size:13px}
.aoi-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:10px;flex-wrap:wrap}
.aoi-summary{font-size:13px;color:var(--text-muted);line-height:1.5}
.aoi-summary strong{color:var(--accent)}
.aoi-clear{font-family:inherit;font-size:12.5px;font-weight:600;color:var(--text-muted);background:var(--bg-alt);border:1.5px solid var(--border);border-radius:7px;padding:7px 14px;cursor:pointer;transition:all .15s}
.aoi-clear:hover{border-color:var(--cta);color:var(--cta)}

/* ─── CONTACT TWO-COLUMN LAYOUT ──────────────────────────── */
.contact-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:44px;align-items:start}
.contact-details{display:flex;flex-direction:column;gap:24px}
.contact-detail{display:flex;gap:16px;align-items:flex-start}
.contact-detail-icon{width:44px;height:44px;border-radius:10px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-detail-icon svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.contact-detail-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-light);margin-bottom:4px}
.contact-detail-val{font-size:14.5px;color:var(--text);line-height:1.6;font-weight:500}
.contact-detail-val a{color:var(--accent)}

/* ─── MAP PLACEHOLDER ────────────────────────────────────── */
.map-placeholder{
  position:relative;border-radius:16px;overflow:hidden;min-height:340px;
  background:linear-gradient(160deg,#071628 0%,#0a2240 100%);
  display:flex;align-items:center;justify-content:center;
}
.map-placeholder .map-pins{position:absolute;inset:0}
.map-placeholder .map-pin{position:absolute}
.map-placeholder-content{position:relative;z-index:1;text-align:center;color:#fff}
.map-placeholder-content svg{width:48px;height:48px;stroke:var(--accent2);fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;margin:0 auto 14px}
.map-placeholder-title{font-size:18px;font-weight:700;color:#fff}
.map-placeholder-sub{font-size:13.5px;color:rgba(255,255,255,.6);margin-top:6px}

/* ─── FAQ ACCORDION ──────────────────────────────────────── */
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--card);border:1.5px solid var(--card-border);border-radius:12px;overflow:hidden;transition:border-color .15s}
.faq-item.open{border-color:var(--accent)}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 24px;font-size:15.5px;font-weight:600;color:var(--text);
  text-align:left;font-family:inherit;background:none;border:none;cursor:pointer;
}
.faq-q-icon{width:22px;height:22px;flex-shrink:0;transition:transform .25s;color:var(--accent)}
.faq-q-icon svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.faq-item.open .faq-q-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 24px}
.faq-item.open .faq-a{max-height:300px}
.faq-a-inner{padding-bottom:22px;font-size:14.5px;color:var(--text-muted);line-height:1.75}

/* ─── ORDER-A-MAP cards ──────────────────────────────────── */
.order-types{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.order-type-card{background:var(--card);border:1.5px solid var(--card-border);border-radius:12px;padding:28px;transition:all .2s}
.order-type-card:hover{border-color:var(--accent);box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.order-type-icon{width:48px;height:48px;border-radius:10px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.order-type-icon svg{width:23px;height:23px;stroke:var(--accent);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.order-type-icon.teal{background:var(--accent2-light)}
.order-type-icon.teal svg{stroke:var(--accent2)}
.order-type-card h3{font-size:16.5px;font-weight:700;margin-bottom:8px}
.order-type-card p{font-size:14px;color:var(--text-muted);line-height:1.65}

/* ─── CONTACT STRIP (order page bottom) ──────────────────── */
.contact-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.contact-strip-item{display:flex;gap:14px;align-items:center;padding:22px;background:var(--card);border:1.5px solid var(--card-border);border-radius:12px}
.contact-strip-item .contact-detail-icon{margin:0}

@media(max-width:860px){
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .order-types,.contact-strip{grid-template-columns:1fr}
}
@media(max-width:640px){
  .form-grid{grid-template-columns:1fr}
  .form-card{padding:26px 22px}
}
