* {
    box-sizing: border-box;
}

:root {
    /* Default Light Theme */
    --bg-app: #f5f7fa;
    --bg-card: #ffffff;
    --bg-card-header: #ffffff;
    --bg-dropdown: #ffffff;
    --text-primary: #2d3748;
    --text-secondary: #718096;
    --accent-blue: #3182ce;
    --border-color: #e2e8f0;
    --divider: #edf2f7;
    --danger: #e53e3e;
    --card-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --header-bg-hover: #f7fafc;
    --link-hover-bg: #f8fafc;

    /* Layout */
    --card-radius: 10px;
}

html.dark-theme,
body.dark-theme {
    /* Dark Theme Overrides */
    --bg-app: #1c1c1e;
    --bg-card: #2c2c2e;
    --bg-card-header: #2c2c2e;
    --bg-dropdown: #232325;
    --text-primary: #f2f2f5;
    --text-secondary: #aeaeb2;
    --accent-blue: #0a84ff;
    --border-color: #38383a;
    --divider: #38383a;
    --danger: #ff453a;
    --card-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    --header-bg-hover: rgba(255, 255, 255, 0.03);
    --link-hover-bg: rgba(255, 255, 255, 0.05);
}

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    background-color: var(--bg-app);
    color: var(--text-primary);
    margin: 0;
    padding: 0;
    min-height: 100vh;
    transition: background-color 0.3s, color 0.3s;
}

.container {
    max-width: 780px;

    margin: 0 auto;
    padding: 2rem 1rem;
}

body.wide-mode .container {
    max-width: 96%;
}

/* Header */
header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--divider);
    flex-wrap: wrap;
    gap: 1rem;
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

h1 {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

h1 span {
    color: var(--accent-blue);
}

/* Cards */
/* Cards */
.group-card {
    background-color: var(--bg-card);
    border-radius: var(--card-radius);
    margin-bottom: 1.5rem;
    box-shadow: var(--card-shadow);

    border: 1px solid var(--border-color);
    transition: transform 0.2s, box-shadow 0.2s, background-color 0.3s, border-color 0.3s;
}

.group-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background-color: var(--bg-card-header);

    border-bottom: 1px solid var(--divider);

    border-top-left-radius: var(--card-radius);
    border-top-right-radius: var(--card-radius);
}

/* Chrome Group Color Tints - Light Theme */
.group-header.group-color-grey {
    background-color: rgba(128, 128, 128, 0.1);
}

.group-header.group-color-blue {
    background-color: rgba(66, 133, 244, 0.12);
}

.group-header.group-color-red {
    background-color: rgba(234, 67, 53, 0.1);
}

.group-header.group-color-yellow {
    background-color: rgba(251, 188, 4, 0.12);
}

.group-header.group-color-green {
    background-color: rgba(52, 168, 83, 0.1);
}

.group-header.group-color-pink {
    background-color: rgba(233, 30, 99, 0.1);
}

.group-header.group-color-purple {
    background-color: rgba(156, 39, 176, 0.1);
}

.group-header.group-color-cyan {
    background-color: rgba(0, 188, 212, 0.12);
}

.group-header.group-color-orange {
    background-color: rgba(255, 112, 67, 0.12);
}

/* Chrome Group Color Tints - Dark Theme */
html.dark-theme .group-header.group-color-grey,
body.dark-theme .group-header.group-color-grey {
    background-color: rgba(158, 158, 158, 0.15);
}

html.dark-theme .group-header.group-color-blue,
body.dark-theme .group-header.group-color-blue {
    background-color: rgba(66, 133, 244, 0.2);
}

html.dark-theme .group-header.group-color-red,
body.dark-theme .group-header.group-color-red {
    background-color: rgba(234, 67, 53, 0.18);
}

html.dark-theme .group-header.group-color-yellow,
body.dark-theme .group-header.group-color-yellow {
    background-color: rgba(251, 188, 4, 0.18);
}

html.dark-theme .group-header.group-color-green,
body.dark-theme .group-header.group-color-green {
    background-color: rgba(52, 168, 83, 0.18);
}

html.dark-theme .group-header.group-color-pink,
body.dark-theme .group-header.group-color-pink {
    background-color: rgba(233, 30, 99, 0.18);
}

html.dark-theme .group-header.group-color-purple,
body.dark-theme .group-header.group-color-purple {
    background-color: rgba(156, 39, 176, 0.18);
}

html.dark-theme .group-header.group-color-cyan,
body.dark-theme .group-header.group-color-cyan {
    background-color: rgba(0, 188, 212, 0.2);
}

html.dark-theme .group-header.group-color-orange,
body.dark-theme .group-header.group-color-orange {
    background-color: rgba(255, 112, 67, 0.2);
}

.group-info {
    display: flex;
    flex-direction: column;
}

.group-title {
    font-size: 1.1rem;
    font-weight: 500;
    color: var(--text-primary);
}

.group-date {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-top: 2px;
}

.group-actions {
    display: flex;
    gap: 8px;
}

/* Action Buttons (Icons style) */
.action-btn {
    background: transparent;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 6px;
    border-radius: 4px;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
}

.action-btn:hover {
    background-color: rgba(255, 255, 255, 0.1);
    color: var(--text-primary);
}

.action-btn.delete:hover {
    color: var(--danger);
    background-color: rgba(255, 69, 58, 0.1);
}

.action-btn.restore:hover {
    color: var(--accent-blue);
    background-color: rgba(10, 132, 255, 0.1);
}

/* Collapse Button & Hover Menu */
.collapse-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    height: 32px;

}

.action-btn.collapse-btn {
    transition: all 0.2s;
    z-index: 10;
}

.action-btn.collapse-btn svg {
    transition: transform 0.2s ease;
}

/* Menu logic */
.collapse-hover-menu {
    display: none;
    position: absolute;
    bottom: 100%;

    left: 50%;
    transform: translateX(-50%);
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.15);
    border-radius: 6px;
    padding: 6px;
    z-index: 100;
    min-width: 170px;
    animation: fadeInCenteredUp 0.1s ease;
    margin-bottom: 4px;
}

.collapse-wrapper:hover .collapse-hover-menu {
    display: block;
}

/* First group: open dropdown downward */
#groups-container .group-card.first-group .collapse-hover-menu,
#groups-container .group-card.first-group .restore-hover-menu {
    bottom: auto;
    top: 100%;
    margin-bottom: 0;
    margin-top: 4px;
    animation: fadeInCentered 0.1s ease;
    z-index: 1000;
}

/* Bridge for downward opening */
#groups-container .group-card.first-group .collapse-wrapper::after,
#groups-container .group-card.first-group .restore-wrapper::after {
    bottom: auto;
    top: 100%;
}

/* Hover bridge */
.collapse-wrapper::after {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 0;
    right: 0;
    height: 6px;
    display: none;
}

.collapse-wrapper:hover::after {
    display: block;
}

.collapse-menu-btn {
    display: block;
    width: 100%;
    text-align: left;
    background: none;
    border: none;
    padding: 8px 12px;
    font-size: 0.85rem;
    color: var(--text-primary);
    cursor: pointer;
    border-radius: 4px;
    white-space: nowrap;
}

.collapse-menu-btn:hover {
    background: var(--header-bg-hover);
    color: var(--accent-blue);
}

@keyframes fadeInCentered {
    from {
        opacity: 0;
        transform: translate(-50%, -5px);
    }

    to {
        opacity: 1;
        transform: translate(-50%, 0);
    }
}

@keyframes fadeInCenteredUp {
    from {
        opacity: 0;
        transform: translate(-50%, 5px);
    }

    to {
        opacity: 1;
        transform: translate(-50%, 0);
    }
}

/* Restore Dropdown */
.restore-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.restore-hover-menu {
    display: none;
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.15);
    border-radius: 6px;
    padding: 6px;
    z-index: 100;
    min-width: 170px;
    animation: fadeInCenteredUp 0.1s ease;
    margin-bottom: 4px;
}

.restore-wrapper:hover .restore-hover-menu {
    display: block;
}

.restore-wrapper::after {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 0;
    right: 0;
    height: 6px;
    display: none;
}

.restore-wrapper:hover::after {
    display: block;
}

/* Group Options Menu (3-dot button) */
.group-menu-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.group-menu-btn {
    opacity: 0.6;
    transition: opacity 0.2s, color 0.2s, background-color 0.2s;
}

.group-menu-btn:hover {
    opacity: 1;
    color: var(--accent-blue);
    background-color: rgba(59, 130, 246, 0.1);
}

.group-options-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999;
}

.group-options-menu {
    position: fixed;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
    z-index: 1000;
    min-width: 180px;
    padding: 6px;
    animation: fadeIn 0.15s ease;
}

.group-options-menu-item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 10px 14px;
    border: none;
    background: none;
    color: var(--text-primary);
    font-size: 0.9rem;
    cursor: pointer;
    border-radius: 6px;
    text-align: left;
    transition: background-color 0.15s, color 0.15s;
}

.group-options-menu-item:hover {
    background-color: var(--header-bg-hover);
    color: var(--accent-blue);
}

.group-options-menu-item svg {
    flex-shrink: 0;
    opacity: 0.7;
}

.group-options-menu-item:hover svg {
    opacity: 1;
}

/* User Submenu (for Move to User feature) */
.has-submenu {
    position: relative;
}

.has-submenu .submenu-arrow {
    margin-left: auto;
    opacity: 0.5;
}

.has-submenu:hover .submenu-arrow {
    opacity: 1;
}

.user-submenu {
    position: absolute;
    top: 0;
    right: 100%;
    left: auto;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
    z-index: 1001;
    min-width: 150px;
    padding: 6px;
    animation: fadeIn 0.15s ease;
    margin-right: 4px;
}

/* Links submenu: position from bottom to avoid clipping in small windows */
.user-submenu.links-submenu {
    top: auto;
    bottom: -60px;
}

.user-submenu .tab-context-menu-item,
.user-submenu .group-options-menu-item {
    width: 100%;
}

/* User Picker Modal (for Copy to another user) */
.user-picker-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 10002;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: fadeIn 0.15s ease;
}

.user-picker-modal {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
    min-width: 240px;
    max-width: 340px;
    padding: 20px;
    animation: contextMenuFadeIn 0.15s ease;
}

.user-picker-modal h3 {
    margin: 0 0 14px 0;
    font-size: 0.95rem;
    color: var(--text-primary);
    font-weight: 600;
}

.user-picker-item {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    padding: 10px 14px;
    border: none;
    background: transparent;
    color: var(--text-primary);
    font-size: 0.9rem;
    cursor: pointer;
    border-radius: 8px;
    transition: background-color 0.15s ease, color 0.15s ease;
}

.user-picker-item:hover {
    background-color: var(--header-bg-hover);
    color: var(--accent-blue);
}

.user-picker-item svg {
    flex-shrink: 0;
    opacity: 0.7;
}

.user-picker-item:hover svg {
    opacity: 1;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-5px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}


.action-btn.collapse-btn.collapsed svg {
    transform: rotate(0deg);
}

/* Collapsed Group State */
.group-card.collapsed .link-list {
    display: none;
}

.group-card.collapsed .group-header {
    border-bottom: none;
    background-color: var(--bg-card);
    /* Remove highlight when collapsed */
    transition: background-color 0.2s;

    border-bottom-left-radius: var(--card-radius);
    border-bottom-right-radius: var(--card-radius);
}

.group-card.collapsed .group-header:hover {
    background-color: var(--header-bg-hover);
}

/* Group Name Editing */
.group-title-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;
    overflow: hidden;
}

.group-tabs {
    font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap;
    font-size: 0.95rem;
}

.group-separator {
    color: var(--text-secondary);
    opacity: 0.5;
}

.group-date {
    color: var(--text-secondary);
    font-size: 0.95rem;
    white-space: nowrap;
}

.group-name-container {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    max-width: 200px;
}

.group-name {
    font-size: 0.95rem;
    color: var(--accent-blue);
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 150px;
}

.group-name:empty {
    display: none;
}

.group-name-input {
    font-size: 0.85rem;
    color: var(--text-primary);
    background-color: var(--bg-card);
    border: 1px solid var(--accent-blue);
    border-radius: 4px;
    padding: 2px 6px;
    outline: none;
    width: 120px;
    max-width: 150px;
}

.edit-name-icon {
    cursor: pointer;
    opacity: 0.3;
    transition: opacity 0.2s;
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
}

.group-name-container:hover .edit-name-icon,
.group-title-row:hover .edit-name-icon {
    opacity: 0.6;
}

.edit-name-icon:hover {
    opacity: 1;
    color: var(--accent-blue);
}

/* Group Date Editing */
.group-date-container {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.group-date {
    cursor: pointer;
    transition: color 0.2s;
}

.group-date:hover {
    color: var(--accent-blue);
}

.group-date-editor {
    display: flex;
    align-items: center;
    gap: 6px;
}

.group-date-editor .date-input,
.group-date-editor .time-input {
    font-size: 0.85rem;
    color: var(--text-primary);
    background-color: var(--bg-card);
    border: 1px solid var(--accent-blue);
    border-radius: 4px;
    padding: 2px 6px;
    outline: none;
    font-family: inherit;
}

.group-date-editor .date-input {
    width: 130px;
}

.group-date-editor .time-input {
    width: 85px;
}

.group-date-editor .date-input:focus,
.group-date-editor .time-input:focus {
    box-shadow: 0 0 0 2px rgba(49, 130, 206, 0.2);
}

/* Dark mode fixes for date/time inputs */
html.dark-theme .group-date-editor .date-input,
html.dark-theme .group-date-editor .time-input,
body.dark-theme .group-date-editor .date-input,
body.dark-theme .group-date-editor .time-input {
    color-scheme: dark;
}

/* Link List */
.link-list {
    list-style: none;
    padding: 8px 0;
    margin: 0;
    min-height: 50px;

    transition: background-color 0.2s, border-color 0.2s;
}

.link-list.drag-over {
    background-color: rgba(49, 130, 206, 0.1);
    border-radius: 8px;
    border: 2px dashed var(--accent-blue);
}

.link-item {
    display: flex;
    align-items: center;
    padding: 14px 50px 14px 16px;

    border-bottom: 1px solid transparent;
    gap: 0;

    cursor: pointer;
    margin: 4px 0;
    border-radius: 8px;
    z-index: 1;
    position: relative;
    background: transparent;
}

.cursor-spacer {
    width: 20px;
    height: 24px;
    cursor: default;
    /* Show arrow */
    flex-shrink: 0;
}

/* Instant hover background */
.link-item::before {
    content: '';
    position: absolute;
    inset: 0 12px;
    border-radius: 8px;
    background-color: var(--link-hover-bg);
    z-index: -1;
    opacity: 0;

}

.link-item:hover::before {
    opacity: 1;
}


.link-item:hover {
    transform: none;
    box-shadow: none;
    z-index: 2;
    /* Bring to front */
}

.link-item:last-child {
    border-bottom: none;
}

.favicon {
    width: 16px;
    height: 16px;
    border-radius: 2px;
    opacity: 0.8;
}

.link-text {
    text-decoration: none;
    color: var(--text-primary);
    font-size: 0.9rem;
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;

}

.link-title-row {
    display: flex;
    align-items: center;
    min-width: 0;
}

.note-indicator {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    margin-left: 6px;
    color: var(--text-tertiary);
    cursor: help !important;
    /* Force help cursor over row pointer */
    position: relative;
}

.note-indicator svg {
    width: 13px;
    height: 13px;
}

/* Note preview tooltip */
.note-indicator[data-note-preview]:not([data-note-preview=""])::after {
    content: attr(data-note-preview);
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--bg-dropdown);
    color: var(--text-primary);
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 0.8rem;
    line-height: 1.4;
    max-width: 280px;
    min-width: 120px;
    width: max-content;
    white-space: pre-wrap;
    word-wrap: break-word;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    border: 1px solid var(--border-color);
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.15s ease, visibility 0.15s ease;
}

/* Tooltip arrow */
.note-indicator[data-note-preview]:not([data-note-preview=""])::before {
    content: '';
    position: absolute;
    bottom: calc(100% + 2px);
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: var(--border-color);
    z-index: 1001;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.15s ease, visibility 0.15s ease;
}

.note-indicator[data-note-preview]:not([data-note-preview=""]):hover::after,
.note-indicator[data-note-preview]:not([data-note-preview=""]):hover::before {
    opacity: 1;
    visibility: visible;
}

.link-item:hover .link-text {
    color: var(--accent-blue);
    /* Highlight on hover */
}

.delete-link-btn {
    opacity: 0.15;
    color: var(--text-secondary);
    background: none;
    border: none;
    font-size: 1.2rem;
    line-height: 1;
    cursor: pointer;
    padding: 0;


    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 48px;
    /* Slightly wider for easier clicking */
    height: auto;
    margin: 0;

    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0 8px 8px 0;
    /* Only right corners rounded to match row */
    z-index: 10;
    /* Ensure it's above the link item link */


}

.link-item:hover .delete-link-btn {
    opacity: 1;
}

.delete-link-btn:hover {
    color: var(--danger);
    background-color: rgba(229, 62, 62, 0.1);

}

/* Context Menu Button (3 dots) */
.context-menu-btn {
    opacity: 0;
    color: var(--text-secondary);
    background: none;
    border: none;
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    padding: 0;
    width: 28px;
    height: 28px;
    margin-right: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    transition: opacity 0.2s, color 0.2s, background-color 0.2s;
}

.context-menu-btn svg {
    width: 16px;
    height: 16px;
}

.link-item:hover .context-menu-btn {
    opacity: 0.7;
}

.context-menu-btn:hover {
    opacity: 1 !important;
    color: var(--accent-blue);
    background-color: rgba(59, 130, 246, 0.1);
}

/* Hide context menu button on pinned items (optional, can be shown if needed) */
.link-item.pinned .context-menu-btn {
    opacity: 0.5;
}

.link-item.pinned:hover .context-menu-btn {
    opacity: 0.7;
}

/* ================================================
   Drag and Drop Styles
   ================================================ */

/* Drag handle indicator */
.link-item .drag-handle {
    width: 16px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: grab;
    opacity: 0;
    color: var(--text-secondary);
    margin-right: 8px;
    flex-shrink: 0;
    transition: opacity 0.2s;
}

.link-item:hover .drag-handle {
    opacity: 0.6;
}

.link-item .drag-handle:hover {
    opacity: 1;
    color: var(--accent-blue);
}

.link-item .drag-handle:active {
    cursor: grabbing;
}

/* Element being dragged */
.link-item.dragging {
    opacity: 0.5;
    background: var(--header-bg-hover);
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.link-item.dragging::before {
    opacity: 0 !important;
}

/* Drop zone when hovering with dragged item */
.link-list.drag-over {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.05) 0%, rgba(59, 130, 246, 0.02) 100%);
    border-radius: 8px;
    box-shadow: inset 0 0 0 2px rgba(59, 130, 246, 0.3);
}

/* Drop indicator line */
.link-item.drag-over-top::after,
.link-item.drag-over-bottom::after {
    content: '';
    position: absolute;
    left: 16px;
    right: 16px;
    height: 3px;
    background: var(--accent-blue);
    border-radius: 2px;
    pointer-events: none;
    z-index: 10;
}

.link-item.drag-over-top::after {
    top: -2px;
}

.link-item.drag-over-bottom::after {
    bottom: -2px;
}

/* Empty drop zone message */
.link-list.drag-over.empty-list::after {
    content: '';
    display: block;
    min-height: 50px;
    border: 2px dashed rgba(59, 130, 246, 0.4);
    border-radius: 8px;
    margin: 8px 16px;
}

/* Prevent text selection during drag */
.dragging-active * {
    user-select: none !important;
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: 4rem 1rem;
    color: var(--text-secondary);
    opacity: 0.6;
}

/* Scrollbar */
::-webkit-scrollbar {
    width: 10px;
}

::-webkit-scrollbar-track {
    background: var(--bg-app);
}

::-webkit-scrollbar-thumb {
    background: #48484a;
    border-radius: 5px;
    border: 2px solid var(--bg-app);
}

::-webkit-scrollbar-thumb:hover {
    background: #636366;
}


/* Dropdown and Headers Fixed */
.header-actions {
    display: flex;
    gap: 16px;
    align-items: center;
    position: relative;
    /* Ensure z-index context */
}

.dropdown {
    position: relative;
    display: inline-block;
}

.dropdown-toggle {
    display: flex;
    align-items: center;
    padding: 8px 16px;
    background-color: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    height: 36px;
    white-space: nowrap;
}

.dropdown-toggle:hover {
    background-color: var(--header-bg-hover);
}

.dropdown-menu {
    display: none;
    /* Crucial */
    position: absolute;
    top: 100%;
    right: 0;
    background-color: var(--bg-dropdown);
    min-width: 180px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    z-index: 9999;
    border-radius: 8px;
    border: 1px solid var(--border-color);
    margin-top: 8px;
    padding: 4px 0;
    flex-direction: column;
}

/* Enable scroll only when advanced options are expanded AND inside embedded mode (popup) */
body.embedded-mode .dropdown-menu.has-expanded-options {
    max-height: 380px;
    overflow-y: auto;
    scrollbar-width: thin;
}


/* Bridge gap */
.dropdown-menu::before {
    content: '';
    position: absolute;
    top: -10px;
    left: 0;
    width: 100%;
    height: 10px;
}

/* Show menu on hover */
.dropdown:hover .dropdown-menu {
    display: flex;
}

.dropdown-item {
    width: 100%;
    text-align: left;
    background: none;
    border: none;
    padding: 10px 16px;
    color: var(--text-primary);
    cursor: pointer;
    font-size: 0.9rem;
    white-space: nowrap;
}

.dropdown-item:hover {
    background-color: var(--header-bg-hover);
    color: var(--accent-blue);
}

.dropdown-divider {
    height: 1px;
    background-color: var(--divider);
    margin: 6px 0;
}

/* ================================================
   Two-Column Export/Import Dropdown
   ================================================ */

/* Override display:block from .dropdown-menu.show for this dropdown */
#export-dropdown .dropdown-menu.show {
    display: flex !important;
    flex-direction: column;
}

.export-import-columns {
    display: flex;
}

/* Center dropdown under button in dashboard mode (not popup) */
body:not(.embedded-mode) #export-dropdown>.dropdown-menu,
body:not(.embedded-mode) #tools-dropdown>.dropdown-menu,
body:not(.embedded-mode) .header-actions>.dropdown:has(.lang-option)>.dropdown-menu {
    right: auto;
    left: 50%;
    transform: translateX(-50%);
}

.ei-column {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

/* Vertical divider between columns */
.ei-column:first-child {
    border-right: 1px solid var(--border-color);
}

/* Responsive: collapse to single column on small screens */
@media (max-width: 600px) {
    .export-import-columns {
        flex-direction: column;
    }

    .ei-column:first-child {
        border-right: none;
        border-bottom: 1px solid var(--border-color);
        padding-bottom: 4px;
        margin-bottom: 4px;
    }
}


.lang-option.disabled {
    opacity: 0.5;
    cursor: default;
    pointer-events: none;
    color: var(--text-secondary) !important;
}

/* Embedded Mode: Two-Column Language Selector */
body.embedded-mode .dropdown-menu.show:has(.lang-option) {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    min-width: 320px;
    /* Wider to accommodate 2 columns */
    padding: 8px;
    gap: 2px;
}

body.embedded-mode .dropdown-menu:has(.lang-option) .dropdown-header,
body.embedded-mode .dropdown-menu:has(.lang-option) .dropdown-close-btn {
    grid-column: 1 / -1;
    /* Span full width */
}

/* Embedded Mode: Scrollable Modals */
body.embedded-mode .modal-overlay {
    align-items: flex-start !important;
    /* Align to top instead of center */
    padding: 20px 10px;
    overflow-y: auto;
}

body.embedded-mode .modal-overlay>div {
    max-height: calc(100vh - 80px);
    overflow-y: auto;
}

/* Embedded Mode: Reposition context-menu-btn next to delete button without overlap */
body.embedded-mode .link-item {
    padding-right: 100px !important;
    overflow: hidden;
}

body.embedded-mode .cursor-spacer {
    display: none;
}

body.embedded-mode .context-menu-btn {
    position: absolute;
    right: 48px;
    top: 50%;
    transform: translateY(-50%);
    margin-right: 0;
    z-index: 11;
    overflow: visible;
}


.search-wrapper svg {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--text-secondary);
}

.dropdown-header {
    padding: 12px 16px 10px;
    font-size: 0.75rem;
    color: var(--text-secondary);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.dropdown-section {
    padding: 8px 16px;
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: nowrap;
    /* Prevent wrapping */
    white-space: nowrap;
    /* Keep text on one line */
}

/* Tools section - vertical layout for buttons */
.dropdown-section.tools-section {
    flex-direction: column !important;
    align-items: stretch;
}

.dropdown-select {
    background: var(--bg-app);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    padding: 4px 8px;
    font-size: 0.85rem;
    outline: none;
    cursor: pointer;
}

.dropdown-checkbox-label {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: 0.9rem;
    color: var(--text-primary);
    width: 100%;
}

.dropdown-divider {
    height: 1px;
    background-color: var(--border-color);
    margin: 4px 0;
}

/* Settings Toggle Button (Show more/less) */
.settings-toggle-btn {
    width: 100%;
    padding: 6px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    background: none;
    border: none;
    color: var(--accent-blue);
    font-size: 0.8rem;
    cursor: pointer;
    transition: all 0.2s;
}

.settings-toggle-btn:hover {
    color: var(--text-primary);
    background: var(--header-bg-hover);
}

.settings-toggle-btn svg {
    transition: transform 0.2s ease;
}

.settings-toggle-btn.expanded svg {
    transform: rotate(180deg);
}

/* Collapsible Advanced Options */
.advanced-options {
    overflow: hidden;
    max-height: 200px;
    transition: max-height 0.3s ease, opacity 0.2s ease;
    opacity: 1;
}

.advanced-options.collapsed {
    max-height: 0;
    opacity: 0;
}

.dropdown-action-btn {
    width: 100%;
    padding: 8px 12px;
    background: var(--bg-app);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    color: var(--text-primary);
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.2s;
}

.dropdown-action-btn:hover {
    background: var(--accent-blue);
    color: white;
    border-color: var(--accent-blue);
}

/* Pagination */
.pagination {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 2rem;
    padding-bottom: 2rem;
}

.page-btn {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    padding: 6px 12px;
    border-radius: 6px;
    cursor: pointer;
    min-width: 32px;
}

.page-btn:hover {
    background: var(--header-bg-hover);
    color: var(--accent-blue);
}

.page-btn.active {
    background: var(--accent-blue);
    color: white;
    border-color: var(--accent-blue);
}

.page-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.total-counter {
    text-align: center;
    padding: 1rem 0;
    color: var(--text-secondary);
    font-size: 0.85rem;
    border-top: 1px solid var(--divider);
    margin-top: 1rem;
}

/* Theme and Help Button styling */
.icon-btn {
    padding: 0;
    width: 36px;
    height: 36px;
    border-radius: 6px;
    background-color: var(--bg-card);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
    /* For the help link */
}

.icon-btn:hover {
    background-color: var(--header-bg-hover);
    color: var(--text-primary);
    border-color: var(--text-secondary);
}

.sun-icon,
.moon-icon {
    width: 20px;
    height: 20px;
}

/* Print Styles */
@media print {

    header,
    .group-actions,
    .delete-link-btn,
    .header-actions {
        display: none !important;
    }

    body,
    .container {
        background: white;
        color: black;
        max-width: 100%;
        margin: 0;
        padding: 0;
    }

    .group-card {
        box-shadow: none;
        border: 1px solid #ddd;
        page-break-inside: avoid;
    }

    a {
        color: black;
        text-decoration: none;
    }

    .link-url {
        /* Optional: show URL in print */
        display: block;
        max-width: 100%;
        margin: 0;
        padding: 0;
    }

    .group-card {
        box-shadow: none;
        border: 1px solid #ddd;
        page-break-inside: avoid;
    }

    a {
        font-size: 0.8em;
        color: #666;
    }
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    position: relative;
}


.help-close {
    position: absolute;
    top: 4px;
    right: 8px;
    background: var(--divider);
    border: none;
    color: var(--text-primary);
    font-size: 1.2rem;
    cursor: pointer;
    z-index: 20;
    line-height: 1;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    opacity: 0.8;
}

.help-close:hover {
    background-color: var(--danger);
    color: white;
    opacity: 1;
    transform: rotate(90deg);
}


/* Close button for small screens */
.help-close {
    position: absolute;
    top: 10px;
    right: 10px;
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 1.2rem;
    padding: 4px;
}

.help-close:hover {
    color: white;
}



@keyframes fadeInModal {
    from {
        opacity: 0;
        transform: translate(-50%, -45%);
    }

    to {
        opacity: 1;
        transform: translate(-50%, -50%);
    }
}


/* Import Modal */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
    animation: fadeIn 0.15s ease-out;
}

.modal-content {
    background-color: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 1.5rem;
    max-width: 700px;
    width: 90%;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

.modal-content h3 {
    margin: 0 0 0.75rem 0;
    color: var(--text-primary);
    font-size: 1.1rem;
}

.modal-content p {
    margin: 0 0 1rem 0;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.modal-info {
    background-color: var(--header-bg-hover);
    border-radius: 8px;
    padding: 0.75rem;
    margin-bottom: 1rem;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.modal-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.modal-btn {
    padding: 10px 16px;
    border-radius: 6px;
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    border: none;
    transition: all 0.2s;
}

.modal-btn-secondary {
    background-color: transparent;
    color: var(--accent-blue);
    border: 1px solid var(--accent-blue);
}

.modal-btn-secondary:hover {
    background-color: rgba(49, 130, 206, 0.1);
}

.modal-btn-danger {
    background-color: transparent;
    color: var(--danger);
    border: 1px solid var(--danger);
}

.modal-btn-danger:hover {
    background-color: rgba(229, 62, 62, 0.1);
}

.modal-btn-text {
    background: transparent;
    color: var(--text-secondary);
    border: 1px solid var(--border-color);
}

.modal-btn-text:hover {
    color: var(--text-primary);
    border-color: var(--text-primary);
    background-color: var(--header-bg-hover);
}

/* Modal Close Button (X) */
.modal-close-btn {
    position: absolute;
    top: 12px;
    right: 12px;
    background: var(--divider);
    border: none;
    color: var(--text-primary);
    font-size: 1.2rem;
    cursor: pointer;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    opacity: 0.7;
}

.modal-close-btn:hover {
    background-color: var(--danger);
    color: white;
    opacity: 1;
    transform: rotate(90deg);
}


/* ================================================
   Import Selector Button Styles
   ================================================ */
.import-selector-btn {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    font-size: 0.9rem;
    background: linear-gradient(135deg, var(--bg-card) 0%, var(--header-bg-hover) 100%);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    cursor: pointer;
    color: var(--text-primary);
    transition: all 0.2s ease;
}

.import-selector-btn:hover {
    border-color: var(--accent-blue);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.import-selector-left {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 500;
}

.import-selector-left svg {
    color: var(--accent-blue);
}

.import-selector-status {
    font-size: 0.8rem;
    color: var(--accent-blue);
    font-weight: 600;
    background: rgba(59, 130, 246, 0.1);
    padding: 4px 10px;
    border-radius: 20px;
}

/* ================================================
   Group Selector Modal (Full Screen Popup)
   ================================================ */
.group-selector-content {
    background-color: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    width: 95vw;
    max-width: 900px;
    height: 90vh;
    max-height: 800px;
    display: flex;
    flex-direction: column;
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.4);
    overflow: hidden;
}

.group-selector-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-color);
    background: linear-gradient(135deg, var(--bg-card) 0%, var(--header-bg-hover) 100%);
    flex-shrink: 0;
}

.group-selector-header h3 {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-primary);
}

.group-selector-close {
    background: var(--divider);
    border: none;
    color: var(--text-primary);
    font-size: 1.2rem;
    cursor: pointer;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    opacity: 0.7;
}

.group-selector-close:hover {
    background-color: var(--danger);
    color: white;
    opacity: 1;
    transform: rotate(90deg);
}

.group-selector-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border-color);
    background: var(--header-bg-hover);
    flex-shrink: 0;
    gap: 12px;
    flex-wrap: wrap;
}

.group-selector-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.group-selector-action-btn {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}

.group-selector-action-btn:hover {
    border-color: var(--accent-blue);
    color: var(--accent-blue);
    background: rgba(59, 130, 246, 0.1);
}

.group-selector-summary {
    font-size: 0.85rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.group-selector-list {
    flex: 1 1 auto;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 12px;
    scrollbar-width: thin;
    min-height: 0;
}

.group-selector-list::-webkit-scrollbar {
    width: 6px;
}

.group-selector-list::-webkit-scrollbar-thumb {
    background-color: var(--border-color);
    border-radius: 10px;
}

.group-selector-footer {
    display: flex;
    justify-content: flex-end;
    padding: 16px 20px;
    border-top: 1px solid var(--border-color);
    background: var(--header-bg-hover);
    flex-shrink: 0;
}

/* Group Item Accordion */
.group-selector-item {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    overflow: hidden;
    transition: border-color 0.2s;
    margin-bottom: 8px;
    flex-shrink: 0;
}

.group-selector-item:hover {
    border-color: var(--accent-blue);
}

.group-selector-item.partial {
    border-color: rgba(59, 130, 246, 0.5);
    background: rgba(59, 130, 246, 0.03);
}

.group-selector-item-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    cursor: pointer;
    transition: background 0.15s;
}

.group-selector-item-header:hover {
    background: var(--header-bg-hover);
}

.group-selector-expand-btn {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s, color 0.2s;
    flex-shrink: 0;
}

.group-selector-expand-btn:hover {
    color: var(--accent-blue);
}

.group-selector-expand-btn.expanded {
    transform: rotate(90deg);
}

.group-selector-checkbox {
    flex-shrink: 0;
}

.group-selector-item-info {
    flex: 1;
    min-width: 0;
}

.group-selector-item-title {
    font-weight: 500;
    font-size: 0.9rem;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 8px;
}

.group-selector-item-title .group-emoji {
    font-size: 1rem;
}

.group-selector-item-meta {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 2px;
}

.group-selector-item-count {
    font-size: 0.75rem;
    color: var(--accent-blue);
    background: rgba(59, 130, 246, 0.1);
    padding: 3px 8px;
    border-radius: 12px;
    font-weight: 600;
    flex-shrink: 0;
}

/* Tabs List (Expandable) */
.group-selector-tabs {
    display: none;
    border-top: 1px solid var(--border-color);
    background: var(--header-bg-hover);
}

.group-selector-tabs.expanded {
    display: block;
}

@keyframes slideDown {
    from {
        opacity: 0;
        max-height: 0;
    }

    to {
        opacity: 1;
        max-height: 300px;
    }
}

.group-selector-tab {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px 10px 42px;
    border-bottom: 1px solid var(--divider);
    transition: background 0.15s;
    min-height: 44px;
    box-sizing: border-box;
}

.group-selector-tab:last-child {
    border-bottom: none;
}

.group-selector-tab:hover {
    background: rgba(255, 255, 255, 0.05);
}

.group-selector-tab-checkbox {
    flex-shrink: 0;
}

.group-selector-tab-favicon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    border-radius: 2px;
}

.group-selector-tab-info {
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

.group-selector-tab-title {
    font-size: 0.8rem;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.group-selector-tab-url {
    font-size: 0.7rem;
    color: var(--text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 1px;
}

/* JSON Drop Zone Modal */
.json-drop-zone {
    border: 2px dashed var(--border-color);
    border-radius: 12px;
    padding: 40px 20px;
    text-align: center;
    transition: all 0.3s ease;
    cursor: pointer;
    background: var(--bg-secondary);
}

.json-drop-zone:hover {
    border-color: var(--accent-blue);
    background: rgba(59, 130, 246, 0.05);
}

.json-drop-zone.drag-over {
    border-color: var(--accent-blue);
    border-style: solid;
    background: rgba(59, 130, 246, 0.1);
    transform: scale(1.02);
}

.json-drop-zone svg {
    color: var(--text-secondary);
    margin-bottom: 16px;
    transition: color 0.2s;
}

.json-drop-zone:hover svg,
.json-drop-zone.drag-over svg {
    color: var(--accent-blue);
}

.json-drop-zone .drop-zone-text {
    font-size: 1rem;
    font-weight: 500;
    color: var(--text-primary);
    margin: 0 0 8px 0;
}

.json-drop-zone .drop-zone-or {
    display: block;
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin: 12px 0;
}

.json-drop-zone .drop-zone-hint {
    font-size: 0.75rem;
    color: var(--text-tertiary);
    margin: 12px 0 0 0;
    opacity: 0.8;
}

/* Theme Selection Modal */
.theme-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: 12px;
    margin: 1.5rem 0;
}

.theme-option {
    display: flex;
    flex-direction: column;
    align-items: center;
    background: none;
    border: 2px solid transparent;
    border-radius: 8px;
    padding: 8px;
    cursor: pointer;
    transition: all 0.2s;
}

.theme-option:hover {
    background-color: var(--bg-hover);
}

.theme-option.selected {
    border-color: var(--accent-blue);
    background-color: var(--bg-hover);
}

.theme-preview {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    margin-bottom: 8px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.theme-option span {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.theme-option.selected span {
    color: var(--text-primary);
    font-weight: 600;
}

#theme-modal .modal-actions {
    flex-direction: row;
    justify-content: flex-end;
    margin-top: 1rem;
}

/* Highlight text in search */
mark {
    background-color: rgba(255, 215, 0, 0.4);
    color: inherit;
    border-radius: 2px;
    padding: 0 2px;
}

/* Search Box Styles */
.search-input {
    width: 100%;
    padding: 12px 40px 12px 16px;
    border: 1px solid var(--border-color);
    background-color: var(--bg-card);
    color: var(--text-primary);
    border-radius: var(--card-radius);
    font-size: 0.95rem;
    outline: none;
    transition: all 0.2s ease;
    box-shadow: var(--card-shadow);
    /* Optional: match cards */
}

.search-input:focus {
    border-color: var(--accent-blue);
    box-shadow: 0 0 0 3px rgba(49, 130, 206, 0.2);
}

.search-wrapper {
    position: relative;
    width: 100%;
}

/* Responsive Dropdown for small screens */
@media (max-width: 600px) {
    .dropdown-menu {
        position: fixed !important;
        top: 160px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        width: 90% !important;
        max-width: 350px !important;
        box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5) !important;
        z-index: 9999 !important;
        border: 1px solid var(--border-color);
    }
}

/* Disable hover, enable click */
.dropdown:hover .dropdown-menu {
    display: none;
}

.dropdown-menu.show {
    display: block !important;
}

/* ================================================
   EMBEDDED MODE (for popup iframe)
   ================================================ */

/* Main body adjustments for embedded mode */
body.embedded-mode {
    overflow-x: hidden;
    width: 100%;
    min-height: 100vh;
}

body.embedded-mode .container {
    max-width: 100%;
    width: 100%;
    padding: 0.5rem;
    box-sizing: border-box;
}

/* Hide the logo/title/description header section */
body.embedded-mode header>div:first-child {
    display: none !important;
}

body.embedded-mode header {
    margin-bottom: 0.5rem;
    padding-bottom: 0.5rem;
    border-bottom: none;
    flex-wrap: wrap;
}

body.embedded-mode .header-actions {
    width: 100%;
    justify-content: flex-start;
    gap: 6px;
}

/* Compact search section */
body.embedded-mode #search-section {
    margin-bottom: 0.5rem !important;
}

body.embedded-mode .search-flex-container {
    flex-wrap: wrap;
    gap: 8px !important;
}

body.embedded-mode .search-input {
    font-size: 0.85rem;
}

/* Compact group cards */
body.embedded-mode .group-card {
    margin-bottom: 0.5rem;
}

body.embedded-mode .group-header {
    padding: 8px 12px;
}

body.embedded-mode .link-item {
    padding: 10px 12px;
    margin: 2px 0;
}

body.embedded-mode .link-item::before {
    inset: 0 8px;
}

body.embedded-mode .empty-state {
    padding: 1.5rem 1rem;
}

body.embedded-mode .pagination {
    margin-top: 0.75rem;
    padding-bottom: 0.5rem;
}

body.embedded-mode .total-counter {
    padding: 0.5rem 0;
    margin-top: 0.5rem;
}

/* Fix dropdown menus positioning in embedded mode */
body.embedded-mode .dropdown-menu {
    max-height: 350px;
    overflow-y: auto;
    right: auto;
    left: 0;
    min-width: 200px;
}

/* Ensure dropdowns don't overflow the container */
body.embedded-mode .dropdown {
    position: static;
}

body.embedded-mode .header-actions {
    position: relative;
}

body.embedded-mode .header-actions .dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: auto;
    margin-top: 4px;
}

/* ================================================
   Emoji Picker Modal Styles
   ================================================ */

.emoji-picker-btn {
    font-family: "Segoe UI Emoji", "Apple Color Emoji", "Noto Color Emoji", sans-serif;
    padding: 4px 6px;
    font-size: 1.1rem;
    min-width: 32px;
}

/* Backdrop */
.emoji-picker-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.6);
    z-index: 9998;
    animation: fadeIn 0.15s ease-out;
}

/* Modal */
.emoji-picker-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90vw;
    max-width: 1200px;
    height: 90vh;
    max-height: 90vh;
    background-color: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
    z-index: 9999;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    /* animation: fadeInModal 0.2s ease-out; */
}

/* Header */
.emoji-picker-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-card-header);
    flex-shrink: 0;
}

.emoji-picker-header span {
    font-weight: 600;
    font-size: 1rem;
    color: var(--text-primary);
}

.emoji-picker-close {
    background: var(--divider);
    border: none;
    color: var(--text-primary);
    font-size: 1rem;
    cursor: pointer;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: all 0.2s;
    opacity: 0.7;
}

.emoji-picker-close:hover {
    background-color: var(--danger);
    color: white;
    opacity: 1;
    transform: rotate(90deg);
}

/* Grid */
.emoji-picker-grid {
    flex: 1;
    overflow-y: scroll;
    overflow-x: hidden;
    padding: 12px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(36px, 1fr));
    gap: 4px;
    align-content: start;
    scrollbar-width: thin;
    /* Performance optimizations */
    -webkit-overflow-scrolling: touch;
    will-change: scroll-position;
    contain: strict;
    transform: translateZ(0);
    /* Prevent scroll from propagating to parent */
    overscroll-behavior: contain;
}

.emoji-picker-grid::-webkit-scrollbar {
    width: 8px;
}

.emoji-picker-grid::-webkit-scrollbar-thumb {
    background-color: var(--border-color);
    border-radius: 4px;
}

.emoji-picker-grid button {
    background: transparent;
    border: none;
    font-size: 1.5rem;
    width: 36px;
    height: 36px;
    cursor: pointer;
    border-radius: 8px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Segoe UI Emoji", "Apple Color Emoji", "Noto Color Emoji", sans-serif;
    line-height: 1;

    transition: none;
}

.emoji-picker-grid button:hover {
    background-color: var(--header-bg-hover);
}

/* Embedded mode adjustments */
body.embedded-mode .emoji-picker-modal {
    width: 95%;
    max-width: none;
    height: 85%;
    max-height: none;
}

/* Emoji Filter Button */
.emoji-filter-btn {
    font-family: "Segoe UI Emoji", "Apple Color Emoji", "Noto Color Emoji", sans-serif;
    font-size: 1.25rem;
    min-width: 44px;
    height: 44px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
}

.emoji-filter-btn.active {
    border-color: var(--accent-blue);
    background-color: var(--header-bg-hover);
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2);
}

/* Emoji Filter Dropdown */
.emoji-filter-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: 8px;
    background-color: var(--bg-dropdown);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
    z-index: 10000;
    min-width: 260px;
    max-width: 320px;
    padding: 12px;
    animation: fadeIn 0.15s ease-out;
}

.emoji-filter-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--divider);
    margin-bottom: 10px;
}

.emoji-filter-header span {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-primary);
}

.emoji-filter-close {
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: 1.2rem;
    cursor: pointer;
    padding: 4px;
    line-height: 1;
    border-radius: 4px;
    transition: all 0.2s;
}

.emoji-filter-close:hover {
    background-color: var(--danger);
    color: white;
}

.emoji-filter-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    max-height: 200px;
    overflow-y: auto;
    padding: 4px 0;
}

.emoji-filter-list::-webkit-scrollbar {
    width: 6px;
}

.emoji-filter-list::-webkit-scrollbar-thumb {
    background-color: var(--border-color);
    border-radius: 10px;
}

.emoji-filter-option {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background-color: var(--bg-app);
    cursor: pointer;
    font-size: 0.85rem;
    color: var(--text-primary);
    transition: all 0.2s;
    font-family: "Segoe UI Emoji", "Apple Color Emoji", "Noto Color Emoji", sans-serif;
}

.emoji-filter-option:hover {
    background-color: var(--header-bg-hover);
    border-color: var(--accent-blue);
}

.emoji-filter-option.selected {
    background-color: var(--accent-blue);
    color: white;
    border-color: var(--accent-blue);
}

.emoji-filter-option .emoji-count {
    font-size: 0.75rem;
    opacity: 0.7;
}

.emoji-filter-clear {
    width: 100%;
    margin-top: 10px;
    padding: 8px;
    background: var(--bg-app);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.2s;
}

.emoji-filter-clear:hover {
    background: var(--accent-blue);
    color: white;
    border-color: var(--accent-blue);
}

.emoji-filter-empty {
    text-align: center;
    padding: 20px;
    color: var(--text-secondary);
    font-size: 0.85rem;
}

.emoji-filter-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 9999;
}

/* Custom Radio Buttons */
.custom-radio {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-size: 0.9rem;
    color: var(--text-primary);
    margin-bottom: 8px;
    padding: 6px 8px;
    border-radius: 6px;
    transition: background-color 0.2s;
}

.custom-radio:hover {
    background-color: rgba(0, 0, 0, 0.05);
}

.custom-radio input[type="radio"] {
    display: none;
}

.radio-indicator {
    width: 18px;
    height: 18px;
    border: 2px solid var(--text-secondary);
    border-radius: 50%;
    margin-right: 10px;
    position: relative;
    transition: all 0.2s;
    flex-shrink: 0;
}

.custom-radio input[type="radio"]:checked+.radio-indicator {
    border-color: var(--accent-blue);
    background-color: var(--accent-blue);
}

.custom-radio input[type="radio"]:checked+.radio-indicator::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 6px;
    height: 6px;
    background-color: white;
    border-radius: 50%;
}

/* Tooltip Styles */
.info-tooltip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background-color: var(--text-secondary);
    color: var(--bg-card);
    font-size: 10px;
    font-weight: bold;
    margin-left: 8px;
    cursor: help;
    opacity: 0.7;
    transition: opacity 0.2s;
    position: relative;
}

.info-tooltip:hover {
    opacity: 1;
}

/* Tooltip Text */
.info-tooltip::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 150%;
    left: 50%;
    transform: translateX(-50%);
    background-color: #333;
    color: white;
    padding: 6px 10px;
    border-radius: 4px;
    font-size: 0.75rem;
    white-space: normal;
    width: max-content;
    max-width: 200px;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s;
    pointer-events: none;
    z-index: 1000;
    text-align: center;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    font-weight: normal;
    line-height: 1.4;
}

.info-tooltip:hover::after {
    opacity: 1;
    visibility: visible;
    bottom: 125%;
}

/* Tooltip Arrow - Points down to element */
.info-tooltip::before {
    content: '';
    position: absolute;
    bottom: 115%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: #333;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s, visibility 0.2s;
}

.info-tooltip:hover::before {
    opacity: 1;
    visibility: visible;
}

#global-tooltip.visible {
    opacity: 1;
    visibility: visible;
}

/* Scroll to Top Button */
.scroll-to-top-btn {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(60, 60, 60, 0.9);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.7);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.scroll-to-top-btn.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.scroll-to-top-btn:hover {
    background: rgba(80, 80, 80, 0.95);
    color: rgba(255, 255, 255, 0.9);
    border-color: rgba(255, 255, 255, 0.2);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.scroll-to-top-btn:active {
    transform: translateY(0);
}

.scroll-to-top-btn svg {
    transition: transform 0.2s ease;
}

.scroll-to-top-btn:hover svg {
    transform: translateY(-1px);
}

/* ================================================
   Tab Context Menu
   ================================================ */
.tab-context-menu {
    position: fixed;
    z-index: 10001;
    background: var(--bg-dropdown);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
    min-width: 180px;
    padding: 6px 0;
    animation: contextMenuFadeIn 0.15s ease;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

@keyframes contextMenuFadeIn {
    from {
        opacity: 0;
        transform: scale(0.95);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

.tab-context-menu-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    cursor: pointer;
    color: var(--text-primary);
    font-size: 0.9rem;
    transition: all 0.15s ease;
    background: transparent;
    border: none;
    width: 100%;
    text-align: left;
}

.tab-context-menu-item:hover {
    background-color: var(--header-bg-hover);
    color: var(--accent-blue);
}

.tab-context-menu-item svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    opacity: 0.7;
}

.tab-context-menu-item:hover svg {
    opacity: 1;
}

.tab-context-menu-divider {
    height: 1px;
    background-color: var(--divider);
    margin: 4px 10px;
}

.tab-context-backdrop {
    position: fixed;
    inset: 0;
    z-index: 10000;
}

/* Embedded Mode: Constrain context menu to viewport */
body.embedded-mode .tab-context-menu {
    max-height: calc(100vh - 20px);
    overflow-y: auto;
}

/* ================================================
   Tab Note Indicator & Preview
   ================================================ */
.link-title-row {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    max-width: 100%;
}

.link-title-row .link-text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex-shrink: 1;
    min-width: 0;
}

.note-indicator {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    color: var(--accent-blue);
    opacity: 0.8;
    flex-shrink: 0;
    cursor: pointer;
    position: relative;
    transition: opacity 0.2s, transform 0.2s;
}

.note-indicator:hover {
    opacity: 1;
    transform: scale(1.15);
}

.note-indicator svg {
    width: 13px;
    height: 13px;
}

/* Note Preview Tooltip - JS Based (to avoid overflow issues) */
.custom-tooltip {
    position: fixed;
    background: var(--bg-dropdown);
    color: var(--text-primary);
    padding: 8px 12px;
    border-radius: 8px;
    font-size: 0.8rem;
    white-space: pre-wrap;
    max-width: 280px;
    z-index: 10000;
    text-align: left;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
    border: 1px solid var(--border-color);
    line-height: 1.4;
    word-wrap: break-word;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s ease;
}

.custom-tooltip.visible {
    opacity: 1;
}

/* ================================================
   Note Modal
   ================================================ */
.note-modal-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 10001;
    animation: fadeIn 0.15s ease-out;
}

.note-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90vw;
    max-width: 500px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
    z-index: 10002;
    display: flex;
    flex-direction: column;
    animation: fadeInModal 0.2s ease-out;
    overflow: hidden;
}

.note-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 18px;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-card-header);
}

.note-modal-header span {
    font-weight: 600;
    font-size: 1rem;
    color: var(--text-primary);
}

.note-modal-close {
    background: var(--divider);
    border: none;
    color: var(--text-primary);
    font-size: 0.9rem;
    cursor: pointer;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    opacity: 0.7;
}

.note-modal-close:hover {
    background-color: var(--danger);
    color: white;
    opacity: 1;
    transform: rotate(90deg);
}

.note-modal-content {
    padding: 16px 18px;
}

.note-modal-textarea {
    width: 100%;
    min-height: 150px;
    max-height: 300px;
    padding: 12px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-app);
    color: var(--text-primary);
    font-size: 0.9rem;
    font-family: inherit;
    resize: vertical;
    line-height: 1.5;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.note-modal-textarea:focus {
    outline: none;
    border-color: var(--accent-blue);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}

.note-modal-textarea::placeholder {
    color: var(--text-secondary);
    opacity: 0.7;
}

.note-modal-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 18px;
    border-top: 1px solid var(--border-color);
    background: var(--bg-card-header);
}

.note-modal-actions {
    display: flex;
    gap: 10px;
}

.note-modal-cancel {
    padding: 8px 16px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: transparent;
    color: var(--text-primary);
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.2s;
}

.note-modal-cancel:hover {
    background: var(--header-bg-hover);
}

.note-modal-save {
    padding: 8px 20px;
    border: none;
    border-radius: 6px;
    background: var(--accent-blue);
    color: white;
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}

.note-modal-save:hover {
    background: #2563eb;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}

.note-modal-delete {
    padding: 8px 16px;
    border: 1px solid var(--danger);
    border-radius: 6px;
    background: transparent;
    color: var(--danger);
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.2s;
}

.note-modal-delete:hover {
    background: var(--danger);
    color: white;
}

/* ================================================
   Pinned Tab Styles
   ================================================ */
.link-item.pinned {
    position: relative;
    background: linear-gradient(135deg,
            rgba(59, 130, 246, 0.08) 0%,
            rgba(59, 130, 246, 0.03) 100%);
    border-left: 3px solid var(--accent-blue);
    margin-left: 8px;
    margin-right: 8px;
    border-radius: 8px;
}

.link-item.pinned::before {
    background: linear-gradient(135deg,
            rgba(59, 130, 246, 0.12) 0%,
            rgba(59, 130, 246, 0.05) 100%);
}

.link-item.pinned:hover::before {
    background: linear-gradient(135deg,
            rgba(59, 130, 246, 0.18) 0%,
            rgba(59, 130, 246, 0.08) 100%);
}

.pinned-indicator {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    margin-right: 8px;
    color: var(--accent-blue);
    flex-shrink: 0;
    opacity: 0.8;
}

.pinned-indicator svg {
    width: 14px;
    height: 14px;
    transform: rotate(45deg);
}

/* Hide delete button on pinned items */
.link-item.pinned .delete-link-btn {
    display: none;
}

/* Pinned section separator */
.pinned-separator {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 16px;
    margin: 4px 0;
    color: var(--text-secondary);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.pinned-separator::before,
.pinned-separator::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--divider);
}

/* Custom Checkbox (matching Radio Button data) */
.custom-checkbox {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-size: 0.9rem;
    color: var(--text-primary);
    margin: 0;
}

.custom-checkbox input[type="checkbox"] {
    display: none;
}

.checkbox-indicator {
    width: 18px;
    height: 18px;
    border: 2px solid var(--text-secondary);
    border-radius: 4px;
    /* Slightly squarer than radio */
    margin-right: 10px;
    position: relative;
    transition: all 0.2s;
    flex-shrink: 0;
}

.custom-checkbox:hover .checkbox-indicator {
    border-color: var(--accent-blue);
}

.custom-checkbox input[type="checkbox"]:checked+.checkbox-indicator {
    border-color: var(--accent-blue);
    background-color: var(--accent-blue);
}

.custom-checkbox input[type="checkbox"]:checked+.checkbox-indicator::after {
    content: "";
    /* Checkmark */
    position: absolute;
    left: 5px;
    top: 1px;
    width: 4px;
    height: 9px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

/* Emoji Picker Sections */
.emoji-section {
    margin-bottom: 12px;
}

.emoji-section-label {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-bottom: 6px;
    padding-left: 2px;
}

.emoji-section-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(32px, 1fr));
    gap: 4px;
}

.emoji-section-grid button {
    background: transparent;
    border: 1px solid transparent;
    cursor: pointer;
    font-size: 1.5rem;
    padding: 4px;
    border-radius: 6px;
    transition: background 0.2s, transform 0.1s;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Segoe UI Emoji", "Apple Color Emoji", "Noto Color Emoji", sans-serif;
}

.emoji-section-grid button:hover {
    background: var(--header-bg-hover);
    border-color: var(--border-color);
    transform: scale(1.1);
}


/* Duplicate Manager Styles */

.duplicates-list::-webkit-scrollbar {
    width: 8px;
}

.duplicates-list::-webkit-scrollbar-track {
    background: transparent;
}

.duplicates-list::-webkit-scrollbar-thumb {
    background-color: var(--scrollbar-thumb);
    border-radius: 4px;
}

.duplicate-set {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    margin-bottom: 10px;
    overflow: hidden;
}

.duplicate-set-header {
    padding: 8px 12px;
    background: var(--header-bg-hover);
    border-bottom: 1px solid var(--border-color);
    font-weight: 600;
    font-size: 0.9em;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.duplicate-set-header .url {
    color: var(--text-secondary);
    font-weight: normal;
    font-size: 0.85em;
    margin-left: 10px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 300px;
}

.duplicate-items {
    padding: 5px 0;
}

.duplicate-item {
    display: flex;
    align-items: center;
    padding: 8px 12px;
    border-bottom: 1px solid var(--border-color);
    font-size: 0.9em;
}

.duplicate-item:last-child {
    border-bottom: none;
}

.duplicate-item:hover {
    background: var(--bg-hover);
}

.duplicate-item-info {
    flex: 1;
    margin-left: 10px;
    min-width: 0;
}

.duplicate-item input[type="checkbox"] {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    cursor: pointer;
    accent-color: var(--accent-blue);
}

.duplicate-group-name {
    font-weight: 500;
}

.duplicate-group-date {
    color: var(--text-secondary);
    font-size: 0.85em;
    margin-left: 5px;
}

.duplicate-item.kept {
    opacity: 0.6;
    text-decoration: none;
    /* Just distinguish visualy */
}

.duplicate-item.to-delete {
    background: rgba(255, 0, 0, 0.05);
}

.duplicate-item.to-delete .duplicate-group-name {
    text-decoration: line-through;
    color: var(--danger-color);
}

/* ================================================
   Embedded Mode (Popup iframe) Styles
   ================================================ */



/* Constrain settings dropdown width and position */
body.embedded-mode #settings-btn+.dropdown-menu {
    max-width: 260px;
    right: 0;
}

/* Custom scrollbar for dropdown in embedded mode */
body.embedded-mode .dropdown-menu::-webkit-scrollbar {
    width: 6px;
}

body.embedded-mode .dropdown-menu::-webkit-scrollbar-track {
    background: transparent;
}

body.embedded-mode .dropdown-menu::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 3px;
}

body.embedded-mode .dropdown-menu::-webkit-scrollbar-thumb:hover {
    background: var(--text-secondary);
}


/* Organizer Modal */
.organizer-content {
    width: 95%;
    height: 90vh;
    max-width: 1400px;
    /* Wide format */
    display: flex;
    flex-direction: column;
    padding: 0;
    /* Reset padding for full height handling */
    overflow: hidden;
    /* Prevent modal itself from scrolling */
}

.organizer-header-row {
    padding: 4px 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-bottom: 1px solid var(--border-color);
    position: relative;
}

.organizer-desc {
    padding: 0 !important;
    color: var(--text-secondary);
    margin: 0 !important;
    border-bottom: none;
    font-size: 0.85rem;
    line-height: 1;
    text-align: center;
}

/* Close button specific to organizer to fit in compact header */
#organizer-close {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: 1.2rem;
    cursor: pointer;
    padding: 0;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

#organizer-close:hover {
    color: var(--text-primary);
}

.organizer-split-view {
    flex: 1;
    display: flex;
    overflow: hidden;
    /* Container doesn't scroll, columns do */
    background: var(--bg-app);
}

.organizer-column {
    flex: 1;
    display: flex;
    flex-direction: column;
    border-right: 1px solid var(--border-color);
    min-width: 0;
    /* Flexbox trick */
}

.organizer-column:last-child {
    border-right: none;
}

.organizer-col-header {
    padding: 5px 10px;
    background: var(--bg-app);
    border-bottom: 1px solid var(--border-color);
}

.org-group-drag-handle {
    cursor: grab;
    color: var(--text-tertiary);
    margin-right: 8px;
    display: flex;
    align-items: center;
    opacity: 0.5;
    transition: opacity 0.2s;
    user-select: none;
    -webkit-user-select: none;
}

.org-group-drag-handle svg {
    pointer-events: none;
    width: 16px;
    height: 16px;
}

.org-group-drag-handle:hover {
    opacity: 1;
    color: var(--text-primary);
}

.org-group-drag-handle:active {
    cursor: grabbing;
}

.org-group.group-dragging {
    opacity: 0.5;
    background: var(--bg-hover);
}

.org-group.group-drag-over-top {
    border-top: 2px solid var(--accent-blue) !important;
}

.org-group.group-drag-over-bottom {
    border-bottom: 2px solid var(--accent-blue) !important;
}

body.group-dragging-active .org-group * {
    pointer-events: none;
    /* Disable inner events while dragging group */
}

body.group-dragging-active .org-group {
    pointer-events: auto;
    /* Re-enable for the group itself */
}

body.group-dragging-active .org-group-drag-handle {
    pointer-events: auto !important;
    /* Keep handle interactive to maintain drag state */
}

.organizer-search {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--bg-app);
    color: var(--text-primary);
    font-size: 0.9rem;
}

.organizer-search:focus {
    outline: none;
    border-color: var(--accent-blue);
    box-shadow: 0 0 0 2px rgba(49, 130, 206, 0.2);
}

.organizer-list {
    flex: 1;
    overflow-y: auto;
    padding: 12px;
    /* Custom scrollbar matching dashboard */
}

/* Compact Group in Organizer */
.org-group {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    margin-bottom: 8px;
    transition: all 0.2s;
}

.org-group:hover {
    border-color: var(--accent-blue);
}

.org-group-header {
    padding: 10px 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    background: var(--bg-card);
    border-radius: 8px;
    /* If collapsed */
    user-select: none;
}

/* If expanded, fix radius */
.org-group.expanded .org-group-header {
    border-bottom: 1px solid var(--border-color);
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    background: var(--header-bg-hover);
}

.org-group-title {
    font-weight: 500;
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-right: 10px;
}

.org-group-meta {
    font-size: 0.8em;
    color: var(--text-secondary);
    display: flex;
    gap: 8px;
    align-items: center;
}

.org-chevron {
    font-size: 0.7em;
    transition: transform 0.2s ease;
    color: var(--text-secondary);
}

.org-chevron.expanded {
    transform: rotate(90deg);
}

.org-tabs-container {
    display: none;
    padding: 4px 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
}

.org-group.expanded .org-tabs-container {
    display: block;
    max-height: 500px;
    /* ~14 tabs visible, scroll for more */
    overflow-y: auto;
    padding: 4px 0;
    min-height: 40px;
    /* Ensure drop space for empty groups */
}

.org-tabs-container.drag-over-container {
    background: rgba(49, 130, 206, 0.05);
    border: 2px dashed var(--accent-blue);
    border-radius: 6px;
}

/* Compact Tab Item */
.org-tab {
    padding: 6px 12px;
    display: flex;
    align-items: center;
    gap: 8px;
    border-bottom: 1px solid var(--divider);
    cursor: grab;
    background: var(--bg-card);
}

.org-tab:last-child {
    border-bottom: none;
}

.org-tab:hover {
    background: var(--header-bg-hover);
}

.org-tab-favicon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

.org-tab-title {
    flex: 1;
    font-size: 0.9em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--text-primary);
}

.org-tab.dragging {
    opacity: 0.5;
    background: var(--bg-app);
}

/* Drop targets */
.org-group.drag-over {
    border: 2px dashed var(--accent-blue);
    background: rgba(49, 130, 206, 0.1);
}

.org-group-header.drag-over-header {
    background: rgba(49, 130, 206, 0.15);
    border-color: var(--accent-blue);
    color: var(--accent-blue);
}

/* Modal footer override */
.modal-content.organizer-content .modal-actions {
    margin-top: 0;
    padding: 15px 20px;
    border-top: 1px solid var(--border-color);
    background: var(--bg-app);
    flex-direction: row;
    justify-content: flex-end;
    gap: 10px;
}


/* Tab drop target indicator */
.org-tab.drag-over-tab {
    background: rgba(49, 130, 206, 0.1);
    border-top: 2px solid var(--accent-blue);
}

/* Organizer Trash Drop Zone (Footer) */
.organizer-trash-zone {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 40px;
    border-radius: 8px;
    background: var(--bg-secondary);
    border: 1px dashed var(--border-color);
    color: var(--text-tertiary);
    opacity: 0.6;
    transition: all 0.3s ease;
    cursor: default;
    margin: 0 auto;
    flex-shrink: 0;
}

/* Make fully visible on hover so tooltip is clear */
.organizer-trash-zone:hover {
    opacity: 1;
}

.organizer-trash-zone svg {
    transition: transform 0.2s ease, color 0.2s ease;
}

/* When dragging is active, highlight the trash zone */
body.org-dragging-active .organizer-trash-zone {
    opacity: 1;
    width: 120px;
    background: linear-gradient(135deg, var(--bg-secondary) 0%, rgba(239, 68, 68, 0.08) 100%);
    border-color: var(--text-secondary);
    border-style: dashed;
    color: var(--text-secondary);
    animation: trash-pulse 1.5s ease-in-out infinite;
}

@keyframes trash-pulse {

    0%,
    100% {
        border-color: var(--text-secondary);
        background: linear-gradient(135deg, var(--bg-secondary) 0%, rgba(239, 68, 68, 0.08) 100%);
    }

    50% {
        border-color: #ef4444;
        background: linear-gradient(135deg, var(--bg-secondary) 0%, rgba(239, 68, 68, 0.15) 100%);
    }
}

/* Hover state when dragging over */
.organizer-trash-zone.drag-over {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.2) 0%, rgba(239, 68, 68, 0.3) 100%) !important;
    color: #ef4444;
    border-color: #ef4444 !important;
    border-style: solid !important;
    animation: none;
    transform: scale(1.05);
}

.organizer-trash-zone.drag-over svg {
    transform: scale(1.15);
    color: #ef4444;
}

/* Organizer footer layout */
.organizer-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* Organizer Undo Button */
.organizer-undo-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 8px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s ease;
    margin-left: 8px;
}

.organizer-undo-btn:hover:not(:disabled) {
    background: var(--header-bg-hover);
    color: var(--accent-blue);
    border-color: var(--accent-blue);
}

.organizer-undo-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Also highlight trash when dragging groups */
body.group-dragging-active .organizer-trash-zone {
    opacity: 1;
    width: 120px;
    background: linear-gradient(135deg, var(--bg-secondary) 0%, rgba(239, 68, 68, 0.08) 100%);
    border-color: var(--text-secondary);
    border-style: dashed;
    color: var(--text-secondary);
    animation: trash-pulse 1.5s ease-in-out infinite;
}

/* Tools dropdown section - Force vertical stack */
.dropdown-section {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.dropdown-action-btn {
    width: 100%;
    text-align: left;
}

/* Organizer Sort Button */
.org-sort-btn {
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--text-secondary);
    /* Using var for consistency */
    padding: 4px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    margin-right: 8px;
    transition: all 0.2s;
    opacity: 0.7;
}

.org-sort-btn:hover {
    background-color: var(--bg-hover);
    /* Using var for consistency */
    color: var(--text-primary);
    opacity: 1;
}

/* Organizer Sort Menu */
.org-sort-menu {
    position: fixed;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 4px 0;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    z-index: 10000;
    min-width: 140px;
    display: flex;
    flex-direction: column;
}

.org-sort-item {
    padding: 8px 12px;
    cursor: pointer;
    font-size: 0.9em;
    color: var(--text-primary);
    transition: background 0.2s;
    user-select: none;
}

.org-sort-item:hover {
    background-color: var(--header-bg-hover);
    color: var(--accent-blue);
}

/* ================================================
   Group Tag Widget (Horizontal Expansion)
   ================================================ */

/* Wrapper to anchor the absolute widget */
.tag-widget-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    /* Reserve space for the absolute widget (icon width + border) */
    min-width: 34px;
    height: 32px;
    z-index: 101;
    /* Ensure higher than siblings if needed */
}

.group-tag-widget {
    display: flex;
    align-items: center;
    background-color: transparent;
    border-radius: 6px;
    height: 32px;
    transition: max-width 0.3s cubic-bezier(0.25, 0.8, 0.25, 1),
        background-color 0.3s cubic-bezier(0.25, 0.8, 0.25, 1),
        border-color 0.3s cubic-bezier(0.25, 0.8, 0.25, 1),
        box-shadow 0.3s cubic-bezier(0.25, 0.8, 0.25, 1),
        padding 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    will-change: max-width;
    transform: translateZ(0);
    /* GPU acceleration to prevent subpixel flickering */
    max-width: 34px;
    /* Default width (icon only) */
    overflow: hidden;
    border: 1px solid transparent;
    /* Prevent jump on expand */
    flex-direction: row-reverse;
    /* Reverse items: [Actions] [Input] [Emoji] */
    flex-shrink: 0;
    order: 2;
    /* Appear after preview badge */
    /* Always absolute to prevent flow changes when toggling visibility */
    position: absolute;
    right: 0;
    top: 0;
}

/* Expanded state - Overlay mode */
.group-tag-widget.expanded {
    position: absolute;
    right: 0;
    top: 0;
    max-width: 400px;
    /* Max width when expanded */
    background-color: var(--bg-card);
    /* White/Dark bg */
    border-color: var(--accent-blue);
    /* Blue border like snippet */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    padding-left: 4px;
    /* Changed from right to left due to reversal */
    z-index: 100;
}

/* Left Emoji Button within Widget */
.tag-widget-emoji-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1.2rem;
    padding: 0;
    flex-shrink: 0;
    color: var(--text-secondary);
    transition: background 0.2s;
    border-radius: 0 4px 4px 0;
    /* Rounded on right now */
}

.tag-widget-emoji-btn:hover {
    background-color: var(--header-bg-hover);
    color: var(--text-primary);
}

/* Container for Chips and Input */
.tag-input-container {
    display: flex;
    align-items: center;
    flex: 1;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0 4px;
    gap: 4px;
    height: 100%;
}

/* Hide scrollbar in input container */
.tag-input-container::-webkit-scrollbar {
    height: 0px;
    background: transparent;
}

/* Tag Chip */
.tag-chip {
    display: inline-flex;
    align-items: center;
    background-color: var(--accent-blue);
    color: white;
    font-size: 0.8rem;
    padding: 2px 6px;
    border-radius: 4px;
    white-space: nowrap;
    height: 22px;
    max-width: 120px;
}

.tag-chip span {
    overflow: hidden;
    text-overflow: ellipsis;
}

.tag-chip-remove {
    background: none;
    border: none;
    color: white;
    margin-left: 4px;
    cursor: pointer;
    font-size: 12px;
    padding: 0;
    display: flex;
    align-items: center;
    opacity: 0.8;
}

.tag-chip-remove:hover {
    opacity: 1;
}

/* Text Input Mechanism */
.tag-input-field {
    border: none;
    background: transparent;
    outline: none;
    color: var(--text-primary);
    font-size: 0.9rem;
    min-width: 60px;
    flex: 1;
    height: 100%;
}

/* Action Buttons (Cancel / Confirm) */
.tag-widget-actions {
    display: flex;
    align-items: center;
    gap: 2px;
    padding-right: 4px;
    border-right: 1px solid var(--divider);
    height: 20px;
    margin-right: 4px;
    padding-left: 0;
    border-left: none;
    margin-left: 0;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s 0.1s;
    /* Delay appearance */
}

.group-tag-widget.expanded .tag-widget-actions {
    opacity: 1;
    pointer-events: auto;
}

.tag-action-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 14px;
    padding: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    border-radius: 4px;
    width: 20px;
    height: 20px;
}

.tag-action-btn:hover {
    background-color: var(--header-bg-hover);
}

.tag-action-btn.confirm:hover {
    color: #48bb78;
    /* Green */
}

.tag-action-btn.cancel:hover {
    color: var(--danger);
}

/* Tag Preview Styles */
.tag-preview {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    /* margin-right set dynamically by JS based on emoji presence */
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    font-size: 0.85em;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s ease;
    vertical-align: middle;
    max-width: 10ch;
    /* ~10 chars for compact mode */
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.tag-preview:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
    border-color: var(--accent-color);
}

.tag-preview-tooltip {
    position: fixed;
    background: var(--bg-overlay, #333);
    color: white;
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 0.85em;
    z-index: 10000;
    pointer-events: none;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    max-width: 250px;
    word-wrap: break-word;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

/* Emoji Filter Search */
.emoji-filter-search-container {
    padding: 8px 12px;
}

.emoji-filter-search {
    width: 100%;
    padding: 6px 10px;
    border-radius: 6px;
    border: 1px solid var(--border-color);
    background-color: var(--bg-app);
    color: var(--text-primary);
    font-size: 0.9rem;
    outline: none;
    transition: box-shadow 0.2s, border-color 0.2s;
}

.emoji-filter-search:focus {
    border-color: var(--accent-blue);
    box-shadow: 0 0 0 2px rgba(49, 130, 206, 0.2);
}

/* Adjust list max-height to account for search bar */
.emoji-filter-list {
    max-height: 250px;
    /* overflow-y handled by existing class if present, otherwise need to check */
    overflow-y: auto;
    padding: 4px 0;
}

/* Tooltip Text - DISABLED (Moved to JS Portal) */
.info-tooltip::after,
.info-tooltip::before {
    display: none !important;
}

/* Global JS Tooltip */
#global-tooltip {
    position: fixed;
    background-color: #333;
    color: white;
    padding: 6px 10px;
    border-radius: 4px;
    font-size: 0.75rem;
    white-space: normal;
    max-width: 200px;
    pointer-events: none;
    z-index: 10000;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    font-weight: normal;
    line-height: 1.4;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s, visibility 0.2s;
    text-align: center;
}

#global-tooltip.visible {
    opacity: 1;
    visibility: visible;
}

/* Arrow for global tooltip - Points down to element */
#global-tooltip::before {
    content: '';
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: #333;
}

/* Custom Immediate Tooltip */
.has-tooltip {
    position: relative;
}

.has-tooltip:hover::after {
    content: attr(data-tooltip);
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    background: #2d3748;
    color: white;
    padding: 6px 10px;
    border-radius: 4px;
    font-size: 0.75rem;
    white-space: nowrap;
    z-index: 99999;
    pointer-events: none;
    margin-top: 8px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15);
    font-weight: 500;
}

.has-tooltip:hover::before {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-bottom-color: #2d3748;
    z-index: 99999;
    pointer-events: none;
    margin-top: -2px;
}

/* Tooltip Top Variation (Appears Above) */
.tooltip-top {
    position: relative;
}

.tooltip-top:hover::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    background: #1a1a1a;
    color: #fff;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 0.8rem;
    white-space: nowrap;
    z-index: 99999;
    pointer-events: none;
    margin-bottom: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    font-weight: 500;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.tooltip-top:hover::before {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: #1a1a1a;
    z-index: 99999;
    pointer-events: none;
    margin-bottom: -4px;
}

/* Hide Wide Mode in embedded/popup view */
body.embedded-mode .wide-mode-section {
    display: none !important;
}

/* ================================================
   Wide Mode Enhancements
   ================================================ */

/* Show full group name in wide mode (no ellipsis) */
body.wide-mode .group-name {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
}

/* Increase tag preview size in wide mode */
body.wide-mode .tag-preview {
    font-size: 0.95rem;
    /* Larger than default */
    padding: 3px 10px;
    /* Slightly larger padding */
    max-width: 300px;
    /* Allow much more text in wide mode */
}

/* Fix for Group Name wrapping in Wide Mode */
body.wide-mode .group-name-container {
    max-width: none;
}

body.wide-mode .group-name {
    max-width: none;
}

/* Increase tooltip text size in wide mode */
body.wide-mode .tag-preview-tooltip {
    font-size: 0.95rem;
}

/* Tooltip Arrow Styles */
.custom-tooltip::after,
.tag-preview-tooltip::after {
    content: '';
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    border-width: 6px;
    border-style: solid;
    border-color: transparent;
}

/* Arrow for Top Position (Tooltip above, arrow points down) */
.custom-tooltip.tooltip-top::after {
    top: 100%;
    border-color: var(--bg-dropdown) transparent transparent transparent;
}

/* Arrow for Bottom Position (Tooltip below, arrow points up) */
.custom-tooltip.tooltip-bottom::after {
    bottom: 100%;
    border-color: transparent transparent var(--bg-dropdown) transparent;
}

/* Ensure border matches if tooltip has border */
.custom-tooltip.tooltip-top::before {
    content: '';
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 100%;
    border-width: 7px;
    border-style: solid;
    border-color: var(--border-color) transparent transparent transparent;
    z-index: -1;
}

.custom-tooltip.tooltip-bottom::before {
    content: '';
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 100%;
    border-width: 7px;
    border-style: solid;
    border-color: transparent transparent var(--border-color) transparent;
    z-index: -1;
}

/* Fix for emoji filter button overflow - Allow expansion in ALL modes */
.emoji-filter-btn,
.emoji-filter-btn.icon-btn {
    width: auto !important;
    height: auto !important;
    min-width: 44px !important;
    min-height: 44px !important;
    max-width: 300px !important;
    /* Safety cap */
    padding: 0 12px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    aspect-ratio: auto !important;
    display: inline-flex !important;
    justify-content: center !important;
}

/* Prevent tag-preview font size from affecting the filter button */
.emoji-filter-btn,
#emoji-filter-btn {
    font-size: 1rem !important;
    line-height: normal !important;
}

/* Undo Toast Notification */
.undo-toast {
    position: fixed;
    bottom: 100px;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    background-color: #3A3A3A;
    /* Pure neutral dark gray - no blue tint */
    color: #E2E8F0;
    padding: 12px 20px;
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow), 0 0 0 1px var(--border-color);
    display: flex;
    align-items: center;
    gap: 12px;
    z-index: 10000;
    font-size: 0.9rem;
    opacity: 0;
    transition: opacity 0.25s ease, transform 0.25s ease;
    pointer-events: none;
}

.undo-toast.show {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
}

.undo-toast span {
    display: flex;
    align-items: center;
    gap: 6px;
}

.undo-toast button {
    background-color: var(--accent-blue);
    border: none;
    color: #ffffff;
    padding: 6px 14px;
    border-radius: 6px;
    cursor: pointer;
    font-weight: 600;
    font-size: 0.8rem;
    transition: background-color 0.15s, transform 0.1s;
}

.undo-toast button:hover {
    filter: brightness(1.1);
}

.undo-toast button:active {
    transform: scale(0.97);
}

/* Progress bar for undo toast */
.undo-toast-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent-blue), #63b3ed);
    border-radius: 0 0 var(--card-radius) var(--card-radius);
    width: 100%;
    transform-origin: left;
    animation: undo-progress-shrink var(--undo-duration, 30s) linear forwards;
}

@keyframes undo-progress-shrink {
    from {
        transform: scaleX(1);
    }

    to {
        transform: scaleX(0);
    }
}

/* ================================================
   Sidebar Mode Styles
   These styles ONLY affect the sidebar view (.sidebar-mode)
   ================================================ */

/* Base sidebar adjustments */
body.sidebar-mode {
    --container-padding: 0.5rem;
    overflow-y: auto;
    height: 100vh;
}

body.sidebar-mode .container {
    padding: var(--container-padding);
    max-width: 100%;
}

/* ---- HEADER SIMPLIFICATION ---- */
body.sidebar-mode header {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    padding-bottom: 0.5rem;
}

body.sidebar-mode header>div:first-child {
    width: 100%;
}

/* Hide header subtitle */
body.sidebar-mode header p {
    display: none !important;
}

/* Simplify header title */
body.sidebar-mode h1 {
    font-size: 1.1rem;
}

/* Hide the entire header-actions row (contains all the buttons) */
body.sidebar-mode .header-actions {
    display: none !important;
}

/* ---- HIDE NON-ESSENTIAL ELEMENTS ---- */
body.sidebar-mode #search-section,
body.sidebar-mode #export-dropdown,
body.sidebar-mode #about-btn,
body.sidebar-mode #help-btn,
body.sidebar-mode #theme-toggle,
body.sidebar-mode #language-btn,
body.sidebar-mode .wide-mode-section,
body.sidebar-mode #settings-btn {
    display: none !important;
}

/* ---- GROUP CARD SIMPLIFICATION ---- */
body.sidebar-mode .group-card {
    border-radius: 6px;
    margin-bottom: 0.75rem;
}

body.sidebar-mode .group-header {
    padding: 8px 10px;
    flex-wrap: nowrap;
    gap: 4px;
}

body.sidebar-mode .group-title-row {
    flex-wrap: wrap;
    flex: 1;
    min-width: 0;
}

/* ---- GROUP ACTIONS: Keep only essential buttons ---- */
body.sidebar-mode .group-actions {
    gap: 4px;
    flex-wrap: nowrap;
}

/* Hide move up/down, tag widget, 3-dot menu, and group name in sidebar */
body.sidebar-mode .group-actions .tag-widget-wrapper,
body.sidebar-mode .group-actions .action-btn[title*="Move"],
body.sidebar-mode .group-actions .action-btn[title*="Mover"],
body.sidebar-mode .group-actions .group-menu-wrapper,
body.sidebar-mode .collapse-wrapper,
body.sidebar-mode .group-name-container {
    display: none !important;
}

/* Keep only restore and delete visible */
body.sidebar-mode .restore-wrapper,
body.sidebar-mode .action-btn.delete {
    display: flex !important;
}

/* Position hover menus below the button in sidebar (space is limited above) */
body.sidebar-mode .restore-hover-menu,
body.sidebar-mode .collapse-hover-menu {
    bottom: auto;
    top: 100%;
    left: auto;
    right: -15px;
    transform: none;
    min-width: 120px;
    margin-bottom: 0;
    margin-top: 4px;
    animation: none;
}

/* Prevent horizontal overflow in sidebar */
body.sidebar-mode {
    overflow-x: hidden;
}

/* Bridge to prevent menu from closing when moving cursor down */
body.sidebar-mode .restore-wrapper::after,
body.sidebar-mode .collapse-wrapper::after {
    bottom: auto;
    top: 100%;
    height: 8px;
}

/* ---- LINK ITEMS ---- */
body.sidebar-mode .link-item {
    padding: 8px 10px;
}

body.sidebar-mode .link-text {
    font-size: 0.85rem;
}

/* Separate context menu button from delete button */
body.sidebar-mode .context-menu-btn {
    margin-right: 32px;
}

/* ---- PAGINATION ---- */
body.sidebar-mode .pagination {
    flex-wrap: wrap;
    justify-content: center;
    gap: 4px;
}

/* ---- USER DROPDOWN ---- */
body.sidebar-mode #user-dashboard-dropdown {
    margin-left: 0;
}

body.sidebar-mode #user-dashboard-dropdown .dropdown-menu {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: auto !important;
    width: auto !important;
    min-width: 180px !important;
    max-width: calc(100vw - 20px) !important;
    margin-top: 4px !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4) !important;
    z-index: 10000 !important;
}

/* ---- SIDEBAR QUICK ACTIONS DROPDOWN ---- */
/* Hidden by default in normal dashboard */
#sidebar-quick-actions-dropdown {
    display: none !important;
}

/* Visible ONLY in sidebar mode */
body.sidebar-mode #sidebar-quick-actions-dropdown {
    display: flex !important;
    margin-left: 6px;
    margin-top: 5px;
}

body.sidebar-mode #sidebar-quick-actions-btn {
    padding: 4px 8px;
    border-radius: 6px;
    color: var(--text-secondary);
    transition: all 0.2s;
}

body.sidebar-mode #sidebar-quick-actions-btn:hover {
    background: var(--header-bg-hover);
    color: var(--text-primary);
}

body.sidebar-mode #sidebar-quick-actions-dropdown .dropdown-menu {
    position: fixed !important;
    top: 50px !important;
    left: 10px !important;
    right: 10px !important;
    width: auto !important;
    min-width: unset !important;
    max-width: none !important;
    margin-top: 0 !important;
    display: block !important;
    opacity: 0;
    visibility: hidden;
    transform: none !important;
    transition: opacity 0.15s ease, visibility 0.15s ease;
    z-index: 10000 !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4) !important;
}

/* ---- SIDEBAR SETTINGS DROPDOWN ---- */
/* Hidden by default in normal dashboard */
#sidebar-settings-dropdown {
    display: none !important;
}

/* Visible ONLY in sidebar mode */
body.sidebar-mode #sidebar-settings-dropdown {
    display: flex !important;
    margin-left: 4px;
    margin-top: 5px;
}

body.sidebar-mode #sidebar-settings-btn {
    padding: 4px 8px;
    border-radius: 6px;
    color: var(--text-secondary);
    transition: all 0.2s;
}

body.sidebar-mode #sidebar-settings-btn:hover {
    background: var(--header-bg-hover);
    color: var(--text-primary);
}

/* Dropdown opens to LEFT to avoid clipping at right edge */
/* Dropdown opens to LEFT to avoid clipping at right edge */
body.sidebar-mode #sidebar-settings-dropdown .dropdown-menu {
    position: fixed !important;
    top: 50px !important;
    left: 10px !important;
    right: 10px !important;
    width: auto !important;
    min-width: unset !important;
    max-width: none !important;
    margin-top: 0 !important;
    display: block !important;
    opacity: 0;
    visibility: hidden;
    transform: none !important;
    transition: opacity 0.15s ease, visibility 0.15s ease;
    z-index: 10000 !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4) !important;
}

/* ---- SIDEBAR HOVER-TO-OPEN DROPDOWNS ---- */
/* Only in sidebar mode: open dropdown on hover */
body.sidebar-mode #sidebar-quick-actions-dropdown:hover .dropdown-menu,
body.sidebar-mode #sidebar-settings-dropdown:hover .dropdown-menu {
    opacity: 1;
    visibility: visible;
}

/* Force close when .sidebar-dropdown-closed is present (set by close button) */
body.sidebar-mode .dropdown-menu.sidebar-dropdown-closed {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

/* Ensure settings dropdown-menu has proper transition */
body.sidebar-mode #sidebar-settings-dropdown .dropdown-menu {
    display: block;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: opacity 0.15s ease, visibility 0.15s ease, transform 0.15s ease;
}

/* Also show when .show class is active (for click fallback) */
body.sidebar-mode #sidebar-quick-actions-dropdown .dropdown-menu.show,
body.sidebar-mode #sidebar-settings-dropdown .dropdown-menu.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* ================================================
   Bookmarks Import Modal Styles
   ================================================ */

.bookmarks-import-content {
    background: var(--bg-card);
    border-radius: 12px;
    width: 90%;
    max-width: 700px;
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.3);
    overflow: hidden;
}

.bookmarks-import-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-color);
}

.bookmarks-import-header h3 {
    margin: 0;
    font-size: 1.2rem;
    color: var(--text-primary);
}

.bookmarks-import-desc {
    padding: 12px 20px;
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.9rem;
    border-bottom: 1px solid var(--border-color);
}

.bookmarks-import-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    gap: 12px;
    border-bottom: 1px solid var(--border-color);
    flex-wrap: wrap;
}

.bookmarks-import-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.bookmarks-tree {
    flex: 1;
    overflow-y: auto;
    padding: 12px 20px;
    min-height: 200px;
    max-height: 400px;
}

.bookmarks-tree::-webkit-scrollbar {
    width: 8px;
}

.bookmarks-tree::-webkit-scrollbar-track {
    background: transparent;
}

.bookmarks-tree::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 4px;
}

/* Folder Container */
.bookmark-folder {
    margin-bottom: 4px;
}

.bookmark-folder-header {
    display: flex;
    align-items: center;
    padding: 8px 10px;
    border-radius: 6px;
    cursor: pointer;
    transition: background 0.15s;
    gap: 8px;
}

.bookmark-folder-header:hover {
    background: var(--header-bg-hover);
}

.bookmark-folder-chevron {
    width: 16px;
    height: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    transition: transform 0.2s;
    flex-shrink: 0;
}

.bookmark-folder.expanded .bookmark-folder-chevron {
    transform: rotate(90deg);
}

.bookmark-folder-icon {
    width: 16px;
    height: 16px;
    color: #f59e0b;
    flex-shrink: 0;
}

.bookmark-folder-name {
    flex: 1;
    font-weight: 500;
    color: var(--text-primary);
    font-size: 0.9rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.bookmark-folder-count {
    font-size: 0.8rem;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    padding: 2px 8px;
    border-radius: 10px;
    flex-shrink: 0;
}

.bookmark-folder-checkbox {
    flex-shrink: 0;
}

/* Folder Children Container */
.bookmark-folder-children {
    display: none;
    padding-left: 24px;
}

.bookmark-folder.expanded>.bookmark-folder-children {
    display: block;
}

/* Individual Bookmark Item */
.bookmark-item {
    display: flex;
    align-items: center;
    padding: 6px 10px;
    border-radius: 6px;
    gap: 8px;
    transition: background 0.15s;
}

.bookmark-item:hover {
    background: var(--header-bg-hover);
}

.bookmark-item-checkbox {
    flex-shrink: 0;
}

.bookmark-item-favicon {
    width: 16px;
    height: 16px;
    border-radius: 2px;
    flex-shrink: 0;
}

.bookmark-item-title {
    flex: 1;
    font-size: 0.85rem;
    color: var(--text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.bookmark-item-url {
    font-size: 0.75rem;
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 200px;
}

/* Bookmarks Import Footer */
.bookmarks-import-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-top: 1px solid var(--border-color);
    gap: 16px;
    flex-wrap: wrap;
}

.bookmarks-import-buttons {
    display: flex;
    gap: 10px;
}

/* Empty State */
.bookmarks-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    color: var(--text-secondary);
    text-align: center;
}

.bookmarks-empty-state svg {
    width: 48px;
    height: 48px;
    opacity: 0.5;
    margin-bottom: 12px;
}

/* Checkbox styling consistency */
.bookmark-folder-checkbox input[type="checkbox"],
.bookmark-item-checkbox input[type="checkbox"] {
    width: 16px;
    height: 16px;
    cursor: pointer;
    accent-color: var(--accent-blue);
}

/* Tools Menu Icons */
.dropdown-action-btn {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 8px 12px;
    border: none;
    background: none;
    text-align: left;
    cursor: pointer;
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.9rem;
    transition: background-color 0.2s;
}

.dropdown-action-btn:hover {
    background-color: var(--header-bg-hover);
    color: var(--accent-blue);
}

.dropdown-action-btn svg {
    flex-shrink: 0;
    opacity: 0.8;
    transition: opacity 0.2s;
}

.dropdown-action-btn:hover svg {
    opacity: 1;
    color: var(--accent-blue);
}

/* ================================================
   Group Divider - Create New Group Between Groups
   ================================================ */
.group-divider {
    position: relative;
    height: 0;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 5;
}

/* Center divider vertically in the gap between groups */
.group-card+.group-divider {
    top: -12px;
}

.group-divider-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    width: 100%;
    height: 32px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    opacity: 0;
    transition: opacity 0.2s ease;
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    transform: translateY(-50%);
}

.group-divider:hover .group-divider-btn {
    opacity: 1;
}

.group-divider-line {
    flex: 1;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent-blue) 20%, var(--accent-blue) 80%, transparent);
    opacity: 0.5;
}

.group-divider-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--bg-card);
    border: 2px solid var(--accent-blue);
    color: var(--accent-blue);
    font-size: 16px;
    font-weight: bold;
    flex-shrink: 0;
    transition: all 0.2s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.group-divider-btn:hover .group-divider-icon {
    background: var(--accent-blue);
    color: white;
    transform: scale(1.1);
    box-shadow: 0 4px 12px rgba(49, 130, 206, 0.3);
}

.group-divider-btn:hover .group-divider-line {
    opacity: 1;
}

/* Dark theme adjustments */
html.dark-theme .group-divider-icon,
body.dark-theme .group-divider-icon {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

html.dark-theme .group-divider-btn:hover .group-divider-icon,
body.dark-theme .group-divider-btn:hover .group-divider-icon {
    box-shadow: 0 4px 12px rgba(10, 132, 255, 0.4);
}

/* Restore Mode - Block interactions during undo restoration */
body.restoring-mode .action-btn.delete,
body.restoring-mode .delete-link-btn,
body.restoring-mode .group-delete-zone {
    pointer-events: none !important;
    opacity: 0.5;
    cursor: wait;
}


/* Sponsors Section */
.sponsors-section {
    margin-top: 2rem;
    margin-bottom: 2rem;
}

/* Hidden until JS adds .sponsors-ready class - prevents flash on page load */
.sponsors-section:not(.sponsors-ready) {
    display: none !important;
}

/* Hide sponsors in sidebar and floating window - only show in full dashboard */
.sidebar-mode .sponsors-section,
.embedded-mode .sponsors-section {
    display: none !important;
}

.sponsors-title {
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin-bottom: 1rem;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.sponsors-grid {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: nowrap;
}

.sponsor-card {
    background-color: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--card-radius);
    flex: 1;
    max-width: 33.333%;
    height: 120px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: var(--text-primary);
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
    position: relative;
    overflow: hidden;
}

.sponsor-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--card-shadow);
    border-color: var(--accent-blue);
}

.sponsor-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    height: 100%;
}

.sponsor-card svg {
    color: var(--text-secondary);
    transition: color 0.2s;
}

.sponsor-card:hover svg {
    color: var(--accent-blue);
}

.globe-icon {
    width: 64px;
    height: 64px;
    opacity: 0.8;
}

.plus-icon {
    width: 64px;
    height: 64px;
    opacity: 0.5;
}

.sponsor-text {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--text-secondary);
}

.sponsor-card:hover .sponsor-text {
    color: var(--text-primary);
}

.add-sponsor-card {
    border-style: dashed;
    background-color: transparent;
}

.add-sponsor-card:hover {
    background-color: var(--header-bg-hover);
    border-style: solid;
}

/* Sponsor Dismiss Button */
.sponsor-dismiss-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 24px;
    height: 24px;
    border: none;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.4);
    color: #fff;
    font-size: 16px;
    line-height: 1;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.2s, background 0.2s, transform 0.2s;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sponsor-card:hover .sponsor-dismiss-btn {
    opacity: 1;
}

.sponsor-dismiss-btn:hover {
    background: #e53e3e;
    transform: scale(1.1);
}

/* Hide entire sponsors section when all cards are hidden */
.sponsors-section:not(:has(.sponsor-card:not([style*="display: none"]))) {
    display: none;
}

/* Restore Sponsors Button - Barely visible */
.restore-sponsors-btn {
    display: block;
    margin: 1rem auto;
    padding: 6px 12px;
    border: 1px dashed var(--border-color);
    border-radius: 6px;
    background: transparent;
    color: var(--text-secondary);
    font-size: 14px;
    cursor: pointer;
    opacity: 0.15;
    transition: opacity 0.3s, background 0.2s;
}

.restore-sponsors-btn:hover {
    opacity: 0.6;
    background: var(--header-bg-hover);
}

/* ================================================
   Quick Links Section (Chrome New Tab Style)
   ================================================ */

.quick-links-section {
    position: relative;
    margin-top: -28px;
    /* Aggressively reduce space (cancels header margin) */
    margin-bottom: 3px;
    /* Micro-adjustment for symmetry */
    padding: 0;
}

.quick-links-section.empty-state {
    opacity: 1 !important;
    /* Prevent generic empty-state opacity from affecting dropdown */
}

.quick-links-grid {
    display: flex;
    justify-content: center;
    column-gap: 20px;
    row-gap: 4px;
    /* Tight vertical spacing for compact grid layout */
    flex-wrap: wrap;
    /* Allow wrapping for 2 rows */
    max-width: 100%;
}

/* Individual Quick Link Item */
.quick-link-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    width: 96px;
    padding: 12px 8px;
    border-radius: 12px;
    cursor: pointer;
    transition: background-color 0.2s, transform 0.15s;
    position: relative;
    text-decoration: none;
}

.quick-link-item:hover {
    background-color: var(--header-bg-hover);
    transform: scale(1.02);
}

.quick-link-item:active {
    transform: scale(0.98);
}

/* Icon container (circular) */
.quick-link-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.quick-link-item:hover .quick-link-icon {
    border-color: var(--accent-blue);
    box-shadow: 0 4px 12px rgba(49, 130, 206, 0.2);
}

.quick-link-icon img {
    width: 28px;
    height: 28px;
    border-radius: 4px;
}

.quick-link-icon svg {
    width: 24px;
    height: 24px;
    color: var(--text-secondary);
}

/* Link name */
.quick-link-name {
    font-size: 0.8rem;
    color: var(--text-primary);
    text-align: center;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.2;
}

/* Add button (empty slot) */
.quick-link-add {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    width: 115px;
    /* Micro-adjustment: slightly wider */
    /* Increased to fit Spanish text */
    padding: 12px 8px;
    border-radius: 12px;
    cursor: pointer;
    opacity: 1;
    transition: background-color 0.2s;
}

.quick-link-add:hover {
    background-color: var(--header-bg-hover);
}

.quick-link-add-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background-color: var(--bg-secondary);
    border: 2px dashed var(--border-color);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color 0.2s, background-color 0.2s;
}

.quick-link-add:hover .quick-link-add-icon {
    border-color: var(--accent-blue);
    background-color: rgba(49, 130, 206, 0.1);
}

.quick-link-add-icon svg {
    width: 24px;
    height: 24px;
    color: var(--text-secondary);
    transition: color 0.2s;
}

.quick-link-add:hover .quick-link-add-icon svg {
    color: var(--accent-blue);
}

.quick-link-add-text {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-align: center;
    white-space: nowrap;
}

/* Remove button (appears on hover) */
.quick-link-remove {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 22px;
    height: 22px;
    border: none;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.5);
    color: white;
    font-size: 14px;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.2s, background 0.2s, transform 0.15s;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
}

.quick-link-item:hover .quick-link-remove {
    opacity: 1;
}

.quick-link-item .quick-link-remove:hover {
    background: #e53e3e !important;
    transform: scale(1.1);
}

/* Edit button (appears on hover, right side) */
.quick-link-edit {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 22px;
    height: 22px;
    border: none;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.5);
    color: white;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.2s, background 0.2s, transform 0.15s;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    padding: 0;
}

.quick-link-edit svg {
    width: 12px;
    height: 12px;
}

.quick-link-item:hover .quick-link-edit {
    opacity: 1;
}

.quick-link-item .quick-link-edit:hover {
    background: #3182ce !important;
    transform: scale(1.1);
}

/* Three-dots menu button (appears on section hover) */
.quick-links-menu-btn {
    position: absolute;
    top: 8px;
    right: 4px;
    /* Moved slightly right */
    width: 32px;
    height: 32px;
    border: none;
    border-radius: 50%;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.2s, background-color 0.2s, color 0.2s;
    z-index: 50;
}

.quick-links-section:hover .quick-links-menu-btn,
.quick-links-section.empty-state .quick-links-menu-btn {
    opacity: 1;
}

.quick-links-menu-btn:hover {
    background: var(--header-bg-hover);
    color: var(--text-primary);
}

/* Expand/Collapse button */
.quick-links-expand-btn {
    position: absolute;
    top: 56px;
    /* Positioned below menu button with comfortable spacing */
    right: 4px;
    /* Perfectly aligned with the menu button (which is at right: 4px) */
    transform: none;
    width: 32px;
    height: 32px;
    border: none;
    border-radius: 50%;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-bottom: 2px;
    /* Visual centering tweak for arrow char */
    opacity: 0;
    transition: opacity 0.2s, background-color 0.2s, color 0.2s, transform 0.2s;
    z-index: 50;
    font-size: 12px;
}

.quick-links-section:hover .quick-links-expand-btn {
    opacity: 1;
}

.quick-links-expand-btn:hover {
    background: var(--header-bg-hover);
    color: var(--text-primary);
    transform: scale(1.1);
}

/* Settings dropdown (opens on click, not hover) */
.quick-links-settings-dropdown {
    position: absolute;
    top: 44px;
    right: 8px;
    background: var(--bg-dropdown, #232325) !important;
    backdrop-filter: none !important;
    /* Disable any accidental blur */
    border: 1px solid var(--border-color);
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    padding: 6px;
    z-index: 100;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: opacity 0.15s, visibility 0.15s, transform 0.15s;
    min-width: 180px;
}

/* Show dropdown when .show class is added via JS */
.quick-links-settings-dropdown.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.quick-links-settings-item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 10px 12px;
    border: none;
    background: none;
    color: var(--text-primary);
    font-size: 0.85rem;
    cursor: pointer;
    border-radius: 6px;
    transition: background-color 0.15s;
    text-align: left;
}

.quick-links-settings-item:hover {
    background-color: var(--header-bg-hover);
}

.quick-links-settings-item svg {
    color: var(--text-secondary);
    flex-shrink: 0;
}

.quick-links-settings-item:hover svg {
    color: var(--accent-blue);
}

.quick-links-settings-divider {
    height: 1px;
    background: var(--border-color);
    margin: 4px 0;
}

/* Activator Zone (when Quick Links is hidden) */
.quick-links-activator {
    position: relative;
    height: 40px;
    /* Smaller hover area to avoid accidental clicks */
    margin-top: -55px;
    /* Position to keep button centered visually */
    margin-bottom: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

/* Horizontal line (like between groups - passes through center of button) */
.quick-links-activator-line {
    position: absolute;
    top: 50%;
    /* Centered in hover area */
    left: 0;
    width: 100%;
    height: 2px;
    background: transparent;
    transition: background-color 0.2s;
}

.quick-links-activator:hover .quick-links-activator-line {
    background: #48bb78;
    /* Green like create-group */
}

/* The Plus Button (centered, Create Group style) */
.quick-links-activator-btn {
    position: absolute;
    top: 50%;
    /* Centered in hover area */
    left: 50%;
    transform: translate(-50%, -50%) scale(0.8);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background-color: #48bb78;
    /* Green */
    color: white;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 12px rgba(72, 187, 120, 0.6), 0 0 24px rgba(72, 187, 120, 0.4);
    /* Neon glow */
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.2s, transform 0.2s, box-shadow 0.2s;
    z-index: 100;
}

/* Show button on hover */
.quick-links-activator:hover .quick-links-activator-btn {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

.quick-links-activator-btn:hover {
    transform: translate(-50%, -50%) scale(1.1);
    background-color: #38a169;
    /* Darker green on hover */
    box-shadow: 0 0 16px rgba(72, 187, 120, 0.8), 0 0 32px rgba(72, 187, 120, 0.5);
    /* Brighter glow */
}

/* Quick Link Context Menu (Right-click) */
.quick-link-context-menu {
    position: fixed;
    background: var(--bg-dropdown, #ffffff);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    padding: 6px;
    z-index: 10000;
    min-width: 160px;
}

.quick-link-context-item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 10px 12px;
    border: none;
    background: none;
    color: var(--text-primary);
    font-size: 0.85rem;
    cursor: pointer;
    border-radius: 6px;
    transition: background-color 0.15s;
    text-align: left;
}

.quick-link-context-item:hover {
    background-color: var(--header-bg-hover);
}

.quick-link-context-item svg {
    width: 16px;
    height: 16px;
    color: var(--text-secondary);
    flex-shrink: 0;
}

.quick-link-context-item:hover svg {
    color: var(--accent-blue);
}

.quick-link-context-item.danger:hover {
    background-color: rgba(229, 62, 62, 0.1);
}

.quick-link-context-item.danger:hover svg {
    color: #e53e3e;
}

.quick-link-context-item.danger:hover span {
    color: #e53e3e;
}

.quick-link-context-divider {
    height: 1px;
    background: var(--border-color);
    margin: 4px 0;
}


/* Dark theme adjustments */
html.dark-theme .quick-link-edit,
body.dark-theme .quick-link-edit {
    background: rgba(0, 0, 0, 0.7);
}

html.dark-theme .quick-links-settings-dropdown,
body.dark-theme .quick-links-settings-dropdown,
html.dark-theme .quick-link-context-menu,
body.dark-theme .quick-link-context-menu {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

/* Hide in sidebar/embedded mode */
body.sidebar-mode .quick-links-section,
body.embedded-mode .quick-links-section,
body.sidebar-mode .quick-links-activator,
body.embedded-mode .quick-links-activator {
    display: none !important;
}

/* Logo animation */
.logo-spin {
    animation: spin-once 0.8s ease-in-out;
}

@keyframes spin-once {
    0% {
        transform: rotate(0deg) scale(1);
    }

    50% {
        transform: rotate(180deg) scale(1.1);
    }

    100% {
        transform: rotate(360deg) scale(1);
    }
}

/* ============================================
   TOGGLE SWITCHES
   ============================================ */

/* ============================================
   TOGGLE CHECKBOX (X → ✓ Animation)
   ============================================ */

.toggle-switch {
    position: relative;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 32px;
    height: 32px;
    flex-shrink: 0;
}

.toggle-switch input {
    display: none;
}

/* The circular checkbox container */
.toggle-slider {
    position: absolute;
    width: 32px;
    height: 32px;
    background: var(--bg-card, var(--surface, #fff));
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    transition: all 0.3s ease-in-out;
    box-shadow: -6px -6px 10px rgba(255, 255, 255, 0.4),
        6px 6px 10px rgba(0, 0, 70, 0.1);
    border: 5px solid var(--border-color, var(--border, #e2e8f0));
}

/* X/Check Lines */
.toggle-slider .line {
    position: absolute;
    width: 14px;
    height: 2px;
    background: var(--text-secondary, #64748B);
    border-radius: 2px;
    transition: all 0.3s ease-in-out;
}

/* Line 1: horizontal line in OFF, becomes short part of check in ON */
.toggle-slider .line1 {
    transform: rotate(0deg);
}

/* Line 2: hidden in OFF, becomes long part of check in ON */
.toggle-slider .line2 {
    transform: rotate(0deg);
    opacity: 0;
}

/* Checked State - Inset shadow */
.toggle-switch input:checked+.toggle-slider {
    box-shadow: -6px -6px 10px rgba(255, 255, 255, 0.4),
        6px 6px 10px rgba(70, 70, 70, 0.1),
        inset -4px -4px 8px rgba(255, 255, 255, 0.4),
        inset 4px 4px 8px rgba(70, 70, 70, 0.1);
}

/* Lines transform to checkmark */
.toggle-switch input:checked+.toggle-slider .line1 {
    transform: rotate(50deg) translateX(-2px) translateY(4px) scaleX(0.5);
    background: var(--accent-blue, var(--primary, #2563EB));
}

.toggle-switch input:checked+.toggle-slider .line2 {
    transform: rotate(-50deg) translateX(3px) translateY(2px);
    background: var(--accent-blue, var(--primary, #2563EB));
    opacity: 1;
}

/* Dark theme adjustments */
html.dark-theme .toggle-slider,
body.dark-theme .toggle-slider {
    box-shadow: -6px -6px 10px rgba(60, 60, 60, 0.2),
        6px 6px 10px rgba(0, 0, 0, 0.3);
}

html.dark-theme .toggle-switch input:checked+.toggle-slider,
body.dark-theme .toggle-switch input:checked+.toggle-slider {
    box-shadow: -6px -6px 10px rgba(60, 60, 60, 0.2),
        6px 6px 10px rgba(0, 0, 0, 0.3),
        inset -4px -4px 8px rgba(80, 80, 80, 0.15),
        inset 4px 4px 8px rgba(0, 0, 0, 0.2);
}

/* Focus state for accessibility */
.toggle-switch input:focus+.toggle-slider {
    outline: 2px solid var(--accent-blue, var(--primary, #2563EB));
    outline-offset: 2px;
}

/* Hover effect */
.toggle-switch:hover .toggle-slider {
    transform: scale(1.05);
}

/* Dropdown toggle label */
.dropdown-toggle-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    cursor: pointer;
    font-size: 0.9rem;
    color: var(--text-primary);
    padding: 0;
    width: 100%;
}

.dropdown-toggle-label .label-text {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 1;
}

/* ================================================
   ORGANIZER MULTI-SELECTION
   ================================================ */

/* Checkbox for tab selection */
.org-tab-checkbox {
    width: 16px;
    height: 16px;
    margin-right: 8px;
    accent-color: var(--accent-blue);
    cursor: pointer;
    flex-shrink: 0;
}

/* Selected tab state */
.org-tab.org-selected {
    background: linear-gradient(135deg, rgba(49, 130, 206, 0.15) 0%, rgba(49, 130, 206, 0.08) 100%);
    border-left: 3px solid var(--accent-blue);
    padding-left: 7px;
}

/* Dark theme selected state */
html.dark-theme .org-tab.org-selected,
body.dark-theme .org-tab.org-selected {
    background: linear-gradient(135deg, rgba(99, 179, 237, 0.2) 0%, rgba(99, 179, 237, 0.1) 100%);
}

/* Selection floating bar */
.org-selection-bar {
    position: absolute;
    bottom: 70px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 10px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
    z-index: 1000;
    animation: org-bar-slide-up 0.2s ease-out;
}

@keyframes org-bar-slide-up {
    from {
        opacity: 0;
        transform: translateX(-50%) translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
    }
}

.org-selection-bar .selection-count {
    font-weight: 600;
    color: var(--accent-blue);
    white-space: nowrap;
}

.org-selection-bar button {
    padding: 6px 12px;
    border-radius: 6px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    color: var(--text-primary);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    transition: all 0.15s;
}

.org-selection-bar button:hover {
    background: var(--header-bg-hover);
    border-color: var(--accent-blue);
}

.org-selection-bar button.danger {
    color: var(--danger);
}

.org-selection-bar button.danger:hover {
    background: rgba(229, 62, 62, 0.1);
    border-color: var(--danger);
}

.org-selection-bar button.clear-btn {
    padding: 6px 8px;
    min-width: auto;
}

/* Group selector dropdown in selection bar */
.org-group-selector {
    position: fixed;
    bottom: 120px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
    min-height: 900px;
    max-height: calc(100vh - 200px);
    overflow-y: auto;
    min-width: 450px;
    z-index: 1001;
}

/* Fix Organizer Trash Zone Centering */
/* Fix Organizer Trash Zone Centering */
/* Fix Organizer Trash Zone Centering */
.organizer-footer {
    position: relative;
    /* Context for absolute positioning */
    justify-content: center;
    /* Center content (trash bin) */
    height: 60px;
    /* Explicit height to prevent collapse */
    display: flex;
    /* Ensure alignment context */
    align-items: center;
    /* Vertically center the non-absolute content if any */
}

#organizer-trash-zone,
.organizer-trash-zone {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    margin: 0;
    z-index: 10;
}

.org-footer-left {
    position: absolute;
    left: 24px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    gap: 12px;
    align-items: center;
}

.org-footer-right {
    position: absolute;
    right: 24px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    gap: 12px;
    align-items: center;
}

.org-group-selector-item {
    padding: 10px 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: background 0.15s;
    color: var(--text-primary);
}

.org-group-selector-item:hover {
    background: var(--header-bg-hover);
}

.org-group-selector-item:first-child {
    border-radius: 8px 8px 0 0;
}

.org-group-selector-item:last-child {
    border-radius: 0 0 8px 8px;
}

/* Organizer Group Date */
.org-group-date {
    font-size: 0.75rem;
    color: var(--text-muted, #888);
    margin-left: 12px;
    margin-right: 16px;
    white-space: nowrap;
    opacity: 0.8;
}

/* Fix for Pin AllTab tooltip arrow */
.info-tooltip[data-i18n-tooltip='settings_pin_tab_tooltip']::before {
    border-width: 5px;
    border-style: solid;
    border-color: #333 transparent transparent transparent !important;
    bottom: 125% !important;
    top: auto !important;
}

/* ============================================
   AUTO-BACKUP MODAL
   ============================================ */

.backup-active-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--accent-green, #48bb78);
    margin-left: 8px;
    vertical-align: middle;
    animation: backup-pulse 2s ease-in-out infinite;
}

@keyframes backup-pulse {

    0%,
    100% {
        opacity: 1;
        box-shadow: 0 0 0 0 rgba(72, 187, 120, 0.5);
    }

    50% {
        opacity: 0.6;
        box-shadow: 0 0 0 4px rgba(72, 187, 120, 0);
    }
}

/* --- Settings row: Destination + Interval + Backup Now --- */

.backup-settings-row {
    display: flex;
    align-items: center;
    gap: 24px;
    padding: 10px 14px;
    background: var(--bg-secondary);
    border-radius: 8px;
    border: 1px solid var(--border-color);
    margin-bottom: 14px;
}

.backup-settings-row .backup-now-btn {
    margin-left: auto;
    width: auto;
    padding: 6px 16px;
    font-size: 0.85rem;
}


.backup-interval-group {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9rem;
    color: var(--text-primary);
}

.backup-select {
    padding: 5px 10px;
    border-radius: 6px;
    border: 1px solid var(--border-color);
    background: var(--bg-card);
    color: var(--text-primary);
    font-size: 0.85rem;
    cursor: pointer;
}

/* --- Status --- */

.backup-status {
    font-size: 0.82rem;
    color: var(--text-secondary);
    margin: 0 0 6px;
}

/* --- Backup Now button (primary) --- */

.backup-now-btn {
    width: 100%;
    padding: 10px;
    font-size: 0.9rem;
}

.backup-now-primary {
    background: #444;
    color: #fff;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    transition: background 0.2s, transform 0.1s;
}

.backup-now-primary:hover {
    background: #555;
    transform: translateY(-1px);
}

.backup-now-primary:active {
    transform: translateY(0);
}

.backup-now-primary:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.backup-now-primary.backup-saved {
    background: var(--accent-green, #48bb78);
    pointer-events: none;
}

/* --- Restore section --- */



.backup-restore-heading {
    margin: 0 0 10px 0;
    font-size: 0.95rem;
}

/* --- Backup items --- */

.backup-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    border-radius: 8px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    margin-bottom: 8px;
    transition: border-color 0.15s;
}

.backup-item:hover {
    border-color: var(--accent-blue);
}

.backup-item-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
}

.backup-item-date {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--text-primary);
}

.backup-item-stats {
    font-size: 0.78rem;
    color: var(--text-secondary);
}

.backup-item-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

.backup-restore-btn {
    padding: 5px 12px;
    font-size: 0.8rem;
    flex-shrink: 0;
    color: var(--text-secondary);
    border-color: var(--border-color);
    transition: color 0.2s, border-color 0.2s;
}

.backup-restore-btn:hover {
    color: var(--accent-blue);
    border-color: var(--accent-blue);
}

.backup-delete-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    border-radius: 4px;
    color: var(--text-secondary);
    opacity: 0.5;
    transition: opacity 0.15s, color 0.15s;
    display: flex;
    align-items: center;
}

.backup-delete-btn:hover {
    opacity: 1;
    color: var(--accent-red, #e53e3e);
}

.backup-empty {
    text-align: center;
    color: var(--text-secondary);
    font-size: 0.85rem;
    padding: 16px 0;
}

/* --- Badges --- */

.backup-badge {
    display: inline-block;
    font-size: 0.65rem;
    padding: 1px 6px;
    border-radius: 4px;
    font-weight: 600;
    vertical-align: middle;
    margin-left: 4px;
    letter-spacing: 0.3px;
}

.backup-badge-manual {
    background: rgba(66, 153, 225, 0.15);
    color: var(--accent-blue, #4299e1);
}

.backup-badge-auto {
    background: rgba(72, 187, 120, 0.15);
    color: var(--accent-green, #48bb78);
}

/* --- File tip --- */

.backup-file-tip {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.9);
    margin: 2px 0 10px;
    line-height: 1.55;
}

/* --- Icons --- */

.backup-icon {
    vertical-align: -2px;
    flex-shrink: 0;
    opacity: 0.7;
}

/* --- How it works details --- */

.backup-details {
    margin-bottom: 14px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
}

.backup-details summary {
    padding: 10px 14px;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.78);
    cursor: pointer;
    user-select: none;
    transition: color 0.15s, background 0.15s;
}

.backup-details summary:hover {
    color: var(--text-primary);
    background: rgba(255, 255, 255, 0.03);
}

.backup-details p {
    padding: 0 20px;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.9);
    line-height: 1.55;
    margin: 0 0 10px;
}

.backup-details p:last-of-type {
    margin-bottom: 14px;
}

/* --- Global Tooltip (JS delegated) --- */
.custom-tooltip {
    position: fixed;
    z-index: 10000;
    background: rgba(15, 23, 42, 0.95);
    color: #f8fafc;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 0.8rem;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s ease, transform 0.15s ease;
    max-width: 260px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
    line-height: 1.5;
    text-align: center;
    visibility: hidden;
    border: 1px solid rgba(255, 255, 255, 0.1);
    transform: translateY(5px);
}

.custom-tooltip.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}