/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/ba9851c3c22cd980-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/21350d82a1f187e9-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/df0a9ae256c0569c-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/8e9860b6e62d6359-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'Inter Fallback';src: local("Arial");ascent-override: 90.44%;descent-override: 22.52%;line-gap-override: 0.00%;size-adjust: 107.12%
}.__className_f367f3 {font-family: 'Inter', 'Inter Fallback';font-style: normal
}.__variable_f367f3 {--font-inter: 'Inter', 'Inter Fallback'
}

*, ::before, ::after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*//*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}

::before,
::after {
  --tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/

html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: Inter, system-ui, sans-serif; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/*
Remove the default font size and weight for headings.
*/

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

a {
  color: inherit;
  text-decoration: inherit;
}

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
  font-weight: bolder;
}

/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}

/*
Add the correct font size in all browsers.
*/

small {
  font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
  text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
  outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

:-moz-ui-invalid {
  box-shadow: none;
}

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
  vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

::-webkit-search-decoration {
  -webkit-appearance: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
  display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
}

legend {
  padding: 0;
}

ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

/*
Reset default styling for dialogs.
*/
dialog {
  padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
  resize: vertical;
}

/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
  cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/
:disabled {
  cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

img,
video {
  max-width: 100%;
  height: auto;
}

/* Make elements with the HTML hidden attribute stay hidden by default */
[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}
.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 1280px) {

  .container {
    max-width: 1280px;
  }
}
.start-1 {
  inset-inline-start: 0.25rem;
}
.start-2 {
  inset-inline-start: 0.5rem;
}
.mt-12 {
  margin-top: 3rem;
}
.mt-4 {
  margin-top: 1rem;
}
.mt-8 {
  margin-top: 2rem;
}
.block {
  display: block;
}
.flex {
  display: flex;
}
.inline-flex {
  display: inline-flex;
}
.table {
  display: table;
}
.hidden {
  display: none;
}
.h-10 {
  height: 2.5rem;
}
.h-12 {
  height: 3rem;
}
.min-h-screen {
  min-height: 100vh;
}
.max-w-xl {
  max-width: 36rem;
}
.resize {
  resize: both;
}
.items-center {
  align-items: center;
}
.justify-center {
  justify-content: center;
}
.border {
  border-width: 1px;
}
.bg-brand-hero-bg {
  --tw-bg-opacity: 1;
  background-color: rgb(22 55 132 / var(--tw-bg-opacity, 1));
}
.bg-white {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.p-2 {
  padding: 0.5rem;
}
.p-4 {
  padding: 1rem;
}
.p-8 {
  padding: 2rem;
}
.text-center {
  text-align: center;
}
.text-4xl {
  font-size: 2.25rem;
  line-height: 2.5rem;
}
.text-lg {
  font-size: 1.125rem;
  line-height: 1.75rem;
}
.text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.font-black {
  font-weight: 900;
}
.font-bold {
  font-weight: 700;
}
.lowercase {
  text-transform: lowercase;
}
.tracking-tight {
  letter-spacing: -0.025em;
}
.text-brand-hero-bg {
  --tw-text-opacity: 1;
  color: rgb(22 55 132 / var(--tw-text-opacity, 1));
}
.text-red-500 {
  --tw-text-opacity: 1;
  color: rgb(239 68 68 / var(--tw-text-opacity, 1));
}
.text-white {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.text-white\/60 {
  color: rgb(255 255 255 / 0.6);
}
.text-white\/80 {
  color: rgb(255 255 255 / 0.8);
}
.filter {
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.\[respondio\:logmode\] {
  respondio: logmode;
}

/* ============================================================
   Brand styles — ported wholesale from /tmp/wcr-hero-insurify/
   assets/styles.css to preserve exact visual fidelity.
   ADR-009: Wise UI/UX preserved 1:1 from prototype.
   ============================================================ */

/* ---------- Tokens ---------- */
:root {
  --purple: #26CE6B;         /* brand accent (CTA) — kept legacy 'purple' name */
  --purple-dark: #1ea35a;    /* darker green for hover / active */
  --pink-danger: #e54180;
  --ink: #05081A;            /* near-black navy used for navbar, footer, dark text */
  --hero-bg: #163784;        /* hero / 'about you' deep navy */
  --muted: #5a5f65;
  --muted-2: #8a8f95;
  --border: #e4e7ea;
  --bg: #ffffff;
  --bg-cream: #f7f3ea;
  --bg-cream-warm: #faf5eb;
  --header-bg: #05081A;
  --success: #2f7d59;
  --danger: #cc3355;
  --trustpilot-green: #00b67a;
  --radius: 10px;
  --radius-lg: 18px;
  --radius-pill: 999px;
  --shadow-card: 0 1px 2px rgba(0,0,0,0.04), 0 4px 16px rgba(0,0,0,0.05);
  --shadow-hover: 0 4px 24px rgba(0,0,0,0.10);
  --font: "Source Sans Pro", "Helvetica Neue", Arial, sans-serif;
  --font-display: "Playfair Display", "Source Sans Pro", Georgia, serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--purple); text-decoration: none; }
a:hover { text-decoration: underline; }
img { max-width: 100%; display: block; }

.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

.muted-small { font-size: 13px; color: var(--muted); }

/* ---------- Icon utility classes ----------
   Every .icon has explicit width/height to avoid SVG auto-sizing tricks.
   !important is used here because parent flex/grid containers and button
   typographic rules otherwise outrank the plain .icon selector, which made
   icons balloon to fill their parent. We never want that. */
svg.icon {
  display: inline-block !important;
  width: 20px !important;
  height: 20px !important;
  flex-shrink: 0;
  vertical-align: middle;
  color: currentColor;
  fill: currentColor;
}
svg.icon-sm { width: 16px !important; height: 16px !important; }
svg.icon-md { width: 28px !important; height: 28px !important; }
svg.icon-lg { width: 48px !important; height: 48px !important; }
svg.icon-xl { width: 72px !important; height: 72px !important; }

/* Section-specific overrides (still explicit sizes) */
.btn svg.icon { width: 18px !important; height: 18px !important; }
.btn-phone svg.icon { width: 20px !important; height: 20px !important; }
svg.faq-shield { width: 64px !important; height: 64px !important; color: var(--purple); }
svg.hw-svg { width: 280px !important; height: 280px !important; max-width: 100%; color: var(--ink); }
svg.resource-svg { width: 64px !important; height: 64px !important; color: var(--purple); }
svg.call-svg { width: 120px !important; height: 120px !important; color: var(--ink); }
svg.star-icon { width: 22px !important; height: 22px !important; color: #fff; background: var(--trustpilot-green); padding: 2px; }
/* Half-on Trustpilot star: hard split — left half green, right half a
   visibly muted gray-green. Uses background-image + !important to win
   over the .stars.green svg.icon rule that sets a flat green bg. */
svg.star-icon.star-half {
  background: linear-gradient(90deg, var(--trustpilot-green) 0 50%, #b9c9c1 50% 100%) !important;
}
.stars.green svg.icon { color: #fff; background: var(--trustpilot-green); padding: 2px; }
svg.tp-star { color: var(--trustpilot-green) !important; background: transparent !important; padding: 0 !important; }
.hl-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; background: var(--purple); margin-right: 8px; flex-shrink: 0; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: var(--radius-pill);
  padding: 14px 28px;
  font-weight: 700;
  font-size: 16px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: background .15s, border-color .15s, color .15s, transform .15s;
  text-decoration: none;
  font-family: inherit;
}
.btn-primary {
  background: var(--purple);
  color: #fff;
}
.btn-primary:hover { background: var(--purple-dark); text-decoration: none; }
.btn-secondary {
  background: #fff;
  color: var(--purple);
  border-color: var(--purple);
}
.btn-secondary:hover { background: #f3eefd; text-decoration: none; }
.btn-outline {
  background: #fff;
  color: var(--ink);
  border-color: var(--ink);
}
.btn-outline:hover { background: #f4f4f4; text-decoration: none; }
.btn-danger {
  background: var(--pink-danger);
  color: #fff;
}
.btn-danger:hover { background: #c8356d; text-decoration: none; }
.btn-pill { border-radius: var(--radius-pill); }
.btn-compact { padding: 8px 18px; font-size: 14px; }

/* ---------- Header ---------- */
.site-header {
  background: var(--header-bg);
  border-bottom: 1px solid var(--ink);
  position: sticky; top: 0; z-index: 50;
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  gap: 14px;
}
.hamburger {
  display: none;
  background: transparent;
  border: none;
  padding: 8px;
  cursor: pointer;
  flex-direction: column;
  gap: 4px;
  width: 40px;
}
.hamburger span {
  display: block;
  height: 2px;
  background: #fff;
  width: 22px;
}
.brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  line-height: 0;
}
.brand:hover { text-decoration: none; }
.brand-logo {
  display: block;
  width: auto;
  height: 40px;          /* desktop (+10% from 36px baseline) */
  max-width: 100%;
}
@media (max-width: 780px) {
  .brand-logo { height: 31px; }
}
.main-nav { display: flex; gap: 28px; flex: 1; justify-content: center; }
.main-nav a { color: #fff; font-weight: 600; font-size: 15px; }
.main-nav a:hover { color: #d0c8ff; }
.header-actions { display: flex; align-items: center; gap: 10px; }
.header-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  border-radius: 10px;
  color: #fff;
  font-size: 18px;
  text-decoration: none;
}
/* Navbar phone-icon badge: ghost-button style.
   Transparent fill + thin white border (60% alpha) + white icon — present
   but unobtrusive so the primary ZIP form draws the eye. */
.header-icon-primary {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.6);
  color: #fff;
}
.header-icon-primary:hover {
  border-color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.06);
}
.sticky-cta { display: none; }
/* Sticky 'Get Quotes' pill: ghost style on the dark navbar — transparent
   fill + thin white border + white text, matching the phone-icon CTA. */
.btn.sticky-cta {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.6);
  color: #fff;
}
.btn.sticky-cta:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.85);
}

/* ---------- Hero ---------- */
.hero {
  background: var(--hero-bg);
  padding: 56px 0 72px;
  position: relative;
  overflow: hidden;
  color: #fff;
}
.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 32px;
  align-items: center;
}
.hero-text { min-width: 0; max-width: 580px; }
.hero h1 {
  font-size: 56px;
  line-height: 1.05;
  margin: 0 0 16px;
  font-weight: 900;
  letter-spacing: -.5px;
  color: #fff;
}
.hero-sub {
  font-size: 18px;
  color: rgba(255, 255, 255, 0.78);
  max-width: 540px;
  margin: 0 0 24px;
}

/* Hero product tabs (Auto / Bundle / Home / Renters / Pet) */
.hero-products {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  /* Cap at the ZIP form's max-width so tiles end on the same vertical
     line as the COMPARE button (matches Insurify). */
  max-width: 480px;
  /* Slightly more breathing room before the ZIP form (was 16, now 22). */
  margin: 0 0 22px;
}
.hero-product {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 8px;
  min-height: 88px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 12px;
  color: #fff;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  text-align: center;
  transition: border-color .15s, box-shadow .15s, transform .15s, background .15s;
}
.hero-product:hover {
  border-color: rgba(255, 255, 255, 0.4);
  background: rgba(255, 255, 255, 0.1);
  transform: translateY(-1px);
  text-decoration: none;
  color: #fff;
}
.hero-product.is-active {
  background: rgba(255, 255, 255, 0.12);
  border-color: #fff;
  box-shadow: 0 0 0 1px #fff inset;
  color: #fff;
}
svg.hero-product-icon {
  display: block !important;
  width: 32px !important;
  height: 32px !important;
  color: currentColor;
  flex-shrink: 0;
}

/* Inline ZIP form in the hero (reuses base .zip-form behavior in home.js) */
/* Higher specificity (form.hero-zip-form) so this beats the later
   `.zip-form` block in the CTA section. The hero form keeps the
   `zip-form` class only so home.js validation still picks it up. */
form.hero-zip-form {
  display: flex;
  align-items: stretch;
  gap: 0;
  margin: 0 0 18px;
  max-width: 480px;
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
}
form.hero-zip-form label,
form.hero-zip-form input {
  margin: 0;
}
.hero-zip-field {
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex: 1 1 auto;
  height: 56px;
  margin: 0;
  padding: 6px 18px;
  background: #fff;
  border: 0;
  /* rounded only on outer (left) side — meets the button flush on the right */
  border-radius: 12px 0 0 12px;
}
.hero-zip-field:focus-within {
  box-shadow: inset 0 0 0 2px rgba(38, 206, 107, .35);
}
.hero-zip-label {
  font-size: 11px;
  color: var(--muted);
  font-weight: 600;
  letter-spacing: .3px;
  text-transform: uppercase;
}
.hero-zip-form input[name="zip"] {
  font-size: 18px;
  font-weight: 700;
  border: none;
  outline: none;
  padding: 0;
  margin: 0;
  background: transparent;
  font-family: inherit;
  color: var(--ink);
  width: 100%;
}
.hero-zip-form input[name="zip"]::-moz-placeholder { color: var(--muted-2); font-weight: 500; }
.hero-zip-form input[name="zip"]::placeholder { color: var(--muted-2); font-weight: 500; }
.hero-zip-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 56px;
  padding: 0 32px;
  /* rounded only on outer (right) side — meets the input flush on the left */
  border-radius: 0 12px 12px 0;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: .3px;
  text-transform: uppercase;
  flex-shrink: 0;
  white-space: nowrap;
}
.hero-zip-submit svg.icon { width: 18px; height: 18px; }

/* Trustpilot row — sits BELOW the form, matching Insurify */
.trustpilot-mock.hero-trustpilot {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin: 0;
  max-width: 540px;
  font-size: 13px;
  color: #fff;
}
.trustpilot-mock.hero-trustpilot .tp-headline {
  font-weight: 700;
  font-size: 14px;
}
.trustpilot-mock.hero-trustpilot .stars {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  background: transparent;
  padding: 0;
}
.trustpilot-mock.hero-trustpilot .stars .star-icon {
  width: 22px !important;
  height: 22px !important;
  color: #fff;
  background: var(--trustpilot-green);
  padding: 2px;
  border-radius: 1px;
}
.trustpilot-mock.hero-trustpilot .stars .star-half { opacity: .5; }
.trustpilot-mock.hero-trustpilot .tp-logo {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: 700;
  color: var(--trustpilot-green);
}
.trustpilot-mock.hero-trustpilot .tp-logo .tp-star {
  width: 16px;
  height: 16px;
  color: var(--trustpilot-green);
}

/* Hero art / illustration column */
.hero-art {
  position: relative;
  min-height: 460px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-phone-img {
  position: relative;
  display: block;
}
.hero-phone-img img {
  display: block;
  /* Source aspect ratio 1182x2489 (phone-only mockup). Scales fluidly with width.
     Bumped ~20% over the previous clamp(121, 17.6vw, 176). */
  width: clamp(145px, 21vw, 210px);
  height: auto;
  filter: drop-shadow(0 20px 40px rgba(38, 206, 107, .18))
          drop-shadow(0 8px 16px rgba(0, 0, 0, .35));
}
.hero-phone-img::before {
  /* Soft brand-blue glow behind the phone */
  content: "";
  position: absolute;
  inset: -10% -20% -10% -20%;
  background: radial-gradient(circle at center, rgba(38, 206, 107, .12), transparent 65%);
  z-index: -1;
  border-radius: 50%;
}

/* ---------- Carrier garden ---------- */
.carriers { padding: 40px 0; background: #fff; }
.carriers-headline { text-align: center; font-weight: 500; font-size: 19px; margin: 0 0 24px; color: var(--ink); }
.carrier-row { display: grid; grid-template-columns: repeat(6, 1fr); gap: 24px; align-items: center; }
.carrier {
  text-align: center;
  padding: 12px 10px;
  color: var(--muted);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .3px;
}
.carrier-progressive { color: #0074c2; font-style: italic; font-size: 15px; }
.carrier-liberty { color: #fcb712; font-size: 12px; }
.carrier-liberty span { color: #c99512; font-size: 9px; display: block; }
.carrier-aarp { color: #e4002b; font-size: 11px; }
.carrier-aarp small { display: inline-block; font-size: 9px; }
.carrier-root { color: #ff5a1f; }
.carrier-root span { color: var(--ink); font-weight: 400; }
.carrier-allstate { color: #002c5f; }
.carrier-travelers { color: var(--ink); }

/* ---------- 3 Features (replaces old How It Works) ---------- */
.features { padding: 72px 0 88px; background: var(--bg); }
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}
.feature-card {
  text-align: center;
  padding: 28px 24px 0;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: hidden;          /* clip the phone bottom — like Insurify */
}
.feature-card h3 {
  font-size: 22px;
  font-weight: 900;
  line-height: 1.2;
  margin: 0 0 12px;
  letter-spacing: -.3px;
  max-width: 320px;
}
.feature-card p {
  color: var(--muted);
  font-size: 15px;
  line-height: 1.5;
  margin: 0 0 24px;
  max-width: 320px;
}
.feature-mock {
  margin-top: auto;
  width: 100%;
  height: 240px;             /* visible window — the phone is taller and gets cropped */
  display: flex;
  justify-content: center;
  align-items: flex-start;
  overflow: hidden;
}

/* Phone-shaped feature mockups */
.fm-frame {
  position: relative;
  width: 220px;
  height: 420px;             /* taller than .feature-mock so the bottom gets clipped */
  background: #fff;
  border: 4px solid var(--ink);
  border-radius: 30px;
  padding: 22px 16px 16px;
  box-shadow: 0 14px 36px rgba(0,0,0,.10);
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex-shrink: 0;
}
.fm-notch {
  position: absolute;
  top: -1px; left: 50%;
  transform: translateX(-50%);
  width: 70px; height: 18px;
  background: var(--ink);
  border-radius: 0 0 12px 12px;
}
.fm-time {
  position: absolute;
  top: 4px; left: 18px;
  font-size: 10px;
  font-weight: 700;
  color: var(--ink);
}
.fm-brand {
  display: flex; align-items: center; justify-content: center;
  gap: 4px;
  padding: 14px 0 10px;
  font-weight: 900;
  font-size: 14px;
  color: var(--ink);
  letter-spacing: .5px;
}
.fm-brand-text { font-weight: 900; }
.fm-brand svg { display: block; }
.fm-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
  color: var(--ink);
}
.fm-row b { color: var(--purple); }
.fm-row.faded {
  background: #f1f1f1;
  border: 0;
  height: 18px;
  padding: 0;
}
.fm-row.faded.short { width: 70%; }
/* Price-drop alert row in card 2 — leading faded "carrier name" placeholder
   on the left, small green ↓ + price on the right (no carrier text). */
.fm-alert {
  display: flex; justify-content: space-between; align-items: center;
  padding: 6px 4px;
  font-size: 11px;
  font-weight: 700;
}
.fm-alert > span {
  display: block;
  width: 90px; height: 8px;
  background: #e8e8e8;
  border-radius: 4px;
}
.fm-alert b.green {
  color: #2eb872;
  display: inline-flex; align-items: center; gap: 3px;
}

/* Bell mockup */
.fm-bell {
  display: flex; justify-content: center; align-items: center;
  padding: 12px 0 6px;
}

/* Ratings mockup — face-shaped avatars (head circle + facial features) */
.fm-avatars {
  display: flex; justify-content: center;
  margin: 10px 0 6px;
}
.fm-face {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 2px solid #fff;
  margin: 0 -6px;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 6px rgba(0,0,0,.08);
}
.fm-face svg { display: block; width: 100%; height: 100%; }
.fm-face-a { background: linear-gradient(135deg, #f0d4b3, #d3a777); }
.fm-face-b { background: linear-gradient(135deg, #d4a87e, #a07851); }
.fm-face-c { background: linear-gradient(135deg, #f5dcb8, #e0bc8c); }
.fm-rating {
  text-align: center;
  font-size: 32px;
  font-weight: 900;
  color: var(--ink);
  line-height: 1;
  margin: 4px 0 2px;
}
.fm-stars {
  display: flex; justify-content: center; gap: 2px;
  margin-bottom: 8px;
}

.features-cta {
  display: flex; justify-content: center;
  margin-top: 36px;
}
.btn-large {
  font-size: 17px;
  padding: 16px 36px;
}

/* ---------- Reviews (Zebra-style: 4 mini cards in a shell) ---------- */
.reviews { background: var(--bg-cream); padding: 64px 0 80px; }
.reviews h2 {
  text-align: center;
  font-size: 44px;
  margin: 0 0 8px;
  font-weight: 900;
  letter-spacing: -.5px;
  line-height: 1.1;
}
.reviews-sub { text-align: center; color: var(--ink); margin: 0 0 32px; font-size: 17px; }

/* Big white shell that wraps the 4 review cards + the rating footer */
.reviews-shell {
  position: relative;
  background: #fff;
  border: 1px solid #ddd2bf;
  border-radius: 14px;
  padding: 28px 60px 22px;
  max-width: 980px;
  margin: 0 auto;
}
.reviews-strip {
  /* horizontally scrollable carousel — 4 cards visible at a time, the rest
     fade in on arrow click */
  display: flex;
  gap: 14px;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  /* hide scrollbar */
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.reviews-strip::-webkit-scrollbar { display: none; }
.review-mini {
  background: #f1f1f1;
  border-radius: 10px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  min-height: 130px;
  flex: 0 0 calc((100% - 14px * 3) / 4);   /* exactly 4 cards visible */
  scroll-snap-align: start;
}
.stars-tp {
  display: flex;
  gap: 2px;
  background: var(--trustpilot-green);
  padding: 2px 4px;
  border-radius: 1px;
  align-self: flex-start;
  margin-bottom: 8px;
}
.stars-tp svg {
  width: 14px; height: 14px;
  fill: #fff;
}
.review-mini-title {
  font-size: 14px;
  font-weight: 800;
  margin: 0 0 6px;
  color: var(--ink);
  /* clamp to 1 line with ellipsis */
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  line-clamp: 1;
}
.review-mini-body {
  font-size: 13px;
  color: var(--ink);
  margin: 0 0 12px;
  line-height: 1.4;
  flex: 1;
  /* clamp to 3 lines with ellipsis */
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  line-clamp: 3;
}
.review-mini-meta {
  font-size: 12px;
  color: var(--muted);
  margin-top: auto;
}

/* Carousel arrows on the sides of the shell */
.reviews-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1.5px solid var(--purple);
  background: #fff;
  color: var(--purple);
  font-size: 22px;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.reviews-arrow-prev { left: 12px; }
.reviews-arrow-next { right: 12px; }
.reviews-arrow:hover { background: #f4f7ff; }

/* Footer line inside the shell */
.reviews-shell-footer {
  margin-top: 18px;
  text-align: center;
  font-size: 13px;
  color: var(--ink);
}
.reviews-shell-footer a { color: var(--purple); text-decoration: underline; }
.reviews-shell-footer .tp-logo {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: 4px;
  color: var(--trustpilot-green);
  font-weight: 700;
}


/* ---------- FAQ ---------- */
.faq { padding: 60px 0; background: var(--bg); }
.faq h2 {
  text-align: center;
  font-size: 44px;
  margin: 0 0 26px;
  font-weight: 900;
  letter-spacing: -.5px;
  line-height: 1.1;
}
.faq h2 .shield { font-size: 48px; display: inline-block; margin-bottom: 12px; }
.faq details {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  margin-bottom: 12px;
  padding: 0 24px;
  max-width: 820px;
  margin-left: auto; margin-right: auto;
  box-shadow: 0 1px 3px rgba(0,0,0,.03);
}
.faq summary {
  cursor: pointer;
  padding: 22px 0;
  font-weight: 500;
  font-size: 18px;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary .chev {
  color: var(--ink);
  transition: transform .15s;
  font-size: 18px;
  font-weight: 700;
}
.faq details[open] summary .chev { transform: rotate(180deg); }
.faq p { color: var(--muted); margin: 0 0 14px; }
.faq details > :last-child { padding-bottom: 22px; }
.faq-list {
  margin: 0 0 16px;
  padding-left: 20px;
  color: var(--muted);
}
.faq-list li { padding: 4px 0; }
.faq-table-meta {
  font-size: 13px !important;
  color: var(--muted) !important;
  margin-bottom: 10px !important;
}
.faq-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  margin: 0 0 16px;
  font-size: 14px;
}
.faq-table th,
.faq-table td {
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.faq-table tr:last-child td { border-bottom: 0; }
.faq-table thead th {
  background: var(--bg-cream);
  color: var(--ink);
  font-weight: 700;
  font-size: 13px;
}
.faq-table tbody td:first-child { font-weight: 600; color: var(--ink); }
.faq-table tbody td:not(:first-child) { color: var(--ink); }
.faq-disclaimer {
  font-size: 12px !important;
  color: var(--muted-2) !important;
  line-height: 1.5;
  margin: 0 !important;
}

/* ---------- Incident / Driving record (replaces calculator) ---------- */
.incident { background: var(--bg-cream); padding: 72px 0 88px; }
.incident-title {
  text-align: center;
  font-size: 38px;
  font-weight: 900;
  letter-spacing: -.5px;
  margin: 0 0 36px;
  line-height: 1.15;
}
.incident-grid {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 56px;
  align-items: center;
  max-width: 980px;
  margin: 0 auto;
}
.incident-copy p {
  color: var(--ink);
  font-size: 16px;
  line-height: 1.6;
  margin: 0 0 16px;
}
.incident-copy p:last-child { margin-bottom: 0; }
.incident-link {
  color: var(--ink);
  text-decoration: none;
}
.incident-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: var(--shadow-card);
}
.incident-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 14px;
  background: #fff;
  border-bottom: 1px solid var(--border);
  font-weight: 700;
  font-size: 16px;
}
.incident-row:last-child { border-bottom: 0; }
.incident-carrier { color: var(--ink); display: inline-flex; align-items: baseline; gap: 4px; }
.incident-carrier small {
  font-size: 9px; letter-spacing: 1px; color: var(--muted); font-weight: 700;
}
.incident-carrier em { font-style: italic; font-weight: 800; }
.ic-dairyland { font-style: italic; color: #c43a55; }
.ic-general { color: #1d8b3e; }
.ic-sr { color: #c43a55; }
.ic-direct { color: #c43a55; }
.ic-progressive { color: #0074c2; font-style: italic; letter-spacing: -.5px; }
.ic-geico { color: #004B86; letter-spacing: -.3px; }
.ic-plymouth { color: var(--ink); font-style: italic; }
.ic-travelers { color: var(--ink); letter-spacing: -.3px; }
.incident-pill {
  background: var(--bg-cream);
  border-radius: 999px;
  padding: 4px 14px;
  font-size: 14px;
  color: var(--ink);
}
.incident-more-DEPRECATED {
  /* '+120 MORE' badge removed; rule kept for safety, no element uses this class */
  display: none;
  padding-top: 4px;
}

/* ---------- Save CTA (Buy Online / OR / Call an Agent) ---------- */
.save-cta {
  background: var(--hero-bg);
  padding: 64px 0 80px;
  color: #fff;
}
.save-cta-title {
  text-align: center;
  font-size: 36px;
  font-weight: 900;
  letter-spacing: -.5px;
  margin: 0 0 40px;
  color: #fff;
}
.save-cta-grid {
  display: grid;
  grid-template-columns: 1fr 60px 1fr;
  align-items: stretch;
  max-width: 980px;
  margin: 0 auto;
}
.save-cta-col {
  text-align: center;
  padding: 0 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.save-illo {
  margin-bottom: 12px;
}
.save-cta-col h3 {
  font-size: 32px;
  font-weight: 900;
  letter-spacing: -.3px;
  margin: 0 0 14px;
  color: #fff;
}
.save-cta-col > p {
  color: rgba(255, 255, 255, 0.78);
  font-size: 15px;
  line-height: 1.5;
  max-width: 340px;
  margin: 0 0 22px;
}

/* OR vertical divider with circle */
.save-or {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.save-or::before {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  width: 1px;
  background: rgba(255, 255, 255, 0.4);
  transform: translateX(-50%);
}
.save-or span {
  position: relative;
  z-index: 1;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #fff;
  color: var(--ink);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 1px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ZIP form on the left col */
.save-zip-form {
  display: flex;
  align-items: stretch;
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
  max-width: 360px;
  width: 100%;
  margin: 0 0 12px;
}
.save-zip-field {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 48px;
  padding: 4px 14px;
  background: #fff;
  border: 1.5px solid var(--purple);
  border-radius: 8px 0 0 8px;
  border-right: 0;
  text-align: left;
}
.save-zip-label {
  font-size: 11px;
  color: var(--muted);
  font-weight: 600;
  letter-spacing: .3px;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.save-zip-form input[name="zip"] {
  font-size: 16px;
  font-weight: 700;
  border: 0;
  outline: none;
  background: transparent;
  color: var(--ink);
  padding: 0;
  margin: 0;
  width: 100%;
}
.save-zip-submit {
  height: 48px;
  padding: 0 18px;
  border-radius: 0 8px 8px 0 !important;
  font-size: 14px;
  font-weight: 700;
  flex-shrink: 0;
}
.save-reassure {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 13px;
  margin: 0;
}

/* Phone CTA on the right col */
.save-phone {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 26px;
  font-weight: 800;
  color: #fff;
  text-decoration: none;
  margin: 0 0 8px;
}
.save-phone:hover { text-decoration: none; color: #fff; }
.save-phone svg.icon { width: 24px !important; height: 24px !important; color: #fff; }
.save-hablamos { margin: 0; }
.save-hablamos a { color: #fff; font-weight: 700; }
.save-hablamos a:hover { color: #fff; text-decoration: underline; }

/* ---------- Footer ---------- */
.site-footer { background: var(--ink); color: #dedede; padding: 50px 0 24px; }
.footer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.site-footer h4 { color: #fff; margin: 0 0 12px; font-size: 14px; text-transform: uppercase; letter-spacing: 1px; font-weight: 800; }
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li { padding: 4px 0; font-size: 15px; }
.site-footer a { color: #cbd5e1; }
.site-footer a:hover { color: #fff; }
.social-icons { display: flex; gap: 14px; }
.social-icons a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  background: #222; border-radius: 50%;
  color: #fff;
  font-weight: 800;
}
.footer-legal {
  display: flex; justify-content: space-between;
  padding-top: 24px; margin-top: 24px;
  border-top: 1px solid #333;
  font-size: 13px; color: #9aa5b1;
  flex-wrap: wrap; gap: 10px;
}

/* ---------- Cookie banner ---------- */
.cookie-banner {
  position: fixed;
  bottom: 20px; left: 20px; right: 20px;
  max-width: 520px;
  margin: 0 auto;
  background: var(--ink);
  color: #fff;
  padding: 22px 24px;
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
  z-index: 100;
}
.cookie-text { margin: 0 0 10px; font-size: 15px; line-height: 1.5; }
.cookie-policy-link { color: #9ec1f5; display: inline-block; margin-bottom: 14px; }
.cookie-buttons { display: flex; flex-direction: column; gap: 10px; }
.cookie-buttons .btn { width: 100%; }

/* ========================================
   MOBILE — breakpoint 780px (at our breakpoint)
   ======================================== */
@media (max-width: 780px) {
  .main-nav { display: none; }
  /* Hamburger has nothing to toggle (no real mobile menu yet), hide it
     so the logo can sit flush against the left container padding —
     mirroring how 'Get Quotes' sits flush against the right padding. */
  .hamburger { display: none; }
  .header-inner { padding: 10px 16px; gap: 10px; }
  .brand { flex: 1; justify-content: flex-start; }
  .header-actions { gap: 6px; }
  .header-actions .header-icon:not(.header-icon-primary) { display: none; }
  .sticky-cta { display: none; }
  body.scrolled .sticky-cta { display: inline-flex; }
  body.scrolled .header-icon-primary { display: none; }
  /* Slightly smaller 'Get Quotes' pill on mobile so it doesn't crowd
     the logo on narrow viewports. */
  .btn.sticky-cta {
    padding: 6px 14px;
    font-size: 13px;
  }

  .hero { padding: 24px 0 40px; text-align: center; }
  .hero-grid { grid-template-columns: minmax(0, 1fr); gap: 24px; text-align: center; }
  .hero-text { min-width: 0; max-width: none; margin: 0 auto; }
  .hero h1 { font-size: 34px; line-height: 1.1; }
  .hero-sub { font-size: 16px; text-align: center; margin: 0 auto 20px; }
  .hero-art { display: none; }

  .hero-products {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 16px;
  }
  /* Top row: Auto + Bundle (3 cols each) */
  .hero-product:nth-child(1),
  .hero-product:nth-child(2) { grid-column: span 3; }
  /* Second row: Home + Renters + Pet (2 cols each) */
  .hero-product:nth-child(3),
  .hero-product:nth-child(4),
  .hero-product:nth-child(5) { grid-column: span 2; }

  form.hero-zip-form {
    flex-direction: column;
    gap: 12px;
    margin: 0 auto 16px;
    max-width: none;
    width: 100%;
  }
  .hero-zip-field {
    width: 100%;
    height: 56px;
    padding: 6px 18px;
    border-radius: 12px;     /* full corners when stacked, not flush */
  }
  .hero-zip-submit {
    width: 100%;
    height: 56px;
    padding: 0;
    font-size: 17px;
    border-radius: 12px;     /* full corners when stacked */
  }
  .trustpilot-mock.hero-trustpilot {
    justify-content: center;
    margin: 0 auto;
  }

  .carriers { padding: 28px 0; }
  .carriers-headline { font-size: 17px; }
  .carrier-row {
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }

  /* Features: stack one per row on mobile */
  .features { padding: 40px 0 56px; }
  .features-grid { grid-template-columns: 1fr; gap: 18px; }
  .feature-card { padding: 24px 20px 28px; }
  .feature-card h3 { font-size: 20px; }

  .reviews { padding: 40px 0 56px; }
  .reviews h2 { font-size: 32px; }
  .reviews-shell { padding: 18px 44px 16px; border-radius: 12px; }
  /* On mobile each card takes the full strip width so the user sees
     exactly ONE review at a time; the rest scroll horizontally. */
  .review-mini {
    flex: 0 0 100%;
    min-height: 110px;
  }
  .reviews-arrow { width: 28px; height: 28px; font-size: 18px; }
  .reviews-arrow-prev { left: 8px; }
  .reviews-arrow-next { right: 8px; }

  .faq h2 { font-size: 32px; }
  .faq details { border-radius: 12px; padding: 0 18px; }
  .faq summary { font-size: 16px; padding: 18px 0; }

  .calc-intro h2 { font-size: 32px; }
  .calc-form { gap: 12px; }
  .incident { padding: 40px 0 56px; }
  .incident-title { font-size: 26px; margin-bottom: 24px; }
  .incident-grid { grid-template-columns: 1fr; gap: 28px; }

  /* Save CTA: stack columns vertically on mobile, OR becomes horizontal */
  .save-cta { padding: 40px 0 56px; }
  .save-cta-title { font-size: 26px; margin-bottom: 24px; }
  .save-cta-grid { grid-template-columns: 1fr; gap: 16px; }
  .save-cta-col { padding: 0 16px; }
  .save-cta-col h3 { font-size: 26px; }
  .save-or { padding: 8px 0; }
  .save-or::before {
    top: 50%; bottom: auto;
    left: 0; right: 0;
    width: auto; height: 1px;
    transform: none;
  }
  .save-zip-form { max-width: 100%; }

  .footer-grid { grid-template-columns: 1fr; text-align: center; gap: 20px; }
  .site-footer h4 { text-align: center; }
  .social-icons { justify-content: center; }
  .footer-legal { flex-direction: column; align-items: center; text-align: center; }
}

@media (max-width: 480px) {
  .hero h1 { font-size: 30px; }
  .hero-product { font-size: 13px; min-height: 78px; padding: 12px 6px; }
  svg.hero-product-icon { width: 28px !important; height: 28px !important; }
  .reviews h2, .faq h2, .calc-intro h2, .zip-copy h2, .call-agent h3 { font-size: 28px; }
}

/* ============================================================

/* ============================================================
   Quote wizard styles — ported wholesale from prototype
   /tmp/wcr-hero-insurify/assets/quote.css
   ============================================================ */

/* ========== Quote flow ========== */
.quote-body { background: var(--bg-cream-warm); min-height: 100vh; padding-bottom: 60px; }
.quote-header {
  background: var(--ink);
  border-bottom: 1px solid var(--ink);
  position: sticky; top: 0; z-index: 40;
}
.quote-header .header-inner { padding: 12px 16px; }
.quote-header .brand { color: #fff; }
.quote-header .header-icon-primary {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.6);
  color: #fff;
}
.quote-header .header-icon-primary:hover {
  border-color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.06);
}

/* ---- Welcome-back page ---- */
.welcome-back {
  padding: 32px 24px 80px;
  text-align: center;
}
.welcome-back h1 {
  font-size: 32px; margin: 0 0 4px; font-weight: 900; line-height: 1.1;
}
.purple-rule {
  width: 40px; height: 3px; background: var(--purple); margin: 8px auto 18px; border-radius: 99px;
}
.welcome-back .muted { max-width: 520px; margin: 0 auto 28px; color: var(--ink); font-size: 15px; }
.welcome-row { text-align: left; max-width: 520px; margin: 18px auto; }
.welcome-row h2 { font-size: 20px; margin: 0 0 8px; }
.welcome-row p { font-size: 20px; margin: 0; color: var(--ink); display: flex; align-items: center; gap: 10px; }
.welcome-row + .welcome-row { border-top: 1px solid var(--border); padding-top: 18px; }
.edit-link {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--ink); text-decoration: underline; font-weight: 600;
  margin: 18px 0 28px;
}
.fine-print-sm {
  max-width: 560px; margin: 0 auto 28px; color: var(--muted); font-size: 13px;
}
.welcome-actions {
  display: flex; flex-direction: column; gap: 10px;
  max-width: 320px; margin: 0 auto;
}
.welcome-actions .btn { width: 100%; }

/* ---- Quote shell ---- */
.quote-shell {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 40px;
  padding: 36px 24px 80px;
}

/* Stepper */
.stepper ol { list-style: none; padding: 0; margin: 0; position: sticky; top: 88px; }
.stepper li {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 14px;
  align-items: center;
  padding: 16px 0;
  position: relative;
  color: #888;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 1px;
}
.stepper li .dot {
  width: 14px; height: 14px;
  background: #c9ccd1;
  border-radius: 50%;
  position: relative;
  z-index: 1;
}
.stepper li:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 30px; bottom: -10px;
  left: 6px;
  width: 2px;
  background: #d0d4d8;
}
.stepper li.done .dot { background: var(--ink); }
.stepper li.active { color: var(--purple); }
.stepper li.active .dot { background: var(--purple); }
.stepper li.done { color: var(--ink); }

/* Main column */
.quote-main {
  background: transparent;
  max-width: 1000px;
}
.step {
  animation: fade .2s ease-out;
}
@keyframes fade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

.category-badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px;
  font-weight: 500;
  color: var(--muted);
  margin-bottom: 14px;
  letter-spacing: .2px;
}
.category-badge svg {
  width: 18px; height: 18px;
  color: var(--muted);
}

.step > h1 {
  font-size: 34px;
  line-height: 1.15;
  margin: 0 0 8px;
  font-weight: 900;
  letter-spacing: -.5px;
}
.step > .muted, .vehicle-title + .muted { color: var(--muted); margin: 0 0 24px; }
.vehicle-title {
  font-size: 20px; font-weight: 500; margin: 18px 0 22px;
  color: var(--ink);
}

/* ---- Zip entry screen ---- */
.step-zip { padding: 20px 0 0; }
.zip-entry-screen { max-width: 480px; margin: 0 auto; text-align: center; }
.zip-entry-screen h1 { font-size: 28px; margin: 0 0 4px; font-weight: 900; }
.zip-entry-screen .muted { font-size: 16px; margin: 0 0 28px; }
/* Mirror the hero's ZIP form: input + button flush together, no outer
   wrapper pill. Input is a white card with floating label, Start button
   is the brand-green pill, both 56px tall, gap: 0 so inner edges meet. */
.zip-entry-form {
  display: flex;
  align-items: stretch;
  gap: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  margin: 0 auto;
  max-width: 480px;
}
.zip-entry-form .input-flat {
  flex: 1 1 auto;
  height: 56px;
  margin: 0;
  padding: 6px 18px;
  background: #fff;
  border: 0;
  border-radius: 12px 0 0 12px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: left;
}
.zip-entry-form .input-flat:focus-within {
  box-shadow: inset 0 0 0 2px rgba(38, 206, 107, .35);
}
.zip-entry-form .input-flat span {
  padding: 0;
  font-size: 11px;
  color: var(--muted);
  font-weight: 600;
  letter-spacing: .3px;
  text-transform: uppercase;
  margin: 0;
}
.zip-entry-form .input-flat input {
  border: 0;
  outline: none;
  padding: 0;
  margin: 0;
  background: transparent;
  font-size: 18px;
  font-weight: 700;
  color: var(--ink);
  width: 100%;
}
.zip-start {
  height: 56px;
  padding: 0 32px !important;
  border-radius: 0 12px 12px 0 !important;
  margin: 0 !important;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: .3px;
  text-transform: uppercase;
  flex-shrink: 0;
}
.trust-center { margin: 60px auto 0; text-align: center; }
.trust-center .muted-sm { font-size: 14px; margin: 8px 0 0; }
.trust-center .stars { display: inline-block; }

/* ---- Questions ---- */
.question {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 36px;
  padding: 28px 0;
  border-bottom: 1px solid rgba(0,0,0,.05);
}
.question[hidden] { display: none; }
.q-label { display: flex; gap: 12px; align-items: flex-start; font-size: 20px; font-weight: 700; }
.q-check {
  width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid #c9ccd1;
  flex-shrink: 0;
  display: inline-block;
  transition: background .15s, border-color .15s;
  margin-top: 2px;
}
.q-label strong { font-weight: 700; }
.question.answered .q-check {
  background: var(--success);
  border-color: var(--success);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 14px;
}
.question > p.muted { grid-column: 1; max-width: 380px; font-size: 14px; }
.pt-sm { padding-top: 14px; }

.options { display: flex; flex-direction: column; gap: 10px; grid-column: 2; }
.options-row { flex-direction: row; flex-wrap: wrap; }
.option {
  display: grid;
  grid-template-columns: 22px 1fr;
  -moz-column-gap: 12px;
       column-gap: 12px;
  row-gap: 2px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px 18px;
  cursor: pointer;
  min-height: 56px;
  transition: border-color .15s, background .15s, color .15s;
  flex: 1;
  min-width: 200px;
  position: relative;
}
.option .radio-title { grid-column: 2; grid-row: 1; }
.option .radio-sub { grid-column: 2; grid-row: 2; }
.option input {
  width: 22px; height: 22px;
  accent-color: var(--purple);
  cursor: pointer; flex-shrink: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: 2px solid #c9ccd1;
  border-radius: 50%;
  transition: border-color .15s, background .15s;
}
.option input:checked {
  background: var(--purple);
  border-color: var(--purple);
  background-image: radial-gradient(circle, #fff 30%, var(--purple) 32%);
}
.option .radio-title { font-weight: 600; font-size: 16px; }
.option .radio-sub { display: block; font-size: 13px; color: var(--muted); margin-top: 2px; font-weight: 400; }
.options-stack .option { flex: unset; width: 100%; }
.option:hover { border-color: var(--purple); }
.option:has(input:checked) {
  background: var(--ink);
  border-color: var(--ink);
  color: #fff;
  box-shadow: 0 0 0 2px rgba(38, 206, 107, .85);
}
.option:has(input:checked) .radio-sub { color: #d8d8d8; }
.option:has(input:checked) input {
  background: transparent;
  border: 2px solid #fff;
  background-image: radial-gradient(circle, #fff 35%, transparent 38%);
}

.error-flash { animation: shake .4s; }
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-6px); }
  75% { transform: translateX(6px); }
}

/* ---- Inputs ---- */
.grid-2 { grid-column: 2; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.grid-2 .full { grid-column: 1 / -1; }
.input-flat {
  display: block;
  position: relative;
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 10px;
  padding: 10px 16px 8px;
  transition: border-color .15s, box-shadow .15s;
}
.input-flat:focus-within {
  border-color: var(--purple);
  box-shadow: 0 0 0 2px rgba(38, 206, 107, .15);
}
.input-flat span {
  display: block;
  font-size: 12px;
  color: var(--muted);
  font-weight: 500;
  pointer-events: none;
}
.input-flat input,
.input-flat select {
  border: none;
  background: transparent;
  padding: 2px 0 4px;
  font-size: 17px;
  font-family: inherit;
  color: var(--ink);
  width: 100%;
  outline: none;
}
.input-flat select { -webkit-appearance: none; -moz-appearance: none; appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23666'><path d='M7 10l5 5 5-5z'/></svg>"); background-repeat: no-repeat; background-position: right center; padding-right: 24px; cursor: pointer; }

/* ---- Combobox (typeahead enhancement of native <select>) ---- */
.combobox { position: relative; width: 100%; }
.combobox .cb-native {
  /* Keep the native select in DOM for form submission/value sync, but hidden */
  position: absolute;
  width: 1px; height: 1px;
  opacity: 0;
  pointer-events: none;
  margin: 0;
  padding: 0;
  border: 0;
}
.combobox .cb-input {
  width: 100%;
  border: none;
  background: transparent;
  padding: 2px 24px 4px 0;
  font-size: 17px;
  font-family: inherit;
  color: var(--ink);
  outline: none;
  cursor: pointer;
}
.combobox .cb-caret {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  color: #666;
  pointer-events: auto;
  cursor: pointer;
  display: inline-flex;
  transition: transform .15s ease;
}
.combobox.cb-open .cb-caret { transform: translateY(-50%) rotate(180deg); }
.combobox .cb-list {
  position: absolute;
  top: calc(100% + 6px);
  left: -16px;
  right: -16px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(5, 8, 26, .12);
  list-style: none;
  margin: 0;
  padding: 4px;
  max-height: 260px;
  overflow-y: auto;
  z-index: 50;
}
.combobox .cb-option {
  padding: 10px 12px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 15px;
  color: var(--ink);
}
.combobox .cb-option:hover,
.combobox .cb-option.active {
  background: rgba(38, 206, 107, .12);
  color: var(--ink);
}
.combobox .cb-option.selected { font-weight: 600; }
.combobox .cb-empty { padding: 12px; color: var(--muted); font-size: 14px; text-align: center; }

/* ---- Extra-panel (additional driver / vehicle, revealed inline) ---- */
.extra-panel {
  background: rgba(38, 206, 107, .06);
  border: 1px dashed rgba(38, 206, 107, .45);
  border-radius: 12px;
  padding: 18px 18px 14px;
  margin-top: 6px;
}
.extra-panel .q-label { margin-top: 0; }

/* ---- Birthdate (DOB) field with hybrid text + native date picker ---- */
.dob-field { position: relative; padding-right: 44px; }
.dob-picker-btn {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px; height: 32px;
  border: none;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: 6px;
}
.dob-picker-btn:hover { background: rgba(0,0,0,.04); color: var(--ink); }
/* Native date input is invisible but covers the picker button so its
   built-in calendar popup anchors there when triggered. */
.dob-native {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px; height: 32px;
  opacity: 0;
  pointer-events: none;
  border: 0; padding: 0;
}

.fine-print {
  grid-column: 1 / -1;
  font-size: 12px; color: var(--muted);
  padding: 22px 0;
  max-width: 720px;
}

.consent-box {
  grid-column: 2;
  background: #eef1f4;
  border-radius: 8px;
  padding: 14px 16px;
  color: var(--muted);
  font-size: 13px;
  margin-top: 10px;
}

.nav-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 28px 0 0;
  grid-column: 1 / -1;
}
.back-link {
  border: none; background: transparent;
  color: var(--ink); text-decoration: underline;
  font-size: 15px; cursor: pointer; padding: 10px 0;
  font-family: inherit;
}
.back-link:hover { color: var(--purple); }

/* ---- Coverage cards ---- */
.coverage-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  margin-bottom: 16px;
  box-shadow: var(--shadow-card);
}
.cc-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.cc-head h3 { margin: 0 0 4px; font-size: 22px; font-weight: 800; }
.cc-head p { margin: 0; }
.cc-body { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.cc-body strong { display: block; margin-bottom: 10px; font-size: 14px; }
.cc-line {
  display: flex; justify-content: space-between;
  padding: 6px 0;
  border-bottom: 1px dotted var(--border);
  font-size: 14px;
}
.cc-line b { color: var(--ink); }

/* ---- Results ---- */
.step-results h1 { display: none; }
.results-summary {
  background: #fff;
  border-bottom: 1px solid var(--border);
  padding: 12px 24px;
  display: flex;
  gap: 32px;
  align-items: center;
  margin: -36px -24px 24px;
  font-size: 14px;
  flex-wrap: wrap;
}
.results-summary .link { margin-left: auto; color: var(--purple); }
.results-summary b { margin-left: 4px; }

.results-grid {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 24px;
}
.results-left h3 { font-size: 20px; margin: 0 0 14px; }
.cov-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 14px;
  cursor: pointer;
  transition: border-color .15s, box-shadow .15s;
  position: relative;
}
.cov-card.selected { border-color: var(--ink); box-shadow: 0 0 0 1px var(--ink); }
.cov-card.selected::after {
  content: "✓";
  position: absolute; top: 12px; right: 12px;
  width: 22px; height: 22px; border-radius: 50%; background: var(--ink); color: #fff;
  display: flex; align-items: center; justify-content: center; font-size: 12px;
}
.cov-card strong { font-size: 20px; }
.cov-card p { margin: 2px 0 10px; font-size: 13px; }
.cc-mini { font-size: 13px; margin-top: 8px; }
.cc-mini b { display: block; font-size: 16px; }

.results-toolbar {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 18px;
  display: flex; justify-content: space-between;
  margin-bottom: 14px;
}
.quote-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px;
  margin-bottom: 14px;
  box-shadow: var(--shadow-card);
}
.qc-head { display: flex; gap: 10px; margin-bottom: 6px; flex-wrap: wrap; }
.tag { font-size: 12px; padding: 4px 10px; border-radius: 99px; font-weight: 700; }
.tag.accent { background: #fdeaa3; color: #6c5a00; }
.tag.fav { background: #f9dbe9; color: #8b1546; }
.qc-top {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 20px;
  align-items: center;
  padding: 10px 0 14px;
}
.qc-carrier { font-size: 24px; font-weight: 900; letter-spacing: -.5px; color: #ed1c24; }
.qc-carrier.geico { color: #004B86; }
.qc-carrier.allstate { color: #002C5F; }
.qc-carrier.libertymutual { color: #FCD116; text-shadow: 0 0 1px var(--ink); }
.qc-carrier.statefarm { color: #C8102E; }
.qc-carrier.usaa { color: #04366C; }
.qc-price { text-align: right; }
.qc-price .price { font-size: 28px; font-weight: 800; color: var(--purple); }
.qc-price .price-sub { font-size: 12px; color: var(--muted); }
.qc-tabs {
  display: flex; gap: 18px; border-bottom: 1px solid var(--border); padding-bottom: 6px; margin-bottom: 14px; font-weight: 600; font-size: 14px; color: var(--muted);
}
.qc-tabs span { padding: 6px 0; cursor: pointer; }
.qc-tabs span.active { color: var(--ink); border-bottom: 3px solid var(--purple); }
.qc-details { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; font-size: 13px; }
.qc-details .kv { display: flex; justify-content: space-between; padding: 4px 0; }
.qc-details .hl { display: flex; align-items: center; gap: 6px; padding: 4px 0; color: var(--ink); }
.qc-actions { display: flex; justify-content: space-between; align-items: center; margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--border); flex-wrap: wrap; gap: 10px; }

/* ===========================================
   MOBILE — one-question-per-screen layout
   =========================================== */
@media (max-width: 780px) {
  .quote-shell {
    grid-template-columns: 1fr;
    padding: 16px 20px 40px;
    gap: 0;
  }
  .stepper {
    margin-bottom: 8px;
  }
  .stepper ol {
    position: static;
    display: flex;
    justify-content: space-between;
    gap: 4px;
    padding: 10px 0;
  }
  .stepper li {
    grid-template-columns: 10px auto;
    padding: 4px 0;
    font-size: 10px;
    gap: 6px;
  }
  .stepper li:not(:last-child)::after { display: none; }
  .stepper li .dot { width: 10px; height: 10px; }
  .stepper li .label { display: none; }
  .stepper li.active .label,
  .stepper li.done .label { display: inline; }

  .step > h1 { font-size: 24px; }
  .category-badge { font-size: 11px; }

  .question {
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 18px 0;
  }
  .q-label { font-size: 18px; }
  .question > p.muted { max-width: 100%; }
  .options { grid-column: 1; }
  .option { min-width: 0; padding: 14px 16px; }
  .options-row { flex-direction: column; }
  .options-row .option { flex: unset; width: 100%; }

  .grid-2 { grid-column: 1; grid-template-columns: 1fr; }
  .grid-2 .full { grid-column: 1; }
  .consent-box { grid-column: 1; }

  /* State + ZIP side-by-side matching the live mobile flow */
  .grid-2 .state-zip { grid-template-columns: 1fr 1fr; display: grid; gap: 12px; }

  .coverage-card { padding: 18px; }
  .cc-head { flex-direction: column; align-items: stretch; }
  .cc-head .btn { width: 100%; margin-top: 10px; }
  .cc-body { grid-template-columns: 1fr; gap: 14px; }

  .results-summary { gap: 10px; font-size: 12px; padding: 10px 16px; margin: -16px -20px 14px; }
  .results-grid { grid-template-columns: 1fr; }
  .results-left { order: 2; }
  .results-left h3 { margin-top: 20px; }

  .qc-details { grid-template-columns: 1fr; }

  /* Sticky Save & continue on mobile */
  .nav-row {
    position: sticky;
    bottom: 0;
    background: linear-gradient(to bottom, rgba(250,245,235,0) 0%, var(--bg-cream-warm) 30%);
    padding: 18px 0 14px;
    margin: 0 -20px;
    padding-left: 20px; padding-right: 20px;
  }

  .zip-entry-form { flex-direction: row; }
  .welcome-back { padding: 24px 20px 60px; }
  .welcome-back h1 { font-size: 28px; }
}

@media (max-width: 480px) {
  .step > h1 { font-size: 22px; }
}

   Admin dashboard styles
   ============================================================ */
/* ----- Admin shell: top-bar + main (always responsive, no broken sidebar) ----- */
.admin-shell {
  min-height: 100vh;
  background: #f8fafc;
  display: flex;
  flex-direction: column;
}

.admin-topbar {
  background: var(--ink);
  color: #fff;
  border-bottom: 1px solid rgba(255, 255, 255, .06);
  position: sticky;
  top: 0;
  z-index: 40;
}
.admin-topbar-inner {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 12px 24px;
  max-width: 1440px;
  margin: 0 auto;
  flex-wrap: wrap;
}
.admin-brand {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  text-decoration: none;
  flex-shrink: 0;
}
.admin-brand:hover { text-decoration: none; }
.admin-brand-mark {
  font-size: 18px;
  font-weight: 900;
  color: #fff;
  letter-spacing: -0.3px;
}
.admin-brand-label {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.55);
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.admin-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  flex: 1;
  min-width: 0;
}
.admin-nav-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 8px;
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
  transition: background .15s, color .15s;
}
.admin-nav-item:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  text-decoration: none;
}
.admin-nav-item svg.icon { color: currentColor; }

.admin-user {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.admin-user-link {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.7);
  transition: all .15s;
}
.admin-user-link:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.4);
  color: #fff;
  text-decoration: none;
}
.admin-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--purple);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.3px;
}

.admin-main {
  flex: 1;
  padding: 32px 36px;
  max-width: 1440px;
  width: 100%;
  margin: 0 auto;
}
@media (max-width: 640px) {
  .admin-main { padding: 20px 16px; }
  .admin-topbar-inner { padding: 10px 16px; gap: 16px; }
  .admin-nav-item span { display: none; }
  .admin-nav-item { padding: 8px 10px; }
}
.admin-main h1 { margin-top: 0; font-size: 28px; font-weight: 900; }

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
  margin: 20px 0 28px;
}
.kpi-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px;
}
.kpi-card.kpi-muted { background: #f3f4f6; }
.kpi-label { font-size: 12px; color: var(--muted); font-weight: 700; text-transform: uppercase; letter-spacing: .3px; }
.kpi-value { font-size: 28px; font-weight: 900; color: var(--ink); margin-top: 6px; }
.kpi-delta { font-size: 13px; color: var(--success); margin-top: 4px; font-weight: 600; }

.admin-section { margin: 32px 0; }
.admin-section h2 { font-size: 18px; font-weight: 800; margin: 0 0 12px; }
.quick-links, .status-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.quick-links li { padding: 6px 0; }
.status-list li { padding: 6px 0; display: flex; align-items: center; gap: 8px; }

.status-dot {
  display: inline-block;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: #d1d5db;
  margin-right: 8px;
}
.status-dot.ok { background: #22c55e; }
.status-dot.warn { background: #f59e0b; }

.empty-state {
  background: #fff;
  border: 1px dashed var(--border);
  border-radius: 14px;
  padding: 24px;
  color: var(--muted);
  margin-top: 16px;
}

.leads-table-wrap {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow-x: auto;
  margin-top: 12px;
}
.leads-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.leads-table th, .leads-table td {
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.leads-table th { background: #f9fafb; font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .3px; }
.leads-table tbody tr:hover { background: #f9fafb; }
.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .3px;
  background: #e5e7eb;
  color: #374151;
}
.badge-synced { background: #dcfce7; color: #166534; }
.badge-pending_crm { background: #fef3c7; color: #92400e; }
.badge-captured { background: #dbeafe; color: #1e3a8a; }
.badge-rejected, .badge-invalid { background: #fee2e2; color: #991b1b; }
.badge-converted { background: #ede9fe; color: #5b21b6; }

.login-shell {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-cream-warm);
}
.login-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 40px 36px;
  max-width: 420px;
  width: 100%;
  text-align: center;
  box-shadow: 0 8px 28px rgba(5, 8, 26, .06);
}
.login-card h1 { margin: 0 0 8px; font-size: 26px; font-weight: 900; }

/* ============================================================
   QuoteWizard React additions (extends prototype quote.css)
   ============================================================ */

/* Wrap for the 3-card coverage selection */
.cov-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin: 18px 0 20px;
}
.cov-card {
  text-align: left;
  cursor: pointer;
  position: relative;
  display: flex;
  flex-direction: column;
}
.cov-card.popular { border-color: var(--purple); box-shadow: 0 0 0 1px var(--purple); }
.cov-tag {
  position: absolute;
  top: -10px;
  right: 12px;
  background: var(--purple);
  color: #fff;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .3px;
  text-transform: uppercase;
}
.cov-name { font-size: 18px; font-weight: 900; margin-bottom: 4px; }
.cov-price { font-size: 14px; color: var(--purple); font-weight: 700; margin-bottom: 8px; }
.cov-desc { font-size: 13px; color: var(--muted); margin: 0 0 12px; flex: 1; }
.cov-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 700;
  color: var(--purple);
  margin-top: auto;
}

.quotes-list { display: flex; flex-direction: column; gap: 14px; margin-top: 16px; }

/* Vertical chooser cards (start screen) */
.vertical-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.vertical-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 22px 14px;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  background: #fff;
  cursor: pointer;
  transition: border-color .15s, box-shadow .15s, transform .15s;
  font-family: inherit;
}
.vertical-card:hover { border-color: var(--purple); transform: translateY(-1px); }
.vertical-card.selected {
  border-color: var(--purple);
  box-shadow: 0 0 0 2px rgba(38, 206, 107, .18);
}

/* Cookie banner positioning (prototype's CSS only handles styles, not the layout) */
.cookie-banner {
  position: fixed;
  bottom: 14px;
  left: 14px;
  right: 14px;
  max-width: 480px;
  z-index: 100;
  padding: 16px 18px;
  background: var(--ink);
  color: #fff;
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.25);
}
@media (min-width: 640px) {
  .cookie-banner { left: auto; right: 14px; }
}

/* Combobox (used by every <select> we replace in the wizard) */
.combobox { position: relative; width: 100%; }
.combobox .cb-input {
  width: 100%;
  border: none;
  background: transparent;
  padding: 2px 24px 4px 0;
  font-size: 16px;
  font-family: inherit;
  color: var(--ink);
  outline: none;
  cursor: pointer;
}
.combobox .cb-caret {
  position: absolute; right: 0; top: 50%;
  transform: translateY(-50%);
  color: #666;
  pointer-events: none;
  display: inline-flex;
  transition: transform .15s ease;
}
.combobox.cb-open .cb-caret { transform: translateY(-50%) rotate(180deg); }
.combobox .cb-list {
  position: absolute;
  top: calc(100% + 8px);
  left: -14px;
  right: -14px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(5, 8, 26, .12);
  list-style: none;
  margin: 0;
  padding: 4px;
  max-height: 260px;
  overflow-y: auto;
  z-index: 50;
}
.combobox .cb-option {
  padding: 10px 12px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 15px;
  color: var(--ink);
}
.combobox .cb-option:hover,
.combobox .cb-option.active {
  background: rgba(38, 206, 107, .12);
}
.combobox .cb-option.selected { font-weight: 700; }
.combobox .cb-empty { padding: 12px; color: var(--muted); font-size: 14px; text-align: center; }

/* Highlight selected radio option (matches prototype's data-q + .answered logic) */
.option.selected {
  border-color: var(--purple);
  box-shadow: 0 0 0 1px var(--purple);
}

.form-error {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 14px;
}

/* ============================================================
   Premium UX overrides — Phase 1 conversion polish
   - Cream-warm bg (vs clinical white)
   - Green radio fill (vs hostile black)
   - Options with elevation + hover lift
   - Sticky CTA bar (always visible)
   - Compact Yes/No (max 280px each)
   - Reassurance banner at top of form
   ============================================================ */

/* 1. Cream background for the quote experience (vs body white).
   Body inherits cream too — otherwise any gap between navbar and main
   shows as a stray white strip (browser rendering quirk with sticky
   header + transformed/rounded children). */
body:has(> main.quote-body) {
  background: var(--bg-cream-warm);
}
.quote-body {
  background: var(--bg-cream-warm);
  min-height: 100vh;
  padding-bottom: 80px;
}

/* Match prototype: questions sit directly on the cream bg (no enclosing card).
   White comes from the .option / .input-flat children, which then "pop" against
   the warm cream — feels lighter and more premium than a card-on-card sandwich. */
.quote-shell {
  background: transparent;
  margin-top: 24px;
}

/* 2. Modern radio: green outline → green fill with white dot */
.option input[type="radio"] {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  width: 22px;
  height: 22px;
  border: 2px solid #c9ccd1;
  border-radius: 50%;
  margin: 0;
  flex-shrink: 0;
  background: #fff;
  cursor: pointer;
  transition: all .18s cubic-bezier(.4, 0, .2, 1);
  position: relative;
}
.option:hover input[type="radio"] { border-color: var(--purple); }
.option input[type="radio"]:checked {
  border-color: var(--purple);
  background: var(--purple);
}
.option input[type="radio"]:checked::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
  animation: cb-pop .28s cubic-bezier(.34, 1.56, .64, 1);
}
@keyframes cb-pop {
  0% { transform: translate(-50%, -50%) scale(0); }
  100% { transform: translate(-50%, -50%) scale(1); }
}

/* 3. Option cards: hover lift + selected-state tint */
.option {
  background: #fff;
  border: 1.5px solid var(--border);
  transition: border-color .2s ease, box-shadow .2s ease, transform .15s ease, background .2s ease;
}
.option:hover {
  border-color: rgba(38, 206, 107, .45);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(5, 8, 26, .05);
}
/* Selected = decisive brand-green fill + white text. Industry-standard pattern
   (Insurify, Lemonade): bold visual feedback that the choice "stuck", brand
   color reinforces "you saved/chose well", contrast meets WCAG AA. */
.option.selected,
.option:has(input:checked) {
  border-color: var(--purple);
  background: var(--purple);
  color: #fff;
  box-shadow: 0 4px 14px rgba(38, 206, 107, .35), 0 1px 3px rgba(38, 206, 107, .25);
}
.option:has(input:checked) .radio-title { color: #fff; font-weight: 700; }
.option:has(input:checked) .radio-sub { color: rgba(255, 255, 255, .85); }
/* Radio dot inside the selected (now-green) card — invert so it's visible:
   white outer ring + green dot center (echoes the white check on the question). */
.option:has(input:checked) input[type="radio"] {
  border-color: #fff;
  background: #fff;
}
.option:has(input:checked) input[type="radio"]::after {
  background: var(--purple);
}

/* 4. Sticky CTA bar (always visible at bottom of viewport while scrolling form) */
.nav-row {
  position: sticky;
  bottom: 0;
  background: linear-gradient(to bottom, transparent 0%, var(--bg-cream-warm) 35%);
  padding: 22px 0 14px;
  margin: 24px -20px -20px;
  padding-left: 20px;
  padding-right: 20px;
  z-index: 10;
}

/* 5. Compact Yes/No / row-style options (max 280px each, side by side) */
.options-row {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 12px;
}
.options-row .option {
  flex: 1 1 140px;
  min-width: 120px;
  max-width: 280px;
}

/* 6. Reassurance banner (top of every step) */
.quote-reassure {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 18px;
  padding: 10px 18px;
  background: rgba(38, 206, 107, .08);
  border: 1px solid rgba(38, 206, 107, .25);
  border-radius: 999px;
  font-size: 13px;
  color: var(--ink);
  margin-bottom: 22px;
  font-weight: 600;
}
.quote-reassure-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.quote-reassure-item svg {
  width: 14px !important;
  height: 14px !important;
  color: var(--success);
  flex-shrink: 0;
}
.quote-reassure-divider {
  width: 1px;
  height: 14px;
  background: rgba(38, 206, 107, .35);
}

/* 7. Question card: subtle elevation + hover focus ring */
.question {
  padding: 24px 24px 20px;
  border-radius: 14px;
  border: 1.5px solid transparent;
  transition: border-color .2s ease, background .2s ease;
}
.question:focus-within {
  border-color: rgba(38, 206, 107, .35);
  background: rgba(38, 206, 107, .015);
}

/* Spacing between consecutive questions feels generous */
.question + .question { margin-top: 4px; }

/* 8. Step header polish: badge gets weight, title bigger */
.step > h1 {
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -.4px;
  margin: 6px 0 8px;
}
.step > .muted {
  font-size: 15px;
  color: var(--muted);
  margin: 0 0 24px;
}
.category-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  background: rgba(22, 55, 132, .08);
  color: var(--hero-bg);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .4px;
  text-transform: uppercase;
}
.category-badge svg {
  width: 14px !important;
  height: 14px !important;
  color: var(--hero-bg);
}

/* 9. Stepper polish: active dot pulse + connecting line */
.stepper li.active .dot {
  box-shadow: 0 0 0 4px rgba(38, 206, 107, .2);
  animation: dot-pulse 2s ease-in-out infinite;
}
@keyframes dot-pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(38, 206, 107, .2); }
  50% { box-shadow: 0 0 0 8px rgba(38, 206, 107, .12); }
}

/* 10. Save & continue — make it more "pressable" */
.nav-row .btn-primary {
  padding: 14px 32px;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .3px;
  box-shadow: 0 4px 14px rgba(38, 206, 107, .25), 0 1px 3px rgba(38, 206, 107, .15);
  transition: transform .15s ease, box-shadow .2s ease;
}
.nav-row .btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(38, 206, 107, .3), 0 2px 5px rgba(38, 206, 107, .2);
}
.nav-row .btn-primary:active { transform: translateY(0); }

/* (Admin layout responsive fix removed — replaced by always-responsive top-bar) */
/* Admin layout responsive fix removed — top-bar above is always responsive */

/* ============================================================
   /admin/leads — Material-style filterable table
   ============================================================ */
.leads-table-shell {
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 1px 2px rgba(5, 8, 26, .04), 0 4px 14px rgba(5, 8, 26, .06);
  overflow: hidden;
  margin-top: 20px;
}

/* Toolbar (search + date picker) */
.leads-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  padding: 18px 20px 12px;
  border-bottom: 1px solid var(--border);
}
.search-input {
  position: relative;
  flex: 1;
  min-width: 220px;
  display: flex;
  align-items: center;
}
.search-input svg.icon {
  position: absolute;
  left: 12px;
  color: var(--muted);
  pointer-events: none;
}
.search-input input {
  width: 100%;
  padding: 10px 36px 10px 38px;
  border: 1px solid var(--border);
  border-radius: 10px;
  font-size: 14px;
  background: #fff;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.search-input input:focus {
  border-color: var(--purple);
  box-shadow: 0 0 0 3px rgba(38, 206, 107, .15);
}
.search-clear {
  position: absolute;
  right: 8px;
  width: 22px;
  height: 22px;
  border: 0;
  background: var(--muted);
  color: #fff;
  border-radius: 50%;
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
.search-clear:hover { background: var(--ink); }

/* Date range picker trigger + menu */
.date-range-picker {
  position: relative;
  flex-shrink: 0;
}
.date-range-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #fff;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  cursor: pointer;
  transition: border-color .15s;
}
.date-range-trigger:hover { border-color: var(--purple); }
.date-range-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(5, 8, 26, .12);
  min-width: 460px;
  z-index: 30;
  display: grid;
  grid-template-columns: 1fr 1fr;
  overflow: hidden;
}
@media (max-width: 600px) {
  .date-range-menu { grid-template-columns: 1fr; min-width: 280px; right: -50%; }
}
.date-preset-list {
  list-style: none;
  margin: 0;
  padding: 6px;
  border-right: 1px solid var(--border);
}
.date-preset {
  display: block;
  width: 100%;
  text-align: left;
  padding: 9px 12px;
  border: 0;
  background: transparent;
  cursor: pointer;
  border-radius: 8px;
  font-size: 14px;
  color: var(--ink);
}
.date-preset:hover { background: rgba(38, 206, 107, .08); }
.date-preset.selected { background: var(--purple); color: #fff; font-weight: 700; }
.date-custom {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.date-custom h4 { margin: 0 0 4px; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .3px; color: var(--muted); }
.date-custom label { display: flex; flex-direction: column; gap: 4px; font-size: 12px; color: var(--muted); font-weight: 600; }
.date-custom input[type="date"] {
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 14px;
  font-family: inherit;
  background: #fff;
}
.date-custom .btn { margin-top: 6px; }

/* Filter chips */
.leads-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--border);
  background: #f9fafb;
}
.filter-chip { position: relative; }
.chip-trigger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  cursor: pointer;
  transition: all .15s;
}
.chip-trigger:hover { border-color: var(--purple); }
.chip-trigger.active {
  background: var(--purple);
  color: #fff;
  border-color: var(--purple);
}
.chip-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(5, 8, 26, .1);
  padding: 6px;
  min-width: 180px;
  z-index: 30;
  max-height: 300px;
  overflow-y: auto;
}
.chip-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  cursor: pointer;
  border-radius: 6px;
  font-size: 14px;
}
.chip-option:hover { background: rgba(38, 206, 107, .08); }
.chip-option input[type="checkbox"] { accent-color: var(--purple); }
.state-input {
  padding: 6px 12px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  width: 110px;
  outline: none;
  text-transform: uppercase;
}
.state-input:focus {
  border-color: var(--purple);
  box-shadow: 0 0 0 2px rgba(38, 206, 107, .18);
}
.clear-filters {
  margin-left: auto;
  padding: 6px 12px;
  border: 0;
  background: transparent;
  color: var(--purple);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  border-radius: 6px;
}
.clear-filters:hover { background: rgba(38, 206, 107, .08); }

.leads-meta {
  padding: 12px 20px;
  font-size: 13px;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
}
.leads-meta strong { color: var(--ink); }
.meta-error { color: #991b1b; }

/* Material-style table refinements */
.leads-table-wrap.material {
  background: #fff;
  border: 0;
  border-radius: 0;
  margin: 0;
}
.leads-table-wrap.material .leads-table th {
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .4px;
  background: #fff;
  padding: 14px 16px 10px;
  border-bottom: 2px solid var(--border);
}
.leads-table-wrap.material .leads-table td {
  padding: 14px 16px;
  font-size: 13px;
  border-bottom: 1px solid #f3f4f6;
  vertical-align: middle;
}
.leads-table-wrap.material .leads-table tbody tr {
  transition: background .15s;
}
.leads-table-wrap.material .leads-table tbody tr:hover {
  background: rgba(38, 206, 107, .04);
}
.leads-table .empty-row {
  text-align: center;
  padding: 36px;
  color: var(--muted);
  font-style: italic;
}
.cell-mono { font-family: ui-monospace, SF Mono, Menlo, monospace; font-size: 12px; }
.cell-name { font-weight: 600; color: var(--ink); }
.pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  text-transform: capitalize;
}
.pill-wise { background: #ecfdf5; color: #065f46; }
.pill-megaleads { background: #eff6ff; color: #1e40af; }
.pill-vertical { background: #f3f4f6; color: #374151; }

/* Pagination */
.leads-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  background: #f9fafb;
  flex-wrap: wrap;
  gap: 14px;
}
.pagination-limit label {
  font-size: 13px;
  color: var(--muted);
  font-weight: 600;
}
.pagination-limit select {
  padding: 4px 8px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  font-family: inherit;
  background: #fff;
  margin-left: 4px;
}
.pagination-controls {
  display: flex;
  align-items: center;
  gap: 4px;
}
.pagination-controls button {
  width: 32px;
  height: 32px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fff;
  cursor: pointer;
  font-size: 16px;
  color: var(--ink);
  font-weight: 700;
  transition: all .15s;
}
.pagination-controls button:hover:not(:disabled) {
  border-color: var(--purple);
  color: var(--purple);
}
.pagination-controls button:disabled {
  opacity: .35;
  cursor: not-allowed;
}
.pagination-current {
  padding: 0 14px;
  font-size: 13px;
  color: var(--muted);
}
.pagination-current strong { color: var(--ink); }
.hover\:bg-white\/90:hover {
  background-color: rgb(255 255 255 / 0.9);
}
@media (min-width: 768px) {

  .md\:text-5xl {
    font-size: 3rem;
    line-height: 1;
  }
}

