/* ============================================================================
   Pup Call — Discord-style redesign layer. Loaded AFTER styles.css so it
   overrides the old setup/room layout while reusing the existing component
   styles (video cards, overlays, auth gate, friend rows, presence dots).
   ============================================================================ */

:root {
  --dc-bg:        #0b0e1a;   /* app background          */
  --dc-rail:      #0a0c16;   /* far-left server rail    */
  --dc-side:      #11152400; /* sidebar (over bg)       */
  --dc-side-bg:   #121728;   /* sidebar solid           */
  --dc-main:      #0e1322;   /* main call area          */
  --dc-panel:     #182036;   /* raised panel            */
  --dc-panel-2:   #1d2742;   /* hover / active          */
  --dc-border:    #232c47;
  --dc-text:      #e7eaf6;
  --dc-muted:     #8b93b8;
  --dc-faint:     #5b6488;
  --dc-accent:    #5b6cff;   /* blurple                 */
  --dc-accent-2:  #6d7bff;
  --dc-online:    #3ddc97;
  --dc-away:      #f5c451;
  --dc-danger:    #ed4d5d;
  --dc-live:      #2fd47a;
  --dc-radius:    14px;
}

.dc-body {
  margin: 0;
  height: 100vh;
  overflow: hidden;
  background: var(--dc-bg);
  color: var(--dc-text);
  font-family: 'Inter', 'Segoe UI', system-ui, Arial, sans-serif;
}

/* Old floating action buttons are now in the rail — neutralize any leftovers */
.settings-fab:not(.dc-rail-btn) { display: none !important; }

/* ---- Shell grid ---------------------------------------------------------- */
.dc-shell {
  display: grid;
  grid-template-columns: 72px 248px minmax(0, 1fr) 244px;
  grid-template-rows: 100vh;
  height: 100vh;
  width: 100vw;
}

/* ---- 1. Server rail ------------------------------------------------------ */
.dc-rail {
  background: var(--dc-rail);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 12px 0;
  border-right: 1px solid #05060c;
}
.dc-rail-logo {
  width: 46px; height: 46px; border-radius: 14px;
  border: none; cursor: pointer;
  background: linear-gradient(135deg, var(--dc-accent), #8a63ff);
  font-size: 22px; color: #fff;
  display: grid; place-items: center;
  box-shadow: 0 4px 14px rgba(91,108,255,.35);
}
.dc-rail-sep { width: 32px; height: 2px; border-radius: 2px; background: #20263c; }
.dc-rail-spring { flex: 1; }
.dc-rail-btn {
  position: relative;
  width: 46px; height: 46px; border-radius: 16px;
  border: none; cursor: pointer;
  background: var(--dc-panel);
  color: var(--dc-muted);
  font-size: 19px;
  display: grid; place-items: center;
  transition: border-radius .15s ease, background .15s ease, color .15s ease;
}
.dc-rail-btn:hover { border-radius: 13px; background: var(--dc-accent); color: #fff; }
.dc-rail-btn.is-active { border-radius: 13px; background: var(--dc-accent); color: #fff; }
.dc-rail-btn.is-active::before {
  content: ""; position: absolute; left: -12px; top: 50%; transform: translateY(-50%);
  width: 5px; height: 26px; border-radius: 0 4px 4px 0; background: #fff;
}
.dc-rail-gray { background: linear-gradient(135deg,#3a4470,#5b6cff); color:#fff; font-size:20px; }
.dc-rail-badge {
  position: absolute; right: -2px; top: -2px; min-width: 16px; height: 16px;
  padding: 0 4px; border-radius: 9px; background: var(--dc-danger); color:#fff;
  font-size: 10px; font-weight: 700; display: grid; place-items: center;
  border: 2px solid var(--dc-rail);
}

/* ---- 2. Sidebar ---------------------------------------------------------- */
.dc-sidebar {
  background: var(--dc-side-bg);
  border-right: 1px solid var(--dc-border);
  display: flex; flex-direction: column;
  min-height: 0;
}
.dc-side-head {
  height: 50px; padding: 0 14px;
  display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--dc-border);
  box-shadow: 0 1px 0 rgba(0,0,0,.2);
}
.dc-brand { font-weight: 700; font-size: 16px; letter-spacing:.2px; }
.dc-brand strong { color: var(--dc-accent-2); }
.dc-ver { font-size: 10px; font-weight: 600; color: var(--dc-faint); margin-left: 6px; vertical-align: middle; }
.dc-side-search { padding: 10px 12px 4px; }
.dc-side-search input {
  width: 100%; box-sizing: border-box; border: none; outline: none;
  background: #0c1020; color: var(--dc-text);
  padding: 7px 10px; border-radius: 8px; font-size: 13px;
}
.dc-side-scroll { flex: 1; overflow-y: auto; padding: 6px 8px 10px; min-height: 0; }
.dc-side-view { display: none; }
.dc-side-view.is-active { display: block; }

.dc-side-group {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 8px 6px;
}
.dc-side-group-label {
  font-size: 11px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase;
  color: var(--dc-faint);
}
.dc-side-group-btn {
  background: none; border: none; cursor: pointer; color: var(--dc-faint);
  font-size: 15px; line-height: 1; padding: 2px 4px; border-radius: 6px;
}
.dc-side-group-btn:hover { color: var(--dc-text); background: var(--dc-panel); }
/* collapsible group header */
.dc-group-toggle {
  display: flex; align-items: center; gap: 6px;
  background: none; border: none; cursor: pointer; padding: 0; flex: 1; text-align: left;
}
.dc-group-toggle:hover .dc-side-group-label { color: var(--dc-text); }
.dc-caret { font-size: 9px; width: 10px; display: inline-block; color: var(--dc-faint); }

/* cleaner auto-room entries */
.dc-roomlist .room-entry {
  background: var(--dc-panel); border: 1px solid var(--dc-border);
  border-radius: 10px; padding: 8px 10px; margin-bottom: 6px;
}
.dc-roomlist .room-entry > summary {
  cursor: pointer; list-style: none;
  font-size: 12.5px; font-weight: 600; color: var(--dc-text);
}
.dc-roomlist .room-entry > summary::-webkit-details-marker { display: none; }
.dc-roomlist .room-entry > summary::before { content: '▸ '; color: var(--dc-faint); font-size: 10px; }
.dc-roomlist .room-entry[open] > summary::before { content: '▾ '; }
.dc-roomlist .room-entry ul { margin: 7px 0 6px; padding-left: 18px; font-size: 11.5px; color: var(--dc-muted); }
.dc-roomlist .room-entry button {
  border: none; cursor: pointer; border-radius: 7px;
  background: var(--dc-accent); color: #fff; padding: 5px 10px; font-size: 11.5px; font-weight: 600;
}
.dc-roomlist .room-entry button:hover { background: var(--dc-accent-2); }

/* room + friend lists reuse .room-list / .friend-entry from styles.css; tidy spacing */
.dc-roomlist, .dc-friendlist { display: flex; flex-direction: column; gap: 2px; }

.dc-addfriend { display: flex; gap: 6px; padding: 4px 6px 8px; align-items: stretch; }
.dc-af-field { flex: 1; min-width: 0; display: block; margin: 0; }
.dc-addfriend input {
  width: 100%; box-sizing: border-box; border: none; outline: none; background: #0c1020;
  color: var(--dc-text); padding: 7px 9px; border-radius: 8px; font-size: 12px;
}

.dc-join { display: flex; flex-direction: column; gap: 6px; padding: 10px 6px; }
.dc-join input {
  border: none; outline: none; background: #0c1020; color: var(--dc-text);
  padding: 8px 10px; border-radius: 8px; font-size: 12px;
}
.dc-join-row { display: flex; gap: 6px; }
.dc-incoming { margin: 4px 6px; }

.dc-btn {
  border: none; cursor: pointer; border-radius: 8px;
  background: var(--dc-panel); color: var(--dc-text);
  padding: 8px 12px; font-size: 13px; font-weight: 600;
  transition: background .12s ease, transform .05s ease;
}
.dc-btn:hover { background: var(--dc-panel-2); }
.dc-btn:active { transform: translateY(1px); }
.dc-btn-primary { background: var(--dc-accent); color: #fff; flex: 1; }
.dc-btn-primary:hover { background: var(--dc-accent-2); }

/* user bar */
.dc-userbar {
  height: 56px; padding: 0 10px; display: flex; align-items: center; gap: 9px;
  background: #0c1020; border-top: 1px solid var(--dc-border);
}
.dc-userbar-avatar {
  width: 34px; height: 34px; border-radius: 50%; object-fit: cover;
  background: var(--dc-panel);
}
.dc-userbar-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; line-height: 1.2; }
.dc-userbar-name { font-size: 13px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dc-userbar-status { font-size: 11px; color: var(--dc-muted); }
.dc-userbar-btn {
  background: none; border: none; cursor: pointer; color: var(--dc-muted);
  font-size: 16px; padding: 6px; border-radius: 8px;
}
.dc-userbar-btn:hover { background: var(--dc-panel); color: var(--dc-text); }

/* ---- 3. Main / call ------------------------------------------------------ */
.dc-main {
  background: var(--dc-main);
  display: flex; flex-direction: column; min-width: 0; min-height: 0;
}
.dc-room-head {
  height: 50px; padding: 0 16px; flex: 0 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--dc-border);
  box-shadow: 0 1px 0 rgba(0,0,0,.25);
}
.dc-room-title { display: flex; align-items: center; gap: 6px; min-width: 0; }
.dc-room-hash { color: var(--dc-faint); font-size: 20px; font-weight: 700; }
.dc-room-title h2 {
  margin: 0; font-size: 15px; font-weight: 700; color: var(--dc-text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dc-room-actions { display: flex; align-items: center; gap: 8px; }
.dc-room-status { font-size: 12px; color: var(--dc-muted); }
.dc-pill {
  border: none; cursor: pointer; border-radius: 8px;
  background: var(--dc-panel); color: var(--dc-text);
  padding: 6px 11px; font-size: 12px; font-weight: 600;
}
.dc-pill:hover { background: var(--dc-panel-2); }
.dc-pill-danger { background: rgba(237,77,93,.16); color: #ff8a96; }
.dc-pill-danger:hover { background: rgba(237,77,93,.28); }
.dc-warn { margin: 10px 16px 0; }

/* video grid — large tiles */
.dc-grid {
  flex: 0 0 auto; max-height: 60vh; min-height: 0; overflow: auto;
  display: grid; gap: 14px; padding: 16px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  align-content: start;
}
.dc-grid .video-card {
  border-radius: var(--dc-radius); overflow: hidden;
  background: #060912; border: 1px solid var(--dc-border);
  aspect-ratio: 16 / 10; min-height: 200px;
  box-shadow: 0 6px 22px rgba(0,0,0,.35);
}
.dc-grid .video-card.speaking { border-color: var(--dc-online); box-shadow: 0 0 0 2px var(--dc-online); }
.dc-grid .video-card video { width: 100%; height: 100%; object-fit: contain; background: #000; }
.dc-grid .video-label {
  position: absolute; left: 10px; bottom: 10px; z-index: 3;
  background: rgba(8,11,20,.78); border-radius: 8px; padding: 4px 9px;
  font-size: 12px; font-weight: 600; backdrop-filter: blur(4px);
}

/* call control bar */
.dc-callbar {
  flex: 0 0 auto; display: flex; gap: 10px; justify-content: center; flex-wrap: wrap;
  padding: 12px; background: #0b0f1c; border-top: 1px solid var(--dc-border);
}
.dc-callbar.hidden { display: none; }
.dc-cbtn {
  position: relative;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px;
  border: none; cursor: pointer; border-radius: 12px;
  background: var(--dc-panel); color: var(--dc-muted);
  width: 62px; min-height: 58px; padding: 9px 4px;
  font-size: 10px; font-weight: 600; line-height: 1.15; text-align: center;
  transition: background .12s ease, color .12s ease, transform .05s ease;
}
/* Icon as a pseudo-element so app.js setting button.textContent (Mute/Unmute,
   Enable/Disable camera, Share/Stop sharing…) can never wipe it out. */
.dc-cbtn::before {
  font-size: 19px; line-height: 1; color: var(--dc-text);
  font-family: 'Segoe UI Emoji', 'Apple Color Emoji', 'Noto Color Emoji', sans-serif;
}
.dc-cbtn:hover { background: var(--dc-panel-2); }
.dc-cbtn:active { transform: translateY(1px); }
.dc-cbtn-label { font-size: 10px; font-weight: 600; color: inherit; }
.dc-cbtn.is-on { background: var(--dc-accent); color: #fff; }
.dc-cbtn.is-on::before { color: #fff; }
.dc-cbtn-go.is-on { background: var(--dc-live); color: #eafff3; }
.dc-cbtn-go.is-on::before { color: #fff; }
.dc-cbtn-hangup { background: var(--dc-danger); color: #ffe0e3; }
.dc-cbtn-hangup::before { transform: rotate(134deg); }
.dc-cbtn-hangup:hover { background: #ff5e6c; }

/* per-button icons */
#micButton::before          { content: "🎙"; }
#muteButton::before         { content: "🔇"; }
#deafenButton::before       { content: "🎧"; }
#cameraButton::before       { content: "📷"; }
#screenButton::before       { content: "🖥"; }
#audioDevicesButton::before { content: "🔊"; }
#resyncButton::before       { content: "↻"; font-size: 22px; }
#leaveButton::before        { content: "📞"; }
.dc-callbar .file-picker-label::before { content: "📎"; }

/* chat */
.dc-chat {
  flex: 1 1 auto; min-height: 0; display: flex; flex-direction: column;
  border-top: 1px solid var(--dc-border); background: var(--dc-main);
}
.dc-chat-head {
  padding: 8px 16px; font-size: 12px; font-weight: 700; letter-spacing:.5px;
  text-transform: uppercase; color: var(--dc-faint);
}
.dc-chat-msgs {
  flex: 1; overflow-y: auto; padding: 0 16px 8px; min-height: 60px;
  display: flex; flex-direction: column-reverse;
}
.dc-compose { display: flex; align-items: center; gap: 8px; padding: 10px 16px 14px; }
.dc-compose #chatInput {
  flex: 1; min-width: 0; border: none; outline: none; border-radius: 10px;
  background: var(--dc-panel); color: var(--dc-text); padding: 11px 14px; font-size: 14px;
}
.dc-compose .attach-button {
  background: var(--dc-panel); border: none; cursor: pointer; color: var(--dc-muted);
  width: 40px; height: 40px; border-radius: 10px; font-size: 17px;
}
.dc-compose .attach-button:hover { color: var(--dc-text); }

/* ---- 4. Members + AI ----------------------------------------------------- */
.dc-members {
  background: var(--dc-side-bg);
  border-left: 1px solid var(--dc-border);
  display: flex; flex-direction: column; min-height: 0;
}
.dc-members-head {
  height: 50px; padding: 0 16px; display: flex; align-items: center;
  font-size: 12px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase;
  color: var(--dc-faint); border-bottom: 1px solid var(--dc-border);
}
.dc-members-scroll {
  flex: 1; min-height: 0; padding: 8px;
  display: flex; flex-direction: column; overflow: hidden;
}
/* everything except the friend list stays at its natural height… */
.dc-members-scroll > :not(#friendList) { flex: 0 0 auto; }
.dc-mem-group {
  padding: 10px 8px 4px; font-size: 11px; font-weight: 700; letter-spacing: .5px;
  text-transform: uppercase; color: var(--dc-faint);
}
.dc-mem-list { display: flex; flex-direction: column; gap: 1px; }
.dc-mem {
  display: flex; align-items: center; gap: 9px; padding: 6px 8px; border-radius: 8px;
  cursor: default;
}
.dc-mem:hover { background: var(--dc-panel); }
.dc-mem.is-speaking { background: rgba(61,220,151,.10); }
.dc-mem-av {
  position: relative; width: 30px; height: 30px; border-radius: 50%; flex: 0 0 auto;
  background: var(--dc-panel); object-fit: cover;
}
.dc-mem-wrap { position: relative; width: 30px; height: 30px; flex: 0 0 auto; }
.dc-mem-wrap .dc-mem-av { width: 30px; height: 30px; }
.dc-mem-dot {
  position: absolute; right: -2px; bottom: -2px; width: 11px; height: 11px;
  border-radius: 50%; border: 2px solid var(--dc-side-bg); background: var(--dc-faint);
}
.dc-mem-dot.active { background: var(--dc-online); }
.dc-mem-dot.away   { background: var(--dc-away); }
.dc-mem-dot.offline{ background: var(--dc-faint); }
.dc-mem-name { font-size: 13px; font-weight: 600; color: var(--dc-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dc-mem.is-offline .dc-mem-name { color: var(--dc-faint); }
.dc-mem-tag { margin-left: auto; font-size: 10px; color: var(--dc-live); font-weight: 700; }
.dc-mem-empty { padding: 6px 10px; font-size: 12px; color: var(--dc-faint); }

/* friends section inside the members panel */
.dc-friends-group {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 4px; border-top: 1px solid var(--dc-border); padding-top: 12px;
}
.dc-members .dc-addfriend { padding: 6px 2px 8px; }
/* Let the friend list use the full panel height instead of scrolling inside a
   220px box (the old .room-list cap) — the whole members panel scrolls only
   once the list actually fills down to the bottom. */
/* …and the friend list grows to fill all remaining space, scrolling ONLY when
   its own rows actually reach the bottom. */
.dc-members #friendList {
  padding: 0 2px; max-height: none;
  flex: 1 1 auto; min-height: 0; overflow-y: auto;
}
/* Remove-friend button in the friend dropdown */
.friend-remove { color: #ff8a96 !important; }
.friend-remove:hover { background: rgba(237,77,93,.18) !important; }

/* ── custom call-bar button art (puppy icon tiles) ───────────────────────── */
.dc-callbar .dc-cbtn {
  width: 92px; height: 92px; padding: 0; border-radius: 18px;
  background-color: transparent;
  background-repeat: no-repeat; background-position: center; background-size: cover;
  color: transparent; font-size: 0; /* labels are baked into the art */
}
.dc-callbar .dc-cbtn::before { display: none; }      /* drop the emoji pseudo-icon */
.dc-callbar .dc-cbtn-label { display: none; }
.dc-callbar .dc-cbtn:hover { filter: brightness(1.12); transform: translateY(-1px); }
.dc-callbar .dc-cbtn:active { transform: translateY(0); }
/* active state = glowing ring (leaves the artwork intact) */
.dc-callbar .dc-cbtn.is-on { box-shadow: 0 0 0 3px var(--dc-accent), 0 0 16px rgba(91,108,255,.55); }
.dc-callbar .dc-cbtn-go.is-on { box-shadow: 0 0 0 3px var(--dc-live), 0 0 16px rgba(47,212,122,.55); }
.dc-callbar .dc-cbtn-hangup { transform: none; }

#micButton          { background-image: url('btn/mic.png?v=1'); }
#muteButton         { background-image: url('btn/mute.png?v=1'); }
#deafenButton       { background-image: url('btn/deafen.png?v=1'); }
#cameraButton       { background-image: url('btn/camera.png?v=1'); }
#screenButton       { background-image: url('btn/screen.png?v=1'); }
#audioDevicesButton { background-image: url('btn/devices.png?v=1'); }
#resyncButton       { background-image: url('btn/resync.png?v=1'); }
#leaveButton        { background-image: url('btn/leave.png?v=1'); }
.dc-callbar .file-picker-label { background-image: url('btn/file.png?v=1'); }

/* file-transfer progress rows in chat (upload + download) */
.message.file-transfer {
  background: var(--dc-panel); border: 1px solid var(--dc-border);
  border-radius: 10px; padding: 8px 10px; gap: 6px;
  display: flex; flex-direction: column;
}
.file-transfer .ft-label { font-size: 12.5px; font-weight: 600; color: var(--dc-text); }
.file-transfer .ft-label a { color: var(--dc-accent-2); text-decoration: none; }
.file-transfer .ft-label a:hover { text-decoration: underline; }
.file-transfer .ft-bar { height: 7px; border-radius: 5px; background: #0a0d18; overflow: hidden; }
.file-transfer .ft-fill {
  height: 100%; width: 0%; border-radius: 5px;
  background: linear-gradient(90deg, var(--dc-accent), #8a63ff);
  transition: width .15s ease;
}
.file-transfer .ft-pct { font-size: 11px; color: var(--dc-muted); align-self: flex-end; }
.file-transfer.ft-done .ft-fill { background: var(--dc-live); }
.file-transfer.ft-fail .ft-fill { background: var(--dc-danger); }
.file-transfer.ft-fail .ft-pct { color: #ff8a96; }

/* attachment file chips — compose preview */
.attach-file {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--dc-panel); border: 1px solid var(--dc-border);
  border-radius: 8px; padding: 6px 8px; max-width: 220px;
}
.attach-file-icon { font-size: 16px; }
.attach-file-meta {
  font-size: 12px; color: var(--dc-text);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
/* received file links inside messages */
.chat-file {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 4px;
  background: var(--dc-panel); border: 1px solid var(--dc-border);
  border-radius: 9px; padding: 7px 10px; text-decoration: none;
  color: var(--dc-text); max-width: 270px;
}
.chat-file:hover { background: var(--dc-panel-2); border-color: var(--dc-accent); }
.chat-file-icon { font-size: 18px; }
.chat-file-meta {
  font-size: 12.5px; flex: 1;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.chat-file-dl { color: var(--dc-accent-2); font-size: 14px; }

/* talking-puppy avatar — transparent PNG, just the puppy (no box) on the tile */
.video-placeholder img.puppy-face {
  width: 100%; height: 100%; object-fit: contain; display: block;
}
.video-card.puppy-on .video-placeholder { background: transparent; }

/* real OS fullscreen: video fills the whole monitor over the desktop */
.video-card:fullscreen { background: #000; border: none; border-radius: 0; }
.video-card:fullscreen video { width: 100%; height: 100%; object-fit: contain; }
.video-card:fullscreen .video-placeholder { width: 100%; height: 100%; aspect-ratio: auto; }
.video-card:fullscreen .puppy-face { width: 100%; height: 100%; object-fit: contain; }

/* avatar picker grid */
.avatar-picker { display: flex; flex-wrap: wrap; gap: 8px; margin: 8px 0 4px; }
.avatar-choice {
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  background: var(--dc-panel); border: 2px solid var(--dc-border); border-radius: 11px;
  padding: 6px 4px; cursor: pointer; width: 74px;
}
.avatar-choice img { width: 54px; height: 54px; object-fit: contain; }
.avatar-choice span { font-size: 11px; color: var(--dc-muted); }
.avatar-choice:hover { border-color: var(--dc-accent); }
.avatar-choice.selected { border-color: var(--dc-accent); background: var(--dc-panel-2); }
.avatar-choice.selected span { color: var(--dc-text); }
.avatar-add { justify-content: center; border-style: dashed; min-height: 78px; }
.avatar-add .avatar-add-plus { font-size: 26px; color: var(--dc-faint); line-height: 1; }
.avatar-add:hover .avatar-add-plus { color: var(--dc-accent); }

/* avatar builder */
.av-builder-window { width: min(440px, 94vw); }
.av-builder-body { padding: 12px 16px 16px; }
.av-name-row { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--dc-muted); }
.av-name-row input { flex: 1; background: #0c1020; border: none; border-radius: 8px; padding: 8px 10px; color: var(--dc-text); outline: none; }
.av-hint { font-size: 11.5px; color: var(--dc-faint); margin: 8px 0 10px; line-height: 1.45; }
.av-slots { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.av-slot {
  border: 2px dashed var(--dc-border); border-radius: 12px; padding: 8px 4px;
  display: flex; flex-direction: column; align-items: center; gap: 4px; cursor: pointer;
  background: var(--dc-panel); min-height: 92px; justify-content: center;
}
.av-slot:hover, .av-slot.drag { border-color: var(--dc-accent); background: var(--dc-panel-2); }
.av-slot.av-slot-key { box-shadow: 0 0 0 1px rgba(91, 108, 255, .35), 0 0 10px rgba(91, 108, 255, .25); }
.av-slot.av-slot-key:not(.filled) { border-color: var(--dc-accent); border-style: solid; }
.av-slot-thumb { width: 56px; height: 56px; display: grid; place-items: center; font-size: 24px; }
.av-slot-thumb img { width: 56px; height: 56px; object-fit: contain; }
.av-slot-label { font-size: 10.5px; color: var(--dc-muted); text-align: center; }
.av-slot.filled .av-slot-label { color: var(--dc-text); }
.av-builder-row { display: flex; align-items: center; gap: 12px; margin: 12px 0; }
.av-preview { width: 64px; height: 64px; flex: 0 0 auto; }
.av-preview img { width: 64px; height: 64px; object-fit: contain; }
.av-private { font-size: 12.5px; color: var(--dc-muted); display: flex; align-items: center; gap: 7px; margin-left: auto; cursor: pointer; }
.av-private input { width: 15px; height: 15px; }
.av-builder-save { display: flex; gap: 8px; }
.av-builder-save .dc-btn { flex: 1; }

/* "Add people" pill + ring-friends modal */
.dc-pill-add { background: rgba(61, 220, 151, .16); color: var(--dc-online); }
.dc-pill-add:hover { background: rgba(61, 220, 151, .28); }
.add-people-window { width: min(360px, 92vw); }
.ap-list { padding: 8px 12px; max-height: 50vh; overflow-y: auto; display: flex; flex-direction: column; gap: 4px; }
.ap-row { display: flex; align-items: center; gap: 9px; padding: 7px 9px; border-radius: 8px; background: var(--dc-panel); }
.ap-dot { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto; background: var(--dc-faint); }
.ap-dot.active { background: var(--dc-online); }
.ap-dot.away { background: var(--dc-away); }
.ap-name { flex: 1; font-size: 13px; font-weight: 600; color: var(--dc-text); }
.ap-ring { font-size: 12px; padding: 5px 12px; }
.ap-empty { padding: 10px; font-size: 12.5px; color: var(--dc-faint); }
.ap-foot { padding: 10px 16px 16px; }
.ap-foot .dc-btn { width: 100%; }

/* auto-update puppy popup */
.update-popup {
  position: fixed; inset: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  background: rgba(8, 11, 20, .82); backdrop-filter: blur(4px);
}
.update-popup.hidden { display: none; }
.update-popup-card {
  background: var(--dc-side-bg); border: 1px solid var(--dc-border); border-radius: 18px;
  padding: 28px 34px; text-align: center; width: min(340px, 90vw);
  box-shadow: 0 20px 60px rgba(0, 0, 0, .6);
}
.update-pup { width: 96px; height: 96px; object-fit: contain; animation: pup-bounce 1s ease-in-out infinite; }
@keyframes pup-bounce { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
.update-pup-title { font-size: 17px; font-weight: 800; color: var(--dc-text); margin-top: 8px; }
.update-pup-sub { font-size: 12.5px; color: var(--dc-muted); margin: 4px 0 14px; }
.update-pup-bar { height: 10px; border-radius: 6px; background: #0a0d18; overflow: hidden; }
.update-pup-fill { height: 100%; width: 0%; border-radius: 6px; background: linear-gradient(90deg, var(--dc-accent), #8a63ff); transition: width .2s ease; }
.update-pup-pct { font-size: 12px; color: var(--dc-muted); margin-top: 8px; font-weight: 700; }

/* ── Dens (user-created servers) ─────────────────────────────────────────── */
.den-rail-box { display: flex; flex-direction: column; align-items: center; gap: 9px; }
.dc-rail-btn.den-icon { overflow: hidden; padding: 0; }
.dc-rail-btn.den-icon img { width: 100%; height: 100%; object-fit: cover; border-radius: inherit; }
.dc-rail-btn.den-add { background: var(--dc-panel); color: var(--dc-faint); font-size: 20px; }
.dc-rail-btn.den-add:hover { background: var(--dc-online); color: #04210f; border-radius: 13px; }

.den-view { display: none; }
.den-head { padding: 10px 8px 8px; border-bottom: 1px solid var(--dc-border); margin-bottom: 8px; }
.den-title { font-size: 15px; font-weight: 700; color: var(--dc-text); }
.den-chan-group { margin-bottom: 8px; }
.den-chan {
  display: block; width: 100%; text-align: left; border: none; background: none; cursor: pointer;
  color: var(--dc-muted); font-size: 13.5px; font-weight: 600; padding: 6px 9px; border-radius: 7px;
}
.den-chan:hover { background: var(--dc-panel); color: var(--dc-text); }
.den-chan-empty { padding: 4px 10px; font-size: 11.5px; color: var(--dc-faint); }
.den-chan-row { display: flex; align-items: center; }
.den-chan-row .den-chan { flex: 1; }
.den-chan-del {
  background: none; border: none; cursor: pointer; color: var(--dc-faint);
  font-size: 12px; padding: 4px 8px; border-radius: 6px; opacity: 0;
}
.den-chan-row:hover .den-chan-del { opacity: 1; }
.den-chan-del:hover { color: var(--dc-danger); background: var(--dc-panel); }
.den-voice-occ { padding: 2px 10px 2px 26px; font-size: 12px; color: var(--dc-muted); }
.den-voice-occ:last-of-type { margin-bottom: 4px; }
.den-actions { flex-wrap: wrap; }
.den-actions .dc-btn { flex: 1 1 40%; font-size: 11.5px; }
/* den members / roles modal */
.den-members-window { width: min(360px, 92vw); }
.den-members-list { padding: 10px 14px 16px; display: flex; flex-direction: column; gap: 5px; max-height: 60vh; overflow-y: auto; }
.den-member-row { display: flex; align-items: center; gap: 9px; padding: 7px 9px; border-radius: 8px; background: var(--dc-panel); }
.den-member-name { flex: 1; font-size: 13px; font-weight: 600; color: var(--dc-text); }
.den-member-role { font-size: 10px; font-weight: 700; text-transform: uppercase; padding: 2px 7px; border-radius: 6px; }
.den-member-role.role-owner { background: rgba(245,196,81,.18); color: var(--dc-away); }
.den-member-role.role-admin { background: rgba(91,108,255,.2); color: var(--dc-accent-2); }
.den-member-role.role-member { background: var(--dc-panel-2); color: var(--dc-muted); }
.den-role-btn { font-size: 11px; padding: 4px 9px; }
.den-kick-btn { color: var(--dc-danger); }
/* drag-reorder feedback */
.den-chan-row.dragging { opacity: .4; }
.den-chan-row.drop-target { box-shadow: inset 0 2px 0 var(--dc-accent); }
.dc-side-group-label.drop-target { box-shadow: inset 0 2px 0 var(--dc-accent); border-radius: 4px; }
.dc-side-group-label[draggable="true"] { cursor: grab; }
/* per-channel notifications: unread + mute */
.den-chan-row { position: relative; }
.den-chan-row.has-unread::before {
  content: ''; position: absolute; left: 1px; top: 50%; transform: translateY(-50%);
  width: 6px; height: 6px; border-radius: 50%; background: var(--dc-text);
}
.den-chan-row.has-unread .den-chan { color: var(--dc-text); font-weight: 800; }
.den-chan-bell { background: none; border: none; cursor: pointer; font-size: 11px; padding: 4px 6px; opacity: 0; }
.den-chan-row:hover .den-chan-bell { opacity: .85; }
.den-chan-bell:hover { opacity: 1; }
.dc-rail-btn.den-icon.has-unread { box-shadow: 0 0 0 2px var(--dc-online); }
/* den audit log */
.den-log-list { padding: 10px 14px 16px; display: flex; flex-direction: column; gap: 4px; max-height: 60vh; overflow-y: auto; }
.den-log-row { display: flex; justify-content: space-between; gap: 10px; font-size: 12px; padding: 6px 8px; border-radius: 6px; background: var(--dc-panel); }
.den-log-text { color: var(--dc-text); }
.den-log-time { color: var(--dc-faint); white-space: nowrap; font-size: 10.5px; }
.den-log-empty { padding: 12px; color: var(--dc-faint); font-size: 12.5px; }

/* text channel = chat room (no video grid / call bar; chat fills the area) */
.text-channel-mode .dc-grid { display: none; }
.text-channel-mode .dc-callbar { display: none !important; }
.text-channel-mode .dc-chat { flex: 1 1 auto; max-height: none; }
.text-channel-mode .dc-chat-msgs { min-height: 0; max-height: none; flex: 1 1 auto; }
.den-actions { display: flex; gap: 7px; padding: 8px 6px; }
.den-actions .dc-btn { flex: 1; font-size: 12px; }

.den-create-window, .den-addchan-window { width: min(360px, 92vw); }
.den-create-body, .den-addchan-body { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 12px; }
.den-icon-pick { display: flex; flex-direction: column; align-items: center; gap: 6px; cursor: pointer; }
.den-icon-preview {
  width: 72px; height: 72px; border-radius: 18px; object-fit: cover;
  background: var(--dc-panel); border: 2px dashed var(--dc-border);
}
.den-icon-preview.has { border-style: solid; border-color: var(--dc-accent); }
.den-icon-hint { font-size: 11.5px; color: var(--dc-faint); }
.den-name-row { display: flex; flex-direction: column; gap: 5px; font-size: 12.5px; color: var(--dc-muted); }
.den-name-row input, .den-name-row select {
  background: #0c1020; border: none; outline: none; border-radius: 8px; padding: 9px 10px;
  color: var(--dc-text); font-size: 13px;
}
.den-create-actions { display: flex; gap: 8px; }
.den-create-actions .dc-btn { flex: 1; }
.den-join-row { display: flex; gap: 7px; border-top: 1px solid var(--dc-border); padding-top: 12px; }
.den-join-row input {
  flex: 1; min-width: 0; background: #0c1020; border: none; outline: none; border-radius: 8px;
  padding: 9px 10px; color: var(--dc-text); font-size: 12.5px;
}

/* settings checkbox row */
.toggle-row { display: flex; align-items: center; gap: 9px; cursor: pointer; font-size: 13px; }
.toggle-row input { width: 16px; height: 16px; flex: 0 0 auto; cursor: pointer; }

/* live file-transfer window */
.xfer-window { width: min(460px, 94vw); }
.xfer-list {
  padding: 10px 14px; max-height: 52vh; overflow-y: auto;
  display: flex; flex-direction: column; gap: 9px;
}
.xfer-list:empty::after {
  content: 'No transfers yet. Pick a file with the 📂 button while in a call.';
  color: var(--dc-faint); font-size: 12.5px; display: block; padding: 8px 2px;
}
.xfer-row { background: var(--dc-panel); border: 1px solid var(--dc-border); border-radius: 11px; padding: 10px 12px; }
.xfer-head { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; }
.xfer-title { font-size: 12.5px; font-weight: 600; color: var(--dc-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.xfer-status { font-size: 11px; color: var(--dc-muted); white-space: nowrap; flex: 0 0 auto; }
.xfer-bar { height: 6px; border-radius: 4px; background: #0a0d18; overflow: hidden; margin-top: 8px; }
.xfer-fill { height: 100%; width: 0%; border-radius: 4px; background: linear-gradient(90deg, var(--dc-accent), #8a63ff); transition: width .12s ease; }
.xfer-row.xfer-done .xfer-fill { background: var(--dc-live); }
.xfer-row.xfer-fail .xfer-fill { background: var(--dc-danger); }
.xfer-actions { display: flex; gap: 7px; margin-top: 9px; flex-wrap: wrap; }
.xfer-actions:empty { display: none; }
.xfer-accept, .xfer-decline, .xfer-dl {
  border: none; cursor: pointer; border-radius: 8px; padding: 6px 12px;
  font-size: 12px; font-weight: 600; text-decoration: none;
}
.xfer-accept { background: var(--dc-accent); color: #fff; }
.xfer-accept:hover { background: var(--dc-accent-2); }
.xfer-decline { background: var(--dc-panel-2); color: var(--dc-muted); }
.xfer-decline:hover { color: var(--dc-text); }
.xfer-dl { background: var(--dc-live); color: #04210f; display: inline-block; }
.xfer-foot { padding: 8px 16px 16px; font-size: 11px; color: var(--dc-faint); }

/* movable, puppy-themed transfer window */
.pup-xfer {
  position: fixed; right: 24px; bottom: 24px; z-index: 200;
  width: min(420px, 92vw);
  background: var(--dc-side-bg); border: 1px solid var(--dc-border);
  border-radius: 14px; box-shadow: 0 18px 50px rgba(0, 0, 0, .55);
  display: flex; flex-direction: column; overflow: hidden;
}
.pup-xfer.hidden { display: none; }
.pup-xfer-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 12px; cursor: grab; user-select: none;
  background: linear-gradient(135deg, var(--dc-accent), #8a63ff); color: #fff;
}
.pup-xfer-bar:active { cursor: grabbing; }
.pup-xfer-title { font-size: 13px; font-weight: 700; display: flex; align-items: center; gap: 7px; }
.pup-xfer-paw { font-size: 15px; }
.pup-xfer-close {
  background: rgba(255, 255, 255, .18); border: none; color: #fff;
  width: 24px; height: 24px; border-radius: 7px; cursor: pointer; font-size: 13px;
}
.pup-xfer-close:hover { background: rgba(255, 255, 255, .32); }
.pup-xfer .xfer-list { max-height: 44vh; }

/* "Send files" recipient picker */
.send-picker-window { width: min(380px, 92vw); }
.sp-section-label {
  padding: 12px 16px 4px; font-size: 11px; font-weight: 700; letter-spacing: .5px;
  text-transform: uppercase; color: var(--dc-faint);
}
.sp-files { padding: 0 16px; display: flex; flex-direction: column; gap: 4px; max-height: 120px; overflow-y: auto; }
.sp-file {
  font-size: 12.5px; color: var(--dc-text); background: var(--dc-panel);
  border: 1px solid var(--dc-border); border-radius: 8px; padding: 6px 9px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.sp-peers { padding: 4px 16px 0; display: flex; flex-direction: column; gap: 4px; max-height: 200px; overflow-y: auto; }
.sp-peer {
  display: flex; align-items: center; gap: 9px; padding: 7px 9px;
  border-radius: 8px; cursor: pointer; background: var(--dc-panel);
}
.sp-peer:hover { background: var(--dc-panel-2); }
.sp-peer input { width: 16px; height: 16px; flex: 0 0 auto; cursor: pointer; }
.sp-peer span { font-size: 13px; font-weight: 600; }
.sp-actions { display: flex; gap: 8px; padding: 14px 16px 16px; }
.sp-actions .dc-btn { flex: 1; }

/* Gray AI helper panel */
.dc-ai { border-top: 1px solid var(--dc-border); background: #0c1020; }
.dc-ai-head {
  list-style: none; cursor: pointer; padding: 11px 14px;
  font-size: 13px; font-weight: 700; color: var(--dc-text);
  display: flex; align-items: center; gap: 8px;
}
.dc-ai-head::-webkit-details-marker { display: none; }
.dc-ai-paw {
  width: 24px; height: 24px; border-radius: 7px; display: grid; place-items: center;
  background: linear-gradient(135deg,#3a4470,#5b6cff); font-size: 13px;
}
.dc-ai-body { padding: 0 12px 12px; display: flex; flex-direction: column; gap: 7px; }
.dc-ai-btn {
  text-align: left; border: 1px solid var(--dc-border); cursor: pointer;
  background: var(--dc-panel); color: var(--dc-text); border-radius: 9px;
  padding: 9px 11px; font-size: 12.5px; font-weight: 600;
}
.dc-ai-btn:hover { background: var(--dc-panel-2); border-color: var(--dc-accent); }
.dc-ai-btn:disabled { opacity: .6; cursor: progress; }
.dc-ai-result {
  margin-top: 4px; padding: 10px 11px; border-radius: 9px;
  background: #0a0d18; border: 1px solid var(--dc-border);
  font-size: 12.5px; line-height: 1.5; color: var(--dc-text);
  white-space: pre-wrap; max-height: 220px; overflow-y: auto;
}
.dc-ai-result.is-loading { color: var(--dc-muted); font-style: italic; }

/* ---- scrollbars ---------------------------------------------------------- */
.dc-side-scroll::-webkit-scrollbar, .dc-members-scroll::-webkit-scrollbar,
.dc-grid::-webkit-scrollbar, .dc-chat-msgs::-webkit-scrollbar,
.dc-ai-result::-webkit-scrollbar { width: 9px; }
.dc-side-scroll::-webkit-scrollbar-thumb, .dc-members-scroll::-webkit-scrollbar-thumb,
.dc-grid::-webkit-scrollbar-thumb, .dc-chat-msgs::-webkit-scrollbar-thumb,
.dc-ai-result::-webkit-scrollbar-thumb { background: #05070e; border-radius: 8px; }

/* ---- responsive: drop side panels on narrow windows ---------------------- */
@media (max-width: 1180px) {
  .dc-shell { grid-template-columns: 64px 220px minmax(0,1fr) 208px; }
}
@media (max-width: 860px) {
  .dc-shell { grid-template-columns: 56px 200px minmax(0,1fr); }
  .dc-members { display: none; }
}
@media (max-width: 620px) {
  .dc-shell { grid-template-columns: 52px minmax(0,1fr); }
  .dc-sidebar { display: none; }
}


/* ===== Den right-click / header dropdown menu ===== */
.den-ctx-menu {
  position: fixed; z-index: 4000; min-width: 196px;
  background: var(--dc-panel); border: 1px solid var(--dc-border);
  border-radius: 10px; padding: 6px; box-shadow: 0 12px 34px rgba(0,0,0,.55);
  display: flex; flex-direction: column; gap: 2px;
}
.den-ctx-head {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px;
  color: var(--dc-faint); padding: 6px 10px 4px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 240px;
}
.den-ctx-item {
  text-align: left; background: transparent; border: none; color: var(--dc-text);
  padding: 8px 10px; border-radius: 7px; font-size: 13px; cursor: pointer; white-space: nowrap;
}
.den-ctx-item:hover { background: var(--dc-accent); color: #fff; }
.den-ctx-item.is-danger { color: #ff8a8a; }
.den-ctx-item.is-danger:hover { background: #b3261e; color: #fff; }
.den-ctx-sep { height: 1px; background: var(--dc-border); margin: 4px 2px; }

/* Den header is now a dropdown trigger */
.den-head { cursor: pointer; display: flex; align-items: center; }
.den-caret { margin-left: auto; color: var(--dc-faint); font-size: 11px; }

/* ===== Den settings modal extras ===== */
.den-settings-section { border-top: 1px solid var(--dc-border); padding-top: 12px; margin-top: 4px; display: flex; flex-direction: column; gap: 6px; }
.den-settings-label { font-size: 12px; color: var(--dc-muted); }
.den-invite-row { display: flex; gap: 6px; }
.den-invite-row input {
  flex: 1; min-width: 0; background: var(--dc-panel-2); border: 1px solid var(--dc-border);
  border-radius: 8px; color: var(--dc-text); padding: 8px 10px; font-family: monospace; font-size: 13px;
}
.den-settings-hint { font-size: 11px; color: var(--dc-faint); }
.den-settings-danger { border-top: 1px solid var(--dc-border); padding-top: 12px; margin-top: 4px; }
.den-settings-danger .dc-btn { width: 100%; }
.den-danger-btn { background: #b3261e; color: #fff; }
.den-danger-btn:hover { background: #cf3a2f; }


/* ===== Den open: members panel shows only the Pack (hide friends UI) ===== */
.dc-members.den-mode .dc-friends-group,
.dc-members.den-mode .dc-addfriend,
.dc-members.den-mode #friendList { display: none; }


/* ===== Brand logo = new Pup Call paw icon ===== */
.dc-rail-logo { background: transparent; box-shadow: none; padding: 0; overflow: hidden; }
.dc-rail-logo-img { width: 100%; height: 100%; object-fit: cover; border-radius: 14px; display: block; }


/* ===== Rooms icon = paw-in-speech-bubble ===== */
.dc-rail-bubble { display: block; }

/* ===== Den voice-channel occupants: avatar + talk pulse ===== */
.den-voice-occ {
  display: flex; align-items: center; gap: 9px;
  padding: 5px 10px 5px 20px; font-size: 13.5px; color: var(--dc-muted);
}
.den-voice-av {
  width: 30px; height: 30px; border-radius: 50%; object-fit: cover;
  background: var(--dc-panel-2); flex: 0 0 auto;
  border: 2px solid transparent;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.den-voice-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.den-voice-occ.is-speaking .den-voice-av {
  border-color: var(--dc-online);
  box-shadow: 0 0 0 3px rgba(47,212,122,.25);
  animation: denVoiceTalk .45s ease-in-out infinite;
}
.den-voice-occ.is-speaking .den-voice-name { color: var(--dc-text); }
@keyframes denVoiceTalk {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.16); }
}


/* ===== occupant menu: volume slider + note ===== */
.den-ctx-vol { display: flex; align-items: center; gap: 8px; padding: 7px 10px; }
.den-ctx-vol input[type=range] { flex: 1; min-width: 90px; accent-color: var(--dc-accent); cursor: pointer; }
.den-ctx-vol-pct { font-size: 11px; color: var(--dc-faint); width: 34px; text-align: right; }
.den-ctx-note { padding: 6px 10px 8px; font-size: 11px; color: var(--dc-faint); max-width: 210px; }


/* ===== force chat to fill the main column below video/call ===== */
.dc-main > .dc-chat { flex: 1 1 0% !important; min-height: 0 !important; }
.dc-chat > .dc-chat-msgs { flex: 1 1 0% !important; min-height: 0 !important; max-height: none !important; }

/* ===== Add Pup call-bar tile (dark tile, green paw icon) ===== */
.dc-callbar .dc-addpup {
  width: 92px; height: 92px; padding: 0; border: none; border-radius: 20px; cursor: pointer;
  background: #1a2132;
  box-shadow: 0 3px 8px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.05);
  color: #d2d8e6; font-size: 12px; font-weight: 600; letter-spacing: .2px;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px;
}
.dc-callbar .dc-addpup .addpup-paw { display: block; fill: #3ddc84; }
.dc-callbar .dc-addpup:hover { filter: brightness(1.15); transform: translateY(-1px); }
.dc-callbar .dc-addpup:active { transform: translateY(0); }


/* force the main column to fill the viewport height so the chat can expand */
.dc-shell > .dc-main { height: 100vh !important; min-height: 0 !important; overflow: hidden; }

/* hamburger removed — settings now opens from the paw logo */
#settingsButton { display: none !important; }



/* ===== signup icon picker (auth gate) ===== */
.gate-avatar-row { display: flex; align-items: center; gap: 10px; margin-top: 4px; }
.gate-avatar-preview { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14); display: none; }
.gate-avatar-preview.has { display: block; }
.gate-avatar-btn { cursor: pointer; padding: 7px 12px; border-radius: 8px; background: rgba(255,255,255,.08); font-size: 13px; }
.gate-avatar-btn:hover { background: rgba(255,255,255,.14); }
.gate-avatar-clear { background: none; border: none; color: #ff8a8a; cursor: pointer; font-size: 12px; }
.auth-optional { opacity: .6; font-size: .85em; }


/* Download-app button in the top bar */
a.dc-pill { text-decoration: none; display: inline-flex; align-items: center; }
.dc-pill-download { background: var(--dc-accent); color: #fff; }
.dc-pill-download:hover { background: var(--dc-accent-2); }


/* Download-app button on the login page */
.auth-download {
  position: fixed; top: 16px; right: 18px; z-index: 5; text-decoration: none;
  background: var(--dc-accent); color: #fff; padding: 8px 14px; border-radius: 8px;
  font-size: 13px; font-weight: 600;
}
.auth-download:hover { background: var(--dc-accent-2); }
