@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,300;0,400;0,500;1,500&display=swap');

body{
    font-family: "Poppins", sans-serif;
}
/* ==========================================================
   Admin console (white UI)
   - Layout: left sidebar + main content
   - Self-contained so it's easy to extend
   ========================================================== */

/* Ensure the admin view can use 100% height of the fixed #app shell */
#app[data-page="admin"] .app-sheet{
  height: 100%;
}

.admin-page{
  /* Fill available app viewport (from below fixed topbar to bottom)
     #app already defines height: calc(100vh - var(--topbar-h))
  */
  height: 100%;
  width: 100%;
  padding: 18px;
  display: flex;
  align-items: stretch;
}

.admin-shell{
  display: grid;
  grid-template-columns: 260px minmax(0,1fr);
  gap: 18px;
  width: 100%;
  height: 100%;
}

.admin-nav{
  background: #fff;
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.08);
  height: 100%;
  overflow: auto;
}

.admin-nav-title{
  font-weight: 800;
  font-size: 18px;
  margin-bottom: 10px;
  color: #111;
}

.admin-nav a{
  display: block;
  padding: 10px 12px;
  border-radius: 12px;
  color: #111;
  text-decoration: none;
  border: 1px solid transparent;
  margin: 2px 0;
}

.admin-nav a:hover{
  background: rgba(0,0,0,0.04);
}

.admin-nav a.active{
  background: rgba(0,0,0,0.06);
  border-color: rgba(0,0,0,0.10);
  font-weight: 700;
}

.admin-sep{
  height: 1px;
  background: rgba(0,0,0,0.10);
  margin: 12px 0;
}

.admin-content{
  background: #fff;
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.08);
  height: 100%;
  overflow: auto;
}

/* Compact row actions as a dropdown menu */
.admin-menu{
  position: relative;
  display: inline-flex;
}

.admin-menu-btn{
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.admin-menu-list{
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 190px;
  padding: 8px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.12);
  box-shadow: 0 14px 40px rgba(0,0,0,0.12);
  display: none;
  z-index: 10;
}

.admin-menu.is-open .admin-menu-list{
  display: block;
}

.admin-menu-item{
  width: 100%;
  display: flex;
  justify-content: flex-start;
  text-align: left;

  padding: 9px 10px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.10);
  background: rgba(0,0,0,0.02);
  color: #111;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}

.admin-menu-item:hover{
  background: rgba(0,0,0,0.05);
  border-color: rgba(0,0,0,0.16);
}

.admin-menu-sep{
  height: 1px;
  background: rgba(0,0,0,0.10);
  margin: 8px 6px;
}

.admin-menu-item-warn{
  border-color: rgba(180, 120, 0, 0.28);
}

.admin-menu-item-danger{
  border-color: rgba(180, 0, 0, 0.28);
}

.admin-menu-item + .admin-menu-item{
  margin-top: 6px;
}

.admin-head{
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.admin-head h1{
  margin: 0;
  color: #111;
  font-size: 22px;
  font-weight: 800;
}

.admin-sub{
  color: rgba(0,0,0,0.64);
  font-size: 13px;
}

.admin-grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.admin-card{
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 16px;
  padding: 12px 12px;
  background: rgba(0,0,0,0.015);
}

.admin-card-label{
  font-size: 12px;
  color: rgba(0,0,0,0.62);
  margin-bottom: 6px;
}

.admin-card-value{
  font-size: 24px;
  font-weight: 900;
  color: #111;
}

.admin-panel{
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 16px;
  padding: 14px;
  background: rgba(0,0,0,0.01);
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

/* Users: quick stats */
.admin-stats{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}
.admin-stat{
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 14px;
  padding: 10px 12px;
  background: rgba(0,0,0,0.01);
}
.admin-stat .k{
  font-size: 12px;
  color: rgba(0,0,0,0.62);
}
.admin-stat .v{
  font-size: 20px;
  font-weight: 900;
  color: #111;
  margin-top: 2px;
}

.admin-small{
  font-size: 12px;
  color: rgba(0,0,0,0.72);
  white-space: nowrap;
}

.admin-panel-title{
  font-weight: 800;
  color: #111;
  margin-bottom: 4px;
}

.admin-muted{
  color: rgba(0,0,0,0.62);
  font-size: 12px;
}

.admin-row{
  margin-top: 10px;
}

.admin-toolbar{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: flex-end;
  margin-bottom: 12px;
}

.admin-field{
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 180px;
}

.admin-field label{
  font-size: 12px;
  color: rgba(0,0,0,0.62);
}

.admin-field input,
.admin-field select{
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.14);
  background: #fff;
  color: #111;
  outline: none;
}

.admin-field input:focus,
.admin-field select:focus{
  border-color: rgba(0,0,0,0.26);
}

.admin-actions{
  display: flex;
  gap: 10px;
  align-items: center;
}

/* When actions sit alongside labeled fields, align buttons to the bottom edge */
.admin-actions-bottom{
  align-items: flex-end;
  padding-top: 18px;
}

/* Checkbox row cards (used in Site settings) */
.admin-check{
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,0.10);
  background: rgba(0,0,0,0.015);
  cursor: pointer;
  user-select: none;
}

.admin-row-actions{
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: nowrap;
}

.admin-row-actions .admin-btn{
  white-space: nowrap;
}

.admin-subpanel{
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 16px;
  padding: 12px;
  background: rgba(0,0,0,0.01);
}


.admin-check:hover{
  background: rgba(0,0,0,0.03);
}

.admin-check input{
  width: 18px;
  height: 18px;
  margin-top: 2px;
}

/* Links inside tables */
.admin-link{
  color: #111;
  text-decoration: none;
}
.admin-link:hover{
  text-decoration: underline;
}

/* Thumbnail hover preview */
.admin-thumb{
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.admin-thumb-name{
  font-weight: 800;
  font-size: 12px;
  color: #111;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.10);
  background: rgba(0,0,0,0.02);
}

.admin-thumb-tip{
  position: absolute;
  left: 0;
  top: calc(100% + 8px);
  width: 260px;
  padding: 8px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.12);
  box-shadow: 0 14px 40px rgba(0,0,0,0.12);
  display: none;
  z-index: 12;
}

.admin-thumb-tip img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.08);
}

.admin-thumb:hover .admin-thumb-tip{
  display: block;
}

.admin-btn{
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.14);
  background: rgba(0,0,0,0.03);
  color: #111;
  font-weight: 700;
  cursor: pointer;
}

.admin-btn:hover{
  background: rgba(0,0,0,0.06);
}

.admin-btn-ghost{
  background: transparent;
}

.admin-btn-small{
  padding: 7px 10px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 12px;
}

.admin-btn-warn{
  border-color: rgba(180, 120, 0, 0.35);
}

.admin-btn-danger{
  border-color: rgba(180, 0, 0, 0.35);
}

.admin-table-wrap{
  overflow: auto;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.10);
  background: #fff;
  margin-top: 10px;
  flex: 1 1 auto;
  min-height: 0;
}

.admin-table{
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.admin-table th,
.admin-table td{
  padding: 10px 10px;
  border-bottom: 1px solid rgba(0,0,0,0.08);
  text-align: left;
  vertical-align: top;
  color: #111;
}

.admin-table th{
  font-size: 12px;
  color: rgba(0,0,0,0.62);
  background: rgba(0,0,0,0.02);
  position: sticky;
  top: 0;
  z-index: 1;
}

.admin-empty{
  color: rgba(0,0,0,0.60);
  text-align: center;
  padding: 18px 10px !important;
}

.admin-row-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.admin-pill{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.12);
  background: rgba(0,0,0,0.03);
  font-size: 12px;
  font-weight: 800;
}

.admin-pill-warn{
  border-color: rgba(180, 120, 0, 0.28);
  background: rgba(180, 120, 0, 0.06);
}

.admin-wrap{
  max-width: 360px;
  word-break: break-word;
  color: rgba(0,0,0,0.74);
}

.admin-usercell-main{
  font-weight: 800;
}

.admin-log{
  background: #0b0b0b;
  color: #f2f2f2;
  border-radius: 14px;
  padding: 12px;
  overflow: auto;
  min-height: 420px;
  border: 1px solid rgba(0,0,0,0.18);
}

@media (max-width: 1100px){
  .admin-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

@media (max-width: 820px){
  .admin-shell{ grid-template-columns: 1fr; }
  .admin-nav{ position: relative; }
  .admin-page{ padding: 14px; }
}


/* ---------------------------
   Admin thumbnails cleaner
   --------------------------- */
.admin-thumb-row{
  display:flex;
  align-items:center;
  gap:10px;
}
.admin-thumb-mini{
  width: 54px;
  height: 34px;
  border-radius: 10px;
  overflow:hidden;
  border: 1px solid rgba(0,0,0,0.10);
  background: #f6f6f6;
  flex: 0 0 auto;
}
.admin-thumb-mini img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
.admin-thumb-fn{
  font-weight: 700;
  color:#111;
  line-height:1.1;
}

/* Confirm overlay */
.admin-confirm-overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.40);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index: 300000;
  padding: 18px;
}
.admin-confirm-overlay[hidden]{display:none !important;}
.admin-confirm-card{
  width: min(520px, 100%);
  background: #fff;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,0.12);
  box-shadow: 0 20px 60px rgba(0,0,0,0.22);
  padding: 16px;
}
.admin-confirm-title{
  font-size: 18px;
  font-weight: 800;
  color:#111;
  margin-bottom: 10px;
}
.admin-confirm-body{
  color:#222;
  font-size: 14px;
  margin-bottom: 14px;
}
.admin-confirm-actions{
  display:flex;
  justify-content:flex-end;
  gap: 10px;
}
.admin-btn-danger{
  background:#e02020;
  color:#fff;
  border-color: rgba(0,0,0,0.10);
}
.admin-btn-danger:hover{
  filter: brightness(0.95);
}
.admin-warn{
  border: 1px solid rgba(224,32,32,0.25);
  background: rgba(224,32,32,0.08);
  color: #7a1212;
  padding: 10px 12px;
  border-radius: 12px;
}


/* Mail UI helpers */
.admin-textarea{
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.14);
  background: #fff;
  color: #111;
  outline: none;
  resize: vertical;
  font-family: inherit;
}

.admin-textarea:focus{
  border-color: rgba(0,0,0,0.26);
}

.admin-inline{
  display: flex;
  gap: 10px;
  align-items: center;
}

.admin-inline input{
  flex: 1;
}

.admin-kpi{
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.14);
  background: rgba(0,0,0,0.03);
  color: #111;
}

.admin-panel code{
  background: rgba(0,0,0,0.06);
  padding: 2px 6px;
  border-radius: 8px;
  font-size: 12px;
}


/* Floating UI (dropdowns + thumbnail previews) are portaled to <body> via JS to avoid being clipped by scroll containers */
body.admin-float-ui .admin-thumb-tip{ display:none !important; }
body.admin-float-ui .admin-menu-list{ display:none !important; }

.admin-float-thumb{
  position: fixed;
  width: 260px;
  padding: 8px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.12);
  box-shadow: 0 14px 40px rgba(0,0,0,0.12);
  z-index: 300005;
  pointer-events: none;
}
.admin-float-thumb[hidden]{ display:none !important; }
.admin-float-thumb img{
  width: 100%;
  height: auto;
  display:block;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.08);
}

.admin-float-menu{
  position: fixed;
  min-width: 190px;
  padding: 8px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.12);
  box-shadow: 0 14px 40px rgba(0,0,0,0.12);
  z-index: 300006;
}
.admin-float-menu[hidden]{ display:none !important; }
.admin-float-menu .admin-menu-item{ width:100%; }

/* -------------------------
   New user defaults editor
   ------------------------- */
.admin-seed-editor{
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* Keep the top action buttons compact and on the same line */
.admin-seed-actions{
  flex-wrap: wrap;
}
.admin-seed-actions .admin-btn{
  width: auto;
  flex: 0 0 auto;
}

.admin-seed-toolbar{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.admin-seed-tab{
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 16px;
  background: #fff;
  padding: 12px;
}

/* More obvious separation between tabs */
.admin-seed-tab + .admin-seed-tab{
  margin-top: 16px;
  position: relative;
}
.admin-seed-tab + .admin-seed-tab:before{
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  top: -9px;
  border-top: 1px dashed rgba(0,0,0,0.16);
}

.admin-seed-tab-head{
  display: flex;
  align-items: flex-end;
  gap: 12px;
  flex-wrap: nowrap;
}

.admin-seed-tab-namewrap{
  flex: 1 1 340px;
  min-width: 260px;
}

.admin-seed-label{
  font-size: 12px;
  color: rgba(0,0,0,0.62);
  margin: 0 0 6px;
}

/* Match the admin-field input styling so it doesn't look "unstyled" */
.admin-seed-input{
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.14);
  background: #fff;
  color: #111;
  outline: none;
  min-width: 0;
}
.admin-seed-input:focus{
  border-color: rgba(0,0,0,0.26);
}

.admin-seed-tab-actions{
  display: flex;
  gap: 8px;
  flex: 0 0 auto;
  white-space: nowrap;
}

.admin-seed-tiles{
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 12px;
}

.admin-seed-tile-head{
  display: grid;
  grid-template-columns: 220px minmax(280px, 1fr) 180px auto;
  gap: 10px;
  align-items: end;
  font-size: 12px;
  color: rgba(0,0,0,0.62);
  padding: 0 10px;
}

.admin-seed-tile{
  padding: 10px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.10);
  background: rgba(0,0,0,0.01);
}

/* Clearer separation between tiles */
.admin-seed-tile + .admin-seed-tile{
  box-shadow: 0 -1px 0 rgba(0,0,0,0.06) inset;
}

.admin-seed-tile-grid{
  display: grid;
  grid-template-columns: 220px minmax(280px, 1fr) 180px auto;
  gap: 10px;
  align-items: end;
}

.admin-seed-tile-actions{
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

@media (max-width: 980px){
  .admin-seed-tab-head{ flex-wrap: wrap; }
  .admin-seed-tile-head{ display:none; }
  .admin-seed-tile-grid{
    grid-template-columns: 1fr;
  }
  .admin-seed-tile-actions{
    justify-content: flex-start;
  }
}


/* -------------------------
   Theme editor
   ------------------------- */
.admin-theme-actions{
  gap: 10px;
  flex-wrap: wrap;
}
.admin-theme-actions .admin-btn{
  width: auto;
  min-width: 0;
  padding-left: 14px;
  padding-right: 14px;
}

.admin-theme-grid{
  grid-template-columns: repeat(2, minmax(240px, 1fr));
}

.admin-inline{
  display: flex;
  align-items: center;
  gap: 10px;
}
.admin-inline input[type="color"]{
  width: 44px;
  height: 36px;
  padding: 0;
  border-radius: 10px;
}

.admin-theme-preview{
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.14);
  min-height: 220px;
}
.admin-theme-preview-bg{
  position: absolute;
  inset: 0;
  background-color: var(--site-bg-color, #0b1220);
  background-image: var(--site-bg-image, none);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
.admin-theme-preview-card{
  position: relative;
  margin: 18px;
  padding: 16px;
  border-radius: 16px;
  background: var(--panel-bg, rgba(255,255,255,0.06));
  border: 1px solid var(--panel-border, rgba(255,255,255,0.14));
  color: var(--site-text, rgba(255,255,255,0.92));
  backdrop-filter: blur(var(--panel-blur, 10px));
}

.admin-theme-preview-popup{
  position: absolute;
  right: 18px;
  bottom: 18px;
  width: 220px;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid var(--popup-border, rgba(255,255,255,0.14));
  background: var(--popup-bg, rgba(255,255,255,0.06));
  color: var(--popup-text, var(--site-text, rgba(255,255,255,0.92)));
  backdrop-filter: blur(var(--popup-blur, 10px));
  -webkit-backdrop-filter: blur(var(--popup-blur, 10px));
  box-shadow: 0 18px 55px rgba(0,0,0,0.35);
}

.admin-theme-preview-pop-title{
  font-weight: 800;
  margin-bottom: 6px;
}

.admin-theme-preview-pop-text{
  color: var(--popup-text-muted, var(--site-text-muted, rgba(255,255,255,0.72)));
  font-size: 12px;
  line-height: 1.35;
}
.admin-theme-preview-title{
  font-weight: 700;
  margin-bottom: 8px;
}
.admin-theme-preview-text{
  color: var(--site-text-muted, rgba(255,255,255,0.72));
  margin-bottom: 12px;
}
.admin-theme-preview-actions{
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.admin-theme-preview-link{
  color: var(--site-accent, #7dd3fc);
  text-decoration: none;
}
.admin-theme-preview-link:hover{
  text-decoration: underline;
}

@media (max-width: 900px){
  .admin-theme-grid{
    grid-template-columns: 1fr;
  }
}


/* -------------------------
   RGBA picker modal
   ------------------------- */
.admin-rgba-inline input[type="text"]{
  flex: 1 1 auto;
  min-width: 220px;
}
.admin-rgba-btn{
  width: auto !important;
  min-width: 0 !important;
  padding-left: 14px;
  padding-right: 14px;
  white-space: nowrap;
}

.rgba-modal{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}
.rgba-modal.is-open{
  display: block;
}
.rgba-modal-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(3px);
}
.rgba-modal-card{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(560px, calc(100vw - 24px));
  border-radius: 18px;
  background: rgba(255,255,255,1);
  border: 1px solid rgba(0,0,0,0.14);
  box-shadow: 0 18px 60px rgba(0,0,0,0.55);
  overflow: hidden;
	color: #000000;
}
.rgba-modal-head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
.rgba-modal-title{
  font-weight: 700;
}
.rgba-modal-close{
  background: transparent;
  border: 0;
  color: rgba(255,255,255,0.85);
  font-size: 22px;
  line-height: 1;
  padding: 6px 10px;
  cursor: pointer;
  border-radius: 10px;
}
.rgba-modal-close:hover{
  background: rgba(255,255,255,0.06);
}
.rgba-modal-body{
  padding: 14px 16px 10px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.rgba-modal-row{
  display: grid;
  grid-template-columns: 90px 1fr auto;
  gap: 10px;
  align-items: center;
}
.rgba-modal-row label{
  color: #000000;
  font-size: 13px;
}
.rgba-modal-row input[type="range"]{
  width: 100%;
}
.rgba-modal-num{
  width: 86px;
}
.rgba-modal-preview{
  display: grid;
  grid-template-columns: 1fr 120px;
  gap: 12px;
  align-items: center;
}
.rgba-modal-preview-box{
  height: 64px;
  border-radius: 14px;
  border: 1px solid #000000;
  background: repeating-conic-gradient(rgba(255,255,255,0.12) 0% 25%, rgba(0,0,0,0.12) 0% 50%) 0/20px 20px;
  position: relative;
  overflow: hidden;
}
.rgba-modal-preview-swatch{
  position: absolute;
  inset: 0;
}
.rgba-modal-out{
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.rgba-modal-out input[type="text"]{
  width: 100%;
}
.rgba-modal-foot{
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  padding: 12px 16px 14px;
  border-top: 1px solid rgba(255,255,255,0.10);
}

@media (max-width: 520px){
  .rgba-modal-row{
    grid-template-columns: 70px 1fr auto;
  }
  .rgba-modal-num{
    width: 70px;
  }
  .rgba-modal-preview{
    grid-template-columns: 1fr;
  }
}


/* Sessions agent icons */
.admin-agent-cell{
  width: 180px;
}
.admin-agent-icons{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.admin-agent-icon{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.10);
  background: rgba(0,0,0,0.03);
  color: #111;
  font-size: 18px;
  line-height: 1;
  cursor: default;
}
.admin-agent-icon:hover{
  background: rgba(0,0,0,0.06);
}
.admin-agent-icon[data-tip]:hover::after{
  content: attr(data-tip);
  position: absolute;
  left: 50%;
  top: calc(100% + 10px);
  bottom: auto;
  transform: translateX(-50%);
  min-width: 140px;
  max-width: 320px;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(17,17,17,0.96);
  color: #fff;
  font-size: 12px;
  line-height: 1.35;
  white-space: pre-line;
  box-shadow: 0 10px 24px rgba(0,0,0,0.18);
  z-index: 2000;
}
.admin-agent-icon[data-tip]:hover::before{
  content: '';
  position: absolute;
  left: 50%;
  top: calc(100% + 2px);
  bottom: auto;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-bottom-color: rgba(17,17,17,0.96);
  z-index: 2001;
}
.admin-btn, .admin-btn:visited{
  color: #111;
}
.admin-btn.admin-btn-danger{
  color: #111;
}
