/* Wolf Admin — Premium UI (strict) */
/* No external CSS (no CDN). Compatible with existing bootstrap-like classnames used in templates. */

:root{
  --bg: #f6f9fc;
  --panel: #ffffff;
  --panel-2: #f3f6fb;
  --text: #0a2540;
  --muted: #425466;
  --border: rgba(10,37,64,0.12);
  --border-strong: rgba(10,37,64,0.18);

  --primary: #635bff;
  --primary-2: #4b44d4;
  --success: #16a34a;
  --danger: #df1b41;
  --warning: #d97706;
  --info: #0ea5e9;

  --shadow: 0 1px 2px rgba(10,37,64,0.06), 0 8px 24px rgba(10,37,64,0.10);
  --radius: 14px;
  --radius-sm: 12px;

  --sidebar-w: 280px;
  --sidebar-w-collapsed: 78px;
  --topbar-h: 56px;

  --focus: 0 0 0 3px rgba(99,91,255,0.25);
}

html[data-theme="dark"]{
  --bg: #0b1220;
  --panel: #0f172a;
  --panel-2: #0b1220;
  --text: #e6edf7;
  --muted: #9db0c3;
  --border: rgba(157,176,195,0.20);
  --border-strong: rgba(157,176,195,0.28);

  --primary: #9e97ff;
  --primary-2: #b8b3ff;
  --success: #22c55e;
  --danger: #ff4d6d;
  --warning: #f59e0b;
  --info: #38bdf8;

  --shadow: 0 1px 2px rgba(0,0,0,0.25), 0 18px 44px rgba(0,0,0,0.35);

  --focus: 0 0 0 3px rgba(158,151,255,0.30);
}


*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  background: var(--bg);
  color: var(--text);
}

a{color: var(--primary); text-decoration:none;}
a:hover{color: var(--primary-2);}

.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;}
.text-muted{color: var(--muted) !important;}
.text-danger{color: var(--danger) !important;}
.text-decoration-none{text-decoration:none !important;}
.text-truncate{overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
.w-100{width:100% !important;}
.mb-0{margin-bottom:0 !important;}
.mb-1{margin-bottom:.25rem !important;}
.mb-2{margin-bottom:.5rem !important;}
.mb-3{margin-bottom:1rem !important;}
.mb-4{margin-bottom:1.5rem !important;}
.mt-2{margin-top:.5rem !important;}
.mt-3{margin-top:1rem !important;}
.mt-4{margin-top:1.5rem !important;}
.ms-2{margin-left:.5rem !important;}
.me-2{margin-right:.5rem !important;}
.py-2{padding-top:.5rem !important; padding-bottom:.5rem !important;}

/* ---------- Shell layout ---------- */
.app-shell{
  display:flex;
  min-height:100vh;
}

/* ---------- Sidebar ---------- */
.sidebar{
  width: var(--sidebar-w);
  flex: 0 0 var(--sidebar-w);
  background: var(--panel);
  border-right: 1px solid var(--border);
  height:100vh;
  position: sticky;
  top: 0;
  display:flex;
  flex-direction:column;
  z-index: 60;
}

.sidebar__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:14px 14px;
  border-bottom:1px solid var(--border);
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  color: var(--text);
  font-weight: 800;
  letter-spacing: 0.2px;
}
.brand__mark{
  width: 34px;
  height: 34px;
  border-radius: 11px;
  background: var(--primary);
  color: #fff;
  display:grid;
  place-items:center;
  font-weight: 900;
}
.brand__text{font-size: 14px;}

.sidebar__nav{
  padding: 10px 10px 12px;
  overflow:auto;
}

.nav-section{margin: 8px 0 14px;}
.nav-section__title{
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: var(--muted);
  padding: 8px 10px;
}

.nav-link{
  display:flex;
  align-items:center;
  gap:10px;
  padding: 10px 10px;
  border-radius: 10px;
  color: var(--text);
  border: 1px solid transparent;
}
.nav-link:hover{
  background: color-mix(in srgb, var(--primary) 10%, transparent);
}
html[data-theme="dark"] .nav-link:hover{
  background: color-mix(in srgb, var(--primary) 18%, transparent);
}
.nav-link.active{
  background: color-mix(in srgb, var(--primary) 14%, transparent);
  border-color: color-mix(in srgb, var(--primary) 26%, transparent);
}
html[data-theme="dark"] .nav-link.active{
  background: color-mix(in srgb, var(--primary) 22%, transparent);
  border-color: color-mix(in srgb, var(--primary) 32%, transparent);
}
.nav-ico{
  color: var(--muted);
  width: 22px;
  display:inline-grid;
  place-items:center;
}
.nav-link.active .nav-ico{color: var(--primary);}
.nav-text{font-weight: 650; font-size: 14px;}

.sidebar__footer{
  padding: 12px 12px 14px;
  border-top:1px solid var(--border);
}

.user-card{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--panel-2);
  padding: 10px 10px;
  margin-bottom: 10px;
}
.user-card__name{font-weight: 800; font-size: 14px;}
.user-card__roles{color: var(--muted); font-size: 12px; margin-top: 2px;}

/* Collapsed sidebar (desktop) */
html[data-sidebar-collapsed="1"] .sidebar{
  width: var(--sidebar-w-collapsed);
  flex-basis: var(--sidebar-w-collapsed);
}
html[data-sidebar-collapsed="1"] .brand__text{display:none;}
html[data-sidebar-collapsed="1"] .nav-text{display:none;}
html[data-sidebar-collapsed="1"] .nav-section__title{
  font-size: 10px;
  padding-left: 8px;
}
html[data-sidebar-collapsed="1"] .user-card{display:none;}
html[data-sidebar-collapsed="1"] .sidebar__footer{padding-top: 8px;}
html[data-sidebar-collapsed="1"] .nav-link{justify-content:center;}

/* ---------- Main area ---------- */
.app-main{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
}

.topbar{
  height: var(--topbar-h);
  position: sticky;
  top: 0;
  z-index: 50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 10px 16px;
  background: color-mix(in srgb, var(--panel) 92%, transparent);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(10px);
}
@supports not (background: color-mix(in srgb, white 50%, transparent)){
  .topbar{background: var(--panel);}
}
.topbar__left{display:flex; align-items:center; gap: 12px;}
.topbar__title{display:flex; flex-direction:column; line-height:1.1;}
.topbar__app{font-size:12px; color: var(--muted);}
.topbar__page{font-size:14px; font-weight: 800; color: var(--text);}
.topbar__center{flex:1; display:flex; justify-content:center; min-width:0;}
.topbar__right{display:flex; align-items:center; gap: 8px;}

.content{
  padding: 18px 18px 24px;
  min-width:0;
}

.footer{
  padding: 12px 18px 18px;
  color: var(--muted);
  font-size: 12px;
  display:flex;
  gap: 8px;
  align-items:center;
}
.footer__dot{opacity:.65}

/* ---------- Icon buttons ---------- */
.icon-btn{
  display:inline-grid;
  place-items:center;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--panel);
  color: var(--text);
  cursor:pointer;
}
.icon-btn:hover{border-color: var(--border-strong);}
.icon-btn:focus{outline:none; box-shadow: var(--focus);}
.sidebar__close{display:none;}

/* Theme icons: show only one */
.theme-ico{display:none;}
html[data-theme="dark"] .theme-ico--sun{display:inline;}
html:not([data-theme="dark"]) .theme-ico--moon{display:inline;}

/* ---------- Topbar search ---------- */
.topbar-search{
  max-width: 560px;
  width: 100%;
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--panel);
  min-width: 240px;
}
.topbar-search__ico{color: var(--muted); flex:0 0 auto;}
.topbar-search__input{
  width:100%;
  border:none;
  outline:none;
  background:transparent;
  color: var(--text);
  font-size: 0.95rem;
}
.topbar-search__input::placeholder{color: color-mix(in srgb, var(--muted) 80%, transparent);}

/* ---------- Responsive: mobile sidebar drawer ---------- */
.overlay{
  display:none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.35);
  z-index: 55;
}
@media (max-width: 980px){
  .sidebar{
    position: fixed;
    left: 0;
    top: 0;
    transform: translateX(-104%);
    transition: transform .18s ease;
    box-shadow: var(--shadow);
    z-index: 70;
  }
  .sidebar__close{display:inline-grid;}
  html[data-sidebar-open="1"] .sidebar{transform: translateX(0);}
  html[data-sidebar-open="1"] .overlay{display:block;}
  .topbar__center{display:none;}
}

/* ---------- Cards ---------- */
.card{
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 1px 0 rgba(0,0,0,0.02);
}
.card-header{
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  font-weight: 800;
  display:flex;
  align-items:center;
  gap: 10px;
}
.card-body{padding: 14px;}
.shadow-sm{box-shadow: 0 1px 2px rgba(0,0,0,0.06) !important;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid transparent;
  background: rgba(148,163,184,0.14);
  color: var(--text);
  cursor:pointer;
  text-decoration:none;
  font-weight: 750;
  letter-spacing: 0.1px;
  line-height: 1;
  user-select:none;
}
html[data-theme="dark"] .btn{background: rgba(148,163,184,0.12);}
.btn:hover{filter: brightness(0.98);}
.btn:focus{outline:none; box-shadow: var(--focus);}
.btn:disabled,.btn[disabled]{opacity:.6; cursor:not-allowed;}

.btn-sm{padding: 8px 10px; font-size: 0.9rem; border-radius: 11px;}
.btn-primary{background: var(--primary); color:#fff;}
.btn-primary:hover{background: var(--primary-2);}
.btn-secondary{background: transparent; border-color: var(--border); color: var(--text);}
.btn-secondary:hover{border-color: var(--border-strong);}
.btn-success{background: var(--success); color:#fff;}
.btn-danger{background: var(--danger); color:#fff;}
.btn-warning{background: var(--warning); color:#111827;}

.btn-outline-primary{background: transparent; border-color: color-mix(in srgb, var(--primary) 60%, transparent); color: var(--primary);}
.btn-outline-secondary{background: transparent; border-color: var(--border-strong); color: var(--text);}
.btn-outline-success{background: transparent; border-color: rgba(22,163,74,0.55); color: var(--success);}
.btn-outline-danger{background: transparent; border-color: rgba(220,38,38,0.55); color: var(--danger);}
.btn-outline-light{background: transparent; border-color: rgba(255,255,255,0.45); color:#fff;}

.btn-ghost{
  background: transparent;
  border-color: var(--border);
  color: var(--text);
}
.btn-ghost:hover{border-color: var(--border-strong);}

/* Button groups (quick actions) */
.btn-group{display:inline-flex; gap: 8px; flex-wrap: wrap;}
.btn-group-sm .btn{padding: 7px 9px; font-size: 0.88rem; border-radius: 11px;}

/* ---------- Forms ---------- */
.form-label{display:block; font-size: 0.85rem; color: var(--muted); margin-bottom: 0.35rem;}
.form-text{font-size: 0.85rem; color: var(--muted); margin-top: 0.35rem;}
.form-control,.form-select{
  width:100%;
  padding: 10px 11px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--panel);
  color: var(--text);
}
.form-control:focus,.form-select:focus{outline:none; box-shadow: var(--focus); border-color: color-mix(in srgb, var(--primary) 50%, transparent);}
.form-control-sm,.form-select-sm{padding: 8px 10px; font-size: 0.9rem; border-radius: 11px;}
.input-group{display:flex; gap: 0;}
.input-group > .form-control{border-top-right-radius: 0; border-bottom-right-radius: 0;}
.input-group > .btn{border-top-left-radius: 0; border-bottom-left-radius: 0;}
.form-check{display:flex; align-items:center; gap: 8px;}
.form-check-input{width: 18px; height: 18px;}
.form-check-label{color: var(--text); font-size: 0.95rem;}

/* ---------- Alerts ---------- */
.alert{
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: var(--radius);
  padding: 12px 14px;
}
.alert-success{border-color: rgba(22,163,74,0.35); background: color-mix(in srgb, var(--success) 8%, var(--panel));}
.alert-danger{border-color: rgba(220,38,38,0.35); background: color-mix(in srgb, var(--danger) 8%, var(--panel));}
.alert-warning{border-color: rgba(217,119,6,0.35); background: color-mix(in srgb, var(--warning) 10%, var(--panel));}
.alert-info{border-color: rgba(14,165,233,0.35); background: color-mix(in srgb, var(--info) 10%, var(--panel));}

/* ---------- Badges ---------- */
.badge{
  display:inline-flex;
  align-items:center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: .02em;
}
.text-bg-success{background: color-mix(in srgb, var(--success) 18%, transparent); color: var(--success); border: 1px solid rgba(22,163,74,0.35);}
.text-bg-danger{background: color-mix(in srgb, var(--danger) 18%, transparent); color: var(--danger); border: 1px solid rgba(220,38,38,0.35);}
.text-bg-warning{background: color-mix(in srgb, var(--warning) 18%, transparent); color: var(--warning); border: 1px solid rgba(217,119,6,0.35);}
.text-bg-secondary{background: rgba(148,163,184,0.18); color: var(--muted); border: 1px solid var(--border);}
.text-bg-primary{background: color-mix(in srgb, var(--primary) 18%, transparent); color: var(--primary); border: 1px solid color-mix(in srgb, var(--primary) 40%, transparent);}
.text-bg-light{background: rgba(148,163,184,0.10); color: var(--muted); border: 1px solid var(--border);}

/* ---------- Tables ---------- */
.table-responsive{width:100%; overflow-x:auto;}
.table{
  width:100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow:hidden;
}
.table thead th{
  text-align:left;
  font-size: 0.82rem;
  color: var(--muted);
  letter-spacing: .02em;
  font-weight: 900;
  padding: 12px 12px;
  background: var(--panel-2);
  border-bottom: 1px solid var(--border);
}
.table tbody td{
  padding: 12px 12px;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
.table tbody tr:last-child td{border-bottom:none;}
.table-sm thead th, .table-sm tbody td{padding: 9px 10px;}
.table-striped tbody tr:nth-child(odd){background: color-mix(in srgb, var(--panel-2) 70%, transparent);}
.table-hover tbody tr:hover{background: color-mix(in srgb, var(--primary) 6%, transparent);}
.align-middle td{vertical-align: middle;}
.display-6{font-size: 2rem; font-weight: 900; letter-spacing: -0.02em;}

/* ---------- Pagination ---------- */
.pagination{display:flex; gap: 8px; list-style:none; padding:0; margin: 14px 0 0;}
.page-item{display:block;}
.page-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--panel);
  color: var(--text);
}
.page-link:hover{border-color: var(--border-strong);}
.page-item.disabled .page-link{opacity: .55; pointer-events:none;}
.page-item.active .page-link{border-color: color-mix(in srgb, var(--primary) 45%, transparent); background: color-mix(in srgb, var(--primary) 10%, var(--panel));}

/* ---------- Lists ---------- */
.list-group{display:flex; flex-direction:column; gap: 10px;}
.list-group-item{
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 12px 14px;
}

/* ---------- Simple grid / flex utils (subset) ---------- */
.d-flex{display:flex !important;}
.flex-wrap{flex-wrap:wrap !important;}
.justify-content-between{justify-content:space-between !important;}
.align-items-end{align-items:flex-end !important;}
.align-items-start{align-items:flex-start !important;}
.align-items-center{align-items:center !important;}
.gap-1{gap:.25rem !important;}
.gap-2{gap:.5rem !important;}
.gap-3{gap:1rem !important;}
.g-2{gap:.5rem !important;}
.g-3{gap:1rem !important;}

/* Basic responsive row/cols (works with templates) */
.row{display:flex; flex-wrap:wrap;}
.row.g-2{gap:.5rem;}
.row.g-3{gap:1rem;}
.col-12{width:100%;}
@media (min-width: 768px){
  .col-md-2{width: calc(16.666% - 1rem);}
  .col-md-3{width: calc(25% - 1rem);}
  .col-md-4{width: calc(33.333% - 1rem);}
  .col-md-6{width: calc(50% - 1rem);}
}
@media (min-width: 992px){
  .col-lg-3{width: calc(25% - 1rem);}
  .col-lg-4{width: calc(33.333% - 1rem);}
  .col-lg-5{width: calc(41.666% - 1rem);}
  .col-lg-6{width: calc(50% - 1rem);}
  .col-lg-7{width: calc(58.333% - 1rem);}
}

/* Container (login page) */
.container{margin: 0 auto; padding: 0 16px;}
.bg-light{background: var(--bg);}

/* ---------- Modal ---------- */
.modal{
  position: fixed;
  inset: 0;
  display:none;
  place-items:center;
  background: rgba(0,0,0,0.42);
  z-index: 90;
  padding: 18px;
}
.modal.open{display:grid;}
.modal__panel{
  width: min(520px, 100%);
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--shadow);
  padding: 14px 14px 12px;
}
.modal__title{font-weight: 900; font-size: 1.0rem; margin-bottom: 6px;}
.modal__body{color: var(--muted); line-height: 1.45; margin-bottom: 12px;}
.modal__actions{display:flex; justify-content:flex-end; gap: 10px; flex-wrap:wrap;}

/* ---------- Toasts ---------- */
.toast-stack{
  position: fixed;
  right: 16px;
  bottom: 16px;
  display:flex;
  flex-direction:column;
  gap: 10px;
  z-index: 95;
}
.toast{
  min-width: 260px;
  max-width: 420px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: var(--shadow);
  padding: 10px 12px;
  display:flex;
  gap: 10px;
  align-items:flex-start;
}
.toast__dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  margin-top: 5px;
  background: var(--primary);
}
.toast--success .toast__dot{background: var(--success);}
.toast--danger .toast__dot{background: var(--danger);}
.toast--warning .toast__dot{background: var(--warning);}
.toast__text{color: var(--text); line-height: 1.35; font-weight: 650;}
.toast__sub{color: var(--muted); font-weight: 600; font-size: 0.85rem; margin-top: 2px;}

/* ---------- HR ---------- */
hr{border:0; border-top: 1px solid var(--border); margin: 14px 0;}

/* ---------- Stripe-like components (v2) ---------- */
.h1{font-size:22px; margin:0; font-weight:850; letter-spacing:-0.01em;}
.page-head{display:flex; align-items:flex-end; justify-content:space-between; gap:12px; flex-wrap:wrap; margin: 2px 0 14px;}
.head-actions{display:flex; gap:10px; align-items:center; flex-wrap:wrap;}
.breadcrumbs{font-size:12px; color: var(--muted); margin-bottom:6px;}
.breadcrumbs a{color: var(--muted);}
.breadcrumbs a:hover{color: var(--text);}
.breadcrumbs__sep{margin:0 6px; opacity:0.7;}
.head-title{display:flex; align-items:center; gap:10px;}
.head-sub{font-size:13px; margin-top:6px;}
.dot{margin:0 8px; opacity:0.6;}

.grid{display:grid; gap:14px;}
.grid--2{grid-template-columns: 360px 1fr;}
@media (max-width: 980px){ .grid--2{grid-template-columns: 1fr;} }

.p-0{padding:0 !important;}
.table-wrap{width:100%; overflow:auto;}

.card-header--between{display:flex; align-items:center; justify-content:space-between;}

.pill{display:inline-flex; align-items:center; gap:6px; padding:5px 10px; border-radius:999px; font-size:12px; font-weight:700; border:1px solid var(--border); background: var(--panel);}
.pill--success{background: color-mix(in srgb, var(--success) 14%, transparent); border-color: color-mix(in srgb, var(--success) 35%, transparent); color: var(--success);}
.pill--info{background: color-mix(in srgb, var(--info) 14%, transparent); border-color: color-mix(in srgb, var(--info) 35%, transparent); color: var(--info);}
.pill--muted{background: color-mix(in srgb, var(--muted) 10%, transparent); border-color: color-mix(in srgb, var(--muted) 20%, transparent); color: var(--muted);}

.segmented{display:inline-flex; padding:4px; border:1px solid var(--border); border-radius:999px; background: var(--panel);}
.segmented__item{padding:7px 12px; border-radius:999px; color: var(--muted); font-weight:700; font-size:13px;}
.segmented__item:hover{background: color-mix(in srgb, var(--primary) 8%, transparent); color: var(--text);}
.segmented__item.active{background: color-mix(in srgb, var(--primary) 16%, transparent); color: var(--primary);}

.kv{display:flex; flex-direction:column; gap:10px;}
.kv__row{display:flex; align-items:flex-start; justify-content:space-between; gap:12px;}
.kv__k{font-size:12px; color: var(--muted);}
.kv__v{font-size:13px; font-weight:700; text-align:right;}

.divider{height:1px; background: var(--border); margin:14px 0;}
.hint{font-size:12px; line-height:1.4;}

.callout{border:1px solid var(--border); border-radius: var(--radius); padding:12px; background: color-mix(in srgb, var(--panel-2) 70%, transparent); margin-top:12px;}
.callout__title{font-weight:800; margin-bottom:4px;}
.callout__text{font-size:13px; color: var(--muted); line-height:1.4;}
.callout--warn{border-color: color-mix(in srgb, var(--warning) 40%, transparent); background: color-mix(in srgb, var(--warning) 10%, transparent);}

.empty{padding:18px 6px; text-align:center;}
.empty__title{font-weight:900; font-size:16px;}
.empty__text{margin-top:6px; font-size:13px;}
.empty__actions{margin-top:12px;}

.chat-card{display:flex; flex-direction:column; min-height:480px;}
.chat-body{flex:1; overflow:auto; padding:14px 14px;}
.chat{display:flex; flex-direction:column; gap:12px;}

.msg{display:flex; flex-direction:column; gap:6px; max-width:820px;}
.msg--admin{align-self:flex-end;}
.msg--user{align-self:flex-start;}

.msg__meta{display:flex; align-items:center; justify-content:space-between; gap:12px; font-size:12px; color: var(--muted);}
.msg__who{display:flex; align-items:center; gap:8px;}
.msg__time{white-space:nowrap;}

.msg__bubble{border:1px solid var(--border); border-radius:14px; padding:10px 12px; background: var(--panel);}
.msg--admin .msg__bubble{background: color-mix(in srgb, var(--primary) 10%, var(--panel)); border-color: color-mix(in srgb, var(--primary) 24%, transparent);}
.msg--admin .msg__meta{justify-content:flex-end;}
.msg__text{white-space:pre-wrap; font-size:14px; line-height:1.45; color: var(--text);}

.msg__media{margin-top:10px; border-top:1px dashed var(--border); padding-top:10px; font-size:13px;}

.chat-footer{padding:12px 12px; border-top:1px solid var(--border); background: var(--panel-2);}
.chat-form{display:flex; flex-direction:column; gap:10px;}
.chat-input{min-height:84px; resize:vertical;}

.quick-replies{display:flex; gap:8px; flex-wrap:wrap;}
.chip{border:1px solid var(--border); background: var(--panel); padding:6px 10px; border-radius:999px; font-size:12px; color: var(--muted); cursor:pointer;}
.chip:hover{border-color: var(--border-strong); color: var(--text); background: color-mix(in srgb, var(--primary) 6%, var(--panel));}

.chat-actions{display:flex; align-items:center; gap:12px; flex-wrap:wrap;}
.chat-actions__spacer{flex:1;}

.check{display:flex; align-items:center; gap:8px; font-size:12px; color: var(--muted);}
.check input{accent-color: var(--primary);}
