/* VIK V1 SWIDGET - STANDALONE BUILD */
/* Extracted from swidget-dev.html */

:root {
  --bg-main: #06070B;
  --bg-panel: rgba(15, 18, 28, 0.65);
  --bg-glass: rgba(255, 255, 255, 0.04);
  --bg-glass-2: rgba(255, 255, 255, 0.03);
  --border-soft: rgba(255, 255, 255, 0.08);
  --border-glow: rgba(140, 120, 255, 0.25);
  --accent-cyan: #4DEBFF;
  --accent-purple: #A78BFA;
  --accent-green: #34D399;
  --accent-orange: #F59E0B;
  --accent-red: #fb7185;
  --text-primary: #E5E7EB;
  --text-secondary: #9CA3AF;
  --text-muted: #686b7a;
  --space-xs: 6px;
  --space-sm: 10px;
  --space-md: 14px;
  --space-lg: 18px;
}

* , *::before , *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  height: 100%;
}
body {
  width: 100%;
  min-height: 100%;
  background: var(--bg-main);
  overflow-x: hidden;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--text-primary);
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 0;
  background-image: radial-gradient(circle at 50% 50%, rgba(123, 92, 255, .03) 0%, transparent 70%), linear-gradient(rgba(255, 255, 255, .015) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, .015) 1px, transparent 1px);
  background-size: 100% 100%, 40px 40px, 40px 40px;
}

/* Hide scrollbars globally */
*::-webkit-scrollbar {
  display: none;
}

* {
  scrollbar-width: none;
  -ms-overflow-style: none;
}

/* XP SURGE animations */
@keyframes xpSurge {
  0% {
    box-shadow: 0 0 0 rgba(0, 255, 136, 0);
    filter: brightness(1);
  }
  15% {
    box-shadow: 0 0 8px rgba(0, 255, 136, .6), 0 0 16px rgba(0, 212, 255, .3);
    filter: brightness(1.4);
  }
  40% {
    box-shadow: 0 0 4px rgba(0, 255, 136, .3), 0 0 10px rgba(0, 212, 255, .15);
    filter: brightness(1.15);
  }
  60% {
    box-shadow: 0 0 6px rgba(0, 255, 136, .5), 0 0 14px rgba(0, 212, 255, .25);
    filter: brightness(1.3);
  }
  100% {
    box-shadow: 0 0 0 rgba(0, 255, 136, 0);
    filter: brightness(1);
  }
}

@keyframes xpGlow {
  0%, 100% {
    box-shadow: 0 0 2px rgba(0, 255, 136, .15);
  }
  50% {
    box-shadow: 0 0 6px rgba(0, 255, 136, .35), 0 0 12px rgba(0, 212, 255, .15);
  }
}

/* VIK PANEL - main container */
#vikPanel {
  position: fixed;
  z-index: 10000;
  width: min(260px, calc(100vw - 28px));
  max-height: min(1008px, calc(100dvh - 100px));
  background: linear-gradient(160deg, #0a0a12, #0c0c10);
  border: 1px solid rgba(167, 139, 250, .2);
  border-radius: 20px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .8);
  flex-direction: column;
  overflow: hidden;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  display: none;
}

#vikPanel.show {
  display: inline-flex;
  text-align: left;
  animation: vikIn .22s ease;
}

@keyframes vikIn {
  from {
    opacity: 0;
    transform: translateY(12px) scale(.95);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes vikOut {
  from {
    opacity: 1;
    transform: none;
  }
  to {
    opacity: 0;
    transform: translateY(8px) scale(.97);
  }
}

#vikPanel.closing {
  animation: vikOut .18s ease forwards;
  pointer-events: none;
}

/* HEADER */
.vik-header {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px 5px;
  border-bottom: 1px solid rgba(255, 255, 255, .06);
  flex-shrink: 0;
}

.vik-char-wrap {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  cursor: pointer;
}

.vik-char-wrap svg {
  width: 100%;
  height: 100%;
}

.vik-name {
  font-size: 12px;
  font-weight: 700;
  color: #eef0f7;
  line-height: 1;
}

.vik-title {
  font-size: 8px;
  color: #686b7a;
  letter-spacing: .04em;
  margin-top: 1px;
}

.vik-header-btns {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
  margin-left: auto;
}

.vik-header-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 5px;
  border: 1px solid rgba(255, 255, 255, .08);
  background: transparent;
  color: #9ca3af;
  font-size: 11px;
  cursor: pointer;
  transition: all .18s;
  flex-shrink: 0;
}

.vik-header-btn:hover {
  border-color: rgba(167, 139, 250, .3);
  color: #c4b5fd;
  background: rgba(123, 97, 255, .06);
}

.vik-btn-home {
  background: linear-gradient(135deg, #7b61ff, #5a45c8);
  color: #fff;
  border-color: transparent;
  font-weight: bold;
  font-size: 12px;
  box-shadow: 0 0 6px rgba(123, 97, 255, .4);
}

.vik-btn-hammer {
  color: #f59e0b;
}

.vik-btn-hammer:hover {
  color: #fbbf24;
  border-color: rgba(245, 158, 11, .4);
  background: rgba(245, 158, 11, .08);
}

.vik-btn-gear {
  color: #4debff;
}

.vik-btn-gear:hover {
  color: #67e8f9;
  border-color: rgba(77, 235, 255, .35);
  background: rgba(77, 235, 255, .06);
}

/* Locked buttons — disabled when not logged in */
.vik-btn-locked {
  opacity: 0.3 !important;
  cursor: not-allowed !important;
  pointer-events: none;
  filter: grayscale(1);
}
.vik-btn-locked:hover {
  border-color: rgba(255, 255, 255, .08) !important;
  background: transparent !important;
  color: inherit !important;
}

.vik-btn-close {
  font-size: 11px;
  color: #9ca3af;
}

.vik-btn-close:hover {
  color: #fb7185;
  border-color: rgba(251, 113, 133, .3);
  background: rgba(251, 113, 133, .06);
}

.vik-eq-icon {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 2px;
  padding: 0;
}

.vik-eq-icon .eq-bar {
  display: inline-block;
  width: 3px;
  border-radius: 1.5px;
  background: currentColor;
  animation: eqPulse 1.2s ease-in-out infinite;
}

.vik-eq-icon .eq-bar:nth-child(1) {
  height: 8px;
  animation-delay: 0s;
}

.vik-eq-icon .eq-bar:nth-child(2) {
  height: 12px;
  animation-delay: .2s;
}

.vik-eq-icon .eq-bar:nth-child(3) {
  height: 6px;
  animation-delay: .4s;
}

@keyframes eqPulse {
  0%, 100% {
    transform: scaleY(1);
  }
  50% {
    transform: scaleY(.4);
  }
}

/* XP BAR */
.vik-xp-bar {
  margin: 4px 12px 2px;
  padding: 4px 8px;
  background: rgba(0, 255, 136, .04);
  border: 1px solid rgba(0, 255, 136, .12);
  border-radius: 7px;
  flex-shrink: 0;
}

.vik-xp-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2px;
}

.vik-xp-level {
  font-size: 9px;
  font-weight: 700;
  color: #00ff88;
  letter-spacing: .08em;
}

.vik-xp-pts {
  font-size: 9px;
  color: #686b7a;
  font-family: monospace;
}

.vik-xp-track {
  height: 2px;
  background: rgba(255, 255, 255, .08);
  border-radius: 2px;
  overflow: hidden;
}

.vik-xp-fill {
  height: 100%;
  background: linear-gradient(90deg, #00ff88, #00d4ff);
  border-radius: 2px;
  transition: width .6s ease;
  animation: xpGlow 3s ease-in-out infinite;
}

.vik-xp-fill.surge {
  animation: xpSurge .6s ease-out;
}

.vik-xp-sub {
  font-size: 7px;
  color: #444;
  margin-top: 2px;
}/* IDENTITY */
.vik-identity {
  padding: 2px 12px 0;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
  flex-wrap: wrap;
}

.vik-id-handle {
  font-size: 10px;
  font-weight: 700;
  color: #fb7185;
}

.vik-id-sep {
  color: #333;
  font-size: 9px;
}

.vik-id-wallet {
  font-size: 8px;
  color: #686b7a;
  font-family: monospace;
}

.vik-id-hint {
  font-size: 9px;
  color: #686b7a;
}

.vik-id-badge-count {
  font-size: 8px;
  color: #a78bfa;
  cursor: pointer;
  padding: 1px 6px;
  border: 1px solid rgba(167, 139, 250, .2);
  border-radius: 4px;
  background: rgba(123, 97, 255, .06);
  transition: all .18s;
}

.vik-id-badge-count:hover {
  background: rgba(123, 97, 255, .15);
  border-color: rgba(167, 139, 250, .4);
}

.vik-id-logout {
  font-size: 8px;
  color: #4b5563;
  padding: 1px 6px;
  border: 1px solid rgba(255, 255, 255, .07);
  border-radius: 4px;
  background: transparent;
  cursor: pointer;
  font-family: inherit;
  letter-spacing: .04em;
  margin-left: 2px;
  transition: all .18s;
}

.vik-id-logout:hover {
  color: #fb7185;
  border-color: rgba(251, 113, 133, .3);
  background: rgba(251, 113, 133, .06);
}

.vik-id-sol {
  font-size: 7px;
  padding: 1px 5px;
  border-radius: 3px;
  border: 1px solid rgba(0, 255, 136, .25);
  color: #00ff88;
  background: rgba(0, 255, 136, .05);
  cursor: pointer;
  transition: all .18s;
}

.vik-id-sol:hover {
  background: rgba(0, 255, 136, .12);
  border-color: rgba(0, 255, 136, .45);
}

.vik-sol-popup {
  display: none;
  position: fixed;
  z-index: 9999;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(10, 10, 20, .97);
  border: 1px solid rgba(0, 255, 136, .3);
  color: #e0fce8;
  font-size: 11px;
  line-height: 1.6;
  max-width: 200px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, .7), 0 0 12px rgba(0, 255, 136, .1);
  backdrop-filter: blur(10px);
  animation: badgePopIn .15s ease;
}

.vik-sol-popup.show {
  display: block;
}

.vik-sol-popup .sol-title {
  font-weight: 700;
  color: #00ff88;
  font-size: 12px;
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 5px;
}

.vik-sol-popup .sol-bal {
  font-size: 16px;
  font-weight: 800;
  color: #fff;
  font-family: monospace;
  letter-spacing: .02em;
}

.vik-sol-popup .sol-usd {
  font-size: 9px;
  color: #686b7a;
  margin-top: 1px;
}

/* BADGE DRAWER */
.vik-badge-drawer-wrap {
  position: relative;
  flex-shrink: 0;
  height: 0;
  overflow: visible;
}

.vik-badge-drawer {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  max-height: 0;
  overflow: visible;
  background: rgba(12, 12, 22, .95);
  border: 1px solid transparent;
  border-radius: 0 0 12px 12px;
  backdrop-filter: blur(12px);
  transition: max-height .25s cubic-bezier(.4, 0, .2, 1), opacity .2s, padding .25s, border-color .2s;
  opacity: 0;
  z-index: 20;
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 0;
}

.vik-badge-drawer.drawer-open {
  max-height: 130px;
  opacity: 1;
  padding: 6px 12px 8px;
  border-color: rgba(167, 139, 250, .2);
}

.vik-badge-drawer .drawer-title {
  font-size: 7px;
  color: #555;
  font-weight: 700;
  letter-spacing: .12em;
}

.vik-badge-drawer .badge-list {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  overflow: visible;
}

.vik-badge-chip {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 3px 7px;
  border-radius: 5px;
  font-size: 9px;
  cursor: pointer;
  transition: transform .15s;
}

.vik-badge-chip:hover {
  transform: scale(1.08);
}

.vik-badge-chip.iconic {
  background: linear-gradient(135deg, rgba(251, 191, 36, .15), rgba(251, 146, 60, .1));
  border: 1px solid rgba(251, 191, 36, .35);
  color: #fbbf24;
}

.vik-badge-chip.rare {
  background: rgba(167, 139, 250, .1);
  border: 1px solid rgba(167, 139, 250, .3);
  color: #c4b5fd;
}

.vik-badge-chip.common {
  background: rgba(0, 255, 136, .06);
  border: 1px solid rgba(0, 255, 136, .2);
  color: #86efac;
}

/* Badge popup */
.vik-badge-popup {
  display: none;
  position: fixed;
  z-index: 9999;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(10, 10, 20, .97);
  border: 1px solid rgba(167, 139, 250, .35);
  color: #e0d8fc;
  font-size: 11px;
  line-height: 1.5;
  max-width: 220px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, .7), 0 0 12px rgba(123, 97, 255, .15);
  backdrop-filter: blur(10px);
  pointer-events: none;
  animation: badgePopIn .15s ease;
}

.vik-badge-popup.show {
  display: block;
}

.vik-badge-popup .bp-name {
  font-weight: 700;
  color: #c4b5fd;
  font-size: 12px;
  margin-bottom: 3px;
  display: flex;
  align-items: center;
  gap: 5px;
}

.vik-badge-popup .bp-tier {
  font-size: 8px;
  padding: 1px 6px;
  border-radius: 3px;
  font-weight: 600;
  letter-spacing: .06em;
}

.vik-badge-popup .bp-tier.iconic {
  background: rgba(251, 191, 36, .18);
  color: #fbbf24;
}

.vik-badge-popup .bp-tier.rare {
  background: rgba(167, 139, 250, .18);
  color: #a78bfa;
}

.vik-badge-popup .bp-tier.common {
  background: rgba(0, 255, 136, .12);
  color: #86efac;
}

.vik-badge-popup .bp-desc {
  color: #9ca3af;
  font-size: 10px;
}

@keyframes badgePopIn {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

/* SETTINGS PANEL */
.vik-settings-panel {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 25;
  background: linear-gradient(180deg, rgba(12, 12, 22, .98), rgba(15, 15, 26, .96));
  backdrop-filter: blur(10px);
  border-radius: 20px;
  padding: 0 12px;
  overflow-y: auto;
  transform: translateY(-100%);
  opacity: 0;
  transition: transform .3s cubic-bezier(.4, 0, .2, 1), opacity .25s;
  pointer-events: none;
}

.vik-settings-panel.settings-open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
  padding: 10px 12px 14px;
}

.vik-settings-close {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

.vik-settings-close-btn {
  padding: 3px 8px;
  border-radius: 5px;
  border: 1px solid rgba(255, 255, 255, .1);
  background: transparent;
  color: #9ca3af;
  font-size: 9px;
  cursor: pointer;
  font-family: inherit;
  transition: all .18s;
}

.vik-settings-close-btn:hover {
  color: #fb7185;
  border-color: rgba(251, 113, 133, .3);
}

.vik-settings-title {
  font-size: 8px;
  color: #555;
  font-weight: 700;
  letter-spacing: .12em;
  margin-bottom: 6px;
}

.vik-setting-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4px 0;
}

.vik-setting-label {
  font-size: 10px;
  color: #9ca3af;
}

.vik-toggle {
  position: relative;
  width: 32px;
  height: 18px;
  border-radius: 9px;
  border: 1px solid rgba(255, 255, 255, .12);
  background: rgba(255, 255, 255, .06);
  cursor: pointer;
  transition: all .2s;
  flex-shrink: 0;
}

.vik-toggle::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #686b7a;
  transition: all .2s;
}

.vik-toggle.on {
  background: rgba(123, 97, 255, .25);
  border-color: rgba(167, 139, 250, .5);
}

.vik-toggle.on::after {
  left: 16px;
  background: #c4b5fd;
}

/* BEGINNER MODE GUIDE SYSTEM */
.vik-guide-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9990;
  background: rgba(0, 0, 0, .55);
  pointer-events: auto;
}

.vik-guide-overlay.active {
  display: block;
}

.vik-guide-highlight {
  position: fixed;
  z-index: 9991;
  border-radius: 8px;
  box-shadow: 0 0 0 3px rgba(167, 139, 250, .7), 0 0 20px rgba(123, 97, 255, .4), 0 0 40px rgba(123, 97, 255, .15);
  pointer-events: none;
  transition: all .35s ease;
}

.vik-guide-highlight::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 10px;
  border: 2px dashed rgba(167, 139, 250, .4);
  animation: guideRing 1.5s ease-in-out infinite;
}

@keyframes guideRing {
  0%, 100% {
    opacity: .4;
    transform: scale(1);
  }
  50% {
    opacity: 1;
    transform: scale(1.02);
  }
}

.vik-guide-popup {
  display: none;
  position: fixed;
  z-index: 9992;
  width: 240px;
  padding: 14px 16px;
  border-radius: 14px;
  background: linear-gradient(160deg, rgba(20, 18, 35, .98), rgba(12, 12, 22, .98));
  border: 1px solid rgba(167, 139, 250, .35);
  box-shadow: 0 12px 40px rgba(0, 0, 0, .7), 0 0 20px rgba(123, 97, 255, .12);
  backdrop-filter: blur(12px);
  animation: guidePopIn .25s ease;
}

.vik-guide-popup.show {
  display: block;
}

@keyframes guidePopIn {
  from {
    opacity: 0;
    transform: translateY(8px) scale(.95);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

.vik-guide-step {
  font-size: 8px;
  color: #a78bfa;
  font-weight: 700;
  letter-spacing: .1em;
  margin-bottom: 4px;
}

.vik-guide-title {
  font-size: 13px;
  font-weight: 700;
  color: #e5e7eb;
  margin-bottom: 6px;
  line-height: 1.3;
}

.vik-guide-desc {
  font-size: 11px;
  color: #9ca3af;
  line-height: 1.5;
  margin-bottom: 10px;
}

.vik-guide-tip {
  font-size: 9px;
  color: #f59e0b;
  background: rgba(245, 158, 11, .08);
  border: 1px solid rgba(245, 158, 11, .2);
  border-radius: 6px;
  padding: 5px 8px;
  margin-bottom: 10px;
  line-height: 1.4;
}

.vik-guide-tip::before {
  content: '💡 ';
  font-size: 10px;
}

.vik-guide-btns {
  display: flex;
  gap: 6px;
  align-items: center;
}

.vik-guide-btn {
  padding: 5px 12px;
  border-radius: 7px;
  border: 1px solid rgba(255, 255, 255, .1);
  background: rgba(255, 255, 255, .04);
  color: #9ca3af;
  font-size: 10px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: all .18s;
}

.vik-guide-btn:hover {
  border-color: rgba(167, 139, 250, .4);
  color: #c4b5fd;
  background: rgba(123, 97, 255, .08);
}

.vik-guide-btn.primary {
  background: linear-gradient(135deg, rgba(123, 97, 255, .2), rgba(77, 235, 255, .08));
  border-color: rgba(167, 139, 250, .4);
  color: #c4b5fd;
}

.vik-guide-btn.primary:hover {
  background: linear-gradient(135deg, rgba(123, 97, 255, .3), rgba(77, 235, 255, .12));
  box-shadow: 0 0 10px rgba(123, 97, 255, .2);
}

.vik-guide-btn.skip {
  border: none;
  background: none;
  color: #555;
  font-size: 9px;
  margin-left: auto;
}

.vik-guide-btn.skip:hover {
  color: #9ca3af;
}

.vik-guide-progress {
  display: flex;
  gap: 3px;
  margin-top: 8px;
}

.vik-guide-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .1);
  transition: all .2s;
}

.vik-guide-dot.done {
  background: rgba(0, 255, 136, .5);
}

.vik-guide-dot.current {
  background: #a78bfa;
  box-shadow: 0 0 6px rgba(167, 139, 250, .5);
}

.vik-guide-arrow {
  position: fixed;
  z-index: 9993;
  font-size: 20px;
  color: #a78bfa;
  filter: drop-shadow(0 0 6px rgba(167, 139, 250, .5));
  animation: guideArrowBounce 1s ease-in-out infinite;
  pointer-events: none;
}

@keyframes guideArrowBounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-6px);
  }
}

/* CREDENTIAL CONNECT SECTION */
.vik-settings-divider {
  height: 1px;
  background: rgba(255, 255, 255, .06);
  margin: 6px 0;
}

.vik-cred-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 2px;
}

.vik-cred-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, .1);
  background: rgba(255, 255, 255, .03);
  color: #9ca3af;
  font-size: 9px;
  font-weight: 600;
  cursor: pointer;
  transition: all .18s;
  font-family: inherit;
}

.vik-cred-btn:hover {
  border-color: rgba(167, 139, 250, .4);
  color: #c4b5fd;
  background: rgba(123, 97, 255, .06);
}

.vik-cred-btn .cred-icon {
  font-size: 11px;
}

.vik-cred-btn.cred-wallet:hover {
  border-color: rgba(0, 255, 136, .4);
  color: #86efac;
  background: rgba(0, 255, 136, .06);
}

.vik-cred-btn.cred-email:hover {
  border-color: rgba(77, 235, 255, .35);
  color: #67e8f9;
  background: rgba(77, 235, 255, .06);
}

.vik-cred-btn.cred-livevo:hover {
  border-color: rgba(251, 113, 133, .35);
  color: #fb7185;
  background: rgba(251, 113, 133, .06);
}

.vik-cred-btn.cred-x:hover {
  border-color: rgba(255, 255, 255, .25);
  color: #e5e7eb;
  background: rgba(255, 255, 255, .06);
}

.vik-cred-linked {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  border-radius: 6px;
  font-size: 9px;
  color: #686b7a;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, .06);
  background: transparent;
}

.vik-cred-linked .cred-check {
  color: #00ff88;
  font-size: 10px;
}
/* CRYPTO TICKER - Locked panel */
.vik-crypto-ticker {
  margin: 4px 12px;
  padding: 5px 8px;
  background: rgba(0, 255, 136, .03);
  border: 1px solid rgba(0, 255, 136, .1);
  border-radius: 7px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 6px;
}

.vik-crypto-price {
  font-size: 14px;
  font-weight: 800;
  color: #e5e7eb;
  font-family: 'Fira Code', monospace;
  letter-spacing: -.02em;
}

.vik-crypto-change {
  font-size: 9px;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
}

.vik-crypto-change.up {
  color: #00ff88;
  background: rgba(0, 255, 136, .1);
}

.vik-crypto-change.down {
  color: #fb7185;
  background: rgba(251, 113, 133, .08);
}

.vik-crypto-label {
  font-size: 8px;
  color: #686b7a;
  font-weight: 600;
  letter-spacing: .08em;
}

.vik-crypto-toggle {
  display: flex;
  gap: 2px;
  margin-left: auto;
}

.vik-crypto-toggle button {
  padding: 2px 6px;
  border-radius: 4px;
  border: 1px solid rgba(255, 255, 255, .08);
  background: transparent;
  color: #686b7a;
  font-size: 8px;
  font-weight: 700;
  cursor: pointer;
  transition: all .18s;
  font-family: inherit;
  letter-spacing: .04em;
}

.vik-crypto-toggle button.active {
  background: rgba(167, 139, 250, .15);
  border-color: rgba(167, 139, 250, .35);
  color: #c4b5fd;
}

.vik-crypto-toggle button:hover {
  border-color: rgba(167, 139, 250, .3);
  color: #9ca3af;
}

.vik-candle-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4px 12px 2px;
  gap: 6px;
}

.vik-candle-header .vik-crypto-price {
  font-size: 12px;
  font-weight: 700;
  color: #e2e8f0;
  font-family: monospace;
}

.vik-candle-header .vik-crypto-change {
  font-size: 9px;
  font-family: monospace;
  margin-left: 2px;
}

.vik-candle-header .vik-crypto-toggle {
  display: flex;
  gap: 2px;
}

.vik-lockable {
  position: relative;
  overflow: hidden;
  min-height: 280px;
}

.vik-candle-wrap {
  position: relative;
  width: 100%;
  margin-top: 6px;
}

.vik-candle-canvas {
  width: 100%;
  height: 64px;
  display: block;
}

.vik-candle-tf {
  display: flex;
  justify-content: flex-end;
  gap: 3px;
  padding: 2px 0 0;
}

.vik-candle-tf button {
  padding: 1px 5px;
  border-radius: 3px;
  border: 1px solid rgba(255, 255, 255, .07);
  background: transparent;
  color: #4b5563;
  font-size: 8px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  transition: all .18s;
}

.vik-candle-tf button.active {
  background: rgba(167, 139, 250, .15);
  border-color: rgba(167, 139, 250, .3);
  color: #c4b5fd;
}

.vik-candle-tf button:hover {
  color: #9ca3af;
  border-color: rgba(255, 255, 255, .15);
}

/* STATUS CARD */
.vik-status-card {
  margin: 6px 12px;
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.vik-status-card.locked {
  background: rgba(251, 146, 60, .06);
  border: 1px solid rgba(251, 146, 60, .2);
  color: rgba(251, 146, 60, .9);
}

.vik-status-card .status-icon {
  font-size: 13px;
}

/* TIMESTAMP */
.vik-ts {
  padding: 0 12px;
  font-size: 7px;
  color: rgba(255, 255, 255, .12);
  flex-shrink: 0;
}

/* TOOLS ROW */
.vik-tools {
  padding: 3px 12px 2px;
  display: flex;
  gap: 3px;
  flex-shrink: 0;
}

.vik-tool {
  flex: 1;
  padding: 6px 6px;
  border-radius: 5px;
  border: 1px solid rgba(255, 255, 255, .08);
  background: transparent;
  color: #9ca3af;
  font-size: 7px;
  font-weight: 600;
  cursor: pointer;
  transition: all .18s;
  font-family: inherit;
  text-align: center;
}

.vik-tool:hover {
  border-color: rgba(167, 139, 250, .4);
  color: #c4b5fd;
  background: rgba(123, 97, 255, .08);
}

/* MESSAGES REEL */
.vik-msgs {
  padding: 0;
  margin: 4px 10px;
  min-height: 52px;
  max-height: 180px;
  overflow-y: auto;
  flex: 0 1 auto;
  position: relative;
  border-radius: 14px;
  background: rgba(255, 255, 255, .02);
  border: 1px solid rgba(255, 255, 255, .05);
  box-shadow: inset 0 2px 8px rgba(0, 0, 0, .3), inset 0 -2px 8px rgba(0, 0, 0, .2);
}

.vik-msgs::before {
  content: '';
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  display: block;
  height: 16px;
  background: linear-gradient(rgba(14, 14, 24, .9), transparent);
  pointer-events: none;
  z-index: 2;
  margin-bottom: -16px;
  border-radius: 14px 14px 0 0;
}

.vik-msgs::after {
  content: '';
  position: sticky;
  bottom: 0;
  left: 0;
  right: 0;
  display: block;
  height: 16px;
  background: linear-gradient(transparent, rgba(14, 14, 24, .9));
  pointer-events: none;
  z-index: 2;
  margin-top: -16px;
  border-radius: 0 0 14px 14px;
}

.vik-msg {
  padding: 8px 12px;
  font-size: 11px;
  color: #c8cce0;
  line-height: 1.5;
  border-bottom: 1px solid rgba(255, 255, 255, .04);
  position: relative;
}

.vik-msg:last-child {
  border-bottom: none;
}

.vik-msg.user {
  background: rgba(123, 97, 255, .06);
  color: #c4b5fd;
  text-align: right;
}

.vik-msg .vik-tag {
  font-size: 7px;
  color: #fb923c;
  font-weight: 700;
  margin-bottom: 1px;
  letter-spacing: .04em;
}

/* INPUT */
.vik-input-wrap {
  padding: 3px 12px 6px;
  display: flex;
  gap: 4px;
  border-top: 1px solid rgba(255, 255, 255, .05);
  flex-shrink: 0;
}

.vik-input {
  flex: 1;
  background: rgba(255, 255, 255, .05);
  border: 1px solid rgba(255, 255, 255, .07);
  border-radius: 7px;
  padding: 10px 14px;
  color: #eef0f7;
  font-size: 10px;
  outline: none;
  font-family: inherit;
}

.vik-input::placeholder {
  color: #686b7a;
}

.vik-input:focus {
  border-color: rgba(167, 139, 250, .3);
  box-shadow: 0 0 8px rgba(123, 97, 255, .1);
}

.vik-send {
  border-radius: 6px;
  border: none;
  background: linear-gradient(135deg, #7b61ff, #5a45c8);
  color: #fff;
  cursor: pointer;
  font-size: 12px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  transition: all .18s;
}

.vik-send:hover {
  box-shadow: 0 0 12px rgba(123, 97, 255, .3);
}

.vik-x-btn {
  width: 100%;
  padding: 3px 8px;
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, .07);
  background: transparent;
  color: #686b7a;
  font-size: 9px;
  cursor: pointer;
  font-family: inherit;
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 2px;
}

.vik-x-btn:hover {
  border-color: rgba(167, 139, 250, .3);
  color: #c4b5fd;
  background: rgba(123, 97, 255, .06);
}

/* LOCK OVERLAY - Pre-login state */
.vik-lock-overlay {
  position: absolute;
  inset: 0;
  z-index: 30;
  background: rgba(7, 7, 12, .88);
  backdrop-filter: blur(6px);
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.lock-icon {
  font-size: 40px;
}

.lock-text {
  font-size: 11px;
  font-weight: 600;
  color: #c4b5fd;
  text-align: center;
  max-width: 180px;
  line-height: 1.4;
}

.lock-btn {
  padding: 6px 20px;
  border-radius: 8px;
  border: 1px solid rgba(167, 139, 250, .3);
  background: linear-gradient(135deg, #7b61ff, #5a45c8);
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: all .18s;
  margin-top: 4px;
}

.lock-btn:hover {
  box-shadow: 0 0 12px rgba(123, 97, 255, .4);
}

/* F4A CHAT PANEL - Free4All state */
@keyframes f4aFadeUp {
  from {
    opacity: 0;
    transform: scale(.85);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes f4aPulse {
  0%, 100% {
    opacity: .5;
  }
  50% {
    opacity: 1;
  }
}

.vik-f4a {
  display: flex;
  flex-direction: column;
  width: min(260px, calc(100vw - 28px));
  min-height: 320px;
  background: rgba(14, 15, 20, .65);
  backdrop-filter: blur(12px);
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, .09);
  box-shadow: 0 0 0.5px rgba(255, 255, 255, .07), 0 10px 30px rgba(0, 0, 0, .65), inset 0 0 20px rgba(255, 255, 255, .02);
  overflow: hidden;
}

.vik-f4a-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px 8px;
  border-bottom: 1px solid rgba(255, 255, 255, .07);
  flex-shrink: 0;
  background: rgba(255, 255, 255, .02);
}

.vik-f4a-title {
  font-size: 10px;
  font-weight: 700;
  color: #a0a8b8;
  letter-spacing: .1em;
  flex: 1;
  text-transform: uppercase;
}

.vik-f4a-online {
  font-size: 8px;
  color: #00ff9f;
  text-shadow: 0 0 8px rgba(0, 255, 160, .6);
  letter-spacing: .06em;
  display: flex;
  align-items: center;
  gap: 4px;
}

.vik-f4a-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #00ff9f;
  box-shadow: 0 0 6px rgba(0, 255, 160, .8);
  animation: f4aPulse 2s infinite;
}

.vik-f4a-msgs {
  flex: 1;
  overflow-y: auto;
  padding: 10px 10px 6px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  scrollbar-width: none;
}

.vik-f4a-msg {
  animation: f4aFadeUp .28s cubic-bezier(.2, .8, .3, 1) both;
  display: flex;
  flex-direction: column;
  gap: 3px;
  align-items: center;
  gap: 6px;
  padding: 0 2px;
}

.vik-f4a-who {
  font-size: 8px;
  font-weight: 700;
  color: #555d6e;
  letter-spacing: .06em;
}

.vik-f4a-ts {
  font-size: 8px;
  color: rgba(255, 255, 255, .18);
}

.vik-f4a-text {
  font-size: 11px;
  color: #c8cdd8;
  background: linear-gradient(135deg, rgba(255, 255, 255, .07), rgba(255, 255, 255, .02));
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 10px;
  padding: 6px 10px;
  display: inline-block;
  max-width: 90%;
  line-height: 1.45;
  transition: border-color .15s, box-shadow .15s;
}

.vik-f4a-text:hover {
  border-color: rgba(255, 255, 255, .22);
  box-shadow: 0 0 10px rgba(255, 255, 255, .06);
}

.vik-f4a-msg.f4a-out {
  align-items: flex-end;
}

.vik-f4a-msg.f4a-out .vik-f4a-who {
  color: #7a8494;
}

.vik-f4a-msg.f4a-out .vik-f4a-text {
  background: linear-gradient(135deg, rgba(255, 255, 255, .1), rgba(255, 255, 255, .04));
  border-color: rgba(255, 255, 255, .15);
  color: #e2e6ee;
}

.vik-f4a-msg.f4a-out .vik-f4a-text:hover {
  border-color: rgba(255, 255, 255, .28);
  box-shadow: 0 0 10px rgba(255, 255, 255, .08);
}

.vik-f4a-bar {
  display: flex;
  gap: 6px;
  padding: 8px 10px;
  border-top: 1px solid rgba(255, 255, 255, .06);
  flex-shrink: 0;
  background: rgba(255, 255, 255, .015);
}

.vik-f4a-input {
  flex: 1;
  background: rgba(8, 10, 14, .85);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 10px;
  color: #c8cdd8;
  font-size: 11px;
  padding: 7px 11px;
  outline: none;
  font-family: inherit;
  transition: border-color .15s, box-shadow .15s;
}

.vik-f4a-input::placeholder {
  color: rgba(255, 255, 255, .2);
}

.vik-f4a-input:focus {
  border-color: rgba(255, 255, 255, .3);
  box-shadow: 0 0 10px rgba(255, 255, 255, .07);
}

.vik-f4a-send {
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .12);
  color: #8a9ab0;
  border-radius: 10px;
  padding: 7px 13px;
  cursor: pointer;
  font-size: 13px;
  transition: background .15s, box-shadow .15s;
}

.vik-f4a-send:hover {
  background: rgba(255, 255, 255, .12);
  box-shadow: 0 0 10px rgba(255, 255, 255, .08);
}

.vik-f4a-msgs .vik-f4a-msg:nth-child(2) {
  animation-delay: 80ms;
}

.vik-f4a-msgs .vik-f4a-msg:nth-child(3) {
  animation-delay: 160ms;
}

/* TERMINAL MODE - Cartridge themes */
#vikPanel.vik-terminal {
  font-family: 'Courier New', Courier, monospace;
  border-color: rgba(124, 92, 255, .12);
  background: linear-gradient(180deg, #0B0C10, #11131A);
}
#vikPanel.vik-terminal .vik-header {
  border-bottom-color: #1A1D26;
}

#vikPanel.vik-terminal .vik-name {
  font-family: inherit;
  letter-spacing: .06em;
  font-size: 11px;
  color: #E6EAF2;
}

#vikPanel.vik-terminal .vik-title {
  color: #5E81AC;
  font-family: inherit;
  letter-spacing: .08em;
}

#vikPanel.vik-terminal .vik-xp-bar {
  border-color: #1A1D26;
  background: rgba(124, 92, 255, .03);
}

#vikPanel.vik-terminal .vik-xp-level {
  font-family: inherit;
  color: #9AA3B2;
}

#vikPanel.vik-terminal .vik-xp-pts {
  font-family: inherit;
  color: #9AA3B2;
}

#vikPanel.vik-terminal .vik-xp-fill {
  background: linear-gradient(90deg, #7C5CFF, #5E81AC);
  animation-name: xpGlow;
}

#vikPanel.vik-terminal .vik-identity {
  font-family: inherit;
}

#vikPanel.vik-terminal .vik-id-handle {
  color: #7C5CFF;
}

#vikPanel.vik-terminal .vik-id-wallet {
  color: #5C6370;
}

#vikPanel.vik-terminal .vik-id-badge-count {
  border-color: #1A1D26;
  color: #7C5CFF;
  background: rgba(124, 92, 255, .05);
}

#vikPanel.vik-terminal .vik-msgs {
  background: rgba(0, 0, 0, .35);
  border-color: rgba(124, 92, 255, .06);
  box-shadow: inset 0 2px 12px rgba(0, 0, 0, .5);
}

#vikPanel.vik-terminal .vik-msg {
  font-family: 'Courier New', Courier, monospace;
  font-size: 10px;
  color: #9AA3B2;
  line-height: 1.6;
  border-bottom-color: #1A1D26;
  padding: 6px 12px;
}

#vikPanel.vik-terminal .vik-msg::before {
  content: '> ';
  color: #5C6370;
}

#vikPanel.vik-terminal .vik-msg.user {
  background: rgba(124, 92, 255, .03);
  color: #E6EAF2;
  text-align: left;
}

#vikPanel.vik-terminal .vik-msg.user::before {
  content: '$ ';
  color: #7C5CFF;
}

#vikPanel.vik-terminal .vik-tag {
  color: #5E81AC;
  font-size: 8px;
  letter-spacing: .1em;
  font-family: inherit;
}

#vikPanel.vik-terminal .vik-tools {
  gap: 4px;
}

#vikPanel.vik-terminal .vik-tool {
  font-family: 'Courier New', Courier, monospace;
  font-size: 8px;
  color: #5C6370;
  border-color: #1A1D26;
  background: rgba(0, 0, 0, .2);
  border-radius: 3px;
  letter-spacing: .02em;
}

#vikPanel.vik-terminal .vik-tool::before {
  content: '[ ';
}

#vikPanel.vik-terminal .vik-tool::after {
  content: ' ]';
}

#vikPanel.vik-terminal .vik-tool:hover {
  border-color: rgba(124, 92, 255, .35);
  color: #E6EAF2;
  background: rgba(124, 92, 255, .06);
  box-shadow: 0 0 8px rgba(124, 92, 255, .08);
}

#vikPanel.vik-terminal .vik-input {
  font-family: 'Courier New', Courier, monospace;
  font-size: 10px;
  background: rgba(0, 0, 0, .3);
  border-color: #1A1D26;
  color: #E6EAF2;
  border-radius: 3px;
}

#vikPanel.vik-terminal .vik-input::placeholder {
  color: #5C6370;
}

#vikPanel.vik-terminal .vik-input:focus {
  border-color: rgba(124, 92, 255, .4);
  box-shadow: 0 0 8px rgba(124, 92, 255, .08);
}

#vikPanel.vik-terminal .vik-send {
  background: rgba(124, 92, 255, .12);
  border: 1px solid rgba(124, 92, 255, .25);
  color: #7C5CFF;
  border-radius: 3px;
  font-family: 'Courier New', Courier, monospace;
  font-size: 10px;
  box-shadow: none;
}

#vikPanel.vik-terminal .vik-send:hover {
  background: rgba(124, 92, 255, .2);
  box-shadow: 0 0 10px rgba(124, 92, 255, .1);
}

#vikPanel.vik-terminal .vik-header-btn {
  border-color: #1A1D26;
  border-radius: 3px;
}

#vikPanel.vik-terminal .vik-header-btn:hover {
  border-color: rgba(124, 92, 255, .3);
  color: #E6EAF2;
  background: rgba(124, 92, 255, .06);
}

#vikPanel.vik-terminal .vik-btn-home {
  background: rgba(124, 92, 255, .12);
  color: #7C5CFF;
  border-color: rgba(124, 92, 255, .25);
  box-shadow: 0 0 6px rgba(124, 92, 255, .12);
}

#vikPanel.vik-terminal .vik-status-card.locked {
  background: rgba(124, 92, 255, .03);
  border-color: #1A1D26;
  color: #5C6370;
  font-family: inherit;
  font-size: 9px;
}

/* OS-SPECIFIC TERMINAL THEMES */
.vik-os-picker {
  display: none;
  gap: 3px;
  margin-top: 4px;
}

.vik-os-picker.os-visible {
  display: flex;
}

.vik-os-btn {
  flex: 1;
  padding: 3px 6px;
  border-radius: 4px;
  border: 1px solid rgba(124, 92, 255, .2);
  background: transparent;
  color: #5C6370;
  font-size: 8px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: all .18s;
}

.vik-os-btn.os-active {
  background: rgba(124, 92, 255, .15);
  border-color: rgba(124, 92, 255, .4);
  color: #7C5CFF;
}

.vik-os-btn:hover {
  border-color: rgba(124, 92, 255, .35);
  color: #9AA3B2;
}

/* Windows Terminal Theme */
#vikPanel.term-win .vik-f4a {
  background: #0C0C0C;
  border: 1px solid #666;
  box-shadow: none;
  font-family: "Fira Code", Consolas, monospace;
}

#vikPanel.term-win .vik-f4a-head {
  background: #1F1F1F;
  border-bottom: 1px solid #555;
  border-radius: 0;
}

#vikPanel.term-win .vik-f4a-title {
  color: #EEEDF0;
  font-family: "Fira Code", Consolas, monospace;
  text-transform: none;
  letter-spacing: 0;
}

#vikPanel.term-win .vik-f4a-online {
  color: #00BFFF;
  text-shadow: none;
}

#vikPanel.term-win .vik-f4a-dot {
  background: #00BFFF;
  box-shadow: none;
  animation: none;
}

#vikPanel.term-win .vik-f4a-msgs {
  color: #CCCCCC;
  font-family: "Fira Code", Consolas, monospace;
}

#vikPanel.term-win .vik-f4a-who {
  color: #4EC9B0;
}

#vikPanel.term-win .vik-f4a-msg.f4a-out .vik-f4a-who {
  color: #DCDCAA;
}

#vikPanel.term-win .vik-f4a-msg.f4a-out .vik-f4a-text {
  color: #EEEDF0;
}

#vikPanel.term-win .vik-f4a-bar {
  background: #0C0C0C;
  border-top: 1px solid #444;
}

#vikPanel.term-win .vik-f4a-bar::before {
  content: "PS>";
  color: #4EC9B0;
  font-family: "Fira Code", Consolas, monospace;
  padding-right: 6px;
  flex-shrink: 0;
  align-self: center;
  font-weight: 700;
  font-size: 11px;
}

#vikPanel.term-win .vik-f4a-input {
  background: #0C0C0C;
  border: none;
  border-bottom: 1px solid #333;
  border-radius: 0;
  color: #CCCCCC;
  font-family: "Fira Code", Consolas, monospace;
}

#vikPanel.term-win .vik-f4a-input:focus {
  box-shadow: none;
  border-color: #4EC9B0;
}

#vikPanel.term-win .vik-f4a-input::placeholder {
  color: #3A3A3A;
}

#vikPanel.term-win .vik-f4a-send {
  background: #1F1F1F;
  border: 1px solid #555;
  color: #4EC9B0;
  font-family: "Fira Code", Consolas, monospace;
}

#vikPanel.term-win .vik-f4a-send:hover {
  background: #2A2A2A;
  box-shadow: none;
}

/* macOS Terminal Theme */
#vikPanel.term-mac .vik-f4a {
  background: #1E1E1E;
  border: 1px solid rgba(255, 255, 255, .15);
  box-shadow: 0 20px 40px rgba(0, 0, 0, .6);
  font-family: "Source Code Pro", Menlo, Monaco, monospace;
}

#vikPanel.term-mac .vik-f4a-head {
  background: #2D2D2D;
  border-bottom: 1px solid #3D3D3D;
  border-radius: 0;
  padding-left: 52px;
  position: relative;
}

#vikPanel.term-mac .vik-f4a-head::before {
  content: "";
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  background: #FF5F57;
  border-radius: 50%;
  box-shadow: 16px 0 0 #FEBC2E, 32px 0 0 #28C840;
}

#vikPanel.term-mac .vik-f4a-title {
  color: #888;
  font-family: "Source Code Pro", Menlo, Monaco, monospace;
  text-transform: none;
  letter-spacing: 0;
  font-size: 11px;
}

#vikPanel.term-mac .vik-f4a-online {
  color: #6CA35E;
  text-shadow: none;
}

#vikPanel.term-mac .vik-f4a-dot {
  background: #6CA35E;
  box-shadow: none;
  animation: none;
}

#vikPanel.term-mac .vik-f4a-msgs {
  color: #F8F8F2;
  font-family: "Source Code Pro", Menlo, Monaco, monospace;
}

#vikPanel.term-mac .vik-f4a-who {
  color: #6CA35E;
}

#vikPanel.term-mac .vik-f4a-msg.f4a-out .vik-f4a-who {
  color: #BD93F9;
}

#vikPanel.term-mac .vik-f4a-msg.f4a-out .vik-f4a-text {
  color: #F8F8F2;
}

#vikPanel.term-mac .vik-f4a-bar {
  background: #1A1A1A;
  border-top: 1px solid #3D3D3D;
}

#vikPanel.term-mac .vik-f4a-bar::before {
  content: "%";
  color: #6CA35E;
  font-family: "Source Code Pro", Menlo, Monaco, monospace;
  font-size: 12px;
  padding-right: 6px;
  flex-shrink: 0;
  align-self: center;
  font-weight: 700;
}

#vikPanel.term-mac .vik-f4a-input {
  background: #1A1A1A;
  border: 1px solid #3D3D3D;
  color: #F8F8F2;
  font-family: "Source Code Pro", Menlo, Monaco, monospace;
}

#vikPanel.term-mac .vik-f4a-input:focus {
  border-color: #6CA35E;
  box-shadow: 0 0 6px rgba(108, 163, 94, .2);
}

#vikPanel.term-mac .vik-f4a-input::placeholder {
  color: #444;
}

#vikPanel.term-mac .vik-f4a-send {
  background: #2D2D2D;
  border: 1px solid #3D3D3D;
  color: #6CA35E;
  font-family: "Source Code Pro", Menlo, Monaco, monospace;
}

#vikPanel.term-mac .vik-f4a-send:hover {
  background: #383838;
  box-shadow: none;
}

/* Ubuntu Terminal Theme */
#vikPanel.term-ubuntu .vik-f4a {
  background: #2C0A1E;
  border: 1px solid rgba(255, 255, 255, .1);
  box-shadow: none;
  font-family: "Ubuntu Mono", "Courier New", monospace;
}

#vikPanel.term-ubuntu .vik-f4a-head {
  background: #3A0D28;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
  border-radius: 0;
}

#vikPanel.term-ubuntu .vik-f4a-title {
  color: #E0A060;
  font-family: "Ubuntu Mono", "Courier New", monospace;
  text-transform: none;
  letter-spacing: 0;
}

#vikPanel.term-ubuntu .vik-f4a-online {
  color: #4EF14E;
  text-shadow: 0 0 8px rgba(78, 241, 78, .5);
}

#vikPanel.term-ubuntu .vik-f4a-dot {
  background: #4EF14E;
  box-shadow: 0 0 6px rgba(78, 241, 78, .7);
}

#vikPanel.term-ubuntu .vik-f4a-msgs {
  color: #E8E8E8;
  font-family: "Ubuntu Mono", "Courier New", monospace;
}

#vikPanel.term-ubuntu .vik-f4a-who {
  color: #4EF14E;
  text-shadow: 0 0 5px rgba(78, 241, 78, .4);
}

#vikPanel.term-ubuntu .vik-f4a-msg.f4a-out .vik-f4a-who {
  color: #82D4FF;
  text-shadow: 0 0 5px rgba(130, 212, 255, .4);
}

#vikPanel.term-ubuntu .vik-f4a-msg.f4a-out .vik-f4a-text {
  color: #EAEAEA;
}

#vikPanel.term-ubuntu .vik-f4a-bar {
  background: rgba(0, 0, 0, .45);
  border-top: 1px solid rgba(78, 241, 78, .12);
}

#vikPanel.term-ubuntu .vik-f4a-bar::before {
  content: "$";
  color: #4EF14E;
  text-shadow: 0 0 5px rgba(78, 241, 78, .6);
  font-family: "Ubuntu Mono", "Courier New", monospace;
  font-size: 12px;
  padding-right: 6px;
  flex-shrink: 0;
  align-self: center;
  font-weight: 700;
}

#vikPanel.term-ubuntu .vik-f4a-input {
  background: rgba(0, 0, 0, .55);
  border: 1px solid rgba(78, 241, 78, .2);
  color: #E8E8E8;
  font-family: "Ubuntu Mono", "Courier New", monospace;
}

#vikPanel.term-ubuntu .vik-f4a-input:focus {
  border-color: rgba(78, 241, 78, .5);
  box-shadow: 0 0 8px rgba(78, 241, 78, .2);
}

#vikPanel.term-ubuntu .vik-f4a-input::placeholder {
  color: rgba(78, 241, 78, .25);
}

#vikPanel.term-ubuntu .vik-f4a-send {
  background: rgba(78, 241, 78, .08);
  border: 1px solid rgba(78, 241, 78, .25);
  color: #4EF14E;
  font-family: "Ubuntu Mono", "Courier New", monospace;
}

#vikPanel.term-ubuntu .vik-f4a-send:hover {
  background: rgba(78, 241, 78, .18);
  box-shadow: 0 0 8px rgba(78, 241, 78, .2);
}

/* V1 Button */
.vikBtn {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 10001;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 2px solid rgba(167, 139, 250, .3);
  cursor: pointer;
  background: linear-gradient(135deg, #0f0f1a, #1a1020);
  box-shadow: 0 4px 20px rgba(0, 0, 0, .6), 0 0 0 1px rgba(255, 255, 255, .05);
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .3s ease;
  filter: drop-shadow(0 0 8px rgba(123, 92, 255, .5)) drop-shadow(0 0 20px rgba(34, 211, 238, .2));
}

.vikBtn:hover {
  box-shadow: 0 8px 32px rgba(123, 97, 255, .4), 0 0 0 2px rgba(167, 139, 250, .3);
}

.vikBtn svg {
  width: 68px;
  height: 68px;
  border-radius: 50%;
  display: block;
}

.vikBtn.vik-locked {
  filter: grayscale(.6) brightness(.7);
  opacity: .7;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .6), 0 0 0 1px rgba(255, 255, 255, .1);
}

.vikBtn.vik-locked svg .emote-bob {
  animation: none;
}

.vikBtn.vik-alive {
  filter: drop-shadow(0 0 8px rgba(123, 92, 255, .5)) drop-shadow(0 0 20px rgba(34, 211, 238, .2));
}

.vikBtn.vik-alive:hover {
  filter: drop-shadow(0 0 12px rgba(123, 92, 255, .7)) drop-shadow(0 0 28px rgba(34, 211, 238, .35));
}

/* Music note pop-out float */
@keyframes noteFloat {
  0% { transform: translateX(0); }
  50% { transform: translateX(12px); }
  100% { transform: translateX(0); }
}

.vik-btn-note.active {
  position: relative;
  z-index: 2;
  border-color: rgba(167, 139, 250, .6) !important;
  background: rgba(123, 92, 255, .15) !important;
  box-shadow: 0 0 14px rgba(123, 92, 255, .3), 0 0 4px rgba(34, 211, 238, .2) !important;
}

.vik-btn-note.active .note-icon {
  display: inline-block;
  animation: noteFloat 2.4s ease-in-out infinite;
  text-shadow: 0 0 8px rgba(167, 139, 250, .7);
}

.vik-btn-note.popped {
  position: fixed !important;
  z-index: 10002 !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  border: 2px solid rgba(167, 139, 250, .5) !important;
  background: linear-gradient(135deg, #1a1030, #0f0f1a) !important;
  box-shadow: 0 4px 20px rgba(123, 92, 255, .4), 0 0 12px rgba(34, 211, 238, .2) !important;
  font-size: 16px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  transition: left 0.4s cubic-bezier(.22,.68,.36,1.1), top 0.4s cubic-bezier(.22,.68,.36,1.1), box-shadow 0.3s ease !important;
}

.vik-btn-note.popped .note-icon {
  animation: noteFloat 2s ease-in-out infinite;
  font-size: 16px;
  text-shadow: 0 0 10px rgba(167, 139, 250, .8);
}

.vik-btn-note.popped:hover {
  box-shadow: 0 6px 28px rgba(123, 92, 255, .5), 0 0 16px rgba(34, 211, 238, .3) !important;
}

/* Skip / Back buttons — flanking the popped note */
.vik-note-skip {
  position: absolute;
  top: 50%;
  transform: translateY(-50%) scale(0);
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1px solid rgba(167, 139, 250, .4);
  background: linear-gradient(135deg, #1a1030, #0f0f1a);
  box-shadow: 0 2px 8px rgba(0, 0, 0, .5), 0 0 6px rgba(123, 92, 255, .2);
  color: rgba(167, 139, 250, .9);
  font-size: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  opacity: 0;
  transition: transform 0.25s cubic-bezier(.22,.68,.36,1.1), opacity 0.2s ease;
  pointer-events: none;
  z-index: 10003;
}
.vik-btn-note.popped:hover .vik-note-skip {
  transform: translateY(-50%) scale(1);
  opacity: 1;
  pointer-events: auto;
}
.vik-note-bk {
  left: -24px;
}
.vik-note-fw {
  right: -24px;
}
.vik-note-skip:hover {
  border-color: rgba(167, 139, 250, .8);
  box-shadow: 0 2px 12px rgba(123, 92, 255, .4), 0 0 8px rgba(34, 211, 238, .2);
  color: #fff;
}
