/* ============================================
   Riley's Roofing — Contact Page CSS
   Load AFTER riley-roofing.css and inner-pages.css.
   ============================================ */

.rr-contact-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 48px; align-items: start; }

/* Override the generic .rr-section h2 (dark text) rule from inner-pages.css —
   this card has a dark background, so its heading must stay white/green. */
.rr-contact-card h2 { color: #fff; }
.rr-contact-card h2 span { color: var(--rr-green); }

/* ── Contact info column ── */
.rr-contact-list { list-style: none; margin: 22px 0 26px; padding: 0; display: flex; flex-direction: column; gap: 18px; }
.rr-contact-list li { display: flex; gap: 14px; align-items: flex-start; }
.rr-contact-list i { width: 38px; height: 38px; flex-shrink: 0; border-radius: 999px; background: rgba(147,201,18,.12); border: 2px solid var(--rr-green); color: var(--rr-green-dark); display: flex; align-items: center; justify-content: center; font-size: 15px; }
.rr-contact-list span { display: block; font-size: 11px; text-transform: uppercase; font-weight: 900; letter-spacing: .4px; color: #999; margin-bottom: 2px; }
.rr-contact-list a, .rr-contact-list p { font-size: 14.5px; font-weight: 700; color: #222; margin: 0; text-decoration: none; }
.rr-contact-list a:hover { color: var(--rr-green-dark); }

.rr-emergency-note { display: flex; gap: 12px; align-items: flex-start; background: #fdf3e7; border: 1px solid #f0dcb8; border-radius: 8px; padding: 16px 18px; }
.rr-emergency-note i { color: #c4791a; font-size: 18px; margin-top: 2px; }
.rr-emergency-note p { margin: 0; font-size: 13px; line-height: 1.5; color: #5a4a30; }

/* ── Contact form card (extends .rr-lead-card from main CSS) ── */
.rr-contact-card { max-width: 100%; margin-left: 0; }
.rr-contact-card textarea { width: 100%; margin-bottom: 8px; border: 0; border-radius: 3px; padding: 10px 13px; font-size: 13px; background: #fff; box-sizing: border-box; font-family: var(--rr-font-body); resize: vertical; }

.rr-toggle-field { border: 0; margin: 0 0 8px; padding: 10px 0 4px; }
.rr-toggle-label { display: block; color: #fff; font-size: 12.5px; font-weight: 800; text-align: left; margin-bottom: 8px; }
.rr-toggle-pair { display: flex; gap: 10px; }
.rr-toggle-pair label { flex: 1; background: #fff; border-radius: 3px; padding: 10px; font-size: 13px; font-weight: 700; color: #333; display: flex; align-items: center; justify-content: center; gap: 6px; cursor: pointer; }
.rr-toggle-pair input { width: auto; margin: 0; }

.rr-consent { display: flex; gap: 8px; align-items: flex-start; text-align: left; color: #ccc; font-size: 11.5px; line-height: 1.5; margin: 6px 0 12px; }
.rr-consent input { width: auto; margin: 2px 0 0; flex-shrink: 0; }
.rr-consent a { color: var(--rr-green); text-decoration: underline; }

.rr-form-success { background: rgba(147,201,18,.15); border: 1px solid var(--rr-green); color: #fff; border-radius: 6px; padding: 14px; font-size: 13.5px; font-weight: 700; margin-bottom: 14px; display: flex; gap: 10px; align-items: center; }
.rr-form-success i { color: var(--rr-green); font-size: 18px; }
.rr-form-error { background: rgba(220,53,69,.15); border: 1px solid #dc3545; color: #fff; border-radius: 6px; padding: 12px; font-size: 13px; font-weight: 700; margin-bottom: 12px; display: flex; gap: 8px; align-items: center; }

/* ── Areas We Serve ── */
.rr-areas-section { text-align: center; background: var(--rr-gray); }
.rr-areas-intro { font-size: 15px; color: #444; max-width: 600px; margin: 0 auto 22px; }
.rr-areas-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin-bottom: 18px; }
.rr-area-chip { display: inline-block; padding: 8px 16px; border-radius: 999px; background: #fff; border: 1px solid #ddd; font-size: 13px; font-weight: 800; color: #333; }
.rr-areas-note { font-size: 13px; color: #777; margin: 0; }

/* Placeholder highlight — remove .rr-todo class once real content is filled in */
.rr-todo { background: #fff3b0; color: #5a4a00; }
.rr-area-chip.rr-todo { background: #fff3b0; border-color: #e8d98a; }

/* ── Storm callout (single full-width banner) ── */
.rr-storm-callout { background: #fff; padding: 0 0 16px; }
.rr-storm-banner { border-radius: 8px; width: 100%; flex-direction: column; align-items: flex-start; gap: 10px; padding: 26px 30px; }
.rr-storm-banner span { margin-bottom: 4px; }
.rr-storm-warning { margin-top: 10px !important; padding-top: 10px; border-top: 1px solid rgba(255,255,255,.15); font-size: 12.5px !important; color: #bbb !important; }

@media (max-width: 1024px) {
  .rr-contact-grid { grid-template-columns: 1fr; gap: 30px; }
}
@media (max-width: 768px) {
  .rr-toggle-pair { flex-direction: column; }
}