/* ── JCS Quote Form v3 ── */
.jcs-qf-wrap { max-width:680px; margin:0 auto; font-family:var(--jcs-font, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif); color:var(--jcs-text,#333); }

/* ── Step Indicator ── */
.jcs-steps-bar { display:flex; align-items:center; justify-content:center; padding:0 8px 24px; gap:0; }
.jcs-step-item { display:flex; flex-direction:column; align-items:center; gap:6px; flex-shrink:0; cursor:default; }
.jcs-step-num {
    width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center;
    font-size:.85rem; font-weight:700; border:2px solid #ddd; color:#aaa; background:#fff; transition:all .3s;
}
.jcs-step-label { font-size:.72rem; font-weight:600; color:#aaa; text-align:center; white-space:nowrap; transition:color .3s; }
.jcs-step-item.jcs-step-active .jcs-step-num { border-color:var(--jcs-primary,#1a6b3c); background:var(--jcs-primary,#1a6b3c); color:#fff; box-shadow:0 2px 8px rgba(26,107,60,.25); }
.jcs-step-item.jcs-step-active .jcs-step-label { color:var(--jcs-primary,#1a6b3c); }
.jcs-step-item.jcs-step-done .jcs-step-num { border-color:var(--jcs-primary,#1a6b3c); background:var(--jcs-primary,#1a6b3c); color:#fff; }
.jcs-step-item.jcs-step-done .jcs-step-num::after { content:'✓'; }
.jcs-step-item.jcs-step-done .jcs-step-num span { display:none; }
.jcs-step-item.jcs-step-done .jcs-step-label { color:var(--jcs-primary,#1a6b3c); }
.jcs-step-connector { flex:1; height:2px; background:#e5e5e5; margin:0 4px; position:relative; margin-bottom:22px; }
.jcs-step-connector-fill { position:absolute; top:0; left:0; height:100%; width:0%; background:var(--jcs-primary,#1a6b3c); transition:width .4s ease; }

/* ── Form Card ── */
.jcs-qf { background:var(--jcs-bg,#fff); border:1px solid var(--jcs-border,#e2e6ea); border-radius:12px; padding:0; box-shadow:0 2px 12px rgba(0,0,0,.06); overflow:hidden; }
.jcs-qf-step { display:none; padding:28px 32px; }
.jcs-qf-step-active { display:block; animation:jcsFadeIn .3s ease; }
@keyframes jcsFadeIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:none} }

/* Step Header */
.jcs-qf-step-header { display:flex; align-items:center; gap:14px; margin-bottom:24px; padding-bottom:16px; border-bottom:1px solid #f0f0f0; }
.jcs-qf-step-icon { font-size:1.8rem; flex-shrink:0; }
.jcs-qf-step-title { font-size:1.2rem; font-weight:700; color:var(--jcs-text,#1a1a2e); line-height:1.2; }
.jcs-qf-step-subtitle { font-size:.82rem; color:#888; margin-top:2px; }

/* ── Fields ── */
.jcs-qf-field { margin-bottom:18px; }
.jcs-qf-field label { display:block; font-size:.88rem; font-weight:600; margin-bottom:6px; color:var(--jcs-text); }
.jcs-qf-field input[type="text"],.jcs-qf-field input[type="email"],.jcs-qf-field input[type="tel"],.jcs-qf-field input[type="number"],.jcs-qf-field select,.jcs-qf-field textarea {
    width:100%; padding:11px 14px; border:1px solid var(--jcs-border,#ddd); border-radius:8px; font-size:.95rem; font-family:inherit; box-sizing:border-box; background:#fff; transition:border-color .2s, box-shadow .2s; }
.jcs-qf-field input:focus,.jcs-qf-field select:focus { outline:none; border-color:var(--jcs-primary); box-shadow:0 0 0 3px rgba(26,107,60,.1); }
.jcs-qf-row { display:flex; gap:14px; }
.jcs-qf-row .jcs-qf-field { flex:1; }
.jcs-qf-hint { font-size:.78rem; color:#888; margin-top:4px; }
.jcs-req { color:#c00; }
.jcs-qf-field-error { font-size:.78rem; color:#c00; margin-top:4px; }

/* ── Buttons / Nav ── */
.jcs-qf-nav { display:flex; gap:12px; margin-top:24px; padding-top:16px; border-top:1px solid #f0f0f0; }
.jcs-qf-nav .jcs-qf-btn { flex:1; }
.jcs-qf-btn {
    display:block; width:100%; padding:14px; background:var(--jcs-primary,#1a6b3c); color:#fff; border:none;
    border-radius:8px; font-size:1rem; font-weight:700; cursor:pointer; text-align:center; transition:all .2s;
}
.jcs-qf-btn:hover { background:var(--jcs-primary-hover,#145530); transform:translateY(-1px); box-shadow:0 4px 12px rgba(26,107,60,.2); }
.jcs-qf-btn:disabled { opacity:.5; cursor:not-allowed; transform:none; box-shadow:none; }
.jcs-qf-btn-back { background:#f0f0f0; color:#555; flex:0 0 120px !important; }
.jcs-qf-btn-back:hover { background:#e0e0e0; transform:none; box-shadow:none; }

/* ── Toggle (VIN/YMM) ── */
.jcs-qf-toggle-row { display:flex; gap:0; margin-bottom:20px; border:1px solid var(--jcs-border,#ddd); border-radius:8px; overflow:hidden; }
.jcs-qf-toggle { flex:1; padding:11px; background:#f5f5f5; border:none; font-size:.88rem; font-weight:600; cursor:pointer; color:#666; transition:all .2s; }
.jcs-qf-toggle-active { background:var(--jcs-primary,#1a6b3c); color:#fff; }

/* Manual Entry & Notices */
.jcs-qf-manual-notice { margin-top:14px; }
.jcs-qf-notice-box { border-radius:8px; padding:14px 18px; font-size:.85rem; line-height:1.5; margin-bottom:14px; }
.jcs-qf-notice-warn { background:#fef8e7; border:1px solid #f0d860; color:#6b5a00; }
.jcs-vin-found { background:#e8f5ee; border:1px solid #b5dfc5; border-radius:8px; padding:14px 18px; font-size:.92rem; margin-top:8px; }

/* ── Radio & Checkbox ── */
.jcs-qf-radios,.jcs-qf-checkboxes { display:flex; flex-direction:column; gap:8px; }
.jcs-qf-radio-label,.jcs-qf-check-label {
    display:flex; align-items:flex-start; gap:10px; padding:12px 16px;
    border:1px solid var(--jcs-border,#e2e6ea); border-radius:8px; cursor:pointer;
    transition:all .15s; font-size:.9rem; line-height:1.4; background:#fff;
}
.jcs-qf-radio-label:hover,.jcs-qf-check-label:hover { border-color:var(--jcs-primary); background:#f9fdfb; }
.jcs-qf-radio-label input:checked + span,.jcs-qf-check-label input:checked + span { font-weight:600; color:var(--jcs-text); }
.jcs-qf-radio-label:has(input:checked),.jcs-qf-check-label:has(input:checked) { border-color:var(--jcs-primary); background:#e8f5ee; box-shadow:0 0 0 1px var(--jcs-primary); }
.jcs-qf-radio-label input,.jcs-qf-check-label input { margin-top:2px; flex-shrink:0; accent-color:var(--jcs-primary,#1a6b3c); }

/* ── Warnings & Auto-set ── */
.jcs-qf-warning {
    background:#fef3e6; border:1px solid #e6a94c; border-radius:8px;
    padding:12px 16px; font-size:.82rem; line-height:1.5; color:#6b4500; margin-top:10px;
}
.jcs-qf-auto-set { position:relative; }
.jcs-qf-auto-set .jcs-qf-radios { opacity:.6; pointer-events:none; }
.jcs-qf-autoset-notice {
    background:#e8f5ee; border:1px solid #b5dfc5; border-radius:8px;
    padding:10px 14px; font-size:.8rem; line-height:1.5; color:#1a6b3c; margin-top:10px;
}
.jcs-qf-question[data-depends-qid] { padding-left:14px; border-left:3px solid var(--jcs-primary,#1a6b3c); }

/* Shake animation for validation */
.jcs-qf-shake { animation:jcsShake .4s ease; }
@keyframes jcsShake { 0%,100%{transform:translateX(0)} 20%{transform:translateX(-6px)} 40%{transform:translateX(6px)} 60%{transform:translateX(-4px)} 80%{transform:translateX(4px)} }

/* ── Result ── */
.jcs-qf-result-box { text-align:center; padding:40px 24px; }
.jcs-qf-result-icon { font-size:3rem; margin-bottom:16px; }
.jcs-qf-result-label { font-size:.85rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:#666; }
.jcs-qf-result-amount { font-size:2.8rem; font-weight:800; color:var(--jcs-primary,#1a6b3c); margin:10px 0; }
.jcs-qf-result-vehicle { font-size:1rem; color:#555; margin-bottom:8px; }
.jcs-qf-result-expires { font-size:.85rem; color:#888; }
.jcs-qf-result-title { font-size:1.3rem; font-weight:700; margin-bottom:10px; }
.jcs-qf-result-text { font-size:.95rem; line-height:1.6; color:#555; }
.jcs-qf-result-review { background:#f0f7ff; border:1px solid #b5d4f0; border-radius:12px; }
.jcs-qf-result-nooffer { background:#fff5f5; border:1px solid #e5c5c5; border-radius:12px; }
.jcs-qf-result-offer { background:#e8f5ee; border:1px solid #b5dfc5; border-radius:12px; }

/* ── Portal ── */
.jcs-portal-wrap { max-width:640px; margin:40px auto; font-family:var(--jcs-font,sans-serif); }
.jcs-portal-header { padding:20px 24px; border-radius:8px 8px 0 0; color:#fff; font-weight:700; font-size:1.1rem; }
.jcs-portal-body { background:#fff; border:1px solid #e5e5e5; border-top:none; border-radius:0 0 8px 8px; }
.jcs-portal-vehicle { padding:16px 24px; font-size:.95rem; color:#555; display:flex; justify-content:space-between; align-items:center; border-bottom:1px solid #eee; }
.jcs-portal-badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:.75rem; font-weight:600; text-transform:uppercase; }
.jcs-portal-offer { padding:24px; text-align:center; }
.jcs-portal-offer-label { font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:#666; }
.jcs-portal-offer-amount { font-size:2.6rem; font-weight:800; color:var(--jcs-primary); margin:8px 0; }
.jcs-portal-offer-expires { font-size:.82rem; color:#888; }
.jcs-portal-breakdown { padding:0 24px 16px; }
.jcs-portal-breakdown h4 { font-size:.85rem; margin:0 0 8px; }
.jcs-portal-bd-row { display:flex; justify-content:space-between; padding:5px 0; font-size:.85rem; border-bottom:1px solid #f0f0f0; }
.jcs-portal-bd-total { display:flex; justify-content:space-between; padding:8px 0 0; font-weight:700; font-size:.95rem; border-top:2px solid #333; margin-top:4px; }
.jcs-portal-accept { padding:16px 24px 24px; }
.jcs-portal-accept h4 { font-size:.95rem; margin:0 0 12px; }

/* Portal Trust Boxes */
.jcs-portal-video { padding:16px 24px; }
.jcs-portal-video h4 { font-size:.9rem; font-weight:700; margin:0 0 12px; text-align:center; color:#333; }
.jcs-portal-video-wrap { position:relative; padding-bottom:56.25%; height:0; overflow:hidden; border-radius:6px; }
.jcs-portal-video-wrap iframe { position:absolute; top:0; left:0; width:100%; height:100%; }
.jcs-portal-trust { padding:8px 24px 16px; display:flex; flex-direction:column; gap:12px; }
.jcs-portal-trust-box { display:flex; gap:14px; align-items:flex-start; padding:16px 18px; background:#f9fafb; border:1px solid #e8eaed; border-radius:8px; transition:border-color .2s; }
.jcs-portal-trust-box:hover { border-color:var(--jcs-primary); }
.jcs-portal-trust-icon { font-size:1.6rem; flex-shrink:0; line-height:1; margin-top:2px; }
.jcs-portal-trust-content { flex:1; min-width:0; }
.jcs-portal-trust-title { font-size:.92rem; font-weight:700; color:#1a1a1a; margin-bottom:4px; }
.jcs-portal-trust-text { font-size:.82rem; line-height:1.5; color:#555; }

/* ── Mini Form ── */
.jcs-mini-wrap { font-family:var(--jcs-font,sans-serif); }
.jcs-mini-row { display:flex; gap:8px; flex-wrap:wrap; }
.jcs-mini-sel { flex:1; min-width:100px; padding:10px 8px; border:1px solid var(--jcs-border,#ddd); border-radius:var(--jcs-radius,4px); font-size:.9rem; }
.jcs-mini-btn { padding:10px 20px; background:var(--jcs-primary,#1a6b3c); color:#fff; border:none; border-radius:var(--jcs-radius,4px); font-size:.9rem; font-weight:700; cursor:pointer; white-space:nowrap; }
.jcs-mini-btn:hover { background:var(--jcs-primary-hover,#145530); }

/* ── Responsive ── */
@media(max-width:600px){
    .jcs-qf-step { padding:20px 18px; }
    .jcs-qf-row { flex-direction:column; }
    .jcs-portal-offer-amount { font-size:2rem; }
    .jcs-mini-sel,.jcs-mini-btn { width:100%; }
    .jcs-steps-bar { gap:0; padding:0 0 20px; }
    .jcs-step-label { font-size:.62rem; }
    .jcs-step-num { width:30px; height:30px; font-size:.75rem; }
    .jcs-qf-nav .jcs-qf-btn-back { flex:0 0 90px !important; }
}
