*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#1B2A4A;--navy-light:#243656;--navy-dark:#111D33;
  --crimson:#DC3545;--crimson-dark:#B82D3B;
  --gold:#D4A853;--gold-light:#E8C97A;--gold-pale:rgba(212,168,83,.1);
  --green:#22a06b;--green-pale:#e6f5ee;
  --white:#fff;--gray-50:#F9FAFB;--gray-100:#F3F4F6;
  --gray-200:#E5E7EB;--gray-400:#9CA3AF;--gray-600:#6B7280;--gray-800:#1F2937;
  --radius:16px;--shadow:0 4px 24px rgba(27,42,74,.06);--transition:all .3s cubic-bezier(.16,1,.3,1);
}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--gray-50);color:var(--gray-800);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}

/* ── Progress bar ── */
.progress-wrap{background:rgba(255,255,255,.9);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1rem 1.5rem;border-bottom:1px solid var(--gray-200);position:sticky;top:44px;z-index:10}
.progress-steps{display:flex;justify-content:space-between;align-items:center;max-width:600px;margin:0 auto;position:relative}
.progress-steps::before{content:'';position:absolute;top:50%;left:0;right:0;height:3px;background:var(--gray-200);transform:translateY(-50%);z-index:0;border-radius:2px}
.progress-fill{position:absolute;top:50%;left:0;height:3px;background:linear-gradient(90deg,var(--crimson),var(--gold));transform:translateY(-50%);z-index:1;transition:width .4s ease;border-radius:2px}
.step-dot{width:36px;height:36px;border-radius:50%;background:var(--gray-100);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:var(--gray-400);z-index:2;transition:var(--transition);border:3px solid var(--white);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.step-dot.active{background:var(--crimson);color:var(--white);box-shadow:0 0 0 4px rgba(220,53,69,.15)}
.step-dot.done{background:var(--navy);color:var(--white);box-shadow:0 0 0 4px rgba(27,42,74,.1)}
.step-label{position:absolute;top:40px;font-size:.65rem;color:var(--gray-400);white-space:nowrap;text-align:center;left:50%;transform:translateX(-50%);font-weight:600;letter-spacing:.02em;text-transform:uppercase}
.step-wrap{position:relative;display:flex;flex-direction:column;align-items:center}

/* ── Container ── */
.container{max-width:640px;margin:0 auto;padding:2rem 1rem 6rem}

/* ── Form steps ── */
.form-step{display:none;animation:fadeUp .45s cubic-bezier(.16,1,.3,1)}
.form-step.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

.section-title{font-family:'Plus Jakarta Sans','Inter',sans-serif;font-size:1.6rem;color:var(--navy);margin-bottom:.3rem;font-weight:800;letter-spacing:-.03em}
.section-sub{color:var(--gray-600);font-size:.9rem;margin-bottom:1.5rem}

/* ── Cards ── */
.card{background:rgba(255,255,255,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--radius);padding:1.75rem;box-shadow:var(--shadow);margin-bottom:1.25rem;border:1px solid rgba(255,255,255,.8)}

/* ── Pills ── */
.pill{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.75rem 1.25rem;
  border:2px solid var(--gray-200);border-radius:50px;
  background:white;font-size:0.9rem;font-weight:600;
  cursor:pointer;transition:all 0.2s cubic-bezier(0.16,1,0.3,1);
  user-select:none;color:var(--gray-800);
}
.pill:hover{
  border-color:var(--navy-light);transform:scale(1.02);
  box-shadow:0 4px 12px rgba(27,42,74,0.08);
}
.pill:active{transform:scale(0.97)}
.pill.selected{
  border-color:var(--crimson);background:rgba(220,53,69,0.06);
  color:var(--crimson);box-shadow:0 0 0 3px rgba(220,53,69,0.1);
}
.pill .pill-icon{font-size:1.2rem}
.pill-sm{padding:0.55rem 1rem;font-size:0.82rem}

.pill-grid{display:flex;flex-wrap:wrap;gap:0.6rem;justify-content:center}
.pill-grid-inline{justify-content:flex-start}

/* ── Fields ── */
.field{margin-bottom:1.15rem}
.field label{display:block;font-weight:600;font-size:.85rem;margin-bottom:.4rem;color:var(--navy)}
.field label .optional{color:var(--gray-400);font-weight:400;font-size:.75rem}
.field input,.field select,.field textarea{width:100%;padding:.8rem 1rem;border:1.5px solid var(--gray-200);border-radius:12px;font-size:.95rem;font-family:inherit;transition:border .2s,box-shadow .2s;background:var(--white)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(27,42,74,.08)}
.field textarea{resize:vertical;min-height:70px}
.field .error-msg{color:var(--crimson);font-size:.78rem;margin-top:.3rem;display:none}
.field.has-error input,.field.has-error select{border-color:var(--crimson);box-shadow:0 0 0 3px rgba(220,53,69,.1)}
.field.has-error .error-msg{display:block}
.row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}

/* ── Buttons ── */
.btn-row{display:flex;gap:.75rem;margin-top:1.75rem}
.btn{flex:1;padding:.9rem;border:none;border-radius:50px;font-size:1rem;font-weight:700;cursor:pointer;transition:var(--transition);font-family:inherit;letter-spacing:-.01em}
.btn-primary{background:var(--crimson);color:var(--white)}
.btn-primary:hover{background:var(--crimson-dark);transform:translateY(-2px);box-shadow:0 8px 20px rgba(220,53,69,.25)}
.btn-secondary{background:var(--gray-100);color:var(--navy);border:1.5px solid var(--gray-200)}
.btn-secondary:hover{background:var(--gray-200)}

.btn-submit{background:var(--crimson);color:var(--white);font-size:1.1rem;padding:1.1rem;width:100%;border:none;border-radius:50px;font-weight:700;cursor:pointer;transition:var(--transition);font-family:inherit;margin-top:1rem;letter-spacing:-.01em}
.btn-submit:hover{background:var(--crimson-dark);transform:translateY(-2px);box-shadow:0 8px 25px rgba(220,53,69,.3)}

/* ── Product result cards ── */
.product-card{background:var(--white);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);border-top:4px solid var(--crimson);margin-bottom:1rem;transition:var(--transition)}
.product-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(27,42,74,.1)}
.product-card h3{color:var(--navy);font-family:'Plus Jakarta Sans','Inter',sans-serif;font-size:1.1rem;margin-bottom:.25rem;font-weight:700}
.product-card .fit-reason{color:var(--crimson);font-size:.85rem;font-weight:600;margin-bottom:.5rem}
.product-card .detail{font-size:.85rem;color:var(--gray-600);margin-bottom:.2rem}
.product-card .carriers{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}
.product-card .carrier-tag{background:rgba(27,42,74,.05);color:var(--navy);font-size:.75rem;padding:.25rem .65rem;border-radius:50px;font-weight:600}
.health-note{background:var(--gold-pale);border-radius:10px;padding:.6rem .85rem;font-size:.8rem;color:#92700c;margin-top:.5rem;border:1px solid rgba(212,168,83,.15)}

/* ── Thank you ── */
.thank-you{text-align:center;padding:2rem 0}
.thank-you .check-circle{width:80px;height:80px;border-radius:50%;background:var(--green-pale);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:2.5rem;animation:popIn .5s ease}
@keyframes popIn{from{transform:scale(0)}70%{transform:scale(1.15)}to{transform:scale(1)}}
.thank-you h2{color:var(--navy);font-family:'Plus Jakarta Sans','Inter',sans-serif;font-weight:800}
.contact-info{background:rgba(27,42,74,.03);border:1px solid var(--gray-200);border-radius:var(--radius);padding:1.25rem;margin-top:1.5rem;text-align:left}
.contact-info h4{color:var(--navy);font-family:'Plus Jakarta Sans','Inter',sans-serif;font-weight:700;margin-bottom:.5rem}
.contact-info p{font-size:.9rem;margin-bottom:.3rem}

.privacy{text-align:center;color:var(--gray-400);font-size:.78rem;padding:1rem;margin-top:1rem}
.privacy svg{vertical-align:middle;margin-right:4px}

.spinner{display:inline-block;width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-right:8px;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Google Places autocomplete dropdown ── */
.pac-container{border-radius:12px;border:1px solid var(--gray-200);box-shadow:0 8px 30px rgba(0,0,0,.12);margin-top:4px;font-family:'Inter',sans-serif}
.pac-item{padding:.5rem .75rem;font-size:.9rem;cursor:pointer}
.pac-item:hover{background:rgba(220,53,69,.04)}

/* ── Responsive ── */
@media(max-width:480px){
  .row{grid-template-columns:1fr}
  .step-label{font-size:.5rem}
  .container{padding:1.25rem .75rem 5rem}
  .card{padding:1.25rem}
  .btn{font-size:.95rem}
  .pill{padding:0.6rem 1rem;font-size:.82rem}
  .pill .pill-icon{font-size:1rem}
}
