/* ==========================================================================
   BabyAquaSpa — Design Tokens
   ========================================================================== */
:root{
  --bg:#3FBEE0;
  --surface:#FFFFFF;
  --ink:#23281F;
  --ink-soft:#4B5449;
  --sage:#6F8F73;
  --sage-light:#E7EEE4;
  --teal-deep:#1E3A5F;
  --teal-deeper:#142A45;
  --gold:#2F7DA8;
  --line:#DCE3D8;
  --danger:#A8503F;

  /* Curated pastel rainbow — used as accents (icon circles, chips), never as
     large flat backgrounds, so the site stays friendly without losing
     medical credibility. Kept in this order wherever they're sequenced. */
  --pastel-pink:#F7D7DC;
  --pastel-peach:#FBE1C7;
  --pastel-yellow:#FCEFC3;
  --pastel-mint:#D6EFDD;
  --pastel-sky:#D3E8F5;
  --pastel-lavender:#E3DAF0;
  --pastel-pink-ink:#8A4A55;
  --pastel-peach-ink:#8A5A2E;
  --pastel-yellow-ink:#7A6A1E;
  --pastel-mint-ink:#3D6B4A;
  --pastel-sky-ink:#3B6E8A;
  --pastel-lavender-ink:#6B5590;

  --font-display:'Fraunces', Georgia, serif;
  --font-body:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono:'IBM Plex Mono', monospace;

  --radius:14px;
  --radius-sm:8px;
  --shadow-soft:0 8px 30px rgba(35,40,31,0.08);
  --shadow-lift:0 16px 48px rgba(35,40,31,0.14);
  --max:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
body.page-white{background:var(--surface);}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.15;
  margin:0 0 0.5em;
  letter-spacing:-0.01em;
}
h1{font-size:clamp(2.4rem,5vw,3.8rem);font-weight:500;}
h2{font-size:clamp(1.8rem,3.2vw,2.6rem);}
h3{font-size:1.3rem;}
p{margin:0 0 1em;color:var(--ink-soft);}
.container{max-width:var(--max);margin:0 auto;padding:0 28px;}
.eyebrow{
  font-family:var(--font-mono);
  font-size:0.72rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--sage);
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:14px;
}
.eyebrow::before{
  content:'';
  width:16px;height:1px;
  background:var(--gold);
}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important;transition-duration:0.001ms !important;}
}

/* ==========================================================================
   Wave motif (signature element)
   ========================================================================== */
.wave-divider{
  width:100%;
  height:40px;
  line-height:0;
  overflow:hidden;
}
.wave-divider svg{width:100%;height:100%;display:block;}
.wave-divider.flip{transform:scaleY(-1);}

.underline-wave{
  position:relative;
  display:inline-block;
}
.underline-wave::after{
  content:'';
  position:absolute;
  left:0;right:0;bottom:-6px;
  height:6px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='6' viewBox='0 0 40 6'%3E%3Cpath d='M0 3 Q5 0 10 3 T20 3 T30 3 T40 3' stroke='%232F7DA8' stroke-width='1.4' fill='none'/%3E%3C/svg%3E") repeat-x;
  background-size:40px 6px;
}

/* ==========================================================================
   Header / Nav
   ========================================================================== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(30,58,95,0.96);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(255,255,255,0.12);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 28px;
  max-width:var(--max);margin:0 auto;
}
.logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-display);
  font-size:1.3rem;
  font-weight:600;
  color:#fff;
}
.logo-mark{
  width:36px;height:36px;
  border-radius:50%;
  background:var(--sage-light);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  /* LOGO PLACEHOLDER: replace this div's contents with <img src="/assets/logo.svg" alt="BabyAquaSpa logo"> */
}
.logo-mark svg{width:20px;height:20px;}
.nav-links{
  display:flex;align-items:center;gap:34px;
  list-style:none;margin:0;padding:0;
}
.nav-links a{
  font-size:0.94rem;
  color:#C7D6EA;
  position:relative;
  transition:color 0.2s;
}
.nav-links a:hover, .nav-links a.active{color:#fff;}
.nav-links a.active::after{
  content:'';
  position:absolute;left:0;right:0;bottom:-8px;height:2px;
  background:#6EC1E4;
}
.nav-cta{
  background:var(--gold);
  color:#fff !important;
  padding:11px 22px;
  border-radius:999px;
  font-size:0.9rem;
  font-weight:500;
  transition:background 0.2s, transform 0.2s;
}
.nav-cta:hover{background:#256A91;transform:translateY(-1px);}
.nav-toggle{
  display:none;
  background:none;border:none;cursor:pointer;
  padding:6px;
}
.nav-toggle svg{width:26px;height:26px;color:#fff;}

@media (max-width:900px){
  .nav-links{
    position:fixed;top:73px;left:0;right:0;
    background:var(--teal-deep);
    flex-direction:column;
    align-items:flex-start;
    gap:0;
    padding:8px 28px 20px;
    border-bottom:1px solid rgba(255,255,255,0.12);
    transform:translateY(-110%);
    transition:transform 0.25s ease;
  }
  .nav-links.open{transform:translateY(0);}
  .nav-links li{width:100%;padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.12);}
  .nav-links a.active::after{display:none;}
  .nav-cta{margin-top:12px;display:inline-block;}
  .nav-toggle{display:block;}
}

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;
  border-radius:999px;
  font-size:0.96rem;
  font-weight:500;
  cursor:pointer;
  border:1px solid transparent;
  transition:transform 0.2s, background 0.2s, color 0.2s, border-color 0.2s;
  font-family:var(--font-body);
}
.btn-primary{background:var(--teal-deep);color:#fff;}
.btn-primary:hover{background:var(--teal-deeper);transform:translateY(-1px);}
.btn-secondary{background:transparent;color:var(--teal-deep);border-color:var(--teal-deep);}
.btn-secondary:hover{background:var(--teal-deep);color:#fff;}
.btn-gold{background:var(--gold);color:#fff;}
.btn-gold:hover{transform:translateY(-1px);filter:brightness(1.04);}
.btn-block{width:100%;justify-content:center;}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{
  background:linear-gradient(180deg, var(--bg) 0%, #FDFCFA 100%);
  padding:72px 0 0;
  overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:1.1fr 0.9fr;
  gap:56px;align-items:center;
  max-width:var(--max);margin:0 auto;padding:0 28px 64px;
}
.hero-trust{
  display:flex;gap:22px;flex-wrap:wrap;
  margin-top:28px;
  font-family:var(--font-mono);
  font-size:0.76rem;
  color:var(--ink-soft);
}
.hero-trust span{display:flex;align-items:center;gap:6px;}
.hero-trust svg{width:14px;height:14px;color:var(--sage);}
.hero-actions{display:flex;gap:16px;margin-top:34px;flex-wrap:wrap;}
.hero-media{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  aspect-ratio:4/5;
  background:var(--sage-light);
  box-shadow:var(--shadow-lift);
}
.hero-media .placeholder-img{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  color:var(--sage);
  font-family:var(--font-mono);font-size:0.8rem;
  text-align:center;padding:20px;
}
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-media{order:-1;aspect-ratio:16/10;}
}

/* ==========================================================================
   Sections / generic
   ========================================================================== */
section{padding:76px 0;}
.section-tight{padding:52px 0;}
.section-dark{background:var(--teal-deep);color:#fff;}
.section-dark p{color:#C7D6EA;}
.section-dark .eyebrow{color:var(--gold);}
.section-dark .eyebrow::before{background:#fff;}
.section-sage{background:var(--sage-light);}
.center{text-align:center;}
.max-w-copy{max-width:640px;}
.mx-auto{margin-left:auto;margin-right:auto;}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;}
@media (max-width:900px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-2{grid-template-columns:1fr;}
}
@media (max-width:600px){
  .grid-3,.grid-4{grid-template-columns:1fr;}
}

.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:30px;
  transition:transform 0.25s, box-shadow 0.25s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);}
.card-icon{
  width:44px;height:44px;border-radius:50%;
  background:var(--sage-light);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;
  color:var(--teal-deep);
}
.card-icon svg{width:22px;height:22px;}

/* Pastel rainbow icon variants — cycle in this order across a row of cards */
.card-icon.pastel-pink{background:var(--pastel-pink);color:var(--pastel-pink-ink);}
.card-icon.pastel-peach{background:var(--pastel-peach);color:var(--pastel-peach-ink);}
.card-icon.pastel-yellow{background:var(--pastel-yellow);color:var(--pastel-yellow-ink);}
.card-icon.pastel-mint{background:var(--pastel-mint);color:var(--pastel-mint-ink);}
.card-icon.pastel-sky{background:var(--pastel-sky);color:var(--pastel-sky-ink);}
.card-icon.pastel-lavender{background:var(--pastel-lavender);color:var(--pastel-lavender-ink);}

/* Pastel section washes — very light, used instead of repeating sage-light
   everywhere. Meant for whole-section backgrounds so it stays soft. */
.section-pink{background:linear-gradient(180deg,#FDF4F5 0%,var(--bg) 100%);}
.section-sky{background:linear-gradient(180deg,#F3F9FC 0%,var(--bg) 100%);}
.section-mint{background:linear-gradient(180deg,#F2FAF5 0%,var(--bg) 100%);}
.section-lavender{background:linear-gradient(180deg,#F8F5FB 0%,var(--bg) 100%);}
.section-peach{background:linear-gradient(180deg,#FDF6EE 0%,var(--bg) 100%);}

/* Pastel chip variants for chatbot quick replies */
.chat-quick-reply.pastel-pink{background:var(--pastel-pink);border-color:var(--pastel-pink);color:var(--pastel-pink-ink);}
.chat-quick-reply.pastel-sky{background:var(--pastel-sky);border-color:var(--pastel-sky);color:var(--pastel-sky-ink);}
.chat-quick-reply.pastel-mint{background:var(--pastel-mint);border-color:var(--pastel-mint);color:var(--pastel-mint-ink);}
.chat-quick-reply.pastel-lavender{background:var(--pastel-lavender);border-color:var(--pastel-lavender);color:var(--pastel-lavender-ink);}

/* Pricing / package cards */
.pkg-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:32px;
  display:flex;flex-direction:column;
  position:relative;
}
.pkg-card.featured{
  border-color:var(--gold);
  box-shadow:var(--shadow-soft);
}
.pkg-featured-tag{
  position:absolute;top:-13px;left:32px;
  background:var(--gold);color:#fff;
  font-family:var(--font-mono);font-size:0.68rem;
  letter-spacing:0.08em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;
}
.pkg-dot{
  display:inline-block;width:10px;height:10px;border-radius:50%;
  margin-right:8px;vertical-align:middle;
}
.pkg-dot.pastel-pink{background:var(--pastel-pink-ink);}
.pkg-dot.pastel-peach{background:var(--pastel-peach-ink);}
.pkg-dot.pastel-yellow{background:var(--pastel-yellow-ink);}
.pkg-dot.pastel-mint{background:var(--pastel-mint-ink);}
.pkg-dot.pastel-sky{background:var(--pastel-sky-ink);}
.pkg-dot.pastel-lavender{background:var(--pastel-lavender-ink);}

.pkg-price{
  font-family:var(--font-display);
  font-size:2.2rem;color:var(--teal-deep);
  margin:6px 0 2px;
}
.pkg-price span{font-size:0.95rem;color:var(--ink-soft);font-family:var(--font-body);}
.pkg-list{list-style:none;padding:0;margin:20px 0 26px;flex-grow:1;}
.pkg-list li{
  display:flex;gap:10px;align-items:flex-start;
  font-size:0.92rem;color:var(--ink-soft);
  padding:7px 0;border-top:1px solid var(--line);
}
.pkg-list li:first-child{border-top:none;}
.pkg-list svg{width:15px;height:15px;flex-shrink:0;margin-top:3px;color:var(--sage);}

/* Insurance code chips */
.code-chip{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);
  font-size:0.78rem;
  background:var(--sage-light);
  color:var(--teal-deep);
  border:1px solid var(--line);
  padding:6px 12px;
  border-radius:999px;
  margin:4px;
}
.code-chip strong{color:var(--gold-dark,var(--teal-deep));}

.code-table{width:100%;border-collapse:collapse;font-size:0.92rem;}
.code-table th{
  text-align:left;font-family:var(--font-mono);font-size:0.72rem;
  letter-spacing:0.06em;text-transform:uppercase;color:var(--sage);
  padding:10px 14px;border-bottom:2px solid var(--line);
}
.code-table td{padding:14px 14px;border-bottom:1px solid var(--line);}
.code-table td:first-child{font-family:var(--font-mono);color:var(--teal-deep);font-weight:600;}
.code-table tr:hover td{background:var(--sage-light);}

/* Numbered process steps (legitimate sequence use) */
.steps{list-style:none;padding:0;margin:0;counter-reset:step;}
.step{
  display:grid;grid-template-columns:52px 1fr;gap:20px;
  padding:22px 0;border-bottom:1px solid var(--line);
}
.step:last-child{border-bottom:none;}
.step-num{
  font-family:var(--font-display);
  font-size:1.4rem;color:var(--gold);
}

/* Compare table (private pay vs hybrid) */
.compare{
  display:grid;grid-template-columns:1fr 1fr;
  gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
}
.compare-col{padding:32px;}
.compare-col:first-child{border-right:1px solid var(--line);background:var(--surface);}
.compare-col.highlight{background:var(--teal-deep);color:#fff;}
.compare-col.highlight p, .compare-col.highlight li{color:#C7D6EA;}
.compare-col ul{padding-left:0;list-style:none;}
.compare-col li{padding:8px 0;display:flex;gap:10px;}
@media (max-width:700px){
  .compare{grid-template-columns:1fr;}
  .compare-col:first-child{border-right:none;border-bottom:1px solid var(--line);}
}

/* Forms */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.form-field.full{grid-column:1/-1;}
.form-field label{font-size:0.82rem;color:var(--ink-soft);font-weight:500;}
.form-field input, .form-field select, .form-field textarea{
  padding:13px 16px;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  font-family:var(--font-body);
  font-size:0.96rem;
  background:var(--surface);
  color:var(--ink);
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus{
  outline:none;border-color:var(--sage);box-shadow:0 0 0 3px var(--sage-light);
}
.form-field textarea{resize:vertical;min-height:110px;}
.radio-row{display:flex;gap:18px;flex-wrap:wrap;}
.radio-option{
  display:flex;align-items:center;gap:8px;
  padding:10px 16px;border:1px solid var(--line);border-radius:999px;
  cursor:pointer;font-size:0.88rem;
}
.radio-option input{margin:0;}
@media (max-width:700px){.form-grid{grid-template-columns:1fr;}}
.form-note{font-size:0.8rem;color:var(--ink-soft);margin-top:-6px;}
.form-success{
  display:none;
  background:var(--sage-light);
  border:1px solid var(--sage);
  border-radius:var(--radius-sm);
  padding:18px 20px;
  margin-top:16px;
  font-size:0.92rem;
}
.form-success.show{display:block;}

/* Testimonial */
.quote-card{
  background:var(--surface);
  border-radius:var(--radius);
  padding:40px;
  border-left:3px solid var(--gold);
}
.quote-card p{font-family:var(--font-display);font-size:1.25rem;color:var(--ink);font-weight:400;}
.quote-attrib{font-size:0.85rem;color:var(--ink-soft);font-family:var(--font-mono);}

/* CTA banner */
.cta-banner{
  background:var(--teal-deep);
  color:#fff;border-radius:var(--radius);
  padding:52px;
  display:flex;align-items:center;justify-content:space-between;
  gap:30px;flex-wrap:wrap;
}
.cta-banner h2{color:#fff;margin-bottom:6px;}
.cta-banner p{color:#C7D6EA;margin:0;}

/* Footer */
.site-footer{
  background:var(--teal-deeper);
  color:#C7D6EA;
  padding:64px 0 28px;
}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,0.12);
}
.footer-logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-display);color:#fff;font-size:1.2rem;margin-bottom:12px;
}
.footer-col h4{
  color:#fff;font-family:var(--font-mono);font-size:0.74rem;
  letter-spacing:0.08em;text-transform:uppercase;margin-bottom:16px;
}
.footer-col ul{list-style:none;padding:0;margin:0;}
.footer-col li{margin-bottom:10px;font-size:0.9rem;}
.footer-col a:hover{color:#fff;}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:22px;font-size:0.8rem;color:#8FA8C4;flex-wrap:wrap;gap:10px;
}
.footer-disclaimer{font-size:0.76rem;color:#7089A8;max-width:700px;margin-top:18px;}
@media (max-width:900px){
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr;}
}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity 0.6s ease, transform 0.6s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* Page hero (non-home pages) */
.page-hero{
  padding:56px 0 40px;
  background:var(--sage-light);
}
.page-hero h1{font-size:clamp(2rem,4vw,2.8rem);}
.breadcrumb{
  font-family:var(--font-mono);font-size:0.76rem;color:var(--sage);
  margin-bottom:14px;
}

/* ==========================================================================
   Chatbot widget
   ========================================================================== */
.chat-launcher{
  position:fixed;bottom:24px;right:24px;z-index:200;
  width:68px;height:68px;border-radius:50%;
  background:var(--teal-deep);color:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:var(--shadow-lift);
  border:none;transition:transform 0.2s;
  animation:launcherPulse 2.6s ease-out infinite;
}
.chat-launcher:hover{transform:scale(1.06);}
.chat-launcher svg{width:28px;height:28px;}
.chat-launcher .pulse-dot{
  position:absolute;top:-3px;right:-3px;
  width:14px;height:14px;border-radius:50%;
  background:var(--gold);border:2px solid var(--bg);
}
@keyframes launcherPulse{
  0%{box-shadow:var(--shadow-lift),0 0 0 0 rgba(30,58,95,0.45);}
  70%{box-shadow:var(--shadow-lift),0 0 0 16px rgba(30,58,95,0);}
  100%{box-shadow:var(--shadow-lift),0 0 0 0 rgba(30,58,95,0);}
}
.chat-launcher.has-teaser{animation:none;}
.chat-teaser{
  position:fixed;bottom:100px;right:24px;z-index:200;
  max-width:240px;
  background:var(--surface);color:var(--ink,#1c1c1c);
  border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-lift);
  padding:14px 34px 14px 16px;
  font-size:0.86rem;line-height:1.4;
  transform:translateY(10px) scale(0.97);
  opacity:0;pointer-events:none;
  transition:transform 0.3s ease, opacity 0.3s ease;
}
.chat-teaser.show{transform:translateY(0) scale(1);opacity:1;pointer-events:auto;cursor:pointer;}
.chat-teaser-close{
  position:absolute;top:8px;right:8px;
  width:20px;height:20px;border:none;background:none;
  color:var(--sage);cursor:pointer;opacity:0.7;
  display:flex;align-items:center;justify-content:center;
}
.chat-teaser-close:hover{opacity:1;}
.chat-panel{
  position:fixed;bottom:96px;right:24px;z-index:200;
  width:360px;max-height:70vh;
  background:var(--surface);
  border-radius:var(--radius);
  box-shadow:var(--shadow-lift);
  border:1px solid var(--line);
  display:flex;flex-direction:column;
  overflow:hidden;
  transform:translateY(16px) scale(0.98);
  opacity:0;pointer-events:none;
  transition:transform 0.25s ease, opacity 0.25s ease;
}
.chat-panel.open{
  transform:translateY(0) scale(1);
  opacity:1;pointer-events:auto;
}
.chat-header{
  background:var(--teal-deep);color:#fff;
  padding:16px 18px;
  display:flex;align-items:center;justify-content:space-between;
}
.chat-header-title{display:flex;align-items:center;gap:10px;font-size:0.95rem;}
.chat-header-title .dot{width:8px;height:8px;border-radius:50%;background:#7BD79A;}
.chat-close{background:none;border:none;color:#fff;cursor:pointer;opacity:0.8;}
.chat-close:hover{opacity:1;}
.chat-body{
  flex:1;overflow-y:auto;
  padding:18px;
  display:flex;flex-direction:column;gap:12px;
  background:var(--bg);
}
.chat-msg{
  max-width:85%;
  padding:11px 14px;
  border-radius:14px;
  font-size:0.9rem;
  line-height:1.45;
}
.chat-msg.bot{
  background:var(--surface);border:1px solid var(--line);
  align-self:flex-start;border-bottom-left-radius:4px;
}
.chat-msg.user{
  background:var(--teal-deep);color:#fff;
  align-self:flex-end;border-bottom-right-radius:4px;
}
.chat-quick-replies{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px;}
.chat-quick-reply{
  font-size:0.8rem;
  background:var(--sage-light);
  border:1px solid var(--line);
  padding:7px 12px;border-radius:999px;
  cursor:pointer;color:var(--teal-deep);
}
.chat-quick-reply:hover{background:var(--gold);color:#fff;border-color:var(--gold);}
.chat-typing{display:flex;gap:4px;padding:4px 0;}
.chat-typing span{
  width:6px;height:6px;border-radius:50%;background:var(--sage);
  animation:blink 1.4s infinite ease-in-out;
}
.chat-typing span:nth-child(2){animation-delay:0.2s;}
.chat-typing span:nth-child(3){animation-delay:0.4s;}
@keyframes blink{0%,80%,100%{opacity:0.25;}40%{opacity:1;}}
.chat-input-row{
  display:flex;gap:8px;padding:14px;
  border-top:1px solid var(--line);background:var(--surface);
}
.chat-input-row input{
  flex:1;border:1px solid var(--line);border-radius:999px;
  padding:11px 16px;font-size:0.88rem;font-family:var(--font-body);
}
.chat-input-row input:focus{outline:none;border-color:var(--sage);}
.chat-send{
  width:40px;height:40px;border-radius:50%;
  background:var(--teal-deep);color:#fff;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.chat-send svg{width:17px;height:17px;}
.chat-send:disabled{opacity:0.5;cursor:not-allowed;}

@media (max-width:480px){
  .chat-panel{width:calc(100vw - 32px);right:16px;bottom:90px;}
  .chat-launcher{right:16px;bottom:16px;}
  .chat-teaser{right:16px;max-width:calc(100vw - 90px);}
}
