
/* Best Property in Navi Mumbai — Premium UI v2
   Minimal, fast, responsive. Inspired by the references you shared (clean container, map layer, soft depth).
*/
:root{
  --bg:#eef0f4;
  --panel:#ffffff;
  --ink:#0b0d12;
  --muted:#5a6472;
  --line:rgba(12,18,30,.10);
  --shadow: 0 22px 60px rgba(10,18,30,.10);
  --shadow2: 0 10px 30px rgba(10,18,30,.08);
  --radius: 24px;
  --radius2: 18px;
  --radius3: 14px;
  --accent:#0b0d12; /* restrained */
  --accent2:#2b3a55;
  --chip:#f6f7fb;
  --chip2:#f1f3f8;
  --success:#0a7a3e;
  --warn:#a05b00;
  --danger:#b00020;
  --focus: rgba(47,128,237,.18);
  --max: 1180px;
  --pad: clamp(16px, 2.2vw, 28px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background: radial-gradient(1200px 700px at 20% -10%, #ffffff 0%, rgba(255,255,255,0) 60%),
              radial-gradient(1000px 600px at 100% 0%, rgba(210,228,255,.45) 0%, rgba(255,255,255,0) 55%),
              var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a{color:inherit; text-decoration:none}
a:hover{opacity:.92}
img{max-width:100%; height:auto; display:block}

.container{
  width:min(var(--max), calc(100% - 2*var(--pad)));
  margin-inline:auto;
}

.app{
  margin: clamp(16px, 3vw, 28px) auto;
  background:var(--panel);
  border:1px solid var(--line);
  box-shadow: var(--shadow);
  border-radius: min(32px, var(--radius));
  overflow:hidden;
}

.topbar{
  position:sticky; top:0; z-index:50;
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px var(--pad);
  gap: 12px;
}
.brand{
  display:flex; align-items:center; gap:12px; min-width: 220px;
}
.logo{
  width:40px; height:40px;
  border-radius: 14px;
  display:block;
  background-color:#fff;
  background-image:url("https://basaao.com/wp-content/uploads/2026/03/BPNM-small-logo.png");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  box-shadow: 0 10px 24px rgba(0,0,0,.16);
  overflow:hidden;
}
.brand b{display:block; font-size:14px; line-height:1.1}
.brand span{display:block; font-size:12px; color:var(--muted)}
.navlinks{
  display:flex; gap: 18px;
  align-items:center;
  font-size: 13px;
  color: rgba(11,13,18,.78);
}
.navlinks a{padding:10px 8px; border-radius: 12px}
.navlinks a[aria-current="page"]{background: var(--chip2); color: var(--ink)}
.actions{
  display:flex; align-items:center; gap:10px; min-width: 220px; justify-content:flex-end;
}
.btn{
  border:1px solid var(--line);
  background:#fff;
  padding: 10px 14px;
  border-radius: 999px;
  font-size: 13px;
  display:inline-flex; gap:10px; align-items:center;
  cursor:pointer;
}
.btn:hover{box-shadow: var(--shadow2)}
.btn.primary{
  background: var(--accent);
  color:#fff;
  border-color: rgba(0,0,0,.06);
}
.btn.primary:hover{filter: brightness(1.02)}
.btn.ghost{background: transparent}
.btn.small{padding:8px 12px; font-size:12px}
.btn.block{width:100%; justify-content:center}

.kbd{
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.16);
}

.main{
  padding: clamp(18px, 2.6vw, 32px) var(--pad) 22px;
}

.hero{
  position:relative;
  border-radius: var(--radius);
  border:1px solid var(--line);
  overflow:hidden;
  min-height: clamp(520px, 70vh, 720px);
  background: #f6f7fb;
}
.hero .mapbg{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.75) 0%, rgba(255,255,255,.92) 55%, rgba(255,255,255,1) 100%),
    url("../placeholder/map.webp");
  background-size: cover;
  background-position: center;
  filter: saturate(.9) contrast(.95);
}
.hero .grid{
  position:relative;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: clamp(16px, 2.6vw, 22px);
  padding: clamp(18px, 2.6vw, 34px);
}
@media (max-width: 980px){
  .hero .grid{grid-template-columns: 1fr; padding: 18px}
  .actions{min-width:auto}
  .brand{min-width:auto}
  .navlinks{display:none}
}

.h-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  padding: 8px 12px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.74);
  border-radius: 999px;
  font-size: 12px;
  color: rgba(11,13,18,.74);
  backdrop-filter: blur(10px);
}
.dot{width:8px; height:8px; border-radius:50%; background: #2f80ed; box-shadow:0 0 0 6px rgba(47,128,237,.12)}
h1{
  margin: 14px 0 10px;
  font-size: clamp(28px, 3.4vw, 52px);
  line-height: 1.02;
  letter-spacing: -0.03em;
}
.lead{
  color: rgba(11,13,18,.72);
  font-size: clamp(14px, 1.25vw, 16px);
  line-height: 1.6;
  max-width: 60ch;
}

.trustbar{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-top: 16px;
}
.pill{
  display:inline-flex; align-items:center; gap:10px;
  padding: 10px 12px;
  border-radius: 999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.70);
  backdrop-filter: blur(10px);
  font-size: 12px;
  color: rgba(11,13,18,.76);
}
.pill strong{color: rgba(11,13,18,.88); font-weight:650}

.filterbar{
  margin-top: 18px;
  border:1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,.86);
  backdrop-filter: blur(14px);
  padding: 10px;
  display:grid;
  grid-template-columns: 1.3fr 1fr 1fr 1fr auto;
  gap: 10px;
}
.filterbar select, .filterbar input{
  width:100%;
  border:1px solid rgba(12,18,30,.10);
  background: #fff;
  padding: 12px 12px;
  border-radius: 999px;
  font-size: 13px;
  outline:none;
}
.filterbar select:focus, .filterbar input:focus{box-shadow: 0 0 0 6px var(--focus); border-color: rgba(47,128,237,.35)}
@media (max-width: 980px){
  .filterbar{grid-template-columns: 1fr 1fr; border-radius: var(--radius2)}
  .filterbar .btn{grid-column: 1 / -1}
}

.floatcard{
  align-self:start;
  border-radius: var(--radius);
  border:1px solid var(--line);
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow2);
  overflow:hidden;
}
.floatcard .media{
  aspect-ratio: 16/10;
  background: url("../placeholder/project.webp");
  background-size: cover;
  background-position:center;
}
.floatcard .body{
  padding: 16px 16px 14px;
}
.badges{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px}
.badge{
  font-size: 11px;
  padding: 6px 10px;
  border-radius: 999px;
  border:1px solid var(--line);
  background: var(--chip);
  color: rgba(11,13,18,.74);
}
.badge.ok{background: rgba(10,122,62,.08); border-color: rgba(10,122,62,.18); color: rgba(10,122,62,.95)}
.badge.warn{background: rgba(160,91,0,.08); border-color: rgba(160,91,0,.18); color: rgba(160,91,0,.95)}
.cardtitle{font-weight:750; letter-spacing:-.01em}
.cardsub{color: var(--muted); font-size: 13px; margin-top:6px; line-height:1.45}
.cardmeta{display:flex; gap:10px; flex-wrap:wrap; margin: 12px 0 14px; color: rgba(11,13,18,.75); font-size: 12px}
.cardmeta span{display:inline-flex; gap:8px; align-items:center; padding:6px 10px; background: var(--chip2); border-radius: 999px; border:1px solid var(--line)}

.section{padding: 26px 0}
.section h2{
  margin: 0 0 12px;
  font-size: clamp(18px, 2vw, 28px);
  letter-spacing: -0.02em;
}
.section p{color: rgba(11,13,18,.72); line-height:1.7; margin: 0 0 10px}

.grid2{display:grid; grid-template-columns: 1fr 1fr; gap: 16px}
.grid3{display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px}
@media(max-width: 980px){.grid2,.grid3{grid-template-columns:1fr}}

.panel{
  border:1px solid var(--line);
  background:#fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow2);
  padding: 16px;
}
.panel.soft{
  background: rgba(255,255,255,.80);
  backdrop-filter: blur(12px);
}
.tabs{
  display:flex; gap: 10px; flex-wrap:wrap;
  padding: 10px;
  border:1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,.78);
}
.tab{
  padding: 10px 14px;
  border-radius: 999px;
  border:1px solid transparent;
  font-size: 13px;
  color: rgba(11,13,18,.75);
}
.tab.active{
  background: var(--ink);
  color:#fff;
  border-color: rgba(0,0,0,.08);
}

.cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media(max-width: 1100px){.cards{grid-template-columns: repeat(2,1fr)}}
@media(max-width: 700px){.cards{grid-template-columns: 1fr}}
.card{
  border:1px solid var(--line);
  border-radius: var(--radius2);
  overflow:hidden;
  background:#fff;
  box-shadow: var(--shadow2);
  display:flex;
  flex-direction:column;
  min-height: 100%;
}
.card .thumb{
  aspect-ratio: 16/10;
  background: url("../placeholder/project.webp");
  background-size: cover;
  background-position:center;
}
.card .cbody{padding: 14px}
.card .cbody h3{margin:0 0 6px; font-size: 16px; letter-spacing:-.01em}
.small{font-size: 12.5px; color: rgba(11,13,18,.70); line-height: 1.45}
.card .cfoot{margin-top:auto; padding: 14px; display:flex; gap:10px}
.card .cfoot .btn{flex:1}

.split{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 16px;
}
@media(max-width: 980px){.split{grid-template-columns:1fr}}

.form{
  display:grid; gap: 10px;
}
.field{
  display:grid; gap: 6px;
}
label{font-size: 12px; color: rgba(11,13,18,.74)}
input, select, textarea{
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(12,18,30,.12);
  outline:none;
  font-size: 14px;
  background:#fff;
}
textarea{min-height: 110px; resize: vertical}
input:focus, select:focus, textarea:focus{box-shadow: 0 0 0 6px var(--focus); border-color: rgba(47,128,237,.35)}

.note{
  font-size: 12px;
  color: rgba(11,13,18,.62);
  line-height:1.5;
}

.footer{
  border-top:1px solid var(--line);
  background: rgba(255,255,255,.76);
  backdrop-filter: blur(14px);
  padding: 18px var(--pad);
}
.footergrid{
  display:grid; grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap: 14px;
}
@media(max-width: 980px){.footergrid{grid-template-columns:1fr 1fr}}
@media(max-width: 520px){.footergrid{grid-template-columns:1fr}}
.footer h4{margin:0 0 10px; font-size: 13px}
.footer a{display:block; padding: 6px 0; color: rgba(11,13,18,.72); font-size: 13px}
.footer a:hover{color: rgba(11,13,18,.95)}
.copy{margin-top: 14px; font-size: 12px; color: rgba(11,13,18,.60); line-height:1.6}

.mobilebar{
  position:fixed;
  left: 12px; right: 12px;
  bottom: 12px;
  z-index: 60;
  display:none;
}
.mobilebar .wrap{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:10px;
  background: rgba(255,255,255,.88);
  border:1px solid var(--line);
  box-shadow: var(--shadow2);
  border-radius: 999px;
  padding: 10px;
  backdrop-filter: blur(14px);
}
@media(max-width: 980px){ .mobilebar{display:block} }

.modal{
  position:fixed; inset:0; z-index: 80;
  display:none; align-items:center; justify-content:center;
  padding: 18px;
  background: rgba(8,10,14,.42);
}
.modal.open{display:flex}
.dialog{
  width:min(980px, 100%);
  background: rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.18);
  border-radius: 28px;
  box-shadow: 0 40px 100px rgba(0,0,0,.25);
  overflow:hidden;
  backdrop-filter: blur(18px);
}
.dialog .dhead{
  display:flex; align-items:flex-start; justify-content:space-between;
  gap: 12px;
  padding: 18px 18px 10px;
  border-bottom:1px solid var(--line);
}
.dialog .dhead h3{margin:0; font-size: 16px}
.dialog .dhead p{margin:6px 0 0; font-size: 13px; color: rgba(11,13,18,.68)}
.dialog .dbody{
  display:grid; grid-template-columns: 1fr 1fr;
  gap: 14px;
  padding: 18px;
}
@media(max-width: 980px){.dialog .dbody{grid-template-columns:1fr}}
.x{
  border:1px solid var(--line);
  background:#fff;
  width:40px; height:40px;
  border-radius: 12px;
  display:grid; place-items:center;
  cursor:pointer;
}


/* === Premium Concierge Popup + Subtle Motion (v3) === */
.cx-popup{position:fixed;inset:0;display:none;z-index:9999}
.cx-popup.cx-show{display:block}
.cx-overlay{position:absolute;inset:0;background:rgba(7,7,14,.68);backdrop-filter:blur(10px)}
.cx-card{
  position:relative;
  width:min(940px,92vw);
  margin:auto;
  top:50%;
  transform:translateY(-50%) scale(.96);
  border-radius:22px;
  overflow:hidden;
  color:#fff;
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(255,255,255,.12), transparent 60%),
    radial-gradient(1000px 600px at 90% 10%, rgba(160,110,255,.16), transparent 55%),
    linear-gradient(180deg, rgba(42,15,68,.92), rgba(18,10,28,.92));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 35px 90px rgba(0,0,0,.55);
  animation:cxIn .22s ease forwards;
}
@keyframes cxIn{to{transform:translateY(-50%) scale(1)}}

.cx-x{
  position:absolute;top:14px;right:14px;
  width:40px;height:40px;border-radius:12px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  color:#fff;cursor:pointer;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.cx-x:hover{transform:scale(1.05);background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.22)}

.cx-top{padding:26px 26px 10px}
.cx-badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.cx-badge{
  font-size:12px;letter-spacing:.2px;
  padding:8px 10px;border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.92);
}

.cx-head{display:flex;gap:14px;align-items:flex-start}
.cx-icon{
  width:46px;height:46px;border-radius:16px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.92);
  flex:0 0 auto;
}
.cx-icon svg{width:26px;height:26px}

.cx-title{font-size:26px;line-height:1.15;margin:0 0 6px}
.cx-sub{margin:0;color:rgba(255,255,255,.78);font-size:14px;max-width:58ch}

.cx-form{padding:14px 26px 24px}
.cx-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cx-grid-3{grid-template-columns:1fr 1fr 1fr;margin-top:14px}

.cx-field{display:block}
.cx-field span{
  display:block;font-size:12px;
  color:rgba(255,255,255,.78);
  margin:0 0 6px;
}
.cx-field input,.cx-field select{
  width:100%;
  padding:14px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.07);
  color:#fff;
  outline:none;
  transition:border .15s ease, background .15s ease, transform .15s ease, box-shadow .15s ease;
}
.cx-field input::placeholder{color:rgba(255,255,255,.58)}
.cx-field input:focus,.cx-field select:focus{
  border-color:rgba(255,255,255,.30);
  background:rgba(255,255,255,.10);
  transform:translateY(-1px);
  box-shadow:0 14px 30px rgba(0,0,0,.25);
}

.cx-actions{display:flex;gap:12px;align-items:center;margin-top:16px;flex-wrap:wrap}
.cx-cta{
  flex:1 1 320px;
  border:none;cursor:pointer;
  padding:14px 16px;border-radius:16px;
  color:#120A1C;
  background:linear-gradient(135deg, rgba(255,224,143,1), rgba(255,187,90,1));
  box-shadow:0 18px 45px rgba(0,0,0,.35);
  transition:transform .15s ease, box-shadow .15s ease, filter .15s ease;
  text-align:left;
  position:relative;
  overflow:hidden;
}
.cx-cta:hover{transform:translateY(-2px);box-shadow:0 22px 55px rgba(0,0,0,.45);filter:saturate(1.06)}
.cx-cta:active{transform:translateY(-1px) scale(.99)}
.cx-cta span{display:block;font-size:15px;font-weight:800}
.cx-cta small{display:block;margin-top:2px;font-size:12px;opacity:.8}

.cx-ghost{
  flex:0 0 auto;
  padding:12px 14px;border-radius:14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.9);
  cursor:pointer;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.cx-ghost:hover{transform:translateY(-1px);background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.22)}

.cx-privacy{
  margin:12px 0 0;
  font-size:12px;
  color:rgba(255,255,255,.68);
}

/* Subtle reveal interactions (safe: no layout shifts) */
.reveal{opacity:0;transform:translateY(12px);transition:opacity .45s ease, transform .45s ease;will-change:opacity,transform}
.reveal.is-visible{opacity:1;transform:none}

@media (prefers-reduced-motion: reduce){
  .cx-card{animation:none;transform:translateY(-50%)}
  .reveal{transition:none;transform:none;opacity:1}
  .cx-x,.cx-cta,.cx-ghost,.cx-field input,.cx-field select{transition:none}
}

/* Responsive */
@media (max-width: 820px){
  .cx-grid-3{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .cx-grid{grid-template-columns:1fr}
  .cx-title{font-size:22px}
  .cx-top,.cx-form{padding-left:18px;padding-right:18px}
}


/* Contact CTA refinements */
.btn.whatsapp-btn,
a[href*="wa.me"].btn,
#waFallback.btn,
#waNow.btn{
  background:#25D366 !important;
  color:#fff !important;
  border-color:#25D366 !important;
  font-weight:500;
}

.mobilebar .wrap{
  grid-template-columns: 1fr 1fr;
}
.mobilebar [data-open-lead][data-source="sticky-mobile"]{display:none !important;}
.mobilebar #callNow.btn{
  background:#d92d20 !important;
  color:#fff !important;
  border-color:#d92d20 !important;
  font-weight:500;
}

.map-embed-card{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  margin-top:10px;
  min-height:320px;
  background:#eef2f7;
}
.map-embed-card iframe{
  width:100%;
  min-height:320px;
  border:0;
  display:block;
}
.map-cta-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
  padding:16px;
  background:linear-gradient(180deg, rgba(11,13,18,0) 45%, rgba(11,13,18,.24) 100%);
}
.map-cta-overlay .btn{
  pointer-events:auto;
}
@media(max-width: 640px){
  .map-embed-card,
  .map-embed-card iframe{min-height:260px}
  .mobilebar{left:10px; right:10px; bottom:10px}
}


/* === Final mobile form + popup fixes === */
html,body{
  max-width:100%;
  overflow-x:hidden;
}

.form .grid2,
.form .grid3,
.form .row{
  min-width:0;
}

input,select,textarea,button{
  font:inherit;
}

@media (max-width: 768px){
  input,select,textarea{
    font-size:16px;
  }

  .modal{
    align-items:flex-start;
    justify-content:center;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    padding:calc(env(safe-area-inset-top, 0px) + 12px) 12px calc(env(safe-area-inset-bottom, 0px) + 12px);
  }

  .dialog{
    width:100%;
    max-width:640px;
    max-height:calc(100dvh - 24px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
    overflow:auto;
    border-radius:22px;
    margin:auto;
  }

  .dialog .dhead{
    position:sticky;
    top:0;
    z-index:2;
    background:rgba(255,255,255,.97);
    backdrop-filter:blur(14px);
  }

  .dialog .dbody{
    grid-template-columns:1fr;
    padding:14px;
  }

  .dialog .panel{
    min-width:0;
  }

  .grid2,
  .grid3{
    grid-template-columns:1fr !important;
    gap:10px;
  }

  .form{
    gap:12px;
  }

  .form .btn.block,
  .form #waFallback.btn{
    width:100%;
  }

  .mobilebar{
    left:10px;
    right:10px;
    bottom:10px;
  }

  .mobilebar .wrap{
    grid-template-columns:1fr 1fr;
    border-radius:22px;
  }

  .cx-popup{
    padding:0;
  }

  .cx-card{
    width:100%;
    max-width:none;
    min-height:100dvh;
    max-height:100dvh;
    border-radius:0;
    top:0;
    transform:none;
    overflow:auto;
    -webkit-overflow-scrolling:touch;
    animation:none;
  }

  .cx-top{
    position:sticky;
    top:0;
    z-index:2;
    padding-top:calc(env(safe-area-inset-top, 0px) + 18px);
    background:linear-gradient(180deg, rgba(42,15,68,.98), rgba(42,15,68,.92));
    backdrop-filter:blur(12px);
  }

  .cx-form{
    padding-bottom:calc(env(safe-area-inset-bottom, 0px) + 24px);
  }

  .cx-grid,
  .cx-grid-3{
    grid-template-columns:1fr !important;
    gap:12px;
  }

  .cx-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .cx-cta,
  .cx-ghost{
    width:100%;
  }
}


/* Expanded editorial sections */
.panel h2[id]{scroll-margin-top:100px}
.panel ul.small{padding-left:18px}
.panel ul.small li{margin:8px 0}
.card .thumb[style]{background-size:cover;background-position:center}
@media(max-width:700px){
  .panel .trustbar .btn{width:100%;justify-content:center}
}


/* === Property chatbot (v4) === */
.pb-wrap{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:74;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:12px;
}

.pb-launcher{
  min-width:290px;
  max-width:min(92vw, 340px);
  display:grid;
  grid-template-columns:52px 1fr 12px;
  align-items:center;
  gap:12px;
  border:1px solid rgba(255,255,255,.26);
  background:linear-gradient(135deg, rgba(11,13,18,.98), rgba(35,49,74,.96));
  color:#fff;
  border-radius:22px;
  box-shadow:0 20px 60px rgba(8,12,20,.28);
  padding:12px 14px 12px 12px;
  cursor:pointer;
  backdrop-filter:blur(18px);
}
.pb-launcher:hover{transform:translateY(-1px)}
.pb-launcher-icon{
  width:52px;height:52px;border-radius:18px;
  display:grid;place-items:center;
  background:linear-gradient(145deg, rgba(255,255,255,.18), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.16);
}
.pb-launcher-icon svg{width:26px;height:26px}
.pb-launcher-copy b{display:block;font-size:14px;line-height:1.15}
.pb-launcher-copy small{display:block;font-size:12px;color:rgba(255,255,255,.74);margin-top:4px}
.pb-dot{
  width:10px;height:10px;border-radius:999px;
  background:#6effb0;
  box-shadow:0 0 0 6px rgba(110,255,176,.14);
}
.pb-launcher.pb-pulse{
  animation:pbPulse 1.4s ease 2;
}
@keyframes pbPulse{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-2px)}
}

.pb-panel{
  width:min(392px, calc(100vw - 24px));
  height:min(72vh, 620px);
  background:rgba(255,255,255,.96);
  border:1px solid rgba(11,13,18,.08);
  border-radius:26px;
  box-shadow:0 36px 100px rgba(7,12,22,.18);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  opacity:0;
  transform:translateY(12px) scale(.985);
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
  backdrop-filter:blur(18px);
}
.pb-open .pb-panel{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}
.pb-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding:16px 16px 14px;
  border-bottom:1px solid var(--line);
  background:
    radial-gradient(700px 220px at 100% 0%, rgba(72,126,255,.14), transparent 50%),
    linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.88));
}
.pb-badge{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  background:#eef4ff;
  border:1px solid rgba(72,126,255,.18);
  color:#294c96;
  font-size:11px;
  font-weight:700;
  letter-spacing:.2px;
}
.pb-head h3{margin:10px 0 4px;font-size:18px}
.pb-head p{margin:0;color:var(--muted);font-size:13px;max-width:28ch;line-height:1.5}
.pb-close{
  width:40px;height:40px;border-radius:14px;
  border:1px solid var(--line);background:#fff;cursor:pointer;
  display:grid;place-items:center;flex:0 0 auto;
}
.pb-stream{
  flex:1;
  overflow:auto;
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:12px;
  background:
    linear-gradient(180deg, rgba(245,247,252,.86), rgba(255,255,255,.98));
}
.pb-msg{
  max-width:92%;
  border-radius:18px;
  padding:14px 14px 12px;
  box-shadow:var(--shadow2);
}
.pb-msg p{margin:0;line-height:1.6;font-size:14px;color:var(--ink)}
.pb-msg.bot{
  align-self:flex-start;
  background:#fff;
  border:1px solid rgba(11,13,18,.08);
  border-top-left-radius:10px;
}
.pb-msg.user{
  align-self:flex-end;
  background:linear-gradient(145deg, #0b0d12, #2a3344);
  color:#fff;
  border-top-right-radius:10px;
}
.pb-msg.user p{color:#fff}
.pb-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.pb-action{
  appearance:none;
  border:1px solid rgba(11,13,18,.08);
  background:#fff;
  color:var(--ink);
  border-radius:999px;
  padding:10px 12px;
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.pb-action.primary{
  background:var(--ink);
  color:#fff;
  border-color:var(--ink);
}
.pb-suggestions{
  display:grid;
  gap:8px;
  margin-top:12px;
}
.pb-suggestion{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 12px;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(11,13,18,.08);
}
.pb-suggestion span{display:block}
.pb-suggestion b{display:block;font-size:13px}
.pb-suggestion small{display:block;color:var(--muted);margin-top:4px}
.pb-suggestion i{
  font-style:normal;
  font-size:12px;
  font-weight:700;
  color:#294c96;
}
.pb-compose{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  padding:14px;
  border-top:1px solid var(--line);
  background:#fff;
}
.pb-compose input{
  min-width:0;
  width:100%;
  border-radius:16px;
  border:1px solid rgba(11,13,18,.12);
  padding:14px 14px;
  background:#fbfcff;
}
.pb-compose input:focus{
  outline:none;
  border-color:#7aa8ff;
  box-shadow:0 0 0 4px rgba(122,168,255,.18);
}
.pb-send{
  border:none;
  background:var(--ink);
  color:#fff;
  border-radius:16px;
  padding:0 16px;
  font-weight:700;
  cursor:pointer;
}

@media(max-width: 980px){
  .pb-wrap{
    right:10px;
    left:10px;
    bottom:84px;
    align-items:stretch;
  }

  .pb-launcher{
    max-width:none;
    width:100%;
    min-width:0;
  }

  .pb-panel{
    width:100%;
    height:min(68vh, 560px);
  }
}

@media(max-width: 640px){
  .pb-wrap{
    bottom:86px;
    gap:10px;
  }
  .pb-panel{
    height:min(70vh, 600px);
    border-radius:22px;
  }
  .pb-head{
    padding:14px 14px 12px;
  }
  .pb-stream{
    padding:12px;
  }
  .pb-msg{
    max-width:96%;
    padding:13px 12px 11px;
  }
  .pb-compose{
    padding:12px;
    grid-template-columns:1fr auto;
  }
  .pb-send{
    min-width:82px;
  }
}


/* === Final chatbot + blog fixes (v5) === */
.mobilebar .wrap{
  grid-template-columns:1fr !important;
}
#chatNow.btn{
  grid-column:1 / -1;
  width:100%;
  justify-content:center;
  min-height:52px;
  border-radius:18px;
  font-weight:700;
  letter-spacing:.01em;
}
body.has-pb-open .mobilebar{
  opacity:0;
  pointer-events:none;
  transform:translateY(16px);
  transition:opacity .18s ease, transform .18s ease;
}
@media(max-width:980px){
  .pb-wrap{
    right:10px;
    left:10px;
    bottom:12px;
    align-items:stretch;
  }
  .pb-launcher{
    display:none;
  }
  .pb-panel{
    width:100%;
    height:min(72vh, 640px);
  }
}
@media(max-width:640px){
  .pb-wrap{
    bottom:12px;
    gap:10px;
  }
  .pb-panel{
    height:min(74vh, 680px);
    border-radius:22px;
  }
}


/* Publish-ready stability fixes */
.navtoggle{display:none}
@media (max-width:980px){
  .nav{position:relative; flex-wrap:wrap}
  .navtoggle{
    display:inline-flex; align-items:center; justify-content:center;
    margin-left:auto; border:1px solid var(--line); background:#fff; border-radius:999px;
    padding:10px 14px; font-size:13px; cursor:pointer;
  }
  .actions{display:none}
  .navlinks{display:none; width:100%; flex-direction:column; align-items:stretch; gap:8px; padding-top:12px}
  .nav.nav-open .navlinks,
  .nav.nav-open .actions{display:flex}
  .nav.nav-open .actions{width:100%; justify-content:stretch; flex-direction:column; min-width:0}
  .nav.nav-open .actions .btn{width:100%; justify-content:center}
  .navlinks a{background:var(--chip2)}
}


/* Mobile interaction hardening v6 */
.navtoggle, #chatNow.btn, .pb-close, .pb-action, .pb-send, .pb-launcher{touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.navtoggle{position:relative;z-index:3;}
@media (max-width:980px){
  .nav{align-items:center;}
  .brand{flex:1 1 auto; min-width:0;}
  .navtoggle{display:inline-flex; min-height:46px; font-weight:700;}
  .nav.nav-open .navlinks, .nav.nav-open .actions{display:flex !important;}
  .nav.nav-open .navlinks{order:3;}
  .nav.nav-open .actions{order:4;}
  .pb-wrap{left:10px; right:10px; bottom:12px; z-index:76;}
  .pb-panel{display:none; width:100%; height:min(76vh,700px); max-height:calc(100vh - 24px); border-radius:24px;}
  .pb-open .pb-panel{display:flex;}
}
@media (max-width:640px){
  .pb-panel{height:min(78vh,720px); border-radius:22px;}
  .pb-head h3{font-size:17px;}
  .pb-head p{font-size:12px;}
  .pb-compose input{font-size:16px;}
}


/* === Final visual cleanup v8 === */
.pb-badge{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}
.pb-head .pb-id{min-width:0;flex:1 1 auto;}
.pb-head h3{margin:10px 0 6px;font-size:22px;line-height:1.15;}
.pb-head p{max-width:none;}
.pb-msg.bot p + p{margin-top:10px;}
@media (max-width:980px){
  .nav{display:flex !important;}
  .navtoggle{display:inline-flex !important;}
  .nav.nav-open .navlinks,.nav.nav-open .actions{display:flex !important; width:100%;}
  .nav.nav-open .navlinks a{display:block; width:100%; padding:12px 14px;}
}
@media (max-width:640px){
  .pb-badge{font-size:10px;}
  .pb-head h3{font-size:20px;}
}



/* === Final mobile chatbot polish v11 === */
.pb-wrap{pointer-events:none;}
.pb-wrap .pb-launcher,
.pb-wrap .pb-panel,
.pb-wrap .pb-panel *,
#chatNow,
.navtoggle{pointer-events:auto;}
.pb-panel{max-width:min(392px, calc(100vw - 24px));}
.pb-stream{overflow:auto; -webkit-overflow-scrolling:touch;}
.pb-action,.pb-send,.pb-close,.pb-launcher,.navtoggle{
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
}
.pb-actions{display:flex; flex-wrap:wrap; gap:10px;}
.pb-action{position:relative; z-index:2;}
@media (max-width:980px){
  .pb-wrap{left:10px; right:10px; bottom:12px; align-items:stretch;}
  .pb-launcher{width:100%; max-width:none; min-width:0;}
  .pb-panel{
    width:100%;
    max-width:none;
    height:min(78vh, 720px);
    max-height:calc(100vh - 24px);
    border-radius:22px;
  }
}
@media (max-width:640px){
  .pb-head{padding:14px 14px 12px;}
  .pb-head h3{font-size:19px;}
  .pb-head p{font-size:12px; line-height:1.45;}
  .pb-stream{padding:12px;}
  .pb-compose{padding:10px;}
  .pb-compose input{font-size:16px;}
  .pb-action{min-height:42px;}
}


/* === Close button hit area patch v12 === */
.pb-close{
  position: relative;
  z-index: 20;
  min-width: 44px;
  min-height: 44px;
  touch-action: manipulation;
  pointer-events: auto;
}
.pb-head{
  position: relative;
  z-index: 5;
}


/* mobile menu cleanup v8 */
@media (max-width:980px){
  .nav.nav-open .navlinks,
  .nav.nav-open .actions{
    width:100%;
    margin:0;
  }
  .nav.nav-open .navlinks{
    display:grid !important;
    grid-template-columns:1fr;
    gap:10px;
    padding:12px;
    border-radius:18px 18px 0 0;
  }
  .nav.nav-open .actions{
    display:grid !important;
    grid-template-columns:1fr;
    gap:10px;
    padding:0 12px 12px;
    border-radius:0 0 18px 18px;
  }
  .nav.nav-open .navlinks a,
  .nav.nav-open .actions .btn,
  .nav.nav-open .actions a,
  .nav.nav-open .actions button{
    width:100% !important;
    min-width:0 !important;
    display:flex !important;
    align-items:center;
    justify-content:center;
    margin:0 !important;
    text-align:center;
  }
  .nav.nav-open .navlinks a{
    justify-content:flex-start;
    min-height:48px;
    padding:12px 16px !important;
    background:#f5f7fb !important;
    border:1px solid var(--line);
    border-radius:14px;
  }
  .nav.nav-open .actions .btn,
  .nav.nav-open .actions a,
  .nav.nav-open .actions button{
    min-height:48px;
    border-radius:999px !important;
  }
}

/* blog readability v8 */
.blog-content, article .content, .prose, article{
  line-height:1.8;
}
.blog-key-takeaways{
  padding:16px 18px;
  background:#f7fafc;
  border:1px solid var(--line);
  border-radius:18px;
  margin:18px 0 22px;
}
.blog-key-takeaways h3{
  margin:0 0 10px;
  font-size:18px;
}
.blog-key-takeaways ul{
  margin:0;
  padding-left:18px;
}



/* mobile menu normalization v9 */
@media (max-width:980px){
  .nav{
    align-items:start !important;
  }
  .nav.nav-open .navlinks,
  .nav.nav-open .actions{
    box-sizing:border-box;
  }
  .nav.nav-open .navlinks{
    margin-top:10px !important;
    padding:12px !important;
    background:#fff !important;
    border:1px solid var(--line) !important;
    border-bottom:0 !important;
    border-radius:18px 18px 0 0 !important;
  }
  .nav.nav-open .actions{
    margin-top:0 !important;
    padding:12px !important;
    background:#fff !important;
    border:1px solid var(--line) !important;
    border-top:1px dashed rgba(11,13,18,.08) !important;
    border-radius:0 0 18px 18px !important;
  }
  .nav.nav-open .navlinks a{
    min-height:46px !important;
    background:#f5f7fb !important;
    border:1px solid var(--line) !important;
    border-radius:14px !important;
  }
  .nav.nav-open .actions .btn,
  .nav.nav-open .actions a,
  .nav.nav-open .actions button{
    min-height:48px !important;
    width:100% !important;
    border-radius:999px !important;
  }
  .nav.nav-open .actions .btn + .btn,
  .nav.nav-open .actions a + a,
  .nav.nav-open .actions button + button,
  .nav.nav-open .actions .btn + a,
  .nav.nav-open .actions a + .btn{
    margin-top:10px !important;
  }
  .nav.nav-open .navlinks::after{
    content:"Quick actions";
    display:block;
    margin-top:10px;
    padding:2px 2px 0;
    color:var(--muted);
    font-size:12px;
    font-weight:700;
    letter-spacing:.02em;
  }
  .nav.nav-open .actions{
    position:relative;
  }
}



/* mobile nav overlap fix v10 */
@media (max-width:980px){
  .nav{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) auto !important;
    grid-template-areas:
      "brand toggle"
      "navlinks navlinks"
      "actions actions" !important;
    align-items:center !important;
    row-gap:12px !important;
  }
  .brand{grid-area:brand !important;}
  .navtoggle{grid-area:toggle !important; align-self:start;}
  .navlinks{grid-area:navlinks !important;}
  .actions{grid-area:actions !important;}

  .nav.nav-open .navlinks,
  .nav.nav-open .actions{
    display:flex !important;
    flex-direction:column !important;
    width:100% !important;
    margin:0 !important;
    clear:both !important;
    position:relative !important;
    inset:auto !important;
    transform:none !important;
  }

  .nav.nav-open .navlinks{
    gap:10px !important;
    padding:12px !important;
    background:#fff !important;
    border:1px solid var(--line) !important;
    border-radius:18px !important;
    box-shadow:none !important;
  }

  .nav.nav-open .actions{
    gap:10px !important;
    padding:0 !important;
    background:transparent !important;
    border:0 !important;
    border-radius:0 !important;
    box-shadow:none !important;
  }

  .nav.nav-open .navlinks::after{
    content:none !important;
    display:none !important;
  }

  .nav.nav-open .navlinks a{
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    width:100% !important;
    min-height:48px !important;
    margin:0 !important;
    padding:12px 16px !important;
    background:#f5f7fb !important;
    border:1px solid var(--line) !important;
    border-radius:14px !important;
  }

  .nav.nav-open .actions .btn,
  .nav.nav-open .actions a,
  .nav.nav-open .actions button{
    display:flex !important;
    width:100% !important;
    min-height:48px !important;
    margin:0 !important;
    justify-content:center !important;
    border-radius:999px !important;
  }
}


/* blog full content v11 */
.blog-content, .blog-article, article, .prose{line-height:1.85}
.blog-content h3{margin-top:24px;font-size:22px}
.blog-content .desc{font-size:18px;color:var(--muted)}
.blog-content .seo{margin:16px 0 20px;padding:14px 16px;background:#f7f9fc;border:1px solid var(--line);border-radius:18px}
.blog-content .faq p{margin:12px 0}
.blog-content .internal-links{margin-top:24px;padding:18px;background:#f7fafc;border:1px solid var(--line);border-radius:18px}

/* chatbot avatar v13 */
.pb2-avatar{
width:44px;
height:44px;
border-radius:50%;
background:url('https://basaao.com/wp-content/uploads/2026/03/chatbot-Arohi.webp') center/cover no-repeat;
animation:botFloat 3.5s ease-in-out infinite;
box-shadow:0 8px 22px rgba(0,0,0,.18);
}

@keyframes botFloat{
0%{transform:translateY(0)}
50%{transform:translateY(-4px)}
100%{transform:translateY(0)}
}

.pb2-head{display:flex;gap:12px;align-items:flex-start}


/* real chatbot avatar pulse v15 */
.chatbot-avatar{
  width:42px;
  height:42px;
  border-radius:50%;
  background:url('https://basaao.com/wp-content/uploads/2026/03/chatbot-Arohi.webp') center/cover no-repeat;
  position:relative;
  box-shadow:0 6px 16px rgba(0,0,0,.18);
  flex:0 0 42px;
  margin-right:10px;
}
.chatbot-avatar::after{
  content:'';
  position:absolute;
  right:-2px;
  bottom:-2px;
  width:10px;
  height:10px;
  background:#22c55e;
  border-radius:50%;
  border:2px solid #fff;
}
.chatbot-avatar::before{
  content:'';
  position:absolute;
  right:-4px;
  bottom:-4px;
  width:16px;
  height:16px;
  background:#22c55e;
  border-radius:50%;
  opacity:.6;
  animation:chatbotPulse 1.8s infinite;
}
@keyframes chatbotPulse{
  0%{transform:scale(.6);opacity:.8}
  70%{transform:scale(1.6);opacity:0}
  100%{opacity:0}
}
.chatbot-info{display:flex;flex-direction:column;min-width:0}
.chatbot-status{font-size:12px;color:#22c55e;font-weight:600;display:block;margin:2px 0 1px}
.pb2-head{align-items:flex-start}
.pb2-head > div:first-child{display:flex;gap:10px;align-items:flex-start;min-width:0}


/* human chat cta v16 */
.chatbot-cta{
  display:flex;
  align-items:center;
  gap:12px;
  width:100%;
  background:linear-gradient(135deg, #0b0d12, #192132);
  color:#fff;
  padding:14px 16px;
  border-radius:999px;
  cursor:pointer;
  transition:transform .22s ease, box-shadow .22s ease, background .22s ease;
  box-shadow:0 14px 34px rgba(7,12,22,.24);
  border:1px solid rgba(255,255,255,.08);
}
.chatbot-cta:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 42px rgba(7,12,22,.30);
}
.chatbot-cta-avatar{
  width:40px;
  height:40px;
  border-radius:50%;
  background:url('https://basaao.com/wp-content/uploads/2026/03/chatbot-Arohi.webp') center/cover no-repeat;
  position:relative;
  flex:0 0 40px;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
}
.chatbot-cta-avatar::after{
  content:'';
  position:absolute;
  right:-2px;
  bottom:-2px;
  width:10px;
  height:10px;
  background:#22c55e;
  border-radius:50%;
  border:2px solid #0b0d12;
}
.chatbot-cta-avatar::before{
  content:'';
  position:absolute;
  right:-4px;
  bottom:-4px;
  width:16px;
  height:16px;
  background:#22c55e;
  border-radius:50%;
  opacity:.55;
  animation:chatCtaPulse 1.8s infinite;
}
@keyframes chatCtaPulse{
  0%{transform:scale(.6);opacity:.85}
  70%{transform:scale(1.6);opacity:0}
  100%{opacity:0}
}
.chatbot-cta-text{
  display:flex;
  flex-direction:column;
  min-width:0;
  text-align:left;
}
.chatbot-cta-text strong{
  font-size:14px;
  line-height:1.15;
  font-weight:700;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.chatbot-cta-text span{
  font-size:12px;
  color:rgba(255,255,255,.74);
  margin-top:4px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.chatbot-cta-action{
  margin-left:auto;
  background:#22c55e;
  color:#fff;
  font-size:13px;
  font-weight:700;
  line-height:1;
  padding:9px 13px;
  border-radius:999px;
  white-space:nowrap;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);
}
@media (max-width:640px){
  .chatbot-cta{padding:13px 14px; gap:10px;}
  .chatbot-cta-avatar{width:36px;height:36px;flex-basis:36px;}
  .chatbot-cta-text strong{font-size:13px;}
  .chatbot-cta-text span{font-size:11px;}
  .chatbot-cta-action{padding:8px 11px; font-size:12px;}
}


/* mobile nav + slim chat cta v17 */
@media (max-width:980px){
  .navtoggle,
  .navlinks a,
  .actions a,
  .actions button,
  .actions .btn{
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
  }
  .nav.nav-open .navlinks,
  .nav.nav-open .actions{
    position: relative !important;
    z-index: 120 !important;
  }
}

/* slim chatbot CTA */
.chatbot-cta{
  overflow:hidden;
}
@media (max-width:768px){
  #chatNow{
    padding:0 !important;
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
  }
  .chatbot-cta{
    gap:10px !important;
    padding:10px 12px !important;
    border-radius:24px !important;
    min-height:58px !important;
  }
  .chatbot-cta-avatar{
    width:34px !important;
    height:34px !important;
    flex-basis:34px !important;
  }
  .chatbot-cta-text{
    min-width:0 !important;
    flex:1 1 auto !important;
  }
  .chatbot-cta-text strong{
    font-size:13px !important;
    line-height:1.1 !important;
  }
  .chatbot-cta-text span{
    font-size:11px !important;
    line-height:1.15 !important;
    margin-top:3px !important;
  }
  .chatbot-cta-action{
    margin-left:0 !important;
    font-size:12px !important;
    padding:7px 10px !important;
    flex:0 0 auto !important;
  }
}


/* mobile menu reopen fix v18 */
@media (max-width:980px){
  .nav.nav-open .navlinks,
  .nav.nav-open .actions{
    display:flex !important;
    flex-direction:column !important;
    width:100% !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
  }
  .navlinks, .actions{
    transition:none !important;
  }
}


/* bottom chat CTA responsive + clickable v19 */
#chatNow{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  position:relative !important;
  z-index:80 !important;
}
#chatNow .chatbot-cta{
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box !important;
}
@media (max-width:768px){
  #chatNow{
    margin:0 !important;
    padding:0 !important;
  }
  #chatNow .chatbot-cta{
    min-height:56px !important;
    border-radius:20px !important;
    padding:10px 12px !important;
    gap:10px !important;
  }
  #chatNow .chatbot-cta-avatar{
    width:34px !important;
    height:34px !important;
    flex:0 0 34px !important;
  }
  #chatNow .chatbot-cta-text{
    min-width:0 !important;
    flex:1 1 auto !important;
  }
  #chatNow .chatbot-cta-text strong{
    font-size:13px !important;
    line-height:1.1 !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  #chatNow .chatbot-cta-text span{
    font-size:11px !important;
    line-height:1.15 !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  #chatNow .chatbot-cta-action{
    padding:8px 10px !important;
    font-size:12px !important;
    line-height:1 !important;
    flex:0 0 auto !important;
  }
}
@media (min-width:769px){
  #chatNow .chatbot-cta{
    min-height:64px !important;
  }
}


/* final mobile publish polish v20 */
html, body{
  max-width:100%;
  overflow-x:hidden;
}

@media (max-width:768px){
  body{
    overflow-x:hidden !important;
  }

  .app, .shell, main, .page, .section, .hero, .panel, .card{
    max-width:100% !important;
  }

  /* Header cleanup */
  .topbar{
    position:sticky;
    top:0;
    z-index:110;
    background:#fff;
  }
  .nav{
    grid-template-columns:minmax(0,1fr) auto !important;
    gap:10px !important;
    padding:12px !important;
    align-items:center !important;
  }
  .brand{
    min-width:0 !important;
    max-width:100% !important;
    display:flex !important;
    align-items:center !important;
    gap:10px !important;
    overflow:hidden !important;
  }
  .brand > div:last-child{
    min-width:0 !important;
    overflow:hidden !important;
  }
  .brand b{
    display:block !important;
    font-size:12px !important;
    line-height:1.15 !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  .brand span{
    display:block !important;
    font-size:10px !important;
    line-height:1.1 !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  .logo{
    width:34px !important;
    height:34px !important;
    flex:0 0 34px !important;
  }
  .navtoggle{
    min-width:74px !important;
    min-height:42px !important;
    padding:8px 14px !important;
    font-size:13px !important;
    border-radius:999px !important;
    justify-self:end !important;
  }

  /* Chat CTA hard width clamp */
  #chatNow{
    display:block !important;
    width:auto !important;
    max-width:none !important;
    margin:0 !important;
    padding:0 !important;
    border:0 !important;
    background:transparent !important;
    box-shadow:none !important;
  }
  #chatNow .chatbot-cta{
    display:flex !important;
    align-items:center !important;
    width:min(calc(100vw - 28px), 100%) !important;
    max-width:min(calc(100vw - 28px), 100%) !important;
    min-height:54px !important;
    margin:0 auto !important;
    padding:8px 10px !important;
    gap:8px !important;
    border-radius:18px !important;
    box-sizing:border-box !important;
    overflow:hidden !important;
  }
  #chatNow .chatbot-cta-avatar{
    width:32px !important;
    height:32px !important;
    flex:0 0 32px !important;
    margin-right:0 !important;
  }
  #chatNow .chatbot-cta-text{
    min-width:0 !important;
    flex:1 1 auto !important;
    overflow:hidden !important;
  }
  #chatNow .chatbot-cta-text strong{
    display:block !important;
    font-size:12px !important;
    line-height:1.05 !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  #chatNow .chatbot-cta-text span{
    display:block !important;
    font-size:10px !important;
    line-height:1.05 !important;
    margin-top:2px !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  #chatNow .chatbot-cta-action{
    flex:0 0 auto !important;
    margin-left:0 !important;
    padding:7px 9px !important;
    font-size:11px !important;
    line-height:1 !important;
    border-radius:999px !important;
    white-space:nowrap !important;
  }
}

/* Slight desktop tidy */
@media (min-width:769px){
  .brand b{line-height:1.15}
  .brand span{line-height:1.1}
}


/* mobile menu link click fix v21 */
@media (max-width:980px){
  .nav.nav-open .navlinks a,
  .nav.nav-open .actions a,
  .nav.nav-open .actions button,
  .nav.nav-open .actions .btn{
    pointer-events:auto !important;
    position:relative !important;
    z-index:140 !important;
    touch-action:manipulation !important;
  }
}




