/* dao/static/css/main.css */

/* ===============================
   Design tokens
   =============================== */
:root{
  --color-bg:#121212;
  --color-text:#f5f5f5;
  --color-muted:#a0a0a0;
  --color-primary:#d4af37;       /* золото */
  --color-primary-dark:#b9972f;  /* тёмное золото */
  --color-accent:#181818;
  --color-border:#2a2a2a;
  --surface:#1a1a1a;
  --surface-elev:#1e1e1e;

  --cta-text:#121212;

  --radius:16px;
  --shadow:0 18px 46px rgba(0,0,0,.35);

  --cta-height:54px;
  --cta-max-width:480px;

  font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

/* ===============================
   Base
   =============================== */
*{box-sizing:border-box}
html,body{
  margin:0;
  background:
    radial-gradient(circle at 20% 0%,rgba(212,175,55,.08),transparent 50%),
    var(--color-bg);
  color:var(--color-text);
  line-height:1.6;
  min-height:100vh;
  min-height:100svh;
  min-height:100dvh;
  overflow-x:hidden; /* отключаем горизонтальный скролл по всей странице */
}
a{color:var(--color-primary);text-decoration:none}
a:hover,a:focus{text-decoration:underline}
button{font:inherit}
img{max-width:100%;height:auto;display:block}
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:static;width:auto;height:auto;padding:.5rem 1rem;background:var(--color-primary);color:var(--cta-text);border-radius:var(--radius)}
.visually-hidden{position:absolute!important;width:1px;height:1px;margin:-1px;border:0;padding:0;clip:rect(0 0 0 0);overflow:hidden}

/* ===============================
   Layout / Header / Nav
   =============================== */
.container{width:min(100%,1120px);margin:0 auto;padding:0 1.5rem}
.site-header{position:sticky;top:0;z-index:20;background:rgba(18,18,18,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border)}
.nav-container{display:flex;align-items:center;justify-content:center;padding:.65rem 0}
.nav__list{display:flex;gap:clamp(.5rem,4vw,1.1rem);list-style:none;padding:0;margin:0}
.nav__link{padding:.3rem clamp(.5rem,3vw,.8rem);border-radius:999px;color:var(--color-text);font-size:clamp(.78rem,3.3vw,.95rem);transition:background .2s ease;white-space:nowrap}
.nav__link--active,.nav__link:hover{background:rgba(255,255,255,.05)}

.page{padding-bottom:0}

/* ===============================
   Hero
   =============================== */
.hero{padding:3.5rem 0 2.5rem}
.hero--minimal{padding-top:4.25rem}
.hero--page{padding-top:4rem;padding-bottom:2rem}

.hero__inner{display:flex;flex-direction:column;gap:1rem;text-align:left}
.hero--page .hero__inner{display:grid;place-items:center;text-align:center;gap:clamp(.85rem,3vw,1.4rem)}

.hero__heading{margin:0;font-weight:800;font-size:clamp(2.35rem,7.4vw,3.4rem);line-height:1.08;letter-spacing:.01em;text-align:center;hyphens:manual}
.hero__subheading{margin:.25rem 0 0;font-weight:700;font-size:clamp(1.65rem,5vw,2.35rem);line-height:1.08;letter-spacing:.015em;text-align:center;color:var(--color-text);opacity:.92;hyphens:manual}

.hero--minimal .hero__inner{text-align:center;align-items:center}
.hero--minimal h1{margin:0 auto .5rem;max-width:20ch;font-size:clamp(2.1rem,7.8vw,3.2rem);line-height:1.12;font-weight:800;letter-spacing:.01em}

.hero__title{margin:0 auto .5rem;max-width:var(--cta-max-width);text-align:center}
.hero__title-main{display:block;font-weight:800;font-size:clamp(2.3rem,7.8vw,3.2rem);line-height:1.08;letter-spacing:.02em}
.hero__title-sub{display:block;font-weight:700;font-size:clamp(1.4rem,5.2vw,3.05rem);line-height:1.15;letter-spacing:.005em;opacity:.95;margin-top:.15rem}

.hero__lead{font-size:1.05rem;color:var(--color-muted);max-width:32rem}
.hero--minimal .hero__lead,.hero--page .hero__lead{text-align:center;margin:.4rem auto 0;max-width:var(--cta-max-width)}

.hero__buttons{display:flex;flex-wrap:wrap;gap:.75rem}
.hero--page .hero__buttons{justify-content:center;margin-top:clamp(1rem,3vw,1.75rem)}
.hero__buttons--stack{flex-direction:column;align-items:center;width:100%}
.hero__buttons--stack .button{width:min(var(--cta-max-width),100%);max-width:var(--cta-max-width);min-height:var(--cta-height);border-radius:999px;display:flex;justify-content:center;align-items:center;margin-left:auto;margin-right:auto}

/* ===============================
   Buttons
   =============================== */
.button{display:inline-flex;align-items:center;justify-content:center;padding:.8rem 1.6rem;border-radius:999px;border:none;background:var(--color-primary);color:var(--cta-text);font-weight:600;cursor:pointer;min-height:46px;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease}
.button:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(212,175,55,.24);filter:brightness(1.06) saturate(1.08)}
.button--ghost{background:transparent;color:var(--color-text);border:1px solid var(--color-primary);box-shadow:none}
.button--ghost:hover{border-color:var(--color-primary-dark);box-shadow:0 10px 20px rgba(212,175,55,.15);background:rgba(212,175,55,.06)}
.button--outline{background:transparent;color:var(--color-text);border:1px solid rgba(255,255,255,.28)}
.button--outline:hover{border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.06)}

.button--cta,.sticky-cta__button{width:min(var(--cta-max-width),100%);min-height:var(--cta-height);border-radius:999px;font-size:clamp(.98rem,2.4vw,1.05rem);font-weight:600;padding:.95rem 1.9rem;box-shadow:0 14px 28px rgba(212,175,55,.25);display:inline-flex;justify-content:center;align-items:center;cursor:pointer;text-decoration:none}
.button--cta{display:flex;margin-left:auto;margin-right:auto}
.button--cta:not(.button--ghost),.sticky-cta__button{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:var(--cta-text);border:none}

/* ===============================
   Sections & Content
   =============================== */
.section{padding:2.75rem 0}
.section--muted{background:var(--color-accent)}
.section--cta{background:transparent}
.section--note{border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);background:var(--surface)}

.list{list-style:none;padding:0;margin:0;display:grid;gap:.7rem}
.list--bulleted{list-style:disc;padding-left:1.25rem;gap:.55rem;display:block}
.list--bulleted li{margin:0 0 .35rem}
.list--bulleted li:last-child{margin-bottom:0}
.list--muted li{color:var(--color-muted)}
.list--columns{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}

.cards{display:grid;gap:1rem}
.cards--grid,.cards--sheet{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.card{padding:1.25rem;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--surface-elev);box-shadow:var(--shadow)}
.card--compact{padding:1rem}
.card--action{display:grid;gap:1rem}

.faq{border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:.75rem;background:var(--surface)}
.faq summary{cursor:pointer;font-weight:600}

/* ===============================
   Bottom sheet (опционально)
   =============================== */
.bottom-sheet{position:fixed;left:0;right:0;bottom:0;transform:translateY(100%);transition:transform .35s ease;z-index:60}
.bottom-sheet.is-open{transform:translateY(0)}
.bottom-sheet-mask{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:59}
.bottom-sheet-mask.is-active{opacity:1;pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.bottom-sheet__handle{width:54px;height:6px;border-radius:999px;background:var(--color-border);margin:.5rem auto}
.bottom-sheet__content{background:var(--surface);border-top-left-radius:24px;border-top-right-radius:24px;border:1px solid var(--color-border);box-shadow:0 -18px 46px rgba(0,0,0,.45);padding:1rem 1.5rem calc(2.75rem + env(safe-area-inset-bottom));max-height:min(92vh,840px);overflow-y:auto;overscroll-behavior:contain;display:grid;gap:1.5rem}
.bottom-sheet__header{display:flex;justify-content:space-between;align-items:center}
.bottom-sheet__close{background:transparent;border:none;color:var(--color-muted);font-size:1.5rem;cursor:pointer}

/* ===============================
   Chips / Badges
   =============================== */
.chip-list{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{border:1px solid var(--color-border);border-radius:999px;padding:.35rem .9rem;background:var(--surface);color:var(--color-text);font-size:.9rem;cursor:pointer;transition:background .2s ease}
.chip:hover{background:rgba(212,175,55,.1)}
.badge-list{display:flex;flex-wrap:wrap;gap:.75rem}
.badge{background:var(--color-accent);border-radius:999px;padding:.45rem .9rem;border:1px solid var(--color-border);font-size:.9rem}

/* ===============================
   Chat modal
   =============================== */
.chat-container{position:fixed;inset:0;pointer-events:none;display:flex;align-items:flex-end;justify-content:center;padding:1.5rem;z-index:1002}
.chat-mask{position:fixed;inset:0;background:rgba(0,0,0,.6);opacity:0;visibility:hidden;transition:opacity .2s ease;pointer-events:none;z-index:1001}
.chat-mask.is-active{opacity:1;visibility:visible;pointer-events:auto}
.chat{width:min(420px,100%);max-height:min(640px,90vh);background:#111;border-radius:22px;box-shadow:0 32px 64px rgba(0,0,0,.48);border:1px solid rgba(255,255,255,.06);transform:translateY(24px);opacity:0;pointer-events:none;transition:transform .22s cubic-bezier(.18,.89,.32,1.28),opacity .2s ease;display:grid;grid-template-rows:auto auto 1fr auto;overflow:hidden;position:relative;z-index:1002}
.chat.is-open{transform:translateY(0);opacity:1;pointer-events:auto}
.chat__header{
  padding:16px 52px 8px 16px;
  display:grid;
  gap:.25rem;
  position:relative;
}
.chat__close{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:rgba(17,17,17,.85);color:var(--color-text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}
.chat__title{margin:0;font-size:1.1rem;font-weight:600}
.chat__subtitle{margin:0;font-size:.85rem;color:var(--color-muted)}
.chat__hints{display:flex;flex-wrap:wrap;gap:.5rem;padding:0 16px 8px}
.chip{padding:.45rem .75rem;border-radius:999px;font-size:.85rem;background:rgba(255,255,255,.08);color:var(--color-text);border:none;cursor:pointer;transition:background .2s ease}
.chip:hover,.chip:focus-visible{background:rgba(255,255,255,.14)}
.chat__messages{padding:.5rem 16px 1rem;overflow-y:auto;display:grid;gap:.75rem}
.msg{
  display:flex;
  flex-direction:column;
  gap:.25rem;
  padding:.65rem .75rem;
  border-radius:14px;
  font-size:.95rem;
  line-height:1.45;
  word-break:break-word;
  max-width:88%;
  background:transparent;
  color:var(--color-text);
}
.msg.bot{
  background:rgba(255,255,255,.06);
  margin-right:auto;
  align-self:flex-start;
}
.msg.user{
  background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));
  color:var(--cta-text);
  margin-left:auto;
  align-self:flex-end;
}
.msg p{
  margin:0;
}
.msg p + p{
  margin-top:.25rem;
}
.msg ul{
  margin:.25rem 0 0;
  padding-left:1.15rem;
}
.msg li{
  margin:0;
}
.msg--typing{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:.55rem;
  color:rgba(255,255,255,.75);
  font-style:normal;
  opacity:1;
}
.msg--typing .typing__label{
  font-size:.85rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  opacity:.85;
}
.msg--typing .typing__dots{
  display:flex;
  align-items:center;
  gap:.25rem;
}
.msg--typing .typing__dot{
  width:7px;
  height:7px;
  border-radius:999px;
  background-color:currentColor;
  opacity:.3;
  animation:typing-bounce 1.2s infinite ease-in-out;
}
.msg--typing .typing__dots .typing__dot:nth-child(2){animation-delay:.15s}
.msg--typing .typing__dots .typing__dot:nth-child(3){animation-delay:.3s}
.msg .code{
  padding:.75rem;
  border:1px solid var(--color-border);
  border-radius:10px;
  background:rgba(0,0,0,.25);
  overflow:auto;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:.9rem;
}
@keyframes typing-bounce{
  0%,80%,100%{opacity:.2;transform:translateY(0)}
  40%{opacity:1;transform:translateY(-3px)}
}
.chat__form{padding:.85rem 16px 1.2rem;display:grid;grid-template-columns:1fr auto;gap:.7rem;align-items:center;background:rgba(12,12,12,.92);border-top:1px solid rgba(255,255,255,.06)}
#chat-input{width:100%;padding:.85rem 1rem;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:rgba(8,8,8,.92);color:var(--color-text)}
#chat-input::placeholder{color:rgba(255,255,255,.5)}
#chat-send{padding:.85rem 1.4rem;border-radius:14px;border:none;font-weight:600;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#121212;cursor:pointer;transition:filter .2s ease}
#chat-send:disabled{opacity:.4;cursor:default}
#chat-send:not(:disabled):hover,#chat-send:not(:disabled):focus-visible{filter:brightness(1.08)}
body.chat-open{overflow:hidden}
body.chat-open .chat-container{pointer-events:auto}
body.chat-open .chat{pointer-events:auto}
[data-action="open_chat"],[data-action="open_picker"],[data-action="open_lead"]{touch-action:manipulation}
.lead-inline-btn{margin-top:.4rem;padding:.5rem .9rem;border-radius:999px;border:none;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#121212;font-weight:600;cursor:pointer}
.lead-inline-btn:hover,.lead-inline-btn:focus-visible{filter:brightness(1.1)}
@media (max-width:520px){
  .chat-container{padding:1rem}
  .chat{border-radius:18px}
  .chat__header,.chat__hints,.chat__messages,.chat__form{padding-left:1rem;padding-right:1rem}
}

/* Chat fullscreen mode (opens like an app) */
.chat-container--fullscreen{padding:0;align-items:stretch;justify-content:stretch}
.chat--fullscreen{width:100vw;max-width:100vw;height:100vh;max-height:100vh;border-radius:0;border:none}
.chat--fullscreen .chat__header{background:rgba(10,10,10,.92);border-bottom:1px solid rgba(255,255,255,.06)}
.chat--fullscreen .chat__form{background:rgba(10,10,10,.92)}

/* ===============================
   Channel picker (опционально)
   =============================== */
body.picker-open{overflow:hidden}
.picker-mask{position:fixed;inset:0;background:rgba(0,0,0,.6);opacity:0;visibility:hidden;transition:.2s;z-index:1000;pointer-events:none}
.picker-mask.is-active{opacity:1;visibility:visible;pointer-events:auto}
.picker{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(12px);transition:.22s;z-index:1100;pointer-events:none}
.picker.is-open{opacity:1;transform:translateY(0);pointer-events:auto}
.picker__panel{width:min(420px,92vw);background:#111;color:#fff;border:1px solid #2a2a2a;border-radius:16px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.5)}
.picker__hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid #222}
.picker__x{background:transparent;color:#fff;border:1px solid #3a3a3a;border-radius:10px;width:36px;height:36px;cursor:pointer}
.picker__body{display:grid;gap:10px;padding:14px}
.picker__btn{display:block;width:100%;text-align:center;padding:14px 16px;border-radius:12px;background:#1a1a1a;color:#fff;border:none;text-decoration:none;cursor:pointer}
.picker__btn:hover,.picker__btn:focus-visible{background:#242424}
html.from-picker .chat__hints,html.from-picker .msg--welcome{display:none!important}

/* ===============================
   Lead modal (опционально)
   =============================== */
body.lead-open{overflow:hidden}
.lead-mask{position:fixed;inset:0;background:rgba(0,0,0,.6);opacity:0;visibility:hidden;transition:.2s;z-index:1200;pointer-events:none}
.lead-mask.is-active{opacity:1;visibility:visible;pointer-events:auto}
.lead-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(12px);transition:.22s;z-index:1210;pointer-events:none}
.lead-modal.is-open{opacity:1;transform:translateY(0);pointer-events:auto}
.lead-modal__panel{width:min(540px,94vw);background:#111;color:#fff;border:1px solid #2a2a2a;border-radius:16px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.55)}
.lead-modal__hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid #222}
.lead-modal__x{background:transparent;color:#fff;border:1px solid #3a3a3a;border-radius:10px;width:36px;height:36px;cursor:pointer}
.lead-modal__form{display:grid;gap:.9rem;padding:14px}
.lead-modal__field{display:grid;gap:.35rem}
.lead-modal__field span{font-size:.9rem;color:var(--color-muted)}
.lead-modal__field input,
.lead-modal__field textarea{
  width:100%;padding:.8rem 1rem;border-radius:12px;border:1px solid #2a2a2a;background:#0f0f0f;color:#fff;outline:none
}
.lead-modal__field input:focus,
.lead-modal__field textarea:focus{border-color:#3a3a3a}
.lead-modal__actions{display:flex;gap:.6rem;justify-content:flex-end;margin-top:.25rem}
.lead-modal__btn{padding:.7rem 1.2rem;border-radius:12px;border:1px solid #2a2a2a;background:#1a1a1a;color:#fff;cursor:pointer}
.lead-modal__submit{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));border:none;color:#121212;font-weight:700}
.lead-modal__cancel{background:#1a1a1a}

/* ===============================
   Toasts
   =============================== */
.toast-stack{position:fixed;right:12px;bottom:12px;display:grid;gap:.6rem;z-index:1400}
.toast{background:#111;color:#fff;border:1px solid #2a2a2a;border-radius:12px;padding:.7rem 1rem;box-shadow:0 10px 24px rgba(0,0,0,.35);max-width:min(92vw,420px)}
.toast--success{border-color:rgba(0,255,128,.28)}
.toast--error{border-color:rgba(255,64,64,.28)}
.toast__title{margin:0 0 .15rem;font-weight:700}
.toast__text{margin:0;color:var(--color-muted);font-size:.95rem}

/* ===============================
   Sticky CTA (мобайл)
   =============================== */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;padding:12px;z-index:900;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.35))}
.sticky-cta__button{display:block;margin:0 auto}

/* ===============================
   Forms (общие)
   =============================== */
input[type="text"],input[type="tel"],input[type="email"],input[type="search"],textarea{
  background:#0f0f0f;border:1px solid #2a2a2a;color:#fff;border-radius:12px;padding:.8rem 1rem;outline:none
}
input:focus,textarea:focus{border-color:#3a3a3a}

/* ===============================
   Animations / Utils
   =============================== */
@keyframes spin{to{transform:rotate(360deg)}}
.spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;animation:spin .9s linear infinite}

/* ===============================
   Footer
   =============================== */
.site-footer{padding:.7rem 0}
.footer-container{
  display:grid;grid-auto-rows:auto;align-content:center;justify-items:center;text-align:center;
  gap:.5rem;padding:.6rem 1rem .8rem;
}
.footer-brand p,.footer-city{margin:0;line-height:1.2}
.footer-nav{list-style:none;display:flex;flex-wrap:wrap;gap:.6rem;padding:0;margin:0}
.footer-nav a{display:inline-flex;align-items:center;line-height:1.2;padding:.2rem .4rem}
@media (min-width:900px){
  .site-footer{padding:.9rem 0}
  /* 3 строки всегда */
  .footer-container{display:grid;grid-auto-rows:auto;align-content:center;justify-items:center;gap:.75rem;padding:.6rem 1.25rem}
  .footer-container > *{grid-column:1 / -1}
  .footer-nav{justify-content:center;gap:.8rem}
}

/* === Chat mobile viewport & safe-area fixes (iOS Safari) === */
:root{
  --vh: 1vh;           /* JS перезапишет по visualViewport */
  --chat-form-h: 56px; /* запасная высота формы */
}

/* Контейнер чата — колонка на всю высоту экрана */
.chat.chat--modal{
  display:flex;
  flex-direction:column;
  height: calc(var(--vh, 1vh) * 100);
  max-height: calc(var(--vh, 1vh) * 100);
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}
@supports (height: 100dvh){
  .chat.chat--modal{ height:100dvh; max-height:100dvh; }
}
@supports (height: 100svh){
  .chat.chat--modal{ height:100svh; max-height:100svh; }
}

/* Сообщения — прокрутка + запас под форму и safe-area */
.chat__messages{
  flex:1 1 auto;
  overflow:auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: calc(env(safe-area-inset-bottom) + var(--chat-form-h));
}

/* Форма — прилипает к низу и не уезжает за адресную строку */
.chat__form{
  position: sticky;
  bottom: 0;
  z-index: 5;
  background: var(--surface, #111);
  border-top: 1px solid var(--color-border, rgba(255,255,255,.12));
  padding-bottom: calc(.5rem + env(safe-area-inset-bottom));
}
.chat__form input[type="search"]{ flex:1 1 auto; min-width:0; }

/* Когда открыта клавиатура — позволяем высоте сжаться до доступной */
.chat.chat--modal.kb-open{
  height:auto;
  max-height:100dvh;
}

/* Не даём флексу «распухнуть» — иначе форма может уехать за край в iOS */
.chat__messages{ min-height:0; }

/* Гасим авто-зум в iOS при фокусе */
.chat__form input,
.chat__form button{ font-size:16px; }

/* === Chat header branding (gold) === */
.chat.chat--modal .chat__header .chat__title{
  color: var(--color-primary, #d4af37) !important;
  font-weight: 800;
}
.chat.chat--modal .chat__close{
  color: var(--color-primary, #d4af37) !important;
  font-weight: 900;
  border-color: rgba(212,175,55,.35);
}
.chat.chat--modal .chat__close:hover,
.chat.chat--modal .chat__close:focus-visible{ filter: brightness(1.08); }

/* === Chat messages: нормальная колонка, компактные интервалы, выравнивание === */
.chat__messages{
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  row-gap:.4rem !important;
  padding-top:0 !important;
  margin-top:0 !important;
  min-height:0 !important;
}
.chat__messages > *{ margin:0 !important; }
.chat__messages > :first-child{ margin-top:0 !important; }
.chat__messages .msg{
  max-width:92%;
  align-self:flex-start;
}
.chat__messages .msg.user,
.chat__messages .msg--user{
  align-self:flex-end;
}
.chat__messages > button,
.chat__messages .chip,
.chat__messages .btn-inline{
  align-self:flex-end;
  margin:0 !important;
}
.chat__messages .msg--welcome{ margin:0 !important; }
