/* Rescue Roofing — public booking form */
.rr-form-wrap *, .rr-form-wrap *::before, .rr-form-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }
.rr-form-wrap {
	--rr-red: #C8102E;
	--rr-bg: #f8fafc;
	--rr-card: #ffffff;
	--rr-border: #e2e8f0;
	--rr-text: #1e293b;
	--rr-muted: #64748b;
	--rr-dim: #94a3b8;
	--rr-green: #16a34a;
	--rr-dark: #0d1424;
	font-family: 'DM Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
	background: var(--rr-bg);
	color: var(--rr-text);
	border-radius: 14px;
	overflow: hidden;
	box-shadow: 0 4px 24px rgba(0,0,0,0.06);
	margin: 20px 0;
}

.rr-hero { background: var(--rr-dark); padding: 28px 20px 36px; text-align: center; position: relative; }
.rr-hero::before { content:''; position:absolute; inset:0; background: linear-gradient(135deg, #C8102E22 0%, transparent 60%); pointer-events: none; }
.rr-hero-logo { display: flex; align-items: center; justify-content: center; gap: 12px; margin-bottom: 20px; }
.rr-hero-icon { width: 44px; height: 44px; background: var(--rr-red); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 22px; }
.rr-hero-name { font-family: 'Bebas Neue', Impact, sans-serif; font-size: 22px; letter-spacing: 2px; color: #fff; }
.rr-hero-tagline { font-size: 11px; color: #94a3b8; }
.rr-hero h1 { font-family: 'Bebas Neue', Impact, sans-serif; font-size: clamp(28px, 7vw, 46px); color: #fff; letter-spacing: 1.5px; line-height: 1.1; margin-bottom: 10px; }
.rr-hero h1 span { color: var(--rr-red); }
.rr-hero p { color: #94a3b8; font-size: 14px; max-width: 440px; margin: 0 auto 20px; line-height: 1.6; }
.rr-trust-row { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; }
.rr-trust-badge { background: #1a2236; border: 1px solid #243050; border-radius: 20px; padding: 5px 14px; font-size: 11px; color: #94a3b8; font-weight: 600; }

.rr-steps-bar { background: #111827; border-bottom: 1px solid #1e2d45; padding: 14px 20px; display: flex; justify-content: center; }
.rr-step { display: flex; align-items: center; gap: 8px; padding: 0 16px; }
.rr-step-num { width: 26px; height: 26px; border-radius: 50%; border: 2px solid #334155; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; color: #64748b; transition: all .3s; }
.rr-step-num.active { background: var(--rr-red); border-color: var(--rr-red); color: #fff; }
.rr-step-num.done { background: var(--rr-green); border-color: var(--rr-green); color: #fff; }
.rr-step-label { font-size: 11px; color: #64748b; font-weight: 600; white-space: nowrap; }
.rr-step-label.active { color: #e2e8f0; }
.rr-step-divider { width: 32px; height: 2px; background: #243050; }

.rr-main { max-width: 600px; margin: 0 auto; padding: 28px 16px 60px; }
.rr-card { background: var(--rr-card); border: 1px solid var(--rr-border); border-radius: 16px; padding: 28px 24px; margin-bottom: 20px; box-shadow: 0 2px 12px rgba(0,0,0,0.04); }
.rr-card-title { font-family: 'Bebas Neue', Impact, sans-serif; font-size: 20px; letter-spacing: 1.5px; color: var(--rr-text); margin-bottom: 6px; border-left: 3px solid var(--rr-red); padding-left: 12px; }
.rr-card-sub { font-size: 12px; color: var(--rr-muted); margin-bottom: 22px; padding-left: 15px; }

.rr-field { margin-bottom: 16px; }
.rr-form-wrap label.rr-lbl { display: block; font-size: 11px; font-weight: 700; color: var(--rr-muted); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 6px; }
.rr-form-wrap input[type=text], .rr-form-wrap input[type=tel], .rr-form-wrap input[type=email], .rr-form-wrap textarea, .rr-form-wrap select {
	width: 100%; background: #f8fafc; border: 1.5px solid var(--rr-border); border-radius: 10px;
	padding: 12px 14px; color: var(--rr-text); font-family: inherit; font-size: 14px;
	outline: none; transition: border-color .2s;
}
.rr-form-wrap input:focus, .rr-form-wrap textarea:focus, .rr-form-wrap select:focus { border-color: var(--rr-red); background: #fff; }
.rr-form-wrap textarea { resize: vertical; min-height: 90px; }
.rr-form-wrap select { appearance: none; padding-right: 36px; cursor: pointer; }
.rr-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media(max-width:480px){ .rr-grid2 { grid-template-columns: 1fr; } }

.rr-issue-pills { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
.rr-issue-pill { padding: 8px 14px; font-size: 12px; font-weight: 600; background: #f1f5f9; color: var(--rr-muted); border: 1.5px solid var(--rr-border); border-radius: 8px; cursor: pointer; transition: all .15s; font-family: inherit; }
.rr-issue-pill.selected { background: var(--rr-red); color: #fff; border-color: var(--rr-red); }

.rr-cal-nav { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.rr-cal-btn { background: #f1f5f9; border: 1.5px solid var(--rr-border); border-radius: 8px; padding: 6px 14px; color: var(--rr-muted); cursor: pointer; font-size: 16px; font-weight: 700; transition: all .15s; }
.rr-cal-btn:hover { border-color: var(--rr-red); color: var(--rr-red); }
.rr-cal-month { font-family: 'Bebas Neue', Impact, sans-serif; font-size: 18px; letter-spacing: 1px; color: var(--rr-text); }
.rr-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; margin-bottom: 14px; }
.rr-dow { text-align: center; font-size: 10px; font-weight: 700; color: var(--rr-dim); padding: 4px 0; }
.rr-day { padding: 8px 4px; border-radius: 8px; font-size: 13px; font-weight: 600; border: 1.5px solid transparent; cursor: pointer; text-align: center; background: #f8fafc; color: var(--rr-text); transition: all .15s; line-height: 1.3; }
.rr-day:hover:not(.blocked):not(.past):not(.empty):not(.full) { border-color: var(--rr-red); color: var(--rr-red); }
.rr-day.blocked { background: #f1f5f9; color: var(--rr-dim); cursor: not-allowed; font-size: 11px; }
.rr-day.past { color: var(--rr-dim); cursor: not-allowed; opacity: .5; }
.rr-day.empty { background: transparent; border: none; cursor: default; }
.rr-day.selected { background: var(--rr-red); color: #fff; border-color: var(--rr-red); }
.rr-day.full { background: #fef3c7; color: #92400e; cursor: not-allowed; font-size: 10px; }
.rr-cal-legend { display: flex; gap: 14px; font-size: 10px; color: var(--rr-muted); flex-wrap: wrap; margin-bottom: 14px; }

.rr-time-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 10px; }
@media(max-width:400px){ .rr-time-grid { grid-template-columns: repeat(2, 1fr); } }
.rr-time-slot-btn { padding: 10px 6px; text-align: center; font-size: 12px; font-weight: 600; background: #f8fafc; border: 1.5px solid var(--rr-border); border-radius: 8px; cursor: pointer; transition: all .15s; color: var(--rr-text); font-family: inherit; }
.rr-time-slot-btn:hover { border-color: var(--rr-red); color: var(--rr-red); }
.rr-time-slot-btn.selected { background: var(--rr-red); color: #fff; border-color: var(--rr-red); }
.rr-time-slot-btn.taken { background: #f1f5f9; color: var(--rr-dim); cursor: not-allowed; }

.rr-submit-btn { width: 100%; background: var(--rr-red); color: #fff; border: none; border-radius: 12px; padding: 16px; cursor: pointer; font-family: 'Bebas Neue', Impact, sans-serif; font-size: 20px; letter-spacing: 1.5px; transition: background .2s, transform .1s; margin-top: 8px; }
.rr-submit-btn:hover { background: #a50d24; }
.rr-submit-btn:active { transform: scale(.99); }
.rr-submit-btn:disabled { opacity: .4; cursor: not-allowed; }
.rr-btn-row { display: flex; gap: 10px; }
.rr-btn-back { background: #1e293b !important; flex: 0 0 80px; font-size: 16px !important; }
.rr-btn-back:hover { background: #0f172a !important; }
.rr-btn-row .rr-submit-btn:not(.rr-btn-back) { flex: 1; }

.rr-progress-wrap { background: #e2e8f0; border-radius: 4px; height: 4px; margin: 20px 0 28px; overflow: hidden; }
.rr-progress-bar { background: var(--rr-red); height: 100%; border-radius: 4px; transition: width .4s; }

.rr-field-error { font-size: 11px; color: var(--rr-red); margin-top: 4px; display: none; }
.rr-confirm-summary { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 10px; padding: 16px 18px; margin-bottom: 20px; font-size: 13px; line-height: 2; color: #374151; }
.rr-info-banner { background: #eff6ff; border: 1px solid #bfdbfe; border-radius: 10px; padding: 14px 16px; margin-bottom: 20px; font-size: 12px; color: #1e40af; line-height: 1.7; }
.rr-submit-error { background: #fef2f2; border: 1px solid #fecaca; color: #b91c1c; padding: 12px 14px; border-radius: 10px; font-size: 13px; margin-top: 12px; }

.rr-success-screen { display: none; text-align: center; padding: 40px 20px; }
.rr-success-icon { font-size: 56px; margin-bottom: 16px; }
.rr-success-title { font-family: 'Bebas Neue', Impact, sans-serif; font-size: 32px; letter-spacing: 1.5px; color: var(--rr-green); margin-bottom: 8px; }
.rr-success-msg { color: var(--rr-muted); font-size: 14px; line-height: 1.7; max-width: 380px; margin: 0 auto 24px; }
.rr-success-detail { background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 12px; padding: 16px 20px; display: inline-block; text-align: left; margin-bottom: 20px; font-size: 13px; color: #166534; line-height: 2; }
