/*
Theme Name: Lebra Engineering & Design (v3)
Theme URI: https://lebraengineering.com
Author: Lebra Engineering & Design
Author URI: https://lebraengineering.com
Description: Modern, responsive, light-themed website for Lebra Engineering & Design. Structural & civil engineering across Massachusetts.
Version: 1.3
Requires at least: 5.5
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: lebra
*/

/* =========================================================
   Lebra Engineering & Design — Redesign
   Shared design system
   ========================================================= */

:root{
  --navy:        #0b1f33;
  --navy-800:    #0f2942;
  --navy-700:    #16405c;
  --steel:       #1e5c82;
  --steel-300:   #6ea6c4;
  --accent:      #f5a623;   /* structural amber */
  --accent-600:  #d8890c;
  --ink:         #16232f;
  --body:        #46586a;
  --muted:       #7d8b98;
  --line:        #e3e9ef;
  --bg:          #ffffff;
  --bg-soft:     #f5f8fb;
  --bg-alt:      #eef3f8;
  --white:       #ffffff;

  --radius:      14px;
  --radius-lg:   22px;
  --shadow-sm:   0 2px 10px rgba(11,31,51,.06);
  --shadow:      0 14px 40px rgba(11,31,51,.12);
  --shadow-lg:   0 30px 70px rgba(11,31,51,.20);

  --maxw:        1200px;
  --font-head:   "Space Grotesk", "Segoe UI", system-ui, sans-serif;
  --font-body:   "Inter", "Segoe UI", system-ui, sans-serif;
  --ease:        cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--body);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3,h4{
  font-family:var(--font-head);
  color:var(--ink);
  line-height:1.12;
  margin:0 0 .5em;
  font-weight:600;
  letter-spacing:-.01em;
}
h1{ font-size:clamp(2.2rem,5vw,3.6rem); }
h2{ font-size:clamp(1.8rem,3.4vw,2.6rem); }
h3{ font-size:1.25rem; }
p{ margin:0 0 1.1em; }

.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.section{ padding:96px 0; }
.section--soft{ background:var(--bg-soft); }
.section--alt{ background:var(--bg-alt); }
.section--navy{ background:var(--navy); color:#c9d6e2; }
.section--navy h2,.section--navy h3{ color:#fff; }

.center{ text-align:center; }
.narrow{ max-width:760px; margin-left:auto; margin-right:auto; }

/* ---------- Eyebrow / kicker ---------- */
.kicker{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-head); font-weight:600;
  font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--steel);
  margin-bottom:14px;
}
.kicker::before{
  content:""; width:26px; height:2px; background:var(--accent); display:inline-block;
}
.section--navy .kicker{ color:var(--accent); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font-head); font-weight:600; font-size:.98rem;
  padding:14px 28px; border-radius:100px; cursor:pointer;
  border:2px solid transparent; transition:.25s var(--ease);
  white-space:nowrap;
}
.btn--primary{ background:var(--accent); color:var(--navy); }
.btn--primary:hover{ background:var(--accent-600); transform:translateY(-2px); box-shadow:0 10px 24px rgba(245,166,35,.35); }
.btn--dark{ background:var(--navy); color:#fff; }
.btn--dark:hover{ background:var(--navy-700); transform:translateY(-2px); }
.btn--ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.5); }
.btn--ghost:hover{ background:#fff; color:var(--navy); border-color:#fff; }
.btn--outline{ background:transparent; color:var(--navy); border-color:var(--line); }
.btn--outline:hover{ border-color:var(--navy); }

/* ---------- Top utility bar ---------- */
.topbar{
  background:var(--navy); color:#aab9c8; font-size:.85rem;
}
.topbar .container{ display:flex; align-items:center; justify-content:space-between; height:42px; }
.topbar a{ color:#c7d4e0; transition:.2s; }
.topbar a:hover{ color:var(--accent); }
.topbar__social{ display:flex; gap:16px; align-items:center; }
.topbar__contact{ display:flex; gap:22px; align-items:center; }

/* ---------- Header ---------- */
.header{
  position:sticky; top:0; z-index:60; background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px); border-bottom:1px solid var(--line);
  transition:box-shadow .3s;
}
.header.scrolled{ box-shadow:var(--shadow-sm); }
.header .container{ display:flex; align-items:center; justify-content:space-between; height:96px; }
.brand img{ height:70px; width:auto; }
.nav{ display:flex; align-items:center; gap:6px; }
.nav a{
  font-family:var(--font-head); font-weight:500; font-size:.98rem; color:var(--ink);
  padding:10px 16px; border-radius:8px; transition:.2s; position:relative;
}
.nav a:hover{ color:var(--steel); }
.nav a.active{ color:var(--steel); }
.nav a.active::after{
  content:""; position:absolute; left:16px; right:16px; bottom:2px; height:2px; background:var(--accent); border-radius:2px;
}
.header__cta{ display:flex; align-items:center; gap:14px; }
.header__cta .btn{ padding:11px 22px; }
.burger{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.burger span{ display:block; width:26px; height:2px; background:var(--navy); margin:5px 0; transition:.3s; }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0; background:var(--navy); z-index:80; padding:90px 32px 40px;
  transform:translateX(100%); transition:transform .4s var(--ease); display:flex; flex-direction:column; gap:6px;
}
.mobile-menu.open{ transform:translateX(0); }
.mobile-menu a{ color:#fff; font-family:var(--font-head); font-size:1.4rem; padding:14px 0; border-bottom:1px solid rgba(255,255,255,.1); }
.mobile-menu .btn{ margin-top:24px; }
.mobile-menu__close{ position:absolute; top:26px; right:26px; background:none; border:0; color:#fff; font-size:2rem; cursor:pointer; }

/* ---------- Hero ---------- */
.hero{ position:relative; background:linear-gradient(180deg,#ffffff 0%, var(--bg-soft) 100%); color:var(--ink); overflow:hidden; }
.hero__grid{ display:grid; grid-template-columns:1.02fr .98fr; gap:60px; align-items:center; padding:80px 0 58px; }
.hero__inner{ max-width:600px; }
.hero .kicker{ color:var(--steel); }
.hero h1{ color:var(--ink); font-size:clamp(2.3rem,4.6vw,3.7rem); margin-bottom:20px; }
.hero p{ font-size:1.16rem; color:var(--body); max-width:545px; }
.hero__actions{ display:flex; gap:16px; flex-wrap:wrap; margin-top:32px; }
.hero__media{ position:relative; }
.hero__media img{ width:100%; aspect-ratio:4/3.35; object-fit:cover; border-radius:var(--radius-lg); box-shadow:var(--shadow); }
.hero__media-badge{ position:absolute; left:-18px; bottom:-18px; background:var(--accent); color:var(--navy); padding:16px 22px; border-radius:var(--radius); box-shadow:var(--shadow); font-family:var(--font-head); display:flex; align-items:center; gap:13px; }
.hero__media-badge b{ font-size:2rem; line-height:1; }
.hero__media-badge span{ font-size:.8rem; line-height:1.25; font-family:var(--font-body); font-weight:500; }
.hero__stats{ display:flex; gap:44px; flex-wrap:wrap; padding:30px 0 4px; border-top:1px solid var(--line); }
.hero__stat b{ font-family:var(--font-head); font-size:2rem; color:var(--ink); display:block; line-height:1; }
.hero__stat span{ font-size:.88rem; color:var(--muted); }

/* page hero (interior) */
.page-hero{ position:relative; color:var(--ink); text-align:left; background:var(--bg-soft); border-bottom:1px solid var(--line); }
.page-hero__bg{ display:none; }
.page-hero__inner{ position:relative; z-index:2; padding:74px 0 66px; }
.page-hero .kicker{ color:var(--steel) !important; }
.page-hero h1{ color:var(--ink); margin-bottom:12px; }
.page-hero p{ color:var(--body); max-width:660px; margin:0; font-size:1.12rem; }
.breadcrumb{ font-size:.85rem; color:var(--muted); margin-top:18px; }
.breadcrumb a:hover{ color:var(--steel); }

/* ---------- Feature strip (why us) ---------- */
.why{ display:grid; grid-template-columns:1.05fr 1fr; gap:64px; align-items:center; }
.why__media{ position:relative; }
.why__media img{ border-radius:var(--radius-lg); box-shadow:var(--shadow); }
.why__badge{
  position:absolute; right:-18px; bottom:-18px; background:var(--accent); color:var(--navy);
  padding:20px 26px; border-radius:var(--radius); font-family:var(--font-head); box-shadow:var(--shadow);
}
.why__badge b{ font-size:2rem; display:block; line-height:1; }
.feature-list{ list-style:none; padding:0; margin:26px 0 0; display:grid; gap:16px; }
.feature-list li{ display:flex; gap:16px; align-items:flex-start; }
.feature-list .ico{
  flex:0 0 44px; height:44px; border-radius:12px; background:var(--bg-alt);
  display:grid; place-items:center; color:var(--steel);
}
.feature-list h3{ margin:2px 0 2px; font-size:1.08rem; }
.feature-list p{ margin:0; font-size:.96rem; }

/* ---------- Cards grid ---------- */
.grid{ display:grid; gap:26px; }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
.grid-2{ grid-template-columns:repeat(2,1fr); }

.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden;
  transition:.3s var(--ease); display:flex; flex-direction:column;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.card__img{ aspect-ratio:16/11; overflow:hidden; }
.card__img img{ width:100%; height:100%; object-fit:cover; transition:.5s var(--ease); }
.card:hover .card__img img{ transform:scale(1.06); }
.card__body{ padding:22px 24px 26px; flex:1; display:flex; flex-direction:column; }
.card__body h3{ margin-bottom:8px; }
.card__body p{ font-size:.95rem; margin-bottom:16px; color:var(--body); }
.card__link{
  margin-top:auto; font-family:var(--font-head); font-weight:600; font-size:.9rem; color:var(--steel);
  display:inline-flex; align-items:center; gap:6px;
}
.card__link::after{ content:"→"; transition:transform .25s; }
.card:hover .card__link::after{ transform:translateX(4px); }

/* section head */
.section-head{ max-width:720px; margin:0 auto 54px; text-align:center; }
.section-head.left{ margin-left:0; text-align:left; }
.section-head p{ color:var(--body); font-size:1.05rem; margin:0; }

/* ---------- CTA banner ---------- */
.cta-band{ position:relative; overflow:hidden; background:var(--navy); color:#fff; border-radius:var(--radius-lg); padding:56px 60px;
  display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.cta-band::before{ content:""; position:absolute; right:-60px; top:-60px; width:280px; height:280px; border-radius:50%; background:radial-gradient(circle,rgba(245,166,35,.25),transparent 70%); }
.cta-band h2{ color:#fff; margin:0 0 6px; }
.cta-band p{ margin:0; color:#c1cfdb; }

/* ---------- Testimonials ---------- */
.tst{ position:relative; max-width:860px; margin:0 auto; }
.tst__track{ position:relative; }
.tst__item{ display:none; text-align:center; animation:fade .5s var(--ease); }
.tst__item.active{ display:block; }
.tst__quote{ font-size:1.18rem; color:var(--body); line-height:1.85; }
.tst__mark{ font-family:var(--font-head); font-size:4rem; color:var(--accent); line-height:.6; margin-bottom:10px; }
.tst__who{ margin-top:22px; font-family:var(--font-head); font-weight:600; color:var(--ink); }
.tst__who small{ display:block; font-family:var(--font-body); font-weight:400; font-size:.85rem; color:var(--muted); margin-top:2px; }
.tst__dots{ display:flex; gap:10px; justify-content:center; margin-top:28px; }
.tst__dots button{ width:11px; height:11px; border-radius:50%; border:0; background:rgba(11,31,51,.18); cursor:pointer; transition:.2s; }
.tst__dots button.active{ background:var(--accent); width:28px; border-radius:6px; }
@keyframes fade{ from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:none;} }

/* ---------- Projects gallery ---------- */
.filters{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:40px; }
.filters button{
  font-family:var(--font-head); font-weight:500; font-size:.92rem; padding:9px 20px; border-radius:100px;
  border:1px solid var(--line); background:#fff; color:var(--body); cursor:pointer; transition:.2s;
}
.filters button:hover{ border-color:var(--steel); color:var(--steel); }
.filters button.active{ background:var(--navy); color:#fff; border-color:var(--navy); }
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.gallery__item{ position:relative; aspect-ratio:3/2; overflow:hidden; border-radius:var(--radius); cursor:pointer; background:var(--bg-alt); }
.gallery__item img{ width:100%; height:100%; object-fit:cover; transition:.5s var(--ease); }
.gallery__item:hover img{ transform:scale(1.08); }
.gallery__item::after{
  content:""; position:absolute; inset:0; background:linear-gradient(transparent 55%,rgba(8,22,37,.75));
  opacity:0; transition:.3s;
}
.gallery__item:hover::after{ opacity:1; }
.gallery__cap{
  position:absolute; left:16px; bottom:14px; z-index:2; color:#fff; font-family:var(--font-head);
  font-weight:500; font-size:.95rem; opacity:0; transform:translateY(8px); transition:.3s;
}
.gallery__item:hover .gallery__cap{ opacity:1; transform:none; }

/* lightbox */
.lightbox{ position:fixed; inset:0; background:rgba(6,16,27,.94); z-index:100; display:none; align-items:center; justify-content:center; padding:40px; }
.lightbox.open{ display:flex; }
.lightbox img{ max-width:92vw; max-height:86vh; border-radius:10px; box-shadow:var(--shadow-lg); }
.lightbox__close{ position:absolute; top:24px; right:30px; background:none; border:0; color:#fff; font-size:2.4rem; cursor:pointer; }
.lightbox__nav{ position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.12); border:0; color:#fff; width:54px; height:54px; border-radius:50%; font-size:1.6rem; cursor:pointer; transition:.2s; }
.lightbox__nav:hover{ background:var(--accent); color:var(--navy); }
.lightbox__nav.prev{ left:24px; }
.lightbox__nav.next{ right:24px; }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1.15fr; gap:56px; align-items:start; }
.info-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:22px 24px; margin-bottom:16px; display:flex; gap:16px; align-items:flex-start; }
.info-card .ico{ flex:0 0 34px; height:34px; background:none; color:var(--steel); display:grid; place-items:center; margin-top:2px; }
.info-card .ico svg{ width:30px; height:30px; }
.info-card h4{ margin:0 0 4px; font-family:var(--font-head); font-size:1rem; color:var(--ink); }
.info-card p{ margin:0; font-size:.95rem; }
.info-card a{ color:var(--steel); }

.form{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:34px; box-shadow:var(--shadow-sm); }
.form h3{ margin-bottom:20px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-family:var(--font-head); font-weight:500; font-size:.9rem; color:var(--ink); margin-bottom:7px; }
.field input,.field select,.field textarea{
  width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:10px; font-family:var(--font-body);
  font-size:.98rem; color:var(--ink); background:var(--bg-soft); transition:.2s;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:0; border-color:var(--steel); background:#fff; box-shadow:0 0 0 4px rgba(30,92,130,.1); }
.field textarea{ min-height:130px; resize:vertical; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form__note{ font-size:.82rem; color:var(--muted); margin-top:4px; }

.map-wrap{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line); }
.map-wrap img{ width:100%; }

/* ---------- Office cards ---------- */
.offices{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.office{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:28px; }
.office h4{ color:var(--ink); font-family:var(--font-head); margin:0 0 14px; display:flex; align-items:center; gap:10px; }
.office h4::before{ content:""; width:22px; height:3px; background:var(--accent); }
.office p{ color:var(--body); font-size:.94rem; margin:0 0 8px; }
.office a{ color:var(--steel); }

/* ---------- Footer ---------- */
.footer{ background:var(--navy); color:#8ea0b1; padding:72px 0 30px; }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:44px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer__brand img{ height:56px; margin-bottom:18px; filter:brightness(0) invert(1); opacity:.95; }
.footer h5{ color:#fff; font-family:var(--font-head); font-size:1rem; margin:0 0 18px; }
.footer ul{ list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.footer ul a{ color:#9fb1c1; font-size:.94rem; transition:.2s; }
.footer ul a:hover{ color:var(--accent); }
.footer__social{ display:flex; gap:12px; margin-top:18px; }
.footer__social a{ width:38px; height:38px; border-radius:9px; background:rgba(255,255,255,.08); display:grid; place-items:center; color:#c7d4e0; transition:.2s; }
.footer__social a:hover{ background:var(--accent); color:var(--navy); }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:24px; font-size:.85rem; flex-wrap:wrap; gap:10px; }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:.7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero__grid{ grid-template-columns:1fr; gap:38px; padding:52px 0 44px; }
  .hero__media img{ aspect-ratio:16/10; }
  .hero__media-badge{ left:14px; }
  .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr); }
  .why{ grid-template-columns:1fr; gap:40px; }
  .contact-grid{ grid-template-columns:1fr; gap:36px; }
  .footer__top{ grid-template-columns:1fr 1fr; gap:32px; }
  .offices{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); }
  .nav,.header__cta .btn{ display:none; }
  .burger{ display:block; }
  .topbar__contact .hide-sm{ display:none; }
}
@media(max-width:600px){
  .section{ padding:64px 0; }
  .grid-3,.grid-4,.grid-2{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr 1fr; gap:12px; }
  .field-row{ grid-template-columns:1fr; }
  .cta-band{ padding:38px 28px; }
  .hero__grid{ padding:40px 0 32px; }
  .hero__stats{ gap:28px; }
  .topbar__contact .hide-sm{ display:none; }
  .footer__top{ grid-template-columns:1fr; }
}

/* =========================================================
   CONVERSION LAYER — chat gateway, sticky quote bar, modal
   ========================================================= */

/* ---------- Floating chat gateway (WhatsApp + SMS) ---------- */
.chat-fab{ position:fixed; right:22px; bottom:22px; z-index:70; display:flex; flex-direction:column; align-items:flex-end; gap:12px; transition:bottom .35s var(--ease); }
body.bar-visible .chat-fab{ bottom:92px; }
.chat-fab__menu{ display:flex; flex-direction:column; gap:10px; opacity:0; pointer-events:none; transform:translateY(12px) scale(.96); transform-origin:bottom right; transition:.28s var(--ease); }
.chat-fab.open .chat-fab__menu{ opacity:1; pointer-events:auto; transform:none; }
.chat-opt{ display:flex; align-items:center; gap:11px; background:#fff; color:var(--ink); padding:11px 16px 11px 12px; border-radius:100px; box-shadow:var(--shadow); font-family:var(--font-head); font-weight:600; font-size:.92rem; border:1px solid var(--line); transition:.2s; }
.chat-opt:hover{ transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.chat-opt small{ display:block; font-family:var(--font-body); font-weight:400; font-size:.74rem; color:var(--muted); }
.chat-opt .ico{ width:32px; height:32px; display:grid; place-items:center; flex:0 0 32px; }
.chat-opt .ico svg{ width:24px; height:24px; }
.chat-opt--wa .ico{ color:#1faa52; }
.chat-opt--sms .ico{ color:var(--steel); }
.chat-fab__btn{ width:62px; height:62px; border-radius:50%; border:0; cursor:pointer; background:var(--accent); color:var(--navy); box-shadow:0 12px 30px rgba(245,166,35,.45); display:grid; place-items:center; transition:.25s var(--ease); position:relative; }
.chat-fab__btn:hover{ transform:scale(1.06); }
.chat-fab__btn svg{ width:28px; height:28px; }
.chat-fab.open .chat-fab__btn{ background:var(--navy); color:#fff; transform:rotate(90deg); }
.chat-fab__pulse{ position:absolute; inset:0; border-radius:50%; box-shadow:0 0 0 0 rgba(245,166,35,.55); animation:pulse 2.4s infinite; }
@keyframes pulse{ 70%{ box-shadow:0 0 0 16px rgba(245,166,35,0);} 100%{ box-shadow:0 0 0 0 rgba(245,166,35,0);} }
.chat-fab__tip{ position:absolute; right:74px; bottom:14px; background:var(--navy); color:#fff; padding:8px 14px; border-radius:10px; font-size:.85rem; white-space:nowrap; box-shadow:var(--shadow); opacity:0; transform:translateX(8px); transition:.3s; pointer-events:none; }
.chat-fab__tip::after{ content:""; position:absolute; right:-5px; bottom:14px; width:10px; height:10px; background:var(--navy); transform:rotate(45deg); }
.chat-fab:not(.open):hover .chat-fab__tip,.chat-fab.tip-show .chat-fab__tip{ opacity:1; transform:none; }

/* ---------- Sticky quote bar ---------- */
.quotebar{ position:fixed; left:0; right:0; bottom:0; z-index:65; background:#fff; color:var(--ink); transform:translateY(105%); transition:transform .4s var(--ease); border-top:1px solid var(--line); box-shadow:0 -10px 34px rgba(11,31,51,.12); }
.quotebar.show{ transform:none; }
.quotebar .container{ display:flex; align-items:center; justify-content:space-between; gap:20px; min-height:64px; padding-top:10px; padding-bottom:10px; }
.quotebar__msg{ display:flex; align-items:center; gap:14px; }
.quotebar__msg .dot{ width:9px; height:9px; border-radius:50%; background:#25d366; box-shadow:0 0 0 0 rgba(37,211,102,.6); animation:pulse2 2s infinite; flex:0 0 9px; }
@keyframes pulse2{ 70%{ box-shadow:0 0 0 8px rgba(37,211,102,0);} }
.quotebar__msg b{ font-family:var(--font-head); font-size:1.05rem; color:var(--ink); display:block; line-height:1.2; }
.quotebar__msg span{ font-size:.85rem; color:var(--muted); }
.quotebar__actions{ display:flex; align-items:center; gap:14px; }
.quotebar__phone{ font-family:var(--font-head); font-weight:600; color:var(--ink); white-space:nowrap; }
.quotebar__phone small{ display:block; font-family:var(--font-body); font-weight:400; font-size:.72rem; color:var(--muted); }
.quotebar__close{ background:none; border:0; color:var(--muted); font-size:1.4rem; cursor:pointer; line-height:1; padding:4px; }
.quotebar__close:hover{ color:var(--ink); }

/* ---------- Quick-quote modal ---------- */
.modal{ position:fixed; inset:0; z-index:90; background:rgba(6,16,27,.72); backdrop-filter:blur(4px); display:none; align-items:center; justify-content:center; padding:24px; }
.modal.open{ display:flex; animation:fade .3s var(--ease); }
.modal__box{ background:#fff; width:100%; max-width:920px; border-radius:var(--radius-lg); overflow:hidden; display:grid; grid-template-columns:.85fr 1.15fr; box-shadow:var(--shadow-lg); max-height:94vh; }
.modal__aside{ background:var(--bg-alt); color:var(--ink); padding:40px 34px; display:flex; flex-direction:column; justify-content:center; border-right:1px solid var(--line); }
.modal__aside h3{ color:var(--ink); font-size:1.5rem; }
.modal__aside p{ color:var(--body); font-size:.95rem; }
.modal__trust{ list-style:none; padding:0; margin:20px 0 0; display:grid; gap:12px; }
.modal__trust li{ display:flex; gap:10px; align-items:flex-start; font-size:.92rem; color:var(--body); }
.modal__trust .ck{ color:var(--accent); font-weight:700; }
.modal__form{ padding:36px 34px; overflow-y:auto; position:relative; }
.modal__close{ position:absolute; top:16px; right:18px; background:none; border:0; font-size:1.8rem; color:var(--muted); cursor:pointer; line-height:1; z-index:2; }
.modal__close:hover{ color:var(--ink); }
.modal__form h3{ margin-bottom:4px; }
.modal__form .lead{ font-size:.92rem; color:var(--body); margin-bottom:20px; }
.modal__success{ display:none; text-align:center; padding:30px 10px; }
.modal__success .big{ font-size:3rem; }
@media(max-width:760px){
  .modal__box{ grid-template-columns:1fr; }
  .modal__aside{ display:none; }
  .quotebar__msg span{ display:none; }
  .quotebar__phone{ display:none; }
}
@media(max-width:600px){
  body.bar-visible .chat-fab{ bottom:8