body.theme-dark {
    --text-color: #f8f8f2;
    --background-color: #1e1e28;
    --keyword-color: #ff79c6;
    --string-color: #f1fa8c;
    --number-color: #bd93f9;
    --comment-color: #6272a4;
    --tag-color: #4ec9b0;
    --delimiter-color: #ffb86c;
    --header-bg: #282a36;
    --sidebar-bg: #282a36;
    --border-color: #44475a;
    --button-hover: #44475a;
    --button-active: #6272a4;
    --tab-bg: #282a36;
    --tab-active-bg: #1e1e28;
    --terminal-bg: #282a36;
    --terminal-text: #f8f8f2;
    --quick-access-bg: #282a36;
    --modal-bg: #282a36;
    --input-bg: #44475a;
    --input-text: #f8f8f2;
    --tooltip-bg: #44475a;
    --tooltip-text: #f8f8f2;
    --dropdown-bg: #44475a;
    --dropdown-text: #f8f8f2;
    --dropdown-hover: #6272a4;
    --fab-bg: #44475a;
    --fab-hover: #6272a4;
    --fab-text: #f8f8f2;
    --error-color: #ff5555;
    --success-color: #50fa7b;
    --warning-color: #ffb86c;
    --info-color: #8be9fd;
}

body.theme-vibrant {
    --text-color: #ffffff;
    --background-color: #1a1a1a;
    --keyword-color: #ffdd40;
    --string-color: #ff7f7f;
    --number-color: #7fdbca;
    --comment-color: #50fa7b;
    --tag-color: #ff5500;
    --delimiter-color: #ff00ff;
    --header-bg: #252525;
    --sidebar-bg: #252525;
    --border-color: #333333;
    --button-hover: #333333;
    --button-active: #555555;
    --tab-bg: #252525;
    --tab-active-bg: #1a1a1a;
    --terminal-bg: #252525;
    --terminal-text: #ffffff;
    --quick-access-bg: #252525;
    --modal-bg: #252525;
    --input-bg: #333333;
    --input-text: #ffffff;
    --tooltip-bg: #333333;
    --tooltip-text: #ffffff;
    --dropdown-bg: #333333;
    --dropdown-text: #ffffff;
    --dropdown-hover: #555555;
    --fab-bg: #333333;
    --fab-hover: #555555;
    --fab-text: #ffffff;
    --error-color: #ff5555;
    --success-color: #50fa7b;
    --warning-color: #ffb86c;
    --info-color: #7fdbca;
}

body.theme-neon {
    --text-color: #ffffff;
    --background-color: #000000;
    --keyword-color: #ff00ff;
    --string-color: #00ff00;
    --number-color: #ff5500;
    --comment-color: #888888;
    --tag-color: #00ffff;
    --delimiter-color: #ffff00;
    --header-bg: #111111;
    --sidebar-bg: #111111;
    --border-color: #333333;
    --button-hover: #222222;
    --button-active: #444444;
    --tab-bg: #111111;
    --tab-active-bg: #000000;
    --terminal-bg: #111111;
    --terminal-text: #ffffff;
    --quick-access-bg: #111111;
    --modal-bg: #111111;
    --input-bg: #222222;
    --input-text: #ffffff;
    --tooltip-bg: #222222;
    --tooltip-text: #ffffff;
    --dropdown-bg: #222222;
    --dropdown-text: #ffffff;
    --dropdown-hover: #444444;
    --fab-bg: #222222;
    --fab-hover: #444444;
    --fab-text: #ffffff;
    --error-color: #ff0000;
    --success-color: #00ff00;
    --warning-color: #ffff00;
    --info-color: #00ffff;
}

body.theme-cyber {
    --text-color: #00ff9d;
    --background-color: #0a0a1a;
    --keyword-color: #ff007f;
    --string-color: #9dff00;
    --number-color: #ff9100;
    --comment-color: #696969;
    --tag-color: #00ccff;
    --delimiter-color: #ff00ff;
    --header-bg: #12122a;
    --sidebar-bg: #12122a;
    --border-color: #24244a;
    --button-hover: #24244a;
    --button-active: #36366a;
    --tab-bg: #12122a;
    --tab-active-bg: #0a0a1a;
    --terminal-bg: #12122a;
    --terminal-text: #00ff9d;
    --quick-access-bg: #12122a;
    --modal-bg: #12122a;
    --input-bg: #24244a;
    --input-text: #00ff9d;
    --tooltip-bg: #24244a;
    --tooltip-text: #00ff9d;
    --dropdown-bg: #24244a;
    --dropdown-text: #00ff9d;
    --dropdown-hover: #36366a;
    --fab-bg: #24244a;
    --fab-hover: #36366a;
    --fab-text: #00ff9d;
    --error-color: #ff007f;
    --success-color: #9dff00;
    --warning-color: #ff9100;
    --info-color: #00ccff;
}

body.theme-royal {
    --text-color: #fff5e6;
    --background-color: #2a1a2f;
    --keyword-color: #d4af37;
    --string-color: #a78faa;
    --number-color: #c9a227;
    --comment-color: #6d4c85;
    --tag-color: #b08d57;
    --delimiter-color: #9b6a6c;
    --header-bg: #3a2a3f;
    --sidebar-bg: #3a2a3f;
    --border-color: #4d3a52;
    --button-hover: #4d3a52;
    --button-active: #5f4a64;
    --tab-bg: #3a2a3f;
    --tab-active-bg: #2a1a2f;
    --terminal-bg: #3a2a3f;
    --terminal-text: #fff5e6;
    --quick-access-bg: #3a2a3f;
    --modal-bg: #3a2a3f;
    --input-bg: #4d3a52;
    --input-text: #fff5e6;
    --tooltip-bg: #4d3a52;
    --tooltip-text: #fff5e6;
    --dropdown-bg: #4d3a52;
    --dropdown-text: #fff5e6;
    --dropdown-hover: #5f4a64;
    --fab-bg: #4d3a52;
    --fab-hover: #5f4a64;
    --fab-text: #fff5e6;
    --error-color: #9b6a6c;
    --success-color: #a78faa;
    --warning-color: #d4af37;
    --info-color: #b08d57;
}

body.theme-sapphire {
    --text-color: #e0f2fe;
    --background-color: #0f172a;
    --keyword-color: #3a6b8f;
    --string-color: #7cb7d0;
    --number-color: #6baed6;
    --comment-color: #4a5568;
    --tag-color: #90cdf4;
    --delimiter-color: #cbd5e0;
    --header-bg: #1e293b;
    --sidebar-bg: #1e293b;
    --border-color: #334155;
    --button-hover: #334155;
    --button-active: #475569;
    --tab-bg: #1e293b;
    --tab-active-bg: #0f172a;
    --terminal-bg: #1e293b;
    --terminal-text: #e0f2fe;
    --quick-access-bg: #1e293b;
    --modal-bg: #1e293b;
    --input-bg: #334155;
    --input-text: #e0f2fe;
    --tooltip-bg: #334155;
    --tooltip-text: #e0f2fe;
    --dropdown-bg: #334155;
    --dropdown-text: #e0f2fe;
    --dropdown-hover: #475569;
    --fab-bg: #334155;
    --fab-hover: #475569;
    --fab-text: #e0f2fe;
    --error-color: #ef4444;
    --success-color: #10b981;
    --warning-color: #f59e0b;
    --info-color: #3b82f6;
}

body.theme-vintage {
    --text-color: #f3e9d2;
    --background-color: #2d1f24;
    --keyword-color: #d3b683;
    --string-color: #9e7e6e;
    --number-color: #b88b4a;
    --comment-color: #5a4d46;
    --tag-color: #7b1e3f;
    --delimiter-color: #2d504f;
    --sidebar-bg: #3d2f34;
    --border-color: #4d3f44;
    --button-hover: #4d3f44;
    --button-active: #5d4f54;
    --tab-bg: #3d2f34;
    --tab-active-bg: #2d1f24;
    --terminal-bg: #3d2f34;
    --terminal-text: #f3e9d2;
    --quick-access-bg: #3d2f34;
    --modal-bg: #3d2f34;
    --input-bg: #4d3f44;
    --input-text: #f3e9d2;
    --tooltip-bg: #4d3f44;
    --tooltip-text: #f3e9d2;
    --dropdown-bg: #4d3f44;
    --dropdown-text: #f3e9d2;
    --dropdown-hover: #5d4f54;
    --fab-bg: #4d3f44;
    --fab-hover: #5d4f54;
    --fab-text: #f3e9d2;
    --error-color: #7b1e3f;
    --success-color: #9e7e6e;
    --warning-color: #b88b4a;
    --info-color: #2d504f;
}

body.theme-platinum {
    --text-color: #333333;
    --background-color: #2d1f24;
    --keyword-color: #008080;
    --string-color: #b76e79;
    --number-color: #6a5acd;
    --comment-color: #a0a0a0;
    --tag-color: #4b6a88;
    --delimiter-color: #e5e4e2;
    --header-bg: #3d2f34;
    --sidebar-bg: #3d2f34;
    --border-color: #4d3f44;
    --button-hover: #4d3f44;
    --button-active: #5d4f54;
    --tab-bg: #3d2f34;
    --tab-active-bg: #2d1f24;
    --terminal-bg: #3d2f34;
    --terminal-text: #333333;
    --quick-access-bg: #3d2f34;
    --modal-bg: #3d2f34;
    --input-bg: #4d3f44;
    --input-text: #333333;
    --tooltip-bg: #4d3f44;
    --tooltip-text: #333333;
    --dropdown-bg: #4d3f44;
    --dropdown-text: #333333;
    --dropdown-hover: #5d4f54;
    --fab-bg: #4d3f44;
    --fab-hover: #5d4f54;
    --fab-text: #333333;
    --error-color: #b76e79;
    --success-color: #008080;
    --warning-color: #6a5acd;
    --info-color: #4b6a88;
}

body.theme-corporate {
    --text-color: #ecf0f1;
    --background-color: #2c3e50;
    --keyword-color: #3498db;
    --string-color: #1abc9c;
    --number-color: #9b59b6;
    --comment-color: #7f8c8d;
    --tag-color: #e67e22;
    --delimiter-color: #bdc3c7;
    --header-bg: #34495e;
    --sidebar-bg: #34495e;
    --border-color: #3d566e;
    --button-hover: #3d566e;
    --button-active: #4d6e86;
    --tab-bg: #34495e;
    --tab-active-bg: #2c3e50;
    --terminal-bg: #34495e;
    --terminal-text: #ecf0f1;
    --quick-access-bg: #34495e;
    --modal-bg: #34495e;
    --input-bg: #3d566e;
    --input-text: #ecf0f1;
    --tooltip-bg: #3d566e;
    --tooltip-text: #ecf0f1;
    --dropdown-bg: #3d566e;
    --dropdown-text: #ecf0f1;
    --dropdown-hover: #4d6e86;
    --fab-bg: #3d566e;
    --fab-hover: #4d6e86;
    --fab-text: #ecf0f1;
    --error-color: #e74c3c;
    --success-color: #2ecc71;
    --warning-color: #f39c12;
    --info-color: #3498db;
}

body.theme-graphite {
    --text-color: #ecf0f1;
    --background-color: #2c3e50;
    --keyword-color: #e74c3c;
    --string-color: #95a5a6;
    --number-color: #f1c40f;
    --comment-color: #7f8c8d;
    --tag-color: #3498db;
    --delimiter-color: #bdc3c7;
    --header-bg: #34495e;
    --sidebar-bg: #34495e;
    --border-color: #3d566e;
    --button-hover: #3d566e;
    --button-active: #4d6e86;
    --tab-bg: #34495e;
    --tab-active-bg: #2c3e50;
    --terminal-bg: #34495e;
    --terminal-text: #ecf0f1;
    --quick-access-bg: #34495e;
    --modal-bg: #34495e;
    --input-bg: #3d566e;
    --input-text: #ecf0f1;
    --tooltip-bg: #3d566e;
    --tooltip-text: #ecf0f1;
    --dropdown-bg: #3d566e;
    --dropdown-text: #ecf0f1;
    --dropdown-hover: #4d6e86;
    --fab-bg: #3d566e;
    --fab-hover: #4d6e86;
    --fab-text: #ecf0f1;
    --error-color: #e74c3c;
    --success-color: #2ecc71;
    --warning-color: #f1c40f;
    --info-color: #3498db;
}

body.theme-tech {
    --text-color: #ffffff;
    --background-color: #1a2f38;
    --keyword-color: #2ecc71;
    --string-color: #27ae60;
    --number-color: #f1c40f;
    --comment-color: #566573;
    --tag-color: #3498db;
    --delimiter-color: #95a5a6;
    --header-bg: #2a3f48;
    --sidebar-bg: #2a3f48;
    --border-color: #3a4f58;
    --button-hover: #3a4f58;
    --button-active: #4a5f68;
    --tab-bg: #2a3f48;
    --tab-active-bg: #11a2f38;
    --terminal-bg: #2a3f48;
    --terminal-text: #ffffff;
    --quick-access-bg: #2a3f48;
    --modal-bg: #2a3f48;
    --input-bg: #3a4f58;
    --input-text: #ffffff;
    --tooltip-bg: #3a4f58;
    --tooltip-text: #ffffff;
    --dropdown-bg: #3a4f58;
    --dropdown-text: #ffffff;
    --dropdown-hover: #4a5f68;
    --fab-bg: #3a4f58;
    --fab-hover: #4a5f68;
    --fab-text: #ffffff;
    --error-color: #e74c3c;
    --success-color: #2ecc71;
    --warning-color: #f1c40f;
    --info-color: #3498db;
}

body.theme-cyan {
    --text-color: #ffffff;
    --background-color: #1a2f38;
    --keyword-color: #00b4d8;
    --string-color: #0077b6;
    --number-color: #ff6b6b;
    --comment-color: #adb5bd;
    --tag-color: #48cae4;
    --delimiter-color: #f53273;
    --header-bg: #2a3f48;
    --sidebar-bg: #2a3f48;
    --border-color: #3a4f58;
    --button-hover: #3a4f58;
    --button-active: #4a5f68;
    --tab-bg: #2a3f48;
    --tab-active-bg: #1a2f38;
    --terminal-bg: #2a3f48;
    --terminal-text: #ffffff;
    --quick-access-bg: #2a3f48;
    --modal-bg: #2a3f48;
    --input-bg: #3a4f58;
    --input-text: #ffffff;
    --tooltip-bg: #3a4f58;
    --tooltip-text: #ffffff;
    --dropdown-bg: #3a4f58;
    --dropdown-text: #ffffff;
    --dropdown-hover: #4a5f68;
    --fab-bg: #3a4f58;
    --fab-hover: #4a5f68;
    --fab-text: #ffffff;
    --error-color: #ff6b6b;
    --success-color: #48cae4;
    --warning-color: #f53273;
    --info-color: #00b4d8;
}

body.theme-dracula {
    --text-color: #f8f8f2;
    --background-color: #282a36;
    --keyword-color: #ff79c6;
    --string-color: #f1fa8c;
    --number-color: #bd93f9;
    --comment-color: #6272a4;
    --tag-color: #50fa7b;
    --delimiter-color: #ffb86c;
    --header-bg: #44475a;
    --sidebar-bg: #44475a;
    --border-color: #6272a4;
    --button-hover: #6272a4;
    --button-active: #8be9fd;
    --tab-bg: #44475a;
    --tab-active-bg: #282a36;
    --terminal-bg: #44475a;
    --terminal-text: #f8f8f2;
    --quick-access-bg: #44475a;
    --modal-bg: #44475aa;
    --input-bg: #6272a4;
    --input-text: #f8f8f2;
    --tooltip-bg: #6272a4;
    --tooltip-text: #f8f8f2;
    --dropdown-bg: #6272a4;
    --dropdown-text: #f8f8f2;
    --dropdown-hover: #8be9fd;
    --fab-bg: #6272a4;
    --fab-hover: #8be9fd;
    --fab-text: #f8f8f2;
    --error-color: #ff5555;
    --success-color: #50fa7b;
    --warning-color: #ffb86c;
    --info-color: #8be9fd;
}

body.theme-solarized {
    --text-color: #839496;
    --background-color: #002b36;
    --keyword-color: #268bd2;
    --string-color: #2aa198;
    --number-color: #b58900;
    --comment-color: #586e75;
    --tag-color: #dc322f;
    --delimiter-color: #859900;
    --header-bg: #073642;
    --sidebar-bg: #073642;
    --border-color: #586e75;
    --button-hover: #586e75;
    --button-active: #6c7a80;
    --tab-bg: #073642;
    --tab-active-bg: #002b36;
    --terminal-bg: #073642;
    --terminal-text: #839496;
    --quick-access-bg: #073642;
    --modal-bg: #073642;
    --input-bg: #586e75;
    --input-text: #839496;
    --tooltip-bg: #586e75;
    --tooltip-text: #839496;
    --dropdown-bg: #586e75;
    --dropdown-text: #839496;
    --dropdown-hover: #6c7a80;
    --fab-bg: #586e75;
    --fab-hover: #6c7a80;
    --fab-text: #839496;
    --error-color: #dc322f;
    --success-color: #2aa198;
    --warning-color: #b58900;
    --info-color: #268bd2;
}

body.theme-ocean {
     --text-color: #82aaff;
    --background-color: #0f111a;
    --keyword-color: #ff5370;
    --string-color: #c3e88d;
    --number-color: #f78c6c;
    --comment-color: #464b5d;
    --tag-color: #89ddff;
    --delimiter-color: #c792ea;
    --header-bg: #1f213a;
    --sidebar-bg: #1f213a;
    --border-color: #3f415a;
    --button-hover: #3f415a;
    --button-active: #5f617a;
    --tab-bg: #1f213a;
    --tab-active-bg: #0f111a;
    --terminal-bg: #1f213a;
    --terminal-text: #82aaff;
    --quick-access-bg: #1f213a;
    --modal-bg: #1f213a;
    --input-bg: #3f415a;
    --input-text: #82aaff;
    --tooltip-bg: #3f415a;
    --tooltip-text: #82aaff;
    --dropdown-bg: #3f415a;
    --dropdown-text: #82aaff;
    --dropdown-hover: #5f617a;
    --fab-bg: #3f415a;
    --fab-hover: #5f617a;
    --fab-text: #82aaff;
    --error-color: #ff5370;
    --success-color: #c3e88d;
    --warning-color: #f78c6c;
    --info-color: #89ddff;
}

body.theme-nord {
    --text-color: #d8dee9;
    --background-color: #2e3440;
    --keyword-color: #81a1c1;
    --string-color: #a3be8c;
    --number-color: #b48ead;
    --comment-color: #4c566a;
    --tag-color: #88c0d0;
    --delimiter-color: #bf616a;
    --header-bg: #3b4252;
    --sidebar-bg: #3b4252;
    --border-color: #4c566a;
    --button-hover: #4c566a;
    --button-active: #5d677a;
    --tab-bg: #3b4252;
    --tab-active-bg: #2e3440;
    --terminal-bg: #3b4252;
    --terminal-text: #d8dee9;
    --quick-access-bg: #3b4252;
    --modal-bg: #3b4252;
    --input-bg: #4c566a;
    --input-text: #d8dee9;
    --tooltip-bg: #4c566a;
    --tooltip-text: #d8dee9;
    --dropdown-bg: #4c566a;
    --dropdown-text: #d8dee9;
    --dropdown-hover: #5d677a;
    --fab-bg: #4c566a;
    --fab-hover: #5d677a;
    --fab-text: #d8dee9;
    --error-color: #bf616a;
    --success-color: #a3be8c;
    --warning-color: #ebcb8b;
    --info-color: #88c0d0;
}

html,
body {
    margin: 0 !important;
    padding: 0 !important;
    max-height: 100%;
    margin: 0;
    overflow: hidden;
    background-color: var(--background-color);
    color: var(--text-color);
}

::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.05);
}

::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.3);
}

.transition-all {
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.editor-glow {
    box-shadow: 0 0 15px var(--number-color);
}

.fab {
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    transition: all 0.2s ease;
    background-color: var(--fab-bg);
    color: var(--fab-text);
}

.fab:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    background-color: var(--fab-hover);
}

.user-profile {
    position: relative;
    transition: all 0.2s ease;
    z-index: 9;
}

.user-profile .dropdown {
    display: none;
    position: absolute;
    right: 0;
    top: 100%;
    min-width: 200px;
    background-color: var(--dropdown-bg);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    padding: 8px 0;
    margin-top: 8px;
}

.user-profile:hover .dropdown,
.user-profile .dropdown:hover {
    display: block;
}

.user-profile .dropdown button {
    width: 100%;
    text-align: left;
    padding: 8px 16px;
    color: var(--dropdown-text);
    transition: all 0.2s ease;
}

.user-profile .dropdown button:hover {
    background-color: var(--dropdown-hover);
    color: var(--text-color);
}

.user-profile .dropdown .user-email {
    padding: 8px 16px;
    color: var(--info-color);
    font-size: 0.9rem;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 4px;
}

@keyframes blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0; }
}

.terminal-cursor {
    animation: blink 1s step-end infinite;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(-20px); }
    to { opacity: 1; transform: translateY(0); }
}

.gradient-text {
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    background-image: linear-gradient(90deg,  #ff007f, #ff00ff);
}

/* .gradient-text{
    color: #00ffff;
    font-weight: 900;
} */
h3 {
    color: var(--text-color);
}

.tooltip-text {
    font-size: 1rem;
    font-family: monospace;
    text-align: center;
    align-items: center;
    color: var(--tooltip-text);
}

button:focus:not(:focus-visible) {
    outline: none;
}

.monaco-editor .suggest-widget .monaco-list-row.focused .codicon {
    color: var(--number-color) !important;
}

.monaco-editor .suggest-widget .monaco-list-row.focused {
    color: var(--text-color) !important;
    background-color: var(--button-hover) !important;
}

.monaco-editor .parameter-hints-widget {
    border: 1px solid var(--border-color);
    background-color: var(--modal-bg);
}

.monaco-editor .parameter-hints-widget .signature {
    color: var(--text-color);
}

.monaco-editor .parameter-hints-widget .docs {
    color: var(--comment-color);
}

.monaco-editor {
    .tag {
        color: var(--tag-color);
    }

    .angle-bracket {
        color: var(--delimiter-color);
    }

    .identifier {
        color: var(--text-color);
    }

    .mtk1 {
        color: var(--text-color);
    }

    .mtk5 {
        color: var(--delimiter-color);
    }

    .mtk6 {
        color: var(--tag-color);
    }

    .mtk10 {
        color: var(--keyword-color);
    }

    .mtk12 {
        color: var(--string-color);
    }

    .mtk8 {
        color: var(--number-color);
    }

    .mtk3 {
        color: var(--comment-color);
    }
}

.modal-overlay {
    background-color: rgba(30, 30, 40, 0.8);
}

#error-modal {
    animation: fadeIn 0.3s ease-out;
}

#error-modal div {
    border-color: var(--error-color);
}

#open-new-window {
    margin-top: 50px;
    background-color: var(--info-color);
}

.tooltip {
    position: relative;
}

.tooltip .tooltip-text {
    visibility: hidden;
    width: 120px;
    background-color: var(--tooltip-bg);
    color: var(--tooltip-text);
    text-align: center;
    border-radius: 6px;
    padding: 5px;
    position: absolute;
    z-index: 1;
    bottom: 125%;
    left: 50%;
    transform: translateX(-50%);
    opacity: 0;
    transition: opacity 0.3s;
}

.tooltip:hover .tooltip-text {
    visibility: visible;
    opacity: 1;
}

.console-log {
    color: var(--text-color);
    font-family: monospace;
    white-space: pre-wrap;
    margin: 4px 0;
    line-height: 1.5;
}

.console-error {
    color: var(--error-color);
    font-family: monospace;
    white-space: pre-wrap;
    margin: 4px 0;
    line-height: 1.5;
}

.console-warn {
    color: var(--warning-color);
    font-family: monospace;
    white-space: pre-wrap;
    margin: 4px 0;
    line-height: 1.5;
}

.console-info {
    color: var(--info-color);
    font-family: monospace;
    white-space: pre-wrap;
    margin: 4px 0;
    line-height: 1.5;
}

#console-content {
    white-space: pre-wrap;
    word-break: break-word;
    font-family: monospace;
    line-height: 1.5;
    padding: 8px;
    background-color: var(--terminal-bg);
    color: var(--terminal-text);
}

.error-lens-decoration-error {
    background: rgba(255, 85, 85, 0.1);
    border-bottom: 2px dashed var(--error-color);
}

.error-lens-glyph-margin-error {
    background: rgba(255, 85, 85, 0.2);
}

.error-lens-inline-error::after {
    content: attr(title);
    color: var(--error-color);
    background: rgba(30, 30, 40, 0.9);
    padding: 2px 4px;
    border-radius: 3px;
    margin-left: 5px;
    font-size: 12px;
}

.error-lens-decoration-warning {
    background: rgba(255, 184, 108, 0.1);
    border-bottom: 2px dashed var(--warning-color);
}

.error-lens-glyph-margin-warning {
    background: rgba(255, 184, 108, 0.2);
}

.error-lens-inline-warning::after {
    content: attr(title);
    color: var(--warning-color);
    background: rgba(30, 30, 40, 0.9);
    padding: 2px 4px;
    border-radius: 3px;
    margin-left: 5px;
    font-size: 12px;
}

.error-lens-decoration-info {
    background: rgba(139, 233, 253, 0.1);
    border-bottom: 2px dashed var(--info-color);
}

.error-lens-glyph-margin-info {
    background: rgba(139, 233, 253, 0.2);
}

.error-lens-inline-info::after {
    content: attr(title);
    color: var(--info-color);
    background: rgba(30, 30, 40, 0.9);
    padding: 2px 4px;
    border-radius: 3px;
    margin-left: 5px;
    font-size: 12px;
}

#sidebar {
    position: absolute;
    min-height: calc(100vh - 4.3rem);
    z-index: 20;
    transition: transform 0.3s ease-in-out;
    background-color: var(--sidebar-bg) !important;
    color: var(--text-color) !important;
}

.modal-compartir {
    z-index: 999;
    background-color: var(--modal-bg);
    color: var(--text-color);
}

.tab-button {
    cursor: pointer;
    padding: 0.5rem 1rem;
    border-bottom: 2px solid transparent;
    background-color: var(--tab-bg);
    color: var(--text-color);
}

.active-tab {
    color: var(--info-color);
    border-bottom-color: var(--info-color);
}

.animate-fade-in {
    animation: fadeIn 0.3s ease-in;
}

@media(max-width:670px) {
    .acciones button {
        font-size: 10px;
    }
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

#live-events {
    max-height: 400px;
    overflow-y: auto;
    background-color: var(--terminal-bg);
    color: var(--terminal-text);
}

@media (min-width: 768px) {
    #sidebar {
        position: absolute;
        transform: translateX(0);
        background-color: var(--sidebar-bg);
    }

    #sidebar.-translate-x-full {
        transform: translateX(-100%);
    }

    #quick-access {
        position: absolute !important;
        right: 0;
        top: 0;
        height: 100%;
        z-index: 20;
        transform: translateX(100%);
        transition: transform 0.3s ease-in-out;
        opacity: 0;
        visibility: hidden;
        background-color: var(--quick-access-bg);
        color: var(--text-color);
    }

    #quick-access.show {
        transform: translateX(0);
        opacity: 1;
        visibility: visible;
        transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out;
    }
}

#main-content {
    width: 100%;
    transition: width 0.3s ease;
    background-color: var(--background-color);
}

#editor-container {
    width: 100%;
    min-height: calc(100vh - 9rem);
    flex: 1;
    transition: all 0.3s ease;
    background-color: var(--background-color);
}

#preview-frame {
    width: 100%;
    height: 100%;
    border: none;
    display: block;
    background: white;
}

#editor-container.half-screen {
    min-height: 40vh !important;
    flex: 0;
}

footer {
    background-color: var(--header-bg) !important;
    border-color: var(--border-color) !important;
    color: var(--text-color) !important;
}

footer a {
    color: var(--text-color) !important;
}

footer a:hover {
    color: var(--info-color) !important;
}

#main-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    background-color: var(--background-color);
}

#preview-container {
    height: 0;
    overflow: hidden;
    transition: height 0.3s ease, flex 0.3s ease;
    flex: none;
    background-color: var(--background-color);
}

#preview-container.full-height {
    flex: 1;
    min-height: calc(100vh - 9rem);
}

#preview-container.half-screen {
    flex: 1;
    min-height: 40vh !important;
}

#terminal-panel {
    height: 0;
    flex-shrink: 0;
    transition: height 0.3s ease, flex 0.3s ease;
    background-color: var(--terminal-bg);
    color: var(--terminal-text);
}

#terminal-panel.half-screen {
    flex: 1;
    min-height: 37vh !important;
}

@media(max-width:799px) {
    html, body {
        margin: 0 !important;
        padding: 0 !important;
        max-height: 100%;
        min-width: 100%;
        margin: 0;
        overflow: hidden;
        position: fixed !important;
        background-color: var(--background-color);
        color: var(--text-color);
    }
    #editor-container {
        min-height: calc(100vh - 9rem);
        background-color: var(--background-color);
    }

    #editor-container.half-screen {
        min-height: 30vh !important;
    }

    #preview-container.half-screen {
        min-height: 30vh !important;
    }

    #terminal-panel.half-screen {
        min-height: 46vh !important;
    }

    #sidebar {
        min-height: calc(100vh - 7.7rem);
        background-color: var(--sidebar-bg);
    }
}

#quick-access {
    position: fixed !important;
    right: 0;
    top: 0;
    height: 100%;
    z-index: 20;
    transform: translateX(100%);
    transition: transform 0.3s ease-in-out;
    background-color: var(--quick-access-bg);
    color: var(--text-color);
}

#quick-access.show {
    transform: translateX(0);
}

.tooltip-text {
    font-size: 1rem;
    font-family: monospace;
    text-align: center;
    align-items: center;
    color: var(--tooltip-text);
}

.color-preset-btn {
    transition: all 0.2s ease;
}

.color-preset-btn:hover {
    transform: translateY(-2px);
}

input[type="color"]::-webkit-color-swatch-wrapper {
    padding: 0;
}

input[type="color"]::-webkit-color-swatch {
    border: none;
    border-radius: 2px;
}

body,
#sidebar,
#quick-access,
#terminal-panel,
#config-modal {
    background-color: var(--background-color) !important;
    color: var(--text-color) !important;
}

#chat-modal {
    max-width: 100% !important;
    min-height: 500px !important;
    right: 0;
    transform: translateX(100%);
    background: var(--modal-bg);
    box-shadow: -8px 0 32px rgba(0, 0, 0, 0.4);
    color: var(--text-color);
}
#repo-modal {
        background-color: var(--background-color )  !important;
    }

#chat-modal.show {
    transform: translateX(0);
}

.custom-scrollbar::-webkit-scrollbar {
    width: 8px;
}

.custom-scrollbar::-webkit-scrollbar-track {
    background: var(--background-color);
}

.custom-scrollbar::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 4px;
}

@media (min-width: 768px) {
    #chat-modal {
        width: 440px;
        height: 100% !important;
    }
}

#editor-tabs,
header {
    background-color: var(--header-bg) !important;
    border-color: var(--border-color) !important;
    color: var(--text-color);
}

.code-tabs-container {
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    background-color: var(--header-bg);
}

.tab-btn {
    transition: all 0.3s ease;
    cursor: pointer;
    background: none;
    border: none;
    outline: none;
    color: var(--text-color);
}

.tab-btn:hover:not(.active) {
    color: var(--number-color) !important;
}

.brief-explanation {
    color: var(--text-color);
    font-size: 0.95rem;
    line-height: 1.5;
}

input,
select,
textarea {
    background-color: var(--input-bg) !important;
    border: 1px solid var(--border-color) !important;
    color: var(--input-text) !important;
}

.file-item:hover,
.folder-item:hover {
    background-color: var(--button-hover) !important;
}

.monaco-editor .view-overlays .current-line {
    border: none !important;
    background-color: var(--header-bg) !important;
}

.monaco-editor .glyph-margin {
    display: none !important;
}

.monaco-editor .view-ruler {
    display: none !important;
}

.loader-dots {
    display: inline-block;
    position: relative;
    width: 80px;
    height: 13px;
}

.dot {
    position: absolute;
    width: 8px;
    height: 8px;
    background: var(--number-color);
    border-radius: 50%;
    animation: loader-dots 1.2s linear infinite;
}

.dot:nth-child(2) {
    left: 10px;
    animation-delay: 0.2s;
}

.dot:nth-child(3) {
    left: 20px;
    animation-delay: 0.4s;
}

@keyframes loader-dots {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-5px); }
}
@keyframes pulse-icon {
    0%   { color: var(--error-color); transform: scale(1); opacity: 1; }
    50%  { color: var(--error-color); transform: scale(1.2); opacity: 0.8; }
    100% { color: var(--error-color); transform: scale(1); opacity: 1; }
}

@keyframes pulse-badge {
    0% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.3); opacity: 0.75; }
    100% { transform: scale(1); opacity: 1; }
}

pre code {
    font-family: 'Fira Code', monospace;
    font-size: 0.9em;
    line-height: 1.4;
    background-color: var(--terminal-bg);
    color: var(--terminal-text);
}

body[class^="theme-"] {
    transition: background-color 0.3s, color 0.3s;
}

.color-preset-btn {
    transition: transform 0.2s, box-shadow 0.3s;
    border-width: 2px;
    border-color: var(--border-color);
}

.color-preset-btn:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
}

.color-preset-btn.active-preset {
    border-color: var(--info-color);
    box-shadow: 0 0 0 2px var(--info-color);
}

body {
    background-color: var(--background-color);
    color: var(--text-color);
}

.monaco-editor {
    background-color: var(--background-color) !important;
}

#view-pricing-modal-welcome {
    z-index: 99999999999;
}

#pricing-modal {
    animation: slideIn 0.3s ease-out;
    background-color: var(--modal-bg);
    color: var(--text-color);
}

.plan-option {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border: 1px solid var(--border-color);
    background-color: var(--modal-bg);
    color: var(--text-color);
}

.plan-option:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.text-accent-green {
    color: var(--success-color);
}

#user-info {
    border: 1px solid var(--border-color);
    background-color: var(--modal-bg);
    color: var(--text-color);
}

.status-dot {
    transition: all 0.3s ease;
}

.status-active .status-dot {
    background: var(--success-color);
    box-shadow: 0 0 8px var(--success-color);
}

.status-inactive .status-dot {
    background: var(--error-color);
    box-shadow: 0 0 8px var(--error-color);
}

#recaptcha-container {
    margin: 10px 0;
    min-height: 40px;
}

.grecaptcha-badge {
    visibility: hidden;
}

.auth-error {
    background-color: rgba(248, 215, 218, 0.2);
    border-color: var(--error-color);
    color: var(--error-color);
    padding: 10px;
    border-radius: 4px;
    margin-top: 10px;
    font-size: 0.9em;
}

@media(max-width:768px) {
    #colors-palet {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    #repo-modal {
        width: 100% !important;
        max-width: 100% !important;
        height: 100% !important;
        max-height: 100% !important;
        border-radius: 0 !important;
        background-color: var(--modal-bg);
        color: var(--text-color);
    }

    #repo-modal .border-r,
    #repo-modal .border-l {
        display: none;
    }

    #repo-modal>div {
        flex-direction: column;
        height: 100%;
    }

    #repo-search-container,
    #repo-actions-panel {
        display: none;
    }

    #repo-editor-container {
        width: 100% !important;
    }

    .repo-menu-toggle {
        display: flex !important;
        position: relative;
        z-index: 1 !important;
        padding: 10px;
        background: var(--header-bg);
        border-radius: 4px;
        color: var(--text-color);
    }

    #repo-search-container.active,
    #repo-actions-panel.active {
        display: block;
        position: fixed;
        top: 30px !important;
        bottom: 0;
        width: 80%;
        max-width: 300px;
        background: var(--header-bg);
        z-index: 40;
        overflow-y: auto;
        box-shadow: 2px 0 10px rgba(0, 0, 0, 0.5);
        color: var(--text-color);
    }

    #repo-search-container.active {
        left: 0;
    }

    #repo-actions-panel.active {
        right: 0;
    }

    .repo-menu-overlay {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.5);
        z-index: 30;
        display: none;
    }

    .repo-menu-overlay.active {
        display: block;
    }
}


.sp-container {
    position: absolute;
    top: 0;
    left: 0;
    display: inline-block;
    z-index: 9999999999999;
    overflow: hidden;
    border-radius: 0;
    background-color: var(--background-color) !important;
    border: var(--border-color);
    padding: 0;
}

.sp-container.sp-flat {
    position: relative;
}

.sp-container,
.sp-container * {
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box;
}

.sp-top {
    position: relative;
    width: 100%;
    display: inline-block;
    margin-bottom: 3px;
}

.sp-top-inner {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

.sp-color {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 20%;
}

.sp-hue {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 84%;
    height: 100%;
    background: linear-gradient(to bottom, red 0, #ff0 17%, #0f0 33%, #0ff 50%, #00f 67%, #f0f 83%, red 100%);
}

.sp-clear-enabled .sp-hue {
    top: 33px;
    height: 77.5%;
}

.sp-fill {
    padding-top: 80%;
}

.sp-sat,
.sp-val {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.sp-alpha-enabled .sp-top {
    margin-bottom: 18px;
}

.sp-alpha-enabled .sp-alpha {
    display: block;
}

.sp-alpha-handle {
    position: absolute;
    top: -4px;
    bottom: -4px;
    width: 6px;
    left: 50%;
    cursor: pointer;
    border: 1px solid #000;
    background: #1b1616;
    opacity: .8;
}

.sp-alpha {
    display: none;
    position: absolute;
    bottom: -14px;
    right: 0;
    left: 0;
    height: 8px;
}

.sp-alpha-inner {
    border: solid 1px #333;
}

.sp-clear {
    display: none;
}

.sp-clear.sp-clear-show {
    background-position: center;
}

.sp-clear-enabled .sp-clear {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 84%;
    height: 28px;
}

.sp-alpha,
.sp-alpha-handle,
.sp-clear,
.sp-container,
.sp-container button,
.sp-container.sp-dragging .sp-input,
.sp-dragger,
.sp-preview,
.sp-replacer,
.sp-slider {
    -webkit-user-select: none;
    -moz-user-select: none;
    -o-user-select: none;
    user-select: none;
}

.sp-container.sp-input-disabled .sp-input-container {
    display: none;
}

.sp-container.sp-buttons-disabled .sp-button-container {
    display: none;
}

.sp-container.sp-palette-buttons-disabled .sp-palette-button-container {
    display: none;
}

.sp-palette-only .sp-picker-container {
    display: none;
}

.sp-palette-disabled .sp-palette-container {
    display: none;
}

.sp-initial-disabled .sp-initial {
    display: none;
}

.sp-sat {
    background-image: linear-gradient(to right, #fff, rgba(204, 154, 129, 0));
}

.sp-val {
    background-image: linear-gradient(to top, #000, rgba(204, 154, 129, 0));
}

.sp-1 {
    height: 17%;
}

.sp-2 {
    height: 16%;
}

.sp-3 {
    height: 17%;
}

.sp-4 {
    height: 17%;
}

.sp-5 {
    height: 16%;
}

.sp-6 {
    height: 17%;
}

.sp-hidden {
    display: none !important;
}

.sp-cf:after,
.sp-cf:before {
    content: "";
    display: table;
}

.sp-cf:after {
    clear: both;
}

@media (max-width: 480px) {
    .sp-color {
        right: 40%;
    }

    .sp-hue {
        left: 63%;
    }

    .sp-fill {
        padding-top: 60%;
    }
}

.sp-dragger {
    border-radius: 5px;
    height: 8px;
    width: 8px;
    border: 1px solid #fff;
    background: #fa0202;
    cursor: pointer;
    position: absolute;
    top: 0;
    left: 0;
}

.sp-slider {
    position: absolute;
    top: 0;
    cursor: pointer;
    height: 3px;
    left: -1px;
    right: -1px;
    border: 1px solid #000;
    background: #fff;
    opacity: .8;
}

.sp-input-container {
    float: right;
    width: 100px;
    margin-bottom: 4px;
}

.sp-initial-disabled .sp-input-container {
    width: 100%;
}

.sp-input {
    font-size: 12px !important;
    border: 1px inset;
    padding: 4px 5px;
    margin: 0;
    width: 100%;
    background: 0 0;
    border-radius: 3px;
    color: #e9d9d9;
}

.sp-input:focus {
    border: 1px solid orange;
}

.sp-input.sp-validation-error {
    border: 1px solid red;
    background: #fdd;
}

.sp-palette-container,
.sp-picker-container {
    float: left;
    position: relative;
    padding: 10px;
    padding-bottom: 300px;
    margin-bottom: -290px;
}

.sp-picker-container {
    width: 172px;
    border-left: solid 1px #fff;
}

.sp-palette-container {
    border-right: solid 1px #ccc;
}

.sp-palette-only .sp-palette-container {
    border: 0;
}

.sp-palette .sp-thumb-el {
    display: block;
    position: relative;
    float: left;
    width: 24px;
    height: 15px;
    margin: 3px;
    cursor: pointer;
    border: solid 2px transparent;
}

.sp-palette .sp-thumb-el.sp-thumb-active,
.sp-palette .sp-thumb-el:hover {
    border-color: orange;
}

.sp-thumb-el {
    position: relative;
}

.sp-initial {
    float: left;
    border: solid 1px #333;
}

.sp-initial span {
    width: 30px;
    height: 25px;
    border: none;
    display: block;
    float: left;
    margin: 0;
}

.sp-initial .sp-clear-display {
    background-position: center;
}

.sp-button-container,
.sp-palette-button-container {
    float: right;
}

.sp-replacer {
    margin: 0;
    overflow: hidden;
    cursor: pointer;
    padding: 6px;
    display: inline-block;
    box-shadow: 0 10px 20px rgba(222, 224, 224, 0.158);
    background: transparent;
    color: #FFB86C;
    vertical-align: middle;
}

.sp-replacer.sp-active,
.sp-replacer:hover {
    border: solid 1px #50FA7B;
    border-radius: 10px 0 10px 0;
    color: #50FA7B;
}

.sp-replacer.sp-disabled {
    cursor: default;
    border-color: silver;
    color: silver;
}

.sp-dd {
    padding: 2px 0;
    height: 16px;
    line-height: 16px;
    float: left;
    font-size: 10px;
}

.sp-preview {
    position: relative;
    width: 25px;
    height: 20px;
    border: solid 1px #222;
    margin-right: 5px;
    float: left;
    z-index: 0;
}

.sp-palette {
    max-width: 220px;
}

.sp-palette .sp-thumb-el {
    width: 16px;
    height: 16px;
    margin: 2px 1px;
    border: solid 1px #d0d0d0;
}

.sp-container {
    padding-bottom: 0;
}

.sp-container button {
   background-color: var(--background-color) !important;
    border: 1px solid #ccc;
    border-bottom: 1px solid #bbb;
    border-radius: 3px;
    color: #ffffff;
    font-size: 14px;
    line-height: 1;
    padding: 5px 4px;
    text-align: center;
    text-shadow: 0 1px 0 #eee;
    vertical-align: middle;
}

.sp-container button:hover {
   background-color: var(--background-color) !important;
    color: rgb(255, 0, 0);
    border: 1px solid #bbb;
    border-bottom: 1px solid #999;
    cursor: pointer;
    text-shadow: 0 1px 0 #ddd;
}

.sp-container button:active {
    border: 1px solid #02ffea91;
    border-bottom: 1px solid #1bf32d;
    -webkit-box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee;
    -moz-box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee;
    -ms-box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee;
    -o-box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee;
    box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee;
}

.sp-cancel {
    font-size: 11px;
    color: #d93f3f !important;
    margin: 0;
    padding: 2px;
    margin-right: 5px;
    vertical-align: middle;
    text-decoration: none;
}

.sp-cancel:hover {
    color: #d93f3f !important;
    text-decoration: underline;
}

.sp-palette span.sp-thumb-active,
.sp-palette span:hover {
    border-color: #000;
}

.sp-alpha,
.sp-preview,
.sp-thumb-el {
    position: relative;
    background: transparent;
}

.sp-alpha-inner,
.sp-preview-inner,
.sp-thumb-inner {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

.sp-palette .sp-thumb-inner {
    background-position: 50% 50%;
    background-repeat: no-repeat;
}

.sp-palette .sp-thumb-light.sp-thumb-active .sp-thumb-inner {
    background: transparent;
}

.sp-palette.sp-thumb-dark.sp-thumb-active .sp-thumb-inner {
    background: transparent;
}

.sp-clear-display {
    background-repeat: no-repeat;
    background-position: center;
    background: transparent;
}

.pro-preset {
    transition: opacity 0.2s ease;
}

.opacity-50 {
    opacity: 0.5;
}

.cursor-not-allowed {
    cursor: not-allowed;
}

@media (max-width: 768px) {
    html, body {
        overflow-x: hidden;
        height: 100%;
        background-color: var(--background-color);
        color: var(--text-color);
    }

    body {
        position: fixed;
        width: 100%;
    }

    #output-container {
        max-height: 300px !important;
        background-color: var(--terminal-bg);
        color: var(--terminal-text);
    }
}

@media(max-width:764px) {
    .chat-container {
        width: 100px;
    }
}

.chat-container {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100vh;
    background: var(--modal-bg);
    display: none;
    flex-direction: column;
    z-index: 1000;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 0;
    box-shadow: none;
    color: var(--text-color);
}

.chat-container.show {
    display: flex;
}

.chat-header {
    padding: 1rem;
    background: var(--header-bg);
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--border-color);
    color: var(--text-color);
}

.header-content {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.header-content h3 {
    font-size: 1.1rem;
    color: var(--info-color);
}

.chat-messages {
    flex: 1;
    overflow-y: auto;
    padding: 1rem;
    margin: 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    background-color: var(--modal-bg);
}

.message {
    padding: 1.5rem;
    border-radius: 0.75rem;
    max-width: 100%;
    animation: messageEnter 0.3s ease;
    position: relative;
    line-height: 1.5;
    margin: 0 0 1rem 0;
}

.message.user {
    background: var(--button-bg);
    align-self: flex-end;
}

.message.bot {
    background: var(--input-bg);
    align-self: flex-start;
}

.code-group {
    width: 100%;
    margin: 1rem 0;
    background: var(--terminal-bg);
    border-radius: 0.5rem;
    border: 1px solid var(--border-color);
}

.code-header {
    padding: 0.5rem 1rem;
    background: var(--header-bg);
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--border-color);
}

.code-header span {
    font-family: 'Fira Code', monospace;
    font-size: 0.9rem;
    color: var(--info-color);
}

pre {
    margin: 0;
    padding: 1.5rem;
    overflow-x: auto;
    background-color: var(--terminal-bg);
}

pre code {
    font-family: 'Fira Code', monospace;
    font-size: 1.1rem;
    display: block;
    white-space: pre-wrap;
    color: var(--terminal-text);
}

.chat-input {
    padding: 1.5rem;
    background: var(--header-bg);
    display: flex;
    gap: 0.5rem;
    width: 100%;
    margin: 0;
    border-top: 1px solid var(--border-color);
}

#user-input {
    flex: 1;
    background: var(--input-bg);
    border: 1px solid var(--border-color);
    color: var(--input-text);
    padding: 1.2rem;
    border-radius: 0.5rem;
    resize: none;
    max-height: 150px;
    font-family: 'Fira Code', monospace;
    font-size: 1rem;
    line-height: 1.5;
    min-height: 60px;
}

#user-input:focus {
    outline: 1px solid var(--info-color);
}

.send-btn {
    background: var(--info-color);
    border: none;
    padding: 0 1.25rem;
    border-radius: 0.5rem;
    cursor: pointer;
    color: var(--text-color);
    transition: opacity 0.2s;
    display: flex;
    align-items: center;
}

.send-btn:hover {
    opacity: 0.9;
}

.open-chat-btn {
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    background: var(--info-color);
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    border: none;
    color: var(--text-color);
    cursor: pointer;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
    z-index: 999;
    display: flex;
    align-items: center;
    justify-content: center;
}

@keyframes messageEnter {
    from { opacity: 0; transform: translateY(1rem); }
    to { opacity: 1; transform: translateY(0); }
}

.typing-indicator {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--comment-color);
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    background: var(--input-bg);
    margin-left: 1rem;
}

.typing-dot {
    width: 6px;
    height: 6px;
    background: var(--info-color);
    border-radius: 50%;
    animation: typing 1.4s infinite;
}

@keyframes typing {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-4px); }
}

.switch {
    position: relative;
    display: inline-block;
    width: 40px;
    height: 24px;
}

.switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--border-color);
    transition: .4s;
    border-radius: 34px;
}

.slider:before {
    position: absolute;
    content: "";
    height: 16px;
    width: 16px;
    left: 4px;
    bottom: 4px;
    background-color: var(--text-color);
    transition: .4s;
    border-radius: 50%;
}

input:checked+.slider {
    background-color: var(--info-color);
}

input:checked+.slider:before {
    transform: translateX(16px);
}

.ai-status-enabled {
    color: var(--success-color);
}

.ai-status-disabled {
    color: var(--error-color);
}

.copy-btn {
    background: none;
    border: none;
    color: var(--comment-color);
    cursor: pointer;
    transition: color 0.2s;
    padding: 0.25rem;
}

.copy-btn:hover {
    color: var(--info-color);
}

#ad-modal-desktop,
#ad-modal-mobile {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 9999;
    background: rgba(0, 0, 0, 0.95);
    display: none;
    margin: 0;
    padding: 0;
    overflow: hidden;
    animation: fadeIn 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

#ad-modal-desktop.active,
#ad-modal-mobile.active {
    display: flex;
    justify-content: center;
    align-items: center;
}

#ad-box {
    background: linear-gradient(135deg, var(--header-bg) 0%, var(--background-color) 100%);
    border-radius: 0;
    padding: 0;
    width: 100%;
    height: 100%;
    position: relative;
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.5);
    animation: slideUp 0.5s cubic-bezier(0.22, 1, 0.36, 1);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.ad-content {
    display: flex;
    flex-direction: column;
    gap: 15px;
    color: var(--text-color);
    padding: 25px;
    height: 100%;
    justify-content: space-between;
}

.ad-header {
    text-align: center;
    padding-top: 40px;
}

.ad-content h3 {
    font-size: 1.8rem;
    margin: 0;
    text-align: center;
    color: var(--text-color);
    font-weight: 700;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
    animation: textGlow 2s infinite alternate;
}

.ad-description {
    font-size: 1.1rem;
    opacity: 0.9;
    text-align: center;
    margin: 15px 0;
    color: var(--text-color);
    line-height: 1.6;
}

.ad-container {
    width: 100% !important;
    height: 45vh !important;
    background-color: rgba(45, 45, 45, 0.3);
    border-radius: 0;
    overflow: hidden;
    display: block !important;
    position: relative;
    border: none;
    box-shadow: inset 0 0 30px rgba(0, 0, 0, 0.5);
}

.ad-fallback {
    padding: 20px;
    text-align: center;
    color: var(--comment-color);
    font-size: 1rem;
    line-height: 1.6;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
}

.ad-fallback p:first-child {
    color: var(--error-color);
    font-weight: bold;
    margin-bottom: 15px;
    font-size: 1.2rem;
}

.ads-btn {
    background: linear-gradient(135deg, var(--number-color) 0%, var(--keyword-color) 100%);
    color: var(--text-color);
    border: none;
    padding: 18px 30px;
    border-radius: 50px;
    font-size: 1.1rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
    box-shadow: 0 10px 25px var(--number-color);
    width: 80%;
    margin: 20px auto;
    position: relative;
    overflow: hidden;
    z-index: 1;
}

.ads-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--keyword-color) 0%, var(--number-color) 100%);
    opacity: 0;
    transition: opacity 0.4s ease;
    z-index: -1;
}

.ads-btn:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 30px var(--number-color);
}

.ads-btn:hover::before {
    opacity: 1;
}

#close-ad-desktop,
#close-ad-mobile {
    position: absolute;
    top: 25px;
    right: 25px;
    font-size: 2rem;
    color: var(--text-color);
    background: rgba(255, 255, 255, 0.1);
    border: none;
    cursor: pointer;
    z-index: 10001;
    opacity: 0.8;
    transition: all 0.3s ease;
    line-height: 1;
    padding: 8px;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    backdrop-filter: blur(5px);
}

#close-ad-desktop:hover,
#close-ad-mobile:hover {
    opacity: 1;
    transform: scale(1.1) rotate(90deg);
    background: rgba(255, 255, 255, 0.2);
}

.ad-footer {
    text-align: center;
    padding-bottom: 20px;
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.6);
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideUp {
    from { transform: translateY(20px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

@keyframes textGlow {
    from { text-shadow: 0 0 10px rgba(255, 255, 255, 0.3); }
    to { text-shadow: 0 0 20px rgba(255, 255, 255, 0.6); }
}

@keyframes pulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.05); }
    100% { transform: scale(1); }
}

@keyframes gradient-xy {
    0%, 100% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
}

.animate-gradient-xy {
    background-size: 300% 300%;
    animation: gradient-xy 6s ease infinite;
}

@media (max-width: 768px) {
    #ad-box {
        width: 100%;
        height: 100%;
        border-radius: 0;
        animation: mobileSlideIn 0.5s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .ad-content {
        padding: 20px;
    }

    .ad-content h3 {
        font-size: 2rem;
        margin-bottom: 10px;
    }

    .ad-description {
        font-size: 1.2rem;
        margin: 20px 0;
    }

    .ad-container {
        height: 50vh !important;
        margin: 20px 0;
    }

    .ads-btn {
        padding: 20px;
        font-size: 1.2rem;
        width: 90%;
        margin: 30px auto;
        animation: pulse 2s infinite;
    }

    #close-ad-desktop,
    #close-ad-mobile {
        top: 20px;
        right: 20px;
        font-size: 2rem;
        width: 45px;
        height: 45px;
    }

    @keyframes mobileSlideIn {
        from { transform: translateY(100%); }
        to { transform: translateY(0); }
    }
}

.particles {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    overflow: hidden;
}

.particle {
    position: absolute;
    background: rgba(255, 255, 255, 0.5);
    border-radius: 50%;
    animation: float linear infinite;
}

@keyframes float {
    to {
        transform: translateY(-1000px) rotate(960deg);
    }
}

#output-container {
    background-color: var(--terminal-bg);
    color: var(--terminal-text);
    font-family: 'Consolas', 'Courier New', monospace;
    font-size: 14px;
    padding: 12px;
    border-radius: 4px;
    width: 100%;
    min-height: 180px !important;
    overflow-y: auto;
    white-space: pre-wrap;
    box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.5);
    position: relative;
    line-height: 1.5;
}

#output {
    margin: 0;
    padding: 0;
    counter-reset: line;
}

.output-line {
    display: flex;
    margin-bottom: 4px;
}

.output-line:before {
    content: counter(line);
    counter-increment: line;
    display: inline-block;
    width: 40px;
    text-align: right;
    padding-right: 10px;
    color: var(--success-color);
    user-select: none;
}

.output-stdout {
    color: var(--terminal-text);
}

.output-stderr {
    color: var(--error-color);
}

.output-prompt {
    color: var(--info-color);
}

.output-info {
    color: var(--info-color);
}

.output-error {
    color: var(--error-color);
}

.output-success {
    color: var(--success-color);
}

.output-divider {
    height: 1px;
    background: var(--border-color);
    margin: 15px 0;
    position: relative;
}

.output-divider:before {
    content: '▶';
    position: absolute;
    left: 20px;
    top: -10px;
    background: var(--terminal-bg);
    color: var(--success-color);
    padding: 0 5px;
    font-size: 12px;
}

#output-container::-webkit-scrollbar {
    width: 10px;
}

#output-container::-webkit-scrollbar-track {
    background: var(--border-color);
}

#output-container::-webkit-scrollbar-thumb {
    background: var(--button-hover);
    border-radius: 5px;
}

#output-container::-webkit-scrollbar-thumb:hover {
    background: var(--button-active);
}

.execution-indicator {
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 12px;
    color: var(--info-color);
    display: flex;
    align-items: center;
}

.execution-indicator .dot {
    width: 8px;
    height: 8px;
    background: var(--info-color);
    border-radius: 50%;
    margin-right: 5px;
    animation: pulse 1.5s infinite;
}

@keyframes pulse {
    0% { opacity: 0.3; }
    50% { opacity: 1; }
    100% { opacity: 0.3; }
}

.play-icon {
    color: var(--success-color);
}

.modal-seguimiento {
    overflow-y: auto;
    width: 100%;
    height: 500px;
    position: relative;
    z-index: 999 !important;
    background-color: var(--modal-bg);
    color: var(--text-color);
}