/* ============== QUOTES PAGE ============== */
.quote-hero {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 7rem 2rem 3rem;
}
.container.narrow {
  max-width: 800px;
  margin: 0 auto;
}
.quote-h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(32px, 5vw, 52px);
  font-weight: 700;
  line-height: 1.15;
  margin: 1rem 0;
  letter-spacing: -0.02em;
}
.quote-h1 em {
  font-style: italic;
  color: var(--gold);
}
.quote-sub {
  font-size: 15.5px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.85;
  max-width: 580px;
  margin: 0 auto;
}

/* PATH CARDS */
.quote-paths {
  position: relative;
  z-index: 2;
  padding: 2rem 2rem 5rem;
}
.path-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  max-width: 1000px;
  margin: 0 auto;
}
.path-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 2.5rem;
  text-align: left;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  font-family: inherit;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  transition: all 0.3s var(--ease);
  position: relative;
  overflow: hidden;
}
.path-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(245, 237, 220, 0.04), transparent 60%);
  opacity: 0;
  transition: opacity 0.3s var(--ease);
  pointer-events: none;
}
.path-card:hover {
  transform: translateY(-6px);
  border-color: var(--glass-border-strong);
}
.path-card:hover::before {
  opacity: 1;
}
.path-client {
  background: linear-gradient(145deg, rgba(107, 39, 55,0.1) 0%, rgba(107, 39, 55,0.02) 100%);
  border-color: rgba(107, 39, 55,0.2);
}
.path-client:hover {
  border-color: rgba(184, 146, 61, 0.45);
  box-shadow: 0 20px 60px rgba(107, 39, 55,0.15);
}
.path-agent {
  background: linear-gradient(145deg, rgba(201, 165, 90, 0.10) 0%, rgba(201, 165, 90, 0.04) 100%);
  border: 1px solid rgba(201, 165, 90, 0.35);
  box-shadow: 0 8px 32px rgba(201, 165, 90, 0.08);
}
.path-agent:hover {
  border-color: rgba(201, 165, 90, 0.6);
  box-shadow: 0 20px 60px rgba(201, 165, 90, 0.18);
}
.path-icon {
  width: 64px;
  height: 64px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  margin-bottom: 1.5rem;
}
.path-client .path-icon {
  background: rgba(107, 39, 55,0.2);
  color: var(--cyan);
}
.path-agent .path-icon {
  background: rgba(201, 165, 90, 0.18);
  color: var(--gold-light);
}
.path-label {
  font-size: 10.5px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 500;
  margin-bottom: 0.5rem;
}
.path-client .path-label { color: var(--cyan); }
.path-agent .path-label { color: var(--gold); }
.path-card h2 {
  font-family: 'Playfair Display', serif;
  font-size: 26px;
  font-weight: 700;
  margin-bottom: 0.875rem;
  letter-spacing: -0.01em;
}
.path-client h2 { color: var(--text); }
.path-agent h2 { color: var(--text); }
.path-card p {
  font-size: 14px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.75;
  margin-bottom: 2rem;
}
.path-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 500;
}
.path-client .path-cta { color: var(--cyan); }
.path-agent .path-cta { color: var(--purple-light); }
.path-cta i {
  transition: transform 0.2s var(--ease);
}
.path-card:hover .path-cta i {
  transform: translateX(4px);
}

/* QUICK QUOTING TOOLS */
.quote-quick-tools {
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid var(--glass-border);
}
.qqt-label {
  font-size: 12px;
  text-align: center;
  color: var(--text2);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 500;
  margin-bottom: 1rem;
}
.qqt-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.75rem;
  max-width: 900px;
  margin: 0 auto;
}
.qqt-pill {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  padding: 0.875rem 1.125rem;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  text-decoration: none;
  color: inherit;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  transition: all 0.2s var(--ease);
}
.qqt-pill:hover {
  background: var(--glass-strong);
  border-color: var(--glass-border-strong);
  transform: translateY(-2px);
}
.qqt-pill > i:first-child {
  font-size: 22px;
  color: var(--purple-light);
  flex-shrink: 0;
}
.qqt-pill > div {
  flex: 1;
}
.qqt-pill strong {
  display: block;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 1px;
}
.qqt-pill span {
  font-size: 11px;
  color: var(--text2);
  font-weight: 300;
}
.qqt-arrow {
  font-size: 14px;
  color: var(--text3);
  transition: transform 0.2s var(--ease);
}
.qqt-pill:hover .qqt-arrow {
  color: var(--text);
  transform: translate(2px, -2px);
}

/* FORM */
.quote-form-section {
  position: relative;
  z-index: 2;
  padding: 2rem 2rem 6rem;
}
.form-shell {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 2.5rem;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  position: relative;
}
.back-btn {
  background: transparent;
  border: 1px solid var(--glass-border);
  color: var(--text2);
  font-family: inherit;
  font-size: 13px;
  padding: 0.5rem 1rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 1.5rem;
  transition: all 0.2s var(--ease);
}
.back-btn:hover {
  color: var(--text);
  background: var(--glass);
}

/* PROGRESS */
.form-progress {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: 2.5rem;
}
.progress-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  min-width: 90px;
}
.progress-dot {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Playfair Display', serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--text3);
  transition: all 0.3s var(--ease);
}
.progress-label {
  font-size: 11px;
  color: var(--text3);
  font-weight: 400;
  letter-spacing: 0.04em;
  transition: color 0.3s var(--ease);
}
.progress-step.active .progress-dot {
  background: var(--purple);
  border-color: var(--purple);
  color: #14263D;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
}
.progress-step.active .progress-label {
  color: var(--text);
}
.progress-step.complete .progress-dot {
  background: var(--cyan);
  border-color: var(--cyan);
  color: #fff;
}
.progress-step.complete .progress-label {
  color: var(--text2);
}
.progress-line {
  flex: 0 0 60px;
  height: 1px;
  background: var(--glass-border);
  margin: 0 -10px 22px;
  position: relative;
  z-index: 0;
}
.progress-line.filled {
  background: linear-gradient(90deg, var(--cyan), var(--purple));
}

/* STEP CONTENT */
.form-step {
  display: none;
  animation: fadeInUp 0.4s var(--ease);
}
.form-step.active {
  display: block;
}
.form-step-head {
  margin-bottom: 2rem;
  text-align: center;
}
.step-eyebrow {
  font-size: 10.5px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--gold-light);
  font-weight: 500;
  margin-bottom: 0.75rem;
}
.form-step-head h3 {
  font-family: 'Playfair Display', serif;
  font-size: 26px;
  font-weight: 700;
  margin-bottom: 0.5rem;
  letter-spacing: -0.01em;
}
.form-step-head p {
  font-size: 14px;
  color: var(--text2);
  font-weight: 300;
}

.form-grid {
  display: grid;
  gap: 1rem;
}
.form-grid.two-col {
  grid-template-columns: 1fr 1fr;
}
.form-field {
  display: flex;
  flex-direction: column;
}
.form-field.full {
  grid-column: 1 / -1;
}
.form-field label {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 0.5rem;
  letter-spacing: 0.02em;
}
.form-field input[type="text"],
.form-field input[type="email"],
.form-field input[type="tel"],
.form-field input[type="date"],
.form-field select,
.form-field textarea {
  background: rgba(245, 237, 220, 0.04);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  padding: 0.75rem 1rem;
  transition: all 0.2s var(--ease);
  width: 100%;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: none;
  border-color: var(--purple);
  background: rgba(245, 237, 220, 0.06);
  box-shadow: 0 0 0 3px rgba(201, 165, 90, 0.18);
}
.form-field input::placeholder,
.form-field textarea::placeholder {
  color: var(--text3);
}
.form-field select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23A09890' stroke-width='2'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}
.form-field select option {
  background: var(--bg2);
}
.form-field textarea {
  resize: vertical;
  font-family: 'DM Sans', sans-serif;
}

/* RADIO PILLS */
.radio-group {
  display: flex;
  gap: 0.5rem;
}
.radio-pill {
  flex: 1;
  position: relative;
  cursor: pointer;
}
.radio-pill input {
  position: absolute;
  opacity: 0;
}
.radio-pill span {
  display: block;
  text-align: center;
  padding: 0.7rem 1rem;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  background: rgba(245, 237, 220, 0.03);
  font-size: 13.5px;
  color: var(--text2);
  transition: all 0.2s var(--ease);
}
.radio-pill input:checked + span {
  background: rgba(201, 165, 90, 0.18);
  border-color: var(--purple);
  color: var(--text);
}
.radio-pill:hover span {
  color: var(--text);
  border-color: var(--glass-border-strong);
}

/* GOAL GRID */
.label-hint {
  display: inline-block;
  margin-left: 8px;
  font-size: 11px;
  font-weight: 400;
  color: var(--text2);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.goal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.75rem;
}
.goal-card {
  cursor: pointer;
  position: relative;
}
.goal-card input {
  position: absolute;
  opacity: 0;
}
.goal-inner {
  background: rgba(245, 237, 220, 0.03);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  padding: 1.125rem 1rem;
  transition: all 0.2s var(--ease);
  height: 100%;
  position: relative;
}
.goal-inner::after {
  content: '';
  position: absolute;
  top: 10px;
  right: 10px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1.5px solid var(--glass-border);
  background: rgba(245, 237, 220, 0.04);
  transition: all 0.2s var(--ease);
}
.goal-card input:checked + .goal-inner::after {
  background: var(--purple);
  border-color: var(--purple);
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='20 6 9 17 4 12'%3e%3c/polyline%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: center;
  box-shadow: 0 0 12px var(--purple-glow);
}
.goal-inner i {
  font-size: 22px;
  color: var(--purple-light);
  display: block;
  margin-bottom: 0.625rem;
}
.goal-inner strong {
  display: block;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 3px;
}
.goal-inner span {
  font-size: 11.5px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.5;
}
.goal-card input:checked + .goal-inner {
  background: rgba(201, 165, 90, 0.18);
  border-color: var(--purple);
}
.goal-card input:checked + .goal-inner i {
  color: var(--purple-light);
}
.goal-card:hover .goal-inner {
  border-color: var(--glass-border-strong);
}

@keyframes shakeX {
  0%, 100% { transform: translateX(0); }
  20%, 60% { transform: translateX(-6px); }
  40%, 80% { transform: translateX(6px); }
}
.goal-grid.shake {
  animation: shakeX 0.5s var(--ease);
}
.goal-grid.shake .goal-inner {
  border-color: rgba(255, 107, 107, 0.5);
}

/* AMOUNT SLIDER */
.amount-display {
  text-align: center;
  margin-bottom: 0.75rem;
}
.amount-value {
  font-family: 'Playfair Display', serif;
  font-size: 36px;
  font-weight: 700;
  color: var(--gold);
}
.amount-slider {
  width: 100%;
  height: 6px;
  background: var(--glass);
  border-radius: 3px;
  appearance: none;
  -webkit-appearance: none;
  outline: none;
  cursor: pointer;
}
.amount-slider::-webkit-slider-thumb {
  appearance: none;
  -webkit-appearance: none;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--gold);
  cursor: pointer;
  box-shadow: 0 0 20px var(--gold-glow);
  border: 3px solid var(--bg);
}
.amount-slider::-moz-range-thumb {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--gold);
  cursor: pointer;
  border: 3px solid var(--bg);
}
.amount-marks {
  display: flex;
  justify-content: space-between;
  margin-top: 0.75rem;
  font-size: 11px;
  color: var(--text3);
}

/* CHECKBOX CONSENT */
.consent-box {
  margin: 1.5rem 0;
}
.checkbox-pill {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  padding: 1rem;
  border-radius: var(--radius-sm);
  background: rgba(245, 237, 220, 0.03);
  border: 1px solid var(--glass-border);
  transition: all 0.2s var(--ease);
}
.checkbox-pill:hover {
  border-color: var(--glass-border-strong);
}
.checkbox-pill input {
  margin-top: 3px;
  accent-color: var(--purple);
}
.checkbox-pill span {
  font-size: 12px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.6;
  flex: 1;
}

/* FORM NAV */
.form-nav {
  display: flex;
  justify-content: flex-end;
  margin-top: 2rem;
}
.form-nav.split {
  justify-content: space-between;
}

/* SUCCESS STATE */
.success-state {
  text-align: center;
  padding: 2rem 0;
}
.success-icon {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan), var(--cyan-dim));
  margin: 0 auto 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 40px;
  color: #fff;
  box-shadow: 0 0 40px var(--cyan-glow);
  animation: successPop 0.6s var(--ease-bounce);
}
@keyframes successPop {
  0% { transform: scale(0); opacity: 0; }
  100% { transform: scale(1); opacity: 1; }
}
.success-state h3 {
  font-family: 'Playfair Display', serif;
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 0.75rem;
}
.success-state > p {
  font-size: 15px;
  color: var(--text2);
  font-weight: 300;
  line-height: 1.8;
  max-width: 460px;
  margin: 0 auto 2rem;
}
.success-info {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  max-width: 480px;
  margin: 0 auto 2.5rem;
}
.info-item {
  background: rgba(245, 237, 220, 0.03);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  padding: 1rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  text-align: left;
}
.info-item i {
  font-size: 24px;
  color: var(--gold);
}
.info-item strong {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
}
.info-item span {
  font-size: 11.5px;
  color: var(--text2);
  font-weight: 300;
}

@media (max-width: 700px) {
  .path-split {
    grid-template-columns: 1fr;
  }
  .form-grid.two-col {
    grid-template-columns: 1fr;
  }
  .form-shell {
    padding: 1.5rem;
  }
  .progress-label {
    display: none;
  }
  .success-info {
    grid-template-columns: 1fr;
  }
  .form-nav.split {
    flex-direction: column-reverse;
    gap: 0.5rem;
  }
  .form-nav.split button {
    width: 100%;
    justify-content: center;
  }
}
