@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/inter/v20/UcCO3FwrK3iLTeHuS_nVMrMxCp50SjIw2boKoduKmMEVuLyfMZg.ttf) format('truetype');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/inter/v20/UcCO3FwrK3iLTeHuS_nVMrMxCp50SjIw2boKoduKmMEVuI6fMZg.ttf) format('truetype');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/inter/v20/UcCO3FwrK3iLTeHuS_nVMrMxCp50SjIw2boKoduKmMEVuGKYMZg.ttf) format('truetype');
}
:root {
  --accent-color: #0078d7;
  --accent-color-light: #0091ff;
  --accent-color-dark: #005a9e;
  --primary-color: #1a1a1a;
  --secondary-color: #2c2c2c;
  --tertiary-color: #444;
  --text-color-primary: rgba(255, 255, 255, 0.9);
  --text-color-secondary: rgba(255, 255, 255, 0.7);
  --text-color-disabled: rgba(255, 255, 255, 0.4);
  --success-color: #27AE60;
  --warning-color: #F39C12;
  --error-color: #E74C3C;
  --info-color: #3498DB;
  --terminal-color: #2C3E50;
  --browser-color: #16A085;
  --code-editor-color: #8E44AD;
  --file-explorer-color: #2980B9;
  --system-monitor-color: #C0392B;
  --mail-color: #D35400;
  --shop-color: #27AE60;
  --hack-tools-color: #7F8C8D;
  --settings-color: #F39C12;
  --window-border-color: #555;
  --window-header-color: #444;
  --desktop-bg-color: #1a1a1a;
  --dialog-bg-color: rgba(40, 40, 40, 0.85);
  --dialog-border-color: rgba(255, 255, 255, 0.1);
  --taskbar-bg-start: #2c2c2c;
  --taskbar-bg-end: #1a1a1a;
  --taskbar-border-top-color: #3a3a3a;
  --taskbar-shadow: 0 -2px 10px rgba(0, 0, 0, 0.4);
  --taskbar-item-bg: rgba(255, 255, 255, 0.04);
  --taskbar-item-hover-bg: rgba(255, 255, 255, 0.08);
  --taskbar-item-active-bg: rgba(255, 255, 255, 0.15);
  --taskbar-item-active-border: 2px solid var(--accent-color);
  --system-tray-bg: rgba(0, 0, 0, 0.2);
  --start-button-bg-start: var(--accent-color);
  --start-button-bg-end: var(--accent-color-dark);
  --start-button-hover-bg-start: var(--accent-color-light);
  --start-button-hover-bg-end: var(--accent-color);
  --start-button-active-bg-start: var(--accent-color-dark);
  --start-button-active-bg-end: var(--accent-color-dark);
  --system-font: 'Inter', 'Segoe UI', Arial, sans-serif;
  --monospace-font: 'Ubuntu Mono', 'Courier New', monospace;
  --header-font: var(--system-font);
  --animation-speed: 1;
  --border-radius: 4px;
  --button-height: 32px;
  --input-height: 32px;
}
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
body {
  font-family: 'Ubuntu Mono', 'Courier New', monospace;
  overflow: hidden;
  height: 100vh;
  user-select: none;
}
/* Main Taskbar */
#taskbar {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 44px;
  background: linear-gradient(to bottom, var(--taskbar-bg-start), var(--taskbar-bg-end));
  display: flex;
  align-items: center;
  z-index: 1000;
  color: white;
  border-top: 1px solid var(--taskbar-border-top-color);
  box-shadow: var(--taskbar-shadow);
  backdrop-filter: blur(10px);
  font-family: 'Segoe UI', Arial, sans-serif;
}
/* Start Button */
#start-menu-button {
  height: calc(44px - 8px);
  margin-left: 4px;
  padding: 0 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  background: linear-gradient(to bottom, var(--start-button-bg-start), var(--start-button-bg-end));
  border-radius: 4px;
  font-weight: 500;
  letter-spacing: 0.3px;
  transition: all 0.2s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
  border: 1px solid rgba(255, 255, 255, 0.1);
}
#start-menu-button:before {
  content: "🚀";
  margin-right: 8px;
  font-size: 16px;
}
#start-menu-button:hover {
  background: linear-gradient(to bottom, var(--start-button-hover-bg-start), var(--start-button-hover-bg-end));
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.4);
}
#start-menu-button:active {
  background: linear-gradient(to bottom, var(--start-button-active-bg-start), var(--start-button-active-bg-end));
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
  transform: translateY(1px);
}
/* Taskbar Items */
#taskbar-items {
  flex: 1;
  display: flex;
  height: 100%;
  overflow-x: auto;
  padding: 0 8px;
  align-items: center;
  scrollbar-width: none;
  /* Hide scrollbar for Firefox */
}
#taskbar-items::-webkit-scrollbar {
  display: none;
  /* Hide scrollbar for Chrome/Safari/Edge */
}
.taskbar-item {
  height: calc(44px - 12px);
  padding: 0 12px;
  margin: 0 4px;
  display: flex;
  align-items: center;
  background: var(--taskbar-item-bg);
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
  min-width: 140px;
  max-width: 200px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  border: 1px solid rgba(255, 255, 255, 0.05);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}
.taskbar-item:hover {
  background: var(--taskbar-item-hover-bg);
}
.taskbar-item:before {
  content: "▷";
  /* Default icon */
  margin-right: 8px;
  opacity: 0.7;
  font-size: 12px;
}
.taskbar-item[data-app-id="browser"]:before {
  content: "🌐";
}
.taskbar-item[data-app-id="terminal"]:before {
  content: "📟";
}
.taskbar-item[data-app-id="code-editor"]:before {
  content: "📝";
}
.taskbar-item[data-app-id="file-explorer"]:before {
  content: "📁";
}
.taskbar-item-active {
  background: var(--taskbar-item-active-bg);
  border-bottom: var(--taskbar-item-active-border);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}
/* System Tray */
#system-tray {
  display: flex;
  align-items: center;
  padding: 0 12px;
  height: 100%;
  background: var(--system-tray-bg);
  border-left: 1px solid rgba(255, 255, 255, 0.05);
}
#system-tray > div {
  margin-left: 18px;
  font-size: 0.8rem;
  padding: 4px 8px;
  border-radius: 4px;
  background: rgba(0, 0, 0, 0.2);
}
#cpu-indicator,
#ram-indicator {
  display: flex;
  align-items: center;
}
#cpu-indicator:before,
#ram-indicator:before {
  margin-right: 5px;
  font-size: 12px;
}
#cpu-indicator:before {
  content: "💻";
}
#ram-indicator:before {
  content: "🧠";
}
#clock {
  font-weight: 500;
  letter-spacing: 0.5px;
}
/* Animation for active apps */
@keyframes pulse {
  0% {
    opacity: 0.6;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0.6;
  }
}
.taskbar-item.running:not(.taskbar-item-active):before {
  animation: pulse 2s infinite;
}
/* Add a glow effect to the taskbar */
@keyframes subtle-glow {
  0% {
    box-shadow: var(--taskbar-shadow);
  }
  50% {
    box-shadow: 0 -2px 15px rgba(0, 120, 215, 0.3);
  }
  100% {
    box-shadow: var(--taskbar-shadow);
  }
}
#taskbar:hover {
  animation: subtle-glow 3s infinite;
}
.window {
  position: absolute;
  background-color: #222;
  border: 1px solid var(--window-border-color);
  display: flex;
  flex-direction: column;
  min-width: 300px;
  min-height: 200px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);
}
.window-header {
  background-color: var(--window-header-color);
  height: 30px;
  display: flex;
  align-items: center;
  padding: 0 10px;
  cursor: move;
}
.window-title {
  flex: 1;
  color: white;
  font-size: 14px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.window-controls {
  display: flex;
}
.window-control {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  margin-left: 8px;
  cursor: pointer;
}
.window-control.window-minimize {
  background-color: #ffbd2e;
}
.window-control.window-maximize {
  background-color: #28c941;
}
.window-control.window-close {
  background-color: #ff5f57;
}
.window-content {
  flex: 1;
  overflow: auto;
  background-color: var(--dialog-bg-color);
  position: relative;
}
.window-minimized {
  display: none !important;
}
.window-resize-handle {
  position: absolute;
}
.window-resize-handle.window-resize-n {
  cursor: ns-resize;
}
.window-resize-handle.window-resize-e {
  cursor: ew-resize;
}
.window-resize-handle.window-resize-s {
  cursor: ns-resize;
}
.window-resize-handle.window-resize-w {
  cursor: ew-resize;
}
.window-resize-handle.window-resize-ne {
  cursor: nesw-resize;
}
.window-resize-handle.window-resize-se {
  cursor: nwse-resize;
}
.window-resize-handle.window-resize-sw {
  cursor: nesw-resize;
}
.window-resize-handle.window-resize-nw {
  cursor: nwse-resize;
}
#desktop {
  width: 100vw;
  height: 100vh;
  background-color: var(--desktop-bg-color);
  position: relative;
  overflow: hidden;
}
/* Desktop icons */
#desktop-icons {
  padding: 10px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.desktop-icon {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 80px;
  margin-bottom: 15px;
  cursor: pointer;
  color: white;
}
.desktop-icon-image {
  width: 48px;
  height: 48px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 5px;
}
.desktop-icon-name {
  color: white;
  text-align: center;
  font-size: 12px;
  word-wrap: break-word;
}
.terminal-container {
  width: 100%;
  height: 100%;
  padding: 5px;
}
.terminal-container .xterm {
  font-family: monospace;
  font-size: 14px;
  letter-spacing: 0;
  line-height: 1.2;
  --terminal-background: #1e1e1e;
  --terminal-foreground: #f0f0f0;
  --terminal-cursor: #f0f0f0;
  --terminal-selection-bg: rgba(255, 255, 255, 0.3);
  --terminal-black: #1e1e1e;
  --terminal-red: #ff5555;
  --terminal-green: #50fa7b;
  --terminal-yellow: #f1fa8c;
  --terminal-blue: #bd93f9;
  --terminal-magenta: #ff79c6;
  --terminal-cyan: #8be9fd;
  --terminal-white: #f8f8f2;
  --terminal-bright-black: #6272a4;
  --terminal-bright-red: #ff6e6e;
  --terminal-bright-green: #69ff94;
  --terminal-bright-yellow: #ffffa5;
  --terminal-bright-blue: #d6acff;
  --terminal-bright-magenta: #ff92df;
  --terminal-bright-cyan: #a4ffff;
  --terminal-bright-white: #ffffff;
}
.terminal-container .xterm .xterm-viewport {
  overflow-y: auto;
}
/* Editor styling */
.editor-container {
  width: 100%;
  height: 100%;
  /* Dialog styles */
}
.editor-container .code-editor-app {
  display: flex;
  flex-direction: column;
  height: 100%;
  background-color: #1e1e1e;
  color: #d4d4d4;
  font-family: 'Segoe UI', 'Arial', sans-serif;
}
.editor-container .editor-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 5px;
  background-color: #252526;
  border-bottom: 1px solid #3c3c3c;
}
.editor-container .file-actions,
.editor-container .editor-actions {
  display: flex;
  gap: 5px;
}
.editor-container .editor-path {
  flex: 1;
  padding: 0 10px;
  font-size: 12px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.editor-container .toolbar-btn {
  background: none;
  border: none;
  color: #d4d4d4;
  padding: 5px 10px;
  cursor: pointer;
  border-radius: 3px;
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
}
.editor-container .toolbar-btn:hover {
  background-color: #3c3c3c;
}
.editor-container .toolbar-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.editor-container .language-selector {
  background-color: #3c3c3c;
  color: #d4d4d4;
  border: 1px solid #555;
  padding: 3px 5px;
  border-radius: 3px;
  cursor: pointer;
}
.editor-container .editor-main {
  display: flex;
  flex: 1;
  overflow: hidden;
}
.editor-container .editor-sidebar {
  width: 220px;
  background-color: #252526;
  border-right: 1px solid #3c3c3c;
  display: flex;
  flex-direction: column;
}
.editor-container .sidebar-header {
  padding: 10px;
  font-size: 13px;
  font-weight: bold;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #3c3c3c;
}
.editor-container .sidebar-actions {
  display: flex;
  gap: 5px;
}
.editor-container .sidebar-btn {
  background: none;
  border: none;
  color: #d4d4d4;
  cursor: pointer;
  border-radius: 3px;
  padding: 2px 5px;
  font-size: 12px;
}
.editor-container .sidebar-btn:hover {
  background-color: #3c3c3c;
}
.editor-container .file-tree {
  flex: 1;
  overflow: auto;
  padding: 5px;
  font-size: 13px;
}
.editor-container .tree-item {
  padding: 3px 5px 3px 15px;
  cursor: pointer;
  border-radius: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  position: relative;
}
.editor-container .tree-item:hover {
  background-color: #2a2d2e;
}
.editor-container .tree-item.active {
  background-color: #37373d;
}
.editor-container .tree-folder {
  padding-left: 5px;
}
.editor-container .tree-folder-header {
  cursor: pointer;
  padding: 3px 5px;
  border-radius: 3px;
  display: flex;
  align-items: center;
}
.editor-container .tree-folder-header:hover {
  background-color: #2a2d2e;
}
.editor-container .tree-folder-content {
  padding-left: 15px;
  display: none;
}
.editor-container .tree-folder.expanded > .tree-folder-content {
  display: block;
}
.editor-container .tree-folder-toggle {
  margin-right: 5px;
  font-size: 10px;
  width: 10px;
  display: inline-block;
}
.editor-container .editor-content-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.editor-container .monaco-container {
  flex: 1;
  position: relative;
}
.editor-container .editor-loading {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #888;
}
.editor-container .editor-terminal-panel {
  height: 200px;
  border-top: 1px solid #3c3c3c;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.editor-container .terminal-tabs {
  display: flex;
  background-color: #252526;
  border-bottom: 1px solid #3c3c3c;
}
.editor-container .terminal-tab {
  padding: 5px 15px;
  font-size: 12px;
  cursor: pointer;
  border-right: 1px solid #3c3c3c;
}
.editor-container .terminal-tab.active {
  background-color: #1e1e1e;
  border-top: 2px solid #007acc;
  padding-top: 4px;
}
.editor-container .add-terminal-btn {
  background: none;
  border: none;
  color: #d4d4d4;
  cursor: pointer;
  padding: 5px 10px;
  font-size: 12px;
}
.editor-container .code-editor-app .editor-terminal-panel .terminal-container {
  flex: 1;
  padding: 2px;
  display: none;
}
.editor-container .code-editor-app .editor-terminal-panel .terminal-container.active {
  display: block;
}
.editor-container .editor-statusbar {
  display: flex;
  justify-content: space-between;
  padding: 3px 10px;
  background-color: #007acc;
  color: white;
  font-size: 12px;
}
.editor-container .file-status {
  margin-left: 10px;
}
.editor-container .dialog-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
}
.editor-container .dialog {
  background-color: #252526;
  border: 1px solid #3c3c3c;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
  width: 550px;
  border-radius: 4px;
  overflow: hidden;
  color: white;
}
.editor-container .dialog-header {
  background-color: #333;
  padding: 10px 15px;
  font-weight: bold;
  border-bottom: 1px solid #3c3c3c;
}
.editor-container .dialog-content {
  padding: 15px;
  max-height: 500px;
  overflow: auto;
}
.editor-container .dialog-footer {
  padding: 10px 15px;
  text-align: right;
  border-top: 1px solid #3c3c3c;
}
.editor-container .dialog-btn {
  padding: 5px 15px;
  margin-left: 10px;
  background-color: #0e639c;
  color: white;
  border: none;
  border-radius: 3px;
  cursor: pointer;
}
.editor-container .dialog-btn.cancel {
  background-color: #3c3c3c;
}
.editor-container .dialog-btn:hover {
  background-color: #1177bb;
}
.editor-container .dialog-btn.cancel:hover {
  background-color: #515151;
}
.editor-container .file-list {
  max-height: 300px;
  overflow-y: auto;
}
.editor-container .file-item {
  padding: 5px 10px;
  cursor: pointer;
  border-radius: 3px;
  display: flex;
  align-items: center;
}
.editor-container .file-item:hover {
  background-color: #2a2d2e;
}
.editor-container .file-item.selected {
  background-color: #0e639c;
}
.editor-container .file-icon {
  margin-right: 5px;
}
.editor-container .path-bar {
  display: flex;
  margin-bottom: 10px;
}
.editor-container .path-input {
  flex: 1;
  background-color: #3c3c3c;
  border: 1px solid #555;
  color: #d4d4d4;
  padding: 5px 10px;
  border-radius: 3px;
}
.editor-container .path-go-btn {
  background-color: #0e639c;
  color: white;
  border: none;
  padding: 5px 10px;
  border-radius: 3px;
  margin-left: 5px;
  cursor: pointer;
}
.editor-container .unsaved-indicator::after {
  content: '*';
  margin-left: 3px;
}
.text-editor {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.text-editor .editor-container {
  width: 100%;
  height: 100%;
  flex: 1;
}
.text-editor .editor-toolbar {
  display: flex;
  padding: 5px;
  background-color: #f0f0f0;
  border-bottom: 1px solid #ddd;
}
.file-explorer {
  /* Dialog styles */
  /* Properties dialog */
}
.file-explorer .progress-bar {
  width: 100%;
  height: 20px;
  background-color: #3c3c3c;
  border-radius: 3px;
  margin: 10px 0;
  position: relative;
  overflow: hidden;
}
.file-explorer .progress-fill {
  height: 100%;
  background-color: #007acc;
  transition: width 0.3s ease;
  border-radius: 3px;
}
.file-explorer .progress-value {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-weight: bold;
  text-shadow: 0 0 2px rgba(0, 0, 0, 0.5);
}
.file-explorer .file-rename-input {
  background-color: #3c3c3c;
  border: 1px solid #0e639c;
  color: #d4d4d4;
  padding: 2px 5px;
  margin: 0;
  width: calc(100% - 10px);
  box-sizing: border-box;
}
.file-explorer .dialog-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
}
.file-explorer .dialog {
  background-color: #252526;
  border: 1px solid #3c3c3c;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
  width: 400px;
  border-radius: 4px;
  overflow: hidden;
}
.file-explorer .dialog-header {
  background-color: #333;
  padding: 10px 15px;
  font-weight: bold;
  border-bottom: 1px solid #3c3c3c;
  color: #d4d4d4;
}
.file-explorer .dialog-content {
  padding: 15px;
  color: #d4d4d4;
}
.file-explorer .dialog-footer {
  padding: 10px 15px;
  text-align: right;
  border-top: 1px solid #3c3c3c;
}
.file-explorer .dialog-btn {
  padding: 5px 15px;
  margin-left: 10px;
  background-color: #0e639c;
  color: white;
  border: none;
  border-radius: 3px;
  cursor: pointer;
}
.file-explorer .dialog-btn.cancel {
  background-color: #3c3c3c;
}
.file-explorer .dialog-btn:hover {
  background-color: #1177bb;
}
.file-explorer .dialog-btn.cancel:hover {
  background-color: #515151;
}
.file-explorer .dialog-input {
  width: 100%;
  padding: 8px 10px;
  background-color: #3c3c3c;
  border: 1px solid #555;
  border-radius: 3px;
  color: #d4d4d4;
  box-sizing: border-box;
  margin: 10px 0;
  font-family: 'Segoe UI', 'Arial', sans-serif;
  font-size: 14px;
  outline: none;
}
.file-explorer .dialog-input:focus {
  border-color: #0e639c;
  box-shadow: 0 0 0 2px rgba(14, 99, 156, 0.25);
}
.file-explorer .dialog-message {
  margin-bottom: 15px;
  color: #d4d4d4;
  font-size: 14px;
}
.file-explorer .properties-table {
  width: 100%;
  border-collapse: collapse;
}
.file-explorer .properties-table td {
  padding: 5px;
  vertical-align: top;
}
.file-explorer .properties-table td:first-child {
  font-weight: bold;
  width: 100px;
}
.file-explorer .file-explorer-app {
  display: flex;
  flex-direction: column;
  height: 100%;
  width: 100%;
  background-color: #1e1e1e;
  color: #d4d4d4;
  font-family: 'Segoe UI', 'Arial', sans-serif;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
}
.file-explorer .file-explorer-app .file-explorer-toolbar {
  display: flex;
  padding: 5px;
  background-color: #252526;
  border-bottom: 1px solid #3c3c3c;
  /* In your file-explorer.less file */
  /* For hover effects */
}
.file-explorer .file-explorer-app .file-explorer-toolbar .navigation-buttons {
  display: flex;
  margin-right: 5px;
}
.file-explorer .file-explorer-app .file-explorer-toolbar .view-btn svg,
.file-explorer .file-explorer-app .file-explorer-toolbar .navigation-btn svg {
  width: 16px;
  height: 16px;
  stroke-width: 2;
  vertical-align: middle;
}
.file-explorer .file-explorer-app .file-explorer-toolbar .view-btn:hover svg,
.file-explorer .file-explorer-app .file-explorer-toolbar .navigation-btn:hover svg {
  stroke: #ffffff;
}
.file-explorer .file-explorer-app .file-explorer-toolbar .navigation-btn {
  background: none;
  border: none;
  color: #d4d4d4;
  padding: 5px 10px;
  cursor: pointer;
  border-radius: 3px;
  font-size: 14px;
}
.file-explorer .file-explorer-app .file-explorer-toolbar .navigation-btn:hover {
  background-color: #3c3c3c;
}
.file-explorer .file-explorer-app .file-explorer-toolbar .navigation-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.file-explorer .file-explorer-app .file-explorer-toolbar .path-bar {
  flex: 1;
  padding: 0 5px;
}
.file-explorer .file-explorer-app .file-explorer-toolbar .path-bar .path-input {
  width: 100%;
  background-color: #3c3c3c;
  border: 1px solid #555;
  color: #d4d4d4;
  padding: 5px 10px;
  border-radius: 3px;
}
.file-explorer .file-explorer-app .file-explorer-toolbar .view-options {
  display: flex;
  margin-left: 5px;
}
.file-explorer .file-explorer-app .file-explorer-toolbar .view-options .view-btn {
  padding: 5px 8px;
  background-color: #333;
  border: none;
  border-radius: 3px;
  color: #d4d4d4;
  margin-left: 2px;
  cursor: pointer;
}
.file-explorer .file-explorer-app .file-explorer-toolbar .view-options .view-btn:hover {
  background-color: #3c3c3c;
}
.file-explorer .file-explorer-app .file-explorer-toolbar .view-options .view-btn.active {
  background-color: #0e639c;
}
.file-explorer .file-explorer-app .file-explorer-main {
  display: flex;
  flex: 1;
  overflow: hidden;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-sidebar {
  width: 200px;
  background-color: #252526;
  border-right: 1px solid #333;
  padding: 5px;
  overflow-y: auto;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-sidebar .sidebar-section {
  margin-bottom: 10px;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-sidebar .sidebar-header {
  font-weight: bold;
  padding: 5px;
  color: #e0e0e0;
  font-size: 14px;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-sidebar .sidebar-item {
  padding: 5px 5px 5px 15px;
  cursor: pointer;
  border-radius: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-sidebar .sidebar-item:hover {
  background-color: #2a2d2e;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-sidebar .sidebar-item.active {
  background-color: #37373d;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content {
  flex: 1;
  overflow: auto;
  padding: 5px;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-size {
  color: #a0a0a0;
  margin-left: 10px;
  font-size: 0.9em;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-date {
  color: #a0a0a0;
  margin-left: 20px;
  font-size: 0.9em;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list {
  display: flex;
  flex-direction: column;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 10px;
  padding: 10px;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.grid .file-size,
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.grid .file-date {
  display: none;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.grid .file-icon {
  font-size: 32px;
  margin-right: 0;
  margin-bottom: 5px;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.grid .file-name {
  width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.grid .file-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: 100px;
  height: 100px;
  margin: 5px;
  padding: 10px 5px;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.list {
  display: table;
  width: 100%;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.list .file-item {
  display: table-row;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.list .file-item:hover {
  background-color: #2d2d2d;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.list .file-item.selected {
  background-color: #37373d;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.list .file-item div {
  display: table-cell;
  padding: 5px;
  border-bottom: 1px solid #333;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.list .file-header {
  display: table-row;
  font-weight: bold;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-list.list .file-header div {
  display: table-cell;
  padding: 5px;
  border-bottom: 1px solid #444;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-item {
  padding: 5px;
  margin: 2px;
  cursor: pointer;
  border-radius: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-item.grid-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 10px;
  border-radius: 5px;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-item.grid-item .file-icon {
  font-size: 2rem;
  margin-bottom: 5px;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-item.grid-item .file-name {
  text-align: center;
  word-break: break-word;
  font-size: 0.9em;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-item.grid-item:hover {
  background-color: #2a2d2e;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .file-item.grid-item.selected {
  background-color: #094771;
}
.file-explorer .file-explorer-app .file-explorer-main .file-explorer-content .loading-indicator {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  color: #a0a0a0;
}
.file-explorer .file-explorer-app .empty-folder {
  padding: 30px;
  text-align: center;
  color: #a0a0a0;
  font-style: italic;
}
.file-explorer .file-explorer-app .file-explorer-statusbar {
  display: flex;
  justify-content: space-between;
  padding: 5px 10px;
  background-color: #007acc;
  color: white;
  font-size: 12px;
}
.file-explorer .file-explorer-app .selection-count {
  margin-left: 10px;
}
.file-explorer .file-explorer-app .context-menu {
  position: fixed;
  background-color: #252526;
  border: 1px solid #3c3c3c;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
  padding: 5px 0;
  z-index: 1000;
  color: #d4d4d4;
  display: none;
  /* Hide by default, JS will set display: block when needed */
  min-width: 150px;
}
.file-explorer .file-explorer-app .context-menu .context-menu-item {
  padding: 5px 20px;
  cursor: pointer;
  color: #d4d4d4;
}
.file-explorer .file-explorer-app .context-menu .context-menu-item:hover {
  background-color: #2a2d2e;
}
.file-explorer .file-explorer-app .context-menu .context-menu-item:disabled {
  opacity: 0.5;
  cursor: default;
  pointer-events: none;
}
.file-explorer .file-explorer-app .context-menu .context-menu-separator {
  height: 1px;
  background-color: #3c3c3c;
  margin: 5px 0;
}
.file-explorer .file-explorer-app .upload-btn,
.file-explorer .file-explorer-app .download-btn {
  font-size: 1.1em;
}
.file-explorer {
  display: flex;
  height: 100%;
}
.file-explorer .file-sidebar {
  width: 200px;
  background-color: #252525;
  border-right: 1px solid #333;
  overflow: auto;
}
.file-explorer .file-content {
  flex: 1;
  overflow: auto;
  padding: 5px;
}
.file-tree {
  list-style: none;
}
.file-tree-item {
  padding: 4px 8px;
  cursor: pointer;
  color: #ddd;
}
.file-tree-item:hover {
  background-color: #333;
}
.file-tree-folder {
  font-weight: bold;
}
.file-tree-file {
  padding-left: 20px;
}
.browser-container {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.browser-container .browser-app {
  display: flex;
  flex-direction: column;
  height: 100%;
  background-color: #1e1e1e;
  color: #d4d4d4;
  font-family: 'Segoe UI', Arial, sans-serif;
}
.browser-container .browser-app .browser-toolbar {
  display: flex;
  align-items: center;
  padding: 8px;
  background-color: #252526;
  border-bottom: 1px solid #3c3c3c;
}
.browser-container .browser-app .browser-nav-buttons {
  display: flex;
  margin-right: 10px;
}
.browser-container .browser-app .browser-btn {
  background: none;
  border: none;
  color: #d4d4d4;
  padding: 5px 8px;
  cursor: pointer;
  border-radius: 3px;
}
.browser-container .browser-app .browser-btn:hover {
  background-color: #3c3c3c;
}
.browser-container .browser-app .browser-btn:disabled {
  color: #666;
  cursor: not-allowed;
}
.browser-container .browser-app .browser-buttons {
  display: flex;
  margin-right: 10px;
}
.browser-container .browser-app .browser-button {
  width: 24px;
  height: 24px;
  background-color: #444;
  border-radius: 50%;
  margin-right: 5px;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}
.browser-container .browser-app .browser-address-bar {
  display: flex;
  align-items: center;
  flex: 1;
  padding: 0 8px;
  margin: 0 8px;
  background-color: #3c3c3c;
  border-radius: 4px;
  color: white;
}
.browser-container .browser-app .browser-url-prefix {
  color: #7cfc00;
  margin-right: 5px;
}
.browser-container .browser-app .browser-url-prefix.insecure {
  color: #dd3112;
}
.browser-container .browser-app .browser-url-input {
  flex: 1;
  background: none;
  border: none;
  color: #d4d4d4;
  padding: 6px 8px;
  outline: none;
  font-size: 14px;
}
.browser-container .browser-app .browser-actions {
  display: flex;
}
.browser-container .browser-app .browser-content {
  flex: 1;
  background-color: white;
  overflow: auto;
  position: relative;
}
.browser-container .browser-app .browser-bookmarks-bar {
  display: flex;
  padding: 4px 8px;
  background-color: #2d2d2d;
  border-bottom: 1px solid #3c3c3c;
  font-size: 13px;
  overflow-x: auto;
  white-space: nowrap;
}
.browser-container .browser-app .bookmark-item {
  padding: 2px 8px;
  cursor: pointer;
  border-radius: 3px;
  margin-right: 8px;
}
.browser-container .browser-app .bookmark-item:hover {
  background-color: #3c3c3c;
}
.browser-container .browser-app .bookmarks-menu {
  position: absolute;
  top: 50px;
  right: 10px;
  width: 300px;
  background-color: #252526;
  border: 1px solid #3c3c3c;
  border-radius: 5px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
  z-index: 1000;
}
.browser-container .browser-app .bookmarks-header {
  display: flex;
  justify-content: space-between;
  padding: 10px;
  border-bottom: 1px solid #3c3c3c;
}
.browser-container .browser-app .bookmarks-title {
  font-weight: bold;
}
.browser-container .browser-app .bookmarks-close {
  background: none;
  border: none;
  color: #d4d4d4;
  cursor: pointer;
  font-size: 18px;
}
.browser-container .browser-app .bookmarks-list {
  max-height: 300px;
  overflow-y: auto;
}
.browser-container .browser-app .bookmark-entry {
  display: flex;
  padding: 8px 10px;
  border-bottom: 1px solid #3c3c3c;
  align-items: center;
}
.browser-container .browser-app .bookmark-name {
  font-weight: bold;
  margin-right: 10px;
}
.browser-container .browser-app .bookmark-url {
  flex: 1;
  color: #888;
  font-size: 12px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.browser-container .browser-app .bookmark-delete {
  background: none;
  border: none;
  color: #d4d4d4;
  cursor: pointer;
  font-size: 16px;
}
.browser-container .browser-app .bookmarks-add {
  display: flex;
  padding: 10px;
  border-top: 1px solid #3c3c3c;
}
.browser-container .browser-app .bookmark-name-input,
.browser-container .browser-app .bookmark-url-input {
  background-color: #3c3c3c;
  border: none;
  color: #d4d4d4;
  padding: 5px;
  margin-right: 5px;
}
.browser-container .browser-app .bookmark-name-input {
  width: 30%;
}
.browser-container .browser-app .bookmark-url-input {
  flex: 1;
}
.browser-container .browser-app .bookmark-add-btn {
  background-color: #0e639c;
  color: white;
  border: none;
  padding: 5px 10px;
  cursor: pointer;
}
.browser-container .browser-app .loading {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  color: #888;
  font-size: 16px;
}
.browser-container .browser-app .error-page {
  padding: 50px;
  text-align: center;
  color: #333;
}
.browser-container .browser-app .error-page h1 {
  color: #d83131;
}
.calculator-app {
  background-color: #202020;
  border-radius: 8px;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  color: #fff;
}
.calculator-app .calculator-display {
  background-color: #111;
  color: #fff;
  padding: 20px;
  text-align: right;
  font-family: 'Courier New', monospace;
}
.calculator-app .calculator-display .calculator-previous-operand {
  color: rgba(255, 255, 255, 0.7);
  font-size: 16px;
  height: 20px;
  margin-bottom: 5px;
}
.calculator-app .calculator-display .calculator-current-operand {
  font-size: 36px;
  min-height: 40px;
}
.calculator-app .calculator-buttons {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-gap: 1px;
  flex: 1;
}
.calculator-app .calculator-buttons .calculator-button {
  background-color: #333;
  border: none;
  color: white;
  font-size: 20px;
  cursor: pointer;
  transition: background-color 0.1s;
}
.calculator-app .calculator-buttons .calculator-button:hover {
  background-color: #444;
}
.calculator-app .calculator-buttons .calculator-button:active {
  background-color: #555;
}
.calculator-app .calculator-buttons .calculator-button.operator {
  background-color: #f90;
}
.calculator-app .calculator-buttons .calculator-button.operator:hover {
  background-color: #fa0;
}
.calculator-app .calculator-buttons .calculator-button.operator:active {
  background-color: #fb0;
}
.calculator-app .calculator-buttons .calculator-button.equals {
  background-color: #4a90e2;
}
.calculator-app .calculator-buttons .calculator-button.equals:hover {
  background-color: #5a9ff2;
}
.calculator-app .calculator-buttons .calculator-button.equals:active {
  background-color: #6aafff;
}
.calculator-app .calculator-buttons .calculator-button.memory-clear,
.calculator-app .calculator-buttons .calculator-button.memory-recall,
.calculator-app .calculator-buttons .calculator-button.memory-add,
.calculator-app .calculator-buttons .calculator-button.memory-subtract,
.calculator-app .calculator-buttons .calculator-button.clear,
.calculator-app .calculator-buttons .calculator-button.all-clear,
.calculator-app .calculator-buttons .calculator-button.sqr,
.calculator-app .calculator-buttons .calculator-button.sqrt,
.calculator-app .calculator-buttons .calculator-button.percentage,
.calculator-app .calculator-buttons .calculator-button.negate {
  background-color: #555;
}
.calculator-app .calculator-buttons .calculator-button.memory-clear:hover,
.calculator-app .calculator-buttons .calculator-button.memory-recall:hover,
.calculator-app .calculator-buttons .calculator-button.memory-add:hover,
.calculator-app .calculator-buttons .calculator-button.memory-subtract:hover,
.calculator-app .calculator-buttons .calculator-button.clear:hover,
.calculator-app .calculator-buttons .calculator-button.all-clear:hover,
.calculator-app .calculator-buttons .calculator-button.sqr:hover,
.calculator-app .calculator-buttons .calculator-button.sqrt:hover,
.calculator-app .calculator-buttons .calculator-button.percentage:hover,
.calculator-app .calculator-buttons .calculator-button.negate:hover {
  background-color: #666;
}
.calculator-app .calculator-buttons .calculator-button.memory-clear:active,
.calculator-app .calculator-buttons .calculator-button.memory-recall:active,
.calculator-app .calculator-buttons .calculator-button.memory-add:active,
.calculator-app .calculator-buttons .calculator-button.memory-subtract:active,
.calculator-app .calculator-buttons .calculator-button.clear:active,
.calculator-app .calculator-buttons .calculator-button.all-clear:active,
.calculator-app .calculator-buttons .calculator-button.sqr:active,
.calculator-app .calculator-buttons .calculator-button.sqrt:active,
.calculator-app .calculator-buttons .calculator-button.percentage:active,
.calculator-app .calculator-buttons .calculator-button.negate:active {
  background-color: #777;
}
.calculator-key {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1.5rem;
  border: 1px solid #444;
  cursor: pointer;
}
.calculator-key:hover {
  background-color: #444;
}
.calculator-key.operation {
  background-color: #ff9500;
}
.calculator-key.operation:hover {
  background-color: #cc7700;
}
.system-monitor-app {
  display: flex;
  flex-direction: column;
  height: 100%;
  background-color: #1e1e1e;
  color: #d4d4d4;
}
.system-monitor-app .system-monitor-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 15px;
  background-color: #252526;
  border-bottom: 1px solid #333;
}
.system-monitor-app .system-monitor-header h2 {
  margin: 0;
  font-size: 16px;
}
.system-monitor-app .system-monitor-header .header-actions .refresh-btn {
  background-color: #0078d7;
  color: white;
  border: none;
  padding: 5px 10px;
  border-radius: 3px;
  cursor: pointer;
}
.system-monitor-app .system-monitor-header .header-actions .refresh-btn:hover {
  background-color: #0086f0;
}
.system-monitor-app .tabs-container {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow: hidden;
}
.system-monitor-app .tabs-container .tab-buttons {
  display: flex;
  background-color: #252526;
  border-bottom: 1px solid #333;
}
.system-monitor-app .tabs-container .tab-buttons .tab-btn {
  padding: 8px 16px;
  background: transparent;
  border: none;
  color: #d4d4d4;
  cursor: pointer;
}
.system-monitor-app .tabs-container .tab-buttons .tab-btn.active {
  background-color: #1e1e1e;
  border-bottom: 2px solid #0078d7;
}
.system-monitor-app .tabs-container .tab-buttons .tab-btn:hover:not(.active) {
  background-color: #2d2d30;
}
.system-monitor-app .tabs-container .tab-content {
  flex: 1;
  padding: 15px;
  overflow: auto;
  display: none;
}
.system-monitor-app .tabs-container .tab-content.active {
  display: block;
}
.system-monitor-app .resource-overview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 15px;
  margin-bottom: 20px;
}
.system-monitor-app .resource-card {
  background-color: #252526;
  border-radius: 5px;
  padding: 15px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}
.system-monitor-app .resource-card .resource-title {
  font-size: 14px;
  margin-bottom: 10px;
  color: #8f8f8f;
}
.system-monitor-app .resource-card .resource-value {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 10px;
}
.system-monitor-app .resource-card .resource-bar-container {
  height: 5px;
  background-color: #333;
  border-radius: 5px;
  overflow: hidden;
}
.system-monitor-app .resource-card .resource-bar-container .resource-bar {
  height: 100%;
  background-color: #0078d7;
  transition: width 0.3s ease-out;
}
.system-monitor-app .resource-card .resource-bar-container .resource-bar.warning {
  background-color: #f0ad4e;
}
.system-monitor-app .resource-card .resource-bar-container .resource-bar.danger {
  background-color: #d9534f;
}
.system-monitor-app .process-list {
  width: 100%;
  border-collapse: collapse;
}
.system-monitor-app .process-list th,
.system-monitor-app .process-list td {
  padding: 8px 12px;
  text-align: left;
  border-bottom: 1px solid #333;
}
.system-monitor-app .process-list th {
  background-color: #252526;
  position: sticky;
  top: 0;
}
.system-monitor-app .process-list tr:hover {
  background-color: #2d2d30;
  cursor: pointer;
}
.system-monitor-app .process-list .process-row.selected {
  background-color: #37373d;
}
.system-monitor-app .chart-container {
  background-color: #252526;
  border-radius: 5px;
  padding: 15px;
  margin-bottom: 15px;
  height: 300px;
}
.system-monitor-app .disk-info {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 15px;
}
.system-monitor-app .disk-card {
  background-color: #252526;
  border-radius: 5px;
  padding: 15px;
}
.system-monitor-app .disk-card .disk-title {
  font-size: 16px;
  margin-bottom: 10px;
}
.system-monitor-app .disk-card .disk-details {
  margin-bottom: 15px;
}
.system-monitor-app .disk-card .disk-details .disk-usage {
  display: flex;
  justify-content: space-between;
  margin-bottom: 5px;
}
.system-monitor-app .network-info .network-card {
  background-color: #252526;
  border-radius: 5px;
  padding: 15px;
  margin-bottom: 15px;
}
.system-monitor-app .network-info .network-card .network-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 15px;
  margin-top: 15px;
}
/* Settings Application Styles */
.settings-app {
  display: flex;
  flex-direction: column;
  height: 100%;
  background-color: #1e1e1e;
  color: #d4d4d4;
  font-family: 'Segoe UI', 'Arial', sans-serif;
  /* Theme selection */
  /* Color selection */
  /* Background settings */
  /* Font size preview */
  /* Slider controls */
  /* Toggle switch */
  /* Buttons */
  /* Select inputs */
  /* System info section */
  /* Search results */
}
.settings-app .settings-header {
  padding: 15px 20px;
  border-bottom: 1px solid #333;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.settings-app .settings-header h1 {
  margin: 0;
  font-size: 24px;
  font-weight: 400;
}
.settings-app .settings-header .settings-search {
  position: relative;
  width: 300px;
}
.settings-app .settings-header .settings-search .search-icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: #999;
}
.settings-app .settings-header .settings-search .search-input {
  width: 100%;
  background-color: #333;
  border: none;
  border-radius: 4px;
  padding: 8px 35px 8px 35px;
  color: #fff;
  font-size: 14px;
}
.settings-app .settings-header .settings-search .search-input:focus {
  outline: none;
  background-color: #3c3c3c;
}
.settings-app .settings-header .settings-search .search-input::placeholder {
  color: #999;
}
.settings-app .settings-header .settings-search .clear-search {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: #999;
  font-size: 16px;
  cursor: pointer;
}
.settings-app .settings-header .settings-search .clear-search:hover {
  color: #fff;
}
.settings-app .settings-main {
  display: flex;
  flex: 1;
  overflow: hidden;
}
.settings-app .settings-main .settings-sidebar {
  width: 220px;
  background-color: #252526;
  border-right: 1px solid #333;
  overflow-y: auto;
}
.settings-app .settings-main .settings-sidebar .settings-nav {
  padding: 10px 0;
}
.settings-app .settings-main .settings-sidebar .settings-nav .nav-item {
  padding: 12px 20px;
  display: flex;
  align-items: center;
  cursor: pointer;
}
.settings-app .settings-main .settings-sidebar .settings-nav .nav-item:hover {
  background-color: #2a2d2e;
}
.settings-app .settings-main .settings-sidebar .settings-nav .nav-item.active {
  background-color: #37373d;
  border-left: 3px solid #0e639c;
  padding-left: 17px;
}
.settings-app .settings-main .settings-sidebar .settings-nav .nav-item .nav-icon {
  margin-right: 10px;
  font-size: 18px;
}
.settings-app .settings-main .settings-sidebar .settings-nav .nav-item .nav-text {
  font-size: 14px;
}
.settings-app .settings-main .settings-content {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}
.settings-app .settings-main .settings-content .settings-section {
  display: none;
}
.settings-app .settings-main .settings-content .settings-section.active {
  display: block;
}
.settings-app .settings-main .settings-content .settings-section h2 {
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 20px;
  font-weight: 400;
}
.settings-app .settings-main .settings-content .settings-section .section-description {
  color: #a0a0a0;
  margin-bottom: 25px;
}
.settings-app .settings-main .settings-content .settings-section .setting-group {
  margin-bottom: 30px;
}
.settings-app .settings-main .settings-content .settings-section .setting-group h3 {
  font-size: 16px;
  font-weight: 400;
  margin-top: 0;
  margin-bottom: 15px;
}
.settings-app .settings-main .settings-content .settings-section .setting-group .setting-description {
  color: #a0a0a0;
  font-size: 13px;
  margin-top: 5px;
}
.settings-app .theme-selector {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}
.settings-app .theme-selector .theme-option {
  width: 120px;
  text-align: center;
  cursor: pointer;
  border: 2px solid transparent;
  border-radius: 6px;
  overflow: hidden;
}
.settings-app .theme-selector .theme-option:hover {
  border-color: #555;
}
.settings-app .theme-selector .theme-option.selected {
  border-color: #0e639c;
}
.settings-app .theme-selector .theme-option .theme-preview {
  height: 80px;
  margin-bottom: 8px;
}
.settings-app .theme-selector .theme-option .theme-name {
  padding: 5px;
  font-size: 13px;
}
.settings-app .color-selector {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.settings-app .color-selector .color-option {
  display: flex;
  flex-direction: column;
  align-items: center;
  cursor: pointer;
  border: 2px solid transparent;
  border-radius: 6px;
  padding: 8px;
}
.settings-app .color-selector .color-option:hover {
  background-color: #3c3c3c;
}
.settings-app .color-selector .color-option.selected {
  border-color: #0e639c;
}
.settings-app .color-selector .color-option .color-preview {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  margin-bottom: 5px;
}
.settings-app .color-selector .color-option .color-name {
  font-size: 12px;
}
.settings-app .background-settings {
  margin-top: 15px;
}
.settings-app .background-settings #solid-color-settings {
  display: flex;
  align-items: center;
  gap: 10px;
}
.settings-app .background-settings #solid-color-settings .color-picker {
  width: 40px;
  height: 40px;
  background: none;
  cursor: pointer;
  padding: 0;
  border: 1px solid #555;
  border-radius: 4px;
}
.settings-app .background-settings .gradient-colors {
  display: flex;
  gap: 20px;
  margin-bottom: 15px;
}
.settings-app .background-settings .gradient-colors div {
  display: flex;
  align-items: center;
  gap: 10px;
}
.settings-app .background-settings .gradient-colors .color-picker {
  width: 40px;
  height: 40px;
  background: none;
  cursor: pointer;
  padding: 0;
  border: 1px solid #555;
  border-radius: 4px;
}
.settings-app .background-settings #image-settings .image-preview {
  width: 250px;
  height: 150px;
  background-color: #2d2d2d;
  border-radius: 4px;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.settings-app .background-settings #image-settings .image-preview img {
  max-width: 100%;
  max-height: 100%;
}
.settings-app .background-settings #image-settings .image-preview .no-image {
  color: #888;
}
.settings-app .background-settings #image-settings .image-fit-options {
  margin-top: 15px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.settings-app .font-preview {
  margin-top: 15px;
  padding: 15px;
  background-color: #2d2d2d;
  border-radius: 4px;
  font-size: 14px;
}
.settings-app .slider-control {
  display: flex;
  align-items: center;
  gap: 15px;
}
.settings-app .slider-control input[type="range"] {
  flex: 1;
  -webkit-appearance: none;
  height: 6px;
  background: #444;
  border-radius: 3px;
}
.settings-app .slider-control input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  background: #0e639c;
  border-radius: 50%;
  cursor: pointer;
}
.settings-app .slider-control .slider-value {
  min-width: 50px;
  text-align: center;
}
.settings-app .toggle-control {
  display: flex;
  align-items: center;
}
.settings-app .toggle-control .toggle {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 26px;
}
.settings-app .toggle-control .toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}
.settings-app .toggle-control .toggle input:checked + .toggle-slider {
  background-color: #0e639c;
}
.settings-app .toggle-control .toggle input:checked + .toggle-slider:before {
  transform: translateX(24px);
}
.settings-app .toggle-control .toggle .toggle-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #555;
  transition: 0.4s;
  border-radius: 34px;
}
.settings-app .toggle-control .toggle .toggle-slider:before {
  position: absolute;
  content: "";
  height: 18px;
  width: 18px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  transition: 0.4s;
  border-radius: 50%;
}
.settings-app .toggle-control .toggle-label {
  margin-left: 15px;
}
.settings-app .settings-button {
  background-color: #0e639c;
  color: white;
  border: none;
  padding: 8px 15px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 14px;
}
.settings-app .settings-button:hover {
  background-color: #1177bb;
}
.settings-app .settings-select {
  background-color: #3c3c3c;
  color: #d4d4d4;
  border: 1px solid #555;
  padding: 8px 10px;
  border-radius: 4px;
  font-size: 14px;
  min-width: 200px;
}
.settings-app .settings-select:focus {
  outline: none;
  border-color: #0e639c;
}
.settings-app .system-info {
  background-color: #2d2d2d;
  border-radius: 6px;
  padding: 20px;
}
.settings-app .system-info .info-item {
  display: flex;
  margin-bottom: 15px;
}
.settings-app .system-info .info-item:last-child {
  margin-bottom: 0;
}
.settings-app .system-info .info-item .info-label {
  width: 120px;
  color: #a0a0a0;
}
.settings-app .system-info .info-item .info-value {
  font-weight: 500;
}
.settings-app #search-results-section .search-result {
  background-color: #2d2d2d;
  border-radius: 6px;
  padding: 15px;
  margin-bottom: 15px;
  cursor: pointer;
  transition: background-color 0.2s;
}
.settings-app #search-results-section .search-result:hover {
  background-color: #37373d;
}
.settings-app #search-results-section .search-result .result-title {
  font-weight: 500;
  margin-bottom: 5px;
}
.settings-app #search-results-section .search-result .result-description {
  color: #a0a0a0;
  font-size: 13px;
  margin-bottom: 10px;
}
.settings-app #search-results-section .search-result .result-section {
  font-size: 12px;
  color: #0e639c;
}
.settings-app #search-results-section .no-results {
  text-align: center;
  padding: 40px;
  color: #888;
}
/* App Tile Color Customization Styles */
.app-tile-colors.disabled {
  opacity: 0.5;
  pointer-events: none;
}
.app-tile-colors .app-tile-color-list {
  margin-top: 15px;
}
.app-tile-colors .app-tile-color-list .loading-message {
  color: #999;
  font-style: italic;
}
.app-tile-colors .app-tile-color-list .no-apps-message {
  color: #999;
  font-style: italic;
  margin: 10px 0;
}
.app-tile-colors .app-tile-color-list .app-color-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.app-tile-colors .app-tile-color-list .app-color-row:last-child {
  border-bottom: none;
}
.app-tile-colors .app-tile-color-list .app-color-row .app-info {
  display: flex;
  align-items: center;
}
.app-tile-colors .app-tile-color-list .app-color-row .app-info i {
  margin-right: 10px;
  font-size: 20px;
}
.app-tile-colors .app-tile-color-list .app-color-row .app-info .app-name {
  font-size: 14px;
}
.app-tile-colors .app-tile-color-list .app-color-row .color-selector {
  display: flex;
  gap: 8px;
}
.app-tile-colors .app-tile-color-list .app-color-row .color-selector .color-option {
  width: 20px;
  height: 20px;
  border-radius: 4px;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
}
.app-tile-colors .app-tile-color-list .app-color-row .color-selector .color-option:hover {
  transform: scale(1.1);
}
.app-tile-colors .app-tile-color-list .app-color-row .color-selector .color-option.selected {
  box-shadow: 0 0 0 2px white;
}
/* Error Log Viewer App Styles */
.error-log-viewer-app {
  display: flex;
  flex-direction: column;
  height: 100%;
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  color: #f0f0f0;
  background-color: #252526;
}
.error-log-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 15px;
  border-bottom: 1px solid #3f3f46;
}
.error-log-header h1 {
  margin: 0;
  font-size: 18px;
  font-weight: 500;
}
.error-log-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}
.search-container {
  position: relative;
}
.search-input {
  padding: 6px 10px;
  padding-right: 30px;
  border: 1px solid #3f3f46;
  border-radius: 4px;
  background-color: #333333;
  color: #f0f0f0;
  width: 200px;
}
.clear-search {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: #999;
  cursor: pointer;
  font-size: 16px;
  padding: 0;
}
.refresh-btn,
.clear-log-btn {
  background-color: #2d2d30;
  border: 1px solid #3f3f46;
  border-radius: 4px;
  color: #f0f0f0;
  padding: 6px 10px;
  cursor: pointer;
  font-size: 14px;
}
.refresh-btn:hover,
.clear-log-btn:hover {
  background-color: #3e3e42;
}
.error-log-tabs {
  display: flex;
  padding: 0 15px;
  border-bottom: 1px solid #3f3f46;
}
.tab {
  padding: 10px 15px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  font-size: 14px;
}
.tab:hover {
  background-color: #2d2d30;
}
.tab.active {
  border-bottom-color: #007acc;
  font-weight: 500;
}
.error-log-container {
  display: flex;
  flex: 1;
  overflow: hidden;
}
/* New sidebar styles */
.error-log-sidebar {
  width: 220px;
  border-right: 1px solid #3f3f46;
  overflow-y: auto;
  background-color: #252526;
}
.log-calendar {
  padding: 10px;
}
.log-calendar h3 {
  margin: 0 0 10px 0;
  font-size: 14px;
  color: #ccc;
  font-weight: normal;
}
.calendar-container {
  font-size: 12px;
}
.calendar-month {
  margin-bottom: 15px;
}
.calendar-month-header {
  font-weight: 500;
  margin-bottom: 5px;
  color: #ccc;
}
.calendar-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}
.calendar-day {
  padding: 3px;
  text-align: center;
  cursor: pointer;
  border-radius: 2px;
}
.calendar-day:hover {
  background-color: #3e3e42;
}
.calendar-day.has-logs {
  color: #007acc;
  font-weight: 500;
}
.calendar-day.active {
  background-color: #007acc;
  color: white;
}
.calendar-day.empty {
  visibility: hidden;
}
.hour-list {
  margin-top: 10px;
  border-top: 1px solid #3f3f46;
  padding-top: 5px;
}
.hour-item {
  padding: 5px 10px;
  font-size: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  border-radius: 2px;
}
.hour-item:hover {
  background-color: #3e3e42;
}
.hour-item.active {
  background-color: #007acc;
  color: white;
}
.hour-item .hour-label {
  flex: 1;
}
.hour-item .error-count {
  font-size: 10px;
  background-color: #3e3e42;
  border-radius: 10px;
  padding: 2px 6px;
}
.hour-item.active .error-count {
  background-color: #0e639c;
}
/* Content area styles */
.error-log-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.error-log-list-container {
  flex: 1;
  overflow: auto;
  border-bottom: 1px solid #3f3f46;
}
.error-details-container {
  height: 300px;
  overflow: auto;
  padding: 15px;
  background-color: #1e1e1e;
}
.error-log-list {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.error-log-list th {
  position: sticky;
  top: 0;
  background-color: #2d2d30;
  padding: 8px 10px;
  text-align: left;
  font-weight: 500;
  border-bottom: 1px solid #3f3f46;
}
.error-log-list th.sortable {
  cursor: pointer;
}
.error-log-list th.sortable:hover {
  background-color: #3e3e42;
}
.error-log-list td {
  padding: 8px 10px;
  border-bottom: 1px solid #1e1e1e;
}
.error-row {
  cursor: pointer;
}
.error-row:hover {
  background-color: #2d2d30;
}
.error-row.selected {
  background-color: #04395e;
}
.level-cell,
.status-cell {
  white-space: nowrap;
}
.level-indicator {
  margin-right: 5px;
}
.loading-row td,
.empty-row td {
  text-align: center;
  padding: 20px;
  color: #999;
}
/* Error level colors */
.level-info .level-cell {
  color: #75beff;
}
.level-warning .level-cell {
  color: #ffcc00;
}
.level-error .level-cell {
  color: #f14c4c;
}
.level-critical .level-cell {
  color: #ff6347;
}
/* Status colors */
.status-cell {
  font-weight: 500;
}
.status-unhandled .status-cell {
  color: #f14c4c;
}
.status-handled .status-cell {
  color: #6cc644;
}
/* Error details styles */
.no-error-selected {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: #999;
  font-size: 14px;
}
.error-details h3 {
  margin-top: 0;
  font-size: 16px;
  font-weight: 500;
  border-bottom: 1px solid #3f3f46;
  padding-bottom: 10px;
}
.error-meta {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-bottom: 20px;
}
.meta-item {
  display: flex;
  flex-direction: column;
  background-color: #2d2d30;
  padding: 10px;
  border-radius: 4px;
}
.meta-label {
  font-size: 12px;
  color: #999;
  margin-bottom: 5px;
}
.meta-value {
  font-weight: 500;
}
.level-value {
  font-weight: 600;
}
.level-info {
  color: #75beff;
}
.level-warning {
  color: #ffcc00;
}
.level-error {
  color: #f14c4c;
}
.level-critical {
  color: #ff6347;
}
.status-handled {
  color: #6cc644;
}
.status-unhandled {
  color: #f14c4c;
}
.error-message-container,
.error-stack-container {
  margin-bottom: 20px;
}
.error-message-container h4,
.error-stack-container h4 {
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 8px;
  color: #ccc;
}
.error-message {
  background-color: #2d2d30;
  padding: 12px;
  border-radius: 4px;
  overflow-wrap: break-word;
}
.error-stack {
  background-color: #1e1e1e;
  padding: 12px;
  border-radius: 4px;
  overflow: auto;
  font-family: 'Consolas', 'Courier New', monospace;
  font-size: 12px;
  max-height: 200px;
  color: #dcdcdc;
  white-space: pre-wrap;
}
.error-actions {
  display: flex;
  justify-content: flex-end;
}
.mark-handled-btn {
  background-color: #0e639c;
  border: none;
  border-radius: 4px;
  color: white;
  padding: 8px 16px;
  cursor: pointer;
  font-size: 13px;
}
.mark-handled-btn:hover {
  background-color: #1177bb;
}
.mark-handled-btn[disabled] {
  background-color: #2d2d30;
  color: #999;
  cursor: not-allowed;
}
/* Status bar */
.error-log-status-bar {
  padding: 6px 15px;
  background-color: #007acc;
  color: white;
  font-size: 12px;
  border-top: 1px solid #0e639c;
}
.theme-editor .theme-editor-container {
  display: flex;
  height: 100%;
  overflow: hidden;
}
.theme-editor .settings-panel {
  flex: 1;
  padding: 15px;
  overflow-y: auto;
  background-color: var(--secondary-color);
  border-right: 1px solid rgba(255, 255, 255, 0.1);
}
.theme-editor .settings-panel::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
.theme-editor .settings-panel::-webkit-scrollbar-track {
  background: #1a1a1a;
}
.theme-editor .settings-panel::-webkit-scrollbar-thumb {
  background-color: #444;
  border-radius: 4px;
}
.theme-editor .settings-panel::-webkit-scrollbar-thumb:hover {
  background-color: #0078d7;
}
.theme-editor .preview-panel {
  flex: 1;
  padding: 15px;
  overflow-y: auto;
  background-color: var(--primary-color);
}
.theme-editor .preview-panel::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
.theme-editor .preview-panel::-webkit-scrollbar-track {
  background: #1a1a1a;
}
.theme-editor .preview-panel::-webkit-scrollbar-thumb {
  background-color: #444;
  border-radius: 4px;
}
.theme-editor .preview-panel::-webkit-scrollbar-thumb:hover {
  background-color: #0078d7;
}
.theme-editor .section {
  margin-bottom: 20px;
  padding-bottom: 15px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.theme-editor .section:last-child {
  border-bottom: none;
}
.theme-editor .section h2 {
  margin-top: 0;
  margin-bottom: 15px;
  font-size: 18px;
  color: var(--text-color-primary);
}
.theme-editor .form-group {
  margin-bottom: 12px;
}
.theme-editor .form-group label {
  display: block;
  margin-bottom: 5px;
  color: var(--text-color-secondary);
  font-size: 14px;
}
.theme-editor .form-group input[type="text"],
.theme-editor .form-group textarea,
.theme-editor .form-group select {
  background-color: #444;
  color: var(--text-color-primary);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--border-radius);
  height: var(--input-height);
  width: 100%;
  padding: 8px;
  box-sizing: border-box;
}
.theme-editor .form-group input[type="text"]:focus,
.theme-editor .form-group textarea:focus,
.theme-editor .form-group select:focus {
  border-color: #0078d7;
}
.theme-editor .form-group input[type="text"]:disabled,
.theme-editor .form-group textarea:disabled,
.theme-editor .form-group select:disabled {
  background-color: rgba(0, 0, 0, 0.1);
  color: var(--text-color-disabled);
}
.theme-editor .form-group textarea {
  resize: vertical;
  min-height: 80px;
}
.theme-editor .color-picker-group {
  display: flex;
  align-items: center;
}
.theme-editor .color-picker-group label {
  flex: 1;
  margin-bottom: 0;
}
.theme-editor .color-picker-group input[type="color"] {
  width: 40px;
  height: 30px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: transparent;
  padding: 0;
}
.theme-editor .color-picker-group input[type="color"]::-webkit-color-swatch-wrapper {
  padding: 0;
}
.theme-editor .color-picker-group input[type="color"]::-webkit-color-swatch {
  border: none;
}
.theme-editor .theme-select-container {
  margin-bottom: 15px;
}
.theme-editor .theme-select-container select {
  background-color: #444;
  color: var(--text-color-primary);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--border-radius);
  height: var(--input-height);
  width: 100%;
  padding: 8px;
}
.theme-editor .theme-select-container select:focus {
  border-color: #0078d7;
}
.theme-editor .theme-select-container select:disabled {
  background-color: rgba(0, 0, 0, 0.1);
  color: var(--text-color-disabled);
}
.theme-editor .actions-section {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.theme-editor .actions-section button {
  background: linear-gradient(to bottom, #0078d7, #005a9e);
  color: white;
  border: 1px solid #005a9e;
  border-radius: var(--border-radius);
  height: var(--button-height);
  transition: all 0.2s ease;
  padding: 0 15px;
  white-space: nowrap;
}
.theme-editor .actions-section button:hover {
  background: linear-gradient(to bottom, #0091ff, #0078d7);
}
.theme-editor .actions-section button:active {
  background: #005a9e;
}
.theme-editor .actions-section button:disabled {
  background: #444;
  color: var(--text-color-disabled);
  border-color: #444;
}
.theme-editor .actions-section button.primary-button {
  background: linear-gradient(to bottom, #0078d7, #005a9e);
  font-weight: bold;
}
.theme-editor .preview-container {
  margin-bottom: 20px;
}
.theme-editor .preview-container .preview-window {
  border-radius: var(--border-radius);
  overflow: hidden;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
  margin-bottom: 20px;
}
.theme-editor .preview-container .preview-window .preview-window-header {
  padding: 10px;
  font-weight: bold;
}
.theme-editor .preview-container .preview-window .preview-window-content {
  padding: 15px;
}
.theme-editor .preview-container .preview-section {
  margin-bottom: 15px;
}
.theme-editor .preview-container .preview-section h3 {
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 16px;
}
.theme-editor .preview-container .preview-section .preview-button {
  display: inline-block;
  padding: 6px 12px;
  margin-right: 10px;
  margin-bottom: 10px;
  border-radius: var(--border-radius);
  border: none;
  cursor: pointer;
  font-size: 14px;
}
.theme-editor .preview-container .preview-section .preview-button.secondary {
  background-color: #444;
  color: var(--text-color-primary);
}
.theme-editor .preview-container .preview-section .preview-input-group {
  margin-bottom: 10px;
}
.theme-editor .preview-container .preview-section .preview-input-group input {
  padding: 6px 12px;
  width: 100%;
  border-radius: var(--border-radius);
  font-size: 14px;
  box-sizing: border-box;
}
.theme-editor .preview-container .preview-section .preview-status {
  margin-bottom: 8px;
  font-size: 14px;
  display: flex;
  align-items: center;
}
.theme-editor .preview-container .preview-section .preview-status::before {
  content: '';
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-right: 8px;
  background-color: currentColor;
}
.theme-editor .preview-container .preview-taskbar {
  height: 40px;
  display: flex;
  align-items: center;
  padding: 0 10px;
  border-radius: var(--border-radius);
}
.theme-editor .preview-container .preview-taskbar .preview-start-button {
  height: 32px;
  padding: 0 12px;
  margin-right: 10px;
  border: none;
  border-radius: var(--border-radius);
  font-weight: bold;
  cursor: pointer;
}
.theme-editor .preview-container .preview-taskbar .preview-taskbar-item {
  height: 32px;
  display: flex;
  align-items: center;
  padding: 0 12px;
  margin-right: 5px;
  border-radius: var(--border-radius);
  color: var(--text-color-primary);
}
.theme-editor .preview-container .preview-taskbar .preview-taskbar-item.active {
  border-bottom-width: 2px;
  border-bottom-style: solid;
}
.theme-editor .notification {
  position: fixed;
  bottom: 20px;
  right: 20px;
  padding: 12px 20px;
  border-radius: var(--border-radius);
  color: white;
  font-weight: bold;
  animation: fadeIn 0.3s ease-out;
  z-index: 1000;
}
.theme-editor .notification.success {
  background-color: #27AE60;
}
.theme-editor .notification.error {
  background-color: #E74C3C;
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.hack-paint-toolbar {
  display: flex;
  gap: 5px;
  padding: 5px;
  background: #333;
}
.hack-paint-toolbar button {
  background: #555;
  color: #fff;
  border: none;
  padding: 4px 8px;
  cursor: pointer;
}
.hack-paint-toolbar input[type="color"],
.hack-paint-toolbar input[type="range"] {
  margin-left: 5px;
}
.hack-paint-canvas-container {
  width: 100%;
  height: 100%;
  overflow: auto;
  background: #222;
  position: relative;
}
.hack-paint-canvas-container.grid {
  background-image: linear-gradient(0deg, transparent 24%, rgba(255, 255, 255, 0.1) 25%, rgba(255, 255, 255, 0.1) 26%, transparent 27%, transparent 74%, rgba(255, 255, 255, 0.1) 75%, rgba(255, 255, 255, 0.1) 76%, transparent 77%), linear-gradient(90deg, transparent 24%, rgba(255, 255, 255, 0.1) 25%, rgba(255, 255, 255, 0.1) 26%, transparent 27%, transparent 74%, rgba(255, 255, 255, 0.1) 75%, rgba(255, 255, 255, 0.1) 76%, transparent 77%);
  background-size: 20px 20px;
}
.selection-rect {
  position: absolute;
  border: 1px dashed #fff;
  pointer-events: none;
}
.hack-paint-canvas {
  background: #fff;
  display: block;
  margin: 0 auto;
}
.start-menu-context-menu {
  position: fixed;
  background-color: rgba(40, 40, 40, 0.95);
  backdrop-filter: blur(10px);
  border-radius: 6px;
  padding: 5px 0;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
  min-width: 180px;
  z-index: 3000;
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: white;
}
.start-menu-context-menu .context-menu-option {
  display: flex;
  align-items: center;
  padding: 10px 15px;
  cursor: pointer;
}
.start-menu-context-menu .context-menu-option:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
.start-menu-context-menu .context-menu-option svg {
  width: 16px;
  height: 16px;
  margin-right: 10px;
  stroke: currentColor;
}
.start-menu {
  position: fixed;
  bottom: 44px;
  left: 0;
  width: 510px;
  height: 600px;
  background-color: var(--start-menu-bg-color, rgba(40, 40, 40, 0.85));
  backdrop-filter: var(--start-menu-backdrop-filter, blur(10px));
  display: flex;
  border-radius: var(--start-menu-border-radius, 8px 8px 0 0);
  border: var(--start-menu-border, none);
  box-shadow: var(--start-menu-shadow, 0 -5px 25px rgba(0, 0, 0, 0.5));
  z-index: 2000;
  transform: translateY(100%);
  opacity: 0;
  transition: transform 0.3s ease, opacity 0.3s ease;
  font-family: var(--system-font, 'Inter', 'Segoe UI', Arial, sans-serif);
  overflow: hidden;
  color: var(--start-menu-text-color, white);
  border: var(--start-menu-border, 1px solid rgba(255, 255, 255, 0.1));
  border-bottom: var(--start-menu-border-bottom, none);
  visibility: hidden;
  /* Context Menu Styles */
}
.start-menu.visible {
  transform: translateY(0);
  opacity: 1;
  visibility: visible;
}
body[data-theme-id="windows-98"] .start-menu {
  background-color: #d4d0c8 !important;
  border-radius: 0 !important;
  backdrop-filter: none !important;
  color: black !important;
  border: 2px solid !important;
  border-color: #ffffff #404040 #404040 #ffffff !important;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
}
.start-menu .start-menu-sidebar {
  width: 50px;
  height: 100%;
  background-color: rgba(30, 30, 30, 0.6);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 15px 0;
  border-right: 1px solid rgba(255, 255, 255, 0.1);
  transition: width 0.3s ease;
}
.start-menu .start-menu-sidebar.expanded {
  width: 200px;
  align-items: flex-start;
}
body[data-theme-id="windows-98"] .start-menu .start-menu-sidebar {
  width: 35px !important;
  background-color: #000080 !important;
  border-right: 1px solid #404040 !important;
  padding: 0 !important;
}
body[data-theme-id="windows-98"] .start-menu .start-menu-sidebar:before {
  content: "Windows 98";
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  color: white;
  font-weight: bold;
  font-size: 20px;
  margin-bottom: 20px;
  margin-top: auto;
  letter-spacing: 1px;
  font-family: 'MS Sans Serif', Arial, sans-serif;
}
body[data-theme-id="windows-98"] .start-menu .start-menu-sidebar.expanded {
  width: 160px !important;
}
.start-menu .sidebar-item {
  width: 36px;
  height: 36px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 6px;
  margin-bottom: 12px;
  cursor: pointer;
  transition: background-color 0.2s ease, width 0.3s ease;
  color: #e0e0e0;
  margin-left: 7px;
  position: relative;
}
body[data-theme-id="windows-98"] .start-menu .sidebar-item {
  border-radius: 0 !important;
  margin-left: 0 !important;
  width: 100% !important;
  height: 30px !important;
  justify-content: flex-start !important;
  color: black !important;
  margin-bottom: 0 !important;
  padding-left: 28px !important;
}
body[data-theme-id="windows-98"] .start-menu .sidebar-item:hover {
  background-color: #000080 !important;
  color: white !important;
}
body[data-theme-id="windows-98"] .start-menu .sidebar-item img,
body[data-theme-id="windows-98"] .start-menu .sidebar-item svg {
  width: 16px !important;
  height: 16px !important;
  margin-right: 8px !important;
}
.start-menu .sidebar-item .sidebar-item-label {
  position: absolute;
  left: 45px;
  white-space: nowrap;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  font-size: 14px;
}
body[data-theme-id="windows-98"] .start-menu .sidebar-item .sidebar-item-label {
  position: static !important;
  opacity: 1 !important;
  transform: none !important;
  font-family: 'MS Sans Serif', Arial, sans-serif !important;
  font-size: 11px !important;
  margin-left: 4px !important;
}
.start-menu .sidebar-item:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
.start-menu .sidebar-item.active {
  background-color: rgba(0, 120, 215, 0.3);
}
.start-menu .sidebar-item svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
}
.start-menu .start-menu-sidebar.expanded .sidebar-item {
  width: 180px;
  justify-content: flex-start;
  padding-left: 10px;
}
.start-menu .start-menu-sidebar.expanded .sidebar-item .sidebar-item-label {
  opacity: 1;
  position: static;
  margin-left: 15px;
}
.start-menu .power-item {
  margin-top: auto;
  margin-bottom: 0;
  color: #e05050;
}
.start-menu .start-menu-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.start-menu .search-bar {
  width: 100%;
  padding: 15px;
}
.start-menu .search-bar input {
  width: 100%;
  background-color: rgba(255, 255, 255, 0.1);
  border: none;
  border-radius: 6px;
  padding: 10px 15px;
  color: white;
  font-size: 14px;
}
.start-menu .search-bar input::placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.start-menu .search-bar input:focus {
  outline: none;
  background-color: rgba(255, 255, 255, 0.15);
}
.start-menu .content-view {
  flex: 1;
  overflow-y: auto;
  padding: 0 15px 15px;
  display: none;
}
.start-menu .content-view.active {
  display: block;
}
.start-menu .pinned-apps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.start-menu .app-tile {
  aspect-ratio: 1/1;
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  transition: transform 0.2s ease;
  padding: 12px;
}
.start-menu .app-tile:hover {
  transform: scale(1.05);
}
.start-menu .app-tile svg {
  width: 32px;
  height: 32px;
  margin-bottom: 8px;
  stroke: white;
}
.start-menu .app-tile-name {
  font-size: 12px;
  text-align: center;
  margin-top: 5px;
  color: rgba(255, 255, 255, 0.9);
}
.start-menu .all-apps-content {
  padding: 20px;
  color: rgba(255, 255, 255, 0.9);
}
.start-menu .all-apps-content .app-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.start-menu .all-apps-content .app-list .app-list-item {
  display: flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 6px;
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.start-menu .all-apps-content .app-list .app-list-item:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
.start-menu .all-apps-content .app-list .app-list-item .app-icon {
  width: 36px;
  height: 36px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-right: 12px;
  font-size: 20px;
}
.start-menu .all-apps-content .app-list .app-list-item .app-icon i {
  width: 24px;
  height: 24px;
  stroke: currentColor;
}
.start-menu .all-apps-content .app-list .app-list-item .app-name {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.9);
}
.start-menu .submenu {
  position: absolute;
  background-color: rgba(40, 40, 40, 0.9);
  backdrop-filter: blur(10px);
  border-radius: 6px;
  padding: 5px 0;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
  min-width: 180px;
  transform: scale(0.95);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.15s ease, opacity 0.15s ease;
  z-index: 3000;
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: white;
  visibility: hidden;
}
.start-menu .submenu.visible {
  transform: scale(1);
  opacity: 1;
  pointer-events: all;
  visibility: visible;
}
.start-menu:not(.visible) .submenu {
  opacity: 0 !important;
  pointer-events: none !important;
  visibility: hidden !important;
}
.start-menu .submenu-item {
  display: flex;
  align-items: center;
  padding: 10px 15px;
  cursor: pointer;
}
.start-menu .submenu-item:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
.start-menu .submenu-item svg {
  width: 16px;
  height: 16px;
  margin-right: 10px;
  stroke: currentColor;
}
.start-menu .user-submenu {
  left: 58px;
  top: 60px;
}
.start-menu .power-submenu {
  left: 58px;
  bottom: 60px;
}
.start-menu .start-menu-sidebar.expanded ~ .user-submenu,
.start-menu .start-menu-sidebar.expanded ~ .power-submenu {
  left: 208px;
}
.start-menu .app-tile-A {
  background-color: var(--terminal-color, #2C3E50);
}
.start-menu .app-tile-B {
  background-color: var(--browser-color, #16A085);
}
.start-menu .app-tile-C {
  background-color: var(--code-editor-color, #8E44AD);
}
.start-menu .app-tile-D {
  background-color: var(--file-explorer-color, #2980B9);
}
.start-menu .app-tile-E {
  background-color: var(--system-monitor-color, #C0392B);
}
.start-menu .app-tile-F {
  background-color: var(--mail-color, #D35400);
}
.start-menu .app-tile-G {
  background-color: var(--shop-color, #27AE60);
}
.start-menu .app-tile-H {
  background-color: var(--hack-tools-color, #7F8C8D);
}
.start-menu .app-tile-I {
  background-color: var(--settings-color, #F39C12);
}
.start-menu .app-tile-terminal {
  background-color: var(--terminal-color, #2C3E50);
}
.start-menu .app-tile-browser {
  background-color: var(--browser-color, #16A085);
}
.start-menu .app-tile-code {
  background-color: var(--code-editor-color, #8E44AD);
}
.start-menu .app-tile-files {
  background-color: var(--file-explorer-color, #2980B9);
}
.start-menu .app-tile-monitor {
  background-color: var(--system-monitor-color, #C0392B);
}
.start-menu .app-tile-mail {
  background-color: var(--mail-color, #D35400);
}
.start-menu .app-tile-shop {
  background-color: var(--shop-color, #27AE60);
}
.start-menu .app-tile-hack {
  background-color: var(--hack-tools-color, #7F8C8D);
}
.start-menu .app-tile-settings {
  background-color: var(--settings-color, #F39C12);
}
.start-menu .app-tile {
  color: white;
}
.start-menu .app-tile.app-tile-A,
.start-menu .app-tile.app-tile-terminal {
  color: var(--app-tile-fg-color-1, white);
}
.start-menu .app-tile.app-tile-B,
.start-menu .app-tile.app-tile-browser {
  color: var(--app-tile-fg-color-2, white);
}
.start-menu .app-tile.app-tile-C,
.start-menu .app-tile.app-tile-code {
  color: var(--app-tile-fg-color-3, white);
}
.start-menu .app-tile.app-tile-D,
.start-menu .app-tile.app-tile-files {
  color: var(--app-tile-fg-color-4, white);
}
.start-menu .app-tile.app-tile-E,
.start-menu .app-tile.app-tile-monitor {
  color: var(--app-tile-fg-color-5, white);
}
.start-menu .app-tile.app-tile-F,
.start-menu .app-tile.app-tile-mail {
  color: var(--app-tile-fg-color-6, white);
}
.start-menu .app-tile.app-tile-G,
.start-menu .app-tile.app-tile-shop {
  color: var(--app-tile-fg-color-7, white);
}
.start-menu .app-tile.app-tile-H,
.start-menu .app-tile.app-tile-hack {
  color: var(--app-tile-fg-color-8, white);
}
.start-menu .app-tile.app-tile-I,
.start-menu .app-tile.app-tile-settings {
  color: var(--app-tile-fg-color-9, white);
}
.start-menu .start-menu-context-menu {
  position: fixed;
  background-color: rgba(40, 40, 40, 0.95);
  backdrop-filter: blur(10px);
  border-radius: 6px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);
  z-index: 3000;
  overflow: hidden;
  min-width: 180px;
}
.start-menu .start-menu-context-menu .context-menu-option {
  display: flex;
  align-items: center;
  padding: 10px 15px;
  cursor: pointer;
}
.start-menu .start-menu-context-menu .context-menu-option:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
.start-menu .start-menu-context-menu .context-menu-option svg {
  width: 16px;
  height: 16px;
  margin-right: 10px;
  stroke: currentColor;
}
.start-menu .start-menu-context-menu .context-menu-option span {
  flex: 1;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.start-menu .save-pinned-apps-button {
  position: absolute;
  bottom: 20px;
  left: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background-color: #0078d7;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
  opacity: 0;
  transform: scale(0.8);
  transition: opacity 0.3s ease, transform 0.3s ease;
  z-index: 100;
}
.start-menu .save-pinned-apps-button.visible {
  opacity: 1;
  transform: scale(1);
}
.start-menu .save-pinned-apps-button:hover {
  background-color: #0086f1;
}
.start-menu .save-pinned-apps-button svg {
  width: 20px;
  height: 20px;
  stroke: white;
}
.start-menu .pinned-apps-view.reorder-mode .app-tile {
  cursor: grab;
  position: relative;
}
.start-menu .pinned-apps-view.reorder-mode .app-tile:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(255, 255, 255, 0.1);
  border: 2px dashed rgba(255, 255, 255, 0.5);
  border-radius: 6px;
  pointer-events: none;
}
.start-menu .pinned-apps-view.reorder-mode .app-tile.dragging {
  opacity: 0.6;
  cursor: grabbing;
}
.GuiApplicationDialog .dialog-container,
.GuiApplicationDialog.dialog-container {
  display: flex;
  flex-direction: column;
  padding: 15px;
  overflow: hidden;
}
.GuiApplicationDialog .dialog-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
  display: flex;
  justify-content: center;
  align-items: center;
}
.GuiApplicationDialog .dialog-backdrop.modal {
  background-color: rgba(0, 0, 0, 0.5);
}
.GuiApplicationDialog .embedded-dialog {
  position: absolute;
  border-radius: 4px;
  background-color: #252526;
  border: 1px solid #3c3c3c;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
  color: #d4d4d4;
  overflow: hidden;
  z-index: 1001;
}
.GuiApplicationDialog .embedded-dialog .dialog-header {
  background-color: #333;
  padding: 10px 15px;
  font-weight: bold;
  border-bottom: 1px solid #3c3c3c;
  color: #d4d4d4;
}
.GuiApplicationDialog .dialog-message {
  margin-bottom: 15px;
}
.GuiApplicationDialog .dialog-filesystem {
  flex: 1;
  overflow: auto;
  border: 1px solid #ccc;
  margin-bottom: 15px;
  padding: 10px;
}
.GuiApplicationDialog .dialog-nav-container {
  display: flex;
  margin-bottom: 10px;
  align-items: center;
}
.GuiApplicationDialog .dialog-path-display {
  flex: 1;
  padding: 8px;
  border: 1px solid #ccc;
  border-radius: 4px;
  background-color: #f5f5f5;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.GuiApplicationDialog .dialog-up-button {
  margin-left: 10px;
  padding: 8px 12px;
  border: 1px solid #ccc;
  border-radius: 4px;
  background-color: #f0f0f0;
  cursor: pointer;
}
.GuiApplicationDialog .dialog-up-button:hover {
  background-color: #e0e0e0;
}
.GuiApplicationDialog .dialog-file-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.GuiApplicationDialog .dialog-file-list li {
  padding: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
}
.GuiApplicationDialog .dialog-file-list li.selected {
  background-color: #e0e0e0;
}
.GuiApplicationDialog .dialog-file-list li .icon {
  margin-right: 8px;
}
.GuiApplicationDialog .dialog-file-list li .name {
  flex: 1;
}
.GuiApplicationDialog .dialog-error {
  padding: 8px;
  color: #f44336;
}
.GuiApplicationDialog .dialog-input-container {
  display: flex;
  margin-bottom: 15px;
}
.GuiApplicationDialog .dialog-input-container label {
  margin-right: 10px;
  align-self: center;
}
.GuiApplicationDialog .dialog-input-container input,
.GuiApplicationDialog .dialog-input-container select {
  flex: 1;
  padding: 8px;
  box-sizing: border-box;
  border: 1px solid #ccc;
  border-radius: 4px;
}
.GuiApplicationDialog .dialog-button-container {
  display: flex;
  justify-content: flex-end;
  margin-top: 15px;
}
.GuiApplicationDialog .dialog-button {
  padding: 8px 16px;
  margin: 5px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 14px;
  background-color: #e0e0e0;
  color: #333;
}
.GuiApplicationDialog .dialog-button:hover {
  background-color: #d0d0d0;
}
.GuiApplicationDialog .dialog-button.dialog-button-primary {
  background-color: #2196F3;
  color: white;
}
.GuiApplicationDialog .dialog-button.dialog-button-primary:hover {
  background-color: #0b7dda;
}
.GuiApplicationDialog .dialog-message-box {
  flex: 1;
  margin-bottom: 15px;
  overflow: auto;
  display: flex;
  align-items: center;
}
.GuiApplicationDialog .dialog-message-box .dialog-icon {
  margin-right: 15px;
  font-size: 24px;
}
.GuiApplicationDialog .dialog-message-box .dialog-text {
  flex: 1;
}
.GuiApplicationDialog .dialog-message-box.error {
  color: #f44336;
}
.GuiApplicationDialog .dialog-message-box.warning {
  color: #ff9800;
}
.GuiApplicationDialog .dialog-message-box.information {
  color: #2196F3;
}
.GuiApplicationDialog .dialog-input {
  width: 100%;
  padding: 8px;
  box-sizing: border-box;
  border: 1px solid #ccc;
  border-radius: 4px;
  margin-bottom: 15px;
}
/**
 * Notification Component Styles
 */
.notification-container {
  position: fixed;
  z-index: 9999;
  pointer-events: none;
  max-width: 400px;
  width: 100%;
}
.notification-container.top-left {
  top: 20px;
  left: 20px;
}
.notification-container.top-center {
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
}
.notification-container.top-right {
  top: 20px;
  right: 20px;
}
.notification-container.bottom-left {
  bottom: 20px;
  left: 20px;
}
.notification-container.bottom-center {
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
}
.notification-container.bottom-right {
  bottom: 20px;
  right: 20px;
}
.notification-container[data-taskbar="bottom"].bottom-left,
.notification-container[data-taskbar="bottom"].bottom-center,
.notification-container[data-taskbar="bottom"].bottom-right {
  bottom: calc(44px + 15px);
}
.notification-container[data-taskbar="top"].top-left,
.notification-container[data-taskbar="top"].top-center,
.notification-container[data-taskbar="top"].top-right {
  top: calc(44px + 15px);
}
.notification-container[data-taskbar="left"].top-left,
.notification-container[data-taskbar="left"].bottom-left {
  left: calc(44px + 15px);
}
.notification-container[data-taskbar="right"].top-right,
.notification-container[data-taskbar="right"].bottom-right {
  right: calc(44px + 15px);
}
.notification {
  margin-bottom: 10px;
  padding: 12px 15px;
  border-radius: 4px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  font-size: 14px;
  position: relative;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: auto;
  max-width: 100%;
  min-width: 180px;
}
.notification.success {
  background-color: var(--success-color, #28a745);
  color: white;
}
.notification.error {
  background-color: var(--error-color, #dc3545);
  color: white;
}
.notification.info {
  background-color: var(--info-color, #17a2b8);
  color: white;
}
.notification.warning {
  background-color: var(--warning-color, #ffc107);
  color: black;
}
.notification.show {
  opacity: 1;
  transform: translateY(0);
}
.notification.hide {
  opacity: 0;
  transform: translateY(-20px);
}
.notification .notification-close {
  position: absolute;
  top: 3px;
  right: 5px;
  background: transparent;
  border: none;
  color: inherit;
  font-size: 18px;
  cursor: pointer;
  padding: 0;
  margin: 0;
  line-height: 1;
  opacity: 0.7;
}
.notification .notification-close:hover {
  opacity: 1;
}
.notification {
  margin-bottom: 10px;
  padding: 12px 15px;
  border-radius: 4px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  font-size: 14px;
  position: relative;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: auto;
  max-width: 100%;
  min-width: 180px;
}
.notification.success {
  background-color: var(--success-color, #28a745);
  color: white;
}
.notification.error {
  background-color: var(--error-color, #dc3545);
  color: white;
}
.notification.info {
  background-color: var(--info-color, #17a2b8);
  color: white;
}
.notification.warning {
  background-color: var(--warning-color, #ffc107);
  color: black;
}
.notification.show {
  opacity: 1;
  transform: translateY(0);
}
.notification.hide {
  opacity: 0;
  transform: translateY(-20px);
}
.notification .notification-close {
  position: absolute;
  top: 3px;
  right: 5px;
  background: transparent;
  border: none;
  color: inherit;
  font-size: 18px;
  cursor: pointer;
  padding: 0;
  margin: 0;
  line-height: 1;
  opacity: 0.7;
}
.notification .notification-close:hover {
  opacity: 1;
}

