/* Unobits — styles.css*/
@font-face {
  font-family: 'DM Sans';
  /* Adjust path if your fonts folder is elsewhere, e.g., '../fonts/DMSans.ttf' */
  src: url('assets/fonts/DMSans.ttf') format('truetype');
  font-weight: 100 1000;
  font-style: normal;
  font-display: swap;
}

:root {
  --bg: #040404;
  --panel: radial-gradient(circle at top left, color-mix(in srgb, var(--primary, #7c5cff) 10%, transparent), transparent 48%),    linear-gradient(180deg, color-mix(in srgb, var(--bg, rgba(255,255,255,.04)) 95%, transparent), color-mix(in srgb, var(--bg, rgba(255,255,255,.04)) 84%, transparent));
  --surface: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.1'/%3E%3C/svg%3E");
  --side: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
  --pans: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
  --blend: hard-light;
  --muted: #181818;
  --text: #e5e7eb;
  --text-muted: #9aa3af;
  --primary: #00d4ff;
  /* users' theme */
  --success: #10b981;
  --warning: #f59e0b;
  --danger: red;
  --radius: 15px;
  --shadow: 1px 3px 20px 1px rgb(10 10 10);
  --ring: 0 0 4px 0px var(--text-muted);
  --space-2: 5px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --line: 1px solid rgba(255, 255, 255, .08);
  --shadow: 2px 2px 5px 0px rgba(255, 255, 255, 0.09);
  --ui-border-subtle: rgba(255, 255, 255, .10);
  --ui-border-strong: rgba(255, 255, 255, .16);
  --ui-surface-soft: rgba(255, 255, 255, .045);
  --ui-surface-raised: rgba(255, 255, 255, .065);
  --ui-control-radius: 15px;
  --ui-card-radius: 18px;
  --ui-motion-fast: 160ms;
  --ui-motion-med: 240ms;
  --dots: rgba(255, 255, 255, 0.144);
  --strans: rgba(255, 255, 255, .05);
  --btrans: rgba(0, 0, 0, .2);
  --btn-bg: red;
  --btn-color: white;
  --bgblur: rgba(255, 255, 255, 0.3);
  --backdrop: blur(3px) brightness(0.5);
  --backdrop-2: blur(6px) brightness(0.5);
  --route-child-in-ms: 300ms;
  --route-child-out-ms: 300ms;
  --route-main-in-ms: 520ms;
  --route-main-out-ms: 260ms;
  --route-transition-ease: cubic-bezier(.16,1,.3,1);
  --route-transition-ease-out: cubic-bezier(.4,0,.2,1);
  --route-main-seed-radius: 28px;
  --route-main-full-radius: 1400px;
  --route-main-start-scale: .62;
  --route-main-mid-scale: .92;
  --route-main-blur-in: 14px;
  --route-main-blur-out: 10px;
}

html[data-theme="light"] {
  --bg: #ffffff;
  --surface: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
  --pans: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
  --blend: unset;
  --muted: #b4b4b4;
  --text: #0d0e0e;
  --text-muted: #475569;
  --line: 1px solid rgba(0, 0, 0, .09);
  --shadow: 1px 2px 5px 2px rgba(0, 0, 0, .15);
  --ui-border-subtle: rgba(0, 0, 0, .10);
  --ui-border-strong: rgba(0, 0, 0, .16);
  --ui-surface-soft: rgba(0, 0, 0, .035);
  --ui-surface-raised: rgba(255, 255, 255, .72);
  --dots: rgba(0, 0, 0, 0.199);
  --strans: rgba(0, 0, 0, 0.05);
  --btrans: rgba(255, 255, 255, .01);
  --btn-bg: white;
  --btn-color: red;
  --bgblur: rgba(0, 0, 0, 0.5);
  --backdrop: blur(3px) brightness(0.95);
  --backdrop-2: blur(6px) brightness(.95);
}

/* High contrast tweak */
html[data-contrast="high"] {
  --line: 1px solid rgba(255, 255, 255, .15);
  --btn-shadow: 0 0 4px 1px #ccc8;
  --surface: #000000;
  --shadow: -2px 1px 5px 1px rgb(104 102 102 / 20%);
  --text: #fff;
  --text-muted: #e5e7eb;
}

html[data-theme="light"][data-contrast="high"] {
  --line: 1px solid rgba(0, 0, 0, .15);
  --btn-shadow: 0 0 4px 1px #262222;
  --shadow: 0 10px 10px rgba(0, 0, 0, .28);
  --surface: #ffffff;
  --bg: #f5f5f5;
  --text: #000;
  --text-muted: #111827;
}

html {
  height: 100%;
  background: transparent;
  color: var(--text);
  margin: 0;
  padding: 0;
  font-family: 'DM Sans', 'Poppins', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Global Webkit Scrollbar */
::-webkit-scrollbar {
  width: 5px;
  height: 5px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: transparent;
  opacity: 0;
  border-radius: 20px;
}

::-webkit-scrollbar-button:single-button{
  width: 10px;
  height: 10px;
  background: transparent !important;
}

.sb-hover::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--primary-faded), var(--primary-dark)) ;
  opacity: 1;
}

body {
  background: var(--bg);
  height: 100%;
}

* {
  box-sizing: border-box;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
select,
textarea {
  font: inherit;
  color: var(--text);
  border: none;
  background: transparent;
  padding: 2px;
  border-radius: 5px;
}

input[type="checkbox" i] {
  accent-color: var(--primary) !important;
}

textarea {
  resize: none;
  width: auto;
}

button {
  cursor: pointer;
}

input::placeholder,
textarea::placeholder {
  left: 3px;
  color: var(--text-muted);
}

hr {
  border: none;
  border-top: var(--line);
}

svg {
  outline: none;
}

.icon {
  width: 18px;
  height: 18px;
  fill: var(--text);
}

span.file-name.truncate {
  text-overflow: ellipsis;
  text-wrap-mode: nowrap;
  width: 60px;
  overflow: hidden;
}

.belt-btn i {
  pointer-events: none;
}

/* Density */
html[data-density="comfortable"] {
  --mar: 3px;
  --pad: 12px;
  --nbtnw: 55px;
  --gap: 12px;
  --h: 35px;
  --text-size: 14px;
}

html[data-density="cozy"] {
  --mar: 4px;
  --pad: 10px;
  --nbtnw: 47px;
  --gap: 10px;
  --h: 30px;
  --text-size: 12px;
}

html[data-density="compact"] {
  --mar: 5px;
  --pad: 8px;
  --nbtnw: 50px;
  --gap: 8px;
  --h: 28px;
  --text-size: 10px;
}

body {
  font-size: var(--text-size);
  margin: 0;
  padding: 0;
  overflow: clip;
}

/* ANIMATED RADIAL MESH */
.app-shell.wp-gradient {
  background-color: var(--bg, #1a1a1a);
  filter: none;
  opacity: 1;
  transition: background .5s ease, background-color .5s ease, color .5s ease, border .5s ease, box-shadow .5s ease;
}


.app-shell {
  background: var(--bg);
  transition: background .5s ease, background-color .5s ease, color .5s ease, border .5s ease, box-shadow .5s ease;
}

body::before {
  content: none;
}

/* Top App Bar */
.topbar {
  position: relative;
  top: 0;
  z-index: 20;
  display: grid;
  grid-template-columns: 1fr 3fr 1fr;
  align-items: center;
  gap: var(--gap);
  padding: 5px 5px;
  height: 45px;
  width: 100%;
  /* border-bottom: var(--line); */
  justify-content: space-between;
}

.topbar .left,
.topbar .centre,
.topbar .right {
  display: flex;
  gap: 5px;
  align-items: center;
}

.centre {
  justify-content: center;
  flex: 1;
}

.logo {
  scale: 1;
  transition: scale 0.5s ease-out;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-radius: 25px;
  cursor: pointer;
  user-select:none;
}

.logo:hover {
  background: rgba(255, 255, 255, .04);
}

.logo-mark {
  font-weight: 800;
  border-radius: 8px;
  width: 26px;
  height: 26px;
  display: block;
  fill: var(--primary-dark);
  transition: fill .2s ease;
}

.logo-text{
  font-size: 15px;
  font-weight: 700;
  width: 100%;
  align-self: end;
  padding-bottom: 5px;
}

@media (max-width: 700px) {
  .topbar .logo .logo-text {
    display: none !important;
  }
}

.icon-btn {
  width: var(--h);
  height: var(--h);
  border-radius: 20px;
  display: grid;
  place-items: center;
  background: var(--strans);
  justify-content: center;
  z-index: 5;
  padding-inline: revert-layer;
}

.icon-btn:hover {
  outline: var(--line);
}

/* Toggle state (used for "Star Donna" and other pressed icon buttons) */
.icon-btn.on {
  outline: var(--ring);
}

.icon-btn svg {
  width: 18px;
  height: 18px;
  fill: var(--text);
  display: flex;
}

.icon-btn.sm {
  width: 25px;
  height: 25px;
}

.icon-btn-notif, #btnAddons, #btnSettings {
  position: relative;
  height: 30px;
  width: 30px;
  padding: 0;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--strans);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.icon-btn-notif svg {
  color: var(--text-muted);
  fill: currentColor;
  transition: color .2s ease-in-out, fill .2s ease-in-out;
  height: 18px;
  width: 18px;
  line-height: 1;
  font-size: 17px;
}

.icon-btn-notif:hover,
.icon-btn-notif:focus-visible {
  border-color: rgba(255, 255, 255, .16);
  box-shadow: 0 10px 20px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.05);
}

.icon-btn-notif:hover i,
.icon-btn-notif:hover svg,
.icon-btn-notif:focus-visible i,
.icon-btn-notif:focus-visible svg {
  color: var(--text);
  fill: currentColor;
}

.icon-btn-notif.has-unread {
  border-color: var(--primary-dark);
}

.icon-btn-notif.notif-popout {
  animation: notifBellDoublePop .56s ease;
}

.notif-counter-pill{
  background: var(--danger);
  display:block;
  border-radius: 999px;
  position: absolute;
  top: 4px;
  right: 7px;
  font-size:0;
  width: 6px;
  height: 6px;
}

.has-unread .notif-counter-pill{
  position: absolute;
  top: -10px;
  right: -8px;
  width: auto;
  height: 13px;
  padding: 0 2px;
  border-radius: 999px;
  background: var(--danger);
  color: #fff;
  box-shadow: 0 0 0 2px var(
  --surface, #111827);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.01em;
  pointer-events: none;
}

@keyframes notifBellDoublePop {
  0% {
    transform: scale(1) translateY(0);
  }

  18% {
    transform: scale(1.08) translateY(-1px);
  }

  34% {
    transform: scale(.96) translateY(0);
  }

  54% {
    transform: scale(1.14) translateY(-2px);
  }

  72% {
    transform: scale(.985) translateY(0);
  }

  100% {
    transform: scale(1) translateY(0);
  }
}

.close-icon-btn {
  height: 26px;
  width: 28px;
  padding: 5px;
  background: var(--strans);
  border-radius: inherit;
  position: absolute;
  display: inline-flex;
  top: 20%;
  left: 91%;
  border: 1px solid var(--primary-faded);
  font-size: 30px;
  flex-direction: column;
  justify-content: center;
}

.cmdk-btn {
  padding: 0 5px;
  font-size: 10px;
  height: 24px;
  border-radius: 15px;
  background: var(--bg);
}

.cmdk-btn:hover {
  background: var(--text);
  color: var(--bg);
}

#btnSettings {
  display: flex;
  overflow: hidden;
  gap: 2px;
  padding: 4px;
  font-size: 0;
}

.search-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
  height: var(--h);
  padding: 0 2px 0 10px;
  border-radius: 20px;
  background: var(--strans);
  /* border: 1px solid var(--primary-faded); */
}

.search-wrap input {
  width: 100%;
  outline: none;
}

.search-icon {
  width: 18px;
  height: 18px;
  fill: var(--text-muted);
}

.search-results {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--bg);
  border-radius: 10px;
  box-shadow: var(--shadow);
  padding: 6px;
  max-height: 50vh;
  overflow: auto;

}

.search-results .res {
  padding: 10px;
  border-radius: 8px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.search-results .res:hover,
.search-results .res[aria-selected="true"] {
  background: rgba(255, 255, 255, .06);
}

.btn {
  height: var(--h);
  color: #fff;
  padding: 0 10px;
  box-shadow: var(--btn-shadow);
  border-radius: var(--ui-control-radius);
  background: linear-gradient(45deg, var(--primary), var(--primary-dark));
  border: 1px solid color-mix(in srgb, var(--primary, #00d4ff) 22%, var(--strans));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  line-height: 1;
  font-weight: 750;
  transition: border-color var(--ui-motion-fast) ease, box-shadow var(--ui-motion-fast) ease, transform var(--ui-motion-fast) ease, background var(--ui-motion-fast) ease;
}

.btn.primary {
  margin: 0;
  border: none;
  color: #fff;
}

.btn.primary:hover {
  filter: brightness(1.05);
}

.btn:hover {
  border-color: color-mix(in srgb, var(--primary, #00d4ff) 42%, var(--ui-border-strong));
  box-shadow: inset 0 0 4px .1px;
  transform: translateY(-1px);
}

.btn:active {
  transform: translateY(0);
}

.btn:disabled {
  opacity: .6;
  cursor: not-allowed;
}

.btn.sm {
  margin: 0;
  padding: 0 10px;
  align-self: flex-end;
  display: flex;
  gap: 5px;
  background: linear-gradient(45deg, var(--primary), var(--primary-dark));
}

.btn.sm.count-btn {
  margin-top: 0px;
}

.btn-group {
  display: flex;
  gap: 4px;
  align-items: center;
}

.btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  padding: 3px;
  align-items: center;
  min-width: 0;
}

.admin-btn-row {
  display: flex;
  flex-wrap: nowrap;
  column-gap: 5px;
  align-items: center;
}

.dept-btn {
  height: var(--h);
  align-self: self-end;
  box-shadow: var(--btn-shadow);
  padding: 0 14px;
  border-radius: 10px;
  background: transparent;
  border: 1px solid var(--primary-faded);
}

/*.icon-btn.danger { color: #b91c1c; }*/
.btn-ghost,
.btn-dark {
  color: var(--text);
  border-radius: var(--ui-control-radius);
  border: 1px solid var(--ui-border-subtle);
  box-shadow: var(--shadow);
  padding: 5px 8px;
  background: var(--ui-surface-soft);
  display: flex;
  align-items: center;
  gap: 5px;
}

.btn.danger {
  background: #b00020;
  color: #fff;
}

.btn.danger:hover {
  filter: brightness(1.05);
}

.btn.sm.danger {
  background: var(--btn-bg);
  color: var(--btn-color);
  font-size: 14px;
  padding: 5px;
  padding-top: 3px;
  margin: 0;
}

.spacer {
  flex: 1 1 auto;
}

.divider {
  width: 1px;
  height: 24px;
  background: rgba(255, 255, 255, .1);
}

canvas { display:block; }

#ui {
  position:fixed; bottom:14px; left:50%; transform:translateX(-50%);
}

.menu {
  position: absolute;
  z-index: 40;
  transform: translateX(35%);
  background: var(--surface);
  width: max-content;
  border: var(--line);
  border-radius: 10px;
  padding: 6px;
  box-shadow: var(--shadow);
}

.menu>button {
  display: block;
  width: 100%;
  text-align: left;
  padding: 8px 10px;
  border-radius: 8px;
}

.menu>button:hover {
  background: rgba(255, 255, 255, .06);
}

.presence {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--muted);
  padding: 0 8px;
  height: var(--h);
  border-radius: 20px;
  border: 1px solid var(--primary-faded);
}

.presence-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--success);
  display: inline-block;
}

.presence .busy {
  background: var(--warning);
}

#presenceSelect {
  background: var(--muted);
  border-radius: 10px;
}

.badge {
  background: var(--danger);
  color: #fff;
  border-radius: 999px;
  padding: 2px 6px;
  font-size: 12px;
}

.profile {
  display: flex;
  align-items: center;
  gap: 8px;
}

.profile select {
  background: var(--muted);
  height: var(--h);
  padding: 1px 10px;
  border-radius: 20px;
  border: var(--line);
}

/* ===== Layout container (header is 64px tall) ===== */
.app-body {
  display: grid;
  position: relative;
  z-index: 1;
  --sidebar-w: 210px;
  grid-template-columns: var(--sidebar-w) 1fr;
  grid-template-areas:
    "sidebar main";
  transition: grid-template-columns .54s ease, --sidebar-w .5s ease;
  overflow: clip;
  justify-items: center;
  padding-left: 5px;
  gap: 0 5px;
}

.sm.count-btn {
  background: transparent;
  box-shadow: none;
}

/* hamburger area unclickable while animating (prevents jitter) */
.sidebar,
.main {
  will-change: transform, width;
}

/* ---------- Sidebar Icon-Only tooltips ---------- */
.app-body.sidebar-icon {
  --sidebar-w: 50px;
}

.app-body.sidebar-icon .sidebar .nav-link {
  justify-content: center;
  padding: 1px 0px;
  margin: 0;
  gap: 0;
}

.app-body.sidebar-icon .sidebar .nav-link .label {
  display: none;
}


.header-clock {
  display: inline-flex;
  gap: 6px;
  min-width: 115px;
  height: 30px;
  padding-left: 5px;
  border-radius: 15px;
  background: var(--strans);
  color: var(--text);
  font-weight: 700;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  letter-spacing: .05em;
  user-select: none;
  align-items: center;
  justify-content: space-around;
}

.header-clock .clock-time {
  font-variant-numeric: tabular-nums;
  -webkit-text-stroke: thin;
}

.header-clock .clock-weather {
  width: 20px;
  height: 20px;
  object-fit: contain;
  display: block;
  border-radius: 6px;
  filter: drop-shadow(0 6px 14px rgba(0, 0, 0, .18));
}

.header-clock .clock-weather[hidden] {
  display: none;
}


.header-hello-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--primary-faded);
  background: linear-gradient(135deg, color-mix(in oklab, var(--primary) 18%, transparent), rgba(255,255,255,.02));
  color: var(--text);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .01em;
  white-space: nowrap;
  box-shadow: 0 10px 20px rgba(0,0,0,.08);
}

.header-hello-pill[hidden],
.header-clock[hidden] {
  display: none !important;
}

/* Chat list accordion */
#chatList .dept-accordion {
  margin-bottom: 8px;
}

#chatList .legend {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 8px;
  border-radius: 8px;
  cursor: pointer;
}

#chatList .legend:hover {
  background: rgba(255, 255, 255, .06);
}

#chatList .group-list {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  margin: 0;
  padding-left: 0px;
  padding-right: 0;
}

#chatInfo .file-card {
  align-content: space-between;
  overflow: hidden;
}

#chatInfo .file-card .icon-btn {
  width: 25px;
  height: 25px;
  font-size: 10px;
}

#chatInfo .file-card .meta .name {
  font-size: 10px;
  text-emphasis: sesame open;
  text-transform: capitalize;
  text-wrap-mode: nowrap;
  width: -webkit-fill-available;
}

#chatInfo .file-card .meta .sub {
  font-size: 8px;
}

/* ===== Sidebar & Main ===== */
.sidebar {
  grid-area: sidebar;
  display: grid;
  grid-template-rows: 45px 1fr;
  gap: 3px;
  list-style: none;
  position: sticky;
  padding: 2px 0 0;
  margin: 0;
  width: 210px;
  height: 100vh;
  -ms-overflow-style: none;
  scroll-behavior: smooth;
  overflow: auto;
  transform: translateX(-1px);
  transition: padding 0.14s ease, border-color .14s ease, width .3s ease, transform .3s ease;
  scrollbar-width: none;
}

.sidebar-icon .sidebar {
  transition: padding .24s ease, border-color .24s ease, width .25s ease, transform .5s ease, width .5s ease;
  width: 50px;
  background: transparent;
}

.sidebar-body {
  display: grid;
  grid-template-rows: 1fr 110px;
  overflow: hidden;
  /* font-family: 'Poppins'; */
  -ms-overflow-style: none;
}
.sidebar-body:before {
  content: "";
  display: block;
  position: absolute;
  height: 20px;
  /* top: 0; */
  left: 0;
  right: 0;
  z-index: 10;
  background: linear-gradient(
180deg, var(--bg), transparent);
}

.sidebar-icon .sidebar-body {
  /* width: fit-content; */
  justify-items: center;
}

.main {
  display: grid;
  gap: 6px;
  grid-area: main;
  transition: margin-left .25s ease;
  min-width: 0;
  width: -webkit-fill-available;
  margin: 4px 0 0;
  scrollbar-width: none;
}

/* ===== Nav / links ===== */
.nav-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px;
  border-radius: 12px;
  margin-right: 8px;
}


#sidebar .nav-link .label {
  min-width: 0;
  flex: 1 1 auto;
  letter-spacing: .1px;
}

.nav-link.active {
  background: var(--primary-faded);
}

.nav-icon {
  width: 18px;
  height: 18px;
  flex: 0 0 16px;
  vertical-align: middle;
}

#sbFlyout .nav-icon,
.sidebar-icon .nav-icon {
  display: flex !important;
}

#sbFlyout .s-icons{background: var(--surface), linear-gradient(45deg, var(--strans)8%, var(--bg));padding: 3px;border-radius: 5px;display: flex;}

.nav-list {
  margin: 0;
  margin-block: 0;
  padding-inline: 0;
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  overflow: auto;
  scrollbar-width: none;
}

.nav-list .sidebar-icon {
  width: 50px;
}

.sidebar-icon .nav-list {
  font-size: 0;
  justify-items: center;
  padding-right: 0;
  width: fit-content;
}

.sidebar-icon .logo-text {
  display: none;
  transition: display 1s ease;
}

.sidebar-icon .logo {
  scale: 1.24;
  margin: 0 15px 0 0;
  transition: scale 0.5s ease
}

.sidebar-header{
  padding: 5px;
  display: flex;
}
.sidebar-icon .sidebar-header{
  width:45px
}
.sidebar-header-animate {
  display: flex;
  gap: 4px;
  width: -webkit-fill-available;
  justify-content: space-between;
  transform: translateX(0);
  transition: transform .2s ease-in;
  align-items: center;
}

.sidebar-icon .sidebar-header-animate:hover {
  transform: translateX(-48px);
  transition: transform .6s ease
}

.sidebar-icon .sidebar-header-animate {
  padding-left: 5px;
  justify-content: left;
  gap: 5px;
  width: 100px;
  background: transparent;
}


a.nav-link:hover {
  background: var(--strans);
  width: -webkit-fill-available;
}

/* Sidebar Icon Active States */
.nav-link[aria-current="page"] .nav-icon,
.nav-link.active .nav-icon {
  color: var(--primary) !important;
}

/* Specific fix for Admin icon which uses stroke */
.st-side[aria-current="page"] .footer-icon circle,
.st-side[aria-current="page"] .footer-icon path,
.st-side.active .footer-icon circle,
.st-side.active .footer-icon path {
  stroke: var(--primary) !important;
}

/* ---- Smooth route transitions ---- */
@keyframes routeChildInForward {
  from {
    opacity: 0;
    transform: translate3d(30px, 0, 0) scale(.968);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes routeChildOutForward {
  from {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }

  to {
    opacity: 0;
    transform: translate3d(-22px, 0, 0) scale(.986);
  }
}

@keyframes routeChildInBack {
  from {
    opacity: 0;
    transform: translate3d(-30px, 0, 0) scale(.968);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes routeChildOutBack {
  from {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }

  to {
    opacity: 0;
    transform: translate3d(22px, 0, 0) scale(.986);
  }
}

@keyframes routeMainIn {
  0% {
    opacity: 0;
    clip-path: circle(var(--route-main-seed-radius, 28px) at var(--route-origin-x, 50%) var(--route-origin-y, 12%));
    transform: translate3d(var(--route-main-shift-x, -28px), var(--route-main-shift-y, -14px), 0) scale(var(--route-main-start-scale, .62));
    filter: blur(var(--route-main-blur-in, 14px)) saturate(1.04);
  }

  58% {
    opacity: 1;
    clip-path: circle(calc(var(--route-main-full-radius, 1400px) * .34) at var(--route-origin-x, 50%) var(--route-origin-y, 12%));
    transform: translate3d(calc(var(--route-main-shift-x, -28px) * .12), calc(var(--route-main-shift-y, -14px) * .12), 0) scale(var(--route-main-mid-scale, .92));
    filter: blur(calc(var(--route-main-blur-in, 14px) * .35)) saturate(1.02);
  }

  100% {
    opacity: 1;
    clip-path: circle(var(--route-main-full-radius, 1400px) at var(--route-origin-x, 50%) var(--route-origin-y, 12%));
    transform: translate3d(0, 0, 0) scale(1);
    filter: blur(0) saturate(1);
  }
}

@keyframes routeMainOut {
  from {
    opacity: 1;
    clip-path: circle(var(--route-main-full-radius, 1400px) at var(--route-origin-x, 50%) var(--route-origin-y, 12%));
    transform: translate3d(0, 0, 0) scale(1);
    filter: blur(0);
  }

  to {
    opacity: 0;
    clip-path: circle(calc(var(--route-main-seed-radius, 28px) * 1.75) at var(--route-origin-x, 50%) var(--route-origin-y, 12%));
    transform: translate3d(calc(var(--route-main-shift-x, -28px) * -0.18), calc(var(--route-main-shift-y, -14px) * -0.18), 0) scale(.96);
    filter: blur(var(--route-main-blur-out, 10px));
  }
}

.route {
  display: none;
  width: 100%;
  height: calc(100dvh - 52px);
  background: var(--strans);
  border-radius: 30px 0 0;
  overflow: auto;
  padding: 0 5px 0 12px;
  transform-origin: var(--route-origin-x, 50%) var(--route-origin-y, 12%);
  backface-visibility: hidden;
  will-change: transform, opacity, clip-path, filter;
  scrollbar-width: none;
  backdrop-filter: blur(5px);
}
.route[data-route='/']{background:none}
.route.active,
.route.route-entering,
.route.route-main-entering,
.route.route-stack-clone {
  display: block;
}

.route.active,
.route.route-entering,
.route.route-main-entering {
  position: relative;
  z-index: 1;
}

.route.route-main-entering {
  z-index: 2;
}

.route.route-entering.dir-forward {
  animation: routeChildInForward var(--route-child-in-ms) var(--route-transition-ease) both;
}

.route.route-entering.dir-back {
  animation: routeChildInBack var(--route-child-in-ms) var(--route-transition-ease) both;
}

.route.route-main-entering.dir-forward,
.route.route-main-entering.dir-back {
  animation: routeMainIn var(--route-main-in-ms) var(--route-transition-ease) both;
}

.route.route-stack-clone {
  position: absolute;
  z-index: 18;
  margin: 0;
  pointer-events: none;
  overflow: hidden;

  background: transparent;
  transform-origin: var(--route-origin-x, 50%) var(--route-origin-y, 12%);
  will-change: transform, opacity, clip-path, filter;
}

.route.route-stack-clone.route-exit-child.dir-forward {
  animation: routeChildOutForward var(--route-child-out-ms) var(--route-transition-ease-out) both;
}

.route.route-stack-clone.route-exit-child.dir-back {
  animation: routeChildOutBack var(--route-child-out-ms) var(--route-transition-ease-out) both;
}

.route.route-stack-clone.route-exit-main.dir-forward,
.route.route-stack-clone.route-exit-main.dir-back {
  animation: routeMainOut var(--route-main-out-ms) var(--route-transition-ease-out) both;
}

.route.route-stack-clone>* {
  pointer-events: none;
}

#content.route-transition-child,
#content.route-transition-main {
  overflow: hidden;
}

/* ---- Tiny route progress bar ---- */
#content {
  position: relative;
}

.route-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 100%;
  z-index: 4000;
  pointer-events: none;
  background: linear-gradient(90deg, var(--muted), var(--primary), var(--muted));
  background-size: 200% 100%;
  transform-origin: 0 0;
  transform: scaleX(0);
  opacity: 0;
  transition: transform .18s ease, opacity .12s ease;
}

.route-skeleton {
  position: absolute;
  inset: 14px;
  z-index: 32;
  pointer-events: none;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .18s ease, transform .18s ease;
}

.route-skeleton.active {
  opacity: 1;
  transform: translateY(0);
}

.route-skeleton-card {
  max-width: 520px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(10, 14, 24, .84);
  box-shadow: 0 24px 48px rgba(0,0,0,.22);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  isolation: isolate;
}

.route-skeleton-title {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 12px;
  color: #fff;
}

.route-skeleton-sub {
  font-size: 12px;
  color: rgba(255,255,255,.7);
  margin-bottom: 14px;
}

.route-skeleton-lines {
  display: grid;
  gap: 10px;
}

.route-skeleton-line {
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255,255,255,.08), rgba(255,255,255,.22), rgba(255,255,255,.08));
  background-size: 200% 100%;
  animation: routeSkeletonPulse 1.15s linear infinite;
}

.route-skeleton-line.short {
  width: 58%;
}

.route-skeleton-line.mid {
  width: 76%;
}

@keyframes routeSkeletonPulse {
  0% { background-position: 0% 0; }
  100% { background-position: 200% 0; }
}

.user-card {
  display: flex;
  gap: 5px;
  justify-content: space-between;
}

.user-card-info {
  display: flex;
  flex: 1;
  flex-direction: column;
  justify-content: center;
}

.sidebar-icon .user-card {
  gap: 0;
}

.sidebar-icon .user-card-info {
  display: none !important;
}

.sidebar-footer .user-cardbtn {
  display: grid;
  border: 0;
  text-align: left;
  cursor: pointer;
}

.sidebar-footer .avatar-ft img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sidebar-footer .status-dot {
  position: absolute;
  right: 6.3vw;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  transition: right .5s ease;
  background: var(--success);
}

section[hidden], ul[hidden] {
    display: none;
}

.sidebar-icon .status-dot {
  right: 8px;
  transition: right .5s ease;
}

/* Small flyout above avatar */
.sb-profile-flyout {
  position: absolute;
  left: -150px;
  bottom: 60px;
  width: auto;
  background: var(--strans);
  -webkit-backdrop-filter: var(--backdrop-2);
  backdrop-filter: var(--backdrop-2);
  isolation: isolate;
  border-radius: 18px;
  z-index: 1;
}

.sidebar-icon .sb-profile-flyout {
  left: -5px;
  bottom: 70px;
  z-index: 10;
}

.sb-profile-flyout[hidden] {
  display: none;
}

.sb-profile-flyout .flyout-inner {
  padding: 10px;
}

.sb-profile-flyout .flyout-row {
  display: flex;
  gap: 5px;
  align-items: center;
  justify-content: space-between;
}

.lg-side,
.st-side {
  display: flex;
  width: 22px;
  height: 22px;
  border-radius: 20px;
  padding: 1px;
  scale: 1;
  background: transparent;
  transform: translateY(0px);
  transition: scale 0.5s ease-out, transform .5s ease-out, background .5s ease-out
}
.lg-side svg,
.st-side svg{
  width:20px;
  height: 20px;
  fill: var(--primary-faded) !important;
}

.sidebar-icon .lg-side,
.sidebar-icon .st-side {
  scale: 1.2 !important;
}

.lg-side:hover,
.st-side:hover {
  background: var(--primary-faded);
  transform: translateY(-2px);
  scale: 1.1;
  transition: transform 0.5s ease, scale 0.3s ease, background 0.5s ease
}

.sidebar-icon .name-ft,
.sidebar-icon .orgsel,
.sidebar-icon .email-ft,
.sidebar-icon .status-pill-container {
  display: none !important;
}

.email-ft {
  font-size: 9px;
  display: block;
}

.avatar-ft {
  position: relative;
  width: 40px;
  height: 40px;
  border-radius: 120%;
  display: inline-grid;
  place-items: center;
  font-weight: 600;
  overflow: hidden;
  background: var(--primary-faded);
  color: var(--text);
  font-size: 14px;
}

.sidebar-icon .avatar-ft {
  width: 30px;
  height: 30px;
  border-radius: 100%
}

.footer-content {
  padding: 0 5px;
  background: linear-gradient(30deg, var(--primary-dark) 30%, var(--primary-light));
  /* background: var(--strans); */
  /* backdrop-filter: blur(5px); */
}

/* --- Shared lightweight carousel (dots only) --- */
.u-carousel-viewport {
  width: 100%;
  overflow: hidden;
}

.u-carousel-track {
  display: flex;
  width: 100%;
  transform: translate3d(0, 0, 0);
  transition: transform 420ms cubic-bezier(.22, .61, .36, 1);
  will-change: transform;
}

.u-carousel-slide {
  flex: 0 0 100%;
  width: 100%;
}

.u-carousel-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  padding-top: 6px;
}

.u-carousel-dots[hidden] {
  display: none !important;
}

.u-dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  border: 0;
  background: rgba(255, 255, 255, 0.35);
  cursor: pointer;
  padding: 0;
}

.u-dot.active {
  background: rgba(255, 255, 255, 0.9);
  width: 14px;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }

  .u-carousel-track {
    transition: none !important;
  }
}

/* Sidebar footer carousel specifics */
.footer-content.footer-carousel {
  position: relative;
  align-items: stretch;
  display: grid;
  width: -webkit-fill-available;
  margin: 0 4px 2px;
  border-radius: 15px;
}

.footer-carousel .u-carousel-slide {
  gap: 5px;
}

.footer-carousel-dots {
  padding-top: 4px;
  position: absolute;
  bottom: 3px;
  justify-self: center;
}

/* Sidebar footer carousel: compact mode (sidebar collapsed/closed) */
#sidebarFooterCarousel[data-compact="1"] .footer-carousel-dots {
  display: none !important;
}
#sidebarFooterCarousel[data-compact="1"] .u-carousel-track {
  transform: translate3d(0, 0, 0) !important;
}

/* Footer announcement / reminder slides */
.footer-carousel .ft-slide {
  border-radius: 10px;
  padding: 4px;
  display: grid;
  gap: 3px;
}

.footer-carousel .ft-slide-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.footer-carousel .ft-slide-avatar {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,0.12);
  cursor: pointer;
}

.footer-carousel .ft-slide-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: inherit;
}

.footer-carousel .ft-slide-open {
  width: 20px;
  height: 20px;
  border-radius: 6px;
  border: var(--line);
  background: var(--strans);
  color: var(--text);
  display: grid;
  place-items: center;
  cursor: pointer;
}

.footer-carousel .ft-slide-open:hover {
  background: rgba(255,255,255,0.14);
}

.footer-carousel .ft-slide-body {
  display: grid;
  gap: 2px;
}

.footer-carousel .ft-slide-title {
  font-size: 12px;
  font-weight: 650;
}

.footer-carousel .ft-slide-desc {
  font-size: 9px;
  opacity: 0.9;
  line-height: 1.25;
}

.footer-carousel .ft-slide-actions {
  display: flex;
  justify-content: flex-end;
}

.footer-carousel .ft-dismiss {
  width: 100%;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.10);
  color: var(--text);
  font-size: 11px;
  padding: 4px 6px;
  cursor: pointer;
}

.footer-carousel .ft-dismiss:hover {
  background: rgba(255,255,255,0.14);
}

.sidebar-icon .footer-content {
  width: -webkit-fill-available;
  padding: 5px;
}

.app-footer {
  display: flex;
  flex-direction: column;
  padding: 4px;
  gap: 5px;
}

.sidebar-icon .app-footer {
  padding: 0;
  gap: 5px;
}

.footer-headbar {
  padding: 6px;
  width: 100%;
  border-radius: 10px;
}

.sidebar-icon .footer-headbar {
  padding: 2px;
  display: flex;
  margin: 0 -4.5px;
}

.footer-actions {
  display: flex;
  gap: 3px;
  padding: 0;
  border-radius: 10px;
  justify-content: center;
  align-items: center;
}

.sidebar-icon .footer-actions {
  flex-direction: column;
  gap: 8px;
  height: auto;
}
.footer-actions .bits-ss{
  font-size: 10px;
  text-overflow: ellipsis;
  border-radius: 10px;
}
.footer-actions .bits-ss-btn{
  padding: 4px;
}
.sidebar-icon .footer-actions .bits-ss{display:none}

.route-progress.active {
  opacity: 1;
  animation: routeBar 1s linear infinite;
  transform: scaleX(1);
}

@keyframes routeBar {
  0% {
    background-position: 0% 0;
  }

  100% {
    background-position: 200% 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .route.active {
    animation: none !important;
  }

  .route.exiting {
    animation: none !important;
  }
}

/* ---- App loader (liquid logo) ---- */
.app-loader {
  --splash-progress: 0;
  /* Driven by the loader gate (setProgressPct): blur clears and the background
     turns transparent as the boot sequence completes, so the app framework stays
     hidden during the auth check and only reveals once it is actually ready. */
  --splash-blur: 48px;
  --splash-bg-pct: 100%;
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--surface) var(--splash-bg-pct), transparent);
  -webkit-backdrop-filter: blur(var(--splash-blur));
  backdrop-filter: blur(var(--splash-blur));
  isolation: isolate;
  z-index: 12000;
  opacity: 1;
  transition: all .52s ease;
}

.app-loader.app-loader-fast {
  transition-duration: 120ms;
}

.app-loader[hidden] {
  display: none;
}

.app-loader.app-loader-hide {
  opacity: 0;
  pointer-events: none;
}

.app-loader .splash {
  width: min(560px, 92vw);
  padding: 24px 20px 18px;
  border-radius: 18px;
  isolation: isolate;
}

.app-loader .splash-logo {
  width: min(110px, 12vw);
  margin: 6px auto 10px;
  user-select: none;
}

.app-loader #splashLogoSvg {
  width: 100%;
  height: auto;
  display: block;
}

.app-loader #splashLogoSvg .splash-logo-outline {
  fill: color-mix(in srgb, var(--text) 8%, transparent);
  stroke: color-mix(in srgb, var(--text) 38%, transparent);
  stroke-width: 10px;
}

.app-loader #splashLogoSvg .splash-wave-fill {
  fill: var(--primary);
}

.app-loader #splashLogoSvg .splash-wave-highlight {
  fill: rgba(255, 255, 255, .18);
}

.app-loader #splashLogoSvg .splash-wave-shift {
  animation: splashWave 3s linear infinite;
  transform-origin: 0 0;
  transform-box: fill-box;
  will-change: transform;
}

@keyframes splashWave {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-800px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .app-loader #splashLogoSvg .splash-wave-shift {
    animation: none !important;
  }
}

.app-loader .splash-status {
  text-align: center;
  margin-top: 12px;
  font-size: 13px;
  opacity: .82;
}

@media (prefers-color-scheme: light) {
  .app-loader {
    background: color-mix(in srgb, #fff var(--splash-bg-pct), transparent);
  }

  .app-loader .splash {
    background: transparent;
  }
}

.success{border-color: green !important}
.warning{border-color: orange !important}
.error{border-color: red !important}
.danger{border-color: red !important}

#emailDetails {
  overflow: auto;

}

#msgTopLoader[hidden] {
  display: none;
}

/* Read vs Unread styling */
.inbox-item.is-unread strong {
  font-weight: 700;
}

.inbox-item.is-read strong {
  font-weight: 500;
  opacity: .9;
}

.inbox-item.is-read {
  background: rgba(0, 0, 0, .03);
}

#settingsPanel.sheet {
  position: fixed;
  width: min(310px, 94vw);
  background: transparent;
  top: 2px;
  border-left: var(--line);
  box-shadow: var(--shadow);
  z-index: 1200;
  transform: translateX(105%);
  transition: transform .52s ease;
  -webkit-backdrop-filter: var(--backdrop-2);
  backdrop-filter: var(--backdrop-2);
  isolation: isolate;
}

.msg.other .msg-belt {
  right: 0;
  left: 100%;
  margin: 0;
  margin-left: 5px;
}

#settingsPanel.sheet[hidden] {
  display: block;
}

/* keep in flow; hidden via transform */
body:not(.no-sheet) #settingsPanel.sheet:not([hidden]) {
  transform: translateX(0);
}

#userSettingsCard {
  display: flex;
  flex-direction: column;
  overflow: auto;


  margin-top: 40px;
  border: 0;
  padding: 0 8px;
  box-shadow: none;
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
  isolation: isolate;
  background: transparent;
}

.panel-header {
  display: flex;
  align-items: center;
  gap: 10px 12px;
  justify-content: space-between;
  padding: 2px 2px 8px;
  height: fit-content;
}
#chat-root .left-panel .panel-header {
  flex-wrap: wrap;
}
#chat-root .right-panel .panel-header {
  gap: 0;
  padding: 10px 8px;
  position: absolute;
  border-radius: 0 15px 0 0;
  z-index: 1;
  inset: 0;
  backdrop-filter: var(--backdrop-2);
}

.chat-header-left {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: space-between;
}

.emails {
  width: 100%;
}

.p {
  color: var(--text) !important
}

.panel-admin-header {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: space-between;
  margin-bottom: 8px;
  padding: 10px 0px;
}

.thread {
  gap: 5px;
  display: flex;
  flex-direction: column;
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
  isolation: isolate;
  user-select: none;
}

.panel-header h2 {
  font-size: clamp(1rem, .9vw, 1.16rem);
  margin: 0;
  color: var(--text);
  width: -webkit-fill-available;
  letter-spacing: -.02em;
  line-height: 1.15;
}

#emailDetailsPane h2{padding:10px;position: relative;}

.panel-header .muted {
  color: var(--text-muted);
  font-size: .9rem;
  margin-left: auto;
}

.panel-header .icon-btn {
  width: 30px;
  height: 30px;
  border-radius: 19px;
  border: var(--line);
  color: var(--text);
}

.setpanel-header {
  background: transparent;
  border-radius: 10px;
  padding: 1px;
  position: absolute;
  width: 94%;
  display: flex;
  align-self: center;
}

.setpanel-header h2 {
  margin: 10px 0 !important;
}

.panel-header .icon-btn:hover {
  background: var(--muted);
}

.panel-section {
  padding: 14px 10px;
  border-radius: 20px;
  margin: 10px 0;
  background: var(--side), radial-gradient(100px 100px at 10% 10%, var(--primary-faded) -68%, var(--bg));
  background-blend-mode: var(--blend);
  position: relative;
}

/* -------------------- Settings: Theme Palette (custom color + gradients) -------------------- */
.set-palette{
  position: absolute;
  z-index: 1;
  margin-top: -8px;
  padding: 10px;
  border: var(--line);
  border-radius: 18px;
  -webkit-backdrop-filter: var(--backdrop-2);
  backdrop-filter: var(--backdrop-2);
  isolation: isolate;
}
.set-palette-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.set-palette-title{
  font-weight: 800;
  letter-spacing: -0.01em;
}
.set-palette-current{
  display:flex;
  align-items:center;
  gap: 8px;
  min-width: 0;
}
.set-palette-swatch{
  width: 22px;
  height: 22px;
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--line, #374151) 55%, transparent);
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
  background: var(--primary, #3b82f6);
}
.set-palette-code{
  padding: 3px 7px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--line, #374151) 35%, transparent);
  background: color-mix(in srgb, var(--muted, #2d2d44) 55%, transparent);
  color: var(--text);
  font-size: 12px;
  max-width: 140px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.set-palette-grid{
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}
.set-chip{
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--line, #374151) 45%, transparent);
  background: var(--chip, #6c7fff);
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.set-chip:hover{
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--primary, #3b82f6) 55%, var(--line, #374151));
  box-shadow: 0 14px 34px rgba(0,0,0,.18);
}
.set-chip:active{ transform: translateY(0) scale(0.99); }
.set-chip.is-selected{
  outline: 2px solid color-mix(in srgb, var(--primary, #3b82f6) 70%, white 25%);
  outline-offset: 2px;
}
.set-chip.is-selected::after{
  content: '✓';
  position: absolute;
  right: 6px;
  bottom: 6px;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: rgba(0,0,0,.45);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 12px;
}
.set-chip.gradient{
  background: var(--chip, linear-gradient(135deg, #3b82f6, #a855f7));
}

.assistant {
  gap: 5px;
  display: flex;
  flex-wrap: wrap;
}

.topbar .right {
  justify-content: right;
  padding-right: 2px;
  gap: 7px;
}

/* Cards, panels */
.card.big {
  grid-column: 1/-1;
}

.panel {
  background: color-mix(in oklab, var(--bg)95%, var(--primary-dark));
  border-radius: var(
  --ui-card-radius);
  padding: 12px;
  overflow: auto;
  position: relative;
  align-content: flex-start;
}

#wePaneEditor.panel {
  overflow-y: auto !important;
  height: 89vh
}

#wePaneList .card {
  max-height: 72.5vh;
  overflow: auto;

}

.panel-sub {
  color: var(--text-muted);
  margin: 14px 0 8px;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .07em;
  text-transform: uppercase;
}

.panel.main-panel,
.right-panel {
  padding: 0;
  display: flex;
  flex-direction: column;
  position: relative;
  border-radius: 15px 0 0 15px;
}

.left-panel {
  isolation: isolate;
  margin-right: 0;
  background: none;
  border-radius: 0;
  border: 0;
  padding: 10px 7px 0 0;
  box-shadow: none;
  display: grid;
}

.list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 9px;
}

.list .item,
.inbox-item,
.deal-card,
.task {
  -webkit-backdrop-filter: var(--backdrop);
  backdrop-filter: var(--backdrop);
  isolation: isolate;
  border-radius: 12px;
  padding: 7px 9px;
  background: linear-gradient(180deg, var(--ui-surface-soft), transparent);
  transition: border-color var(--ui-motion-fast) ease, background var(--ui-motion-fast) ease, transform var(--ui-motion-fast) ease, box-shadow var(--ui-motion-fast) ease;
}

.list .item:hover,
.selectable .item:hover,
.inbox-item:hover {
  /* background: rgba(255,255,255,.06); */
  scale: 1;
}

.inbox-item:hover {
  scale: 1;
  transform: translateY(-1px);
}

.list.selectable .item[aria-selected="true"] {
  outline: var(--ring);
}

.dashboard .dash-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: var(--gap);
}

.dashboard .grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}

.grid-2 {
  display: flex;
  flex-direction: column;
  gap: var(--gap);
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}

.grid-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}

.flex-2 {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--gap);
}

.flex-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--gap);
  align-items: center;
  margin-bottom: 12px;
}

/* Three-column module layout (1fr/2fr/1fr) */
.three-col {
  --col-left: 1fr;
  --col-center: 2fr;
  --col-right: 0fr;
  display: grid;
  grid-template-columns: var(--col-left) var(--col-center) var(--col-right);
  transition: grid-template-columns 320ms cubic-bezier(0.4, 0, 0.2, 1);
  margin: 0;
  border-radius: var(--ui-card-radius);
  padding: 2px 1px 0;
  min-height: 0;
  height: -webkit-fill-available;
  margin-right: -5px;
  gap: 0;
  overflow: hidden;
}

.inbox-three-col{
  --col-left: .65fr;
}

.three-col.show-info {
  --col-right: 1fr;
  gap: 4px;
}

.three-col > .right-panel {
  overflow: hidden;
  transition: opacity 240ms ease, visibility 240ms;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.three-col.show-info > .right-panel {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  height: -webkit-fill-available;
  border-left: var(--line);
}

#boardsShell .panel.main-panel {
  grid-column: 2;
}

#boardsShell .panel.left-panel {
  grid-column: 1;
}

#boardsShell .panel.right-panel {
  grid-column: 3;
}

.split.two {
  display: grid;
  grid-template-columns: 0.5fr 1fr;
  min-height: 0;
  height: -webkit-fill-available;
  overflow: auto;
  padding: 5px 0 5px 5px;
  gap: 4px;
}

.filters,
.chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.chip {
  background: var(--ui-surface-soft);
  border: 1px solid var(--ui-border-subtle);
  border-radius: 999px;
  padding: 6px 10px;
  font-weight: 750;
}

.chip.busy {
  background: rgba(239, 68, 68, .2);
  border-color: rgba(239, 68, 68, .4);
}

.chip.me {
  background: rgba(79, 70, 229, .2);
  border-color: rgba(79, 70, 229, .4);
}

.chip.active {
  background: var(--primary);
  color: #fff;
  border: none;
}

.inbox-list {
  display: flex;
  flex-direction: column;
  gap: var(--gap);
  overflow: auto;
  -ms-overflow-style: none;

  max-height: auto;
}

.inbox-item {
  align-items: flex-start;
  cursor: pointer;
  overflow-wrap: anywhere;
}

.inbox-item .meta {
  color: var(--text-muted);
  font-size: 9px;
  align-items: center;
  gap: 5px;
}

.head.meta {
  max-width: 14.5vw;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  flex-wrap: nowrap;
}

.thread-view {
  /* background: var(--bg); */
  /* border: var(--line); */
  /* border-radius: 10px; */
  /* padding: var(--pad); */
  padding-right: 4px;
  min-height: 320px;
}

.thread-empty {
  color: var(--text-muted);
  padding: 20px;
  text-align: center;
}

.messages {
  height: -webkit-fill-available;
  min-height: 0;
  -ms-overflow-style: none;
  scroll-behavior: smooth;

}

.messages::-webkit-scrollbar-track {
  background: transparent;
  margin-top: 50px;
  margin-bottom: 60px;
}

.msg.me {
  margin-right: 2px
}

.message {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  flex-direction: column;
}

.message.me {
  background: rgba(79, 70, 229, .08);
}

.composer {
  display: flex;
  position: sticky;
  gap: 10px;
  width: 99.8%;
  margin-bottom: 7.8px;
  border-radius: 0 0 10px 10px;
  align-items: flex-end;
  -webkit-backdrop-filter: var(--backdrop-2);
  backdrop-filter: var(--backdrop-2);
  isolation: isolate;
  pointer-events: all;
}


/* Two-row chat composer (typing row + controls row) */
.composer.composer-two-row {
  flex-direction: column;
  align-items: stretch;
  gap: 5px;
  padding: 5px;
  border: var(--line);
  border-radius: 20px;
  width: 60%;
}

.composer.composer-two-row .composer-top {
  position: relative;
  display: flex;
  align-items: stretch;
}

.composer.composer-two-row .composer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.composer.composer-two-row .composer-left,
.composer.composer-two-row .composer-right {
  display: flex;
  align-items: center;
  gap: 4px;
}

.composer.composer-two-row .composer-right {
  justify-content: flex-end;
}

.composer.composer-two-row #chatInput {
  width: 100%;
  min-height: 25px;
}

.composer.composer-two-row .composer-left .icon-btn,
.composer.composer-two-row .composer-right .icon-btn {
  width: 25px;
  height: 25px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.composer.composer-two-row #chatSend {
  height: 24px;
}

.composer input,
.input {
  width: 65%;
  height: var(--h);
  outline: none;
  border: 1px solid var(--ui-border-subtle);
  border-radius: var(--ui-control-radius);
  background: var(--ui-surface-soft);
  padding: 0 10px;
  transition: border-color var(--ui-motion-fast) ease, box-shadow var(--ui-motion-fast) ease, background var(--ui-motion-fast) ease;
}

.composer input:hover,
.input:hover {
  border-color: var(--ui-border-strong);
}

.composer input:focus,
.input:focus {
  border-color: color-mix(in srgb, var(--primary, #00d4ff) 55%, var(--ui-border-strong));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary, #00d4ff) 14%, transparent);
}

.composer textarea {
  width: 100%;
  border-radius: 10px;
  padding: 5px;
  background: var(--muted);
  border: var(--line);
  max-height: 200px;
  outline: none;
  border-radius: 20px !important;
}

.composer-actions {
  display: flex;
  align-items: center;
  flex-direction: row;
  gap: 5px;
}

.avatar {
  border-radius: 50%;
  object-fit: cover;
  background: #ddd;
}

.avatar.sm {
  width: 28px;
  height: 28px;
  display: inline-block;
}

.avatar.sm.initials {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: inline-grid;
  place-items: center;
  font-weight: 600;
}

.chip {
  display: inline-block;
  padding: 0.2rem .5rem;
  border-radius: 999px;
  font-size: var(--text);
  margin: .1rem;
}

.chip.quiet {
  opacity: .7;
}

.msg-row {
  margin: 4px 0;
}

.message-bubble {
  width: 100%;
  overflow: scroll;

  margin-top: 15px;
  color: var(--text);
}

.message-bubble.mine {
  background: var(--surface);
}

#assistantMessages.messages {
  height: 73vh;
}

.assistant.card {
  margin-bottom: 10px;
}

.toolbar {
  display: flex;
  gap: var(--gap);
  align-items: center;
}

.grid-cards .card {
  transition: transform .15s ease, scale .15s ease;
}

.grid-cards .card:hover {
  transform: translateY(-1px);
  scale: 1.006;
}

.buckets {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}

.bucket>header {
  font-weight: 700;
  margin-bottom: 8px;
}

.task-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 200px;
  padding: 6px;
  background: rgba(255, 255, 255, .03);
  border: var(--line);
  border-radius: 10px;
}

.task {
  display: flex;
  align-items: center;
  gap: 8px;
}

.task .meta {
  margin-left: auto;
  color: var(--text-muted);
  font-size: 12px;
}

.task.dragging {
  opacity: .6;
}

.kanban {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}

.kanban.crm {
  grid-template-columns: repeat(5, 1fr);
}

.kan-col>header {
  font-weight: 700;
  margin-bottom: 8px;
}

.kan-items {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 200px;
  background: rgba(255, 255, 255, .03);
  border: var(--line);
  border-radius: 10px;
  padding: 6px;
}

.deal-card {
  cursor: grab;
}

.table {
  width: 100%;
  border-collapse: collapse;
}

.table th,
.table td {
  text-align: left;
  border-bottom: var(--line);
  padding: 10px;
}

.table th {
  color: var(--text-muted);
  font-weight: 600;
}

.table.compact td,
.table.compact th {
  padding: 6px 8px;
}

.table-wrap {
  overflow: auto;
  border: var(--line);
  border-radius: 8px;

}

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

.note-editor {
  min-height: 240px;
  margin-top: 10px;
  border-radius: 5px;
  padding: 10px;
  background: var(--ubp-bg);
  outline: none;
}

#noteEditor a {
  cursor: pointer;
  color: var(--primary-light)
}

#noteEditor {
  font-weight: 250;
  letter-spacing: .41px;
  height: 55vh;
  overflow: auto;

}

#noteEditor b {
  font-weight: 500
}

#noteToolbar select {
  width: 20vw
}

.tools {
  display: flex;
  gap: 3px;
  width: 45vw;
}

.muted {
  color: var(--text-muted);
  margin: 0;
}

.legend {
  display: flex;
  gap: 6px;
  margin-bottom: 8px;
}

.desk-grid {
  --cols: 12;
  display: grid;
  grid-template-columns: repeat(var(--cols), 1fr);
  gap: 6px;
  background: rgba(255, 255, 255, .03);
  border: var(--line);
  border-radius: 10px;
  padding: 10px;
}

.desk {
  height: 38px;
  border-radius: 6px;
  border: var(--line);
  background: rgba(255, 255, 255, .06);
  display: grid;
  place-items: center;
  font-size: 12px;
  cursor: pointer;
}

.desk.booked {
  background: rgba(239, 68, 68, .2);
  border-color: rgba(239, 68, 68, .4);
}

.desk.mine {
  background: rgba(79, 70, 229, .2);
  border-color: rgba(79, 70, 229, .4);
}

.bar-chart {
  height: 140px;
  display: flex;
  align-items: end;
  gap: 6px;
}

.bar {
  flex: 1;
  background: linear-gradient(180deg, rgba(79, 70, 229, .8), rgba(79, 70, 229, .2));
  border-radius: 6px 6px 0 0;
}

.form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.form-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 10px;
}

.form-row[hidden] {
  display: none
}

.form-row:last-child {
  /* margin-bottom: 0; */
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.form-inline {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 2px !important;
}

.flyout-row .form-inline {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  flex-direction: row;
  height: 40px;
}

.form-row label {
  display: flex;
  gap: 6px;
  color: var(--text);
  flex-direction: column;
}

.form-row input[type="text"],
.form-row input[type="email"],
.form-row input[type="url"],
.form-row input[type="color"],
.form-row input[type="file"],
.form-row select,
.form-row textarea,
.form-row input[type="range"] {
  color: var(--text);
  border-radius: 20px;
  padding: 7px 9px;
  outline: none;
}
#voiceForm label{display:flex;flex-direction: column;gap: 5px;}
.form-row input[type="color"] {
  padding: 0;
  height: 40px;
}

.form-row input[type="range"] {
  padding: 6px;
}

.form-row textarea {
  resize: vertical;
  min-height: 70px;
}

.flyout-row input {
  padding: 1px 2px !important;
  border-radius: 5px !important;
  width: 80px;
}

.flyout-row input[type="text"] {
  padding: 1px 5px !important;
  border-radius: 10px !important;
  width: 100%;
}

/* --admin group select feilds-- */
.flex-3 label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: var(--text);
}

.flex-3 input[type="text"],
.flex-3 input[type="email"],
.flex-3 input[type="url"],
.flex-3 input[type="color"],
.flex-3 input[type="file"],
.flex-3 select,
.flex-3 textarea,
.flex-3 input[type="range"] {
  background: var(--muted);
  color: var(--text);
  border: var(--line);
  border-radius: 20px;
  padding: 8px 8px;
  outline: none;
}

.flex-3 input[type="color"] {
  padding: 0;
  height: 40px;
}

.flex-3 input[type="range"] {
  padding: 6px;
}

.flex-3 textarea {
  resize: vertical;
  min-height: 70px;
}

.toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 0 !important;
}

.toggle input {
  accent-color: var(--primary);
}

.chatbar {
  width: 100%;
}

.avatar-preview {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.avatar-preview img {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: var(--line);
  object-fit: cover;
  background: var(--muted);
  align-self: end;
}

.sliders label {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.code {
  background: var(--btrans);
  border: var(--line);
  border-radius: 10px;
  padding: 10px;
  overflow: auto;
}

#emailDetails .code {
  height: 50vh;
  width: 15vw;
  padding: 3px;
  font-size: .6rem;

  letter-spacing: 1px;
}

#notifPanel.sheet {
  position: fixed;
  top: var(--notif-panel-top, 56px);
  left: var(--notif-panel-left, calc(100vw - 444px));
  right: auto;
  bottom: auto;
  width: min(420px, calc(100vw - 16px));
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  transform: translateY(-8px);
  background: color-mix(in oklab, var(--surface) 92%, transparent);
  border: 1px solid rgba(255, 255, 255, .10);
  border-radius: 18px;
  box-shadow: 0 22px 46px rgba(0, 0, 0, .30);
  display: flex;
  flex-direction: column;
  transition: max-height .26s ease, opacity .2s ease, transform .2s ease;
  z-index: 80;
}

#notifPanel.sheet[hidden] {
  display: none;
}

#notifPanel.sheet:not([hidden]) {
  display: flex;
}

#notifPanel.sheet.is-open {
  max-height: min(70vh, 640px);
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

#notifPanel.sheet.is-closing {
  max-height: 0;
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
}

#notifPanel .sheet-header {
  align-items: flex-start;
  padding: 14px 16px 12px;
  border-bottom: var(--line);
  background: var(--strans);
  color: #fff;
}

#notifPanel .sheet-header h2 {
  margin: 0;
  font-size: 15px;
  font-weight: 800;
}

#notifPanel .sheet-body {
  min-height: 0;
  padding: 12px;
}

#notifGroups {
  display: grid;
  gap: 10px;
  overflow: auto;

}

.notif-empty {
  padding: 18px 14px;
  border-radius: 14px;
  border: 1px dashed rgba(255,255,255,.10);
  color: var(--text-muted);
  text-align: center;
  background: rgba(255,255,255,.02);
}

.notif-item {
  position: relative;
  display: grid;
  gap: 0;
  height: max-content;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  overflow: hidden;
  transition: transform .24s ease, opacity .22s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.notif-item.is-unread {
  border-color: color-mix(in oklab, var(--primary) 60%, rgba(255,255,255,.08));
  box-shadow: inset 3px 0 0 0 color-mix(in oklab, var(--primary) 72%, transparent);
}

.notif-item.is-expanded {
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: 0 12px 30px rgba(0,0,0,.18);
}

.notif-item.is-dismissing {
  transform: translateX(-44px);
  opacity: 0;
  pointer-events: none;
}

.notif-summary{
  width: 100%;
  display: grid;
  gap: 8px;
  text-align: left;
  padding: 12px;
  border: 0;
  background: var(--strans);
  color: inherit;
  cursor: pointer;
}
.notif-preview{display: grid;grid-template-columns: minmax(0, auto) 1fr;align-items:center;gap:10px;grid-auto-flow: column;}
.notif-summary:hover,
.notif-summary:focus-visible {
  background: rgba(255,255,255,.03);
  outline: none;
}

.notif-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 10px;
  width: -webkit-fill-available;
  justify-content: space-between;
}

.notif-title {
  min-width: 0;
  font-weight: 800;
  line-height: 1.3;
}

.notif-time {
  font-size: 11px;
  color: var(--text-muted);
  white-space: nowrap;
  margin-top: 1px;
}


.notif-time.is-detailed {
  color: var(--text);
  font-weight: 700;
  letter-spacing: .01em;
}

.notif-body {
  min-width: 0;
  color: var(--text-muted);
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.notif-expand {
  display: grid;
  grid-template-rows: 0fr;
  opacity: 0;
  margin-top: 0;
  visibility: hidden;
  pointer-events: none;
  height: 0;
  transition:
    grid-template-rows .26s ease,
    opacity .18s ease,
    margin-top .26s ease,
    visibility 0s linear .26s;
}

.notif-item.is-expanded .notif-expand {
  grid-template-rows: 1fr;
  opacity: 1;
  margin-top: 2px;
  visibility: visible;
  pointer-events: auto;
  transition-delay: 0s, 0s, 0s, 0s;
  height: auto;
}

.notif-expand-inner {
  min-height: 0;
  overflow: hidden;
  display: grid;
  gap: 10px;
  padding: 0 12px 12px;
}

.notif-route {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  max-width: 100%;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}

.notif-route-icon {
  width: 20px;
  height: 20px;
  display: inline-grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255,255,255,.06);
  color: var(--primary);
  flex: 0 0 20px;
}

.notif-route-icon i,
.notif-route-icon span {
  font-size: 12px;
  line-height: 1;
}

.notif-route-icon svg {
  width: 14px;
  height: 14px;
  display: block;
}

.notif-route-icon svg[fill="var(--text)"],
.notif-route-icon svg[fill="var(--text-muted)"] {
  fill: currentColor;
}

.notif-route-icon svg[stroke="var(--text)"],
.notif-route-icon svg[stroke="var(--text-muted)"] {
  stroke: currentColor;
}

.notif-route-name {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .02em;
}

.notif-detail-btn {
  width: 100%;
  display: grid;
  gap: 4px;
  text-align: left;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.notif-detail-btn:hover,
.notif-detail-btn:focus-visible {
  border-color: color-mix(in oklab, var(--primary) 40%, rgba(255,255,255,.10));
  background: rgba(255,255,255,.05);
  transform: translateY(-1px);
}

.notif-detail-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--primary) 72%, white);
}

.notif-detail-copy {
  color: var(--text);
  line-height: 1.35;
}

.notif-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.notif-actions .btn.sm {
  min-height: 30px;
}

.notif-load-older-row {
  display: flex;
  justify-content: center;
  padding-top: 2px;
}

.notif-load-older {
  width: 100%;
  justify-content: center;
}

.notif-load-older[disabled] {
  opacity: .72;
  cursor: progress;
}

.notif-target-pulse {
  animation: notifTargetPulse 1.15s ease;
}

@keyframes notifTargetPulse {
  0% {
    box-shadow: 0 0 0 0 color-mix(in oklab, var(--primary) 55%, transparent);
  }

  100% {
    box-shadow: 0 0 0 14px transparent;
  }
}

/* Sheets / Panels */
.sheet {
  position: fixed;
  right: 3px;
  top: 3px;
  bottom: 3px;
  width: 350px;
  background: transparent;
  -webkit-backdrop-filter: var(--backdrop-2);
  backdrop-filter: var(--backdrop-2);
  isolation: isolate;
  border: var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  overflow: auto;
  z-index: 50;
  transform: translateY(-105%);
}

.sheet-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--pad);
  border-bottom: var(--line);
}

.sheet-body {
  padding: var(--pad);
  overflow: auto;
}

/* Command Palette */
.cmdk {
  border: none;
  padding: 0;
  background: transparent;
}

.cmdk::backdrop {
  background: rgba(0, 0, 0, .5);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  isolation: isolate;
}

.cmdk-inner {
  width: min(720px, 92vw);
  background: var(--surface);
  border: var(--line);
  border-radius: 12px;
  padding: 10px;
  box-shadow: var(--shadow);
  color: var(--text);
}

#cmdkInput {
  width: 100%;
  height: 48px;
  border-radius: 10px;
  padding: 0 12px;
  background: var(--muted);
  border: var(--line);
  outline: none;
}

.cmdk-list {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  max-height: 50vh;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.cmdk-list li {
  padding: 10px;
  border-radius: 8px;
}

.cmdk-list li[aria-selected="true"],
.cmdk-list li:hover {
  background: rgba(255, 255, 255, .06);
}

.cmdk-hint {
  color: var(--text-muted);
  font-size: 12px;
  padding: 8px 4px 4px;
  text-align: right;
}

/* Toasts */
.toasts {
  position: fixed;
  right: 12px;
  bottom: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 6000;
}

.toast {
  backdrop-filter: var(--backdrop);
  border: var(--line);
  border-radius: 15px;
  padding: 10px 12px;
  box-shadow: var(--shadow);
}

.toast-bar { display:flex; flex-direction:column; }
.toast-bar {
  position: fixed;
  right: 16px;
  bottom: 16px;
  display: grid;
  gap: 8px;
  z-index: 9999;
}

.toast.banner.error {
  border: 4px solid red
}

.toast.banner.success {
  border: 4px solid var(--primary-dark)
}

.toast.banner.anim-fade-in-down { animation: fadeInDown .20s ease-out both; }
.toast.banner.anim-fade-out-up  { animation: fadeOutUp .20s ease-in both; }
.toast.notification-big { min-width: 360px; max-width: 520px; padding: 14px 16px 14px 14px; border-radius: 10px; box-shadow: var(--elev-3, 0 8px 24px rgba(0,0,0,.16)); font-size: 14px; line-height: 1.35; }
.toast.notification-big{cursor:pointer;}
.toast.notification-big .msg{display: grid; gap:5px; pointer-events:none;}
.toast.notification-big .close-x { position:absolute; top:8px; right:10px; background:none; border:0; font:inherit; cursor:pointer; }
.toast.notification-big .close-x{pointer-events:auto;}
.toast.notification-big.fade-out{opacity:0; transform: translateY(6px); transition: opacity .18s ease, transform .18s ease;}

.toast:not(.banner):not(.notification-big) {
  border-left: 4px solid var(--primary);
  animation: slide-in-out 3.2s ease-in-out forwards;
}

@keyframes fadeInDown { from { opacity:0; transform: translate(-50%, -8px);} to { opacity:1; transform: translate(-50%, 0);} }
@keyframes fadeOutUp   { from { opacity:1; transform: translate(-50%, 0);}   to { opacity:0; transform: translate(-50%, -8px);} }
@keyframes slide-in-out {
  0% {
    transform: translateX(-100vw);
    opacity: 0;
  }

  10% {
    transform: translateX(0);
    opacity: 1;
  }

  90% {
    transform: translateX(0);
    opacity: 1;
  }

  100% {
    transform: translateX(100vw);
    opacity: 0;
  }
}

/* Accessibility & Focus */
:focus-visible {
  border-radius: 10px;
  outline: none;
  outline-offset: 2px;
}

/* Optional: consistent sizing for the confirm panel */
#logoutConfirm .modal-card {
  max-width: 420px;
  width: 100%;
}

#logoutConfirm .modal-body {
  padding: 8px 0 16px;
}

/* Responsive */
@media (min-width: 1440px) {
  .grid-cards {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (max-width: 900px) {

  .dashboard .dash-row,
  .grid-3 {
    grid-template-columns: 1fr;
  }

  .grid-2 {
    grid-template-columns: 1fr;
  }

  .grid-cards {
    grid-template-columns: 1fr 1fr;
  }

  .three-col {
    grid-template-columns: 1fr;
  }

  .split.two {
    grid-template-columns: 1fr;
  }

  .sidebar.open {
    transform: translateX(0);
  }

  .app-body {
    grid-template-columns: 1fr;
    grid-template-areas: "main";
  }

  .sidebar {
    position: fixed;
    visibility: visible !important;
    pointer-events: auto !important;
    top: 10px;
    bottom: 0;
    left: 10px;
    width: var(--sidebar-w);
    max-width: 80vw;
    height: auto;
    background: var(--surface, #111418);
    transform: translateX(-100%);
    z-index: 1100;
    transition:
      transform .2s ease;
  }

  body.sidebar-open .sidebar {
    transform: translateX(0);
  }

  /* Scrim blocks background clicks and dims content */
  #sbScrim {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .35);
    z-index: 999;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
  }

  body.sidebar-open #sbScrim {
    opacity: 1;
    pointer-events: auto;
  }

  /* Prevent content squeeze class from doing anything on mobile */
  .app-body.sidebar-collapsed {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  html,
  body {
    min-height: 100%;
    overflow: hidden;
  }

  body {
    background:
      radial-gradient(620px 420px at 18% 10%, color-mix(in srgb, var(--primary, #00d4ff) 28%, transparent), transparent 62%),
      radial-gradient(520px 360px at 85% 92%, rgba(255, 255, 255, .08), transparent 58%),
      var(--bg);
  }

  body::before {
    content: "Unobits is built for desktop right now. Please use a larger screen or download the mobile app when it becomes available.";
    position: fixed;
    inset: 0;
    z-index: 2147483647;
    display: grid;
    place-items: center;
    padding: 28px;
    color: var(--text);
    text-align: center;
    font: 800 clamp(20px, 6vw, 34px)/1.15 'DM Sans', ui-sans-serif, system-ui, sans-serif;
    letter-spacing: -.03em;
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--bg) 84%, transparent), var(--bg)),
      radial-gradient(560px 360px at 50% 20%, color-mix(in srgb, var(--primary, #00d4ff) 20%, transparent), transparent 68%);
  }

  #app,
  .app-loader,
  dialog,
  .sheet,
  .toasts {
    display: none !important;
  }
}

/* --- Admin Users Manager (scoped) --- */
#adminUsersCard .priv-checks {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 6px;
  padding: 8px;
  background: rgba(255, 255, 255, .03);
  border: var(--line);
  border-radius: 8px;
}

#adminUsersCard .priv-checks label {
  display: flex;
  align-items: center;
  gap: 8px;
}

#adminUsersCard .form-inline {
  display: flex;
  gap: 8px;
  align-items: center;
}

/* Multi-select dropdown (Admin Users) */
#adminUsersCard details.ms {
  position: relative;
}

#adminUsersCard details.ms .ms-trigger {
  cursor: pointer;
}

#adminUsersCard details.ms .ms-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  width: 100%;
  max-height: 260px;
  overflow: auto;
  background: var(--surface);
  border: var(--line);
  border-radius: 8px;
  padding: 8px;
  box-shadow: var(--shadow);
  z-index: 20;
}

#adminUsersCard details.ms[open] .ms-menu {
  display: block;
}

#adminUsersCard .ms-menu .row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 4px;
}

#adminUsersCard .ms-menu label {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
}

#adminUsersCard .ms-menu strong {
  font-weight: 600;
}

#adminUsersCard .ms-menu small {
  color: var(--text-muted);
  display: block;
}

.list-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 4px;
  cursor: pointer;
}
.avatar.sm {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  padding: 1px;
  object-fit: cover;
  background: var(--bgblur);
  display: inline-block;
}

.avatar.sm.initials {
  display: inline-grid;
  place-items: center;
  font-weight: 600;
  color: #374151;
  padding: 10px;
  align-content: center;
}

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

.chip.perm {
  display: inline-block;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  padding: .15rem .5rem;
  font-size: .8rem;
  margin: .1rem .25rem .1rem 0
}

.perm-wrap .chips {
  display: inline
}

.perm-wrap .chips.extra {
  margin-left: .5rem
}

.link-btn {
  background: none;
  border: none;
  color: #2563eb;
  cursor: pointer;
  font-size: .85rem
}

.btn.xs {
  padding: .25rem .5rem;
  font-size: .8rem;
  border-radius: .375rem;
  border: 1px solid #e5e7eb;
  background: #f9fafb
}

.btn.xs.warn {
  color: #92400e;
  border-color: #fcd34d;
  background: #fffbeb
}

.btn.xs.danger {
  color: #991b1b;
  border-color: #fecaca;
  background: #fef2f2
}

tr.is-disabled {
  opacity: .6
}

input[type="password" i] {
  background: var(--primary-faded);
  border-radius: 20px;
  color: var(--bg);
}

.form-row-2 {
  display: grid;
  grid-template-columns: auto auto;
  gap: 8px;
  align-items: center;
  margin-bottom: 12px;
}

.form-row-3 {
  display: grid;
  grid-template-columns: 1.5fr 1.5fr 2.5fr;
  gap: 8px;
  align-items: center;
  margin-bottom: 12px;
}

.stack {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap);
}
.stack .field{
  display:flex;
  width: 100%;
  justify-content: space-between;
}

#listModalList.stack {
  display: block;
}

input#profileName,
input#profileEmail {
  background: var(--primary-faded);
  padding-left: 5px;
  border-radius: 10px;
}

/* Modal */
dialog::backdrop {
  background: rgba(0, 0, 0, .1);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  isolation: isolate;
}

dialog.user-modal {
  border: none;
  padding: 0;
}

.user-modal .modal-card {
  width: min(300px, 92vw);
  background: var(--surface);
  border-radius: 12px;
  box-shadow: var(--shadow);
  padding: var(--pad);
  box-shadow: inset 1px 1px 18px 2px var(--primary-faded);
}

#backToBottom {
  transform: translateZ(0);
  transition: transform .18s ease, color .18s ease, opacity .18s ease, background .18s ease, box-shadow .18s ease;
  color: var(--muted);
  border-radius: 999px;
  bottom: 2%;
  display: inline-flex;
  position: absolute;
  right: 30px;
  padding: 0 4px;
  background: var(--primary-dark);
  font-size: 11px;
  width: 23px;
  min-width: 23px;
  height: 23px;
  z-index: 10;
  justify-content: center;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  box-shadow: 0 10px 20px rgba(0, 0, 0, .14);
}

#backToBottom.pill {
  width: auto;
  min-width: 110px;
  height: 30px;
  padding: 0 12px;
  right: 24px;
  font-weight: 700;
}

#backToBottom[data-mode="new"] {
  color: var(--bg);
}

#backToBottom[hidden] {
  display: none;
}

#backToBottom:hover {
  transform: translateY(-1px) scale(1.06);
  color: var(--bg);
}

#backToBottom .bi {
  font-size: 15px;
  width: 15px;
  padding: 5px;
  display: flex;
  vertical-align: middle;
  justify-content: center;
}

#backToBottom.pill .bi {
  width: auto;
  padding: 0;
}

dialog {
  background: transparent;
  background-blend-mode: hue;
  border-radius: 15px;
  border: none;
  color: var(
  --text);
  }

dialog#logoutConfirm .modal {
  background: var(--surface);
}

dialog:not([open]) {
  display: none
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--text);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.modal-body {
  color: var(--text);
}

.user-modal header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

.user-modal .muted {
  margin-top: 4px;
}

.message-bubble .plain-text {
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--text);
}

.thread-actions {
  position: absolute;
  display: flex;
  bottom: 5px;
  padding: 3px;
  width: 100%;
  border-radius: 15px;
  pointer-events: none;
  justify-content: space-between;
  align-items: flex-end;
}

.thread-actions-inner {
  display: flex;
  height: fit-content;
  gap: .31rem;
  position: relative;
  -webkit-backdrop-filter: var(--backdrop);
  backdrop-filter: var(--backdrop);
  isolation: isolate;
  border-radius: 15px;
  padding: 3px;
  pointer-events: all
}

.kv {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  overflow: auto;
}

.kv-row {
  display: flex;
  gap: 5px;
  align-items: baseline;
  flex-direction: column;
  margin-bottom: 1px;
  background: var(--dots);
  border-radius: 5px;
  padding: 5px 5px;
}

.kv-row .k {
  width: 110px;
  color: var(--text-muted);
  font-size: .9em;
  text-decoration: underline;
}

.kv-row .v {
  flex: 1;
  word-break: break-word;
  font: status-bar;
}

.mt-sm {
  margin-top: 8px;
}

/*#emailList.selectable {overflow:auto; width: 166px;}*/
.topbar #roleSelect {
  display: none !important;
}

.mail.three-col {
  margin: 0;
  margin-right: -6px;
}

#noteMeta {
  margin-top: 0;
  padding: 0 7px;
  font-size: 10px;
}

.mail.left-panel {
  background: transparent;
  padding: 5px 5px 0 0;
  display: flex;
  min-height: 0;
  height: -webkit-fill-available;
  overflow-x: hidden;
  flex-direction: column;
}

#emailList.list.selectable {
  list-style: none;
  margin: 0;
  padding: 2px 5px 0 2px;
  margin-right: -5px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 0;
  height: -webkit-fill-available;
  overflow: auto;
}

#emailMailboxName.truncate {
  font-size: 1.1rem;
  margin: 0;
  color: var(--text);
}

.mail.right-actions {
  display: flex;
  margin-left: auto;
  padding-right: 5px;
  gap: .3rem;
  position: relative;
}
#emailToggleDetails{
  padding: 3px 5px;
}
#emailToggleDetails.edge{
  position: fixed;
  right: 18px;
  top: 12px;
}
#emailToggleDetails i{font-size:18px}

.meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.mail .chip {
  padding: 4px 9px;
}

/* === HTML Email bubble (isolated via iframe) === */
:root {
  --email-bubble-w: min(680px, 100%);
}

#chatInfo {
  display: flex;
  flex-direction: column;
  padding: 60px 8px 0;
  position: relative;
  overflow: auto;
  min-height: 0;
  height: -webkit-fill-available;
}

.chat-btns {
  display: flex;
  gap: 3px;
  font-size: 13px;
}

.email-frame-wrap {
  position: relative;
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
  border: var(--line);
  color: var(--surface) !important;
}

/* === Attachments grid === */
.attachments {
  margin-top: 10px;
}

.attch-card {
  position: relative;
  border: var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, .03);
  overflow: hidden;
  cursor: pointer;
}

.attch-card .attch-thumb {
  aspect-ratio: 4/3;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: var(--muted);
}

.attch-card .attch-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.attch-card .file-icon {
  font-weight: 700;
  letter-spacing: .03em;
  font-size: 14px;
  color: var(--text-muted);
}

.attch-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  padding: 6px 8px;
  font-size: 12px;
  color: var(--text-muted);
}

#pmPeopleDialog {
  transform: translateY(0)
}

.attch-actions {
  position: absolute;
  left: 6px;
  right: 6px;
  bottom: 6px;
  display: none;
  gap: 6px;
  flex-wrap: wrap;
  padding: 6px;
  border-radius: 8px;
  background: rgba(0, 0, 0, .55);
  border: var(--line);
}

.attch-card[aria-expanded="true"] .attch-actions {
  display: flex;
}

.attch-card[data-saved="1"] .attch-actions .att-save {
  opacity: .6;
  pointer-events: none;
}

/* Busy state for action buttons */
.is-busy {
  opacity: .6;
  pointer-events: none;
}

/* Spinner overlay (requested for API-controlled buttons)
   - Only applies to actual buttons/links styled as .btn to avoid affecting other busy elements.
*/
button.is-busy,
.btn.is-busy,
[role="button"].is-busy {
  position: relative;
}

button.is-busy::after,
.btn.is-busy::after,
[role="button"].is-busy::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 16px;
  height: 16px;
  margin-left: -8px;
  margin-top: -8px;
  border-radius: 999px;
  border: 2px solid currentColor;
  border-top-color: var(--primary);
  opacity: .55;
  animation: puSpin .9s linear infinite;
  pointer-events: none;
}

[aria-busy="true"] {
  cursor: progress !important;
}

/* Base style for all placeholder elements */
.file-hero .placeholder {
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.file-hero .placeholder[data-icon="doc"] {
  background: url('/assets/img/filetypes/doc.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="sheet"] {
  background: url('/assets/img/filetypes/sheet.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="file"] {
  background: url('/assets/img/filetypes/file.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="pdf"] {
  background: url('/assets/img/filetypes/pdf.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="slide"] {
  background: url('/assets/img/filetypes/slide.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="ppt"] {
  background: url('/assets/img/filetypes/ppt.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="image"] {
  background: url('/assets/img/filetypes/image.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="archive"] {
  background: url('/assets/img/filetypes/archive.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="zip"] {
  background: url('/assets/img/filetypes/zip.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="code"] {
  background: url('/assets/img/filetypes/code.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="design"] {
  background: url('/assets/img/filetypes/design.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="audio"] {
  background: url('/assets/img/filetypes/audio.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="video"] {
  background: url('/assets/img/filetypes/video.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon="text"] {
  background: url('/assets/img/filetypes/text.svg') center/contain no-repeat;
}

.file-hero .placeholder[data-icon=""] {
  background: url('/assets/img/filetypes/unknown.svg') center/contain no-repeat;
}

.media-missing {
  background: url('/assets/img/filetypes/missing.svg') center/contain no-repeat;
}

/* Ensure main has positioning context for the overlay */
.main {
  position: relative;
}

/* Optional: tweak messages look for Donna */
#assistantMessages .message .meta {
  font-size: 11px;
  margin-bottom: 4px;
}

#assistantMessages .message .plain-text {
  white-space: pre-wrap;
  word-break: break-word;
}

.info.icon-btn {
  position: fixed;
  bottom: 10px;
  width: 30px;
  height: 30px;
  right: 10px;
  z-index: 99999999;
}

/* Liquid sidebar and container that wraps items under each nav section */
#sidebar .nav-group {
  margin: 0px 0 0px -6px;
  display: block;
  border-radius: 10px;
}

#sidebar .nav-group-title .nav-icon {
  display: none;
}

#sidebar .nav-group .nav-group-list {
  list-style: none;
  padding-left: 10px;
  margin: 0;
  display: grid;
  gap: 6px;
}

.sidebar-icon .nav-group-title {
  display: flex;
  gap: 8px;
  padding: 3px 5px;
  border-radius: 10px;
  background: var(--strans);
  border: var(--line);
  align-items: center;
  justify-content: center;
}

.sidebar-icon .sidebar .label {
  display: none;
}

.Admin.card {
  height: 91vh;
  overflow: auto;

}

.admin-view {
  display: grid;
  gap: 8px;
  width: 100%;
  height: -webkit-fill-available;
}

.admin-topnav {
  display: flex;
  gap: .5rem;
  margin-bottom: 12px;
}

.admin-topnav .tab {
  border: 1px solid var(--line);
  background: var(--panel-2);
  padding: .45rem .75rem;
  border-radius: 8px;
  cursor: pointer;
}

.admin-topnav .tab.active {
  background: var(--panel-3);
  border-color: var(--primary-faded);
}

/* Scroll-top pill (chat older loader) */
.scroll-pill {
  position: sticky;
  top: 0;
  align-self: start;
  margin: 6px auto 8px;
  z-index: 2;
  border: 1px solid var(--line);
  background: var(--panel-2);
  padding: 2px 8px;
  border-radius: 999px;
  font-size: .85rem;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.scroll-pill .loading-dots {
  display: inline-flex;
  gap: 4px;
  line-height: 0;
}

.scroll-pill .loading-dots i {
  width: 6px;
  height: 6px;
  border-radius: 20px;
  background: currentColor;
  opacity: .7;
  animation: ldb 1s infinite both;
}

.scroll-pill .loading-dots i:nth-child(2) {
  animation-delay: .15s;
}

.scroll-pill .loading-dots i:nth-child(3) {
  animation-delay: .3s;
}

@keyframes ldb {

  0%,
  80%,
  100% {
    transform: scale(.6);
    opacity: .4;
  }

  40% {
    transform: scale(1);
    opacity: 1;
  }
}


/* Hide section heading text in icon-only (closed) mode */
.sidebar-icon #sidebar .nav-group .nav-group-list {
  display: none;
}

/* Keep group subtle in icon-only mode */
.sidebar-icon #sidebar .nav-group {
  padding: 5px;
  width: fit-content;
  margin: 0;
}

/* Small dot on nav items that have data-new */
.nav-group-list a[data-new]::after {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--primary);
  display: inline-block;
  margin-left: .4rem;
  vertical-align: middle;
}

/* Active icon highlight when sidebar is closed (icon-only) */
.sidebar-icon #sidebar .nav-link.active> :first-child {
  box-shadow: 0 0 2px 2px var(--primary), inset 0 0 0 2px var(--primary-faded);
  outline: 2px solid var(--primary-faded);
  transform: scale(1.08);
}

/* Ensure icons animate smoothly (used by liquid magnify) */
.sidebar-icon #sidebar .nav-link> :first-child {
  transition: transform .22s ease, filter .12s ease, box-shadow .12s ease;
  will-change: transform, filter, box-shadow;
}

/* Numeric nav badges */
.nav-group-list a.nav-link[data-new="1"] {
  position: relative;
}

.nav-group-list a.nav-link[data-new="1"]::after,
.nav-group-list a[data-has-new="1"]::after,
nav a[data-has-new="1"]::after {
  content: attr(data-new-count);
  position: absolute;
  top: 8px;
  right: 6px;
  min-width: 14px;
  height: 13px;
  padding: 0 2px;
  border-radius: 999px;
  background: var(--danger);
  color: #fff;
  box-shadow: 0 0 0 2px var(--surface, #fff);
  display: inline-flex;
  justify-content: center;
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.01em;
  pointer-events: none;
  align-items: center;
}

.dm-row {
  display: flex;
  align-items: center;
  gap: .5rem;
}

.dm-meta {
  flex: 1;
  min-width: 0;
}

.dm-time {
  font-size: 9px;
  margin-left: .5rem;
}

.composer-box {
  display: flex;
  flex-direction: column;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  gap: 2px;
  pointer-events: none;
  z-index: 10;
  align-items: center;
}

/* ── Web Elements (we-*) ───────────────────────────────────────────────────────── */
.we-layout {
  gap: var(--gap);
}

.we-layout .toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
}

.we-layout .toolbar .spacer {
  flex: 1 1 auto;
}

.we-layout .toolbar .icon-btn[aria-busy="true"] {
  opacity: .6;
  pointer-events: none;
}

.we-layout #weLastRefresh {
  font-size: 12px;
  color: var(--text-muted);
}

.we-templates-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--gap);
}

.we-templates-grid .tpl-card {
  border: var(--line);
  border-radius: var(--radius);
  padding: 12px;
  background: var(--muted);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.we-templates-grid .tpl-card header {
  font-weight: 600;
}

.we-templates-grid .tpl-card .muted {
  font-size: 12px;
  color: var(--text-muted);
}

.we-templates-grid .tpl-card .btn-row {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

.we-templates-grid .tpl-card button {
  font-size: 12px;
}

.we-editor-open .three-col {
  grid-template-columns: var(--col-left, 1fr) 0fr var(--col-right, 3fr);
}
.right-panel{
  border-radius: 0 15px 15px 0;
  border-left: 0;
}
.right-panel[hidden] {
  display: none;
}

.editor-split {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--gap);
  align-items: start;
}

.mini-preview {
  background: var(--surface);
  border: var(--line);
  border-radius: 10px;
  padding: 12px;
  min-height: 180px;
}

.prop-panel {
  background: var(--surface);
  border: var(--line);
  border-radius: 10px;
  padding: 12px;
  max-height: 60vh;
  overflow: auto;
}

.prop-panel .section {
  margin-bottom: 12px;
}

.prop-panel .section header {
  font-weight: 600;
  margin-bottom: 6px;
}

.prop-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.prop-grid label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12px;
}

.prop-grid input[type="range"] {
  width: 100%;
}

.prop-grid input[type="number"] {
  width: 100%;
}

.prop-grid select,
.prop-grid input,
.prop-grid textarea {
  width: 100%;
}

/* Code mode */
.editor-body.code-mode .editor-split {
  display: none;
}

.code-editor {
  display: block;
}

.code-editor textarea {
  width: 100%;
  min-height: 220px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px;
}

.code-editor .btn-row {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 8px;
}

.editor-body .form label {
  display: block;
  margin: 10px 0 6px;
  font-weight: 600;
}

.editor-body .form input[type="text"],
.editor-body .form input[type="number"],
.editor-body .form input[type="url"],
.editor-body .form textarea,
.editor-body .form select {
  width: 100%;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #0e1116;
  color: var(--text);
}

.preview-wrap.expanded {
  position: fixed;
  inset: 0;
  z-index: 999;
  padding: 2px;
  padding-top: 16px;
  background: rgba(0, 0, 0, 0.85);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.preview-wrap.expanded .we-preview-stage {
  max-width: 1280px;
  /* margin: 0 auto; */
  height: 90vh;
}

/* Parent row with caret */
.sidebar-icon .nav-group .nav-group-title {
  width: 28px;
  margin: 8px 0 5px;
  border: 0;
  gap: 0;
  box-shadow: var(--shadow);
}

.sidebar-icon .nav-group.has-active .nav-group-title{outline: 2px solid var(--primary);padding: 3px 4px;box-shadow: 0 0 0 1px color-mix(in oklab, var(--primary) 22%, transparent);}

.sidebar-icon #sidebar .s-icons {
  scale: 1;
  transition: scale .3s ease-out;
  background: transparent;
}

.sidebar-icon #sidebar .s-icons:hover {
  scale: 1.2;
  transition: scale .3s ease
}

.dashboard {
  height: 100.5vh;
}

.dashboard-icon {
  border-radius: 15px;
  padding: 5px 0 0 5px;
  background: none;
  align-items: center;
}

.sidebar-icon .dashboard-icon {
  background: var(--strans);
  padding: 3px;
  margin: 10px 0;
  width: 30px;
  box-shadow: var(--shadow);
  align-self: anchor-center;
}

.sidebar-icon .nav-group-title {
  border-radius: 15px;
  font-size: 0;
}

.nav-group-title {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px;
  border-radius: 6px;
  letter-spacing: .2px;
  color: var(--text-muted);
  font-size: 9px;
  margin: 10px 5px 0;
  text-transform: uppercase;
}

.nav-group-label {
  min-width: 0;
  width: -webkit-fill-available;
  flex: 1 1 auto;
}

.nav-group-mark {
  display: none;
  width: 22px;
  height: 22px;
  align-items: center;
  justify-content: center;
  flex: 0 0 22px;
}

.nav-group-mark svg,
.nav-group-mark .nav-icon {
  width: 18px;
  height: 18px;
  display: block;
}

#sidebar .nav-group-title .nav-group-mark .nav-icon {
  display: block;
}

.sidebar-icon #sidebar .nav-group-title .nav-group-mark {
  display: inline-flex;
}

#sidebar .nav-group-title .s-icons {display:none}
.sidebar-icon #sidebar .nav-group-title .s-icons {display:flex}


.toggle-scope,
.new-convo {
  width: 25px;
  height: 25px;
  display: grid;
  place-items: center;
  justify-content: center;
  background: var(--primary-faded);
  color: var(--text);
  border: var(--line);
  border-radius: 20px;
}

/* === Icon-only flyout (right aligned) === */
#sbFlyout {
  position: fixed;
  display: block;
  z-index: 200000;
  transform: none;
  background: var(--side) ,color-mix(in oklab, var(--bg), transparent);
  -webkit-backdrop-filter: var(--backdrop-2);
  backdrop-filter: var(--backdrop-2);
  isolation: isolate;
  border: var(--line);
  border-left: none;
  border-radius: 18px 18px;
  min-width: 220px;
  max-width: 330px;
  overflow: visible;
  box-shadow: 18px 22px 44px rgba(0, 0, 0, .24);
}

#sbFlyout::before {
  content: '';
  position: absolute;
  left: -46px;
  top: var(--sb-fly-anchor-top, -0.52px); /* <-- Now Javascript controls it */
  height: 42px;
  width: 45px;
  isolation: isolate;
  border-top: var(--line);
  border-bottom: var(--line);
  border-left: var(--line);
  border-right: none;
  border-radius: 14px 0 0 14px;
  z-index: 1;
}

#sbFlyout[hidden] {
  display: none;
}

#sbFlyout .sb-fly-caret {
  margin-left: auto;
  display: inline-flex;
  opacity: .65;
}

#sbFlyout .title {
  font-weight: 800;
  padding: 10px 12px 8px;
}

#sbFlyout .body {
  padding: 8px 8px 10px;
  height: auto;
  max-height: 70vh;
  overflow: auto;
  margin-bottom: 0;
  gap: 4px;
  display: flex;
  flex-direction: column;
}

#sbFlyout .body .nav-link {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 10px;
}

#sbFlyout .body .nav-link:hover .label {
  box-shadow: none !important;
}

#sbFlyout .body .nav-link:hover {
  background: rgba(255, 255, 255, .06);
  margin-right: 0;
  width: auto;
}

#sbFlyout .body .nav-link:hover .s-icons {
  color: var(--primary);
}

/* Active route styling inside flyout (matches main sidebar behavior) */
#sbFlyout .body .nav-link.active,
#sbFlyout .body .nav-link[aria-current="page"] {
  background: var(--primary-faded);
  margin-right: 0;
  width: auto;
}

#sbFlyout .body .nav-link.active .s-icons,
#sbFlyout .body .nav-link[aria-current="page"] .s-icons {
  color: var(--primary);
}

#sbFlyout .arrow {
  display: none;
}

#sbFlyout .toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 10px;
}

#sbFlyout .toggle-row:hover {
  background: rgba(255, 255, 255, .06);
}

#sbFlyout .toggle-row .switch {
  display: inline-flex;
  align-items: center;
}

#sbFlyout .toggle-row .switch input {
  width: 36px;
  height: 18px;
}

/* =========================
   Dynamic Sidebar (s-icons + Advanced mode)
   ========================= */
#sidebar .s-icons{
  width: 22px;
  height: 22px;
  align-items:center;
  background: var(--strans);
  padding: 2px;
  border-radius: 12px;
  color: var(--text);
}
#sidebar .s-icons svg{
  width: 18px;
  height: 14px;
}
.sidebar-icon #sidebar .s-icons svg{
  width: 20px;
  height: 20px;
}
#sidebar .s-icons svg[fill="var(--text)"],
#sidebar .s-icons svg[fill="var(--text-muted)"]{
  fill:currentColor;
}
#sidebar .s-icons svg[stroke="var(--text)"],
#sidebar .s-icons svg[stroke="var(--text-muted)"]{
  stroke:currentColor;
}
#sidebar .nav-link.active .s-icons{ color:var(--primary); }
#sidebar .nav-link:hover .s-icons{ color:var(--primary); }

/* In icon-only mode the group label is hidden, so make sure the group icon is visible */
.sidebar-icon #sidebar .nav-group-title .nav-icon{ display:block; }

/* Advanced sidebar: parent → children tree */
body.sidebar-advanced #sidebar .nav-parent{
  position:relative;
}
body.sidebar-advanced #sidebar .nav-parent > .nav-link{
  padding-right:34px;
}
body.sidebar-advanced #sidebar .nav-child-toggle{
  position:absolute;
  right: 10px;
  top:3px;
  width: 25px;
  height: 25px;
  border:none;
  background:transparent;
  color:var(--text-muted);
  border-radius:10px;
  cursor:pointer;
  display:grid;
  place-items:center;
}
body.sidebar-advanced #sidebar .nav-child-toggle:hover{
  background:rgba(255,255,255,.06);
  color:var(--text);
}
body.sidebar-advanced #sidebar .nav-child-toggle svg{
  width: 15px;
  height: 17px;
  transition:transform .18s ease;
}
body.sidebar-advanced #sidebar .nav-parent.is-expanded > .nav-child-toggle svg{
  transform:rotate(90deg);
}

body.sidebar-advanced #sidebar .nav-parent.has-children > .nav-parent-link{
  padding-right:34px;
}
body.sidebar-advanced #sidebar .nav-parent.has-active-child > .nav-parent-link{
  background: var(--strans);
  border-top: 2px solid var(--primary-faded);
}
body.sidebar-advanced #sidebar .nav-child-toggle.is-expanded{
  color: var(--primary);
  background: color-mix(in oklab, var(--primary) 12%, transparent);
}
body.sidebar-advanced #sidebar .nav-child-list.is-expanded{
  display:grid;
}
body.sidebar-advanced #sidebar .nav-child-list.is-collapsed{
  display:none;
}
body.sidebar-advanced #sidebar .nav-child-list{
  margin: 0 0 0 8px;
  padding: 4px 0 2px 0;
  display:grid;
  gap:2px;
  position:relative;
  list-style: none;
}
body.sidebar-advanced #sidebar .nav-child-list::before{
  content:'';
  position:absolute;
  left:6px;
  top:4px;
  bottom:8px;
  width:1px;
  background: var(--primary-faded);
}
body.sidebar-advanced #sidebar .nav-child-list > li{
  position:relative;
  padding-left:8px;
}
body.sidebar-advanced #sidebar .nav-child-link{
  padding: 6px 2px;
  font-size: 10px;
  opacity: 0.95;
}
body.sidebar-advanced #sidebar .nav-child-link .s-icons{
  width:14px;
  height: 14px;
  flex: 0 0 14px;
}
body.sidebar-advanced #sidebar .nav-child-link .s-icons svg{
  width: 10px;
  height: 10px;
  flex: 0 0 10px;
}

/* Flyout: show children (advanced mode) */
#sbFlyout .flyout-children{
  margin-left:28px;
  padding-left:12px;
  border-left:1px solid rgba(255,255,255,.12);
  display:grid;
  gap:2px;
  margin-top:-2px;
  margin-bottom:6px;
}
#sbFlyout .nav-link.flyout-child{
  font-size:12px;
  padding:6px 8px;
  opacity:.92;
}

/* Mobile: topbar sidebar toggle button */
.sidebar-toggle-top{ display:none; }
@media (max-width: 900px){
  .sidebar-toggle-top{ display:inline-grid; }
}

/* =========================
   Command Center (split layout)
   ========================= */
.cmdk{ padding:0; border:none; background:transparent; color:var(--text); }
.cmdk::backdrop{ background:rgba(0,0,0,.55); }

.cmdk-shell{
  width:min(980px, 94vw);
  max-height:92vh;
  overflow:hidden;
  background: var(--bg);
  border:var(--line);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:12px;
}

.cmdk-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:2px 2px 10px;
  border-bottom:var(--line);
}
.cmdk-title{ font-weight:800; font-size:14px; }
.cmdk-sub{ font-size:12px; color:var(--text-muted); }

#cmdkInput{
  width:min(420px, 48vw);
}

.cmdk-grid{
  display:grid;
  grid-template-columns:1.7fr 1fr;
  gap:12px;
  padding-top:12px;
}
@media (max-width: 760px){
  .cmdk-head{ flex-direction:column; align-items:stretch; }
  #cmdkInput{ width:100%; }
  .cmdk-grid{ grid-template-columns:1fr; }
}

.cmdk-pane{
  border:var(--line);
  border-radius:12px;
  overflow:hidden;
  background:rgba(255,255,255,.02);
  min-height:220px;
}
.cmdk-pane-head{
  padding:10px;
  border-bottom:var(--line);
  display:flex;
  flex-direction:column;
  gap:2px;
}
.cmdk-pane-title{ font-weight:800; font-size:12px; }
.cmdk-pane-hint{ font-size:11px; color:var(--text-muted); }

.cmdk-list{
  list-style:none;
  margin:0;
  padding:10px;
  max-height:62vh;
  overflow:auto;
  display:grid;
  gap:8px;
}

.cmdk-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 10px;
  border:var(--line);
  border-radius:12px;
  background:rgba(255,255,255,.02);
  cursor:pointer;
}
.cmdk-item:hover{
  background:rgba(255,255,255,.06);
}
.cmdk-item-title{
  font-weight:700;
  font-size:12px;
}
.cmdk-item-meta{
  font-size:11px;
  color:var(--text-muted);
  margin-top:2px;
}
.cmdk-item-keys{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.cmdk-key{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:3px 7px;
  border:var(--line);
  border-radius:10px;
  background:var(--muted);
  font-size:11px;
  color:var(--text);
  white-space:nowrap;
}

.cmdk-footer{
  padding-top:10px;
  font-size:11px;
  color:var(--text-muted);
  text-align:right;
}

/* Ensure CMDK styling maps to the new dynamic dialog wrapper */
dialog.cmdk {
  background: transparent !important;
  box-shadow: none !important;
  padding: 0;
}
dialog.cmdk::backdrop {
  background: rgba(0,0,0,0.4);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.cmdk-item.selected {
  background: color-mix(in srgb, var(--primary) 15%, transparent);
  border-color: color-mix(in srgb, var(--primary) 35%, transparent);
}

/* ===== Onboarding Wizard (v1) ===== */

/* Reduce distractions during first-time setup */
.is-onboarding .app-body{grid-template-columns: 0 1fr !important;}
.is-onboarding #sidebar{ display: none !important; }
.is-onboarding .topbar{ display: none !important; }

.onboard{
  display: none;
  width: 100%;
  height: 100%;
  background: none;
  border-radius: 0;
  overflow: hidden;
  padding: 0;
  transform-origin: none;
  backface-visibility: hidden;
  will-change: transform, opacity, clip-path, filter;
  scrollbar-width: none;
}

.onboard-shell{
  min-height: calc(100vh - 40px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 24px;
}
.onboard-card{
  display: flex;
  width: 80%;
  max-width: 860px;
  border: var(--line);
  border-radius: 16px;
  flex-direction: column;
  height: 90vh;
  overflow: hidden;
  justify-content: space-between;
}
.onboard-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 6px 0;
}
.onboard-brand{ display:flex; align-items:center; gap: 12px; }
.onboard-mark{width: 40px;height: 40px;border-radius: 12px;border: var(--line);}
.onboard-meta{ display:flex; gap: 10px; align-items:center; }

.onboard-progress{padding: 10px 0px;}
.onboard-progress .bar{
  height: 6px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--strans);
  border: var(--line);
}
.onboard-progress .bar-fill{
  height: 100%;
  width: 0%;
  background: var(--primary);
  transition: width .2s ease;
}
.onboard-progress .dots{display:flex;gap: 6px;padding-top: 8px;justify-content:center;}
.onboard-progress .dot{ width: 8px; height: 8px; border-radius: 999px; background: rgba(255,255,255,.22); }
.onboard-progress .dot.active{ background: var(--primary); }

.onboard-form{padding: 10px 18px 12px;display: flex;flex-direction: column;gap: 10px;}
.onboard-steps{display: flex; flex-direction: column; min-height: 0; height: -webkit-fill-available;}
.onboard-step{display: flex; flex-direction: column; gap: 5px;}
.onboard-step[hidden] {display:none}
.onboard-step h2{ margin: 10px 0 6px; font-size: 1.25rem; }
.onboard-step p{ margin: 0 0 8px; }

.onboard-options{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.onboard-options.two{ grid-template-columns: repeat(2, minmax(190px, 1fr)); }

.onboard-option{
  text-align:left;
  padding: 12px 12px;
  border: var(--line);
  border-radius: 14px;
  background: rgba(255,255,255,.03);
  cursor: pointer;
  transition: transform .06s ease, border-color .12s ease, background .12s ease;
}
.onboard-option:hover{ transform: translateY(-1px); border-color: var(--primary-faded); background: rgba(255,255,255,.04); }
.onboard-option.selected{ border-color: var(--primary); box-shadow: 0 0 0 1px var(--primary-faded) inset; }
.onboard-option strong{ display:block; font-size: .81rem; }
.onboard-option .muted{ display:block; margin-top: 4px; font-size: .7rem; }

.onboard-actions{ display:flex; justify-content:space-between; gap: 10px; }
.onboard-actions .btn.disabled,
.onboard-actions .btn[disabled]{opacity: .55;pointer-events: none;}

.onboard-build{
  display:flex;
  gap: 14px;
  align-items:flex-start;
  margin-top: 14px;
  padding: 12px;
  border: var(--line);
  border-radius: 14px;
  background: rgba(255,255,255,.02);
}
.onboard-build .spinner{
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 3px solid rgba(255,255,255,.18);
  border-top-color: var(--primary);
  animation: puSpin 1s linear infinite;
  margin-top: 2px;
}
@keyframes puSpin{ to{ transform: rotate(360deg); } }

.onboard-build-list{ list-style: none; padding: 0; margin: 0; display:grid; gap: 8px; }
.onboard-build-list li{ display:flex; align-items:center; gap: 10px; color: var(--text-muted); }
.onboard-build-list li .bullet{ width: 9px; height: 9px; border-radius: 999px; background: rgba(255,255,255,.18); }
.onboard-build-list li.done{ color: var(--text); }
.onboard-build-list li.done .bullet{ background: var(--primary); }

.onboard-footer{ padding: 10px 18px 16px; border-top: var(--line); display:flex; justify-content:flex-end; }
.onboard-locked{padding: 16px 18px;margin: 16px 18px 0;border: var(--line);border-radius: 14px;background: rgba(255,255,255,.02);}

.onboard-meta-left{ display:flex; align-items:center; gap: 10px; }

.onboard-search{ margin-top: 10px; }
.onboard-search input{
  width: 100%;
  padding: 10px 12px;
  border: var(--line);
  border-radius: 12px;
  background: rgba(255,255,255,.02);
  color: var(--text);
  outline: none;
}
.onboard-search input::placeholder{ color: rgba(255,255,255,.45); }

.onboard-scroll{
  margin-top: 12px;
  max-height: 360px;
  overflow:auto;
  padding-right: 4px;
}

.onboard-cat{ margin-top: 12px; }
.onboard-cat:first-child{ margin-top: 0; }
.onboard-cat-title{
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 2px 2px 8px;
}

.onboard-options.industry{
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

/* Modules confirm modal */
.modules-group{ margin-top: 14px; }
.modules-group:first-child{ margin-top: 0; }
.modules-group-title{
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 2px 2px 8px;
}
.modules-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 10px;
}
.module-tile{
  border: var(--line);
  border-radius: 14px;
  padding: 10px 12px;
  background: rgba(255,255,255,.02);
  display:flex;
  gap: 10px;
  align-items:flex-start;
  cursor:pointer;
}
.module-tile:hover{ background: rgba(255,255,255,.03); }
.module-tile input{ margin-top: 3px; }
.module-meta{ display:flex; flex-direction:column; gap: 2px; }
.module-meta strong{ font-weight: 750; }
.module-meta .muted{ font-size: .9rem; }

/* Add-ons drawer tiles */
.addons-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 10px;
  margin-top: 10px;
}
.addon-tile{
  border: var(--line);
  border-radius: 14px;
  padding: 12px;
  background: rgba(255,255,255,.02);
  display:flex;
  flex-direction:column;
  gap: 8px;
}
.addon-tile .row{ display:flex; align-items:center; justify-content:space-between; gap: 10px; }
.addon-tile .title{ font-weight: 750; }
.addon-tile .desc{ color: var(--text-muted); font-size: .9rem; }
.addon-tile .actions{ display:flex; gap: 8px; flex-wrap:wrap; }
.addon-pill{ font-size: .75rem; padding: 4px 8px; border-radius: 999px; border: var(--line); color: var(--text-muted); background: rgba(255,255,255,.02); }

/* =========================
   Sheets: Add-ons drawer fix
   ========================= */
#addonsDrawer.sheet{
  left:auto;
  right:0;
  max-width:420px;
  transform:translateX(105%);
  z-index:500;
  transition:transform .25s ease;
}
#addonsDrawer.sheet:not([hidden]){ transform:translateX(0); }
#addonsDrawer.sheet[hidden]{ display:block; }
#addonsDrawer .card{background:transparent;padding-top: 45px;}

/* === Notes === */
.note-card{display:flex;background: var(--side), radial-gradient(300px 300px at -7% -10%, var(--primary-faded), var(--bg));flex-direction: column;width:-webkit-fill-available;height:-webkit-fill-available;overflow: hidden;gap: 10px;cursor: pointer;}
.note-card-header{
    display: flex;
    justify-content: space-between;
}
.note-card-details{
    display: flex;
    flex-direction: column-reverse;
    gap: 6px;
}
.note-card-preview{width: -webkit-fill-available;}
.note-card-code{
    margin: 0;
    white-space: break-spaces;
}
.notes-toolbar{display:flex;align-items: center;gap: 10px;flex-wrap: wrap;}
.notes-toolbar .notesttl{flex: 1 1 280px; min-width: 180px;}
#btnDownloadCaret{border-radius: 0  10px 10px 0;border: 0;height: stretch;}
#btnDownloadNote{border-radius: 10px 0 0 10px;}
/* Download menu (reuse split button) */
.download-split{ position: relative; display: inline-flex; }
.download-split .dropdown-menu{ position: absolute; right: 0; top: calc(100% + 6px); min-width: 180px; background: var(--surface); border: var(--line); border-radius: 12px; padding: 6px; z-index: 2000; box-shadow: 0 18px 50px rgba(0,0,0,.35); }
.download-split .dropdown-menu[hidden]{ display:none !important; }
.download-split .dropdown-menu button{ width: 100%; text-align:left; border: none; background: transparent; color: var(--text); padding: 8px 10px; border-radius: 8px; cursor:pointer; }
.download-split .dropdown-menu button:hover{ background: var(--bg-hover); }

/* Attachments stage + infinite canvas */
.note-attachments-stage{ margin-top: 10px; border: var(--line); border-radius: 12px; background: rgba(255,255,255,.03); position: relative; overflow: hidden; touch-action: none; height: 320px; min-height: 260px; }
.note-attachments-stage .note-attachments-canvas{ position:absolute; left:0; top:0; width: 100%; height:100%; transform-origin: 0 0; }
.note-attachments-stage .canvas-hint{ position:absolute; left:10px; bottom:10px; font-size: 12px; color: var(--text-muted); background: rgba(0,0,0,.35); border: 1px solid rgba(255,255,255,.12); padding: 6px 8px; border-radius: 10px; user-select:none; }
.note-attachments-stage .canvas-empty{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color: var(--text-muted); font-size: 13px; }

.note-attach{ position: absolute; border: 1px solid rgba(255,255,255,.14); border-radius: 12px; background: rgba(255,255,255,.06); overflow: hidden; box-shadow: 0 12px 30px rgba(0,0,0,.25); }
.note-attach .note-attach-pill .name{ white-space: nowrap; overflow:hidden; text-overflow: ellipsis; max-width: 210px; }
.note-attach .note-attach-pill .actions{ display:flex; gap:6px; align-items:center; }
.note-attach .note-attach-pill .pill-btn{ border: 1px solid rgba(255,255,255,.16); background: rgba(255,255,255,.06); color: var(--text); height: 24px; padding: 0 8px; border-radius: 8px; cursor:pointer; }
.note-attach .note-attach-pill .pill-btn:hover{ outline: var(--ring); }
.note-attach.open .note-attach-body{ display:block; }
.note-attach .note-attach-body img,
.note-attach .note-attach-body video,
.note-attach .note-attach-body iframe{ width:100%; height:100%; display:block; object-fit:contain; background: rgba(0,0,0,.25); }
.note-attach .note-attach-body audio{ width: calc(100% - 16px); margin: 10px 8px; }
.note-attach .note-attach-file{ padding: 10px; display:flex; align-items:center; gap:10px; flex-wrap:wrap }
.note-attach .note-attach-file .meta{ flex:1 1 auto; min-width: 180px; font-size: 12px; color: var(--text-muted) }
.note-attach .note-attach-resize{ position:absolute; right: 6px; bottom: 6px; width: 14px; height: 14px; border-radius: 4px; border: 1px solid rgba(255,255,255,.22); background: rgba(255,255,255,.12); cursor: nwse-resize; opacity: 0; }
.note-attach.open .note-attach-resize{ opacity: 1; }
.note-attach .note-attach-body{ width:100%; height: calc(100% - 34px); }
.note-attach .note-attach-pill{ height: 34px; display:flex; align-items:center; justify-content:space-between; gap: 10px; padding: 0 10px; font-size: 12px; border-bottom: 1px solid rgba(255,255,255,.12); background: rgba(0,0,0,.20); cursor: grab; user-select:none; }


.note-attach-block{ padding: 10px; font-size: 13px; line-height: 1.35; color: var(--text); }
.note-attach-block .b-h{ font-weight: 700; margin: 0 0 6px 0; }
.note-attach-block .b-p{ margin: 0; }
.note-attach-block ul, .note-attach-block ol{ margin: 6px 0 0 18px; }
.note-attach-block pre{ margin: 8px 0 0 0; padding: 10px; border-radius: 10px; border: 1px solid rgba(255,255,255,.12); background: rgba(0,0,0,.25); overflow:auto; }

/* New note type picker */
.note-type-picker{ position: fixed; background: var(--surface); border: var(--line); border-radius: 12px; padding: 6px; display:flex; gap: 6px; z-index: 5000; box-shadow: 0 18px 50px rgba(0,0,0,.35); }
.note-type-picker button{ border: var(--line); background: var(--bg-elev); color: var(--text); padding: 8px 10px; border-radius: 10px; cursor:pointer; }
.note-type-picker button:hover{ outline: var(--ring); }

/* Editor.js tweaks */
.codex-editor{ color: var(--text); }
.ce-toolbar__plus, .ce-toolbar__settings-btn{ color: var(--text); }
.ce-inline-toolbar{ background: var(--surface); border: var(--line); }
.ce-popover{ background: var(--surface); border: var(--line); }
.ce-block{ position: relative; }
.ce-drag-handle {
  position: absolute;
  left: 1.5%;
  top: 4%;
  width: 20px;
  height: 20px;
  opacity: 0;
  border-radius: 8px;
  border: var(--line);
  background: var(--strans);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: grab;
  user-select: none;
}
.ce-drag-handle:hover{ opacity: 1; outline: var(--ring); }

/* /ai inline menu */
.ai-inline-menu{ position: fixed; z-index: 6000; background: var(--surface); border: var(--line); border-radius: 12px; box-shadow: 0 18px 50px rgba(0,0,0,.35); padding: 10px; width: min(520px, calc(100vw - 24px)); }
.ai-inline-menu .row{ display:flex; gap: 8px; align-items:center; }
.ai-inline-menu input{ width: 100%; border: var(--line); background: rgba(255,255,255,.04); color: var(--text); padding: 10px 12px; border-radius: 10px; outline: none; }
.ai-inline-menu .hint{ margin-top: 8px; font-size: 12px; color: var(--text-muted); }

/* Donna side panel */
.donna-panel{ position: fixed; top: 0; right: 0; height: 100vh; width: min(420px, 92vw); background: var(--surface); border-left: var(--line); box-shadow: -18px 0 50px rgba(0,0,0,.35); transform: translateX(105%); transition: transform .18s ease; z-index: 6500; display:flex; flex-direction: column; }
.donna-panel.open{ transform: translateX(0); }
.donna-panel .donna-head{ padding: 12px; border-bottom: var(--line); display:flex; align-items:center; justify-content:space-between; gap: 10px; }
.donna-panel .donna-title{ font-weight: 700; }
.donna-panel .donna-body{ padding: 12px; overflow:auto; flex: 1 1 auto; display:flex; flex-direction: column; gap: 10px; }
.donna-panel .msg{ border: 1px solid rgba(255,255,255,.12); border-radius: 12px; padding: 10px; background: rgba(255,255,255,.04); white-space: pre-wrap; }
.donna-panel .msg.user{ background: rgba(99,102,241,.12); }
.donna-panel .donna-foot{ padding: 12px; border-top: var(--line); display:flex; gap: 8px; }
.donna-panel textarea{ flex:1 1 auto; min-height: 44px; max-height: 140px; resize: none; border: var(--line); background: rgba(255,255,255,.04); color: var(--text); padding: 10px 12px; border-radius: 12px; outline:none; }

/* Donna unified shell and bubble styles */
.donna-unified-shell{ display: flex; flex-direction: column; gap: 10px; }

/* Intent/Prompt bubbles */
.donna-intent-bubble, .donna-details-bubble, .donna-summary-bubble{ border: 1px solid rgba(99, 102, 241, 0.4); border-radius: 12px; padding: 12px; background: linear-gradient(135deg, rgba(99,102,241,0.12) 0%, rgba(59,130,246,0.08) 100%); }
.intent-header{ display: flex; align-items: center; gap: 8px; margin-bottom: 8px; font-weight: 600; color: var(--text); }
.intent-header i{ font-size: 18px; color: rgba(99, 102, 241, 0.9); }
.intent-message{ font-size: 14px; color: var(--text-muted); margin-bottom: 12px; line-height: 1.4; }
.intent-actions{ display: flex; gap: 8px; flex-wrap: wrap; }
.intent-actions .u-btn{ margin-top: 4px; }

/* Details form */
.detail-field{ margin-bottom: 10px; display: flex; flex-direction: column; gap: 6px; }
.detail-field label{ font-size: 13px; font-weight: 500; color: var(--text); }
.detail-field input{ padding: 8px 10px; border: 1px solid rgba(255,255,255,0.15); background: rgba(0,0,0,0.2); color: var(--text); border-radius: 6px; font-size: 13px; outline: none; }
.detail-field input:focus{ border-color: rgba(99, 102, 241, 0.6); background: rgba(0,0,0,0.3); }

/* Summary steps */
.summary-step{ display: flex; align-items: flex-start; gap: 10px; padding: 8px 0; }
.summary-step i{ color: rgba(34, 197, 94, 0.8); margin-top: 2px; flex-shrink: 0; }
.summary-step span{ font-size: 14px; color: var(--text-muted); }

/* Terminal bubble styles */
.donna-terminal-row{ border: 1px solid rgba(34, 197, 94, 0.3); border-radius: 10px; background: linear-gradient(135deg, rgba(17,24,39,0.8) 0%, rgba(31,41,55,0.8) 100%); overflow: hidden; font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', monospace; font-size: 12px; color: #a3e635; }
.donna-terminal-header{ padding: 8px 12px; background: rgba(0,0,0,0.5); display: flex; align-items: center; gap: 10px; border-bottom: 1px solid rgba(34, 197, 94, 0.2); cursor: pointer; user-select: none; transition: background 0.2s; }
.donna-terminal-header:hover{ background: rgba(0,0,0,0.6); }
.dots-wrap{ display: flex; gap: 6px; }
.dot{ width: 10px; height: 10px; border-radius: 50%; }
.dot.red{ background: #ff5f56; }
.dot.yellow{ background: #ffbd2e; }
.dot.green{ background: #27c93f; }
.terminal-title{ font-size: 12px; font-weight: 600; color: #a3e635; flex: 1; }
.term-toggle{ font-size: 16px; color: #a3e635; transition: transform 0.2s; }
.donna-terminal-body{ padding: 10px 12px; max-height: 300px; overflow-y: auto; display: flex; flex-direction: column; gap: 0; background: rgba(0,0,0,0.3); }
.term-line{ display: flex; gap: 8px; align-items: flex-start; line-height: 1.5; animation: slideIn 0.2s ease-out; }
.term-prompt{ color: #60a5fa; font-weight: 600; flex-shrink: 0; }
.terminal-cursor{ display: inline-block; width: 6px; height: 12px; background: #a3e635; margin-left: 2px; animation: blink 1s infinite; }
.current-line .terminal-cursor{ animation: blink 0.6s infinite; }

@keyframes slideIn { from { opacity: 0; transform: translateX(-10px); } to { opacity: 1; transform: translateX(0); } }
@keyframes blink { 0%, 49% { opacity: 1; } 50%, 100% { opacity: 0.3; } }

/* Output section with pouring animation */
.donna-output-row{ display: flex; flex-direction: column; gap: 8px; }
.donna-output-section{ padding: 10px; border-radius: 8px; border: 1px solid rgba(255,255,255,0.08); background: rgba(0,0,0,0.2); }
.donna-output-label{ font-size: 11px; font-weight: 600; color: rgba(255,255,255,0.5); text-transform: uppercase; margin-bottom: 6px; letter-spacing: 0.5px; }
.donna-output-text{ font-size: 13px; color: var(--text); line-height: 1.5; }

/* Pouring animation tokens */
.pour-token{ opacity: 0.4; transition: opacity 0.15s ease-out; }
.pour-token.visible{ opacity: 1; animation: pourIn 0.18s ease-out; }
@keyframes pourIn { from { opacity: 0; transform: translateY(-2px); } to { opacity: 1; transform: translateY(0); } }

/* Block cursor during streaming */
.donna-block-cursor{ display: inline-block; width: 6px; height: 0.9em; background: var(--primary, rgba(99, 102, 241, 0.9)); margin-left: 2px; animation: blockBlink 0.7s infinite; }
@keyframes blockBlink { 0%, 49% { opacity: 1; } 50%, 100% { opacity: 0.4; } }

/* Sentient card */
.sentient-card{ border: 1px solid rgba(99,102,241,.35); border-radius: 14px; padding: 12px; background: rgba(99,102,241,.10); box-shadow: 0 14px 40px rgba(0,0,0,.20); }
.sentient-head{ display:flex; align-items:center; justify-content:space-between; gap: 10px; margin-bottom: 10px; }
.sentient-title{ font-weight: 800; }
.sentient-head-right{ display:flex; gap: 8px; align-items:center; }
.sentient-tag{ font-size: 12px; color: var(--text-muted); }
.sentient-prompt{ width:100%; min-height: 60px; border: 1px solid rgba(255,255,255,.14); background: rgba(0,0,0,.14); color: var(--text); padding: 10px; border-radius: 12px; outline:none; resize: vertical; }
.sentient-output{ margin-top: 10px; border: 1px solid rgba(255,255,255,.12); background: rgba(0,0,0,.14); border-radius: 12px; padding: 10px; min-height: 56px; white-space: pre-wrap; }

/* Export-only helper */
.sentient-export{ border: 1px solid #bbb; border-radius: 12px; padding: 12px; background: #f6f6ff; }
.sentient-export-head{ font-weight: 700; margin-bottom: 8px; }

/* ---------- Inbox route upgrade ---------- */
.inbox-route .panel-sub {
  margin: 0;
}

.inbox-left-panel,
.inbox-main-panel,
.inbox-context-panel {
  min-height: 78vh;
  padding: 6px 6px 0 0;
  display: grid;
  height: -webkit-fill-available;
}
.inbox-context-panel {
  padding: 8px 0 0 5px;
}
.context-content{
    display: flex;
    width: -webkit-fill-available;
    overflow: auto;
}
.inbox-panel-head {
  align-items: center;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  flex-wrap: nowrap;
  gap: 0;
}

.inbox-search {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 2px 8px;
  border-radius: 15px;
  border: var(--line);
  background: color-mix(in srgb, var(--muted) 68%, transparent);
  margin: 0 0 10px;
}

.inbox-search i {
  color: var(--text-muted);
}

.inbox-search input {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
  font: inherit;
}

.inbox-top-filters,
.inbox-source-filters {
  margin-top: 10px;
}

.inbox-left-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow-y: auto;
}

.list.inbox-smart-list {
  gap: 10px;
  display: flex;
  padding-right: 4px;
}

.list.inbox-smart-list li{
  display: block;
  width: stretch;
}

.inbox-smart-view {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 4px 9px;
  border-radius: 16px;
  border: var(--line);
  color: var(--text);
  background: color-mix(in srgb, var(--pans) 72%, transparent);
}

.inbox-smart-view.is-active {
  border-color: color-mix(in srgb, var(--primary) 55%, transparent);
  box-shadow: 2px 2px 5px color-mix(in srgb, var(--primary-dark) 24%, transparent);
  background: color-mix(in srgb, var(--primary-dark) 16%, var(--pans));
}

.inbox-smart-main {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  overflow: auto;
}
.inbox-smart-main span{
  text-wrap-mode:nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.inbox-smart-count,
.inbox-source-count {
  min-width: 32px;
  padding: 4px 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--bg) 85%, transparent);
  border: var(--line);
  font-size: .52rem;
  text-align: center;
}

.inbox-source-chip {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.inbox-source-empty {
  padding: 12px 0;
}

.inbox-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 10px 12px 5px;
  border-bottom: var(--line);
}

.inbox-toolbar-copy {
  display: flex;
  flex-direction: column;
}

.inbox-list-wrap {
  min-height: 0;
  overflow: auto;
  padding: 0 0 0 2px;
}

.inbox-route .inbox-list {
  gap: 10px;
  padding-right: 4px;
}

.inbox-route .inbox-item {
  position: relative;
  display: grid;
  padding: 8px;
  border-radius: 10px;
  backdrop-filter: none;
  background: var(--strans);
}

.inbox-route .inbox-item.is-unread {
  background: color-mix(in srgb, var(--primary-dark) 80%, transparent);
  color: #fff;
}
.inbox-route .inbox-item-summary {
  color: #ccc;
}

.inbox-route .inbox-item.is-selected {
  border-color: color-mix(in srgb, var(--primary) 55%, transparent);
  box-shadow: 0 2px 5px color-mix(in srgb, var(--primary-dark) 26%, transparent);
}

.inbox-item-accent {
  width: 100%;
  border-radius: 999px;
  background: color-mix(in srgb, var(--primary-dark) 45%, transparent);
}

.inbox-item-accent.tone-warn {
  background: linear-gradient(180deg, #f59e0b, #f97316);
}

.inbox-item-accent.tone-accent {
  background: linear-gradient(180deg, var(--primary), var(--primary-dark));
}

.inbox-item-accent.tone-soft {
  background: linear-gradient(180deg, color-mix(in srgb, var(--primary) 40%, transparent), color-mix(in srgb, var(--primary-dark) 30%, transparent));
}

.inbox-item-accent.tone-danger {
  background: linear-gradient(180deg, #ef4444, #b91c1c);
}

.inbox-item-body,
.inbox-item-topline,
.inbox-item-head,
.inbox-item-meta-row,
.inbox-item-tags {
  display: flex;
}

.inbox-item-body {
  min-width: 0;
  flex-direction: column;
  gap: 8px;
}

.inbox-item-topline {
  justify-content: space-between;
  align-items: flex-start;
}

.inbox-item-head {
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.inbox-item-title {
  font-weight: 700;
  font-size: .7rem;
  line-height: 1.35;
}

.inbox-item-summary {
  color: var(--text-muted);
  font-size: .6rem;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  line-break: anywhere;
  overflow: hidden;
}

.inbox-item-time {
  color: var(--text-muted);
  white-space: nowrap;
  font-size: .65rem;
}

.inbox-item-meta-row {
  justify-content: space-between;
  gap: 8px;
  align-items: center;
}

.inbox-badges-row{
  display:grid;
}

.inbox-item-tags {
  gap: 8px;
  flex-wrap: wrap;
}

.inbox-item-source {
  text-transform: capitalize;
  font-size: .84rem;
  flex: 1;
  text-wrap-mode: nowrap;
}

.inbox-unread-dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--primary);
  box-shadow: 0 0 0 4px var(--primary-faded);
}

.inbox-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 5px;
  height: 20px;
  border-radius: 999px;
  border: var(--line);
  background: var(--strans);
  font-size: .54rem;
  line-height: 1;
  text-wrap-mode: nowrap;
}

.inbox-pill.tone-warn {
  border-color: color-mix(in srgb, #f59e0b 45%, transparent);
  background: color-mix(in srgb, #f59e0b 16%, var(--bg));
}

.inbox-pill.tone-accent {
  border-color: color-mix(in srgb, var(--primary) 42%, transparent);
  background: color-mix(in srgb, var(--primary) 14%, var(--bg));
}

.inbox-pill.tone-soft {
  border-color: var(--primary);
}

.inbox-pill.tone-danger {
  border-color: color-mix(in srgb, #ef4444 42%, transparent);
  background: color-mix(in srgb, #ef4444 14%, var(--bg));
}

.inbox-empty-state,
.inbox-thread-empty {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  text-align: center;
  padding: 28px;
}

.inbox-empty-icon {
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  border: var(--line);
  background: color-mix(in srgb, var(--pans) 82%, transparent);
  font-size: 1.5rem;
}

.inbox-thread-view {
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: auto;
}

.inbox-detail-shell {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.inbox-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 5px;
  flex-direction: column;
}

.inbox-detail-badges,
.inbox-detail-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.inbox-detail-title {
  margin: 10px 0 4px;
  font-size: 1.35rem;
}

.inbox-detail-meta,
.inbox-detail-summary {
  color: var(--text-muted);
}

.inbox-detail-summary {
  padding: 12px 14px;
  border-radius: 16px;
  border: var(--line);
  background: color-mix(in srgb, var(--pans) 80%, transparent);
}

.inbox-detail-message {
  padding: 16px;
  border-radius: 18px;
}

.inbox-detail-facts {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}

.inbox-detail-fact {
  display: flex;
  flex-direction: column;
  padding: 4px 10px;
  border-radius: 16px;
  border: var(--line);
  background: color-mix(in srgb, var(--pans) 80%, transparent);
}

.inbox-detail-fact span {
  color: var(--text-muted);
  font-size: .82rem;
  text-transform: capitalize;
}

.inbox-context-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-right: 3px;
  min-width: 0;
}

.inbox-context-card {
  padding: 8px;
  border-radius: 18px;
  border: var(--line);
  background: color-mix(in srgb, var(--dots) 82%, transparent);
}

.inbox-context-card h4 {
  margin: 0 0 10px;
}

.inbox-context-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.inbox-context-list div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.inbox-context-list dt,
.inbox-context-list dd {
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 10px;
}

.inbox-context-list dt {
  color: var(--text-muted);
}

.inbox-context-json {
  margin: 0;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  font-size: .52rem;
  color: var(--text-muted);
}

/* Plan-locked navigation keeps visibility but reads as unavailable until the org upgrades. */
a.acl-plan-locked,
button.acl-plan-locked,
[data-nav].acl-plan-locked {
  opacity: .62;
  filter: saturate(.72);
  cursor: not-allowed !important;
}

/* Shared route shell chrome (used by Web Elements phase 2 shell) */
.app-route-shell-bar {
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 22px;
  background: var(--bg);
  box-shadow: 0 24px 60px rgba(0,0,0,0.28);
}

.app-route-pills {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.app-route-pill {
  appearance: none;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.05);
  color: var(--text, #f8fafc);
  min-height: 30px;
  padding: 0 14px;
  border-radius: 999px;
  cursor: pointer;
  font: inherit;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.01em;
  transition: background-color .18s ease, border-color .18s ease, transform .18s ease, box-shadow .18s ease;
}

.app-route-pill:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
}

.app-route-pill.is-active,
.app-route-pill[aria-current="page"] {
  background: rgba(255,255,255,0.16);
  border-color: rgba(255,255,255,0.22);
  box-shadow: 0 12px 30px rgba(0,0,0,0.18);
}

.app-route-status {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 40px;
  padding: 4px 12px;
  border-radius: 12px;
  border: var(--line);
  background: var(--strans);
}

.app-route-status-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0 0 0 currentColor;
}

/* --- Global Route Skeletons (Finance-style) --- */
.ub-skel {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  background: rgba(255,255,255,.06);
}

html[data-theme="light"] .ub-skel {
  background: rgba(0,0,0,.04);
}

.ub-skel::after {
  content: "";
  position: absolute;
  inset: 0;
  transform: translateX(-100%);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
  animation: ub-skel-shimmer 1.2s ease-in-out infinite;
}

html[data-theme="light"] .ub-skel::after {
  background: linear-gradient(90deg, transparent, rgba(0,0,0,.06), transparent);
}

@keyframes ub-skel-shimmer {
  100% { transform: translateX(100%); }
}

.ub-skel.line { height: 12px; }
.ub-skel.pill { height: 28px; border-radius: 999px; }
.ub-skel.btn  { height: 34px; border-radius: 12px; }
.ub-skel.card { border-radius: 18px; min-height: 100px; }

.ub-skel-stack { display: grid; gap: 10px; }
.ub-skel-grid  { display: grid; gap: 12px; }

.ub-skel-page {
  width: 100%;
  height: 100%;
  background: var(--bg);
  color: var(--text);
  overflow: hidden;
  animation: ub-skel-fade-in 0.2s ease-out forwards;
}

@keyframes ub-skel-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

.ub-route-skel-overlay {
  position: absolute;
  inset: 0;
  z-index: 9999;
  background: var(--bg);
  pointer-events: none;
  transition: opacity 0.2s ease-in-out;
}

.ub-route-skel-overlay.fade-out {
  opacity: 0;
}

/* Skeleton container inside a route */
.route-skeleton-host {
  padding: 12px;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

@property --vinc-angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}

.vinc {
  position: relative;
}

.vinc.vinc-ring-active::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 2px;

  background: conic-gradient(
    from var(--vinc-angle),
    transparent 10%,
    var(--primary-dark) 40%,
    var(--primary) 80%,
    transparent 100%
  );
  mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;

  pointer-events: none; /* Ensures the border doesn't block clicks to the panel inside */

  /* The rotation animation */
  animation: vinc-spin 3.5s linear infinite;
}

/* 4. The Animation Keyframes */
@keyframes vinc-spin {
  from { --vinc-angle: 0deg; }
  to { --vinc-angle: 360deg; }
}
/* --- 2025 TOPBAR & NAVIGATION UPDATES --- */

.mini-routes {
  display: flex;
  align-items: center;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
  padding: 0 16px;
}
.mini-routes::-webkit-scrollbar { display: none; }

.mini-route-pill {
  white-space: nowrap;
  padding: 6px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 500;
  background: var(--strans);
  text-decoration: none;
  transition: all 0.5s ease-in-out;
  border: var(--line);
}
.mini-route-pill:hover {
  background: var(--surface, rgba(0,0,0,0.05));
}
.mini-route-pill.active {
  background: var(--primary-dark);
  color: #fff;
}

.topbar-search-container {
  position: relative;
}

.search-wrap.floating {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 220px;
  background: var(--strans);
  backdrop-filter: var(--backdrop-2);
  border: var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow);
  z-index: 1000;
  display: flex;
  align-items: center;
  padding: 0 2px 0 10px;
  animation: searchDrop 0.2s cubic-bezier(0.2, 1, 0.3, 1);
}

@keyframes searchDrop {
  from { opacity: 0; transform: translateY(-10px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

.search-wrap[hidden] {
  display: none;
}

/* --- WORKSPACE SETUP REDESIGN --- */

.workspace-setup-redesign .setup-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 12px;
}

.setup-card {
  padding: 16px;
  background: var(--surface, rgba(0,0,0,0.02));
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  border: 1px solid transparent;
  transition: all 0.2s ease;
}

.setup-card:hover {
  border-color: var(--primary-faded);
  background: var(--bg);
}

.setup-card-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--primary-faded);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}

.setup-card-body strong {
  display: block;
  font-size: 14px;
  margin-bottom: 4px;
}

.setup-card-body p {
  font-size: 12px;
  margin: 0;
  line-height: 1.4;
}

/* --- ADD-ONS MODAL REDESIGN --- */

.addons-redesign-modal .u-card {
  max-width: 900px;
  width: 90vw;
}

.modal-nav-pills {
  display: flex;
  gap: 4px;
  background: var(--surface, rgba(0,0,0,0.05));
  padding: 4px;
  border-radius: 10px;
}

.modal-nav-pill {
  padding: 6px 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
}

.modal-nav-pill.active {
  background: var(--bg);
  color: var(--primary);
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

.addons-modal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
  padding: 8px 0;
}

.addon-modal-card {
  padding: 20px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: all 0.3s cubic-bezier(0.2, 1, 0.3, 1);
}

.addon-modal-card:hover {
  transform: translateY(-4px);
  border-color: var(--primary);
  box-shadow: 0 8px 24px var(--primary-faded);
}

.addon-card-head {
  display: flex;
  gap: 12px;
  align-items: center;
}

.addon-card-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--primary-faded);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
}

.addon-card-info strong {
  display: block;
  font-size: 15px;
  margin-bottom: 4px;
}

.addon-card-tags {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}

.addon-pill {
  font-size: 10px;
  padding: 2px 6px;
  background: var(--surface, rgba(0,0,0,0.05));
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 700;
}

.addon-card-actions {
  display: flex;
  gap: 8px;
  margin-top: auto;
}

.addon-card-actions .btn {
  flex: 1;
}

/* Container setup */
.u-progress-dots {
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 24px;
}

/* Base styles for the dots */
.u-progress-dots span {
  width: 12px;
  height: 12px;
  background-color: var(--primary);
  border-radius: 50%;
  animation: bounce 0.5s infinite alternate;
}

/* Staggering the animation delay for the wave effect */
.u-progress-dots span:nth-child(1) {
  animation-delay: 0s;
}

.u-progress-dots span:nth-child(2) {
  animation-delay: 0.15s;
}

.u-progress-dots span:nth-child(3) {
  animation-delay: 0.3s;
}

/* The jumping animation */
@keyframes bounce {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-8px);
  }
}

/* 1. The Parent Container (The Window) */
.tinc {
  overflow: hidden;
  width: 100%; /* Or whatever fixed width you want */
  white-space: nowrap;
  position: relative;
  
  /* Optional: Adds a nice fade out effect on the edges */
  mask-image: linear-gradient(to right, transparent, var(--bg) 10%, var(--bg) 90%, transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, var(--bg) 10%, vavr(--bg) 90%, transparent);
}

/* 2. The Moving Track */
.inf {
  display: inline-flex;
  gap: 4px; /* Spacing between pills */
  padding: 2px 0;
  
  /* Adjust '20s' to change the speed (higher = slower) */
  animation: scrollInfinite 20s linear infinite;
  flex-wrap: nowrap;
}

/* 3. The Hover State (Pause Effect) */
.tinc:hover .inf {
  animation-play-state: paused;
}

/* 4. The Animation Keyframes */
@keyframes scrollInfinite {
  0% {
    transform: translateX(0);
  }
  100% {
    /* Moves exactly half the track width (the first set of pills) */
    transform: translateX(-50%); 
  }
}