/* Super Ivan "Get Rates" funnel — refined-luxury styling.
   Critical layout (shell/aside/main/cards) is inlined in get-rates.html; this is the rest. */

/* ---- Brand panel (left) ---- */
.aside-trust { list-style: none; display: flex; flex-direction: column; gap: 11px; margin: 4px 0 28px; }
.aside-trust li { display: flex; align-items: center; gap: 11px; font-size: .92rem; color: #d7d2c4; }
.aside-trust .stars { color: var(--gold-2); letter-spacing: 2px; font-size: .9rem; }
.aside-trust .tick {
  flex: 0 0 auto; width: 22px; height: 22px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(201, 168, 76, .16); color: var(--gold-2); font-size: .72rem; font-weight: 800;
}
.aside-call { margin-top: auto; color: #b8b2a2; text-decoration: none; font-size: .92rem; }
.aside-call strong { color: #fff; }
.aside-call:hover strong { color: var(--gold-2); }

/* ---- Mobile call bar (hidden on desktop) ---- */
.fnl-mobilebar { display: none; }

/* ---- Inputs ---- */
.fnl-input {
  width: 100%; font-family: 'Hanken Grotesk', sans-serif; font-size: 1.08rem;
  padding: 16px 18px; border: 1.5px solid var(--line); border-radius: 14px;
  background: var(--card); color: var(--text); outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.fnl-input:focus { border-color: var(--gold); box-shadow: 0 0 0 4px rgba(201, 168, 76, .2); }
.fnl-input::placeholder { color: #7a7f86; }

.fnl-label { display: block; font-weight: 600; font-size: .9rem; margin: 15px 0 6px; color: #cfd2d6; }
.fnl-label .opt { font-weight: 400; color: #9a948a; }

/* ---- Buttons ---- */
.fnl-btn {
  display: inline-block; width: 100%; margin-top: 18px; text-align: center;
  background: var(--gold-grad); color: #1a1407; font-family: 'Hanken Grotesk', sans-serif;
  font-weight: 800; font-size: 1.05rem; padding: 17px 20px; border: none; border-radius: 14px;
  cursor: pointer; text-decoration: none; letter-spacing: .01em;
  box-shadow: 0 10px 26px rgba(201, 168, 76, .28);
  transition: transform .1s, box-shadow .18s, filter .15s;
}
.fnl-btn:hover { filter: brightness(1.04); box-shadow: 0 14px 32px rgba(201, 168, 76, .38); transform: translateY(-1px); }
.fnl-btn:active { transform: translateY(0); }
.fnl-btn[disabled] { opacity: .55; cursor: not-allowed; box-shadow: none; filter: none; transform: none; }
.fnl-btn.big { padding: 19px 20px; font-size: 1.12rem; }
.fnl-btn.ghost { background: transparent; color: #b8bdc2; border: 1.5px solid var(--line); box-shadow: none; }
.fnl-btn.ghost:hover { border-color: var(--gold); color: #fff; filter: none; }
.fnl-row { display: flex; gap: 10px; }
.fnl-row .fnl-btn { margin-top: 18px; }
.fnl-row .ghost { flex: 0 0 auto; width: auto; padding-left: 20px; padding-right: 20px; }
.fnl-row .fnl-btn:not(.ghost) { flex: 1; }

/* ---- Honeypot (off-screen, not display:none) ---- */
.fnl-hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

/* ---- Consent + fine print ---- */
.fnl-consent { display: flex; gap: 10px; align-items: flex-start; margin: 18px 0 4px; font-size: .82rem; color: #9aa0a6; line-height: 1.45; cursor: pointer; }
.fnl-consent input { margin-top: 2px; flex-shrink: 0; width: 18px; height: 18px; accent-color: var(--gold); }
.fnl-fine { text-align: center; font-size: .76rem; color: #9a948a; margin-top: 14px; line-height: 1.5; }
.fnl-turnstile { margin: 14px 0 2px; display: flex; justify-content: center; }
.fnl-err { color: #b23c2e; font-size: .85rem; margin-top: 8px; min-height: 1px; }

/* ---- Progress dots ---- */
.fnl-progress { display: flex; justify-content: center; gap: 7px; margin-bottom: 14px; }
.fnl-progress span { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,.18); transition: background .25s, transform .25s, width .25s; }
.fnl-progress span.on { background: var(--gold); }
.fnl-progress span.cur { background: var(--gold); width: 22px; border-radius: 4px; }

/* ---- Running summary ---- */
.fnl-summary { list-style: none; display: flex; flex-wrap: wrap; gap: 6px 8px; justify-content: center; margin-bottom: 20px; }
.fnl-summary li { font-size: .76rem; font-weight: 600; color: var(--gold-2); background: rgba(201, 168, 76, .12); border: 1px solid rgba(201, 168, 76, .25); padding: 3px 10px; border-radius: 999px; }
.fnl-summary li::before { content: "✓ "; color: var(--gold); font-weight: 800; }

/* ---- Thank-you ---- */
.fnl-done { text-align: center; padding: 10px 0; }
.fnl-check { width: 78px; height: 78px; border-radius: 50%; margin: 0 auto 18px; background: var(--gold-grad); color: #1a1407; font-size: 2.3rem; font-weight: 800; display: flex; align-items: center; justify-content: center; box-shadow: 0 12px 30px rgba(201, 168, 76, .35); animation: pop .4s cubic-bezier(.2,.8,.2,1.3); }
@keyframes pop { from { transform: scale(.6); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.fnl-done-sub { font-size: 1.05rem; color: #c5c8cc; max-width: 440px; margin: 4px auto 24px; line-height: 1.55; }

/* ---- Google Places dropdown ---- */
.pac-container { background: #181b20; border-radius: 12px; margin-top: 6px; box-shadow: 0 14px 34px rgba(12,13,14,.16); border: 1px solid var(--line); font-family: 'Hanken Grotesk', sans-serif; overflow: hidden; }
.pac-item { padding: 11px 14px; font-size: .95rem; cursor: pointer; color: #d7dadd; border-top: 1px solid rgba(255,255,255,.08); }
.pac-item:hover { background: #22262c; }
.pac-item-query { font-size: .95rem; color: var(--text); }

/* ---- Mobile ---- */
@media (max-width: 880px) {
  .fnl-mobilebar { display: flex; justify-content: center; padding: 10px; background: #0e1013; border-bottom: 1px solid var(--line); }
  .mb-call { color: #b08f33; font-weight: 700; text-decoration: none; font-size: .92rem; }
  .aside-trust { flex-direction: row; flex-wrap: wrap; gap: 6px 14px; margin: 10px 0 2px; }
  .aside-trust li { font-size: .76rem; gap: 7px; }
  .aside-trust .tick { width: 18px; height: 18px; }
  .aside-call { display: none; }
  .fnl-q { font-size: 1.62rem; }
  .fnl-card { padding: 17px 14px; font-size: 1.04rem; }
}
