/* 
  Sublime Text Swamp Editor Theme - style.css
  Interactive Resume/Portfolio CSS Stylesheet (Rich Media & Text Wrap Enabled Version)
*/

/* ----------------------------------------------------
   1. VARIABLES & THEMES SYSTEM
------------------------------------------------------- */
:root {
    /* Fonts */
    --font-ui: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    --font-code: 'Fira Code', 'JetBrains Mono', 'Courier New', Courier, monospace;
}

/* 1.1. Swamp Theme (Bolo-Sublime, Default) */
.theme-swamp {
    --bg-window: #131815;
    --bg-sidebar: #0e1210;
    --bg-editor: #151c18;
    --bg-terminal: #0b0e0c;
    --bg-tabs: #0e1210;
    --bg-tab-active: #151c18;
    --bg-tab-hover: #1b241f;
    --bg-line-active: #1a241f;
    --bg-statusbar: #0a0d0b;

    --border-color: #212c25;
    --text-ui: #b0c4b8;
    --text-ui-muted: #647b6e;

    /* Syntax Highlighting Colors */
    --accent-orange: #ff922b;
    --syntax-key: #56b6c2; /* Ice Blue for keys */
    --syntax-string: #e5c07b; /* Golden Amber/Orange strings */
    --syntax-number: #ae81ff; /* Soft purple */
    --syntax-boolean: #f07178; /* Soft red */
    --syntax-comment: #5c6370; /* Muted gray-green */
    --syntax-bracket: #abb2bf; /* Plain text color */
    --syntax-link: #ff922b; /* Orange clickable links */

    --shadow-color: rgba(0, 0, 0, 0.5);
    --scroll-thumb: #2d3b32;
    --scroll-thumb-hover: #ff922b;

    /* Photo Frame Glassmorphism */
    --bg-photo-card: rgba(21, 28, 24, 0.85);
}

/* 1.2. Monokai Theme (Classic Sublime) */
.theme-monokai {
    --bg-window: #1e1e1e;
    --bg-sidebar: #181818;
    --bg-editor: #272822;
    --bg-terminal: #151515;
    --bg-tabs: #181818;
    --bg-tab-active: #272822;
    --bg-tab-hover: #34352f;
    --bg-line-active: #3e3d32;
    --bg-statusbar: #151515;

    --border-color: #3e3e3e;
    --text-ui: #cfcfc2;
    --text-ui-muted: #75715e;

    /* Syntax Highlighting Colors */
    --accent-orange: #fd971f;
    --syntax-key: #f92672; /* Monokai Pink for keys */
    --syntax-string: #e6db74; /* Monokai Yellow strings */
    --syntax-number: #ae81ff; /* Purple numbers */
    --syntax-boolean: #66d9ef; /* Cyan booleans */
    --syntax-comment: #75715e; /* Olive-gray comments */
    --syntax-bracket: #f8f8f2; /* Plain text color */
    --syntax-link: #a6e22e; /* Monokai Green links */

    --shadow-color: rgba(0, 0, 0, 0.6);
    --scroll-thumb: #49483e;
    --scroll-thumb-hover: #fd971f;

    --bg-photo-card: rgba(39, 40, 34, 0.85);
}

/* 1.3. Matrix (Hacker green) Theme */
.theme-matrix {
    --bg-window: #030503;
    --bg-sidebar: #050a06;
    --bg-editor: #000c02;
    --bg-terminal: #000501;
    --bg-tabs: #050a06;
    --bg-tab-active: #000c02;
    --bg-tab-hover: #07150a;
    --bg-line-active: #071a0b;
    --bg-statusbar: #020603;

    --border-color: #0d3a18;
    --text-ui: #39ff14;
    --text-ui-muted: #1f8010;

    /* Syntax Highlighting Colors */
    --accent-orange: #39ff14; /* Green is the new orange here */
    --syntax-key: #ffffff; /* Pure white keys */
    --syntax-string: #39ff14; /* Neon Green strings */
    --syntax-number: #82e0aa; /* Pale Green numbers */
    --syntax-boolean: #28b463; /* Deep Green booleans */
    --syntax-comment: #196f3d; /* Dark Green comments */
    --syntax-bracket: #52be80; /* Medium Green */
    --syntax-link: #00ff66; /* Electric green */

    --shadow-color: rgba(0, 255, 20, 0.05);
    --scroll-thumb: #0d3a18;
    --scroll-thumb-hover: #39ff14;

    --bg-photo-card: rgba(0, 12, 2, 0.85);
}

/* 1.4. Cyber-Vapor Theme */
.theme-cyber {
    --bg-window: #120e16;
    --bg-sidebar: #17111d;
    --bg-editor: #1c1526;
    --bg-terminal: #0d0a0f;
    --bg-tabs: #17111d;
    --bg-tab-active: #1c1526;
    --bg-tab-hover: #261d33;
    --bg-line-active: #2c203e;
    --bg-statusbar: #0c080f;

    --border-color: #3b2d4b;
    --text-ui: #e2c5f5;
    --text-ui-muted: #7d658c;

    /* Syntax Highlighting Colors */
    --accent-orange: #ff007f; /* Neon Pink */
    --syntax-key: #00f0ff; /* Cyan keys */
    --syntax-string: #ff007f; /* Neon Pink strings */
    --syntax-number: #bd93f9; /* Light Purple numbers */
    --syntax-boolean: #f1fa8c; /* Pastel Yellow booleans */
    --syntax-comment: #6272a4; /* Cool Gray comments */
    --syntax-bracket: #f8f8f2; /* White */
    --syntax-link: #00ff66; /* Cyber green links */

    --shadow-color: rgba(255, 0, 127, 0.1);
    --scroll-thumb: #3b2d4b;
    --scroll-thumb-hover: #ff007f;

    --bg-photo-card: rgba(28, 21, 38, 0.85);
}

/* ----------------------------------------------------
   2. GLOBAL STYLES & RESET
------------------------------------------------------- */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--font-ui);
    background-color: #0b0e0c; /* Deep base under window */
    color: var(--text-ui);
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    padding: 10px;
    transition: background-color 0.4s ease;
}

/* Custom Scrollbars */
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

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

::-webkit-scrollbar-thumb {
    background: var(--scroll-thumb);
    border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--scroll-thumb-hover);
}

/* ----------------------------------------------------
   3. SUBSTANTIAL WINDOW CONTAINER (Sublime Window)
------------------------------------------------------- */
.editor-window {
    width: 100%;
    max-width: 1400px;
    height: calc(100vh - 20px);
    background-color: var(--bg-window);
    border-radius: 8px;
    box-shadow: 0 20px 50px var(--shadow-color);
    border: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* 3.1. Title Bar */
.title-bar {
    height: 40px;
    background-color: var(--bg-sidebar);
    display: grid;
    grid-template-columns: 80px 1fr 80px;
    align-items: center;
    padding: 0 15px;
    border-bottom: 1px solid var(--border-color);
    user-select: none;
}

.window-controls {
    display: flex;
    gap: 8px;
}

.control {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    cursor: pointer;
    display: inline-block;
    position: relative;
}

.control.close {
    background-color: #ff5f56;
}

.control.minimize {
    background-color: #ffbd2e;
}

.control.maximize {
    background-color: #27c93f;
}

/* Window and Modal controls: show icons on hover */
.control::after,
.modal-dot::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: none;
}

.control.close:hover::after,
.window-controls:hover .control.close::after,
.modal-dot.red:hover::after,
.about-modal-header:hover .modal-dot.red::after {
    content: '×';
    font-family: -apple-system, BlinkMacSystemFont, Arial, sans-serif;
    font-size: 10px;
    font-weight: 600;
    color: rgba(0, 0, 0, 0.7);
    transform: translate(-50%, -52%);
    line-height: 1;
    display: block;
}

.control.minimize:hover::after,
.window-controls:hover .control.minimize::after,
.modal-dot.yellow:hover::after,
.about-modal-header:hover .modal-dot.yellow::after {
    content: '–';
    font-family: -apple-system, BlinkMacSystemFont, Arial, sans-serif;
    font-size: 10px;
    font-weight: 600;
    color: rgba(0, 0, 0, 0.7);
    transform: translate(-50%, -55%);
    line-height: 1;
    display: block;
}

.control.maximize:hover::after,
.window-controls:hover .control.maximize::after,
.modal-dot.green:hover::after,
.about-modal-header:hover .modal-dot.green::after {
    content: '⤢';
    font-family: -apple-system, BlinkMacSystemFont, Arial, sans-serif;
    font-size: 9px;
    font-weight: 500;
    color: rgba(0, 0, 0, 0.7);
    transform: translate(-50%, -50%);
    line-height: 1;
    display: block;
}

.window-title {
    text-align: center;
    font-size: 13px;
    color: var(--text-ui-muted);
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
}

.active-tab-icon {
    color: var(--accent-orange);
}

.window-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

.window-actions button {
    background: transparent;
    border: none;
    color: var(--text-ui-muted);
    font-size: 14px;
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 4px;
    transition: all 0.2s ease;
}

.window-actions button:hover {
    color: var(--accent-orange);
    background-color: var(--bg-tab-hover);
}

#mobileMenuBtn {
    display: none; /* Desktop hidden, active on mobile */
}

/* 3.2. Menu Bar */
.menu-bar {
    height: 25px;
    background-color: var(--bg-sidebar);
    display: flex;
    gap: 15px;
    padding: 0 15px;
    align-items: center;
    font-size: 12px;
    border-bottom: 1px solid var(--border-color);
    user-select: none;
    overflow: visible;
    white-space: nowrap;
}

.menu-item {
    color: var(--text-ui-muted);
    cursor: pointer;
    padding: 2px 5px;
    border-radius: 3px;
    transition: all 0.2s ease;
}

.menu-item:hover {
    color: var(--accent-orange);
    background-color: var(--bg-tab-hover);
}

/* ----------------------------------------------------
   4. LAYOUT: SIDEBAR AND EDITOR PANEL
------------------------------------------------------- */
.main-container {
    flex: 1;
    display: flex;
    position: relative;
    overflow: hidden;
    height: calc(100% - 65px); /* Minus header bars */
}

/* 4.1. Sidebar Folder Explorer */
.sidebar {
    width: 240px;
    min-width: 200px;
    background-color: var(--bg-sidebar);
    border-right: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    user-select: none;
    z-index: 10;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar-header {
    padding: 12px 16px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1px;
    color: var(--text-ui-muted);
}

.folder-tree {
    flex: 1;
    overflow-y: auto;
    padding: 0 8px;
}

.tree-item {
    display: flex;
    align-items: center;
    padding: 6px 8px;
    font-size: 13px;
    border-radius: 4px;
    cursor: pointer;
    color: var(--text-ui);
    gap: 6px;
    transition: background-color 0.2s ease;
}

.tree-item:hover {
    background-color: var(--bg-tab-hover);
}

.tree-item.active {
    background-color: var(--bg-tab-hover);
    color: var(--accent-orange);
}

.tree-item .arrow {
    width: 14px;
    display: flex;
    justify-content: center;
    font-size: 10px;
    color: var(--text-ui-muted);
}

.tree-item .arrow i {
    transition: transform 0.2s ease-in-out;
}

.tree-item.folder:not(.expanded) .arrow i {
    transform: rotate(-90deg);
}

.tree-item .icon {
    font-size: 14px;
    color: var(--text-ui-muted);
}

.tree-item.active .icon {
    color: var(--accent-orange);
}

.tree-item.file {
    margin-left: 12px;
}

.tree-children {
    display: flex;
    flex-direction: column;
    gap: 2px;
    max-height: 500px;
    opacity: 1;
    overflow: hidden;
    transition: max-height 0.25s ease-in-out, opacity 0.25s ease-in-out;
}

.tree-item.folder:not(.expanded) + .tree-children {
    max-height: 0;
    opacity: 0;
    pointer-events: none;
}

.json-icon {
    color: #e5c07b !important;
}

.json-icon-svg {
    width: 13px;
    height: 13px;
    stroke: currentColor;
    stroke-width: 2.5;
    fill: none;
    vertical-align: middle;
    display: inline-block;
    transform: translate3d(0, 0, 0);
    backface-visibility: hidden;
}

.font-code-icon {
    font-family: var(--font-code) !important;
    font-weight: 700;
    font-size: 13px !important;
    display: inline-block;
    width: 14px;
    height: 14px;
    line-height: 14px;
    text-align: center;
    vertical-align: middle;
    user-select: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    transform: translate3d(0, 0, 0);
    backface-visibility: hidden;
}


.sh-icon {
    color: #49b3ff !important;
}

/* 4.1.1. Sidebar Footer Author Card */
.sidebar-footer {
    padding: 12px;
    border-top: 1px solid var(--border-color);
    background-color: rgba(0, 0, 0, 0.15);
}

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

.avatar-glow {
    padding: 2px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-orange), #ff4500);
    box-shadow: 0 0 10px rgba(255, 146, 43, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
}

.avatar-container {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    overflow: hidden;
    background-color: var(--bg-editor);
    display: flex;
    align-items: center;
    justify-content: center;
}

.avatar-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    pointer-events: none;
    user-select: none;
    -webkit-user-drag: none;
}


.author-info {
    display: flex;
    flex-direction: column;
}

.author-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-ui);
}

.author-status {
    font-size: 11px;
    color: var(--text-ui-muted);
    display: flex;
    align-items: center;
    gap: 4px;
}

.status-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
}

.status-dot.online {
    background-color: #2ec945;
    box-shadow: 0 0 6px #2ec945;
    animation: glowPulse 2s infinite alternate;
}

@keyframes glowPulse {
    0% {
        opacity: 0.6;
        box-shadow: 0 0 2px #2ec945;
    }
    100% {
        opacity: 1;
        box-shadow: 0 0 8px #2ec945;
    }
}

/* ----------------------------------------------------
   5. EDITOR WORKSPACE AND CODE PRESENTATION
------------------------------------------------------- */
.editor-workspace {
    flex: 1;
    display: flex;
    flex-direction: column;
    background-color: var(--bg-editor);
    overflow: hidden;
    height: 100%;
    position: relative;
}

/* 5.1. Tabs Bar */
.tabs-container {
    height: 38px;
    background-color: var(--bg-tabs);
    display: flex;
    border-bottom: 1px solid var(--border-color);
    align-items: flex-end;
    user-select: none;
    padding-left: 5px;
    justify-content: space-between;
}

.tabs-list {
    display: flex;
    align-items: flex-end;
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    -ms-overflow-style: none; /* IE and Edge */
    scrollbar-width: none; /* Firefox */
}

.tabs-list::-webkit-scrollbar {
    display: none; /* Hide scrollbar for Chrome, Safari and Opera */
}

.tab {
    display: flex;
    align-items: center;
    height: 32px;
    padding: 0 14px;
    background-color: var(--bg-tabs);
    border: 1px solid var(--border-color);
    border-bottom: none;
    border-radius: 5px 5px 0 0;
    margin-right: 3px;
    font-size: 13px;
    color: var(--text-ui-muted);
    cursor: pointer;
    gap: 8px;
    position: relative;
    transition: background-color 0.2s ease;
}

.tab:hover {
    background-color: var(--bg-tab-hover);
    color: var(--text-ui);
}

.tab.active {
    background-color: var(--bg-tab-active);
    color: var(--text-ui);
    border-bottom: 1px solid var(--bg-tab-active);
    margin-bottom: -1px;
    z-index: 2;
}

.tab.dragging {
    opacity: 0.95;
    background-color: var(--bg-tab-active) !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4);
    z-index: 1000 !important;
    border-color: var(--accent-orange) !important;
    cursor: grabbing;
}

.tab.active::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background-color: var(--accent-orange);
    border-radius: 5px 5px 0 0;
}

.tab-close {
    font-size: 10px;
    width: 14px;
    height: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 20%;
    color: transparent;
    transition: all 0.2s ease;
}

.tab:hover .tab-close, .tab.active .tab-close {
    color: var(--text-ui-muted);
}

.tab-close:hover {
    background-color: var(--bg-tab-hover);
    color: var(--accent-orange) !important;
}

.editor-actions {
    display: flex;
    gap: 6px;
    align-self: center;
    margin-right: 12px;
}

.editor-actions button {
    background-color: var(--bg-tab-hover);
    border: 1px solid var(--border-color);
    color: var(--text-ui);
    font-size: 11px;
    padding: 4px 10px;
    border-radius: 4px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 4px;
    font-family: var(--font-ui);
    transition: all 0.2s ease;
}

.editor-actions button:hover {
    background-color: var(--accent-orange);
    color: #000;
    border-color: var(--accent-orange);
}

#runScriptBtn {
    border-color: #27c93f;
    color: #2ec945;
}

#runScriptBtn:hover {
    background-color: #27c93f;
    color: #000;
    border-color: #27c93f;
}

#runScriptBtn:hover i {
    color: #000 !important;
}

#downloadPdfBtn {
    border-color: #ff5f56;
    color: #ff5f56;
}

#downloadPdfBtn:hover {
    background-color: #ff5f56;
    color: #000;
    border-color: #ff5f56;
}

#downloadPdfBtn:hover i {
    color: #000 !important;
}

.run-trigger {
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 12px;
    height: 21px;
    transition: transform 0.15s ease;
}

.run-trigger:hover {
    transform: scale(1.2);
}

/* 5.2. Code Area Wrapper (Scrolls the editor) */
.code-area-wrapper {
    flex: 1;
    overflow: auto;
    position: relative;
}

.code-editor {
    display: flex;
    flex-direction: column;
    font-family: var(--font-code);
    font-size: 14px;
    line-height: 1.5;
    min-height: 100%;
    padding: 15px 0;
    width: 100%;
    transition: padding-right 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* On desktop, pad the right side of the editor when the preview card is visible to prevent text overlap */
@media (min-width: 769px) {
    .floating-photo-card.visible ~ .code-editor {
        padding-right: 360px;
    }
}


/* Unified Code Row Layout (GUTTER & CODE IN ONE ROW) */
.code-line {
    display: flex;
    align-items: stretch; /* Critical for wrapping: aligns gutter and code cells in height */
    width: 100%;
    min-height: 21px;
    transition: background-color 0.15s ease;
    position: relative;
}

.code-line.active {
    background-color: var(--bg-line-active);
}

/* Line Number Gutter */
.line-number-gutter {
    width: 60px;
    min-width: 60px;
    text-align: right;
    padding-right: 12px;
    color: var(--text-ui-muted);
    user-select: none;
    border-right: 1px solid var(--border-color);
    opacity: 0.7;
    display: flex;
    justify-content: flex-end;
    align-items: flex-start; /* Start numbers at the top of wrapped lines */
    gap: 4px;
}

.line-num-text {
    font-size: 13px;
    line-height: 21px;
}

/* Line Fold Buttons */
.fold-trigger {
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 12px;
    height: 21px; /* Align with line text height */
    font-size: 10px;
    color: var(--text-ui-muted);
    transition: color 0.15s ease;
}

.fold-trigger:hover {
    color: var(--accent-orange);
}

.fold-spacer {
    width: 12px;
    height: 21px;
}

/* Code Content (WITH TEXT WRAPPING!) */
.line-code-content {
    flex: 1;
    padding-left: 15px;
    white-space: pre-wrap; /* ENABLES TEXT WRAPPING! */
    word-break: break-word; /* Wraps nicely at word breaks */
    color: var(--syntax-bracket);
    line-height: 21px;
    overflow: hidden; /* Hide horizontal scrollbar, text wraps instead */
}

/* Prevent horizontal wrapping specifically for Shell Script files to keep character alignment intact */
.code-editor.lang-sh .line-code-content {
    white-space: pre !important;
    word-break: normal !important;
    overflow-x: visible !important;
}

/* ----------------------------------------------------
   5.3. FLOATING MEDIA CARD (Developer Avatar Image Preview)
------------------------------------------------------- */
.floating-photo-card {
    position: absolute;
    right: 35px;
    top: 25px;
    width: 300px;
    background-color: var(--bg-photo-card);
    backdrop-filter: blur(10px);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5), 0 0 0 1px var(--border-color);
    z-index: 25;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    user-select: none;

    /* Animations */
    opacity: 0;
    transform: translateY(-10px);
    visibility: hidden;
    transition: opacity 0.4s cubic-bezier(0.25, 0.8, 0.25, 1),
    transform 0.4s cubic-bezier(0.25, 0.8, 0.25, 1),
    visibility 0.4s;
}

.floating-photo-card.visible {
    opacity: 1;
    transform: translateY(0);
    visibility: visible;
}

.photo-header {
    height: 28px;
    background-color: var(--bg-tabs);
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    padding: 0 10px;
    gap: 8px;
}

.photo-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.photo-dot.green {
    background-color: #27c93f;
    box-shadow: 0 0 4px #27c93f;
}

.photo-title {
    font-family: var(--font-code);
    font-size: 11px;
    color: var(--text-ui-muted);
}

.photo-body {
    padding: 8px;
    background-color: rgba(0, 0, 0, 0.2);
    display: flex;
    justify-content: center;
    align-items: center;
}

.photo-preview-image {
    width: 284px;
    height: 284px;
    border-radius: 4px;
    border: 1px solid var(--border-color);
    box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.5);
    object-fit: cover;
    transition: transform 0.3s ease;
    pointer-events: none;
    user-select: none;
    -webkit-user-drag: none;
}

.photo-body:hover .photo-preview-image {
    transform: scale(1.03);
}


/* ----------------------------------------------------
   6. SYNTAX HIGHLIGHTING CLASSES
------------------------------------------------------- */
.j-key {
    color: var(--syntax-key);
    font-weight: 500;
}

.j-string {
    color: var(--syntax-string);
}

.j-number {
    color: var(--syntax-number);
}

.j-boolean {
    color: var(--syntax-boolean);
    font-weight: 600;
}

.j-comment {
    color: var(--syntax-comment);
    font-style: italic;
}

.j-bracket {
    color: var(--syntax-bracket);
}

/* Clickable Links inside JSON & Editor */
.j-link,
.j-link:link,
.j-link:visited,
.j-link:active {
    color: var(--syntax-link) !important;
    text-decoration: none;
    border-bottom: 1px dashed transparent;
    transition: border-color 0.2s ease, text-shadow 0.2s ease;
    cursor: pointer;
}

.j-link:hover {
    border-bottom-color: var(--syntax-link) !important;
    text-shadow: 0 0 5px rgba(255, 146, 43, 0.4);
}

/* Folded code replacement block */
.folded-indicator {
    display: inline-block;
    background-color: var(--bg-tab-hover);
    border: 1px solid var(--border-color);
    color: var(--accent-orange);
    font-size: 11px;
    padding: 0 6px;
    border-radius: 4px;
    margin: 0 4px;
    cursor: pointer;
    font-weight: 700;
    user-select: none;
}

.folded-indicator:hover {
    background-color: var(--accent-orange);
    color: #000;
}

/* ----------------------------------------------------
   7. INTERACTIVE TERMINAL
------------------------------------------------------- */
/* Terminal Panel */
.terminal-panel {
    height: 200px;
    min-height: 120px;
    max-height: 450px;
    background-color: var(--bg-terminal);
    border-top: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: height 0.2s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* Folded terminal state - leaves header visible */
.terminal-panel.collapsed {
    height: 38px !important;
    min-height: 38px !important;
}

.terminal-panel.collapsed .terminal-body {
    display: none !important;
}

/* Completely hidden terminal state */
.terminal-panel.hidden {
    height: 0px !important;
    min-height: 0px !important;
    border-top: none !important;
}

.terminal-panel.hidden .terminal-body {
    display: none !important;
}

.terminal-header {
    height: 38px;
    background-color: var(--bg-tabs);
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 15px;
    user-select: none;
    cursor: pointer;
}

.terminal-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-ui-muted);
    display: flex;
    align-items: center;
    gap: 8px;
}

.terminal-title i {
    color: var(--accent-orange);
}

.terminal-controls {
    display: flex;
    gap: 10px;
}

.terminal-controls button {
    background: transparent;
    border: none;
    color: var(--text-ui-muted);
    cursor: pointer;
    font-size: 13px;
    padding: 4px 6px;
    border-radius: 4px;
    transition: all 0.2s ease;
}

.terminal-controls button:hover {
    color: var(--accent-orange);
    background-color: var(--bg-tab-hover);
}

.terminal-body {
    flex: 1;
    padding: 12px 15px;
    font-family: var(--font-code);
    font-size: 13px;
    line-height: 1.6;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
}

.terminal-output {
    margin-bottom: 10px;
    white-space: pre-wrap;
    color: var(--text-ui);
}

.system-message {
    color: var(--text-ui-muted);
}

.cmd-highlight {
    color: var(--accent-orange);
    font-weight: 600;
}

.terminal-input-line {
    display: flex;
    align-items: center;
    gap: 10px;
}

.terminal-prompt {
    color: var(--accent-orange);
    font-weight: 700;
    white-space: nowrap;
}

#terminalInput {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: #fff;
    font-family: var(--font-code);
    font-size: 13px;
    caret-color: var(--accent-orange);
    width: 100%;
}

/* Neofetch Styles */
.neofetch-container {
    display: flex;
    gap: 25px;
    margin: 10px 0;
    flex-wrap: wrap;
}

.neofetch-logo {
    color: var(--accent-orange);
    font-weight: 700;
    line-height: 1.2;
}

.neofetch-info {
    display: flex;
    flex-direction: column;
}

.neofetch-header {
    color: var(--syntax-key);
    font-weight: 700;
    margin-bottom: 5px;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 2px;
}

.neofetch-item {
    margin: 2px 0;
}

.neofetch-label {
    color: var(--accent-orange);
    font-weight: 600;
}

/* Resize Gutter */
.resize-handle {
    height: 4px;
    background-color: transparent;
    cursor: row-resize;
    width: 100%;
    transition: background-color 0.2s ease;
    z-index: 5;
}

.resize-handle:hover, .resize-handle:active {
    background-color: var(--accent-orange);
}

/* ----------------------------------------------------
   9. STATUS BAR (Footer)
------------------------------------------------------- */
.status-bar {
    height: 25px;
    background-color: var(--bg-statusbar);
    border-top: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 15px;
    font-size: 11px;
    color: var(--text-ui-muted);
    user-select: none;
    z-index: 10;
}

.status-left, .status-right {
    display: flex;
    gap: 15px;
    align-items: center;
}

.status-item {
    display: flex;
    align-items: center;
    gap: 5px;
}

.status-item i {
    color: var(--accent-orange);
}

/* ----------------------------------------------------
   10. MOBILE STYLES & RESPONSIVENESS
------------------------------------------------------- */
@media (max-width: 768px) {
    body {
        padding: 0;
    }

    .editor-window {
        height: 100vh;
        border-radius: 0;
        border: none;
    }

    .title-bar {
        grid-template-columns: 50px 1fr 60px;
        padding: 0 10px;
    }

    #mobileMenuBtn {
        display: inline-block;
    }

    .font-desktop-only {
        display: none !important;
    }

    /* Sidebar responsive collapse */
    .sidebar {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        transform: translateX(-100%);
        width: 250px;
        z-index: 100;
        box-shadow: 10px 0 30px rgba(0, 0, 0, 0.5);
    }

    .sidebar.mobile-visible {
        transform: translateX(0);
    }

    .sidebar-overlay {
        display: none;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background-color: rgba(0, 0, 0, 0.6);
        z-index: 90;
        backdrop-filter: blur(2px);
    }

    .sidebar-overlay.active {
        display: block;
    }

    /* Adjust workspace */
    .editor-workspace {
        width: 100%;
    }

    .tabs-container {
        padding-left: 0;
    }

    .tab {
        padding: 0 10px;
        font-size: 11px;
    }

    .editor-actions {
        margin-right: 5px;
    }

    .editor-actions button {
        padding: 2px 6px;
        font-size: 10px;
    }

    .code-editor {
        font-size: 12px;
    }

    .line-number-gutter {
        width: 45px;
        min-width: 45px;
        padding-right: 6px;
    }

    .line-code-content {
        padding-left: 8px;
    }

    /* Hide floating photo card on mobile to prevent blocking JSON code view */
    .floating-photo-card {
        display: none !important;
    }
}

/* ----------------------------------------------------
   11. MAXIMIZE WINDOW / FULL-SCREEN STYLES
------------------------------------------------------- */
body.window-maximized {
    padding: 0 !important;
}

.editor-window.maximized {
    max-width: 100% !important;
    height: 100vh !important;
    border-radius: 0 !important;
    border: none !important;
}

/* ----------------------------------------------------
   12. INTERACTIVE DROPDOWNS & EMPTY STATE UPGRADES
------------------------------------------------------- */

/* Dropdown Menu Style - Sublime Dark */
.menu-item-wrapper {
    position: relative;
    display: inline-block;
    height: 100%;
}

.dropdown-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background-color: var(--bg-sidebar);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
    min-width: 220px;
    z-index: 1000;
    padding: 4px 0;
    animation: menuFadeIn 0.12s cubic-bezier(0.25, 0.8, 0.25, 1);
}

@keyframes menuFadeIn {
    from {
        opacity: 0;
        transform: translateY(-5px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.dropdown-menu.show {
    display: block;
}

.dropdown-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 15px;
    font-size: 12px;
    color: var(--text-ui-muted);
    cursor: pointer;
    transition: background-color 0.15s, color 0.15s;
    white-space: nowrap;
}

.dropdown-item:hover {
    background-color: var(--bg-line-active);
    color: var(--text-ui);
}

.dropdown-item.disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.dropdown-item.disabled:hover {
    background-color: transparent !important;
    color: var(--text-ui-muted) !important;
}

.dropdown-item .shortcut {
    font-size: 11px;
    color: var(--text-ui-muted);
    opacity: 0.6;
    padding-left: 20px;
}

.dropdown-divider {
    height: 1px;
    background-color: var(--border-color);
    margin: 4px 0;
}

/* Empty Editor State styling */
.empty-editor-placeholder {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--text-ui-muted);
    padding: 40px 20px;
    background-color: var(--bg-editor);
    text-align: center;
    user-select: none;
    animation: fadeIn 0.3s ease-out;
}

.empty-logo {
    font-size: 64px;
    color: var(--accent-orange);
    margin-bottom: 20px;
    opacity: 0.6;
    filter: drop-shadow(0 0 15px rgba(39, 201, 63, 0.2));
    animation: pulseGlow 3s infinite alternate;
}

@keyframes pulseGlow {
    0% {
        transform: scale(1);
        filter: drop-shadow(0 0 10px rgba(39, 201, 63, 0.15));
    }
    100% {
        transform: scale(1.05);
        filter: drop-shadow(0 0 25px rgba(39, 201, 63, 0.35));
    }
}

.empty-editor-placeholder h2 {
    font-family: var(--font-code);
    font-size: 20px;
    font-weight: 500;
    color: var(--text-ui);
    margin-bottom: 5px;
}

.empty-editor-placeholder .subtitle {
    font-size: 13px;
    margin-bottom: 30px;
    opacity: 0.7;
}

.empty-shortcuts {
    max-width: 320px;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.shortcut-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    padding: 8px 12px;
    background-color: var(--bg-sidebar);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s, transform 0.1s ease;
    user-select: none;
}

.shortcut-item:hover {
    background-color: var(--bg-line-active);
    transform: translateY(-1px);
    border-color: var(--accent-orange);
}

.shortcut-item:active {
    transform: translateY(1px) scale(0.98);
}

.shortcut-item .label {
    opacity: 0.8;
}

.shortcut-item .value {
    font-weight: 500;
    color: var(--text-ui);
}

.shortcut-item .value .cmd-highlight {
    background-color: var(--bg-editor);
    padding: 2px 6px;
    border-radius: 3px;
    border: 1px solid var(--border-color);
    font-family: var(--font-code);
    color: var(--accent-orange);
}

/* Status Bar Interactive Items */
.status-item.clickable {
    cursor: pointer;
    transition: color 0.15s, background-color 0.15s;
    padding: 2px 8px;
    margin: -2px -4px;
    border-radius: 3px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.status-item.clickable:hover {
    background-color: var(--bg-line-active);
    color: var(--text-ui);
}

/* ----------------------------------------------------
   13. macOS STYLE ABOUT MODAL
------------------------------------------------------- */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(5px);
    display: none; /* Hidden by default */
    align-items: center;
    justify-content: center;
    z-index: 9999;
    animation: fadeIn 0.25s ease-out;
}

.about-modal-card {
    background-color: var(--bg-sidebar);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
    width: 320px;
    overflow: hidden;
    animation: scaleUp 0.25s cubic-bezier(0.25, 0.8, 0.25, 1);
}

@keyframes scaleUp {
    from {
        transform: scale(0.9);
        opacity: 0;
    }
    to {
        transform: scale(1);
        opacity: 1;
    }
}

.about-modal-header {
    height: 30px;
    background-color: var(--bg-tabs);
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    padding: 0 12px;
    gap: 8px;
}

.modal-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    cursor: pointer;
    position: relative;
    display: inline-block;
}

.modal-dot.red {
    background-color: #ff5f56;
}

.modal-dot.yellow {
    background-color: #ffbd2e;
}

.modal-dot.green {
    background-color: #27c93f;
}

.control.disabled,
.modal-dot.disabled {
    background-color: #4a4a4a !important;
    cursor: default !important;
    pointer-events: none !important;
}

/* Ensure disabled controls and dots never display hover symbols! */
.control.disabled::after,
.modal-dot.disabled::after,
.window-controls:hover .control.disabled::after,
.about-modal-header:hover .modal-dot.disabled::after {
    display: none !important;
    content: '' !important;
}

.about-modal-body {
    padding: 30px 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    color: var(--text-ui);
}

.about-app-icon {
    font-size: 48px;
    color: var(--accent-orange);
    margin-bottom: 15px;
    filter: drop-shadow(0 0 10px rgba(39, 201, 63, 0.25));
}

.about-modal-body h2 {
    font-family: var(--font-code);
    font-size: 22px;
    margin-bottom: 5px;
    font-weight: 600;
}

.about-version {
    font-size: 12px;
    color: var(--text-ui-muted);
    opacity: 0.8;
    margin-bottom: 20px;
}

.about-divider {
    width: 80px;
    height: 1px;
    background-color: var(--border-color);
    margin-bottom: 20px;
}

.about-dev {
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 8px;
}

.about-copyright {
    font-size: 11px;
    color: var(--text-ui-muted);
    opacity: 0.6;
    margin-bottom: 25px;
}

.about-close-btn {
    background-color: var(--bg-tab-hover);
    border: 1px solid var(--border-color);
    color: var(--text-ui);
    padding: 6px 20px;
    border-radius: 6px;
    font-size: 13px;
    cursor: pointer;
    transition: background-color 0.2s, color 0.2s;
    outline: none;
}

.about-close-btn:hover {
    background-color: var(--accent-orange);
    color: var(--bg-sidebar);
}

/* ----------------------------------------------------
   14. SUBLIME-STYLE FIND PANEL & HIGHLIGHTING
------------------------------------------------------- */
.find-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 42px;
    background-color: var(--bg-sidebar);
    border-top: 1px solid var(--border-color);
    padding: 0 16px;
    box-sizing: border-box;
    font-family: var(--font-ui);
    color: var(--text-ui);
    z-index: 100;
    user-select: none;
    animation: slideUp 0.15s cubic-bezier(0.25, 0.8, 0.25, 1);
}

@keyframes slideUp {
    from {
        height: 0;
        opacity: 0;
    }
    to {
        height: 42px;
        opacity: 1;
    }
}

.find-panel-left {
    display: flex;
    align-items: center;
    flex: 1;
}

.find-panel-right {
    display: flex;
    align-items: center;
}

.find-label {
    font-size: 11px;
    color: var(--text-ui-muted);
    margin: 0 10px;
    font-weight: 700;
    letter-spacing: 0.8px;
    text-transform: uppercase;
}

.find-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    flex: 1;
    max-width: 320px;
}

.find-input-wrapper input {
    width: 100%;
    background-color: var(--bg-terminal);
    border: 1px solid var(--border-color);
    color: var(--text-ui);
    border-radius: 4px;
    padding: 5px 65px 5px 10px;
    font-family: var(--font-code);
    font-size: 13px;
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.find-input-wrapper input:focus {
    border-color: var(--accent-orange);
    box-shadow: 0 0 4px rgba(255, 146, 43, 0.15);
}

.find-count {
    position: absolute;
    right: 10px;
    font-size: 11px;
    color: var(--text-ui-muted);
    font-family: var(--font-code);
    pointer-events: none;
}

.find-toggle-btn {
    background: transparent;
    border: 1px solid transparent;
    border-radius: 4px;
    color: var(--text-ui-muted);
    padding: 3px 8px;
    cursor: pointer;
    font-weight: bold;
    font-size: 12px;
    transition: all 0.15s ease;
}

.find-toggle-btn:hover {
    color: var(--text-ui);
    background-color: var(--bg-tab-hover);
}

.find-toggle-btn.active {
    color: var(--bg-sidebar);
    background-color: var(--accent-orange);
    border-color: var(--accent-orange);
    box-shadow: 0 0 6px var(--accent-orange);
}

.find-action-btn {
    background: transparent;
    border: none;
    color: var(--text-ui-muted);
    width: 28px;
    height: 28px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    margin-left: 6px;
    transition: all 0.15s ease;
}

.find-action-btn:hover {
    background-color: var(--bg-tab-hover);
    color: var(--accent-orange);
}

.find-action-btn:active {
    transform: scale(0.95);
}

.find-action-btn.close-btn:hover {
    color: var(--syntax-boolean);
}

/* Find Highlight Styles */
.find-highlight {
    background-color: rgba(255, 146, 43, 0.25);
    border-bottom: 2px solid var(--accent-orange);
    color: inherit;
    border-radius: 2px;
    transition: background-color 0.15s ease;
}

.find-highlight.active-match {
    background-color: var(--accent-orange) !important;
    color: #000000 !important;
    box-shadow: 0 0 8px var(--accent-orange);
    border-bottom-color: transparent;
}

/* ----------------------------------------------------
   15. SUBLIME-STYLE GOTO ANYTHING PALETTE
------------------------------------------------------- */
.goto-panel-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.45);
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding-top: 50px;
    z-index: 1000;
    box-sizing: border-box;
}

.goto-panel {
    width: 450px;
    max-width: 90%;
    background-color: var(--bg-sidebar);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5), 0 0 1px var(--border-color);
    overflow: hidden;
    animation: gotoFadeDown 0.18s cubic-bezier(0.25, 0.8, 0.25, 1);
}

@keyframes gotoFadeDown {
    from {
        opacity: 0;
        transform: translateY(-15px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.goto-input-wrapper {
    display: flex;
    align-items: center;
    padding: 10px 16px;
    border-bottom: 1px solid var(--border-color);
    background-color: var(--bg-terminal);
}

.goto-input-wrapper .search-icon {
    color: var(--text-ui-muted);
    margin-right: 12px;
    font-size: 14px;
}

.goto-input-wrapper input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: var(--text-ui);
    font-family: var(--font-code);
    font-size: 14px;
}

.goto-results {
    max-height: 250px;
    overflow-y: auto;
    background-color: var(--bg-sidebar);
}

.goto-result-item {
    display: flex;
    align-items: center;
    padding: 8px 16px;
    cursor: pointer;
    color: var(--text-ui);
    font-size: 13px;
    font-family: var(--font-code);
    transition: background-color 0.12s ease, color 0.12s ease;
    border-left: 3px solid transparent;
}

.goto-result-item:hover,
.goto-result-item.active {
    background-color: var(--bg-tab-hover);
}

.goto-result-item.active {
    color: var(--accent-orange);
    border-left-color: var(--accent-orange);
}

.goto-result-item .item-icon {
    margin-right: 10px;
    font-size: 12px;
    width: 16px;
    text-align: center;
    display: inline-block;
}

.goto-result-item .json-icon {
    color: var(--accent-orange);
    font-weight: bold;
}

.goto-result-item .sh-icon {
    color: var(--syntax-link);
}


