/* ===== QUOTES PAGE LAYOUT ===== */
.quotes-page{min-height:100vh;display:flex;flex-direction:column}
.quotes-main{flex:1;padding:60px 0;background:linear-gradient(170deg,var(--white) 60%,#fef9ec 100%)}
.quotes-container{max-width:1700px;margin:0 auto;padding:0 20px}

/* ===== INTAKE CARD ===== */
.intake-card{background:var(--white);border-radius:var(--radius-lg);padding:48px;box-shadow:var(--shadow-lg);max-width:640px;margin:0 auto}

/* ===== INTAKE FORM (page version) ===== */
.intake-progress{height:4px;background:var(--gray-200);border-radius:2px;margin-bottom:36px;overflow:hidden}
.intake-progress__bar{height:100%;background:var(--accent);border-radius:2px;transition:width 0.4s ease;width:20%}
.intake-steps{position:relative}
.intake-step{display:none;animation:fadeInUp 0.3s ease}
.intake-step.active{display:block}
.intake-step__title{font-size:1.5rem;font-weight:800;margin-bottom:8px;letter-spacing:-0.02em}
.intake-step__subtitle{color:var(--gray-600);font-size:0.95rem;margin-bottom:28px}

.intake-options{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}
.intake-options--two{grid-template-columns:repeat(2,1fr)}
.intake-option{display:flex;flex-direction:column;align-items:center;gap:10px;padding:24px 16px;border:2px solid var(--gray-200);border-radius:var(--radius-lg);background:var(--white);cursor:pointer;font-family:inherit;font-size:0.95rem;font-weight:600;color:var(--gray-600);transition:all 0.2s ease}
.intake-option:hover{border-color:var(--accent);color:var(--black)}
.intake-option.selected{border-color:var(--accent);background:#fef9ec;color:var(--black)}
.intake-option svg{color:var(--gray-400);transition:color 0.2s}
.intake-option:hover svg,.intake-option.selected svg{color:var(--accent)}

.intake-slider-wrap{margin-bottom:32px}
.intake-slider__value{text-align:center;font-size:2.5rem;font-weight:800;color:var(--accent);margin-bottom:20px;letter-spacing:-0.02em}
.intake-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;background:var(--gray-200);border-radius:3px;outline:none;transition:background 0.2s}
.intake-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 2px 8px rgba(244,186,62,.4);transition:transform 0.15s}
.intake-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}
.intake-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;box-shadow:0 2px 8px rgba(244,186,62,.4)}
.intake-slider__labels{display:flex;justify-content:space-between;margin-top:8px;font-size:0.8rem;color:var(--gray-400)}
.intake-usage{margin-top:16px;text-align:center;font-size:0.95rem;color:var(--gray-600)}
.intake-usage strong{color:var(--black);font-weight:700}

.intake-address-wrap{margin-bottom:28px}
.intake-address-field{position:relative}
.intake-address-input{
  width:100%;
  padding:18px 20px;
  border:2px solid var(--gray-200);
  border-radius:14px;
  font-size:1rem;
  font-family:inherit;
  font-weight:500;
  color:var(--black);
  background:#fff;
  background-image:linear-gradient(180deg,#ffffff 0%,#fefbf3 100%);
  box-shadow:0 1px 2px rgba(0,0,0,.03);
  transition:border-color 0.2s ease, box-shadow 0.2s ease;
}
.intake-address-input::placeholder{color:#a3a3a3;font-weight:500}
.intake-address-input:hover:not(:focus){border-color:#d1d5db}
.intake-address-input:focus{
  outline:none;
  border-color:var(--accent);
  background-image:linear-gradient(180deg,#ffffff 0%,#fff7e0 100%);
  box-shadow:0 0 0 4px rgba(244,186,62,.18), 0 2px 6px rgba(244,186,62,.12);
}
.intake-address-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--white);border:1px solid var(--gray-200);border-top:none;border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow-md);display:none;z-index:10;max-height:240px;overflow-y:auto}
.intake-address-dropdown.visible{display:block}
.intake-address-item{padding:12px 20px;cursor:pointer;font-size:0.9rem;color:var(--gray-600);transition:background 0.15s;border-bottom:1px solid var(--gray-100)}
.intake-address-item:last-child{border-bottom:none}
.intake-address-item:hover{background:var(--gray-50);color:var(--black)}

.intake-nav{display:flex;justify-content:space-between;gap:12px;margin-top:8px}
.intake-nav .btn{min-width:120px}

/* ===== TEXT INPUTS (name/email/phone) ===== */
.intake-fields{display:flex;flex-direction:column;gap:14px;margin-bottom:28px}
.intake-fields__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.intake-fields__row{grid-template-columns:1fr}}
.intake-input{
  width:100%;
  padding:18px 20px;
  border:2px solid var(--gray-200);
  border-radius:14px;
  font-size:1rem;
  font-family:inherit;
  font-weight:500;
  color:var(--black);
  background:#fff;
  background-image:linear-gradient(180deg,#ffffff 0%,#fefbf3 100%);
  box-shadow:0 1px 2px rgba(0,0,0,.03);
  transition:border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
.intake-input::placeholder{color:#a3a3a3;font-weight:500}
.intake-input:hover:not(:focus){border-color:#d1d5db}
.intake-input:focus{
  outline:none;
  border-color:var(--accent);
  background-image:linear-gradient(180deg,#ffffff 0%,#fff7e0 100%);
  box-shadow:0 0 0 4px rgba(244,186,62,.18), 0 2px 6px rgba(244,186,62,.12);
}
.intake-input:not(:placeholder-shown):not(:focus){border-color:#d1d5db}

/* ===== CONFIRM PROPERTY ===== */
.intake-satellite{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--radius-lg);overflow:hidden;background:var(--gray-100);margin-bottom:16px;border:2px solid var(--gray-200)}
.intake-satellite img{width:100%;height:100%;object-fit:cover;display:block}
.intake-satellite__fallback{position:absolute;inset:0;display:none;align-items:center;justify-content:center;color:var(--gray-400);font-size:0.9rem;font-weight:600}
.intake-confirm{background:#fef9ec;border:2px solid var(--accent);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:28px}
.intake-confirm__label{font-size:0.75rem;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:6px}
.intake-confirm__address{font-size:1rem;font-weight:600;color:var(--black);line-height:1.5}

/* ===== FILE UPLOAD ===== */
.intake-upload{margin-bottom:28px}
.intake-upload__label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 20px;border:2px dashed var(--gray-200);border-radius:var(--radius-lg);background:var(--white);cursor:pointer;color:var(--gray-600);font-weight:600;font-size:0.95rem;transition:all 0.2s ease;text-align:center}
.intake-upload__label:hover{border-color:var(--accent);color:var(--black);background:#fef9ec}
.intake-upload__label svg{color:var(--gray-400);transition:color 0.2s}
.intake-upload__label:hover svg{color:var(--accent)}

/* ===== QUOTES RESULTS ===== */
.quotes-header{margin-bottom:40px}
.quotes-header__top{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.quotes-header__title{font-size:2.25rem;font-weight:800;letter-spacing:-0.02em;margin-bottom:8px}
.quotes-header__subtitle{color:var(--gray-600);font-size:1rem}

.quotes-header__actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}

.advisor-chip{
  appearance:none;
  display:inline-flex;align-items:center;gap:10px;
  padding:6px 14px 6px 6px;
  background:#fff;
  border:1px solid var(--gray-200);
  border-radius:999px;
  cursor:pointer;
  font-family:inherit;
  color:var(--black);
  box-shadow:0 1px 3px rgba(0,0,0,.06);
  transition:border-color 0.2s,box-shadow 0.2s,transform 0.15s;
}
.advisor-chip:hover{border-color:var(--accent);box-shadow:0 4px 14px rgba(244,186,62,.22);transform:translateY(-1px)}
.advisor-chip__avatar{
  width:38px;height:38px;border-radius:50%;object-fit:cover;
  border:2px solid var(--accent);
  flex-shrink:0;
}
.advisor-chip__text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1}
.advisor-chip__label{font-size:0.85rem;font-weight:700;color:var(--black)}
.advisor-chip__name{
  font-size:0.72rem;font-weight:600;color:var(--gray-600);margin-top:3px;
  display:inline-flex;align-items:center;gap:5px;
}
.advisor-chip__name::before{
  content:'';width:6px;height:6px;border-radius:50%;background:#22c55e;
}

.quotes-toggle{
  position:relative;
  display:inline-flex;
  background:#f1f1f3;
  border-radius:999px;
  padding:5px;
  gap:0;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.06);
}
.quotes-toggle__btn{
  position:relative;
  z-index:1;
  appearance:none;
  border:none;
  background:transparent;
  padding:11px 26px;
  font-family:inherit;
  font-size:0.92rem;
  font-weight:700;
  color:#6b7280;
  cursor:pointer;
  border-radius:999px;
  transition:color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
  white-space:nowrap;
  letter-spacing:-0.005em;
}
.quotes-toggle__btn:hover:not(.quotes-toggle__btn--active){color:#111}
.quotes-toggle__btn--active{
  color:#111;
  background:var(--accent);
  box-shadow:
    0 1px 2px rgba(0,0,0,.10),
    0 4px 14px rgba(244,186,62,.45);
}
.quotes-toggle__btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

@media(max-width:640px){
  .quotes-header__top{flex-direction:column;align-items:flex-start;gap:16px}
  .quotes-toggle{align-self:stretch;display:grid;grid-template-columns:1fr 1fr}
  .quotes-toggle__btn{padding:12px 12px}
}

.quotes-layout{display:grid;grid-template-columns:280px 1fr;gap:20px;align-items:start}
.quotes-side{display:flex;flex-direction:column;gap:20px;position:sticky;top:24px}
.quotes-side .quotes-stats{position:static;top:auto}
.quotes-bill{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}
.quotes-bill__head{padding:16px 18px;border-bottom:1px solid var(--gray-200);font-weight:700;font-size:0.95rem;color:var(--black)}
.quotes-bill__body{padding:16px 18px}
.quotes-bill__img{display:block;width:100%;height:auto;border-radius:8px;border:1px solid var(--gray-200)}
.quotes-bill__pdf{display:flex;align-items:center;gap:10px;padding:14px 16px;border:1px solid var(--gray-200);border-radius:8px;text-decoration:none;color:var(--black);font-weight:600;font-size:0.92rem}
.quotes-bill__pdf:hover{border-color:var(--accent)}
.quotes-bill__prompt{display:block;padding:22px 18px;text-align:center;cursor:pointer;color:var(--gray-600)}
.quotes-bill__prompt:hover{background:#fff9ec}
.quotes-bill__prompt-icon{font-size:1.6rem;line-height:1;display:block;margin-bottom:8px}
.quotes-bill__prompt strong{display:block;color:var(--black);font-size:0.98rem;margin-bottom:4px}
.quotes-bill__prompt span.sub{font-size:0.82rem;color:var(--gray-600)}
.quotes-bill__note{font-size:0.78rem;color:var(--gray-600);margin:10px 0 0;text-align:center}
@media(max-width:880px){.quotes-side{position:static}}
/* 4 row tracks per card row: head, details (fills), finance, cta.
   Each .quote-card is a subgrid spanning these 4 rows, so the corresponding
   section in every card lines up horizontally regardless of how tall each
   card's individual content is. */
.quotes-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:auto 1fr auto auto;gap:20px}
.quotes-note{text-align:center;font-size:0.8rem;color:var(--gray-400);margin-top:24px}
.quotes-actions{text-align:center;margin-top:24px}

/* EV charger upsell banner — sits in the right column of .quotes-layout
   (grid-column:2) so it spans exactly the width of the quotes-grid above. */
.quotes-ev-banner{grid-column:2;display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:10px;padding:22px 28px;background:#fffaed;border:1px solid var(--gray-200);border-left:4px solid var(--accent);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.quotes-ev-banner__text{display:flex;flex-direction:column;gap:4px;text-align:left}
.quotes-ev-banner__title{font-size:1.15rem;font-weight:800;color:var(--black);letter-spacing:-0.01em;line-height:1.2}
.quotes-ev-banner__sub{font-size:0.92rem;color:var(--gray-600);line-height:1.4}
.quotes-ev-banner__cta{flex-shrink:0;white-space:nowrap}

@media(max-width:980px){
  .quotes-ev-banner{grid-column:1/-1}
}
@media(max-width:640px){
  .quotes-ev-banner{flex-direction:column;align-items:stretch;text-align:left;gap:16px;padding:20px}
  .quotes-ev-banner__cta{text-align:center}
}

/* ===== STATS PANEL ===== */
.quotes-stats{position:sticky;top:24px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;display:flex;flex-direction:column}
.quotes-stats__inner{padding:24px;display:flex;flex-direction:column;gap:18px}
.quotes-stats__placeholder{color:var(--gray-400);font-size:0.9rem;text-align:center;padding:24px}
.quotes-stats__satellite{display:block;width:100%;height:200px;object-fit:cover;background:var(--gray-100)}
.quotes-stats__title{font-size:0.78rem;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:8px}
.quotes-stats__savings{font-size:2.25rem;font-weight:800;color:var(--accent);letter-spacing:-0.02em;line-height:1.05;margin-bottom:8px;word-break:break-word}
.quotes-stats__sub{font-size:0.85rem;color:var(--gray-600);line-height:1.4}
.quotes-stats__chart{display:flex;flex-direction:column;gap:12px;margin-top:6px}
.quotes-stats__bar-row{display:flex;flex-direction:column;gap:6px}
.quotes-stats__bar-label{display:flex;justify-content:space-between;font-size:0.85rem}
.quotes-stats__bar-label span:first-child{color:var(--gray-600);font-weight:600}
.quotes-stats__bar-label span:last-child{color:var(--black);font-weight:700}
.quotes-stats__bar-track{height:14px;background:var(--gray-100);border-radius:7px;overflow:hidden}
.quotes-stats__bar-fill{height:100%;border-radius:7px;transition:width 0.4s cubic-bezier(.34,1.56,.64,1)}
.quotes-stats__bar-fill--utility{background:linear-gradient(90deg,#6b7280,#9ca3af)}
.quotes-stats__bar-fill--solar{background:linear-gradient(90deg,var(--accent),#f8d676)}
.quotes-stats__selected{font-size:0.78rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:0.06em}
.quotes-stats__installer{font-size:0.95rem;font-weight:700;color:var(--black)}

.quote-card{cursor:pointer}
.quote-card--selected{border-color:var(--accent);box-shadow:0 0 0 3px rgba(244,186,62,.18),var(--shadow-md)}

@media(max-width:980px){
  .quotes-layout{grid-template-columns:1fr}
  .quotes-stats{position:static}
}

.quotes-empty{text-align:center;padding:40px;color:var(--gray-600);grid-column:1/-1}
.quotes-empty h3{font-size:1.25rem;margin-bottom:8px;color:var(--black)}

/* Expand container for quotes grid */
#quotesSection{max-width:1700px;margin:0 auto}

/* Site-wide announcement banner that sits above the quotes title. Breaks
   out of the #quotesSection / .quotes-container max-widths so it spans the
   full viewport regardless of how wide the inner content is. Centered text,
   subtle warm fill so it pops without overwhelming. */
/* margin-top cancels .quotes-main's padding-top so the banner sits flush
   against the navbar with no gap. Same trick for the mobile-only 32px
   variant of that padding. */
.quotes-update-banner{margin-top:-60px;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);width:100vw;background:#fffaed;border-top:1px solid rgba(244,186,62,.55);border-bottom:1px solid rgba(244,186,62,.55);padding:14px 24px;text-align:center;font-size:0.95rem;color:#1f2937;margin-bottom:28px;line-height:1.4}
.quotes-update-banner__text{margin-right:6px}
.quotes-update-banner__link{color:#1f2937;font-weight:700;text-decoration:underline;text-underline-offset:3px;white-space:nowrap}
.quotes-update-banner__link:hover{color:#b58510}
@media(max-width:640px){
  .quotes-update-banner{padding:12px 18px;font-size:0.9rem}
  .quotes-update-banner__text{display:block;margin:0 0 4px}
}
@media(max-width:480px){
  .quotes-update-banner{margin-top:-32px}
}

@media(max-width:1100px){
  .quotes-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  .intake-card{padding:28px 20px}
  .quotes-grid{grid-template-columns:1fr}
  .intake-options{grid-template-columns:1fr}
  .intake-options--two{grid-template-columns:1fr}
}

@media(max-width:480px){
  .quotes-main{padding:32px 0}
}

/* ===== QUOTE CARDS ===== */
.quote-card{border:2px solid var(--gray-200);border-radius:var(--radius-lg);padding:28px;transition:all 0.25s ease;display:grid;grid-template-rows:subgrid;grid-row:span 4;background:var(--white)}
.quote-card__head{display:flex;flex-direction:column}
.quote-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}
.quote-card--best{position:relative}
.quote-card--best::before{content:'Best Value';position:absolute;top:-12px;left:20px;background:var(--accent);color:var(--black);font-size:0.75rem;font-weight:700;padding:3px 12px;border-radius:4px}
.quote-card__logo{display:block;max-width:160px;height:56px;object-fit:contain;margin:0 auto 14px}
.quote-card__installer{font-size:1.15rem;font-weight:700;margin-bottom:6px;text-align:center}
.quote-card__learn{display:block;text-align:center;font-size:0.82rem;font-weight:600;color:#0369a1;text-decoration:none;margin:0 0 16px}
.quote-card__learn:hover{text-decoration:underline}
.quote-card__price{font-size:2.25rem;font-weight:800;color:var(--accent);margin-bottom:4px;letter-spacing:-0.02em}
.quote-card__ppw{font-size:0.85rem;color:var(--gray-400);margin-bottom:20px}
.quote-card__details{list-style:none;display:flex;flex-direction:column;gap:10px}
.quote-card__detail{display:flex;justify-content:space-between;font-size:0.88rem;padding:6px 0;border-bottom:1px solid var(--gray-100)}
.quote-card__detail-label{color:var(--gray-600)}
.quote-card__detail-value{font-weight:600}
.quote-card__finance{margin-top:18px;padding-top:14px;border-top:1px solid var(--gray-200)}
.quote-card__finance-title{font-size:0.78rem;font-weight:700;color:var(--gray-600);margin-bottom:12px;text-transform:uppercase;letter-spacing:0.06em}
.quote-card__finance-options{display:flex;flex-wrap:wrap;gap:6px}
.quote-card__finance-tag{font-size:0.78rem;background:var(--gray-50);border:1px solid var(--gray-200);padding:3px 10px;border-radius:4px}

/* New finance option blocks */
.quote-finance{display:flex;flex-direction:column;gap:14px}
.quote-finance__option{background:#fafafa;border:1px solid var(--gray-200);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:6px}
.quote-finance__type{font-size:0.95rem;font-weight:700;color:var(--black);margin-bottom:4px}
.quote-finance__row{display:flex;justify-content:space-between;align-items:baseline;font-size:0.88rem;color:var(--gray-600)}
.quote-finance__row span:last-child{color:var(--black);font-weight:600}
.quote-finance__row--bold{padding-top:6px;border-top:1px dashed var(--gray-200);margin-top:4px}
.quote-finance__row--bold span:first-child{font-weight:700;color:var(--black)}
.quote-finance__row--bold span:last-child{color:var(--accent);font-weight:800;font-size:1rem}
.quote-finance__note{font-size:0.75rem;color:var(--accent);background:rgba(244,186,62,.12);border-radius:6px;padding:5px 10px;font-weight:600;margin-bottom:4px;font-style:italic}
/* Empty placeholder version: reserves the badge's height so loan cards stay
   the same height across quotes (keeps financing headers aligned). */
.quote-finance__note--placeholder{visibility:hidden;background:transparent}

/* Restructured equipment rows */
.quote-card__equip{padding:8px 0;border-bottom:1px solid var(--gray-100)}
.quote-card__equip-row{display:flex;justify-content:space-between;align-items:baseline;font-size:0.88rem}
.quote-card__equip-label{color:var(--gray-600)}
.quote-card__equip-brand{font-weight:700;color:var(--black)}
.quote-card__equip-model{font-size:0.82rem;color:var(--gray-400);margin-top:2px;text-align:right}
.quote-card__cta{margin-top:20px}
.quote-card__cta .btn{width:100%;justify-content:center}

/* ===== PLACEHOLDER QUOTE CARD ===== */
/* Placeholder card: opt out of subgrid (only has 3 sections, not 4) and span
   all 4 row tracks as one cell so it matches sibling card height. */
.quote-card--placeholder{border-style:dashed;background:var(--gray-50);display:flex;flex-direction:column;justify-content:space-between;grid-row:span 4;grid-template-rows:none}
.quote-card--placeholder:hover{border-color:var(--accent);background:#fef9ec}
.quote-card--placeholder .quote-card__installer{color:var(--gray-600)}
.quote-card__placeholder-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:24px 4px;color:var(--gray-600)}
.quote-card__placeholder-body svg{color:var(--gray-400)}
.quote-card__placeholder-body p{font-size:0.9rem;line-height:1.5;margin:0}

/* ===== CHAT WIDGET ===== */
.chat-widget{position:fixed;bottom:24px;right:24px;z-index:1000;font-family:inherit}
.chat-fab{
  position:relative;
  width:60px;height:60px;border-radius:50%;border:none;cursor:pointer;
  background:var(--accent);color:#000;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 24px rgba(244,186,62,.5),0 2px 6px rgba(0,0,0,.12);
  transition:transform 0.2s ease, box-shadow 0.2s ease;
}
.chat-fab:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(244,186,62,.55),0 4px 10px rgba(0,0,0,.15)}
.chat-fab:active{transform:translateY(0)}
.chat-fab__badge{
  position:absolute;top:-4px;right:-4px;
  min-width:22px;height:22px;border-radius:11px;padding:0 6px;
  background:#ef4444;color:#fff;font-size:0.78rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  border:2px solid #fff;
  box-shadow:0 2px 6px rgba(239,68,68,.4);
}
.chat-fab__pulse{
  position:absolute;inset:-4px;border-radius:50%;
  background:var(--accent);opacity:.45;
  animation:chatPulse 2.4s cubic-bezier(.4,0,.6,1) infinite;
  pointer-events:none;z-index:-1;
}
@keyframes chatPulse{
  0%{transform:scale(.85);opacity:.5}
  70%{transform:scale(1.45);opacity:0}
  100%{transform:scale(.85);opacity:0}
}

/* Callout popup above the FAB */
.chat-callout{
  position:absolute;bottom:76px;right:0;
  width:300px;max-width:calc(100vw - 48px);
  background:#fff;border-radius:14px;
  box-shadow:0 16px 40px rgba(0,0,0,.16),0 2px 6px rgba(0,0,0,.06);
  padding:14px 16px 14px 14px;
  display:flex;align-items:center;gap:12px;
  animation:chatCalloutSlide .35s cubic-bezier(.34,1.56,.64,1);
  cursor:pointer;
  transition:transform 0.15s, box-shadow 0.15s;
}
.chat-callout:hover{transform:translateY(-2px);box-shadow:0 18px 44px rgba(0,0,0,.20),0 4px 10px rgba(0,0,0,.08)}
.chat-callout[hidden]{display:none}
.chat-callout::after{
  content:'';position:absolute;bottom:-7px;right:24px;
  width:14px;height:14px;background:#fff;
  transform:rotate(45deg);box-shadow:3px 3px 6px rgba(0,0,0,.06);
}
.chat-callout__avatar{
  width:48px;height:48px;border-radius:50%;object-fit:cover;
  border:2px solid var(--accent);flex-shrink:0;
}
.chat-callout__text{flex:1;min-width:0}
.chat-callout__greeting{font-size:0.92rem;line-height:1.2;color:#111}
.chat-callout__greeting strong{font-weight:700}
.chat-callout__sub{font-size:0.78rem;color:#6b7280;margin-top:3px;line-height:1.3}
.chat-callout__close{
  position:absolute;top:6px;right:8px;
  background:none;border:none;cursor:pointer;
  font-size:1.1rem;color:#9ca3af;line-height:1;
  padding:4px 6px;border-radius:50%;
}
.chat-callout__close:hover{background:#f3f4f6;color:#374151}
@keyframes chatCalloutSlide{
  from{opacity:0;transform:translateY(8px) scale(.95);transform-origin:bottom right}
  to{opacity:1;transform:translateY(0) scale(1)}
}

.chat-panel{
  position:absolute;bottom:76px;right:0;
  width:360px;max-width:calc(100vw - 48px);
  height:520px;max-height:calc(100vh - 120px);
  background:#fff;border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.18),0 4px 10px rgba(0,0,0,.06);
  display:flex;flex-direction:column;overflow:hidden;
  animation:chatPop .22s cubic-bezier(.34,1.56,.64,1);
}
.chat-panel[hidden]{display:none}
.chat-panel__book[hidden]{display:none}
@keyframes chatPop{
  from{opacity:0;transform:translateY(10px) scale(.97);transform-origin:bottom right}
  to{opacity:1;transform:translateY(0) scale(1)}
}

.chat-panel__header{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;background:linear-gradient(135deg,var(--accent) 0%,#f8d676 100%);
  color:#000;
}
.chat-panel__avatar{
  width:42px;height:42px;border-radius:50%;object-fit:cover;
  border:2px solid #fff;flex-shrink:0;
  box-shadow:0 2px 6px rgba(0,0,0,.12);
}
.chat-panel__heading{flex:1;min-width:0;line-height:1.2}
.chat-panel__title{font-weight:800;font-size:1rem;letter-spacing:-0.01em}
.chat-panel__sub{font-size:0.75rem;color:rgba(0,0,0,.7);margin-top:3px;display:flex;align-items:center;gap:5px}
.chat-status-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 2px rgba(34,197,94,.25)}
.chat-panel__close{
  appearance:none;border:none;background:rgba(0,0,0,.08);color:#000;
  width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:1.4rem;line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.15s;
}
.chat-panel__close:hover{background:rgba(0,0,0,.16)}

.chat-panel__messages{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:10px;background:#fafafa}
.chat-msg{padding:10px 14px;border-radius:12px;max-width:80%;font-size:0.9rem;line-height:1.4;word-break:break-word}
.chat-msg--bot{background:#fff;border:1px solid var(--gray-200);color:var(--black);align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg--user{background:var(--accent);color:#000;align-self:flex-end;border-bottom-right-radius:4px;font-weight:600}

.chat-panel__actions{padding:10px 14px;border-top:1px solid var(--gray-200);background:#fff}
.chat-action{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border:1px solid var(--gray-200);border-radius:999px;
  background:#fff;cursor:pointer;font-family:inherit;font-size:0.85rem;font-weight:600;color:var(--black);
  transition:border-color 0.15s,background 0.15s;
}
.chat-action:hover{border-color:var(--accent);background:#fef9ec}

.chat-panel__book{padding:14px;border-top:1px solid var(--gray-200);background:#fff;display:flex;flex-direction:column;gap:10px}
.chat-panel__book-label{font-size:0.85rem;font-weight:600;color:var(--gray-600)}
.chat-panel__book-input{padding:10px 12px;border:1.5px solid var(--gray-200);border-radius:8px;font-family:inherit;font-size:0.9rem}
.chat-panel__book-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(244,186,62,.18)}
.chat-panel__book-actions{display:flex;justify-content:flex-end;gap:8px}

.chat-panel__input{
  display:flex;align-items:flex-end;gap:8px;padding:12px;border-top:1px solid var(--gray-200);background:#fff;
}
.chat-panel__input textarea{
  flex:1;resize:none;border:1.5px solid var(--gray-200);border-radius:10px;
  padding:10px 12px;font-family:inherit;font-size:0.9rem;line-height:1.4;
  max-height:100px;transition:border-color 0.15s;
}
.chat-panel__input textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(244,186,62,.18)}
.chat-send{
  width:38px;height:38px;border-radius:50%;border:none;cursor:pointer;
  background:var(--accent);color:#000;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background 0.15s, transform 0.15s;
}
.chat-send:hover{background:var(--accent-hover)}
.chat-send:active{transform:scale(.95)}

@media(max-width:480px){
  .chat-panel{width:calc(100vw - 32px);height:calc(100vh - 100px);bottom:72px}
  .chat-widget{bottom:16px;right:16px}
}

/* Saved-quotes confirmation note (customer account) */
.quotes-saved-note{
  margin-top:14px;background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;
  border-radius:10px;padding:10px 14px;font-size:0.92rem;line-height:1.5;
}

/* Quote loading screen with progress bar */
.quotes-loading{max-width:560px;margin:64px auto;text-align:center;padding:0 1.25rem}
.quotes-loading__spinner{width:46px;height:46px;margin:0 auto 24px;border:4px solid #e5e7eb;border-top-color:#f5b301;border-radius:50%;animation:quotesSpin 0.9s linear infinite}
@keyframes quotesSpin{to{transform:rotate(360deg)}}
.quotes-loading__title{font-size:1.5rem;font-weight:800;color:#111;margin:0 0 8px}
.quotes-loading__sub{color:#6b7280;margin:0 0 28px;font-size:1rem}
.quotes-loading__bar{height:10px;background:#eef1f5;border-radius:999px;overflow:hidden}
.quotes-loading__fill{height:100%;width:0;background:linear-gradient(90deg,#f5b301,#ffcf5c);border-radius:999px;transition:width 4.8s ease-in-out}

/* ===== SCQuoteEditor (editable multi-quote panel) ===== */
.qe-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.qe-toggle{display:inline-flex;background:#eef1f5;border-radius:999px;padding:4px}
.qe-toggle__btn{border:none;background:transparent;padding:7px 16px;border-radius:999px;font-weight:600;font-size:.88rem;cursor:pointer;color:#475569}
.qe-toggle__btn.is-active{background:#f5b301;color:#111}
.qe-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.qe-card{border:1px solid #e5e7eb;border-radius:14px;padding:18px;background:#fff;display:flex;flex-direction:column}
.qe-logo{max-height:34px;max-width:120px;object-fit:contain;margin:0 auto 8px;display:block}
.qe-installer{font-size:1.02rem;font-weight:800;text-align:center;border:1px solid transparent;background:transparent;border-radius:8px;padding:4px;width:100%}
.qe-price{font-size:1.7rem;font-weight:800;color:var(--accent,#f5b301);text-align:center;margin-top:6px;line-height:1}
.qe-unit,.qe-price .qe-unit{font-size:.85rem;font-weight:700;color:#6b7280;margin-left:4px}
.qe-sub{text-align:center;color:#6b7280;font-size:.82rem;margin:4px 0 14px}
.qe-body{display:flex;flex-direction:column;gap:9px}
.qe-row{display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:.85rem;border-bottom:1px solid #f1f5f9;padding-bottom:8px}
.qe-row--stack{flex-direction:column;align-items:stretch;gap:4px}
.qe-label{color:#6b7280;font-weight:500;flex-shrink:0}
.qe-val{display:inline-flex;align-items:center;gap:2px;color:#111;font-weight:600}
.qe-input{font:inherit;color:#111;border:1px solid transparent;background:transparent;border-radius:6px;padding:2px 4px;max-width:130px;text-align:right}
.qe-row--stack .qe-input{max-width:none;text-align:left;width:100%}
.qe-input:not(:disabled){border-color:#cbd5e1;background:#fff}
.qe-select:disabled,.qe-input:disabled{-webkit-appearance:none;appearance:none;opacity:1}
.qe-notes{text-align:left;min-height:42px}
.qe-stepper{display:inline-flex;align-items:center;gap:6px}
.qe-step{width:24px;height:24px;border:1px solid #cbd5e1;background:#fff;border-radius:6px;line-height:1;cursor:pointer;color:#334155}
.qe-card:not(:has(.qe-input:not(:disabled))) .qe-step{opacity:.35}

/* ===== Returning-customer refresh prompt ===== */
.returning-overlay{position:fixed;inset:0;background:rgba(17,24,39,.55);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:returningFade .2s ease}
@keyframes returningFade{from{opacity:0}to{opacity:1}}
.returning-card{background:#fff;border-radius:16px;max-width:460px;width:100%;padding:32px;box-shadow:0 20px 60px rgba(0,0,0,.25);text-align:center}
.returning-card__title{font-size:1.5rem;font-weight:800;color:#111;margin:0 0 10px}
.returning-card__text{font-size:1rem;line-height:1.6;color:#374151;margin:0 0 24px}
.returning-card__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
@media(max-width:480px){.returning-card__actions{flex-direction:column-reverse}.returning-card__actions .btn{width:100%}}
