﻿:root {
    --app-viewport-height: 1vh;
    --app-viewport-100: calc(var(--app-viewport-height) * 100);
    --bg-page: #0f1319;
    --bg-card: #1a212b;
    --bg-card-soft: #202a36;
    --bg-sidebar: linear-gradient(180deg, #181f2a 0%, #111722 100%);
    --border-color: #2b3646;
    --text-primary: #ecf2ff;
    --text-secondary: #9fb0c7;
    --accent: #2dd46f;
    --accent-soft: #154c2d;
    --danger: #f05454;
    --warning: #f4bf4f;
    --shadow: 0 12px 30px rgba(0, 0, 0, 0.28);
    --sidebar-width: 286px;
    --z-sidebar: 2147483000;
    --z-popup-backdrop: 2147483300;
    --z-popup: 2147483301;
    --z-popup-top: 2147483302;
    --z-edge: 2147483647;
    --surface-panel-bg: linear-gradient(180deg, rgba(27, 34, 45, 0.96) 0%, rgba(17, 23, 33, 0.97) 100%);
    --surface-panel-border: #304157;
    --surface-panel-header-border: #354a64;
    --surface-panel-header-text: #bfd1ea;
    --surface-lane-bg: rgba(22, 28, 36, 0.94);
    --surface-card-bg: linear-gradient(180deg, rgba(18, 24, 33, 0.98) 0%, rgba(16, 22, 30, 1) 100%);
    --surface-card-border: #2b394d;
    --surface-card-hover-border: #4a5f7d;
    --surface-card-head-text: #89a6c8;
    --surface-card-action-text: #bfd0e9;
    --surface-card-metrics-text: #d2deed;
    --surface-card-complete-bg: linear-gradient(180deg, rgba(21, 45, 29, 0.95) 0%, rgba(17, 34, 24, 0.95) 100%);
    --surface-card-complete-border: #2f5f3a;
    --surface-empty-bg: transparent;
    --surface-empty-border: #2f3d50;
    --surface-empty-text: #89a2c0;
    --surface-widget-bg: rgba(18, 25, 34, 0.9);
    --surface-subpanel-bg: rgba(14, 21, 31, 0.86);
    --surface-subpanel-border: #2c3d52;
    --surface-subpanel-header-border: rgba(58, 77, 100, 0.75);
    --surface-subpanel-header-text: #a9bfdc;
    --surface-avatar-bg: #132030;
    --surface-avatar-border: #39506c;
    --surface-scrollbar-thumb: #334a66;
    --surface-scrollbar-thumb-hover: #466286;
    --surface-scrollbar-track: rgba(9, 14, 22, 0.55);
    --surface-scrollbar-size: 10px;
    --theme-btn-primary-bg: var(--accent);
    --theme-btn-primary-border: var(--accent);
    --theme-btn-primary-text: #ffffff;
    --theme-btn-outline-bg: transparent;
    --theme-btn-outline-border: var(--surface-panel-border);
    --theme-btn-outline-text: var(--text-primary);
    --theme-btn-outline-hover-bg: var(--surface-empty-bg);
    --theme-btn-outline-hover-border: var(--surface-card-hover-border);
    --theme-btn-outline-hover-text: var(--text-primary);
    --theme-btn-outline-secondary-bg: var(--theme-btn-outline-bg);
    --theme-btn-outline-secondary-border: var(--surface-subpanel-border);
    --theme-btn-outline-secondary-text: var(--text-secondary);
    --theme-btn-outline-secondary-hover-bg: var(--surface-empty-bg);
    --theme-btn-outline-secondary-hover-border: var(--surface-card-hover-border);
    --theme-btn-outline-secondary-hover-text: var(--text-primary);
    --theme-btn-warning-bg: color-mix(in srgb, var(--warning) 14%, transparent);
    --theme-btn-warning-border: color-mix(in srgb, var(--warning) 60%, var(--surface-panel-border) 40%);
    --theme-btn-warning-text: color-mix(in srgb, var(--warning) 76%, var(--text-primary) 24%);
    --theme-btn-warning-hover-bg: color-mix(in srgb, var(--warning) 22%, transparent);
    --theme-btn-warning-hover-border: color-mix(in srgb, var(--warning) 72%, var(--surface-card-hover-border) 28%);
    --theme-btn-warning-hover-text: color-mix(in srgb, var(--warning) 84%, var(--text-primary) 16%);
    --theme-btn-danger-bg: color-mix(in srgb, var(--danger) 12%, transparent);
    --theme-btn-danger-border: color-mix(in srgb, var(--danger) 62%, var(--surface-panel-border) 38%);
    --theme-btn-danger-text: color-mix(in srgb, var(--danger) 80%, var(--text-primary) 20%);
    --theme-btn-danger-hover-bg: color-mix(in srgb, var(--danger) 20%, transparent);
    --theme-btn-danger-hover-border: color-mix(in srgb, var(--danger) 74%, var(--surface-card-hover-border) 26%);
    --theme-btn-danger-hover-text: color-mix(in srgb, var(--danger) 88%, var(--text-primary) 12%);
    --theme-focus-ring: color-mix(in srgb, var(--accent) 24%, transparent);
    --theme-field-bg: var(--surface-subpanel-bg);
    --theme-field-border: var(--surface-subpanel-border);
    --theme-field-text: var(--text-primary);
    --theme-field-label: var(--surface-card-action-text);
    --theme-field-focus-border: var(--accent);
    --theme-field-focus-ring: var(--theme-focus-ring);
    --brand-block-bg: color-mix(in srgb, var(--accent) 78%, #1fad47 22%);
    --brand-block-text: var(--theme-btn-primary-text);
    --menu-link-hover-text: var(--text-primary);
    --menu-link-hover-bg: color-mix(in srgb, var(--surface-subpanel-bg) 84%, var(--accent-soft) 16%);
    --menu-link-hover-border: color-mix(in srgb, var(--surface-card-hover-border) 86%, var(--accent) 14%);
    --menu-link-active-text: var(--text-primary);
    --menu-link-active-bg: color-mix(in srgb, var(--accent-soft) 72%, transparent);
    --menu-link-active-border: color-mix(in srgb, var(--accent) 42%, var(--surface-card-hover-border) 58%);
    --notification-toast-border: color-mix(in srgb, var(--surface-card-hover-border) 35%, var(--surface-panel-border));
    --notification-toast-bg: var(--bg-card);
    --notification-toast-success-border: color-mix(in srgb, var(--accent) 54%, var(--surface-panel-border));
    --notification-toast-success-bg: color-mix(in srgb, var(--accent) 22%, var(--bg-card) 78%);
    --notification-toast-warning-border: color-mix(in srgb, var(--warning) 52%, var(--surface-panel-border));
    --notification-toast-warning-bg: color-mix(in srgb, var(--warning) 22%, var(--bg-card) 78%);
    --notification-toast-error-border: color-mix(in srgb, var(--danger) 58%, var(--surface-panel-border));
    --notification-toast-error-bg: color-mix(in srgb, var(--danger) 22%, var(--bg-card) 78%);
    --notification-toast-title: var(--text-primary);
    --notification-toast-message: var(--surface-card-action-text);
    --notification-toast-time: var(--surface-card-head-text);
    --notification-toast-shadow: 0 18px 28px color-mix(in srgb, var(--bg-page) 68%, transparent);
    --context-menu-shadow: 0 16px 34px color-mix(in srgb, var(--bg-page) 72%, transparent);
    --dark-modal-bg: var(--surface-card-bg);
    --modal-popup-shadow: 0 22px 42px color-mix(in srgb, var(--bg-page) 62%, transparent);
    --upload-toast-bg: color-mix(in srgb, var(--surface-panel-bg) 88%, #000000 12%);
    --upload-toast-border: color-mix(in srgb, var(--accent) 36%, var(--surface-panel-border) 64%);
    --upload-toast-shadow: 0 18px 48px rgba(0, 0, 0, 0.35);
    --upload-toast-text: var(--text-primary);
    --upload-toast-title: color-mix(in srgb, var(--text-primary) 88%, #ffffff 12%);
    --upload-toast-close: color-mix(in srgb, var(--text-primary) 78%, transparent);
    --upload-toast-close-hover: var(--text-primary);
    --upload-toast-progress-bg: color-mix(in srgb, var(--text-primary) 10%, transparent);
    --upload-toast-progress-start: color-mix(in srgb, var(--accent) 72%, #5aaeff 28%);
    --upload-toast-progress-end: color-mix(in srgb, var(--accent) 52%, #6af3c0 48%);
    --upload-toast-success-border: color-mix(in srgb, var(--accent) 58%, var(--surface-panel-border) 42%);
    --upload-toast-error-border: color-mix(in srgb, var(--danger) 62%, var(--surface-panel-border) 38%);
    --system-watch-shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
    --system-watch-bg-info: color-mix(in srgb, var(--accent-soft) 28%, var(--surface-panel-bg) 72%);
    --system-watch-border-info: color-mix(in srgb, var(--accent) 44%, var(--surface-panel-border) 56%);
    --system-watch-text-info: color-mix(in srgb, var(--text-primary) 88%, #d8eeff 12%);
    --system-watch-bg-offline: color-mix(in srgb, var(--warning) 24%, var(--surface-panel-bg) 76%);
    --system-watch-border-offline: color-mix(in srgb, var(--warning) 62%, var(--surface-panel-border) 38%);
    --system-watch-text-offline: color-mix(in srgb, var(--warning) 86%, var(--text-primary) 14%);
    --notification-icon-job-color: color-mix(in srgb, var(--accent) 86%, var(--text-primary) 14%);
    --notification-icon-comment-color: color-mix(in srgb, var(--warning) 88%, var(--text-primary) 12%);
    --notification-icon-default-color: color-mix(in srgb, var(--surface-panel-header-text) 84%, var(--text-primary) 16%);
    --todo-item-accent: var(--accent);
    --todo-item-done-accent: var(--surface-panel-border);
    --todo-toggle-border: var(--surface-panel-border);
    --todo-toggle-bg: var(--surface-empty-bg);
    --todo-toggle-text: var(--text-primary);
    --todo-toggle-hover-border: var(--accent);
    --todo-toggle-hover-bg: var(--accent-soft);
    --todo-toggle-hover-text: var(--accent);
    --todo-badge-new-bg: var(--accent-soft);
    --todo-badge-new-border: var(--accent);
    --todo-badge-new-text: var(--accent);
    --todo-badge-done-bg: var(--surface-empty-bg);
    --todo-badge-done-border: var(--surface-panel-border);
    --todo-badge-done-text: var(--text-secondary);
    --todo-preview-close-hover-bg: var(--surface-empty-bg);
    --todo-preview-close-hover-border: var(--surface-card-hover-border);
    --todo-preview-check-active-bg: var(--accent-soft);
    --todo-preview-check-active-border: var(--accent);
    --todo-preview-check-active-text: var(--accent);
    --todo-preview-delete-hover-bg: var(--surface-empty-bg);
    --todo-preview-delete-hover-border: var(--danger);
    --todo-preview-delete-hover-text: var(--danger);
    --addjob-header-bg: linear-gradient(120deg, rgba(255, 255, 255, 0.03) 0%, rgba(255, 255, 255, 0.01) 100%), var(--surface-panel-bg);
    --addjob-header-chip-border: var(--surface-panel-border);
    --addjob-header-chip-bg: var(--surface-empty-bg);
    --addjob-header-chip-text: var(--surface-panel-header-text);
    --addjob-header-user-text: var(--text-primary);
    --addjob-close-filter: invert(1) grayscale(1) brightness(200%);
    --addjob-label-text: var(--surface-subpanel-header-text);
    --addjob-type-scroll-border: var(--surface-panel-border);
    --addjob-type-scroll-bg: var(--surface-subpanel-bg);
    --addjob-type-scroll-thumb: var(--surface-scrollbar-thumb);
    --addjob-type-nav-border: var(--surface-panel-border);
    --addjob-type-nav-bg: var(--surface-empty-bg);
    --addjob-type-nav-text: var(--text-primary);
    --addjob-type-nav-hover-border: var(--surface-card-hover-border);
    --addjob-type-nav-hover-bg: var(--surface-subpanel-bg);
    --addjob-type-card-border: var(--surface-panel-border);
    --addjob-type-card-bg: var(--surface-card-bg);
    --addjob-type-card-text: var(--text-primary);
    --addjob-type-card-subtext: var(--text-secondary);
    --addjob-type-card-hover-border: var(--surface-card-hover-border);
    --addjob-type-card-selected-bg: var(--accent-soft);
    --addjob-type-card-selected-border: var(--accent);
    --addjob-type-card-selected-text: var(--text-primary);
    --addjob-type-card-selected-subtext: var(--text-secondary);
    --addjob-month-border: var(--surface-panel-border);
    --addjob-month-bg: var(--surface-subpanel-bg);
    --addjob-month-text: var(--text-primary);
    --addjob-month-year: var(--text-secondary);
    --addjob-month-selected-bg: var(--accent-soft);
    --addjob-month-selected-border: var(--accent);
    --addjob-month-selected-text: var(--text-primary);
    --addjob-month-selected-year: var(--text-secondary);
    --addjob-titlebar-border: var(--surface-panel-border);
    --addjob-titlebar-chip-bg: var(--surface-lane-bg);
    --addjob-titlebar-chip-text: var(--surface-panel-header-text);
    --addjob-person-thumb-border: var(--surface-subpanel-border);
    --addjob-person-thumb-bg: var(--surface-subpanel-bg);
    --addjob-person-thumb-icon: var(--text-secondary);
    --addjob-person-thumb-avatar-border: var(--surface-avatar-border);
    --addjob-person-thumb-avatar-bg: var(--surface-avatar-bg);
    --addjob-person-thumb-text: var(--text-secondary);
    --addjob-floating-label-text: var(--text-secondary);
    --addjob-editor-border: var(--surface-subpanel-border);
    --addjob-editor-bg: var(--surface-subpanel-bg);
    --addjob-editor-text: var(--text-primary);
    --addjob-editor-focus-ring: rgba(79, 140, 207, 0.16);
    --addjob-editor-link: var(--accent);
    --addjob-file-holder-border: var(--surface-panel-border);
    --addjob-file-holder-bg: var(--surface-panel-bg);
    --addjob-file-holder-top-bg: var(--surface-subpanel-bg);
    --addjob-file-holder-top-text: var(--surface-panel-header-text);
    --addjob-existing-files-border: var(--surface-subpanel-border);
    --addjob-existing-files-bg: var(--surface-subpanel-bg);
    --addjob-existing-files-header-bg: var(--surface-lane-bg);
    --addjob-existing-files-header-text: var(--surface-panel-header-text);
    --addjob-existing-files-hint-text: var(--text-secondary);
    --addjob-existing-files-empty-border: var(--surface-empty-border);
    --addjob-existing-files-empty-text: var(--surface-empty-text);
    --addjob-attachment-list-border: var(--surface-subpanel-border);
    --addjob-attachment-item-bg: var(--surface-subpanel-bg);
    --addjob-attachment-item-border: var(--surface-subpanel-border);
    --addjob-attachment-item-text: var(--text-primary);
    --addjob-attachment-item-muted: var(--text-secondary);
    --addjob-upload-picker-bg: var(--surface-subpanel-bg);
    --addjob-upload-picker-border: var(--surface-subpanel-border);
    --addjob-upload-picker-title: var(--text-primary);
    --addjob-upload-picker-subtext: var(--text-secondary);
    --addjob-upload-queue-empty-bg: var(--surface-empty-bg);
    --addjob-upload-queue-empty-border: var(--surface-empty-border);
    --addjob-upload-queue-empty-text: var(--surface-empty-text);
    --addjob-upload-card-note: var(--accent);
    --addjob-soft-row-bg: var(--surface-empty-bg);
    --addjob-icon-title-text: var(--surface-panel-header-text);
    --addjob-planned-panel-border: var(--surface-panel-border);
    --addjob-planned-panel-bg: var(--surface-widget-bg);
}

.header-notification-dropdown {
    position: fixed;
    right: max(0px, env(safe-area-inset-right));
    bottom: max(0px, env(safe-area-inset-bottom));
    z-index: 2147483200;
}

.header-notification-btn {
    position: relative;
    width: 52px;
    height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border-color: color-mix(in srgb, var(--accent) 54%, var(--surface-panel-border));
    background: var(--surface-panel-bg);
    color: var(--text-primary);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.36);
}

.header-notification-btn .bi {
    font-size: 1.28rem;
    line-height: 1;
}

.header-notification-btn:hover,
.header-notification-btn:focus,
.header-notification-btn:active {
    border-color: color-mix(in srgb, var(--accent) 72%, var(--surface-panel-border));
    background: color-mix(in srgb, var(--surface-panel-bg) 68%, var(--accent-soft) 32%);
    color: var(--text-primary);
}

.header-notification-badge {
    position: absolute;
    top: 3px;
    right: 2px;
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
    border-radius: 999px;
    background: var(--danger);
    color: #fff;
    font-size: 0.72rem;
    font-weight: 800;
    line-height: 22px;
    text-align: center;
    border: 2px solid color-mix(in srgb, var(--bg-page) 85%, transparent);
    box-shadow: 0 8px 20px color-mix(in srgb, var(--danger) 28%, transparent);
}

.header-notification-menu {
    width: min(420px, calc(100vw - 32px));
    min-width: 320px;
    max-height: min(70vh, 560px);
    overflow-y: auto;
    padding: 0.35rem;
    border-radius: 14px;
    border: 1px solid var(--surface-panel-border);
    background: var(--surface-panel-bg);
    box-shadow: var(--shadow);
}

.header-notification-dropdown .dropdown-menu {
    margin-bottom: 0.55rem;
}

.header-notification-menu .dropdown-item {
    color: var(--text-secondary);
    border-radius: 10px;
}

.header-notification-actions {
    list-style: none;
    margin: 0 0 0.32rem;
    padding: 0 0 0.34rem;
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--surface-panel-bg);
    border-bottom: 1px solid var(--surface-panel-border);
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.55rem;
}

.header-notification-sound-wrap {
    display: inline-flex;
    align-items: center;
    gap: 0;
    min-width: 0;
}

.header-notification-sound-select {
    width: auto;
    flex: 0 0 auto;
    height: 32px;
    padding: 0.28rem 1.95rem 0.28rem 0.58rem;
    border-radius: 9px;
    border: 1px solid color-mix(in srgb, var(--surface-panel-border) 78%, var(--accent) 22%);
    background-color: color-mix(in srgb, var(--surface-panel-bg) 78%, var(--surface-empty-bg) 22%);
    color: var(--text-primary);
    color-scheme: light;
    font-size: 0.73rem;
    font-weight: 600;
    line-height: 1.2;
}

.header-notification-sound-select option {
    background-color: #ffffff !important;
    color: #111111 !important;
}

.header-notification-sound-select:focus {
    border-color: color-mix(in srgb, var(--accent) 72%, var(--surface-panel-border));
    box-shadow: 0 0 0 0.14rem color-mix(in srgb, var(--accent-soft) 44%, transparent);
    background-color: #ffffff;
    color: #111111;
    outline: none;
}

.header-notification-sound-select:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.header-notification-mark-all {
    width: auto;
    max-width: 100%;
    margin-left: auto;
    border: 1px solid color-mix(in srgb, var(--accent) 42%, var(--surface-panel-border));
    border-radius: 9px;
    background: color-mix(in srgb, var(--surface-panel-bg) 70%, var(--accent-soft) 30%);
    color: var(--text-primary);
    font-size: 0.74rem;
    font-weight: 700;
    line-height: 1.2;
    padding: 0.42rem 0.58rem;
    transition: border-color 0.16s ease, background-color 0.16s ease, opacity 0.16s ease;
    display: inline-flex;
    align-items: center;
    gap: 0.38rem;
    white-space: nowrap;
}

.header-notification-mark-all i {
    font-size: 0.82rem;
    line-height: 1;
}

.header-notification-mark-all:hover:not(:disabled),
.header-notification-mark-all:focus-visible:not(:disabled) {
    border-color: color-mix(in srgb, var(--accent) 70%, var(--surface-panel-border));
    background: color-mix(in srgb, var(--surface-panel-bg) 56%, var(--accent-soft) 44%);
    outline: none;
}

.header-notification-mark-all:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.header-notification-item {
    list-style: none;
    margin: 0;
    position: relative;
}

.header-notification-link {
    display: block;
    padding: 0.6rem 2.85rem 0.6rem 0.75rem;
    border-radius: 10px;
    border: 1px solid transparent;
    color: inherit;
}

.header-notification-item.is-unread .header-notification-link {
    background: color-mix(in srgb, var(--accent-soft) 75%, transparent);
    border-color: color-mix(in srgb, var(--accent) 35%, var(--surface-panel-border));
}

.header-notification-item.is-read .header-notification-link {
    opacity: 0.9;
}

.header-notification-link:hover {
    background: var(--surface-empty-bg);
    border-color: var(--surface-card-hover-border);
}

.header-notification-mark-one {
    position: absolute;
    top: 50%;
    right: 0.62rem;
    transform: translateY(-50%);
    width: 26px;
    height: 26px;
    border-radius: 8px;
    border: 1px solid color-mix(in srgb, var(--surface-panel-border) 75%, transparent);
    background: color-mix(in srgb, var(--surface-panel-bg) 78%, var(--surface-empty-bg) 22%);
    color: var(--surface-card-head-text);
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    transition: border-color 0.16s ease, background-color 0.16s ease, color 0.16s ease, opacity 0.16s ease;
}

.header-notification-mark-one i {
    font-size: 0.86rem;
    line-height: 1;
}

.header-notification-mark-one.is-unread {
    color: color-mix(in srgb, var(--accent) 78%, var(--text-primary));
    border-color: color-mix(in srgb, var(--accent) 42%, var(--surface-panel-border));
}

.header-notification-mark-one:hover:not(:disabled),
.header-notification-mark-one:focus-visible:not(:disabled) {
    background: color-mix(in srgb, var(--surface-panel-bg) 60%, var(--accent-soft) 40%);
    border-color: color-mix(in srgb, var(--accent) 72%, var(--surface-panel-border));
    color: color-mix(in srgb, var(--accent) 92%, var(--text-primary));
    outline: none;
}

.header-notification-mark-one:disabled {
    cursor: default;
    opacity: 0.68;
}

.header-notification-item-title {
    display: inline-flex;
    align-items: center;
    gap: 0.38rem;
    font-weight: 700;
    font-size: 0.88rem;
    color: var(--text-primary);
    margin-bottom: 0.15rem;
}

.header-notification-item-title i {
    color: var(--notification-icon-default-color);
    font-size: 0.82rem;
    line-height: 1;
}

.header-notification-item-title i.notification-icon-job-assigned,
.notification-toast-title i.notification-icon-job-assigned {
    color: var(--notification-icon-job-color);
}

.header-notification-item-title i.notification-icon-task-comment,
.notification-toast-title i.notification-icon-task-comment {
    color: var(--notification-icon-comment-color);
}

.header-notification-item-title i.notification-icon-default,
.notification-toast-title i.notification-icon-default {
    color: var(--notification-icon-default-color);
}

.header-notification-item-message {
    color: var(--text-secondary);
    font-size: 0.8rem;
    line-height: 1.35;
    white-space: normal;
    margin-bottom: 0.18rem;
}

.header-notification-item-time {
    color: var(--surface-card-head-text);
    font-size: 0.7rem;
    font-weight: 600;
}

.notification-toast-container {
    position: fixed;
    top: 14px;
    right: 14px;
    left: auto;
    width: min(360px, calc(100vw - 28px));
    display: grid;
    gap: 0.5rem;
    z-index: 2147482500;
    pointer-events: none;
}

html:has(.app-shell.is-embedded) .notification-toast-container {
    right: 14px;
    left: auto;
    width: min(360px, calc(100vw - 28px));
}

.notification-toast {
    pointer-events: auto;
    cursor: pointer;
    border-radius: 14px;
    border: 1px solid var(--notification-toast-border);
    background: var(--notification-toast-bg);
    box-shadow: var(--notification-toast-shadow);
    padding: 0.75rem 0.85rem;
    opacity: 0;
    transform: translateY(-8px) scale(0.98);
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.notification-toast.notification-toast-inline {
    cursor: default;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.notification-toast.notification-toast-inline.is-success {
    border-color: var(--notification-toast-success-border);
    background: var(--notification-toast-success-bg);
}

.notification-toast.notification-toast-inline.is-warning {
    border-color: var(--notification-toast-warning-border);
    background: var(--notification-toast-warning-bg);
}

.notification-toast.notification-toast-inline.is-error {
    border-color: var(--notification-toast-error-border);
    background: var(--notification-toast-error-bg);
}

.notification-toast.show {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.notification-toast-title {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.88rem;
    font-weight: 800;
    color: var(--notification-toast-title);
    margin-bottom: 0.15rem;
}

.notification-toast-title i {
    color: var(--notification-icon-default-color);
    font-size: 0.84rem;
    line-height: 1;
}

.notification-toast-message {
    font-size: 0.8rem;
    color: var(--notification-toast-message);
    line-height: 1.35;
}

.notification-toast-time {
    margin-top: 0.35rem;
    font-size: 0.7rem;
    color: var(--notification-toast-time);
}

#gdSystemWatchBanner.gd-system-watch-banner {
    position: fixed;
    top: 12px;
    left: 50%;
    transform: translateX(-50%);
    width: min(620px, calc(100vw - 16px));
    z-index: var(--z-popup-top);
    margin: 0;
    border-radius: 12px;
    border-width: 1px;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
    background: #0d6efd;
    border-color: #0a58ca;
    color: #ffffff;
}

#gdSystemWatchBanner.gd-system-watch-banner.is-offline {
    background: #fff3cd;
    border-color: #ffecb5;
    color: #664d03;
}

.gd-system-watch-title {
    font-size: 0.92rem;
}

.gd-system-watch-message {
    opacity: 0.95;
    white-space: pre-line;
}

.gd-system-watch-refresh {
    min-width: 86px;
    border-color: rgba(255, 255, 255, 0.75);
    color: #ffffff;
}

.gd-system-watch-refresh:hover,
.gd-system-watch-refresh:focus-visible {
    background: rgba(255, 255, 255, 0.14);
    border-color: #ffffff;
    color: #ffffff;
}

.todo-panel-shell {
    position: fixed;
    left: 12px;
    bottom: 12px;
    width: min(250px, calc(100vw - 24px));
    height: min(620px, calc(var(--app-viewport-100) - 96px));
    border-radius: 14px;
    border: 1px solid var(--surface-panel-border);
    background: var(--surface-panel-bg);
    box-shadow: 0 24px 40px rgba(0, 0, 0, 0.32);
    display: grid;
    grid-template-rows: auto 1fr;
    overflow: hidden;
    z-index: 2147482200;
    backdrop-filter: blur(6px);
}

.app-sidebar .todo-panel-shell {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    top: auto;
    width: auto;
    height: min(28vh, 320px);
    flex: 0 0 auto;
    margin: 0 0.75rem 0.75rem;
    z-index: 1;
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.18);
    border-color: var(--surface-panel-border);
}

.todo-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.9rem 0.75rem 0.65rem;
    border-bottom: 1px solid var(--surface-panel-header-border);
    cursor: pointer;
}

.todo-panel-header:focus-visible {
    outline: 2px solid var(--theme-btn-primary-border, rgba(255, 255, 255, 0.45));
    outline-offset: -2px;
}

.todo-panel-title {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--surface-panel-header-text);
    letter-spacing: -0.01em;
}

.todo-panel-actions {
    display: inline-flex;
    gap: 0.35rem;
}

.todo-panel-actions .btn {
    border-radius: 8px;
    padding: 0.25rem 0.45rem;
}

.todo-panel-list {
    padding: 0.55rem;
    overflow-y: auto;
    display: grid;
    align-content: start;
    gap: 0.5rem;
}

.todo-panel-shell.is-collapsed {
    height: auto;
    grid-template-rows: auto;
}

.todo-panel-shell.is-collapsed .todo-panel-header {
    border-bottom-color: transparent;
}

.todo-panel-shell.is-collapsed .todo-panel-list {
    display: none;
}

.todo-empty {
    color: var(--surface-empty-text);
    font-size: 0.84rem;
    border-radius: 10px;
    border: 1px dashed var(--surface-empty-border);
    padding: 0.8rem;
    background: var(--surface-empty-bg);
}

.todo-item {
    border-radius: 12px;
    border: 1px solid var(--surface-card-border);
    background: var(--surface-card-bg);
    padding: 0.65rem 0.7rem;
    cursor: pointer;
    position: relative;
    box-shadow: inset 3px 0 0 var(--todo-item-accent);
}

.todo-item:hover {
    border-color: var(--surface-card-hover-border);
    background: var(--surface-card-bg);
}

.todo-item.done {
    opacity: 0.7;
    box-shadow: inset 3px 0 0 var(--todo-item-done-accent);
}

.todo-item.done .todo-item-title,
.todo-item.done .todo-note {
    text-decoration: line-through;
}

.todo-item-header {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 0.35rem;
}

.todo-item-title {
    font-weight: 800;
    font-size: 0.93rem;
    color: var(--text-primary);
    line-height: 1.2;
}

.todo-item .todo-actions {
    display: inline-flex;
    align-items: center;
}

.todo-toggle {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    border: 1px solid var(--todo-toggle-border);
    background: var(--todo-toggle-bg);
    color: var(--todo-toggle-text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: border-color 0.14s ease, background-color 0.14s ease, color 0.14s ease;
}

.todo-toggle:hover {
    border-color: var(--todo-toggle-hover-border);
    color: var(--todo-toggle-hover-text);
    background: var(--todo-toggle-hover-bg);
}

.todo-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.15rem 0.45rem;
    border-radius: 999px;
    background: var(--todo-badge-new-bg);
    color: var(--todo-badge-new-text);
    border: 1px solid var(--todo-badge-new-border);
    font-size: 0.68rem;
    font-weight: 800;
    line-height: 1;
}

.todo-badge.is-done {
    background: var(--todo-badge-done-bg);
    color: var(--todo-badge-done-text);
    border-color: var(--todo-badge-done-border);
}

.todo-note {
    margin-top: 0.35rem;
    color: var(--text-secondary);
    font-size: 0.8rem;
    line-height: 1.35;
    min-height: 2.05em;
}

.todo-meta {
    margin-top: 0.4rem;
    color: var(--text-secondary);
    font-size: 0.67rem;
    font-weight: 600;
}

.todo-preview {
    position: fixed;
    width: min(360px, calc(100vw - 24px));
    min-height: 360px;
    max-height: calc(var(--app-viewport-100) - 24px);
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px) scale(0.98);
    transition: opacity 0.14s ease, transform 0.14s ease, visibility 0.14s ease;
    z-index: 2147482300;
}

.todo-preview.open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
}

.todo-preview-inner {
    height: 100%;
    border-radius: 14px;
    border: 1px solid var(--surface-panel-border);
    background: var(--surface-panel-bg);
    box-shadow: 0 26px 40px rgba(0, 0, 0, 0.34);
    padding: 0.75rem;
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 0.55rem;
}

.todo-preview-header {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0.4rem;
    align-items: center;
}

.todo-preview-title-input,
.todo-preview-note {
    width: 100%;
    border-radius: 10px;
    border: 1px solid var(--surface-panel-border);
    background: var(--surface-subpanel-bg);
    color: var(--text-primary);
    outline: none;
}

.todo-preview-title-input {
    min-height: 38px;
    padding: 0.5rem 0.7rem;
    font-weight: 700;
}

.todo-preview-note {
    resize: none;
    padding: 0.65rem 0.7rem;
    line-height: 1.4;
    font-size: 0.9rem;
}

.todo-preview-title-input[readonly],
.todo-preview-note[readonly] {
    border-color: transparent;
    background: var(--surface-empty-bg);
}

.todo-preview-title-input.editing,
.todo-preview-note.editing {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.04);
    background: var(--surface-subpanel-bg);
}

.todo-preview-close {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    border: 1px solid var(--surface-panel-border);
    background: var(--surface-empty-bg);
    color: var(--text-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.todo-preview-close:hover {
    background: var(--todo-preview-close-hover-bg);
    border-color: var(--todo-preview-close-hover-border);
}

.todo-preview-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.todo-preview-meta {
    color: var(--text-secondary);
    font-size: 0.72rem;
}

.todo-preview-actions {
    display: inline-flex;
    gap: 0.35rem;
}

.todo-preview-check,
.todo-preview-delete {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    border: 1px solid var(--surface-panel-border);
    background: var(--surface-empty-bg);
    color: var(--text-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.todo-preview-check.active {
    color: var(--todo-preview-check-active-text);
    border-color: var(--todo-preview-check-active-border);
    background: var(--todo-preview-check-active-bg);
}

.todo-preview-check:hover:not(:disabled) {
    background: var(--todo-toggle-hover-bg);
    border-color: var(--todo-toggle-hover-border);
    color: var(--todo-toggle-hover-text);
}

.todo-preview-delete:hover:not(:disabled) {
    background: var(--todo-preview-delete-hover-bg);
    border-color: var(--todo-preview-delete-hover-border);
    color: var(--todo-preview-delete-hover-text);
}

.todo-panel-actions #todoAddBtn {
    color: var(--theme-btn-primary-text) !important;
    border-color: var(--theme-btn-primary-border) !important;
    background: var(--theme-btn-primary-bg) !important;
}

.todo-panel-actions #todoAddBtn:hover,
.todo-panel-actions #todoAddBtn:focus {
    color: var(--theme-btn-primary-text) !important;
    border-color: var(--theme-btn-primary-border) !important;
    background: var(--theme-btn-primary-bg) !important;
    filter: brightness(0.95) saturate(1.03);
}

.todo-preview-delete:disabled,
.todo-preview-delete.disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

@media (max-width: 1199px) {
    .todo-panel-shell {
        width: 220px;
        height: min(470px, calc(var(--app-viewport-100) - 90px));
    }

    .todo-preview {
        width: min(320px, calc(100vw - 20px));
    }

    .app-sidebar .todo-panel-shell {
        height: min(24vh, 250px);
    }
}

@media (max-width: 860px) {
    .todo-panel-shell {
        left: 8px;
        bottom: 8px;
        width: min(200px, calc(100vw - 16px));
        height: min(340px, calc(var(--app-viewport-100) - 80px));
    }

    .todo-preview {
        left: 8px !important;
        top: auto !important;
        bottom: calc(min(340px, calc(var(--app-viewport-100) - 80px)) + 16px);
        height: min(340px, calc(var(--app-viewport-100) - 100px));
    }

    .notification-toast-container {
        top: 8px;
        right: 8px;
        left: auto;
        width: min(320px, calc(100vw - 16px));
    }

    .header-notification-menu {
        width: min(360px, calc(100vw - 20px));
        min-width: 280px;
    }

    .header-notification-actions {
        gap: 0.4rem;
    }

    .header-notification-dropdown {
        right: max(0px, env(safe-area-inset-right));
        bottom: max(0px, env(safe-area-inset-bottom));
    }

    .header-notification-btn {
        width: 48px;
        height: 48px;
    }

    .header-notification-btn .bi {
        font-size: 1.18rem;
    }

    .header-notification-badge {
        min-width: 20px;
        height: 20px;
        line-height: 20px;
        font-size: 0.68rem;
        padding: 0 5px;
        top: 2px;
        right: 1px;
    }

    .app-sidebar .todo-panel-shell {
        display: none;
    }
}

* {
    box-sizing: border-box;
}

html,
body,
form {
    height: 100%;
}

body {
    margin: 0;
    font-family: "Manrope", sans-serif;
    color: var(--text-primary);
    background: radial-gradient(circle at 20% 5%, #192230 0%, var(--bg-page) 40%, #0d1016 100%);
}

html {
    scrollbar-color: var(--surface-scrollbar-thumb) var(--surface-scrollbar-track);
    scrollbar-width: thin;
}

* {
    scrollbar-color: var(--surface-scrollbar-thumb) var(--surface-scrollbar-track);
    scrollbar-width: thin;
}

*::-webkit-scrollbar {
    width: var(--surface-scrollbar-size);
    height: var(--surface-scrollbar-size);
}

*::-webkit-scrollbar-track {
    background: var(--surface-scrollbar-track);
}

*::-webkit-scrollbar-thumb {
    background: var(--surface-scrollbar-thumb);
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: padding-box;
}

*::-webkit-scrollbar-thumb:hover {
    background: var(--surface-scrollbar-thumb-hover);
}

a {
    text-decoration: none;
}

.app-shell {
    display: block;
    min-height: 100%;
    box-sizing: border-box;
    padding-left: var(--sidebar-width);
}

.app-sidebar {
    background: var(--bg-sidebar);
    border-right: 1px solid var(--border-color);
    padding: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: fixed;
    left: 0;
    top: 0;
    width: var(--sidebar-width);
    height: var(--app-viewport-100);
    z-index: var(--z-sidebar);
    transform: translateX(0);
    transition: none;
    will-change: auto;
    box-shadow: 0 24px 50px rgba(0, 0, 0, 0.32);
}

.brand-block {
    background: var(--brand-block-bg);
    color: var(--brand-block-text);
    padding: 1rem 1.25rem;
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: -1px;
}

.brand-text {
    text-transform: lowercase;
}

.menu-groups {
    padding: 1rem 0.75rem;
    display: flex;
    flex-direction: column;
    gap: calc(0.4rem - 2px);
    overflow-y: auto;
    flex: 1 1 auto;
    min-height: 0;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
}

.menu-groups::-webkit-scrollbar {
    width: 10px;
}

.menu-groups::-webkit-scrollbar-track {
    background: transparent;
}

.menu-groups::-webkit-scrollbar-thumb {
    background: var(--surface-scrollbar-thumb);
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: padding-box;
}

.menu-link {
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 0.75rem;
    border: 1px solid transparent;
    border-radius: 12px;
    padding: 0.7rem 0.8rem;
    font-size: 1rem;
    font-weight: 600;
}

.menu-link:hover {
    color: var(--menu-link-hover-text);
    background: var(--menu-link-hover-bg);
    border-color: var(--menu-link-hover-border);
}

.menu-link.active:not(.menu-subsection-toggle) {
    color: var(--menu-link-active-text);
    background: var(--menu-link-active-bg);
    border-color: var(--menu-link-active-border);
}

.menu-link i {
    font-size: 1.1rem;
}

.menu-link-sub {
    margin-left: 1.9rem;
    padding-left: 0.6rem;
    font-size: 0.95rem;
    color: var(--text-secondary);
}

.menu-subsection-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    border: 1px solid transparent;
    background: transparent;
    color: var(--text-secondary);
    font-size: 0.9rem;
    font-weight: 800;
    padding: 0.7rem 0.8rem;
    cursor: pointer;
    text-align: left;
}

.menu-subsection-title {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}

.menu-subsection-title i {
    font-size: 1.1rem;
}

.menu-subsection-toggle > i {
    font-size: 0.72rem;
    transition: transform 0.15s ease;
}

.menu-subsection-toggle[aria-expanded="true"] > i {
    transform: rotate(180deg);
}

.menu-subsection-group {
    margin: 0;
    padding: 0;
    display: none;
}

.menu-subsection-group.is-open {
    display: block;
}

.sidebar-footer {
    margin-top: auto;
    flex: 0 0 auto;
    padding: 1rem;
    border-top: 1px solid var(--border-color);
    background: linear-gradient(180deg, rgba(17, 23, 34, 0) 0%, rgba(10, 13, 19, 0.9) 100%);
}

.app-main {
    display: block;
    --app-header-expanded-height: 72px;
    --app-header-collapsed-height: 10px;
    min-height: var(--app-viewport-100);
    margin-left: 0;
    width: auto;
    min-width: 0;
    position: relative;
}

.app-header {
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0 1.25rem;
    background: var(--surface-panel-bg);
    backdrop-filter: blur(8px);
    height: var(--app-header-expanded-height);
    overflow: hidden;
    position: fixed;
    top: 0;
    left: var(--sidebar-width);
    right: 0;
    width: auto;
    z-index: 9999;
    transform: translateY(calc(-1 * (var(--app-header-expanded-height) - var(--app-header-collapsed-height))));
    transition: transform 0.24s cubic-bezier(0.22, 1, 0.36, 1), background-color 0.2s ease, border-color 0.2s ease;
    will-change: transform;
}

.app-header > * {
    opacity: 0;
    transform: translateY(-10px);
    pointer-events: none;
    transition: opacity 0.16s ease, transform 0.22s cubic-bezier(0.22, 1, 0.36, 1);
}

@media (hover: hover) and (pointer: fine) {
    .app-main:has(.app-header:hover) .app-header {
        transform: translateY(0);
    }
}

.app-main:has(.app-header:focus-within) .app-header {
    transform: translateY(0);
}

.app-main:has(.app-header:hover) .app-header,
.app-main:has(.app-header:focus-within) .app-header {
    background: var(--surface-panel-bg);
    border-bottom-color: var(--surface-card-hover-border);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12);
    overflow: visible;
}

.app-main:has(.app-header:hover) .app-header > *,
.app-main:has(.app-header:focus-within) .app-header > * {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

@media (hover: none), (pointer: coarse) {
    .app-header {
        transform: translateY(0);
        overflow: visible;
    }

    .app-header > * {
        opacity: 1;
        transform: none;
        pointer-events: auto;
    }

    .app-content {
        padding-top: calc(1rem + var(--app-header-expanded-height));
    }
}

.header-username {
    font-weight: 700;
    font-size: 0.95rem;
}

.header-theme-picker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-width: 220px;
    max-width: 320px;
    padding: 0.2rem 0.35rem;
    border: 1px solid var(--surface-panel-border);
    border-radius: 10px;
    background: var(--surface-widget-bg);
}

.header-theme-picker > i {
    color: var(--accent);
    font-size: 0.95rem;
    flex: 0 0 auto;
}

.header-theme-select {
    min-width: 0;
    border: 0;
    background: transparent;
    color: var(--text-primary);
    box-shadow: none !important;
    font-weight: 600;
    font-size: 0.85rem;
    padding-top: 0.2rem;
    padding-bottom: 0.2rem;
}

.header-theme-select:focus {
    background: transparent;
    color: var(--text-primary);
}

.header-theme-select:disabled {
    opacity: 0.7;
}

.header-user {
    min-width: 0;
    flex-wrap: nowrap;
}

.header-user-switch {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    min-width: 220px;
    max-width: none;
    padding: 0.2rem 0.35rem;
    border: 1px solid var(--surface-panel-border);
    border-radius: 10px;
    background: var(--surface-widget-bg);
}

.header-user-switch > i {
    color: var(--accent);
    font-size: 0.95rem;
    flex: 0 0 auto;
}

.header-user-switch-select {
    flex: 0 0 auto;
    width: 168px;
    max-width: none;
    min-width: 0;
    border: 0;
    background: transparent;
    color: var(--text-primary);
    box-shadow: none !important;
    font-weight: 600;
    font-size: 0.82rem;
    padding-top: 0.2rem;
    padding-bottom: 0.2rem;
}

.header-user-switch-select:focus {
    background: transparent;
    color: var(--text-primary);
}

.header-user-switch .btn {
    white-space: nowrap;
}

.header-user-switch-apply,
.header-user-switch-return {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.header-user-switch-apply {
    min-width: 58px;
    padding-left: 0.7rem;
    padding-right: 0.7rem;
}

@media (max-width: 1360px) {
    .header-user-switch {
        min-width: 220px;
        max-width: none;
    }
}

.app-content {
    padding: calc(1rem + var(--app-header-collapsed-height)) 1rem 1rem;
}

.app-shell.is-embedded {
    padding-left: 0;
}

.app-shell.is-embedded .app-sidebar,
.app-shell.is-embedded .app-header {
    display: none !important;
}

.app-shell.is-embedded .app-main {
    min-height: 0;
}

.app-shell.is-embedded .app-content {
    padding: 0 !important;
}

.app-shell.is-embedded #jobViewBackButton {
    display: none !important;
}

.app-shell.is-embedded,
.app-shell.is-embedded .app-main,
.app-shell.is-embedded .app-content {
    height: 100%;
    min-height: 0;
    overflow: hidden;
}

.app-shell.is-embedded #jobViewPage {
    height: 100%;
    min-height: 0;
    overflow: hidden;
}

.app-shell.is-embedded #jobViewPage .job-view-shell {
    height: 100%;
    min-height: 0;
    grid-template-rows: auto minmax(0, 1fr);
    overflow: hidden;
}

.app-shell.is-embedded #jobViewPage .job-view-main-layout {
    flex-wrap: nowrap;
    align-items: stretch;
    min-height: 0;
    overflow: hidden;
}

.app-shell.is-embedded #jobViewPage .job-view-left-column,
.app-shell.is-embedded #jobViewPage .job-view-right-column {
    display: flex;
    min-height: 0;
    overflow: hidden;
}

.app-shell.is-embedded #jobViewPage .job-view-detail-card,
.app-shell.is-embedded #jobViewPage .job-view-flow-card {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    width: 100%;
    overflow: hidden;
}

.app-shell.is-embedded #jobViewPage .job-view-detail-card .board-card-body {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    overflow: hidden;
    overscroll-behavior: contain;
}

.app-shell.is-embedded #jobViewPage #jobViewSelectedStage {
    flex: 1 1 auto;
    min-height: 0;
}

.app-shell.is-embedded #jobViewPage #jobViewSelectedStage .job-view-stage-detail {
    height: 100%;
    min-height: 0;
    overflow: hidden;
}

.app-shell.is-embedded #jobViewPage #jobViewSelectedStage .job-view-stage-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    max-height: none;
    margin-bottom: 0;
}

.app-shell.is-embedded #jobViewPage .job-view-chip-row {
    display: none;
}

.app-shell.is-embedded #jobViewPage .job-view-summary-tiles {
    flex: 0 0 auto;
}

.app-shell.is-embedded #jobViewPage .job-view-flow-card .board-card-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
}

.app-shell.is-embedded #jobViewPage .job-view-flow-timeline {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
    overflow: auto;
    overscroll-behavior: contain;
    align-items: stretch;
    padding-right: 0.35rem;
}

.daily-header-row {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    margin-bottom: 1rem;
    gap: 1rem;
}

.daily-date,
.daily-time {
    font-size: 1.8rem;
    color: #56e17a;
    font-weight: 700;
}

.daily-time {
    text-align: right;
}

.daily-title {
    text-align: center;
    font-size: 2rem;
    font-weight: 800;
    color: #7eff8e;
    letter-spacing: 1px;
}

.timeline-wrapper {
    --timeline-caption-width: 188px;
    --timeline-hours-right-pad: 6px;
    --timeline-lane-left-gap: 6px;
    border: 1px solid var(--border-color);
    border-radius: 14px;
    background: var(--surface-lane-bg);
    margin-bottom: 1rem;
    overflow: hidden;
    box-shadow: var(--shadow);
}

.timeline-hours {
    display: grid;
    grid-template-columns: repeat(17, minmax(0, 1fr));
    padding: 0.6rem var(--timeline-hours-right-pad) 0.6rem calc(((34 * var(--timeline-caption-width)) - 100% + var(--timeline-hours-right-pad)) / 33);
    border-bottom: 1px solid var(--border-color);
    color: #84a4c8;
    font-size: 0.74rem;
    font-weight: 700;
}

.timeline-hours span {
    text-align: center;
    white-space: nowrap;
}

.timeline-hours span:last-child {
    justify-self: end;
    text-align: right;
    padding-right: 2px;
}

.timeline-row {
    display: grid;
    grid-template-columns: var(--timeline-caption-width) 1fr;
    min-height: 48px;
    align-items: center;
    border-top: 1px solid rgba(43, 54, 70, 0.65);
}

.timeline-caption {
    border-right: 1px solid var(--border-color);
    padding: 0 1rem;
    color: #cdd7e8;
    font-weight: 700;
    white-space: nowrap;
}

.timeline-caption span {
    color: #f3f8ff;
    margin-right: 0.45rem;
}

.timeline-lane {
    padding: 0 0.4rem 0 var(--timeline-lane-left-gap);
    display: flex;
    align-items: center;
    min-height: 48px;
    gap: 0.3rem;
}

.timeline-block {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    border-radius: 6px;
    color: #f8fbff;
    font-size: 0.7rem;
    font-weight: 700;
    min-width: 16px;
    white-space: nowrap;
    text-align: center;
    line-height: 1;
    overflow: hidden;
}

.timeline-block.planned {
    background: linear-gradient(90deg, #5b670f 0%, #7e8f21 100%);
}

.timeline-block.actual {
    background: linear-gradient(90deg, #01576d 0%, #167892 100%);
}

.daily-grid {
    display: grid;
    grid-template-columns: minmax(280px, 0.5fr) minmax(0, 1.5fr);
    gap: 1rem;
    align-items: stretch;
    min-height: clamp(560px, calc(var(--app-viewport-100) - 255px - var(--app-header-collapsed-height)), 860px);
}

.daily-left-column {
    display: grid;
    grid-template-rows: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    min-height: 0;
}

.daily-right-column {
    display: grid;
    grid-template-columns: minmax(0, 2.4fr) minmax(270px, 1fr);
    gap: 1rem;
    min-height: 0;
}

.daily-left-column > .board-card,
.daily-right-column > .board-card,
.daily-right-column > .working-card {
    min-height: 0;
    height: 100%;
}

.daily-left-column .board-card-body,
.daily-right-column .board-card-body {
    min-height: 0;
}

.daily-left-column .board-card-body.drop-lane,
.daily-right-column .board-card-body.drop-lane {
    height: 100%;
}

.board-card,
.working-card {
    border: 1px solid var(--surface-panel-border);
    border-radius: 14px;
    background: var(--surface-panel-bg);
    box-shadow: var(--shadow);
    min-height: 560px;
    display: flex;
    flex-direction: column;
}

.board-card-header,
.working-card-header {
    border-bottom: 1px solid var(--surface-panel-header-border);
    padding: 0.9rem 0.95rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
}

.board-card-header h3,
.working-card-header h3 {
    font-size: 1.1rem;
    margin: 0;
    font-weight: 800;
}

.header-columns {
    display: flex;
    gap: 0.8rem;
    color: var(--text-secondary);
    font-size: 0.76rem;
    font-weight: 700;
}

.board-card-body {
    padding: 0.6rem;
    overflow-y: auto;
    min-height: 500px;
    flex: 1 1 auto;
}

.board-card-body.drop-lane {
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.drop-lane > .job-card,
.drop-lane > .empty-lane {
    flex: 0 0 auto;
}

.drop-lane {
    position: relative;
}

.drop-lane.drag-over {
    outline: none;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 28%, transparent), inset 0 0 22px color-mix(in srgb, var(--accent) 20%, transparent);
}

.drop-lane.drag-over::after {
    content: "";
    position: absolute;
    inset: 4px;
    border-radius: 10px;
    pointer-events: none;
    z-index: 3;
    opacity: 0.96;
    background: repeating-conic-gradient(
        from 0deg,
        color-mix(in srgb, var(--accent) 90%, white 10%) 0deg 10deg,
        transparent 10deg 22deg
    );
    padding: 2px;
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    mask-composite: exclude;
    animation: drop-lane-dash-spin 2.2s linear infinite, drop-lane-glow-breathe 1.1s ease-in-out infinite alternate;
}

.job-card {
    border: 1px solid var(--surface-card-border);
    background: var(--surface-card-bg);
    border-radius: 10px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0.75rem;
    padding: 0.65rem;
    margin-bottom: 0.55rem;
    cursor: pointer;
    position: relative;
    isolation: isolate;
    overflow: hidden;
    transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.job-card::after {
    content: "";
    position: absolute;
    inset: -1px;
    padding: 1px;
    border-radius: inherit;
    opacity: 0;
    pointer-events: none;
    z-index: 1;
    background: conic-gradient(
        from 0deg,
        color-mix(in srgb, var(--accent) 88%, white 12%) 0deg,
        color-mix(in srgb, var(--surface-card-hover-border) 45%, transparent) 90deg,
        color-mix(in srgb, var(--accent) 78%, transparent) 180deg,
        color-mix(in srgb, var(--surface-card-hover-border) 55%, var(--accent) 45%) 270deg,
        color-mix(in srgb, var(--accent) 88%, white 12%) 360deg
    );
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    mask-composite: exclude;
}

.job-card > * {
    position: relative;
    z-index: 2;
}

.job-card:hover {
    border-color: var(--surface-card-hover-border);
    box-shadow: 0 8px 18px rgba(4, 7, 11, 0.22);
}

.job-card.is-selected,
.job-card.active {
    border-color: color-mix(in srgb, var(--accent) 66%, var(--surface-card-hover-border) 34%);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent), 0 10px 24px rgba(4, 7, 11, 0.24);
}

.job-card.is-selected::after,
.job-card.active::after {
    opacity: 0.9;
    animation: job-view-flow-border-spin 3.2s linear infinite;
}

.job-card.is-selected::before,
.job-card.active::before {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    pointer-events: none;
    z-index: 1;
    background: radial-gradient(circle at 14% 10%, color-mix(in srgb, var(--accent) 16%, transparent) 0%, transparent 56%);
}

.job-card:hover::after,
.job-card:focus-visible::after {
    opacity: 1;
    animation: job-view-flow-border-spin 2.4s linear infinite;
}

.job-card.dragging {
    opacity: 0.45;
}

.job-card.dragging::after {
    opacity: 0 !important;
    animation: none !important;
}

.job-card.completed {
    border-color: var(--surface-card-complete-border);
    background: var(--surface-card-complete-bg);
}

.job-card.is-running {
    border-color: color-mix(in srgb, #2ca24f 60%, var(--surface-card-border) 40%);
    background: linear-gradient(0deg, rgba(44, 162, 79, 0.5), rgba(44, 162, 79, 0.5)), var(--surface-card-bg);
}

.job-card.incomplete-readonly,
.job-card.incomplete-readonly.is-running {
    border-color: color-mix(in srgb, #d63b3b 72%, var(--surface-card-border) 28%);
    background: linear-gradient(0deg, rgba(214, 59, 59, 0.34), rgba(214, 59, 59, 0.34)), var(--surface-card-bg);
    cursor: pointer;
    pointer-events: auto;
    box-shadow: none;
}

.job-card.incomplete-readonly.is-selected,
.job-card.incomplete-readonly.active,
.job-card.incomplete-readonly:hover,
.job-card.incomplete-readonly:focus-visible {
    border-color: color-mix(in srgb, #d63b3b 76%, var(--surface-card-border) 24%);
    box-shadow: none;
}

.job-card.incomplete-readonly::before,
.job-card.incomplete-readonly::after {
    opacity: 0 !important;
    animation: none !important;
}

.job-card-main {
    min-width: 0;
}

.job-card-head {
    font-size: 0.72rem;
    color: var(--surface-card-head-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.job-card-title {
    margin-top: 0.28rem;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.25;
}

.job-card-action {
    margin-top: 0.24rem;
    font-size: 0.74rem;
    color: var(--surface-card-action-text);
}

.job-card-effort-pending {
    margin-top: 0.14rem;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--warning);
}

.job-card-metrics {
    display: grid;
    align-content: center;
    gap: 0.22rem;
    font-size: 0.76rem;
    color: var(--surface-card-metrics-text);
    font-weight: 700;
    text-align: right;
}

.planning-job-card.has-delegated-task {
    padding-bottom: 1.1rem;
}

.planning-job-card .planning-delegated-refresh-indicator {
    position: absolute;
    right: 0.52rem;
    bottom: 0.34rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.82rem;
    line-height: 1;
    color: color-mix(in srgb, #8eb8ff 76%, var(--text-primary) 24%);
    opacity: 0.92;
    pointer-events: none;
}

.empty-lane {
    border: 1px dashed var(--surface-empty-border);
    border-radius: 10px;
    color: var(--surface-empty-text);
    background: var(--surface-empty-bg);
    text-align: center;
    font-size: 0.85rem;
    padding: 1rem;
}

.job-context-menu {
    position: fixed;
    min-width: 210px;
    padding: 0.3rem;
    border: 1px solid var(--surface-subpanel-border, var(--surface-panel-border, #364a63));
    border-radius: 10px;
    background: var(--surface-subpanel-bg, #121a25);
    box-shadow: var(--context-menu-shadow);
    z-index: 2147483646;
    display: none;
    transform-origin: top left;
    will-change: transform, opacity;
}

.job-context-menu[aria-hidden="false"] {
    animation: job-context-menu-reveal 0.16s cubic-bezier(0.2, 0.85, 0.25, 1);
}

.job-context-menu[aria-hidden="false"] button {
    animation: job-context-menu-item-reveal 0.16s cubic-bezier(0.2, 0.85, 0.25, 1);
}

.job-context-menu[aria-hidden="false"] button:nth-child(1) { animation-delay: 0ms; }
.job-context-menu[aria-hidden="false"] button:nth-child(2) { animation-delay: 12ms; }
.job-context-menu[aria-hidden="false"] button:nth-child(3) { animation-delay: 24ms; }
.job-context-menu[aria-hidden="false"] button:nth-child(4) { animation-delay: 36ms; }
.job-context-menu[aria-hidden="false"] button:nth-child(5) { animation-delay: 48ms; }
.job-context-menu[aria-hidden="false"] button:nth-child(6) { animation-delay: 60ms; }
.job-context-menu[aria-hidden="false"] button:nth-child(7) { animation-delay: 72ms; }
.job-context-menu[aria-hidden="false"] button:nth-child(8) { animation-delay: 84ms; }

.job-context-menu button {
    animation-fill-mode: both;
}

.job-context-menu button {
    width: 100%;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: var(--text-primary, #d4e2f6);
    text-align: left;
    font-size: 0.86rem;
    font-weight: 700;
    padding: 0.58rem 0.62rem;
}

.job-context-menu button:hover,
.job-context-menu button:focus-visible {
    background: var(--accent-soft, #0f2f52);
    color: var(--text-primary, #f8fbff);
    outline: none;
}

.job-context-menu button:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.job-context-menu .planning-context-date-wrap .form-control {
    color: var(--text-primary, #d4e2f6);
    background: var(--surface-lane-bg, rgba(22, 28, 36, 0.94));
    border-color: var(--surface-subpanel-border, var(--surface-panel-border, #364a63));
}

.job-context-menu .planning-context-date-wrap .form-control:focus {
    color: var(--text-primary, #d4e2f6);
    background: var(--surface-lane-bg, rgba(22, 28, 36, 0.94));
    border-color: var(--accent, #2dd46f);
    box-shadow: 0 0 0 0.12rem color-mix(in srgb, var(--accent, #2dd46f) 22%, transparent);
}

.upload-toast {
    position: fixed;
    top: 1rem;
    right: 1rem;
    width: min(380px, calc(100vw - 2rem));
    z-index: 2147483645;
    background: var(--upload-toast-bg);
    border: 1px solid var(--upload-toast-border);
    border-radius: 12px;
    box-shadow: var(--upload-toast-shadow);
    padding: 0.75rem 0.875rem 0.875rem;
    color: var(--upload-toast-text);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-8px);
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.upload-toast.show {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.upload-toast.is-success {
    border-color: var(--upload-toast-success-border);
}

.upload-toast.is-error {
    border-color: var(--upload-toast-error-border);
}

.upload-toast-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.upload-toast-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--upload-toast-title);
}

.upload-toast-close {
    border: 0;
    background: transparent;
    color: var(--upload-toast-close);
    font-size: 1.25rem;
    line-height: 1;
    padding: 0;
    width: 1.5rem;
    height: 1.5rem;
    cursor: pointer;
}

.upload-toast-close:hover {
    color: var(--upload-toast-close-hover);
}

.upload-toast-text {
    margin-top: 0.35rem;
    font-size: 0.84rem;
    color: var(--upload-toast-text);
}

.upload-toast-progress {
    margin-top: 0.65rem;
    height: 7px;
    border-radius: 999px;
    background: var(--upload-toast-progress-bg);
    overflow: hidden;
}

.upload-toast-progress-bar {
    width: 0%;
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--upload-toast-progress-start) 0%, var(--upload-toast-progress-end) 100%);
    transition: width 0.18s ease;
}

.flow-empty {
    border: 1px dashed var(--surface-empty-border);
    border-radius: 12px;
    padding: 0.85rem;
    text-align: center;
    color: var(--surface-empty-text);
    background: var(--surface-empty-bg);
}

.attachment-thumb-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 0.55rem;
}

.attachment-thumb-list.compact {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 0.45rem;
}

.attachment-thumb-card {
    display: grid;
    grid-template-rows: auto auto;
    border: 1px solid #2f4056;
    border-radius: 10px;
    background: rgba(15, 23, 33, 0.94);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: border-color 0.15s ease, background-color 0.15s ease, transform 0.15s ease;
    min-width: 0;
}

.attachment-thumb-card:hover {
    border-color: #4a6383;
    background: rgba(18, 29, 41, 0.97);
    transform: translateY(-1px);
}

.attachment-thumb-media {
    position: relative;
    aspect-ratio: 16 / 10;
    background: linear-gradient(180deg, rgba(21, 31, 44, 0.98) 0%, rgba(13, 20, 29, 1) 100%);
    border-bottom: 1px solid rgba(63, 84, 108, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.attachment-thumb-list.compact .attachment-thumb-media {
    aspect-ratio: 4 / 3;
}

.attachment-thumb-media img,
.attachment-thumb-media video {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    background: #0f151d;
}

.attachment-thumb-media video {
    pointer-events: none;
}

.attachment-thumb-media.is-file {
    padding: 0.45rem;
}

.attachment-thumb-file {
    width: 100%;
    height: 100%;
    border: 1px dashed rgba(89, 114, 143, 0.55);
    border-radius: 8px;
    display: grid;
    align-content: center;
    justify-items: center;
    gap: 0.25rem;
    color: #b8cbe4;
    text-align: center;
    padding: 0.35rem;
}

.attachment-thumb-file i {
    font-size: 1.2rem;
    line-height: 1;
}

.attachment-thumb-ext {
    display: inline-block;
    max-width: 100%;
    padding: 0.1rem 0.35rem;
    border-radius: 999px;
    background: rgba(73, 99, 129, 0.3);
    color: #d4e5fb;
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.attachment-thumb-meta {
    min-width: 0;
    display: grid;
    gap: 0.16rem;
    padding: 0.42rem 0.5rem 0.48rem;
}

.attachment-thumb-name {
    font-size: 0.74rem;
    line-height: 1.2;
    color: #edf5ff;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.attachment-thumb-sub {
    font-size: 0.67rem;
    line-height: 1.2;
    color: #9bb1cf;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.attachment-thumb-card.compact .attachment-thumb-meta {
    padding: 0.38rem 0.42rem 0.4rem;
}

.attachment-thumb-card.compact .attachment-thumb-name {
    font-size: 0.7rem;
}

.attachment-thumb-card.compact .attachment-thumb-sub {
    font-size: 0.64rem;
}

.working-card-body {
    padding: 1rem;
    display: grid;
    grid-template-rows: auto auto auto minmax(0, 1fr) auto;
    gap: 1rem;
    min-height: 0;
}

#workingTaskBadge {
    font-size: 0.75rem;
    color: #89a6c8;
    font-weight: 700;
}

.working-meta {
    font-size: 0.82rem;
    color: #91aac9;
}

.working-title {
    font-size: 1.3rem;
    line-height: 1.4;
    font-weight: 800;
}

.timer-panel {
    background: var(--surface-widget-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 0.9rem;
}

.timer-display {
    font-size: 2.1rem;
    font-weight: 800;
    letter-spacing: 1px;
}

.timer-caption {
    margin-top: 0.35rem;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.4rem;
    color: #9cb5d3;
    font-size: 0.82rem;
}

.working-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.6rem;
}

.working-attachments {
    min-height: 0;
    border: 1px solid var(--surface-subpanel-border);
    border-radius: 12px;
    background: var(--surface-subpanel-bg);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.working-attachments-header {
    padding: 0.45rem 0.6rem;
    border-bottom: 1px solid var(--surface-subpanel-header-border);
    color: var(--surface-subpanel-header-text);
    font-size: 0.75rem;
    font-weight: 700;
}

.working-attachments-body {
    min-height: 0;
    overflow: auto;
    padding: 0.55rem;
}

.working-attachments-body .empty-lane {
    margin: 0;
    min-height: 110px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.6rem;
}

.dark-modal {
    background: var(--dark-modal-bg);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}

/* Keep every popup above fixed sidebar/header layers. */
.modal-backdrop,
.offcanvas-backdrop {
    z-index: var(--z-popup-backdrop) !important;
}

.modal,
.offcanvas {
    z-index: var(--z-popup) !important;
}

.dropdown-menu,
.popover,
.tooltip,
.toast-container,
.select2-container--open,
.flatpickr-calendar,
.ui-datepicker {
    z-index: var(--z-popup-top) !important;
}

.form-label {
    color: var(--theme-field-label);
    font-size: 0.83rem;
    font-weight: 700;
}

.form-control,
.form-select {
    background: var(--theme-field-bg);
    border-color: var(--theme-field-border);
    color: var(--theme-field-text);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--theme-field-focus-border);
    box-shadow: 0 0 0 0.2rem var(--theme-field-focus-ring);
    background: var(--theme-field-bg);
    color: var(--theme-field-text);
}

.form-check-input:checked {
    background-color: var(--accent);
    border-color: var(--accent);
}

.btn.btn-primary {
    background: var(--theme-btn-primary-bg);
    border-color: var(--theme-btn-primary-border);
    color: var(--theme-btn-primary-text);
}

.btn.btn-primary:hover,
.btn.btn-primary:focus,
.btn.btn-primary:active,
.btn.btn-primary.active,
.show > .btn.btn-primary.dropdown-toggle {
    background: var(--theme-btn-primary-bg);
    border-color: var(--theme-btn-primary-border);
    color: var(--theme-btn-primary-text);
    filter: brightness(0.94);
}

.btn.btn-primary:focus,
.btn.btn-primary.focus {
    box-shadow: 0 0 0 0.2rem var(--theme-focus-ring);
}

.btn.btn-primary.disabled,
.btn.btn-primary:disabled {
    background: var(--theme-btn-primary-bg);
    border-color: var(--theme-btn-primary-border);
    color: var(--theme-btn-primary-text);
    opacity: 0.55;
}

.btn.btn-success {
    background: var(--theme-btn-primary-bg);
    border-color: var(--theme-btn-primary-border);
    color: var(--theme-btn-primary-text);
}

.btn.btn-success:hover,
.btn.btn-success:focus,
.btn.btn-success:active,
.btn.btn-success.active,
.show > .btn.btn-success.dropdown-toggle {
    background: var(--theme-btn-primary-bg);
    border-color: var(--theme-btn-primary-border);
    color: var(--theme-btn-primary-text);
    filter: brightness(0.94);
}

.btn.btn-success:focus,
.btn.btn-success.focus {
    box-shadow: 0 0 0 0.2rem var(--theme-focus-ring);
}

.btn.btn-success.disabled,
.btn.btn-success:disabled {
    background: var(--theme-btn-primary-bg);
    border-color: var(--theme-btn-primary-border);
    color: var(--theme-btn-primary-text);
    opacity: 0.55;
}

.btn.btn-outline-light {
    color: var(--theme-btn-outline-text);
    background: var(--theme-btn-outline-bg);
    border-color: var(--theme-btn-outline-border);
}

.btn.btn-outline-light:hover,
.btn.btn-outline-light:focus,
.btn.btn-outline-light:active,
.btn.btn-outline-light.active,
.show > .btn.btn-outline-light.dropdown-toggle {
    color: var(--theme-btn-outline-hover-text);
    background: var(--theme-btn-outline-hover-bg);
    border-color: var(--theme-btn-outline-hover-border);
    box-shadow: none;
}

.btn.btn-outline-light:focus,
.btn.btn-outline-light.focus {
    box-shadow: 0 0 0 0.2rem var(--theme-focus-ring);
}

.btn.btn-outline-secondary {
    color: var(--theme-btn-outline-secondary-text);
    background: var(--theme-btn-outline-secondary-bg);
    border-color: var(--theme-btn-outline-secondary-border);
}

.btn.btn-outline-secondary:hover,
.btn.btn-outline-secondary:focus,
.btn.btn-outline-secondary:active,
.btn.btn-outline-secondary.active,
.show > .btn.btn-outline-secondary.dropdown-toggle {
    color: var(--theme-btn-outline-secondary-hover-text);
    background: var(--theme-btn-outline-secondary-hover-bg);
    border-color: var(--theme-btn-outline-secondary-hover-border);
    box-shadow: none;
}

.btn.btn-outline-secondary:focus,
.btn.btn-outline-secondary.focus {
    box-shadow: 0 0 0 0.2rem var(--theme-focus-ring);
}

.btn.btn-outline-warning {
    color: var(--theme-btn-warning-text);
    background: var(--theme-btn-warning-bg);
    border-color: var(--theme-btn-warning-border);
}

.btn.btn-outline-warning:hover,
.btn.btn-outline-warning:focus,
.btn.btn-outline-warning:active,
.btn.btn-outline-warning.active,
.show > .btn.btn-outline-warning.dropdown-toggle {
    color: var(--theme-btn-warning-hover-text);
    background: var(--theme-btn-warning-hover-bg);
    border-color: var(--theme-btn-warning-hover-border);
    box-shadow: none;
}

.btn.btn-outline-warning:focus,
.btn.btn-outline-warning.focus {
    box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--warning) 24%, transparent);
}

.btn.btn-outline-danger {
    color: var(--theme-btn-danger-text);
    background: var(--theme-btn-danger-bg);
    border-color: var(--theme-btn-danger-border);
}

.btn.btn-outline-danger:hover,
.btn.btn-outline-danger:focus,
.btn.btn-outline-danger:active,
.btn.btn-outline-danger.active,
.show > .btn.btn-outline-danger.dropdown-toggle {
    color: var(--theme-btn-danger-hover-text);
    background: var(--theme-btn-danger-hover-bg);
    border-color: var(--theme-btn-danger-hover-border);
    box-shadow: none;
}

.btn.btn-outline-danger:focus,
.btn.btn-outline-danger.focus {
    box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--danger) 24%, transparent);
}

.btn.btn-outline-warning.disabled,
.btn.btn-outline-warning:disabled,
.btn.btn-outline-danger.disabled,
.btn.btn-outline-danger:disabled,
.btn.btn-outline-light.disabled,
.btn.btn-outline-light:disabled,
.btn.btn-outline-secondary.disabled,
.btn.btn-outline-secondary:disabled {
    opacity: 0.55;
}

.btn-theme-primary {
    color: var(--theme-btn-primary-text) !important;
    background: var(--theme-btn-primary-bg) !important;
    border-color: var(--theme-btn-primary-border) !important;
    box-shadow: none;
}

.btn-theme-primary:hover,
.btn-theme-primary:focus,
.btn-theme-primary:active,
.btn-theme-primary.active,
.show > .btn-theme-primary.dropdown-toggle {
    color: var(--theme-btn-primary-text) !important;
    background: var(--theme-btn-primary-bg) !important;
    border-color: var(--theme-btn-primary-border) !important;
    filter: brightness(0.95) saturate(1.03);
    box-shadow: none;
}

.btn-theme-primary:disabled,
.btn-theme-primary.disabled {
    color: var(--theme-btn-primary-text) !important;
    background: var(--theme-btn-primary-bg) !important;
    border-color: var(--theme-btn-primary-border) !important;
    opacity: 0.55;
}

.btn-theme-outline {
    color: var(--theme-btn-outline-text) !important;
    background: var(--theme-btn-outline-bg) !important;
    border-color: var(--theme-btn-outline-border) !important;
    box-shadow: none;
}

.btn-theme-outline:hover,
.btn-theme-outline:focus,
.btn-theme-outline:active,
.btn-theme-outline.active,
.show > .btn-theme-outline.dropdown-toggle {
    color: var(--theme-btn-outline-hover-text) !important;
    background: var(--theme-btn-outline-hover-bg) !important;
    border-color: var(--theme-btn-outline-hover-border) !important;
    box-shadow: none;
}

.btn-theme-outline:disabled,
.btn-theme-outline.disabled {
    opacity: 0.55;
}

.completion-target-radios {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 1rem;
    padding: 0.55rem 0.65rem;
    border: 1px solid var(--theme-field-border);
    border-radius: 10px;
    background: var(--theme-field-bg);
}

.completion-target-radios .form-check {
    margin: 0;
}

.completion-target-radios .form-check-label {
    color: var(--text-primary);
    font-size: 0.83rem;
}

#completeTargetHint {
    color: #95a8c1;
    font-size: 0.76rem;
}

#completeTaskModal .dark-modal,
#customerProgressModal .dark-modal,
#taskDelegateModal .dark-modal,
#taskQuickEditModal .dark-modal,
#entryExitRecordDeleteModal .dark-modal {
    background: var(--surface-panel-bg);
    border-color: var(--surface-panel-border);
    color: var(--text-primary);
}

#completeTaskModal .modal-header,
#completeTaskModal .modal-footer,
#customerProgressModal .modal-header,
#customerProgressModal .modal-footer,
#taskDelegateModal .modal-header,
#taskDelegateModal .modal-footer,
#taskQuickEditModal .modal-header,
#taskQuickEditModal .modal-footer,
#entryExitRecordDeleteModal .modal-header,
#entryExitRecordDeleteModal .modal-footer {
    border-color: var(--surface-panel-header-border) !important;
}

#completeTaskModal .modal-title,
#customerProgressModal .modal-title,
#taskDelegateModal .modal-title,
#taskQuickEditModal .modal-title,
#entryExitRecordDeleteModal .modal-title {
    color: var(--text-primary);
}

#completeTaskModal .btn-close,
#customerProgressModal .btn-close,
#taskDelegateModal .btn-close,
#taskQuickEditModal .btn-close,
#entryExitRecordDeleteModal .btn-close {
    filter: var(--addjob-close-filter) !important;
    opacity: 0.9;
    border-radius: 10px;
    background-color: var(--surface-empty-bg);
    border: 1px solid var(--surface-panel-border);
    padding: 0.5rem;
}

#completeTaskModal .btn-close:hover,
#customerProgressModal .btn-close:hover,
#taskDelegateModal .btn-close:hover,
#taskQuickEditModal .btn-close:hover,
#entryExitRecordDeleteModal .btn-close:hover {
    opacity: 1;
    border-color: var(--surface-card-hover-border);
}

#completeTaskModal .form-label,
#customerProgressModal .form-label,
#taskDelegateModal .form-label,
#taskQuickEditModal .form-label {
    color: var(--addjob-label-text);
}

#completeTaskModal .form-text,
#completeTaskModal .text-secondary,
#customerProgressModal .form-text,
#customerProgressModal .text-secondary,
#taskDelegateModal .form-text,
#taskDelegateModal .text-secondary,
#taskQuickEditModal .form-text,
#taskQuickEditModal .text-secondary {
    color: var(--text-secondary) !important;
}

#completeTaskModal .form-control,
#completeTaskModal .form-select,
#customerProgressModal .form-control,
#customerProgressModal .form-select,
#taskDelegateModal .form-control,
#taskDelegateModal .form-select,
#taskQuickEditModal .form-control,
#taskQuickEditModal .form-select {
    background: var(--surface-subpanel-bg);
    border-color: var(--surface-subpanel-border);
    color: var(--text-primary);
}

#completeTaskModal .form-control::placeholder,
#customerProgressModal .form-control::placeholder,
#taskDelegateModal .form-control::placeholder,
#taskQuickEditModal .form-control::placeholder {
    color: var(--text-secondary);
    opacity: 0.9;
}

#completeTaskModal .form-control:focus,
#completeTaskModal .form-select:focus,
#customerProgressModal .form-control:focus,
#customerProgressModal .form-select:focus,
#taskDelegateModal .form-control:focus,
#taskDelegateModal .form-select:focus,
#taskQuickEditModal .form-control:focus,
#taskQuickEditModal .form-select:focus {
    background: var(--surface-subpanel-bg);
    color: var(--text-primary);
    border-color: var(--accent);
    box-shadow: 0 0 0 0.2rem var(--addjob-editor-focus-ring);
}

#completeTaskModal .completion-target-radios,
#customerProgressModal .completion-target-radios {
    border-color: var(--surface-subpanel-border);
    background: var(--surface-subpanel-bg);
}

#completeTaskModal .completion-target-radios .form-check-label,
#customerProgressModal .completion-target-radios .form-check-label {
    color: var(--text-primary);
}

#completeTaskModal .btn.btn-outline-light,
#customerProgressModal .btn.btn-outline-light,
#taskDelegateModal .btn.btn-outline-light,
#taskQuickEditModal .btn.btn-outline-light,
#entryExitRecordDeleteModal .btn.btn-outline-light {
    color: var(--theme-btn-outline-text) !important;
    border-color: var(--theme-btn-outline-border) !important;
    background: var(--theme-btn-outline-bg) !important;
}

#completeTaskModal .btn.btn-outline-light:hover,
#completeTaskModal .btn.btn-outline-light:focus,
#completeTaskModal .btn.btn-outline-light:active,
#customerProgressModal .btn.btn-outline-light:hover,
#customerProgressModal .btn.btn-outline-light:focus,
#customerProgressModal .btn.btn-outline-light:active,
#taskDelegateModal .btn.btn-outline-light:hover,
#taskDelegateModal .btn.btn-outline-light:focus,
#taskDelegateModal .btn.btn-outline-light:active,
#taskQuickEditModal .btn.btn-outline-light:hover,
#taskQuickEditModal .btn.btn-outline-light:focus,
#taskQuickEditModal .btn.btn-outline-light:active,
#entryExitRecordDeleteModal .btn.btn-outline-light:hover,
#entryExitRecordDeleteModal .btn.btn-outline-light:focus,
#entryExitRecordDeleteModal .btn.btn-outline-light:active {
    color: var(--theme-btn-outline-hover-text) !important;
    border-color: var(--theme-btn-outline-hover-border) !important;
    background: var(--theme-btn-outline-hover-bg) !important;
    box-shadow: none !important;
}

#completeTaskModal .btn.btn-outline-secondary,
#customerProgressModal .btn.btn-outline-secondary {
    color: var(--text-secondary);
    border-color: var(--surface-panel-border);
    background: transparent;
}

#completeTaskModal .btn.btn-outline-secondary:hover,
#completeTaskModal .btn.btn-outline-secondary:focus,
#customerProgressModal .btn.btn-outline-secondary:hover,
#customerProgressModal .btn.btn-outline-secondary:focus {
    color: var(--text-primary);
    border-color: var(--surface-card-hover-border);
    background: var(--surface-empty-bg);
    box-shadow: none;
}

#taskDelegateModal .completion-target-radios {
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    gap: 0.35rem 0.75rem;
}

#taskDelegateModal .completion-target-radios .form-check-label {
    font-size: 0.8rem;
}

#taskDelegateModal #taskDelegateAssignmentModeGroup {
    align-self: flex-start;
}

#taskDelegateModal .form-label {
    color: var(--addjob-label-text);
}

#taskDelegateModal .form-text,
#taskDelegateModal .text-secondary {
    color: var(--text-secondary) !important;
}

#taskDelegateModal .form-control,
#taskDelegateModal .form-select {
    background: var(--surface-subpanel-bg);
    border-color: var(--surface-subpanel-border);
    color: var(--text-primary);
}

#taskDelegateModal .form-control::placeholder {
    color: var(--text-secondary);
    opacity: 0.9;
}

#taskDelegateModal .form-control:focus,
#taskDelegateModal .form-select:focus {
    background: var(--surface-subpanel-bg);
    color: var(--text-primary);
    border-color: var(--accent);
    box-shadow: 0 0 0 0.2rem var(--addjob-editor-focus-ring);
}

#taskDelegateModal .form-control:disabled,
#taskDelegateModal .form-select:disabled {
    background: color-mix(in srgb, var(--surface-subpanel-bg) 88%, #000000 12%);
    border-color: var(--surface-subpanel-border);
    color: color-mix(in srgb, var(--text-secondary) 88%, #ffffff 12%);
    opacity: 1;
    cursor: not-allowed;
}

.planned-date-rows {
    display: grid;
    gap: 0.45rem;
}

.planned-date-row {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr) 160px 46px;
    gap: 0.45rem;
    align-items: center;
}

.addjob-dialog {
    max-width: min(1320px, 96vw);
}

.legacy-addjob-modal {
    border-radius: 14px;
    overflow: hidden;
    background: var(--surface-panel-bg);
    border: 1px solid var(--surface-panel-border);
    color: var(--text-primary);
}

.legacy-addjob-header {
    background: var(--addjob-header-bg);
    display: grid;
    grid-template-columns: minmax(240px, 1fr) 130px minmax(220px, 1fr) auto auto;
    align-items: center;
    gap: 0.85rem;
    border-bottom: 1px solid var(--surface-panel-header-border);
    backdrop-filter: blur(8px);
}

.legacy-header-brand,
.legacy-header-taskid,
.legacy-header-planner {
    min-width: 0;
}

.legacy-header-brand > .legacy-inline-label {
    display: block;
    margin-left: calc(36px + 0.6rem);
}

.legacy-header-brand-field {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    min-width: 0;
}

.legacy-header-brand-field .form-select {
    min-width: 0;
}

.legacy-header-brand-logo {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    flex: 0 0 36px;
    border: 1px solid var(--surface-subpanel-border);
    background:
        radial-gradient(circle at 50% 50%, transparent 44%, var(--surface-subpanel-border) 46%, transparent 48%),
        var(--surface-subpanel-bg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02);
}

.legacy-header-brand-logo.has-image {
    background: var(--surface-subpanel-bg);
}

.legacy-header-brand-logo-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
}

.legacy-header-planner {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.75rem;
}

.legacy-header-customer-switch {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin: 0;
    min-height: 38px;
    align-self: center;
    padding-bottom: 0;
    white-space: nowrap;
}

#addJobModal .legacy-header-customer-switch .form-check-input {
    margin: 0;
    float: none;
    cursor: pointer;
}

#addJobModal .legacy-header-customer-switch .form-check-label {
    margin: 0;
    cursor: pointer;
    user-select: none;
}

.legacy-header-planner-select {
    margin-top: 0;
    min-width: 0;
    display: flex;
    align-items: center;
}

.legacy-header-taskid label {
    display: block;
    width: 100%;
    margin: 0;
    border: 1px solid var(--addjob-header-chip-border);
    border-radius: 10px;
    min-height: 38px;
    line-height: 36px;
    text-align: center;
    color: var(--addjob-header-chip-text);
    font-size: 0.88rem;
    font-weight: 700;
    background: var(--addjob-header-chip-bg);
}

.legacy-header-user {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--addjob-header-user-text);
    font-size: 0.8rem;
    justify-self: end;
}

.legacy-header-user-avatar {
    width: 30px;
    height: 30px;
    border-radius: 999px;
    object-fit: cover;
    border: 1px solid var(--surface-avatar-border);
    background: var(--surface-avatar-bg);
    flex: 0 0 auto;
}

.legacy-header-user.has-avatar i {
    display: none;
}

.legacy-header-user i {
    font-size: 1.75rem;
    line-height: 1;
}

.legacy-header-user small {
    display: block;
    max-width: 140px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.legacy-inline-label {
    font-size: 0.74rem;
    letter-spacing: 0.01em;
    color: var(--addjob-label-text);
}

.legacy-addjob-body {
    padding-top: 0.55rem;
}

#addJobModal .form-label {
    color: var(--addjob-label-text);
}

#addJobModal .form-control,
#addJobModal .form-select {
    background: var(--surface-subpanel-bg);
    border-color: var(--surface-subpanel-border);
    color: var(--text-primary);
}

#addJobModal .form-control:focus,
#addJobModal .form-select:focus {
    background: var(--surface-subpanel-bg);
    color: var(--text-primary);
    border-color: var(--accent);
    box-shadow: 0 0 0 0.2rem var(--addjob-editor-focus-ring);
}

#addJobModal .btn.btn-outline-light {
    color: var(--theme-btn-outline-text) !important;
    border-color: var(--theme-btn-outline-border) !important;
    background: var(--theme-btn-outline-bg) !important;
}

#addJobModal .btn.btn-outline-light:hover,
#addJobModal .btn.btn-outline-light:focus,
#addJobModal .btn.btn-outline-light:active {
    color: var(--theme-btn-outline-hover-text) !important;
    border-color: var(--theme-btn-outline-hover-border) !important;
    background: var(--theme-btn-outline-hover-bg) !important;
    box-shadow: none !important;
}

#addJobModal .btn.btn-success,
#addJobModal .btn.btn-primary {
    color: var(--theme-btn-primary-text) !important;
    border-color: var(--theme-btn-primary-border) !important;
    background: var(--theme-btn-primary-bg) !important;
}

#addJobModal .btn.btn-success:hover,
#addJobModal .btn.btn-success:focus,
#addJobModal .btn.btn-primary:hover,
#addJobModal .btn.btn-primary:focus {
    color: var(--theme-btn-primary-text) !important;
    border-color: var(--theme-btn-primary-border) !important;
    background: var(--theme-btn-primary-bg) !important;
    filter: brightness(0.95) saturate(1.03);
    box-shadow: none !important;
}

#addJobModal .btn.btn-outline-danger {
    color: var(--theme-btn-danger-text) !important;
    border-color: var(--theme-btn-danger-border) !important;
    background: var(--theme-btn-danger-bg) !important;
}

#addJobModal .btn.btn-outline-danger:hover,
#addJobModal .btn.btn-outline-danger:focus {
    color: var(--theme-btn-danger-hover-text) !important;
    border-color: var(--theme-btn-danger-hover-border) !important;
    background: var(--theme-btn-danger-hover-bg) !important;
    box-shadow: none !important;
}

#addJobModal .btn-close {
    filter: var(--addjob-close-filter) !important;
    opacity: 0.9;
    border-radius: 10px;
    background-color: var(--surface-empty-bg);
    border: 1px solid var(--surface-panel-border);
    padding: 0.5rem;
}

#addJobModal .btn-close:hover {
    opacity: 1;
    border-color: var(--surface-card-hover-border);
}

.legacy-type-selector {
    margin-bottom: 0.85rem;
}

.legacy-type-carousel {
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr) 38px;
    gap: 0.45rem;
    align-items: center;
}

.legacy-type-scroll {
    border: 1px solid var(--addjob-type-scroll-border);
    border-radius: 12px;
    background: var(--addjob-type-scroll-bg);
    padding: 0.35rem;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    -ms-overflow-style: none;
    scroll-behavior: smooth;
}

.legacy-type-scroll::-webkit-scrollbar {
    width: 0;
    height: 0;
    display: none;
}

.legacy-type-scroll::-webkit-scrollbar-track {
    background: transparent;
}

.legacy-type-scroll::-webkit-scrollbar-thumb {
    background: var(--addjob-type-scroll-thumb);
    border-radius: 999px;
}

.legacy-type-nav {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    border: 1px solid var(--addjob-type-nav-border);
    background: var(--addjob-type-nav-bg);
    color: var(--addjob-type-nav-text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: border-color 0.14s ease, background-color 0.14s ease, color 0.14s ease;
}

.legacy-type-nav:hover:not(:disabled) {
    border-color: var(--addjob-type-nav-hover-border);
    background: var(--addjob-type-nav-hover-bg);
}

.legacy-type-nav:disabled {
    opacity: 0.35;
    cursor: default;
}

.legacy-type-cards {
    display: flex;
    flex-wrap: nowrap;
    gap: 0.45rem;
    min-width: max-content;
}

.legacy-type-card {
    flex: 0 0 190px;
    min-height: 56px;
    border: 1px solid var(--addjob-type-card-border);
    border-radius: 10px;
    padding: 0.75rem 0.4rem;
    background: var(--addjob-type-card-bg);
    color: var(--addjob-type-card-text);
    text-align: center;
    transition: border-color 0.14s ease, background-color 0.14s ease, transform 0.14s ease;
}

.legacy-type-card span {
    display: block;
    line-height: 1.2;
}

.legacy-type-card strong {
    display: block;
    font-size: 0.82rem;
    font-weight: 800;
}

.legacy-type-card small {
    display: block;
    margin-top: 0.12rem;
    font-size: 0.65rem;
    color: var(--addjob-type-card-subtext);
}

.legacy-type-card:hover {
    border-color: var(--addjob-type-card-hover-border);
    transform: translateY(-1px);
}

.legacy-type-card.selected {
    background: var(--addjob-type-card-selected-bg);
    color: var(--addjob-type-card-selected-text);
    border-color: var(--addjob-type-card-selected-border);
}

.legacy-type-card.selected small {
    color: var(--addjob-type-card-selected-subtext);
}

.legacy-period-wrapper {
    margin-bottom: 0.9rem;
}

.legacy-month-picker {
    margin-bottom: 0;
}

.legacy-month-picker .page-item {
    width: 8.333%;
}

.legacy-month-picker .page-link {
    width: 100%;
    border: 1px solid var(--addjob-month-border);
    background: var(--addjob-month-bg);
    color: var(--addjob-month-text);
    padding: 0.32rem 0.2rem;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.legacy-month-picker .page-link .page-month {
    margin: 0;
    font-size: 0.77rem;
    line-height: 1.1;
    font-weight: 700;
}

.legacy-month-picker .page-link .page-year {
    margin: 0.08rem 0 0;
    font-size: 0.66rem;
    line-height: 1;
    color: var(--addjob-month-year);
}

.legacy-month-picker .page-link:hover,
.legacy-month-picker .page-link:focus {
    border-color: var(--surface-card-hover-border);
    background: var(--surface-empty-bg);
    color: var(--text-primary);
    box-shadow: none !important;
}

.legacy-month-picker .page-link.selected {
    background: var(--addjob-month-selected-bg);
    color: var(--addjob-month-selected-text);
    border-color: var(--addjob-month-selected-border);
}

.legacy-month-picker .page-link.selected .page-year {
    color: var(--addjob-month-selected-year);
}

.legacy-titlebar {
    margin: 0.9rem 0 0.7rem;
    border-bottom: 1px solid var(--addjob-titlebar-border);
    text-align: center;
}

.legacy-titlebar span {
    display: inline-block;
    padding: 0.15rem 0.8rem;
    margin-bottom: -0.7rem;
    background: var(--addjob-titlebar-chip-bg);
    font-size: 0.82rem;
    font-weight: 800;
    color: var(--addjob-titlebar-chip-text);
}

.legacy-person-thumb {
    border: 1px solid var(--addjob-person-thumb-border);
    border-radius: 12px;
    background: var(--addjob-person-thumb-bg);
    text-align: center;
    padding: 0.52rem 0.3rem;
}

.legacy-person-thumb i {
    display: block;
    font-size: 1.65rem;
    color: var(--addjob-person-thumb-icon);
    line-height: 1;
}

.legacy-person-thumb img {
    display: block;
    width: 34px;
    height: 34px;
    margin: 0 auto;
    border-radius: 999px;
    object-fit: cover;
    border: 1px solid var(--addjob-person-thumb-avatar-border);
    background: var(--addjob-person-thumb-avatar-bg);
}

.legacy-person-thumb small {
    display: block;
    margin-top: 0.28rem;
    color: var(--addjob-person-thumb-text);
    font-size: 0.68rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.legacy-person-thumb.has-avatar small {
    margin-top: 0.32rem;
}

.legacy-job-title {
    min-height: 84px;
    padding-top: 1.3rem;
    font-size: 1.03rem;
    font-weight: 700;
}

.legacy-floating-label {
    position: absolute;
    right: 1rem;
    top: 0.38rem;
    color: var(--addjob-floating-label-text);
    font-size: 0.72rem;
    pointer-events: none;
}

.legacy-rich-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 0.45rem;
}

.legacy-rich-toolbar .btn {
    min-width: 42px;
    padding: 0.28rem 0.55rem;
    font-size: 0.8rem;
}

.legacy-rich-editor {
    min-height: 132px;
    border: 1px solid var(--addjob-editor-border);
    border-radius: 10px;
    background: var(--addjob-editor-bg);
    color: var(--addjob-editor-text);
    padding: 0.65rem 0.75rem;
    line-height: 1.45;
    font-size: 0.92rem;
    overflow: auto;
}

.legacy-rich-editor:focus {
    outline: 0;
    border-color: var(--accent);
    box-shadow: 0 0 0 0.2rem var(--addjob-editor-focus-ring);
}

.legacy-rich-editor a {
    color: var(--addjob-editor-link);
    text-decoration: underline;
}

.legacy-file-holder {
    border: 1px solid var(--addjob-file-holder-border);
    border-radius: 12px;
    overflow: hidden;
    background: var(--addjob-file-holder-bg);
}

.legacy-file-holder-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.58rem 0.72rem;
    border-bottom: 1px solid var(--addjob-file-holder-border);
    background: var(--addjob-file-holder-top-bg);
}

.legacy-file-holder-top h2 {
    margin: 0;
    font-size: 0.84rem;
    color: var(--addjob-file-holder-top-text);
    font-weight: 700;
}

.legacy-file-holder-top i {
    margin-right: 0.35rem;
}

.legacy-file-holder-content {
    padding: 0.74rem;
}

.job-existing-attachments-panel {
    border: 1px solid var(--addjob-existing-files-border);
    border-radius: 10px;
    background: var(--addjob-existing-files-bg);
    margin-bottom: 0.7rem;
    overflow: hidden;
}

.job-existing-attachments-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.6rem;
    padding: 0.45rem 0.6rem;
    border-bottom: 1px solid var(--addjob-existing-files-border);
    background: var(--addjob-existing-files-header-bg);
    color: var(--addjob-existing-files-header-text);
    font-size: 0.78rem;
    font-weight: 700;
}

.job-existing-attachments-header small {
    color: var(--addjob-existing-files-hint-text);
    font-weight: 500;
    font-size: 0.7rem;
}

.job-existing-attachments-list {
    padding: 0.6rem;
}

.job-existing-attachments-empty {
    border: 1px dashed var(--addjob-existing-files-empty-border);
    border-radius: 10px;
    color: var(--addjob-existing-files-empty-text);
    padding: 0.65rem;
    text-align: center;
    font-size: 0.78rem;
}

.job-existing-attachments-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 0.55rem;
}

.job-existing-attachment-tile {
    min-width: 0;
    display: grid;
    gap: 0.35rem;
}

.job-existing-attachment-tile .attachment-thumb-card {
    min-height: 0;
}

.job-existing-attachment-actions {
    display: flex;
    justify-content: flex-end;
}

.job-existing-attachment-actions .btn {
    padding: 0.18rem 0.45rem;
    font-size: 0.72rem;
    line-height: 1.2;
}

.job-attachment-native-input {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.job-attachment-picker-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    padding: 0.65rem 0.75rem;
    border: 1px solid var(--addjob-upload-picker-border);
    border-radius: 12px;
    background: var(--addjob-upload-picker-bg);
}

.job-attachment-picker-copy {
    min-width: 0;
    display: grid;
    gap: 0.1rem;
}

.job-attachment-picker-copy strong {
    color: var(--addjob-upload-picker-title);
    font-size: 0.82rem;
    font-weight: 800;
}

.job-attachment-picker-copy small {
    color: var(--addjob-upload-picker-subtext);
    font-size: 0.73rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.job-attachment-picker-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

#jobAttachmentsList.job-attachment-queue-grid,
#completeTaskAttachmentsList.job-attachment-queue-grid,
#customerProgressAttachmentsList.job-attachment-queue-grid,
#taskQuickEditAttachmentsList.job-attachment-queue-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
    gap: 0.55rem;
    align-items: start;
    position: relative;
}

#jobAttachmentsList.job-attachment-queue-grid.is-drag-over::after,
#completeTaskAttachmentsList.job-attachment-queue-grid.is-drag-over::after,
#customerProgressAttachmentsList.job-attachment-queue-grid.is-drag-over::after,
#taskQuickEditAttachmentsList.job-attachment-queue-grid.is-drag-over::after {
    content: "";
    position: absolute;
    inset: -2px;
    border: 2px dashed var(--accent);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.02);
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08) inset;
    pointer-events: none;
    z-index: 2;
}

.job-upload-queue-empty {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-height: 90px;
    padding: 0.8rem;
    border: 1px dashed var(--addjob-upload-queue-empty-border);
    border-radius: 12px;
    background: var(--addjob-upload-queue-empty-bg);
    color: var(--addjob-upload-queue-empty-text);
    font-size: 0.8rem;
    text-align: center;
    transition: border-color 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}

.job-upload-queue-empty i {
    font-size: 1rem;
    opacity: 0.9;
}

#jobAttachmentsList.job-attachment-queue-grid.is-drag-over .job-upload-queue-empty,
#completeTaskAttachmentsList.job-attachment-queue-grid.is-drag-over .job-upload-queue-empty,
#customerProgressAttachmentsList.job-attachment-queue-grid.is-drag-over .job-upload-queue-empty,
#taskQuickEditAttachmentsList.job-attachment-queue-grid.is-drag-over .job-upload-queue-empty {
    border-color: var(--accent);
    background: var(--surface-card-bg);
    color: var(--text-primary);
}

#jobAttachmentsList.job-attachment-queue-grid.is-drag-over .job-upload-queue-empty i,
#completeTaskAttachmentsList.job-attachment-queue-grid.is-drag-over .job-upload-queue-empty i,
#customerProgressAttachmentsList.job-attachment-queue-grid.is-drag-over .job-upload-queue-empty i,
#taskQuickEditAttachmentsList.job-attachment-queue-grid.is-drag-over .job-upload-queue-empty i {
    color: var(--accent);
    opacity: 1;
}

.job-upload-queue-tile {
    min-width: 0;
    display: grid;
    gap: 0.35rem;
}

.job-upload-queue-card {
    min-height: 0;
}

#addJobModal .attachment-thumb-card,
#completeTaskModal .attachment-thumb-card,
#customerProgressModal .attachment-thumb-card,
#taskQuickEditModal .attachment-thumb-card {
    border-color: var(--addjob-attachment-item-border);
    background: var(--addjob-attachment-item-bg);
}

#addJobModal .attachment-thumb-card:hover,
#completeTaskModal .attachment-thumb-card:hover,
#customerProgressModal .attachment-thumb-card:hover,
#taskQuickEditModal .attachment-thumb-card:hover {
    border-color: var(--surface-card-hover-border);
    background: var(--surface-card-bg);
}

#addJobModal .attachment-thumb-media,
#completeTaskModal .attachment-thumb-media,
#customerProgressModal .attachment-thumb-media,
#taskQuickEditModal .attachment-thumb-media {
    background: var(--surface-widget-bg);
    border-bottom-color: var(--addjob-attachment-item-border);
}

#addJobModal .attachment-thumb-media img,
#addJobModal .attachment-thumb-media video,
#completeTaskModal .attachment-thumb-media img,
#completeTaskModal .attachment-thumb-media video,
#customerProgressModal .attachment-thumb-media img,
#customerProgressModal .attachment-thumb-media video,
#taskQuickEditModal .attachment-thumb-media img,
#taskQuickEditModal .attachment-thumb-media video {
    background: var(--surface-widget-bg);
}

#addJobModal .attachment-thumb-file,
#completeTaskModal .attachment-thumb-file,
#customerProgressModal .attachment-thumb-file,
#taskQuickEditModal .attachment-thumb-file {
    border-color: var(--surface-empty-border);
    color: var(--text-secondary);
}

#addJobModal .attachment-thumb-ext,
#completeTaskModal .attachment-thumb-ext,
#customerProgressModal .attachment-thumb-ext,
#taskQuickEditModal .attachment-thumb-ext {
    background: var(--accent-soft);
    color: var(--accent);
}

#addJobModal .attachment-thumb-name,
#completeTaskModal .attachment-thumb-name,
#customerProgressModal .attachment-thumb-name,
#taskQuickEditModal .attachment-thumb-name {
    color: var(--addjob-attachment-item-text);
}

#addJobModal .attachment-thumb-sub,
#completeTaskModal .attachment-thumb-sub,
#customerProgressModal .attachment-thumb-sub,
#taskQuickEditModal .attachment-thumb-sub {
    color: var(--addjob-attachment-item-muted);
}

.job-upload-queue-note {
    color: var(--addjob-upload-card-note);
    font-size: 0.65rem;
    line-height: 1.1;
    font-weight: 700;
}

.job-upload-queue-actions {
    display: flex;
    justify-content: flex-end;
}

.job-upload-queue-actions .btn {
    padding: 0.18rem 0.4rem;
    line-height: 1.15;
}

.job-upload-queue-actions .btn i {
    font-size: 0.8rem;
}

.legacy-grey-row {
    background: var(--addjob-soft-row-bg);
    border-radius: 12px;
    padding: 0.5rem 0.12rem;
    margin-top: 0.5rem;
}

.legacy-icon-title {
    display: inline-flex;
    align-items: center;
    gap: 0.52rem;
    color: var(--addjob-icon-title-text);
    font-size: 0.8rem;
    font-weight: 700;
}

.legacy-icon-title i {
    font-size: 1.06rem;
}

.legacy-planned-days-panel {
    border: 1px solid var(--addjob-planned-panel-border);
    border-radius: 12px;
    background: var(--addjob-planned-panel-bg);
    padding: 0.6rem;
}

.legacy-planned-days-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    margin-bottom: 0.58rem;
}

.legacy-planned-days-header-actions {
    display: inline-flex;
    align-items: flex-start;
    gap: 0.8rem;
    margin-left: auto;
}

.legacy-planned-days-columns {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr) 160px 46px;
    gap: 0.45rem;
    margin-bottom: 0.42rem;
}

.legacy-planned-days-columns span {
    color: var(--text-secondary);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.01em;
}

.legacy-planned-date-rows {
    display: grid;
    gap: 0.45rem;
}

.legacy-planned-date-rows .planned-date-row {
    grid-template-columns: 52px minmax(0, 1fr) 160px 46px;
}

.legacy-planned-date-rows .planned-date-row .form-control {
    min-height: 34px;
}

.planned-day-index {
    min-height: 34px;
    border-radius: 8px;
    border: 1px solid var(--surface-subpanel-border);
    background: var(--surface-subpanel-bg);
    color: var(--text-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.84rem;
    font-weight: 700;
}

.planned-day-remove {
    min-height: 34px;
    padding: 0.2rem 0.35rem;
}

.legacy-planned-days-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: 0.55rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--addjob-planned-panel-border);
}

.legacy-planned-effort-global-switch {
    margin: 0;
}

.legacy-planned-total-effort {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
}

.legacy-planned-total-effort small {
    color: var(--text-secondary);
    font-size: 0.75rem;
    font-weight: 700;
}

.legacy-planned-total-effort strong {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 88px;
    min-height: 34px;
    padding: 0.2rem 0.62rem;
    border-radius: 8px;
    border: 1px solid var(--surface-subpanel-border);
    background: var(--surface-subpanel-bg);
    color: var(--text-primary);
    font-size: 0.95rem;
    font-weight: 800;
    letter-spacing: 0.01em;
}

.legacy-addjob-side-actions {
    height: 100%;
    display: grid;
    grid-template-rows: auto;
    align-content: start;
    gap: 0.75rem;
    justify-items: stretch;
    padding-top: 0.1rem;
}

.legacy-addjob-switch-stack {
    display: grid;
    gap: 0.55rem;
    justify-content: start;
}

.legacy-addjob-switch {
    margin: 0;
    min-height: 1.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.45rem;
    color: var(--text-primary);
}

.legacy-addjob-switch .form-check-input {
    margin-top: 0;
    margin-left: 0;
    float: none;
    flex: 0 0 auto;
}

.legacy-addjob-switch .form-check-label {
    margin: 0;
    text-align: left;
}

.legacy-addjob-submit {
    justify-self: end;
    min-width: 132px;
    margin-top: 0.2rem;
}

.legacy-addjob-delete {
    justify-self: end;
    min-width: 132px;
}

.jobTimer {
    position: fixed;
    right: -420px;
    bottom: 96px;
    width: 400px;
    padding: 22px;
    background: rgba(248, 252, 255, 0.97);
    border-radius: 100px 0 0 100px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.35);
    z-index: 2147483001;
    transition: right 0.22s ease;
}

.jobTimer.active,
.jobTimer.started {
    right: 0;
}

.jobTimer .inner {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    position: relative;
}

.jobTimer .inner .action {
    position: absolute;
    right: 18px;
    top: -44px;
    color: #1f2b35;
    text-align: center;
    padding: 0.18rem 0.7rem;
    border-radius: 8px 8px 0 0;
    font-size: 0.78rem;
    background: #1abc9c;
    font-weight: 700;
    max-width: 250px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.jobTimer .inner .icon {
    width: 96px;
    height: 96px;
    border-radius: 100%;
    position: relative;
    cursor: pointer;
    background: #1abc9c;
    border: 0;
    outline: none;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.24);
}

.jobTimer .inner .icon i {
    color: #ffffff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 2rem;
    line-height: 1;
}

.jobTimer .inner .right {
    width: calc(100% - 96px);
    padding-left: 14px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.jobTimer .inner .right .counter {
    width: 50%;
    color: #223142;
    font-size: 2.55rem;
    line-height: 1;
    font-weight: 800;
}

.jobTimer .inner .right .info {
    width: 50%;
    display: flex;
    flex-wrap: wrap;
}

.jobTimer .inner .right .info p {
    width: calc(100% - 26px);
    padding: 0 9px 0 2px;
    margin: 0;
}

.jobTimer .inner .right .info p span {
    font-size: 0.71rem;
    display: block;
    color: #4c5e73;
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.jobTimer .inner .right .info p #timerBrand {
    font-weight: 800;
    color: #243849;
}

.jobTimer .inner .right .info i {
    width: 26px;
    height: 26px;
    text-align: center;
    line-height: 26px;
    font-style: normal;
    display: block;
    border-radius: 6px;
    background: #1abc9c;
    color: #13232f;
    font-weight: 800;
    font-size: 0.75rem;
}

.jobTimer .inner .right .effort {
    width: 100%;
    height: 24px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin-top: 0.2rem;
}

.jobTimer .inner .right .effort small {
    width: 25%;
    font-size: 0.86rem;
    color: #23384a;
    font-weight: 700;
}

.jobTimer .inner .right .effort span {
    width: 75%;
    height: 100%;
    background: #dbe6ee;
    border-radius: 999px;
    overflow: hidden;
}

.jobTimer .inner .right .effort span i {
    width: 0;
    height: 100%;
    display: block;
    background: linear-gradient(90deg, #1abc9c 0%, #35d077 100%);
    transition: width 0.2s ease;
}

/* Mini efor sayaci: tema uyumlu + overlap-safe layout */
.jobTimer {
    width: min(440px, calc(100vw - 20px));
    right: calc(-1 * min(440px, calc(100vw - 20px)) - 12px);
    bottom: 90px;
    padding: 12px 14px 14px;
    background: color-mix(in srgb, var(--surface-panel-bg, #f8fcff) 94%, transparent);
    border: 1px solid var(--surface-panel-border, rgba(74, 96, 122, 0.45));
    border-right: 0;
    border-radius: 24px 0 0 24px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.28);
    backdrop-filter: blur(10px) saturate(1.05);
}

.jobTimer .inner {
    display: grid;
    grid-template-columns: 88px minmax(0, 1fr);
    grid-template-areas:
        "icon action"
        "icon right";
    column-gap: 12px;
    row-gap: 6px;
    align-items: center;
}

.jobTimer .inner .action {
    position: static;
    grid-area: action;
    justify-self: end;
    max-width: min(100%, 240px);
    color: var(--theme-btn-primary-text, #ffffff);
    background: color-mix(in srgb, var(--accent, #1abc9c) 88%, transparent);
    border: 1px solid color-mix(in srgb, var(--accent, #1abc9c) 60%, white 8%);
    box-shadow: 0 4px 12px color-mix(in srgb, var(--accent, #1abc9c) 18%, transparent);
    border-radius: 8px;
    padding: 0.2rem 0.55rem;
    line-height: 1.2;
}

.jobTimer .inner .icon {
    grid-area: icon;
    width: 88px;
    height: 88px;
    align-self: center;
    justify-self: start;
    background: color-mix(in srgb, var(--accent, #1abc9c) 92%, white 8%);
    border: 1px solid color-mix(in srgb, var(--accent, #1abc9c) 52%, transparent);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.22);
}

.jobTimer .inner .icon i {
    color: var(--theme-btn-primary-text, #ffffff);
}

.jobTimer .inner .right {
    grid-area: right;
    width: auto;
    min-width: 0;
    padding-left: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
        "counter info"
        "effort effort";
    column-gap: 10px;
    row-gap: 4px;
    align-items: start;
}

.jobTimer .inner .right .counter {
    grid-area: counter;
    width: auto;
    min-width: 0;
    color: var(--text-primary, #223142);
    font-size: clamp(2rem, 2vw + 1.25rem, 2.45rem);
    letter-spacing: 0.01em;
}

.jobTimer .inner .right .info {
    grid-area: info;
    width: auto;
    min-width: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.35rem 0.45rem;
    align-items: start;
    justify-items: end;
}

.jobTimer .inner .right .info p {
    width: auto;
    min-width: 0;
    padding: 0;
    margin: 0;
    text-align: right;
}

.jobTimer .inner .right .info p span {
    color: var(--text-secondary, #4c5e73);
    font-size: 0.66rem;
    line-height: 1.1;
}

.jobTimer .inner .right .info p #timerBrand {
    color: var(--text-primary, #243849);
}

.jobTimer .inner .right .info i {
    width: 28px;
    height: 28px;
    line-height: 28px;
    border-radius: 8px;
    background: color-mix(in srgb, var(--accent, #1abc9c) 22%, var(--surface-empty-bg, #dbe6ee));
    color: color-mix(in srgb, var(--accent, #1abc9c) 70%, var(--text-primary, #223142));
    border: 1px solid color-mix(in srgb, var(--accent, #1abc9c) 28%, transparent);
}

.jobTimer .inner .right .effort {
    grid-area: effort;
    width: auto;
    min-width: 0;
    height: auto;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.55rem;
    margin-top: 0.1rem;
}

.jobTimer .inner .right .effort small {
    width: auto;
    white-space: nowrap;
    color: var(--text-secondary, #23384a);
    font-size: 0.78rem;
}

.jobTimer .inner .right .effort span {
    width: auto;
    min-width: 0;
    height: 20px;
    background: color-mix(in srgb, var(--surface-empty-bg, #dbe6ee) 86%, var(--surface-panel-bg, #ffffff) 14%);
    border: 1px solid var(--surface-subpanel-border, rgba(72, 93, 118, 0.2));
    border-radius: 999px;
}

.jobTimer .inner .right .effort span i {
    background: linear-gradient(
        90deg,
        color-mix(in srgb, var(--accent, #1abc9c) 85%, white 12%) 0%,
        color-mix(in srgb, var(--accent, #1abc9c) 72%, #6be89b 28%) 100%
    );
}

.login-body {
    --login-accent: var(--accent, #2dd46f);
    --login-accent-soft: var(--accent-soft, #154c2d);
    --login-panel-border: color-mix(in srgb, var(--login-accent) 32%, var(--surface-panel-border, #304157) 68%);
    --login-panel-text: var(--text-primary, #ecf2ff);
    --login-panel-muted: color-mix(in srgb, var(--text-secondary, #9fb0c7) 88%, var(--surface-card-head-text, #89a6c8) 12%);
    position: relative;
    overflow-x: hidden;
    background:
        radial-gradient(1200px 680px at 8% -10%, color-mix(in srgb, var(--login-accent) 28%, transparent) 0%, transparent 62%),
        radial-gradient(980px 620px at 102% 108%, color-mix(in srgb, var(--login-accent-soft) 56%, transparent) 0%, transparent 60%),
        linear-gradient(145deg, color-mix(in srgb, var(--bg-page, #0f1319) 88%, #050b13 12%) 0%, color-mix(in srgb, var(--bg-page, #0f1319) 74%, #0a1b2f 26%) 50%, color-mix(in srgb, var(--bg-page, #0f1319) 84%, #06101e 16%) 100%);
    color: var(--login-panel-text);
}

.login-body::before,
.login-body::after {
    content: "";
    position: fixed;
    pointer-events: none;
    border-radius: 50%;
    z-index: 0;
    filter: blur(18px);
}

.login-body::before {
    width: 540px;
    height: 540px;
    left: -150px;
    top: -170px;
    background: radial-gradient(circle, color-mix(in srgb, var(--login-accent) 42%, white 18%) 0%, color-mix(in srgb, var(--login-accent) 0%, transparent) 72%);
    animation: login-aurora-float-a 16s ease-in-out infinite alternate;
}

.login-body::after {
    width: 660px;
    height: 660px;
    right: -220px;
    bottom: -240px;
    background: radial-gradient(circle, color-mix(in srgb, var(--login-accent-soft) 54%, var(--login-accent) 26%) 0%, color-mix(in srgb, var(--login-accent-soft) 0%, transparent) 74%);
    animation: login-aurora-float-b 19s ease-in-out infinite alternate;
}

.login-page-wrapper {
    position: relative;
    z-index: 1;
    min-height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1.2rem;
}

.login-card {
    position: relative;
    width: 100%;
    max-width: 520px;
    border-radius: 24px;
    padding: clamp(1.25rem, 2.6vw, 2rem);
    border: 1px solid var(--login-panel-border);
    background:
        linear-gradient(145deg, color-mix(in srgb, var(--bg-card, #1a212b) 84%, #071323 16%) 0%, color-mix(in srgb, var(--bg-card, #1a212b) 74%, #06101d 26%) 56%, color-mix(in srgb, var(--bg-card, #1a212b) 84%, #040c16 16%) 100%),
        linear-gradient(180deg, color-mix(in srgb, var(--login-accent) 20%, transparent) 0%, color-mix(in srgb, var(--login-accent-soft) 16%, transparent) 100%);
    backdrop-filter: blur(20px) saturate(138%);
    box-shadow:
        0 24px 52px rgba(3, 12, 24, 0.56),
        0 0 0 1px color-mix(in srgb, var(--login-accent) 14%, transparent) inset,
        0 -20px 56px color-mix(in srgb, var(--login-accent) 10%, transparent) inset;
    overflow: hidden;
    animation: login-card-enter 520ms cubic-bezier(0.22, 1, 0.36, 1);
}

.login-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(128deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0) 30%);
    pointer-events: none;
}

.login-card > * {
    position: relative;
    z-index: 1;
}

.login-title {
    margin: 0 0 1.2rem;
    font-family: "Sora", "Manrope", sans-serif;
    font-size: clamp(1.65rem, 2.9vw, 2.3rem);
    font-weight: 800;
    letter-spacing: -0.025em;
    color: var(--login-panel-text);
    display: flex;
    flex-direction: column;
    line-height: 1.05;
}

.login-title-main {
    font-size: clamp(2rem, 3.45vw, 2.75rem);
    font-weight: 800;
}

.login-title-sub {
    margin-top: 0.62rem;
    font-size: clamp(0.875rem, 1.45vw, 1.18rem);
    font-weight: 500;
    color: color-mix(in srgb, var(--login-panel-text) 90%, white 10%);
}

.login-subtitle {
    margin: 0.58rem 0 1.3rem;
    font-size: 0.96rem;
    line-height: 1.55;
    color: var(--login-panel-muted);
}

.login-card .form-label {
    font-size: 0.88rem;
    font-weight: 700;
    color: color-mix(in srgb, var(--login-panel-text) 88%, var(--login-panel-muted) 12%);
    letter-spacing: 0.01em;
}

.login-card .form-control {
    height: 52px;
    border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--login-panel-border) 78%, transparent 22%);
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface-subpanel-bg, rgba(14, 21, 31, 0.86)) 84%, #040b15 16%) 0%, color-mix(in srgb, var(--surface-subpanel-bg, rgba(14, 21, 31, 0.86)) 94%, #050f1c 6%) 100%);
    color: color-mix(in srgb, var(--login-panel-text) 92%, white 8%);
    font-weight: 600;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.09);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.login-card .form-control:focus {
    border-color: color-mix(in srgb, var(--login-accent) 72%, white 10%);
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface-subpanel-bg, rgba(14, 21, 31, 0.86)) 80%, #071526 20%) 0%, color-mix(in srgb, var(--surface-subpanel-bg, rgba(14, 21, 31, 0.86)) 90%, #071424 10%) 100%);
    box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--login-accent) 24%, transparent), inset 0 1px 0 rgba(255, 255, 255, 0.11);
}

.login-submit-btn {
    margin-top: 1rem !important;
    height: 54px;
    border: none;
    border-radius: 14px;
    font-size: 1.06rem;
    font-weight: 800;
    letter-spacing: 0.012em;
    color: var(--theme-btn-primary-text, #ffffff);
    background: var(--theme-btn-primary-bg, linear-gradient(130deg, color-mix(in srgb, var(--login-accent) 78%, white 22%) 0%, color-mix(in srgb, var(--login-accent) 62%, #6fdcff 38%) 56%, color-mix(in srgb, var(--login-accent-soft) 68%, var(--login-accent) 32%) 100%));
    box-shadow: 0 16px 32px color-mix(in srgb, var(--login-accent) 32%, transparent), inset 0 1px 0 rgba(255, 255, 255, 0.38);
    transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

.login-submit-btn:hover {
    color: var(--theme-btn-primary-text, #ffffff);
    transform: translateY(-1px);
    box-shadow: 0 20px 34px color-mix(in srgb, var(--login-accent) 42%, transparent), inset 0 1px 0 rgba(255, 255, 255, 0.44);
    filter: brightness(1.04);
}

.login-submit-btn:active {
    transform: translateY(0);
}

.login-submit-btn:focus-visible {
    color: var(--theme-btn-primary-text, #ffffff);
    box-shadow:
        0 0 0 0.24rem color-mix(in srgb, var(--login-accent) 30%, transparent),
        0 16px 32px color-mix(in srgb, var(--login-accent) 32%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.4);
}

.login-card .alert-danger {
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--danger, #f05454) 60%, transparent);
    background: color-mix(in srgb, var(--danger, #f05454) 36%, rgba(46, 10, 15, 0.74) 64%);
    color: #ffe1e4;
    font-weight: 700;
}

@keyframes login-aurora-float-a {
    0% {
        transform: translate3d(0, 0, 0) scale(1);
    }
    100% {
        transform: translate3d(66px, 36px, 0) scale(1.12);
    }
}

@keyframes login-aurora-float-b {
    0% {
        transform: translate3d(0, 0, 0) scale(1);
    }
    100% {
        transform: translate3d(-84px, -40px, 0) scale(1.15);
    }
}

@keyframes login-card-enter {
    from {
        opacity: 0;
        transform: translateY(16px) scale(0.985);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@media (max-width: 991.98px) {
    .login-page-wrapper {
        padding: 1rem;
    }

    .login-card {
        max-width: 560px;
    }
}

@media (max-width: 575.98px) {
    .login-page-wrapper {
        padding: 0.8rem;
    }

    .login-card {
        border-radius: 18px;
        padding: 1.1rem 1rem;
    }

    .login-submit-btn {
        height: 50px;
        font-size: 1rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .login-body::before,
    .login-body::after,
    .login-card,
    .login-card .form-control,
    .login-submit-btn {
        animation: none;
        transition: none;
    }
}

.planning-page {
    display: grid;
    gap: 0.85rem;
    min-width: 0;
}

.planning-toolbar-panel {
    border: 1px solid var(--surface-panel-border);
    border-radius: 14px;
    background: var(--surface-panel-bg);
    box-shadow: var(--shadow);
    padding: 0.85rem 0.9rem;
    display: grid;
    grid-template-columns: minmax(240px, 1fr) minmax(220px, 1fr) auto;
    gap: 0.75rem;
    align-items: center;
}

.planning-toolbar-left,
.planning-toolbar-right {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    align-items: center;
}

.planning-toolbar-left {
    grid-column: 1;
    grid-row: 1;
}

.planning-toolbar-center {
    grid-column: 1 / -1;
    grid-row: 1;
    justify-self: center;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    min-width: 0;
}

.planning-toolbar-right {
    grid-column: 3;
    grid-row: 1;
    justify-self: end;
}

#planningRangeLabel {
    color: var(--text-secondary);
    font-size: 0.82rem;
}

.planning-select-wrap {
    min-width: 168px;
}

.planning-status-filter-wrap {
    min-width: min(100%, 460px);
    flex: 1 1 460px;
}

#planningPage .planning-toolbar-left {
    flex-wrap: nowrap;
    min-width: 0;
}

#planningPage #planningUserWrap {
    flex: 0 0 166px;
    min-width: 166px;
}

#planningPage .planning-status-filter-wrap {
    min-width: 0;
    flex: 1 1 auto;
}

.planning-status-filter-wrap .planning-status-filters {
    width: 100%;
}

.planning-status-filters {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 0.95fr) minmax(0, 1.18fr) minmax(0, 1.08fr) minmax(0, 1.34fr);
    gap: 0.32rem;
    min-width: 0;
}

.planning-status-filter.projects-type-tile {
    min-height: 34px;
    padding: 0.32rem 0.34rem;
    display: flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    text-align: center;
    font-size: 0.7rem;
    font-weight: 700;
    line-height: 1.1;
}

.planning-status-filter.is-running.is-selected {
    border-color: color-mix(in srgb, #a8ff1f 72%, var(--surface-card-border) 28%);
    box-shadow: 0 0 0 1px color-mix(in srgb, #a8ff1f 24%, transparent);
    background: linear-gradient(0deg, rgba(168, 255, 31, 0.24), rgba(168, 255, 31, 0.24)), var(--surface-card-bg);
}

.planning-status-filter.is-completed.is-selected {
    border-color: color-mix(in srgb, #2ca24f 72%, var(--surface-card-border) 28%);
    box-shadow: 0 0 0 1px color-mix(in srgb, #2ca24f 24%, transparent);
    background: linear-gradient(0deg, rgba(44, 162, 79, 0.24), rgba(44, 162, 79, 0.24)), var(--surface-card-bg);
}

.planning-status-filter.is-incomplete.is-selected {
    border-color: color-mix(in srgb, #d63b3b 74%, var(--surface-card-border) 26%);
    box-shadow: 0 0 0 1px color-mix(in srgb, #d63b3b 24%, transparent);
    background: linear-gradient(0deg, rgba(214, 59, 59, 0.24), rgba(214, 59, 59, 0.24)), var(--surface-card-bg);
}

.planning-page .planning-job-card.completed {
    border-color: color-mix(in srgb, #2ca24f 64%, var(--surface-card-border) 36%);
    background: linear-gradient(0deg, rgba(44, 162, 79, 0.34), rgba(44, 162, 79, 0.34)), var(--surface-card-bg);
}

.planning-page .planning-job-card.is-running:not(.incomplete-readonly),
.daily-grid .job-card.is-running:not(.incomplete-readonly) {
    border-color: color-mix(in srgb, #a8ff1f 68%, var(--surface-card-border) 32%);
    background: linear-gradient(0deg, rgba(168, 255, 31, 0.34), rgba(168, 255, 31, 0.34)), var(--surface-card-bg);
}

.daily-grid .job-card.completed {
    border-color: color-mix(in srgb, #2ca24f 64%, var(--surface-card-border) 36%);
    background: linear-gradient(0deg, rgba(44, 162, 79, 0.34), rgba(44, 162, 79, 0.34)), var(--surface-card-bg);
}

#departmentPlanningPage .planning-toolbar-right {
    flex-wrap: nowrap;
    justify-content: flex-end;
}

#departmentPlanningPage .planning-toolbar-right .btn {
    min-width: 34px;
    padding-left: 0.45rem;
    padding-right: 0.45rem;
}

#departmentPlanningPage .planning-toolbar-right .form-control {
    flex: 0 0 auto;
}

.planning-board-layout {
    display: flex;
    gap: 0.85rem;
    align-items: start;
    min-width: 0;
    width: 100%;
    max-width: 100%;
}

.planning-main-column {
    display: grid;
    gap: 0.85rem;
    min-width: 0;
    flex: 0 1 calc(100% - 360px - 0.85rem);
    width: calc(100% - 360px - 0.85rem);
    max-width: calc(100% - 360px - 0.85rem);
    overflow: hidden;
}

.planning-side-column {
    min-width: 0;
    flex: 0 0 360px;
    max-width: 360px;
    width: min(100%, 360px);
}

.planning-board-card {
    min-height: 0;
    overflow: hidden;
}

.planning-main-column > .planning-board-card > .board-card-body {
    overflow-x: hidden;
}

.planning-days-grid {
    display: grid;
    gap: 0.6rem;
    grid-template-columns: repeat(var(--planning-day-count, 5), minmax(180px, 1fr));
    grid-auto-flow: column;
    padding: 0.75rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-x: contain;
    scrollbar-gutter: stable;
}

.planning-days-grid::-webkit-scrollbar {
    height: 8px;
}

.planning-days-grid::-webkit-scrollbar-thumb {
    background: var(--surface-scrollbar-thumb, var(--surface-panel-border));
    border-radius: 999px;
}

.planning-day-column {
    border: 1px solid var(--surface-panel-border);
    border-radius: 12px;
    background: var(--surface-panel-bg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.planning-day-header {
    border-bottom: 1px solid var(--surface-panel-header-border);
    padding: 0.6rem 0.65rem;
    color: var(--surface-panel-header-text);
    font-weight: 800;
    font-size: 0.83rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.45rem;
    min-width: 0;
}

.planning-day-header-label {
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.planning-mini-effort {
    flex: 0 0 92px;
    width: 92px;
    min-width: 92px;
    display: grid;
    gap: 0.12rem;
}

.planning-mini-effort-row {
    display: grid;
    grid-template-columns: 10px minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.22rem;
}

.planning-mini-effort-label {
    color: #9eb4d1;
    font-size: 0.56rem;
    line-height: 1;
    font-weight: 800;
    text-align: center;
}

.planning-mini-effort-track {
    height: 4px;
    border-radius: 999px;
    background: rgba(84, 102, 128, 0.35);
    overflow: hidden;
    position: relative;
}

.planning-mini-effort-fill {
    height: 100%;
    border-radius: 999px;
    width: 0;
}

.planning-mini-effort-row.planned .planning-mini-effort-fill {
    background: linear-gradient(90deg, #5b670f 0%, #7e8f21 100%);
}

.planning-mini-effort-row.actual .planning-mini-effort-fill {
    background: linear-gradient(90deg, #01576d 0%, #167892 100%);
}

.planning-mini-effort-value {
    color: #d4e0f0;
    font-size: 0.56rem;
    line-height: 1;
    font-weight: 800;
    min-width: 22px;
    text-align: right;
}

.planning-mini-effort-value::after {
    content: "dk";
    margin-left: 1px;
    color: #8fa6c5;
    font-size: 0.48rem;
    font-weight: 700;
}

.planning-drop-lane {
    min-height: 210px;
    padding: 0.5rem;
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.planning-day-column > .planning-drop-lane {
    flex: 1 1 auto;
}

.planning-pools-card {
    min-height: 0;
}

.planning-pools-body {
    min-height: 420px;
    padding: 0.6rem;
}

.planning-pool-tabs {
    display: inline-flex;
    gap: 0.45rem;
}

.planning-pool-tabs .btn.active {
    background: var(--accent-soft);
    border-color: var(--accent);
    color: var(--text-primary);
}

.planning-toolbar-panel .btn.btn-outline-light,
.planning-toolbar-panel .btn.btn-outline-secondary {
    color: var(--text-primary);
    border-color: var(--surface-panel-border);
    background: transparent;
}

.planning-toolbar-panel .btn.btn-outline-light:hover,
.planning-toolbar-panel .btn.btn-outline-secondary:hover {
    background: var(--surface-empty-bg);
    border-color: var(--surface-card-hover-border);
    color: var(--text-primary);
}

.planning-toolbar-panel .form-control,
.planning-toolbar-panel .form-select {
    background: var(--surface-subpanel-bg);
    border-color: var(--surface-panel-border);
    color: var(--text-primary);
}

.planning-toolbar-panel .form-control:focus,
.planning-toolbar-panel .form-select:focus {
    background: var(--surface-subpanel-bg);
    color: var(--text-primary);
    border-color: var(--accent);
    box-shadow: 0 0 0 0.2rem rgba(79, 140, 207, 0.16);
}

.planning-status-badge {
    margin-top: 0.38rem;
    display: inline-flex;
    align-items: center;
    border: 1px solid #3a4d67;
    border-radius: 999px;
    padding: 0.1rem 0.5rem;
    font-size: 0.68rem;
    font-weight: 800;
    color: #dce8f7;
    background: #20334a;
}

.planning-status-badge.status-0 {
    background: #2c3040;
}

.planning-status-badge.status-1 {
    background: #1d425f;
}

.planning-status-badge.status-2 {
    background: #4c6d1f;
}

.planning-status-badge.status-3 {
    background: #2b5b33;
}

.department-planning-grid {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    gap: 0.7rem;
    padding: 0.75rem;
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-x: contain;
}

.department-planning-grid > .empty-lane {
    width: 100%;
    min-width: 100%;
}

.department-planning-column {
    flex: 0 0 280px;
    min-width: 280px;
    border: 1px solid var(--surface-panel-border);
    border-radius: 12px;
    background: var(--surface-panel-bg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.department-planning-column-header {
    border-bottom: 1px solid var(--surface-panel-header-border);
    padding: 0.55rem 0.65rem;
    color: var(--surface-panel-header-text);
    font-weight: 800;
    font-size: 0.83rem;
    display: flex;
    align-items: center;
    gap: 0.55rem;
    min-width: 0;
}

.department-planning-name {
    flex: 1 1 auto;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.department-planning-avatar {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    object-fit: cover;
    border: 1px solid var(--surface-avatar-border);
    background: var(--surface-avatar-bg);
}

.department-planning-lane {
    min-height: 210px;
    padding: 0.5rem;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    flex: 1 1 auto;
}

#departmentPlanningPage {
    min-width: 0;
    overflow-x: hidden;
}

#departmentPlanningPage .planning-board-card {
    min-width: 0;
}

#departmentPlanningPage .department-planning-grid::-webkit-scrollbar {
    height: 10px;
}

#departmentPlanningPage .department-planning-grid::-webkit-scrollbar-thumb {
    background: var(--surface-scrollbar-thumb);
    border-radius: 999px;
}

.jobs-page {
    display: grid;
    gap: 0.85rem;
}

.jobs-layout {
    display: grid;
    grid-template-columns: minmax(260px, 300px) minmax(0, 1fr);
    gap: 0.85rem;
    align-items: start;
}

.jobs-filter-card,
.jobs-main-column > .board-card,
.jobs-detail-card {
    min-height: 0;
}

.jobs-filter-body {
    min-height: 100%;
}

.jobs-filter-body .btn.btn-success {
    --bs-btn-bg: var(--accent);
    --bs-btn-border-color: var(--accent);
    --bs-btn-hover-bg: var(--accent);
    --bs-btn-hover-border-color: var(--accent);
    --bs-btn-active-bg: var(--accent);
    --bs-btn-active-border-color: var(--accent);
    --bs-btn-color: #fff;
    --bs-btn-hover-color: #fff;
    --bs-btn-active-color: #fff;
    background-color: var(--accent) !important;
    border-color: var(--accent) !important;
    color: #fff !important;
}

.jobs-filter-body .btn.btn-success:hover,
.jobs-filter-body .btn.btn-success:focus {
    background-color: var(--accent) !important;
    border-color: var(--accent) !important;
    color: #fff !important;
    filter: brightness(0.94);
}

.jobs-filter-body .btn.btn-outline-light {
    --bs-btn-color: var(--text-primary);
    --bs-btn-border-color: var(--surface-panel-border);
    --bs-btn-hover-color: var(--text-primary);
    --bs-btn-hover-bg: var(--surface-empty-bg);
    --bs-btn-hover-border-color: var(--surface-card-hover-border);
    --bs-btn-active-color: var(--text-primary);
    --bs-btn-active-bg: var(--surface-empty-bg);
    --bs-btn-active-border-color: var(--surface-card-hover-border);
    color: var(--text-primary) !important;
    border-color: var(--surface-panel-border) !important;
    background: transparent !important;
}

.jobs-filter-body .btn.btn-outline-light:hover,
.jobs-filter-body .btn.btn-outline-light:focus {
    color: var(--text-primary) !important;
    border-color: var(--surface-card-hover-border) !important;
    background: var(--surface-empty-bg) !important;
}

#jobsPage #jobsApplyFilters {
    --bs-btn-bg: var(--accent);
    --bs-btn-border-color: var(--accent);
    --bs-btn-hover-bg: var(--accent);
    --bs-btn-hover-border-color: var(--accent);
    --bs-btn-active-bg: var(--accent);
    --bs-btn-active-border-color: var(--accent);
    --bs-btn-disabled-bg: var(--accent);
    --bs-btn-disabled-border-color: var(--accent);
    --bs-btn-color: #fff;
    --bs-btn-hover-color: #fff;
    --bs-btn-active-color: #fff;
    --bs-btn-disabled-color: #fff;
    background: var(--accent) !important;
    background-image: none !important;
    border-color: var(--accent) !important;
    color: #fff !important;
}

#jobsPage #jobsApplyFilters:hover,
#jobsPage #jobsApplyFilters:focus {
    background: var(--accent) !important;
    background-image: none !important;
    border-color: var(--accent) !important;
    color: #fff !important;
    filter: brightness(0.94);
}

#jobsPage #jobsClearFilters {
    --bs-btn-color: var(--text-primary);
    --bs-btn-border-color: var(--surface-panel-border);
    --bs-btn-hover-color: var(--text-primary);
    --bs-btn-hover-bg: var(--surface-empty-bg);
    --bs-btn-hover-border-color: var(--surface-card-hover-border);
    --bs-btn-active-color: var(--text-primary);
    --bs-btn-active-bg: var(--surface-empty-bg);
    --bs-btn-active-border-color: var(--surface-card-hover-border);
    color: var(--text-primary) !important;
    border-color: var(--surface-panel-border) !important;
    background: transparent !important;
    background-image: none !important;
}

#jobsPage #jobsClearFilters:hover,
#jobsPage #jobsClearFilters:focus {
    color: var(--text-primary) !important;
    border-color: var(--surface-card-hover-border) !important;
    background: var(--surface-empty-bg) !important;
    background-image: none !important;
}

.jobs-main-column {
    display: grid;
    gap: 0.85rem;
    grid-template-rows: minmax(320px, 1.2fr) minmax(240px, 1fr);
}

.jobs-list-card.active {
    border-color: #5a95d1;
    box-shadow: 0 0 0 1px rgba(91, 157, 222, 0.35) inset;
}

.jobs-detail-card .board-card-body {
    min-height: 240px;
}

.jobs-detail-block h4 {
    margin: 0;
    font-size: 1.08rem;
    font-weight: 800;
}

.jobs-detail-meta {
    margin: 0.35rem 0 0.75rem;
    color: #9cb1cc;
    font-size: 0.82rem;
}

.jobs-detail-grid {
    display: grid;
    gap: 0.45rem;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    font-size: 0.86rem;
}

.jobs-detail-note {
    font-size: 0.92rem;
    line-height: 1.45;
    color: #e9f2ff;
}

.jobs-detail-note a {
    color: #71b7ff;
    text-decoration: underline;
}

.projects-page {
    display: grid;
    gap: 0.85rem;
    height: calc(var(--app-viewport-100) - (2rem + var(--app-header-collapsed-height)));
    grid-template-rows: auto minmax(0, 1fr);
    min-height: 0;
}

.projects-top-card,
.projects-results-card {
    min-height: 0;
}

.projects-top-card {
    height: auto;
}

.projects-top-card > .board-card-body {
    padding-top: 0.9rem;
    padding-left: 0.95rem;
    padding-right: 0.95rem;
    padding-bottom: 0.62rem;
    overflow: hidden;
}

.projects-results-card {
    height: 100%;
}

.projects-header-search {
    width: min(100%, 620px);
    max-width: min(100%, 620px);
    justify-self: end;
}

.projects-header-search .form-control {
    min-height: 34px;
}

.projects-top-card .board-card-body,
.projects-results-card .board-card-body,
.project-detail-summary-card .board-card-body,
.project-detail-viewer-card .board-card-body {
    min-height: 0;
}

.projects-results-card .board-card-body {
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.projects-type-panel {
    border: 0;
    border-radius: 0;
    background: transparent;
    padding: 0;
    display: grid;
    gap: 0.62rem;
    min-width: 0;
    overflow: hidden;
}

.projects-type-header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.65rem;
    padding-bottom: 0.62rem;
    border-bottom: 1px solid var(--surface-panel-header-border);
    min-width: 0;
}

.projects-type-panel h4 {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--text-primary);
}

.projects-type-actions {
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    justify-self: end;
}

.projects-type-tiles {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    gap: 0.36rem;
    min-width: 0;
    overflow: hidden;
}

.projects-type-tile {
    flex: 1 1 0;
    min-width: 0;
    min-height: 80px;
    border: 1px solid var(--surface-card-border);
    border-radius: 11px;
    background: var(--surface-card-bg);
    color: var(--text-primary);
    display: grid;
    gap: 0.08rem;
    align-content: start;
    text-align: left;
    padding: 0.46rem 0.52rem;
    overflow: hidden;
    transition: border-color 0.15s ease, background-color 0.15s ease;
}

.projects-type-tile:hover,
.projects-type-tile:focus-visible {
    border-color: var(--surface-card-hover-border);
    background: var(--surface-card-hover-bg);
    outline: none;
}

.projects-type-tile.is-selected {
    border-color: color-mix(in srgb, var(--accent) 70%, var(--surface-card-hover-border) 30%);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent);
}

.projects-type-tile-title {
    display: flex;
    align-items: flex-start;
    gap: 0.3rem;
    min-width: 0;
    font-size: 0.86rem;
    font-weight: 700;
    line-height: 1.04;
}

.projects-type-tile-title i {
    flex: 0 0 auto;
    font-size: 0.84rem;
}

.projects-type-tile-title span {
    display: block;
    min-width: 0;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    word-break: keep-all;
    overflow-wrap: break-word;
}

.projects-type-tile-title span.is-single-line {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: clip;
}

.projects-type-tile-title span.is-multi-line {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: clip;
    line-height: 1.04;
}

.projects-type-tile small {
    color: var(--text-secondary);
    font-size: 0.71rem;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.projects-results-card .board-card-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: center;
    gap: 0.75rem;
}

.projects-inline-filters {
    display: flex;
    align-items: center;
    justify-self: center;
    gap: 0.65rem;
    min-width: 0;
}

.projects-inline-filter-field {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    min-width: 0;
}

.projects-inline-filter-field label {
    margin: 0;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--theme-field-label);
    white-space: nowrap;
}

.projects-inline-filter-field .form-select {
    min-width: 170px;
    max-width: 230px;
}

.projects-results-card .board-card-header small {
    justify-self: end;
    text-align: right;
    white-space: nowrap;
}

.projects-results-card .board-card-header h3 {
    justify-self: start;
}

.projects-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 0.65rem;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    align-content: start;
    scrollbar-gutter: stable;
    padding-right: 0.15rem;
}

.projects-result-card {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--surface-card-border);
    border-radius: 14px;
    background: color-mix(in srgb, var(--surface-card-bg) 86%, #ffffff 14%);
    min-height: 132px;
    height: auto;
    padding: 0.75rem 0.82rem 0.62rem;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    gap: 0.34rem;
    align-content: start;
    transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.projects-result-card::before {
    content: "";
    position: absolute;
    top: 12px;
    bottom: 12px;
    width: 14px;
    border-radius: 12px;
    background: color-mix(in srgb, var(--surface-card-head-text) 76%, transparent);
    pointer-events: none;
}

.projects-result-card::before { left: -7px; }

.projects-result-card-text {
    min-width: 0;
    display: grid;
    gap: 0.08rem;
    align-content: start;
}

.projects-result-card:hover,
.projects-result-card:focus-visible {
    border-color: var(--surface-card-hover-border);
    background: var(--surface-card-hover-bg);
    box-shadow: 0 10px 24px rgba(4, 7, 11, 0.2);
    outline: none;
}

.projects-result-card-top {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 0.45rem;
}

.projects-result-card-title {
    margin: 0;
    font-size: 1.07rem;
    font-weight: 800;
    line-height: 1;
    color: var(--surface-card-head-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: clip;
}

.projects-result-card-type-line,
.projects-result-card-period-line {
    display: block;
    color: var(--text-primary);
    font-size: 0.92rem;
    font-weight: 400;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.projects-result-card-type-line {
    margin-top: 0.2rem;
}

.projects-result-card-period-line {
    margin-top: 0.16rem;
}

.projects-result-card-corner-icon {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    border: 1px solid var(--surface-subpanel-border);
    background: color-mix(in srgb, var(--surface-card-border) 56%, var(--bg-page) 44%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--surface-card-head-text);
    font-size: 1.1rem;
}

.projects-result-card-bottom {
    margin-top: 0.12rem;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 0.55rem;
    min-width: 0;
}

.projects-result-card-active {
    min-width: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    color: var(--text-secondary);
    font-size: 0.72rem;
    font-weight: 400;
    line-height: 1.2;
    cursor: default;
    border-radius: 8px;
    padding: 0.08rem 0.16rem;
    margin-top: 0.18rem;
    transition: color 0.15s ease, background-color 0.15s ease;
}

.projects-result-card-active:hover,
.projects-result-card-active:focus-visible {
    color: var(--text-primary);
    background: color-mix(in srgb, var(--surface-card-border) 38%, transparent);
    outline: none;
}

.projects-result-card-active i {
    font-size: 0.8rem;
    color: var(--surface-card-head-text);
}

.projects-result-card-active span {
    display: block;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.projects-result-card-active-count {
    flex: 0 0 auto;
    display: inline-block;
    min-width: 0;
    min-height: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: color-mix(in srgb, var(--text-secondary) 84%, transparent);
    padding: 0;
    font-size: 1.48rem;
    font-weight: 700;
    line-height: 0.92;
    letter-spacing: 0.01em;
    opacity: 0.72;
}

.projects-result-card:hover .projects-result-card-active-count,
.projects-result-card:focus-visible .projects-result-card-active-count {
    color: color-mix(in srgb, var(--text-secondary) 90%, transparent);
    opacity: 0.8;
}

.projects-active-hover-panel {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 1300;
    width: min(390px, calc(100vw - 1.2rem));
    max-height: min(320px, calc(100vh - 1.2rem));
    border: 1px solid var(--surface-card-hover-border);
    border-radius: 11px;
    background: var(--bg-card);
    box-shadow:
        0 12px 30px rgba(2, 5, 10, 0.36),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
    opacity: 0;
    transform: translateY(5px);
    pointer-events: none;
    transition: opacity 0.14s ease, transform 0.14s ease;
    display: grid;
    gap: 0.3rem;
    padding: 0.54rem;
}

.projects-active-hover-panel.is-open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.projects-active-hover-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.45rem;
    min-width: 0;
}

.projects-active-hover-header strong {
    margin: 0;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-primary);
    white-space: nowrap;
}

.projects-active-hover-header small {
    color: var(--text-secondary);
    font-size: 0.71rem;
    white-space: nowrap;
}

.projects-active-hover-list {
    display: grid;
    gap: 0.34rem;
    max-height: min(260px, calc(100vh - 4.8rem));
    overflow: auto;
    padding-right: 0.16rem;
}

.projects-active-hover-item {
    border: 1px solid var(--surface-subpanel-border);
    border-radius: 8px;
    background: color-mix(in srgb, var(--surface-subpanel-bg) 90%, transparent);
    padding: 0.45rem 0.5rem;
    display: grid;
    gap: 0.16rem;
}

.projects-active-hover-item.is-clickable {
    cursor: pointer;
}

.projects-active-hover-item.is-clickable:hover,
.projects-active-hover-item.is-clickable:focus-visible {
    border-color: var(--surface-card-hover-border);
    background: color-mix(in srgb, var(--surface-subpanel-bg) 96%, var(--accent-soft) 4%);
    outline: none;
}

.projects-active-hover-item h6 {
    margin: 0;
    font-size: 0.76rem;
    font-weight: 700;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.projects-active-hover-item small {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.68rem;
    line-height: 1.28;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.projects-active-hover-empty,
.projects-active-hover-truncation {
    border: 1px dashed var(--surface-subpanel-border);
    border-radius: 8px;
    padding: 0.42rem 0.46rem;
    color: var(--text-secondary);
    font-size: 0.72rem;
}

@media (hover: none), (pointer: coarse) {
    .projects-page {
        height: calc(var(--app-viewport-100) - (2rem + var(--app-header-expanded-height)));
    }
}

.project-detail-page {
    display: grid;
    gap: 0.85rem;
    height: calc(var(--app-viewport-100) - (2rem + var(--app-header-collapsed-height)));
    min-height: 0;
    grid-template-rows: auto minmax(0, 1fr);
}

#projectDetailAlert {
    grid-row: 1;
}

.project-detail-shell-card {
    grid-row: 2;
    height: 100%;
    min-height: 0;
}

.project-detail-summary-card .board-card-body {
    overflow: visible;
}

.project-detail-heading {
    border: 1px solid var(--surface-panel-border);
    border-radius: 12px;
    padding: 0.7rem 0.8rem;
    background: var(--surface-panel-bg);
}

.project-detail-heading-main {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.45rem;
    font-size: 1.2rem;
    line-height: 1.3;
    color: var(--text-primary);
}

.project-detail-heading-main strong {
    font-weight: 800;
}

.project-detail-filter-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.project-detail-filter-box {
    border: 1px solid var(--surface-subpanel-border);
    border-radius: 12px;
    background: var(--surface-subpanel-bg);
    padding: 0.65rem;
    min-height: 140px;
}

.project-detail-filter-box header h4 {
    margin: 0 0 0.5rem;
    font-size: 0.86rem;
    font-weight: 800;
    color: var(--text-primary);
}

.project-detail-chip-list {
    display: grid;
    gap: 0.4rem;
}

.project-detail-chip {
    border: 1px solid var(--surface-card-border);
    border-radius: 9px;
    background: var(--surface-card-bg);
    color: var(--text-primary);
    text-align: left;
    display: grid;
    gap: 0.16rem;
    padding: 0.48rem 0.55rem;
}

.project-detail-chip:hover,
.project-detail-chip:focus-visible {
    border-color: var(--surface-card-hover-border);
    background: var(--surface-card-hover-bg);
    outline: none;
}

.project-detail-chip.is-selected {
    border-color: color-mix(in srgb, var(--accent) 70%, var(--surface-card-hover-border) 30%);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent);
}

.project-detail-chip strong {
    font-size: 0.85rem;
    font-weight: 700;
}

.project-detail-chip small {
    color: var(--text-secondary);
    font-size: 0.72rem;
}

.project-detail-task-list {
    display: grid;
    gap: 0.45rem;
    max-height: 340px;
    overflow: auto;
}

.project-detail-task-row {
    border: 1px solid var(--surface-card-border);
    border-radius: 9px;
    background: var(--surface-card-bg);
    color: var(--text-primary);
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.45rem;
    align-items: center;
    text-align: left;
    padding: 0.5rem 0.55rem;
}

.project-detail-task-row:hover,
.project-detail-task-row:focus-visible {
    border-color: var(--surface-card-hover-border);
    background: var(--surface-card-hover-bg);
    outline: none;
}

.project-detail-task-row.is-selected {
    border-color: color-mix(in srgb, var(--accent) 70%, var(--surface-card-hover-border) 30%);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent);
}

.project-detail-task-row-main {
    min-width: 0;
    display: grid;
    gap: 0.12rem;
}

.project-detail-task-row-main strong {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.project-detail-task-row-main small {
    font-size: 0.72rem;
    color: var(--text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.project-detail-task-row-metrics {
    display: grid;
    gap: 0.15rem;
    text-align: right;
    color: var(--text-secondary);
    font-size: 0.71rem;
    font-weight: 700;
}

.project-detail-viewer-card .board-card-body {
    min-height: 420px;
}

.project-task-viewer-shell {
    display: grid;
    gap: 0.7rem;
}

.project-task-viewer-header {
    border: 1px solid var(--surface-panel-border);
    border-radius: 12px;
    background: var(--surface-panel-bg);
    padding: 0.7rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.7rem;
    align-items: start;
}

.project-task-viewer-title small {
    display: block;
    color: var(--text-secondary);
    font-size: 0.72rem;
    font-weight: 700;
}

.project-task-viewer-title h4 {
    margin: 0.15rem 0 0;
    font-size: 1.02rem;
    font-weight: 800;
    color: var(--text-primary);
}

.project-task-viewer-meta {
    margin-top: 0.25rem;
    color: var(--text-secondary);
    font-size: 0.77rem;
}

.project-task-viewer-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.35rem;
}

.project-task-viewer-metrics span {
    border: 1px solid var(--surface-subpanel-border);
    border-radius: 8px;
    background: var(--surface-subpanel-bg);
    padding: 0.3rem 0.45rem;
    text-align: center;
}

.project-task-viewer-metrics strong {
    display: block;
    color: var(--text-primary);
    font-size: 0.82rem;
}

.project-task-viewer-metrics small {
    color: var(--text-secondary);
    font-size: 0.68rem;
    font-weight: 700;
}

.project-task-viewer-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(320px, 1fr);
    gap: 0.7rem;
}

.project-task-viewer-main,
.project-task-viewer-flow {
    border: 1px solid var(--surface-subpanel-border);
    border-radius: 12px;
    background: var(--surface-subpanel-bg);
    padding: 0.65rem;
    min-height: 0;
}

.project-task-viewer-flow-head {
    font-size: 0.82rem;
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: 0.5rem;
}

.project-task-viewer-flow-list {
    display: grid;
    gap: 0.45rem;
    max-height: 420px;
    overflow: auto;
}

.project-task-flow-card {
    border: 1px solid var(--surface-card-border);
    border-radius: 9px;
    background: var(--surface-card-bg);
    padding: 0.46rem 0.52rem;
    display: grid;
    gap: 0.2rem;
}

.project-task-flow-card-top {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.project-task-flow-card-top small {
    color: var(--text-secondary);
    font-size: 0.72rem;
}

.project-task-flow-card-title {
    color: var(--text-primary);
    font-size: 0.8rem;
    font-weight: 700;
}

.project-task-flow-card-sub {
    color: var(--text-secondary);
    font-size: 0.7rem;
}

.project-detail-shell-card .board-card-body {
    min-height: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.project-detail-shell-body {
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
    overflow: hidden;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 0.5rem;
}

.project-detail-shell-header {
    position: relative;
    justify-content: flex-start;
    align-items: center;
    min-height: 56px;
}

.project-detail-shell-header-left {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    min-width: 0;
    position: relative;
    z-index: 1;
}

.project-detail-shell-header-left h3 {
    margin: 0;
}

.project-detail-header-context {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    max-width: min(980px, calc(100% - 320px));
    min-width: 0;
    pointer-events: none;
}

.project-detail-header-context .project-detail-heading-main {
    justify-content: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 1.05rem;
}

.project-detail-back-btn {
    flex: 0 0 auto;
}

.project-detail-operation-strip {
    border: 1px solid var(--surface-subpanel-border);
    border-radius: 12px;
    background: var(--surface-subpanel-bg);
    padding: 0.42rem;
}

.project-detail-operation-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 0.4rem;
}

.project-detail-operation-chip {
    border: 1px solid var(--surface-card-border);
    border-radius: 10px;
    background: var(--surface-card-bg);
    color: var(--text-primary);
    min-height: 52px;
    display: grid;
    gap: 0.1rem;
    align-content: center;
    justify-items: center;
    text-align: center;
    padding: 0.35rem 0.45rem;
}

.project-detail-operation-chip:hover,
.project-detail-operation-chip:focus-visible {
    border-color: var(--surface-card-hover-border);
    background: var(--surface-card-hover-bg);
    outline: none;
}

.project-detail-operation-chip.is-selected {
    border-color: color-mix(in srgb, var(--accent) 70%, var(--surface-card-hover-border) 30%);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent);
}

.project-detail-operation-chip span {
    display: block;
    font-size: 0.9rem;
    font-weight: 800;
    line-height: 1.15;
}

.project-detail-operation-chip small {
    color: var(--text-secondary);
    font-size: 0.7rem;
    font-weight: 700;
}

.project-detail-main-layout {
    display: grid;
    grid-template-columns: minmax(250px, 300px) minmax(0, 1fr);
    gap: 0.72rem;
    min-height: 0;
    height: 100%;
    overflow: hidden;
}

.project-detail-sidebar {
    min-height: 0;
    height: 100%;
    display: grid;
    grid-template-rows: minmax(170px, auto) minmax(0, 1fr);
    gap: 0.7rem;
}

.project-detail-side-panel {
    border: 1px solid var(--surface-subpanel-border);
    border-radius: 12px;
    background: var(--surface-subpanel-bg);
    padding: 0.58rem;
    min-height: 0;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
}

.project-detail-side-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.48rem;
}

.project-detail-side-header h4 {
    margin: 0;
    font-size: 0.84rem;
    font-weight: 800;
    color: var(--text-primary);
}

.project-detail-side-header small {
    color: var(--text-secondary);
    font-size: 0.7rem;
    font-weight: 700;
}

.project-detail-process-list {
    display: grid;
    gap: 0.35rem;
    align-content: start;
    grid-auto-rows: max-content;
    min-height: 0;
    height: 100%;
    max-height: 260px;
    overflow: auto;
    padding-right: 0.05rem;
}

.project-detail-process-row {
    border: 1px solid var(--surface-card-border);
    border-radius: 9px;
    background: var(--surface-card-bg);
    color: var(--text-primary);
    text-align: left;
    display: grid;
    gap: 0.12rem;
    padding: 0.42rem 0.5rem;
}

.project-detail-process-row:hover,
.project-detail-process-row:focus-visible {
    border-color: var(--surface-card-hover-border);
    background: var(--surface-card-hover-bg);
    outline: none;
}

.project-detail-process-row.is-selected {
    border-color: color-mix(in srgb, var(--accent) 70%, var(--surface-card-hover-border) 30%);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent);
}

.project-detail-process-row strong {
    font-size: 0.8rem;
    font-weight: 700;
}

.project-detail-process-row small {
    color: var(--text-secondary);
    font-size: 0.7rem;
    font-weight: 700;
}

.project-detail-job-list {
    display: grid;
    gap: 0.42rem;
    align-content: start;
    grid-auto-rows: max-content;
    min-height: 0;
    height: 100%;
    max-height: 100%;
    overflow: auto;
    padding-right: 0.05rem;
}

.project-detail-job-row {
    border: 1px solid var(--surface-card-border);
    border-radius: 9px;
    background: var(--surface-card-bg);
    color: var(--text-primary);
    text-align: left;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.42rem;
    align-items: center;
    padding: 0.44rem 0.5rem;
}

.project-detail-job-row:hover,
.project-detail-job-row:focus-visible {
    border-color: var(--surface-card-hover-border);
    background: var(--surface-card-hover-bg);
    outline: none;
}

.project-detail-job-row.is-selected {
    border-color: color-mix(in srgb, var(--accent) 70%, var(--surface-card-hover-border) 30%);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent);
}

.project-detail-job-row-main {
    min-width: 0;
    display: grid;
    gap: 0.08rem;
}

.project-detail-job-row-main strong {
    color: var(--text-primary);
    font-size: 0.79rem;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.project-detail-job-row-main small {
    color: var(--text-secondary);
    font-size: 0.69rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.project-detail-job-row-metrics {
    display: grid;
    gap: 0.1rem;
    text-align: right;
    color: var(--text-secondary);
    font-size: 0.67rem;
    font-weight: 700;
}

.project-detail-viewer-panel {
    border: 1px solid var(--surface-subpanel-border);
    border-radius: 12px;
    background: var(--surface-subpanel-bg);
    padding: 0.6rem;
    min-height: 0;
    display: grid;
    grid-template-rows: minmax(0, 1fr);
    overflow: hidden;
}

.project-detail-viewer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.55rem;
    margin-bottom: 0.54rem;
    padding-bottom: 0.52rem;
    border-bottom: 1px solid var(--surface-panel-border);
}

.project-detail-viewer-header h4 {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 800;
    color: var(--text-primary);
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.project-detail-viewer-frame-wrap {
    border: 1px solid var(--surface-panel-border);
    border-radius: 10px;
    overflow: hidden;
    min-height: 0;
    height: 100%;
    display: grid;
    grid-template-rows: minmax(0, 1fr);
    background: var(--surface-panel-bg);
    position: relative;
}

.project-detail-job-frame {
    width: 100%;
    min-height: 0;
    height: 100%;
    display: block;
    border: 0;
    background: var(--surface-panel-bg);
}

.project-detail-viewer-frame-wrap .flow-empty {
    margin: 0;
    min-height: 0;
    height: 100%;
    display: grid;
    place-items: center;
    border: 0;
    border-radius: 0;
}

.job-view-page {
    display: grid;
    gap: 0.85rem;
}

.job-view-toolbar {
    display: flex;
    gap: 0.55rem;
    align-items: center;
}

.job-view-section {
    margin-top: 0.8rem;
}

.job-view-section h4 {
    margin: 0 0 0.45rem;
    font-size: 0.92rem;
    font-weight: 800;
    color: #d7e5f8;
}

.job-view-note {
    border: 1px solid #31445d;
    border-radius: 12px;
    background: rgba(14, 22, 32, 0.55);
    padding: 0.75rem;
    min-height: 100px;
    line-height: 1.45;
    color: #e9f2ff;
}

.job-view-note a {
    color: #71b7ff;
    text-decoration: underline;
}

.job-view-list-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.6rem;
    align-items: center;
    border: 1px solid #31445d;
    border-radius: 10px;
    background: rgba(14, 22, 32, 0.55);
    padding: 0.55rem 0.6rem;
    margin-bottom: 0.45rem;
    color: inherit;
}

.job-view-list-main {
    min-width: 0;
    display: grid;
    gap: 0.15rem;
}

.job-view-list-main strong {
    font-size: 0.84rem;
    color: #edf5ff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.job-view-list-main small {
    font-size: 0.74rem;
    color: #99aec9;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.job-view-list-metrics {
    display: grid;
    gap: 0.15rem;
    text-align: right;
    color: #d2deed;
    font-size: 0.74rem;
    font-weight: 700;
}

.job-view-attachment-item:hover {
    border-color: #4b6281;
    background: rgba(16, 27, 40, 0.8);
}

.job-view-shell {
    display: grid;
    gap: 0.9rem;
}

.job-view-topbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: 0.8rem;
    align-items: start;
    border: 1px solid rgba(103, 71, 47, 0.45);
    border-radius: 14px;
    background:
        linear-gradient(90deg, rgba(255, 135, 45, 0.14) 0%, rgba(255, 135, 45, 0.03) 18%, rgba(14, 11, 23, 0.92) 50%, rgba(95, 21, 44, 0.12) 100%),
        rgba(14, 11, 23, 0.9);
    padding: 0.85rem 0.95rem;
}

.job-view-actions {
    grid-column: 1;
    justify-self: start;
    display: inline-flex;
    gap: 0.45rem;
    align-items: center;
    flex-wrap: wrap;
}

.job-view-heading {
    grid-column: 2;
    justify-self: center;
    text-align: center;
    min-width: 0;
    width: min(100%, 760px);
}

.job-view-kicker {
    color: #f1a35d;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.job-view-heading h1 {
    margin: 0.15rem 0 0;
    font-size: 1.18rem;
    line-height: 1.25;
    font-weight: 800;
    color: #fff2e7;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.job-view-heading-meta {
    margin-top: 0.18rem;
    color: #b8bfd1;
    font-size: 0.75rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.job-view-header-metrics {
    grid-column: 3;
    justify-self: end;
    display: grid;
    grid-template-columns: repeat(2, minmax(88px, 1fr));
    gap: 0.45rem;
    width: min(100%, 236px);
    min-width: 0;
}

.job-view-header-metric {
    border: 1px solid rgba(122, 94, 61, 0.35);
    border-radius: 10px;
    background: rgba(14, 12, 20, 0.72);
    padding: 0.45rem 0.55rem;
    display: grid;
    gap: 0.12rem;
    text-align: center;
}

.job-view-header-metric span {
    color: #aab8cf;
    font-size: 0.68rem;
    font-weight: 700;
}

.job-view-header-metric strong {
    color: #fff6ee;
    font-size: 0.92rem;
    font-weight: 800;
}

.job-view-main-layout {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    align-items: start;
}

.job-view-left-column,
.job-view-right-column {
    min-width: 0;
    flex: 1 1 0;
}

.job-view-detail-card .board-card-body,
.job-view-flow-card .board-card-body {
    padding: 0.8rem;
}

.job-view-detail-card .board-card-body {
    display: grid;
    gap: 0.65rem;
}

.job-view-chip-row {
    display: grid;
    grid-template-columns: minmax(90px, 0.28fr) minmax(0, 1fr) minmax(120px, 0.34fr);
    gap: 0.45rem;
}

.job-view-chip {
    border-radius: 8px;
    border: 1px solid rgba(63, 74, 96, 0.75);
    background: linear-gradient(180deg, rgba(31, 42, 57, 0.88) 0%, rgba(23, 29, 41, 0.9) 100%);
    color: #d9e6f9;
    font-size: 0.78rem;
    font-weight: 700;
    min-height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.35rem 0.5rem;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.job-view-chip-logo {
    background: rgba(243, 246, 250, 0.94);
    color: #677083;
    border-color: rgba(203, 214, 227, 0.9);
}

.job-view-chip-main {
    background: linear-gradient(180deg, rgba(219, 228, 240, 0.95) 0%, rgba(202, 214, 230, 0.95) 100%);
    border-color: rgba(193, 204, 219, 0.95);
    color: #465469;
    font-weight: 800;
}

.job-view-summary-strip {
    border-radius: 10px;
    border: 1px solid rgba(59, 72, 95, 0.72);
    background: rgba(237, 242, 248, 0.08);
    color: #e5edf9;
    padding: 0.55rem 0.7rem;
    display: flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.9rem;
    font-weight: 800;
}

.job-view-summary-strip i {
    color: #d0ddf2;
    font-size: 1rem;
}

.job-view-summary-tiles {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-auto-flow: column;
    gap: 0.45rem;
    min-width: 0;
}

.job-view-summary-box {
    border-radius: 10px;
    border: 1px solid rgba(62, 75, 97, 0.72);
    background: rgba(16, 20, 31, 0.72);
    padding: 0.5rem 0.55rem;
    display: grid;
    gap: 0.18rem;
    min-width: 0;
}

.job-view-summary-box small {
    color: #98aecb;
    font-size: 0.69rem;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    min-width: 0;
}

.job-view-summary-box strong {
    color: #edf4ff;
    font-size: 0.78rem;
    line-height: 1.25;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    min-width: 0;
}

.job-view-flow-card .board-card-header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.65rem;
    align-items: center;
}

.job-view-flow-header-title {
    display: grid;
    gap: 0.05rem;
}

.job-view-flow-header-title h3 {
    margin: 0;
}

.job-view-flow-header-title small {
    color: #95a9c5;
    font-size: 0.72rem;
    font-weight: 700;
}

.job-view-flow-filters {
    display: grid;
    grid-template-columns: minmax(160px, 220px) minmax(0, 1fr) auto;
    gap: 0.45rem;
    align-items: center;
    justify-self: end;
    width: min(100%, 580px);
}

.job-view-flow-filters .form-control,
.job-view-flow-filters .form-select {
    min-height: 34px;
    font-size: 0.8rem;
}

.job-view-flow-count {
    color: var(--text-secondary);
    font-size: 0.76rem;
    font-weight: 700;
    white-space: nowrap;
    justify-self: end;
}

.job-view-flow-timeline {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.65rem;
    max-height: none;
    overflow: visible;
    padding-right: 0;
}

.job-view-stage-detail,
.job-view-flow-item {
    border: 1px solid rgba(57, 72, 94, 0.84);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(16, 20, 30, 0.96) 0%, rgba(11, 14, 22, 0.96) 100%);
    overflow: hidden;
}

.job-view-flow-item {
    cursor: pointer;
    position: relative;
    isolation: isolate;
    flex: 0 0 auto;
    transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.job-view-flow-item::after {
    content: "";
    position: absolute;
    inset: -1px;
    padding: 1px;
    border-radius: inherit;
    opacity: 0;
    pointer-events: none;
    z-index: 1;
    background: conic-gradient(from 0deg, rgba(126, 160, 207, 0.95), rgba(81, 105, 138, 0.2), rgba(126, 160, 207, 0.95));
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    mask-composite: exclude;
}

.job-view-flow-item > * {
    position: relative;
    z-index: 2;
}

.job-view-flow-item:hover {
    border-color: #51698a;
    box-shadow: 0 8px 18px rgba(4, 7, 11, 0.28);
}

.job-view-flow-item:hover::after,
.job-view-flow-item:focus-visible::after {
    opacity: 1;
    animation: job-view-flow-border-spin 2.4s linear infinite;
}

.job-view-flow-item.is-selected {
    border-color: #7ea0cf;
    box-shadow: 0 0 0 1px rgba(126, 160, 207, 0.26), 0 8px 22px rgba(8, 12, 18, 0.32);
}

@keyframes job-view-flow-border-spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes drop-lane-dash-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes drop-lane-glow-breathe {
    from { opacity: 0.62; filter: drop-shadow(0 0 0 rgba(0, 0, 0, 0)); }
    to { opacity: 1; filter: drop-shadow(0 0 8px color-mix(in srgb, var(--accent) 35%, transparent)); }
}

@keyframes job-context-menu-reveal {
    from {
        opacity: 0;
        transform: translateY(-3px) scale(0.985);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes job-context-menu-item-reveal {
    from {
        opacity: 0;
        transform: translateY(-3px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.job-view-stage-top {
    min-height: 38px;
    padding: 0.35rem 0.6rem 0;
    display: grid;
    grid-template-columns: auto auto 1fr;
    align-items: end;
    gap: 0.45rem;
}

.job-view-stage-top.compact {
    padding-top: 0.3rem;
}

.job-view-stage-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 12px 12px 0 0;
    background: linear-gradient(180deg, rgba(141, 160, 190, 0.95) 0%, rgba(111, 132, 165, 0.95) 100%);
    color: #f6fbff;
    padding: 0.28rem 0.8rem;
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1;
}

.job-view-stage-top small {
    color: #9eb2cf;
    font-size: 0.69rem;
    margin-bottom: 0.24rem;
}

.job-view-stage-top span {
    justify-self: end;
    color: #c8d6ea;
    font-size: 0.72rem;
    font-weight: 700;
    margin-bottom: 0.2rem;
    text-align: right;
}

.job-view-stage-top-meta {
    justify-self: end;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-width: 0;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.job-view-stage-top-date {
    order: 2;
    margin-bottom: 0;
    white-space: nowrap;
    flex: 0 0 auto;
}

.job-view-stage-top-actions {
    order: 1;
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.35rem;
    white-space: nowrap;
    min-width: 0;
    flex: 0 0 auto;
}

.job-view-stage-top-actions .btn {
    min-height: 30px;
    font-size: 0.72rem;
    padding: 0.16rem 0.56rem;
    white-space: nowrap;
    flex: 0 0 auto;
}

.job-view-stage-top-meta.compact .job-view-stage-top-date {
    font-size: 0.7rem;
}

.job-view-stage-top-actions.compact {
    display: inline-flex;
}

.job-view-stage-top-actions.compact .btn {
    min-height: 26px;
    font-size: 0.66rem;
    padding: 0.1rem 0.45rem;
}

.job-view-stage-body {
    background: rgba(240, 244, 250, 0.04);
    margin: 0 0.45rem 0.5rem;
    border: 1px solid rgba(58, 70, 91, 0.7);
    border-radius: 10px;
    padding: 0.55rem;
    display: grid;
    grid-template-columns: minmax(130px, 0.28fr) minmax(0, 1fr);
    gap: 0.6rem;
    align-items: start;
}

.job-view-stage-body.compact {
    grid-template-columns: minmax(128px, 0.25fr) minmax(0, 1fr);
    padding: 0.5rem;
}

.job-view-rail {
    border-radius: 8px;
    background: rgba(242, 246, 251, 0.03);
    border: 1px solid rgba(61, 72, 93, 0.5);
    padding: 0.45rem 0.4rem;
    display: grid;
    gap: 0.35rem;
    align-content: start;
}

.job-view-rail.compact {
    padding: 0.38rem 0.34rem;
    gap: 0.28rem;
}

.job-view-rail-person {
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr);
    gap: 0.35rem;
    align-items: center;
}

.job-view-avatar {
    width: 28px;
    height: 28px;
    border-radius: 999px;
    border: 1px solid rgba(115, 138, 168, 0.55);
    background: linear-gradient(180deg, rgba(54, 79, 112, 0.55) 0%, rgba(35, 48, 69, 0.55) 100%);
    color: #e9f2ff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    flex: 0 0 28px;
    font-size: 0.68rem;
    font-weight: 800;
}

.job-view-avatar-fallback {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    line-height: 1;
}

.job-view-avatar img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    z-index: 2;
}

.job-view-avatar.muted {
    background: linear-gradient(180deg, rgba(72, 72, 88, 0.45) 0%, rgba(44, 44, 55, 0.45) 100%);
    border-color: rgba(121, 121, 139, 0.45);
}

.job-view-rail-person small {
    display: block;
    color: #91a6c3;
    font-size: 0.62rem;
    font-weight: 700;
    line-height: 1.15;
}

.job-view-rail-person strong {
    display: block;
    color: #e8f1ff;
    font-size: 0.72rem;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.job-view-rail-line {
    width: 1px;
    height: 18px;
    background: rgba(115, 130, 154, 0.45);
    justify-self: center;
}

.job-view-rail-time {
    display: grid;
    grid-template-columns: 14px minmax(0, 1fr);
    gap: 0.3rem;
    align-items: center;
    color: #c8d8ef;
    font-size: 0.67rem;
    font-weight: 700;
}

.job-view-rail-time i {
    font-size: 0.72rem;
    color: #9db8de;
}

.job-view-rail-status {
    margin-top: 0.1rem;
    border-radius: 999px;
    border: 1px solid rgba(92, 109, 134, 0.6);
    background: rgba(28, 35, 49, 0.8);
    color: #dbe8fb;
    font-size: 0.62rem;
    font-weight: 800;
    padding: 0.15rem 0.35rem;
    text-align: center;
}

.job-view-rail-status.job-view-effort-pending {
    border-color: color-mix(in srgb, var(--warning) 60%, rgba(92, 109, 134, 0.4) 40%);
    background: color-mix(in srgb, var(--warning) 16%, rgba(28, 35, 49, 0.84) 84%);
    color: color-mix(in srgb, var(--warning) 90%, #ffffff 10%);
}

.job-view-rail-status.status-completed {
    border-color: color-mix(in srgb, #2ca24f 72%, rgba(92, 109, 134, 0.4) 28%);
    background: linear-gradient(0deg, rgba(44, 162, 79, 0.24), rgba(44, 162, 79, 0.24)), rgba(28, 35, 49, 0.8);
    color: #eafff0;
}

.job-view-rail-status.status-running {
    border-color: color-mix(in srgb, #a8ff1f 72%, rgba(92, 109, 134, 0.4) 28%);
    background: linear-gradient(0deg, rgba(168, 255, 31, 0.24), rgba(168, 255, 31, 0.24)), rgba(28, 35, 49, 0.8);
    color: #f5ffe6;
}

.job-view-rail-status.status-incomplete {
    border-color: color-mix(in srgb, #d63b3b 74%, rgba(92, 109, 134, 0.4) 26%);
    background: linear-gradient(0deg, rgba(214, 59, 59, 0.24), rgba(214, 59, 59, 0.24)), rgba(28, 35, 49, 0.8);
    color: #ffe9e9;
}

.job-view-stage-content {
    min-width: 0;
    display: grid;
    gap: 0.5rem;
}

.job-view-stage-context-row {
    display: flex;
    align-items: flex-start;
    gap: 0.45rem;
}

.job-view-stage-context-row .job-view-stage-context {
    flex: 1 1 auto;
    min-width: 0;
}

.job-view-stage-status-pill {
    margin: 0;
    flex: 0 0 auto;
    align-self: flex-start;
    white-space: nowrap;
}

.job-view-stage-status-pill.compact {
    font-size: 0.6rem;
    padding: 0.14rem 0.32rem;
}

.job-view-transfer-reason-pill {
    cursor: help;
}

.job-view-stage-context {
    color: #9cb1cc;
    font-size: 0.73rem;
    line-height: 1.25;
}

.job-view-stage-title {
    margin: 0;
    font-size: 1.03rem;
    line-height: 1.3;
    font-weight: 800;
    color: #f2f7ff;
}

.job-view-stage-badges {
    display: flex;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.job-view-stage-badges span {
    border-radius: 999px;
    border: 1px solid rgba(74, 91, 114, 0.78);
    background: rgba(21, 28, 40, 0.82);
    color: #d7e6fb;
    padding: 0.18rem 0.48rem;
    font-size: 0.68rem;
    font-weight: 800;
}

.job-view-stage-note {
    border: 1px solid rgba(58, 71, 92, 0.72);
    border-radius: 10px;
    background: rgba(15, 20, 31, 0.7);
    padding: 0.65rem 0.7rem;
    min-height: 90px;
    color: #edf4ff;
    font-size: 0.86rem;
    line-height: 1.45;
}

.job-view-stage-note a {
    color: #84bcff;
    text-decoration: underline;
}

.job-view-stage-section {
    display: grid;
    gap: 0.42rem;
}

.job-view-stage-section > header {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    color: #bfd0e8;
    font-size: 0.76rem;
    font-weight: 800;
    border-top: 1px solid rgba(59, 73, 96, 0.55);
    padding-top: 0.42rem;
}

.job-view-day-list {
    display: grid;
    gap: 0.35rem;
}

.job-view-day-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 0.45rem;
    align-items: center;
    border: 1px solid rgba(55, 67, 88, 0.72);
    border-radius: 8px;
    background: rgba(15, 19, 29, 0.72);
    padding: 0.38rem 0.45rem;
}

.job-view-day-date {
    color: #d8e4f7;
    font-size: 0.69rem;
    font-weight: 800;
    white-space: nowrap;
}

.job-view-day-main {
    min-width: 0;
    display: grid;
    gap: 0.05rem;
}

.job-view-day-main strong {
    color: #edf5ff;
    font-size: 0.72rem;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.job-view-day-main small {
    color: #90a6c4;
    font-size: 0.64rem;
}

.job-view-day-metrics {
    display: grid;
    gap: 0.08rem;
    text-align: right;
    color: #ccd9ec;
    font-size: 0.64rem;
    font-weight: 700;
}

.job-view-empty {
    border: 1px dashed rgba(74, 92, 118, 0.7);
    border-radius: 8px;
    color: #97adca;
    font-size: 0.75rem;
    text-align: center;
    padding: 0.65rem;
}

.job-view-flow-titleline {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.45rem;
    align-items: start;
}

.job-view-flow-titleline.no-title {
    display: flex;
    justify-content: flex-end;
}

.job-view-flow-titleline strong {
    color: #f0f6ff;
    font-size: 0.83rem;
    line-height: 1.25;
}

.job-view-flow-metricline {
    display: grid;
    gap: 0.08rem;
    text-align: right;
    color: #d0ddee;
    font-size: 0.66rem;
    font-weight: 700;
    white-space: nowrap;
}

.job-view-flow-note {
    color: #dbe8fb;
    font-size: 0.75rem;
    line-height: 1.35;
}

.job-view-flow-note em {
    color: #9eb3d0;
}

.job-view-comments {
    display: grid;
    gap: 0.38rem;
    border-top: 1px solid rgba(59, 73, 96, 0.55);
    padding-top: 0.42rem;
}

.job-view-comments.compact {
    gap: 0.32rem;
    padding-top: 0.35rem;
}

.job-view-comments-toggle {
    border: 1px solid rgba(60, 77, 101, 0.68);
    border-radius: 8px;
    background: rgba(17, 22, 34, 0.6);
    color: #c8d8ef;
    padding: 0.28rem 0.45rem;
    min-height: 30px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.55rem;
    font-size: 0.73rem;
    font-weight: 700;
}

.job-view-comments-toggle:hover,
.job-view-comments-toggle:focus-visible {
    border-color: rgba(108, 132, 166, 0.72);
    color: #e4f0ff;
    outline: none;
}

.job-view-comments-toggle-label {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.job-view-comments-panel {
    display: grid;
    gap: 0.38rem;
}

.job-view-comments-panel.is-collapsed {
    display: none;
}

.job-view-comments-list {
    display: grid;
    gap: 0.34rem;
    margin-left: 0.78rem;
    padding-left: 0.72rem;
    border-left: 1px solid rgba(82, 101, 129, 0.5);
    max-height: none;
    overflow: visible;
    padding-right: 0;
}

.job-view-comments.compact .job-view-comments-list {
    margin-left: 0.62rem;
    padding-left: 0.56rem;
}

.job-view-comment-item {
    border: 1px solid rgba(58, 71, 92, 0.72);
    border-radius: 10px;
    background: rgba(15, 20, 31, 0.7);
    padding: 0.45rem 0.5rem;
    display: grid;
    gap: 0.3rem;
}

.job-view-comment-item.compact {
    padding: 0.38rem 0.42rem;
    border-radius: 9px;
    gap: 0.24rem;
}

.job-view-comment-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.4rem;
}

.job-view-comment-author-wrap {
    display: inline-flex;
    align-items: center;
    gap: 0.38rem;
    min-width: 0;
}

.job-view-comment-author-wrap .job-view-avatar.has-comment-avatar {
    width: 24px;
    height: 24px;
    flex: 0 0 24px;
    font-size: 0.62rem;
}

.job-view-comment-author-meta {
    min-width: 0;
    display: grid;
    gap: 0.05rem;
}

.job-view-comment-author-meta strong {
    color: #eaf3ff;
    font-size: 0.68rem;
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.job-view-comment-author-meta small {
    color: #96abc8;
    font-size: 0.61rem;
    line-height: 1.1;
}

.job-view-comment-reactions {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
}

.job-view-comment-reaction-btn {
    width: 28px;
    height: 24px;
    border-radius: 7px;
    border: 1px solid rgba(68, 84, 109, 0.72);
    background: rgba(19, 25, 37, 0.72);
    color: #9ab1cf;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    line-height: 1;
    opacity: 0.5;
    transition: opacity 0.16s ease, border-color 0.16s ease, background-color 0.16s ease, color 0.16s ease;
}

.job-view-comment-reaction-btn.compact {
    width: 24px;
    height: 21px;
    border-radius: 6px;
    font-size: 0.66rem;
}

.job-view-comment-reaction-btn:hover:not(:disabled),
.job-view-comment-reaction-btn:focus-visible:not(:disabled) {
    border-color: rgba(109, 133, 168, 0.82);
    color: #e6f2ff;
    opacity: 0.72;
    outline: none;
}

.job-view-comment-reaction-btn.is-active {
    border-color: rgba(129, 165, 211, 0.92);
    color: #e6f2ff;
    background: rgba(27, 37, 54, 0.88);
    opacity: 1;
}

.job-view-comment-reaction-btn.is-active.is-like {
    border-color: #35b86a;
    background: rgba(27, 93, 60, 0.72);
    color: #ddffee;
}

.job-view-comment-reaction-btn.is-active.is-dislike {
    border-color: #d64a5c;
    background: rgba(107, 34, 45, 0.72);
    color: #ffe6eb;
}

.job-view-comment-reaction-btn:disabled {
    opacity: 0.34;
    cursor: not-allowed;
}

.job-view-comment-delete-btn {
    width: 28px;
    height: 24px;
    border-radius: 7px;
    border: 1px solid rgba(135, 72, 72, 0.82);
    background: rgba(42, 20, 20, 0.68);
    color: #f0b7b7;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    line-height: 1;
}

.job-view-comment-delete-btn.compact {
    width: 24px;
    height: 21px;
    border-radius: 6px;
    font-size: 0.66rem;
}

.job-view-comment-delete-btn:hover:not(:disabled),
.job-view-comment-delete-btn:focus-visible:not(:disabled) {
    border-color: rgba(214, 81, 81, 0.92);
    background: rgba(68, 28, 28, 0.8);
    color: #ffe7e7;
    outline: none;
}

.job-view-comment-delete-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.job-view-comment-text {
    color: #e3eeff;
    font-size: 0.73rem;
    line-height: 1.34;
    word-break: break-word;
}

.job-view-comment-text a {
    color: #8fc9ff;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
    word-break: break-all;
}

.job-view-comment-text a:hover,
.job-view-comment-text a:focus-visible {
    color: #c2e1ff;
}

.job-view-comment-item.compact .job-view-comment-text {
    font-size: 0.7rem;
}

.job-view-comments-compose {
    display: grid;
    gap: 0.28rem;
}

.job-view-comments-quick {
    display: flex;
    align-items: flex-start;
    flex-wrap: nowrap;
    gap: 0.26rem;
    min-width: 0;
}

.job-view-comments-quick-main {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.26rem;
    flex: 0 1 auto;
    max-width: 100%;
    min-width: 0;
}

.job-view-comments-quick-more {
    position: relative;
    display: inline-flex;
    align-items: center;
    flex: 0 0 auto;
    margin-left: auto;
}

.job-view-comment-emoji-picker {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.job-view-comment-emoji-toggle {
    width: 30px;
    height: 24px;
    border: 1px solid var(--jv-subpanel-border, var(--surface-subpanel-border));
    border-radius: 999px;
    background: var(--jv-widget-bg, var(--surface-subpanel-bg));
    color: var(--jv-text-secondary, var(--text-secondary));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.78rem;
    line-height: 1;
    transition: border-color 0.16s ease, background-color 0.16s ease, color 0.16s ease, opacity 0.16s ease;
}

.job-view-comment-emoji-toggle-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    line-height: 1;
}

.job-view-comment-emoji-toggle:hover:not(:disabled),
.job-view-comment-emoji-toggle:focus-visible:not(:disabled),
.job-view-comment-emoji-picker.is-open .job-view-comment-emoji-toggle {
    border-color: var(--jv-card-hover, var(--surface-card-hover-border));
    background: color-mix(in srgb, var(--jv-widget-bg, var(--surface-subpanel-bg)) 70%, var(--jv-accent, var(--accent)) 30%);
    color: var(--jv-text-primary, var(--text-primary));
    outline: none;
}

.job-view-comment-emoji-toggle:disabled,
.job-view-comment-emoji-picker.is-disabled .job-view-comment-emoji-toggle {
    opacity: 0.55;
    cursor: not-allowed;
}

.job-view-comment-emoji-popup {
    position: absolute;
    left: 0;
    bottom: calc(100% + 0.28rem);
    display: none;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.2rem;
    padding: 0.32rem;
    border-radius: 10px;
    border: 1px solid var(--jv-subpanel-border, var(--surface-subpanel-border));
    background: var(--jv-subpanel-bg, var(--surface-subpanel-bg));
    box-shadow: 0 8px 22px color-mix(in srgb, var(--bg-page, #000000) 56%, transparent);
    min-width: 178px;
    z-index: 14;
}

.job-view-comment-emoji-picker.is-open .job-view-comment-emoji-popup {
    display: grid;
}

.job-view-comment-emoji-option {
    width: 30px;
    height: 28px;
    border-radius: 8px;
    border: 1px solid var(--jv-subpanel-border, var(--surface-subpanel-border));
    background: var(--jv-widget-bg, var(--surface-widget-bg));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    line-height: 1;
    transition: border-color 0.16s ease, background-color 0.16s ease, transform 0.16s ease, opacity 0.16s ease;
}

.job-view-comment-emoji-option:hover:not(:disabled),
.job-view-comment-emoji-option:focus-visible:not(:disabled) {
    border-color: var(--jv-card-hover, var(--surface-card-hover-border));
    background: color-mix(in srgb, var(--jv-widget-bg, var(--surface-widget-bg)) 68%, var(--jv-accent, var(--accent)) 32%);
    transform: translateY(-1px);
    outline: none;
}

.job-view-comment-emoji-option:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.job-view-comment-quick-btn,
.job-view-comment-quick-more-toggle {
    border: 1px solid var(--jv-subpanel-border, var(--surface-subpanel-border));
    border-radius: 999px;
    background: var(--jv-widget-bg, var(--surface-widget-bg));
    color: var(--jv-text-secondary, var(--text-secondary));
    font-size: 0.62rem;
    font-weight: 600;
    line-height: 1;
    white-space: nowrap;
    padding: 0.21rem 0.48rem;
    transition: border-color 0.16s ease, background-color 0.16s ease, color 0.16s ease, opacity 0.16s ease;
}

.job-view-comment-quick-btn:hover:not(:disabled),
.job-view-comment-quick-btn:focus-visible:not(:disabled),
.job-view-comment-quick-more-toggle:hover:not(:disabled),
.job-view-comment-quick-more-toggle:focus-visible:not(:disabled) {
    border-color: var(--jv-card-hover, var(--surface-card-hover-border));
    background: color-mix(in srgb, var(--jv-widget-bg, var(--surface-widget-bg)) 68%, var(--jv-accent, var(--accent)) 32%);
    color: var(--jv-text-primary, var(--text-primary));
    outline: none;
}

.job-view-comment-quick-btn:disabled,
.job-view-comment-quick-more-toggle:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.job-view-comments-quick-overflow {
    position: absolute;
    right: 0;
    top: auto;
    bottom: calc(100% + 0.28rem);
    display: none;
    align-items: center;
    flex-wrap: nowrap;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.26rem;
    padding: 0.34rem;
    border-radius: 10px;
    border: 1px solid var(--jv-subpanel-border, var(--surface-subpanel-border));
    background: color-mix(in srgb, var(--bg-card, #1a212b) 50%, transparent);
    box-shadow: 0 8px 22px color-mix(in srgb, var(--bg-page, #000000) 56%, transparent);
    width: fit-content;
    min-width: fit-content;
    max-width: calc(100vw - 72px);
    z-index: 14;
}

.job-view-comments-quick-more:hover .job-view-comments-quick-overflow,
.job-view-comments-quick-more:focus-within .job-view-comments-quick-overflow {
    display: flex;
}

.job-view-comments-compose .job-view-comments-input {
    min-height: 58px;
    resize: vertical;
    font-size: 0.74rem;
}

.job-view-comments-compose .job-view-comments-input[contenteditable="true"] {
    resize: none;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    line-height: 1.35;
}

.job-view-comments-compose .job-view-comments-input[contenteditable="true"]:empty::before {
    content: attr(data-placeholder);
    color: #758aa8;
    pointer-events: none;
}

.job-view-comments-compose .job-view-comments-input.is-disabled {
    opacity: 0.75;
    cursor: not-allowed;
}

.job-view-comments.compact .job-view-comments-compose .job-view-comments-input {
    min-height: 46px;
}

.job-view-comments-compose-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.35rem;
}

.job-view-comments-compose-hint {
    color: #90a6c4;
    font-size: 0.62rem;
}

.job-view-flow-attach-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.35rem 0.5rem;
    flex-wrap: wrap;
}

.job-view-flow-zip-btn {
    white-space: nowrap;
    padding: 0.2rem 0.5rem;
    line-height: 1.15;
}

.job-view-flow-attach .attachment-thumb-list.compact {
    grid-template-columns: repeat(auto-fill, minmax(108px, 1fr));
}

/* Keep timeline cards readable in wide layouts; prevent collapsed compact bodies. */
#jobViewPage .job-view-flow-timeline .job-view-flow-item .job-view-stage-body.compact {
    display: grid;
    grid-template-columns: minmax(128px, 0.25fr) minmax(0, 1fr);
    align-items: start;
    min-height: 92px;
}

#jobViewPage .job-view-flow-timeline .job-view-flow-item .job-view-stage-content {
    align-content: start;
}

.job-view-page,
.job-view-shell,
.job-view-main-layout,
.job-view-left-column,
.job-view-right-column,
.job-view-stage-detail,
.job-view-flow-item,
.job-view-stage-body,
.job-view-stage-content {
    min-width: 0;
    max-width: 100%;
}

.job-view-page {
    height: 100%;
    min-height: 0;
    overflow: hidden;
}

.app-main:has(#jobViewPage),
.app-content:has(#jobViewPage) {
    height: var(--app-viewport-100);
    min-height: 0;
    overflow: hidden;
}

.app-main:has(#projectDetailPage),
.app-content:has(#projectDetailPage) {
    height: var(--app-viewport-100);
    min-height: 0;
    overflow: hidden;
}

body.job-view-active {
    overflow: hidden;
}

body.project-detail-active {
    overflow: hidden;
}

body.job-view-active .app-main,
body.job-view-active .app-content {
    height: var(--app-viewport-100);
    min-height: 0;
    overflow: hidden;
}

body.project-detail-active .app-main,
body.project-detail-active .app-content {
    height: var(--app-viewport-100);
    min-height: 0;
    overflow: hidden;
}

.app-content:has(#jobViewPage) {
    box-sizing: border-box;
    overscroll-behavior: none;
}

.app-content:has(#projectDetailPage) {
    box-sizing: border-box;
    overscroll-behavior: none;
    padding-bottom: 0.35rem;
}

body.job-view-active .app-content {
    box-sizing: border-box;
    overscroll-behavior: none;
}

body.project-detail-active .app-content {
    box-sizing: border-box;
    overscroll-behavior: none;
    padding-bottom: 0.35rem;
}

#jobViewPage .job-view-shell {
    height: 100%;
    min-height: 0;
    grid-template-rows: auto minmax(0, 1fr);
    overflow: hidden;
}

#jobViewPage .job-view-main-layout {
    flex-wrap: nowrap;
    align-items: stretch;
    min-height: 0;
    height: 100%;
    overflow: hidden;
}

#jobViewPage .job-view-left-column,
#jobViewPage .job-view-right-column {
    display: flex;
    min-height: 0;
    height: 100%;
    overflow: hidden;
}

.job-view-detail-card,
.job-view-flow-card {
    min-height: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    width: 100%;
    overflow: hidden;
}

#jobViewPage .job-view-detail-card .board-card-body {
    flex: 1 1 auto;
    min-height: 0;
    grid-template-rows: auto minmax(0, 1fr) auto;
    align-content: stretch;
    overflow: hidden;
}

#jobViewPage #jobViewSelectedStage {
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

#jobViewPage #jobViewSelectedStage .job-view-stage-detail {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

#jobViewPage #jobViewSelectedStage .job-view-stage-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    overscroll-behavior: contain;
    padding-right: 0.2rem;
}

#jobViewPage .job-view-flow-card .board-card-body {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

#jobViewPage .job-view-flow-timeline {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
    overflow: auto;
    overscroll-behavior: contain;
    align-items: stretch;
    padding-right: 0.35rem;
}

.job-view-stage-context,
.job-view-stage-title,
.job-view-stage-note,
.job-view-flow-note,
.job-view-flow-titleline strong {
    overflow-wrap: anywhere;
    word-break: break-word;
}

@media (max-width: 1120px) {
    .job-view-topbar {
        grid-template-columns: 1fr;
    }

    .job-view-actions,
    .job-view-heading,
    .job-view-header-metrics {
        grid-column: 1;
    }

    .job-view-heading {
        justify-self: stretch;
        width: 100%;
        text-align: left;
    }

    .job-view-header-metrics {
        justify-self: stretch;
        width: 100%;
    }

    .job-view-flow-card .board-card-header {
        grid-template-columns: 1fr;
    }

    .job-view-flow-filters {
        grid-template-columns: 1fr;
        justify-self: stretch;
        width: 100%;
    }
}

@media (max-width: 1440px) {
    .job-view-main-layout {
        grid-template-columns: 1fr;
    }

    .job-view-flow-timeline {
        max-height: none;
    }

    .job-view-summary-tiles {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (hover: none), (pointer: coarse) {
    .job-view-page {
        height: calc(var(--app-viewport-100) - (2rem + var(--app-header-expanded-height)));
    }
}

@media (max-width: 992px) {
    body.job-view-active {
        overflow: auto;
    }

    .job-view-page {
        height: auto;
        overflow: visible;
    }

    .app-main:has(#jobViewPage),
    .app-content:has(#jobViewPage) {
        height: auto;
        min-height: 0;
        overflow: visible;
    }

    body.job-view-active .app-main,
    body.job-view-active .app-content {
        height: auto;
        min-height: 0;
        overflow: visible;
    }

    #jobViewPage .job-view-shell,
    #jobViewPage .job-view-main-layout,
    #jobViewPage .job-view-left-column,
    #jobViewPage .job-view-right-column,
    #jobViewPage .job-view-detail-card,
    #jobViewPage .job-view-flow-card,
    #jobViewPage .job-view-detail-card .board-card-body,
    #jobViewPage .job-view-flow-card .board-card-body,
    #jobViewPage .job-view-flow-timeline {
        overflow: visible;
    }

    #jobViewPage .job-view-main-layout {
        flex-wrap: wrap;
    }

    #jobViewPage .job-view-flow-card .board-card-body {
        display: block;
    }

    .job-view-topbar {
        grid-template-columns: 1fr;
    }

    .job-view-actions,
    .job-view-heading,
    .job-view-header-metrics {
        grid-column: 1;
    }

    .job-view-heading {
        justify-self: stretch;
        width: 100%;
        text-align: left;
    }

    .job-view-header-metrics {
        justify-self: stretch;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        min-width: 0;
    }

    .job-view-chip-row {
        grid-template-columns: 1fr;
    }

    .job-view-flow-card .board-card-header {
        grid-template-columns: 1fr;
    }

    .job-view-flow-filters {
        grid-template-columns: 1fr;
        justify-self: stretch;
        width: 100%;
    }

    .job-view-stage-body,
    .job-view-stage-body.compact {
        grid-template-columns: 1fr;
    }

    .job-view-rail {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.35rem 0.55rem;
        align-items: center;
    }

    .job-view-rail-line {
        display: none;
    }

    .job-view-rail-time {
        grid-template-columns: auto 1fr;
    }
}

@media (max-width: 640px) {
    .job-view-summary-tiles {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .job-view-header-metrics {
        grid-template-columns: 1fr;
    }

    .job-view-stage-top {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .job-view-stage-top-meta {
        justify-self: start;
        align-items: flex-start;
        flex-direction: column;
    }

    .job-view-stage-top-date {
        justify-self: start;
        text-align: left;
        margin-bottom: 0;
    }

    .job-view-stage-top-actions {
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .job-view-day-row {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .job-view-day-metrics {
        text-align: left;
        grid-auto-flow: column;
        justify-content: start;
        gap: 0.5rem;
    }

    .job-view-flow-titleline {
        grid-template-columns: 1fr;
    }

    .job-view-flow-metricline {
        text-align: left;
        grid-auto-flow: column;
        justify-content: start;
        gap: 0.5rem;
    }

    .app-shell.is-embedded .app-main,
    .app-shell.is-embedded .app-content {
        height: 100%;
        min-height: 0;
        overflow: hidden;
    }

    .app-shell.is-embedded #jobViewPage {
        height: 100%;
        min-height: 0;
        overflow: hidden;
    }

    .app-shell.is-embedded #jobViewPage .job-view-shell,
    .app-shell.is-embedded #jobViewPage .job-view-main-layout,
    .app-shell.is-embedded #jobViewPage .job-view-left-column,
    .app-shell.is-embedded #jobViewPage .job-view-right-column,
    .app-shell.is-embedded #jobViewPage .job-view-detail-card,
    .app-shell.is-embedded #jobViewPage .job-view-flow-card,
    .app-shell.is-embedded #jobViewPage .job-view-detail-card .board-card-body,
    .app-shell.is-embedded #jobViewPage .job-view-flow-card .board-card-body {
        height: 100%;
        min-height: 0;
        overflow: hidden;
    }

    .app-shell.is-embedded #jobViewPage .job-view-main-layout {
        flex-wrap: nowrap;
    }

    .app-shell.is-embedded #jobViewPage .job-view-flow-card .board-card-body {
        display: flex;
        flex-direction: column;
    }

    .app-shell.is-embedded #jobViewPage .job-view-flow-timeline {
        overflow: auto;
    }
}

.job-view-shell {
    --jv-accent: var(--accent, #f1a35d);
    --jv-accent-soft: var(--accent-soft, #2c1f17);
    --jv-text-primary: var(--text-primary, #edf4ff);
    --jv-text-secondary: var(--text-secondary, #b8bfd1);
    --jv-panel-bg: var(--surface-panel-bg, linear-gradient(180deg, rgba(18, 22, 31, 0.95) 0%, rgba(12, 15, 23, 0.97) 100%));
    --jv-panel-border: var(--surface-panel-border, var(--border-color, #4d5f79));
    --jv-panel-header-border: var(--surface-panel-header-border, var(--border-color, #657a98));
    --jv-card-bg: var(--surface-card-bg, linear-gradient(180deg, rgba(16, 20, 30, 0.96) 0%, rgba(11, 14, 22, 0.96) 100%));
    --jv-card-border: var(--surface-card-border, var(--border-color, #50647f));
    --jv-card-hover: var(--surface-card-hover-border, var(--accent, #7ea0cf));
    --jv-widget-bg: var(--surface-widget-bg, rgba(17, 22, 32, 0.82));
    --jv-subpanel-bg: var(--surface-subpanel-bg, rgba(14, 18, 27, 0.82));
    --jv-subpanel-border: var(--surface-subpanel-border, var(--border-color, #4f627d));
    --jv-empty-bg: var(--surface-empty-bg, rgba(255, 255, 255, 0.02));
    --jv-empty-border: var(--surface-empty-border, var(--border-color, #607694));
    --jv-empty-text: var(--surface-empty-text, var(--text-secondary, #97adca));
    --jv-avatar-bg: var(--surface-avatar-bg, #1a2432);
    --jv-avatar-border: var(--surface-avatar-border, var(--border-color, #738aa8));
    --jv-shadow: var(--shadow, 0 12px 28px rgba(7, 10, 16, 0.32));
}

.job-view-attachment-item:hover {
    border-color: var(--jv-card-hover);
    background: var(--jv-subpanel-bg);
}

.job-view-topbar {
    border-color: var(--jv-panel-border);
    background:
        linear-gradient(90deg, color-mix(in srgb, var(--jv-accent-soft) 75%, transparent) 0%, transparent 38%),
        var(--jv-panel-bg);
    box-shadow: var(--jv-shadow);
}

.job-view-kicker {
    color: var(--jv-accent);
}

.job-view-heading h1 {
    color: var(--jv-text-primary);
}

.job-view-heading-meta {
    color: var(--jv-text-secondary);
}

.job-view-header-metric {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-widget-bg);
}

.job-view-header-metric span {
    color: var(--jv-text-secondary);
}

.job-view-header-metric strong {
    color: var(--jv-text-primary);
}

.job-view-chip {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-widget-bg);
    color: var(--jv-text-primary);
}

.job-view-chip-logo {
    background: var(--jv-subpanel-bg);
    color: var(--jv-text-secondary);
    border-color: var(--jv-subpanel-border);
}

.job-view-chip-main {
    background: linear-gradient(180deg, color-mix(in srgb, var(--jv-panel-bg) 70%, var(--jv-accent-soft) 30%) 0%, var(--jv-subpanel-bg) 100%);
    border-color: var(--jv-panel-header-border);
    color: var(--jv-text-primary);
}

.job-view-summary-strip {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-widget-bg);
    color: var(--jv-text-primary);
}

.job-view-summary-strip i {
    color: var(--jv-accent);
}

.job-view-summary-box {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-subpanel-bg);
}

.job-view-summary-box small {
    color: var(--jv-text-secondary);
}

.job-view-summary-box strong {
    color: var(--jv-text-primary);
}

.job-view-flow-header-title small {
    color: var(--jv-text-secondary);
}

.job-view-stage-detail,
.job-view-flow-item {
    border-color: var(--jv-card-border);
    background: var(--jv-card-bg);
}

.job-view-flow-item:hover {
    border-color: var(--jv-card-hover);
    box-shadow: var(--jv-shadow);
}

.job-view-flow-item::after {
    background: conic-gradient(
        from 0deg,
        color-mix(in srgb, var(--jv-accent) 90%, white 10%) 0deg,
        color-mix(in srgb, var(--jv-card-hover) 45%, transparent) 70deg,
        color-mix(in srgb, var(--jv-accent) 82%, transparent) 155deg,
        color-mix(in srgb, var(--jv-panel-header-border) 55%, var(--jv-accent) 45%) 240deg,
        color-mix(in srgb, var(--jv-accent) 90%, white 10%) 360deg
    );
}

.job-view-flow-item.is-selected {
    border-color: var(--jv-accent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--jv-accent) 28%, transparent), var(--jv-shadow);
}

@media (prefers-reduced-motion: reduce) {
    .drop-lane.drag-over::after,
    .job-card:hover::after,
    .job-card.is-selected::after,
    .job-card.active::after,
    .job-card:focus-visible::after,
    .job-view-flow-item:hover::after,
    .job-view-flow-item:focus-visible::after {
        animation: none;
    }

    .job-context-menu[aria-hidden="false"],
    .job-context-menu[aria-hidden="false"] button {
        animation: none;
    }
}

.job-view-stage-pill {
    background: linear-gradient(180deg, color-mix(in srgb, var(--jv-panel-header-border) 55%, var(--jv-accent) 45%) 0%, var(--jv-panel-header-border) 100%);
    color: var(--jv-text-primary);
}

.job-view-stage-top small,
.job-view-stage-top span {
    color: var(--jv-text-secondary);
}

.job-view-stage-body {
    background: var(--jv-widget-bg);
    border-color: var(--jv-subpanel-border);
}

.job-view-rail {
    background: var(--jv-subpanel-bg);
    border-color: var(--jv-subpanel-border);
}

.job-view-avatar {
    border-color: var(--jv-avatar-border);
    background: linear-gradient(180deg, color-mix(in srgb, var(--jv-avatar-bg) 82%, white 18%) 0%, var(--jv-avatar-bg) 100%);
    color: var(--jv-text-primary);
}

.job-view-avatar.muted {
    background: color-mix(in srgb, var(--jv-avatar-bg) 70%, #666 30%);
    border-color: color-mix(in srgb, var(--jv-avatar-border) 70%, #777 30%);
}

.job-view-rail-person small,
.job-view-stage-context,
.job-view-day-main small,
.job-view-flow-header-title small,
.job-view-flow-note em {
    color: var(--jv-text-secondary);
}

.job-view-rail-person strong,
.job-view-stage-title,
.job-view-day-main strong,
.job-view-flow-titleline strong {
    color: var(--jv-text-primary);
}

.job-view-rail-line {
    background: color-mix(in srgb, var(--jv-text-secondary) 40%, transparent);
}

.job-view-rail-time {
    color: var(--jv-text-secondary);
}

.job-view-rail-time i {
    color: var(--jv-accent);
}

.job-view-rail-status {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-widget-bg);
    color: var(--jv-text-primary);
}

.job-view-rail-status.job-view-effort-pending {
    border-color: color-mix(in srgb, var(--warning) 65%, var(--jv-subpanel-border) 35%);
    background: color-mix(in srgb, var(--warning) 20%, var(--jv-widget-bg) 80%);
    color: color-mix(in srgb, var(--warning) 88%, var(--jv-text-primary) 12%);
}

.job-view-stage-badges span {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-subpanel-bg);
    color: var(--jv-text-primary);
}

.job-view-stage-note {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-subpanel-bg);
    color: var(--jv-text-primary);
}

.job-view-stage-note a {
    color: var(--jv-accent);
}

.job-view-comments {
    border-top-color: var(--jv-subpanel-border);
}

.job-view-comments-list {
    border-left-color: color-mix(in srgb, var(--jv-subpanel-border) 80%, transparent 20%);
}

.job-view-comments-toggle {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-widget-bg);
    color: var(--jv-text-secondary);
}

.job-view-comments-toggle:hover,
.job-view-comments-toggle:focus-visible {
    border-color: var(--jv-card-hover);
    color: var(--jv-text-primary);
}

.job-view-comment-item {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-subpanel-bg);
}

.job-view-comment-author-meta strong,
.job-view-comment-text {
    color: var(--jv-text-primary);
}

.job-view-comment-text a {
    color: var(--jv-accent);
}

.job-view-comment-author-meta small,
.job-view-comments-compose-hint {
    color: var(--jv-text-secondary);
}

.job-view-comment-emoji-toggle {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-widget-bg);
    color: var(--jv-text-secondary);
}

.job-view-comment-emoji-toggle:hover:not(:disabled),
.job-view-comment-emoji-toggle:focus-visible:not(:disabled),
.job-view-comment-emoji-picker.is-open .job-view-comment-emoji-toggle {
    border-color: var(--jv-card-hover);
    background: color-mix(in srgb, var(--jv-widget-bg) 70%, var(--jv-accent) 30%);
    color: var(--jv-text-primary);
}

.job-view-comment-quick-btn,
.job-view-comment-quick-more-toggle {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-widget-bg);
    color: var(--jv-text-secondary);
}

.job-view-comment-quick-btn:hover:not(:disabled),
.job-view-comment-quick-btn:focus-visible:not(:disabled),
.job-view-comment-quick-more-toggle:hover:not(:disabled),
.job-view-comment-quick-more-toggle:focus-visible:not(:disabled) {
    border-color: var(--jv-card-hover);
    background: color-mix(in srgb, var(--jv-widget-bg) 70%, var(--jv-accent) 30%);
    color: var(--jv-text-primary);
}

.job-view-comments-quick-overflow {
    border-color: var(--jv-subpanel-border);
    background: color-mix(in srgb, var(--bg-card) 50%, transparent);
}

.job-view-comment-reaction-btn {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-widget-bg);
    color: var(--jv-text-secondary);
    opacity: 0.5;
}

.job-view-comment-reaction-btn:hover:not(:disabled),
.job-view-comment-reaction-btn:focus-visible:not(:disabled) {
    border-color: var(--jv-card-hover);
    color: var(--jv-text-primary);
    opacity: 0.72;
}

.job-view-comment-reaction-btn.is-active {
    border-color: var(--jv-accent);
    background: color-mix(in srgb, var(--jv-widget-bg) 68%, var(--jv-accent) 32%);
    color: var(--jv-text-primary);
    opacity: 1;
}

.job-view-comment-reaction-btn.is-active.is-like {
    border-color: #35b86a;
    background: color-mix(in srgb, var(--jv-widget-bg) 72%, #2a8f60 28%);
    color: #ddffee;
}

.job-view-comment-reaction-btn.is-active.is-dislike {
    border-color: #d64a5c;
    background: color-mix(in srgb, var(--jv-widget-bg) 72%, #8b3341 28%);
    color: #ffe6eb;
}

.job-view-comment-delete-btn {
    border-color: color-mix(in srgb, var(--jv-subpanel-border) 70%, #d65f5f 30%);
    background: var(--jv-widget-bg);
    color: color-mix(in srgb, var(--jv-text-secondary) 55%, #ffb2b2 45%);
}

.job-view-comment-delete-btn:hover:not(:disabled),
.job-view-comment-delete-btn:focus-visible:not(:disabled) {
    border-color: #d65f5f;
    background: color-mix(in srgb, var(--jv-widget-bg) 65%, #7c2c2c 35%);
    color: #ffe6e6;
}

.job-view-stage-section > header {
    color: var(--jv-text-secondary);
    border-top-color: var(--jv-subpanel-border);
}

.job-view-day-row {
    border-color: var(--jv-subpanel-border);
    background: var(--jv-subpanel-bg);
}

.job-view-day-date,
.job-view-day-metrics,
.job-view-flow-metricline,
.job-view-flow-note {
    color: var(--jv-text-primary);
}

.job-view-empty {
    border-color: var(--jv-empty-border);
    background: var(--jv-empty-bg);
    color: var(--jv-empty-text);
}

.job-view-flow-filters .form-control,
.job-view-flow-filters .form-select {
    background-color: var(--jv-subpanel-bg);
    border-color: var(--jv-subpanel-border);
    color: var(--jv-text-primary);
}

.job-view-flow-filters .form-control::placeholder {
    color: color-mix(in srgb, var(--jv-text-secondary) 80%, transparent);
}

.job-view-flow-timeline::-webkit-scrollbar-thumb {
    background: var(--surface-scrollbar-thumb, var(--jv-panel-border));
}

.management-page {
    display: grid;
    gap: 0.85rem;
}

html:has(#employeeManagementPage) {
    scrollbar-gutter: stable both-edges;
}

.management-page .board-card {
    min-height: 0;
}

.management-page .board-card-body {
    min-height: 0;
}

.management-page .board-card-header .btn.btn-success,
.management-page .board-card-header .btn.btn-primary {
    --bs-btn-bg: var(--accent);
    --bs-btn-border-color: var(--accent);
    --bs-btn-hover-bg: var(--accent);
    --bs-btn-hover-border-color: var(--accent);
    --bs-btn-active-bg: var(--accent);
    --bs-btn-active-border-color: var(--accent);
    --bs-btn-disabled-bg: var(--accent);
    --bs-btn-disabled-border-color: var(--accent);
    --bs-btn-color: #fff;
    --bs-btn-hover-color: #fff;
    --bs-btn-active-color: #fff;
    --bs-btn-disabled-color: #fff;
    background-color: var(--accent) !important;
    border-color: var(--accent) !important;
    color: #fff !important;
}

.management-page .board-card-header .btn.btn-success:hover,
.management-page .board-card-header .btn.btn-success:focus,
.management-page .board-card-header .btn.btn-primary:hover,
.management-page .board-card-header .btn.btn-primary:focus {
    background-color: var(--accent) !important;
    border-color: var(--accent) !important;
    color: #fff !important;
    filter: brightness(0.94);
}

.management-page .table th,
.management-page .table td {
    border-color: var(--surface-panel-border);
    font-size: 0.86rem;
    vertical-align: middle;
}

.management-page .management-table {
    margin-bottom: 0;
    color: var(--text-primary);
    --bs-table-color: var(--text-primary);
    --bs-table-bg: transparent;
    --bs-table-border-color: var(--surface-panel-border);
    --bs-table-striped-color: var(--text-primary);
    --bs-table-striped-bg: color-mix(in srgb, var(--surface-subpanel-bg) 55%, transparent);
    --bs-table-hover-color: var(--text-primary);
    --bs-table-hover-bg: color-mix(in srgb, var(--accent) 8%, var(--surface-subpanel-bg) 92%);
    --bs-table-active-color: var(--text-primary);
    --bs-table-active-bg: color-mix(in srgb, var(--accent) 10%, var(--surface-subpanel-bg) 90%);
}

.management-page .management-table > thead > tr > th {
    background: color-mix(in srgb, var(--surface-subpanel-bg) 80%, transparent);
    color: var(--surface-panel-header-text);
    font-weight: 700;
    border-bottom-color: var(--surface-panel-header-border);
}

.management-page .management-table > tbody > tr > td {
    background: transparent;
    color: var(--text-primary);
}

.management-page .management-table.table-hover > tbody > tr:hover > * {
    color: var(--text-primary);
    background: color-mix(in srgb, var(--accent) 7%, var(--surface-lane-bg) 93%);
}

.management-page .board-card-header .form-select,
.management-page .board-card-body .form-select,
.management-page .board-card-body .form-control {
    background: var(--surface-subpanel-bg);
    border-color: var(--surface-subpanel-border);
    color: var(--text-primary);
}

.management-page .board-card-header .form-select:focus,
.management-page .board-card-body .form-select:focus,
.management-page .board-card-body .form-control:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 0.14rem color-mix(in srgb, var(--accent) 18%, transparent);
}

.management-page .board-card-header .form-select option,
.management-page .board-card-body .form-select option {
    color: var(--text-primary);
    background: color-mix(in srgb, var(--surface-panel-bg) 96%, transparent);
}

.management-page .badge.text-bg-success,
.management-page .badge.text-bg-primary {
    background: color-mix(in srgb, var(--accent) 18%, var(--surface-subpanel-bg) 82%) !important;
    color: color-mix(in srgb, var(--accent) 82%, var(--text-primary) 18%) !important;
    border: 1px solid color-mix(in srgb, var(--accent) 32%, transparent);
}

.management-page .badge.text-bg-secondary {
    background: color-mix(in srgb, var(--surface-subpanel-bg) 88%, var(--surface-empty-bg) 12%) !important;
    color: var(--text-secondary) !important;
    border: 1px solid color-mix(in srgb, var(--surface-panel-border) 92%, transparent);
}

.management-page .badge.text-bg-dark {
    background: color-mix(in srgb, var(--surface-subpanel-bg) 90%, transparent) !important;
    color: var(--text-primary) !important;
    border: 1px solid color-mix(in srgb, var(--surface-subpanel-border) 88%, transparent);
}

@media (min-width: 992px) {
    #employeeManagementPage .table-responsive {
        overflow-x: visible;
        overflow-y: visible;
    }
}

.management-avatar {
    width: 38px;
    height: 38px;
    border-radius: 999px;
    object-fit: cover;
    border: 1px solid var(--surface-avatar-border);
    background: var(--surface-avatar-bg);
}

.management-brand-logo {
    width: 56px;
    height: 40px;
    object-fit: contain;
    display: block;
    border-radius: 8px;
    border: 1px solid var(--surface-subpanel-border);
    background: color-mix(in srgb, var(--surface-subpanel-bg) 92%, transparent);
    padding: 0.2rem;
}

.management-logo-placeholder {
    width: 56px;
    height: 40px;
    border-radius: 8px;
    border: 1px dashed var(--surface-empty-border);
    color: var(--surface-empty-text);
    background: color-mix(in srgb, var(--surface-empty-bg) 72%, transparent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.78rem;
    font-weight: 700;
}

.planning-context-date-wrap {
    border-top: 1px solid var(--surface-subpanel-border);
    margin-top: 0.25rem;
    padding: 0.45rem 0.35rem 0.2rem;
    display: grid;
    gap: 0.35rem;
}

.planning-context-date-wrap .form-control {
    min-height: 32px;
    font-size: 0.8rem;
}

.planning-context-date-wrap button {
    background: var(--surface-lane-bg, rgba(22, 28, 36, 0.94));
    color: var(--text-primary, #d4e2f6);
    border: 1px solid var(--surface-subpanel-border, var(--surface-panel-border, #364a63));
}

.planning-context-date-wrap button:hover,
.planning-context-date-wrap button:focus-visible {
    background: var(--accent-soft, rgba(15, 47, 82, 0.45));
    color: var(--text-primary, #f8fbff);
    border-color: var(--accent, #2dd46f);
    outline: none;
}

#planningContextMenu {
    width: min(280px, calc(100vw - 16px));
    min-width: 240px;
    max-width: calc(100vw - 16px);
}

#planningContextMenu button {
    font-size: 0.82rem;
    line-height: 1.2;
    padding: 0.5rem 0.55rem;
    white-space: normal;
    word-break: break-word;
}

#planningContextMenu .planning-context-date-wrap {
    min-width: 0;
    padding-left: 0.25rem;
    padding-right: 0.25rem;
}

#planningContextMenu .planning-context-date-wrap .form-control,
#planningContextMenu .planning-context-date-wrap button {
    width: 100%;
    min-width: 0;
}

.department-cards-grid {
    display: grid;
    gap: 0.85rem;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

.department-card {
    min-height: 0;
}

.department-card.is-passive {
    opacity: 0.82;
}

.department-card-header {
    align-items: flex-start;
}

.department-card-meta {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
}

.department-card-body {
    min-height: 130px;
}

.department-member-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.48rem;
}

.department-member-item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0.5rem;
    align-items: center;
    border: 1px solid var(--surface-subpanel-border);
    border-radius: 10px;
    background: color-mix(in srgb, var(--surface-subpanel-bg) 92%, transparent);
    padding: 0.5rem 0.55rem;
}

.department-member-info {
    display: grid;
    min-width: 0;
}

.department-member-profile {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    align-items: center;
    gap: 0.55rem;
    min-width: 0;
}

.department-member-avatar {
    width: 34px;
    height: 34px;
    border-radius: 999px;
    object-fit: cover;
    border: 1px solid var(--surface-avatar-border);
    background: var(--surface-avatar-bg);
    display: block;
}

.department-member-info strong {
    font-size: 0.86rem;
}

.department-member-info small {
    color: var(--text-secondary);
    font-size: 0.74rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.department-member-actions {
    display: inline-flex;
    gap: 0.3rem;
}

.department-member-actions .btn {
    min-width: 32px;
    padding: 0.22rem 0.35rem;
}

.department-member-empty {
    border: 1px dashed var(--surface-empty-border);
    border-radius: 10px;
    color: var(--surface-empty-text);
    background: color-mix(in srgb, var(--surface-empty-bg) 70%, transparent);
    text-align: center;
    font-size: 0.83rem;
    padding: 0.75rem;
}

.management-modal.dark-modal {
    background-color: var(--bg-card);
    background-image: linear-gradient(
        180deg,
        var(--bg-card) 0%,
        var(--bg-card-soft, var(--bg-card)) 100%
    );
    color: var(--text-primary);
    border: 1px solid var(--surface-panel-border);
    box-shadow: var(--modal-popup-shadow);
    backdrop-filter: none;
}

.management-modal .modal-header,
.management-modal .modal-footer {
    border-color: var(--surface-panel-header-border) !important;
}

.management-modal .modal-title {
    color: var(--text-primary);
}

.management-modal .btn-close {
    opacity: 0.78;
    filter: var(--addjob-close-filter, invert(1));
}

.management-modal .btn-close:hover {
    opacity: 1;
}

.management-modal .modal-body,
.management-modal .form-check-label {
    color: var(--text-primary);
}

.management-modal .form-label {
    color: var(--text-primary);
}

.management-modal .form-label small {
    color: var(--text-secondary);
}

.management-modal .form-control,
.management-modal .form-select {
    background: var(--surface-subpanel-bg);
    border-color: var(--surface-subpanel-border);
    color: var(--text-primary);
}

.management-modal .form-control::placeholder {
    color: color-mix(in srgb, var(--text-secondary) 76%, transparent);
}

.management-modal .form-control:focus,
.management-modal .form-select:focus {
    background: var(--surface-subpanel-bg);
    color: var(--text-primary);
    border-color: var(--accent);
    box-shadow: 0 0 0 0.14rem color-mix(in srgb, var(--accent) 18%, transparent);
}

.management-modal .form-select option {
    color: var(--text-primary);
    background: color-mix(in srgb, var(--surface-panel-bg) 96%, transparent);
}

.management-modal .form-check-input {
    background-color: color-mix(in srgb, var(--surface-subpanel-bg) 92%, transparent);
    border-color: var(--surface-subpanel-border);
}

.management-modal .form-check-input:checked {
    background-color: var(--accent);
    border-color: var(--accent);
}

.management-modal .form-check-input:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 0.14rem color-mix(in srgb, var(--accent) 18%, transparent);
}

@media (max-width: 1680px) {
    .daily-grid {
        grid-template-columns: minmax(250px, 0.58fr) minmax(0, 1.42fr);
    }

    .daily-right-column {
        grid-template-columns: minmax(0, 2.2fr) minmax(240px, 1fr);
    }
}

@media (max-width: 1280px) {
    :root {
        --sidebar-width: 286px;
    }

    .daily-header-row {
        grid-template-columns: 1fr;
    }

    .daily-date,
    .daily-title,
    .daily-time {
        text-align: left;
    }

    .planning-toolbar-panel {
        grid-template-columns: 1fr;
    }

    .planning-toolbar-left,
    .planning-toolbar-center,
    .planning-toolbar-right {
        grid-column: auto;
        grid-row: auto;
        justify-self: stretch;
        pointer-events: auto;
    }

    .planning-toolbar-center {
        text-align: left;
        align-items: flex-start;
    }

    .planning-status-filter-wrap {
        min-width: 0;
        width: 100%;
        flex: 1 1 auto;
    }

    #planningPage .planning-toolbar-left {
        flex-wrap: wrap;
    }

    #planningPage #planningUserWrap {
        flex: 1 1 168px;
        min-width: 168px;
    }

    .planning-status-filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .planning-board-layout {
        flex-direction: column;
    }

    .planning-main-column {
        flex: 1 1 auto;
        width: 100%;
        max-width: 100%;
    }

    .planning-side-column {
        flex: 1 1 auto;
        max-width: 100%;
        width: 100%;
    }

    .jobs-layout {
        grid-template-columns: 1fr;
    }

    .jobs-main-column {
        grid-template-rows: minmax(280px, 1fr) minmax(220px, 1fr);
    }

}

@media (max-width: 992px) {
    :root {
        --sidebar-width: min(82vw, 286px);
    }

    .header-theme-picker {
        min-width: 150px;
        max-width: 180px;
    }

    .header-theme-picker > i {
        display: none;
    }

    .header-user-switch {
        min-width: 0;
        max-width: 220px;
    }

    .header-user-switch-select {
        flex: 1 1 auto;
        width: auto;
        max-width: 100%;
    }

    .header-user-switch > i,
    .header-user-switch-return {
        display: none;
    }

    .daily-grid {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .daily-left-column {
        grid-template-rows: none;
        grid-template-columns: 1fr;
    }

    .daily-right-column {
        grid-template-columns: 1fr;
    }

    .daily-left-column > .board-card,
    .daily-right-column > .board-card,
    .daily-right-column > .working-card {
        min-height: 460px;
        height: auto;
    }

    .daily-left-column .board-card-body,
    .daily-right-column .board-card-body {
        min-height: 360px;
    }

    .timeline-row {
        grid-template-columns: 1fr;
    }

    .timeline-hours {
        padding: 0.6rem 0.75rem;
    }

    .timeline-caption {
        border-right: 0;
        border-bottom: 1px solid var(--border-color);
        padding: 0.6rem 0.85rem;
    }

    .planned-date-row {
        grid-template-columns: 1fr;
    }

    .legacy-addjob-header {
        grid-template-columns: 1fr auto;
    }

    .legacy-header-taskid,
    .legacy-header-planner,
    .legacy-header-user {
        display: none;
    }

    .legacy-type-cards {
        gap: 0.35rem;
    }

    .legacy-type-card {
        flex-basis: 150px;
        min-height: 52px;
        padding: 0.55rem 0.35rem;
    }

    .legacy-type-nav {
        width: 34px;
        height: 34px;
    }

    .legacy-type-carousel {
        grid-template-columns: 34px minmax(0, 1fr) 34px;
        gap: 0.35rem;
    }

    .legacy-planned-days-header {
        flex-wrap: wrap;
        align-items: flex-start;
    }

    .legacy-planned-days-header-actions {
        width: 100%;
        justify-content: space-between;
        flex-wrap: wrap;
        gap: 0.6rem;
        margin-left: 0;
    }

    .legacy-addjob-switch-stack {
        justify-content: start;
    }

    .legacy-addjob-switch {
        justify-content: flex-start;
    }

    .legacy-addjob-switch .form-check-label {
        text-align: left;
    }

    .legacy-addjob-submit,
    .legacy-addjob-delete {
        justify-self: stretch;
        width: 100%;
    }

    .legacy-month-picker .page-item {
        width: 25%;
    }

    .legacy-planned-days-columns {
        display: none;
    }

    .legacy-planned-date-rows .planned-date-row {
        grid-template-columns: 34px minmax(0, 1fr) auto;
        grid-template-areas:
            "index date remove"
            "index effort remove";
        align-items: stretch;
    }

    .legacy-planned-date-rows .planned-date-row .planned-day-index {
        grid-area: index;
        min-height: 100%;
    }

    .legacy-planned-date-rows .planned-date-row .planned-date-input {
        grid-area: date;
    }

    .legacy-planned-date-rows .planned-date-row .planned-effort-input {
        grid-area: effort;
    }

    .legacy-planned-date-rows .planned-date-row .planned-day-remove {
        grid-area: remove;
        min-width: 36px;
    }

    .legacy-planned-days-footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .legacy-planned-total-effort {
        width: 100%;
        justify-content: space-between;
    }

    .working-actions {
        grid-template-columns: 1fr;
    }

    .jobTimer {
        width: min(390px, calc(100vw - 12px));
        right: calc(-1 * min(390px, calc(100vw - 12px)) - 10px);
        bottom: 72px;
        padding: 10px 12px 12px;
    }

    .jobTimer .inner {
        grid-template-columns: 74px minmax(0, 1fr);
        column-gap: 10px;
        row-gap: 5px;
    }

    .jobTimer .inner .icon {
        width: 74px;
        height: 74px;
    }

    .jobTimer .inner .right {
        width: auto;
        grid-template-columns: minmax(0, 1fr);
        grid-template-areas:
            "counter"
            "info"
            "effort";
        row-gap: 4px;
    }

    .jobTimer .inner .right .counter {
        font-size: 1.85rem;
    }

    .jobTimer .inner .right .info {
        grid-template-columns: minmax(0, 1fr) auto;
        justify-items: stretch;
        align-items: center;
    }

    .jobTimer .inner .right .info p {
        text-align: left;
    }

    .jobTimer .inner .action {
        max-width: 100%;
        font-size: 0.72rem;
    }

    .planning-days-grid {
        grid-template-columns: 1fr;
    }

    .planning-drop-lane {
        min-height: 150px;
    }

    .department-planning-grid {
        gap: 0.55rem;
    }

    .department-planning-column {
        flex-basis: min(84vw, 280px);
        min-width: min(84vw, 280px);
    }

    .department-planning-lane {
        min-height: 150px;
    }

    .department-cards-grid {
        grid-template-columns: 1fr;
    }
}

/* CodePen-inspired FX replacements
   Drag-Drop: tibo3000/yMpBXV
   Buttons (Button One): fishtoyo/VYQVQx
   Selected card: liyrofx/poVZeEG
   Hover card: JohannesKantz/GRzmZoO */

.btn-theme-primary,
.btn-theme-outline,
.btn.btn-primary,
.btn.btn-success,
.btn.btn-outline-light,
.btn.btn-outline-secondary,
.btn.btn-outline-warning,
.btn.btn-outline-danger {
    position: relative;
    overflow: hidden;
    isolation: isolate;
}

.btn-theme-primary::before,
.btn-theme-outline::before,
.btn.btn-primary::before,
.btn.btn-success::before,
.btn.btn-outline-light::before,
.btn.btn-outline-secondary::before,
.btn.btn-outline-warning::before,
.btn.btn-outline-danger::before {
    content: "";
    position: absolute;
    top: -18%;
    left: -38%;
    width: 34%;
    height: 136%;
    pointer-events: none;
    opacity: 0;
    transform: translateX(0) skewX(-20deg);
    transition: transform 0.38s ease, opacity 0.26s ease;
    background: linear-gradient(
        90deg,
        transparent 0%,
        color-mix(in srgb, white 82%, transparent) 45%,
        color-mix(in srgb, white 92%, transparent) 52%,
        color-mix(in srgb, white 78%, transparent) 58%,
        transparent 100%
    );
    z-index: 1;
}

.btn-theme-primary:hover::before,
.btn-theme-primary:focus-visible::before,
.btn-theme-outline:hover::before,
.btn-theme-outline:focus-visible::before,
.btn.btn-primary:hover::before,
.btn.btn-primary:focus-visible::before,
.btn.btn-success:hover::before,
.btn.btn-success:focus-visible::before,
.btn.btn-outline-light:hover::before,
.btn.btn-outline-light:focus-visible::before,
.btn.btn-outline-secondary:hover::before,
.btn.btn-outline-secondary:focus-visible::before,
.btn.btn-outline-warning:hover::before,
.btn.btn-outline-warning:focus-visible::before,
.btn.btn-outline-danger:hover::before,
.btn.btn-outline-danger:focus-visible::before {
    opacity: 0.55;
    transform: translateX(430%) skewX(-20deg);
}

.job-card,
.job-view-flow-item {
    --fx-pointer-x: 50%;
    --fx-pointer-y: 50%;
}

.job-card::before,
.job-view-flow-item::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    z-index: 1;
    opacity: 0;
    transition: opacity 0.22s ease;
    background:
        radial-gradient(
            240px circle at var(--fx-pointer-x) var(--fx-pointer-y),
            color-mix(in srgb, var(--accent) 18%, white 8%) 0%,
            color-mix(in srgb, var(--accent) 9%, transparent) 28%,
            transparent 62%
        ),
        linear-gradient(180deg, color-mix(in srgb, var(--surface-card-bg, transparent) 88%, white 2%) 0%, transparent 100%);
}

.job-view-flow-item::before {
    background:
        radial-gradient(
            260px circle at var(--fx-pointer-x) var(--fx-pointer-y),
            color-mix(in srgb, var(--jv-accent, var(--accent)) 20%, white 8%) 0%,
            color-mix(in srgb, var(--jv-accent, var(--accent)) 10%, transparent) 30%,
            transparent 64%
        ),
        linear-gradient(180deg, color-mix(in srgb, var(--jv-widget-bg, transparent) 90%, white 2%) 0%, transparent 100%);
}

.job-card:hover::before,
.job-card:focus-visible::before,
.job-view-flow-item:hover::before,
.job-view-flow-item:focus-visible::before {
    opacity: 1;
}

.job-card:hover,
.job-card:focus-visible,
.job-view-flow-item:hover,
.job-view-flow-item:focus-visible {
    transform: none;
    box-shadow: 0 12px 24px rgba(4, 7, 11, 0.22);
}

.job-card:hover,
.job-card:focus-visible {
    border-color: color-mix(in srgb, var(--accent) 68%, var(--surface-card-hover-border) 32%);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--accent) 16%, transparent),
        0 0 16px color-mix(in srgb, var(--accent) 10%, transparent),
        0 12px 24px rgba(4, 7, 11, 0.22);
}

.job-card::after,
.job-view-flow-item::after {
    inset: -1px;
    padding: 1px;
    opacity: 0;
    z-index: 1;
    background: conic-gradient(
        from 0deg,
        color-mix(in srgb, var(--accent) 94%, white 8%) 0deg,
        color-mix(in srgb, var(--accent) 35%, transparent) 55deg,
        transparent 120deg,
        color-mix(in srgb, var(--accent) 28%, transparent) 190deg,
        color-mix(in srgb, var(--accent) 84%, white 10%) 270deg,
        color-mix(in srgb, var(--accent) 94%, white 8%) 360deg
    );
    filter: saturate(1.08);
    animation: none;
}

.job-view-flow-item::after {
    background: conic-gradient(
        from 0deg,
        color-mix(in srgb, var(--jv-accent, var(--accent)) 94%, white 8%) 0deg,
        color-mix(in srgb, var(--jv-accent, var(--accent)) 38%, transparent) 60deg,
        transparent 130deg,
        color-mix(in srgb, var(--jv-accent, var(--accent)) 28%, transparent) 210deg,
        color-mix(in srgb, var(--jv-accent, var(--accent)) 86%, white 10%) 300deg,
        color-mix(in srgb, var(--jv-accent, var(--accent)) 94%, white 8%) 360deg
    );
}

.job-card:hover::after,
.job-card:focus-visible::after,
.job-view-flow-item:hover::after,
.job-view-flow-item:focus-visible::after {
    opacity: 0.92 !important;
    background: linear-gradient(
        115deg,
        transparent 10%,
        color-mix(in srgb, var(--accent) 72%, transparent) 34%,
        color-mix(in srgb, white 68%, var(--accent) 32%) 50%,
        color-mix(in srgb, var(--accent) 82%, white 8%) 60%,
        color-mix(in srgb, var(--accent) 58%, transparent) 74%,
        transparent 92%
    ) !important;
    background-size: 260% 260% !important;
    background-position: 185% 50% !important;
    animation: fx-hover-card-borderSweep 2.4s linear infinite !important;
    filter: none !important;
}

.job-view-flow-item:hover::after,
.job-view-flow-item:focus-visible::after {
    background: linear-gradient(
        115deg,
        transparent 10%,
        color-mix(in srgb, var(--jv-accent, var(--accent)) 72%, transparent) 34%,
        color-mix(in srgb, white 68%, var(--jv-accent, var(--accent)) 32%) 50%,
        color-mix(in srgb, var(--jv-accent, var(--accent)) 82%, white 8%) 60%,
        color-mix(in srgb, var(--jv-accent, var(--accent)) 58%, transparent) 74%,
        transparent 92%
    ) !important;
    background-size: 260% 260% !important;
    background-position: 185% 50% !important;
    filter: none !important;
}

.job-card.is-selected,
.job-card.active,
.job-view-flow-item.is-selected {
    border-color: color-mix(in srgb, var(--accent) 84%, var(--surface-card-hover-border) 16%);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--accent) 42%, transparent),
        0 0 0 3px color-mix(in srgb, var(--accent) 10%, transparent),
        0 0 28px color-mix(in srgb, var(--accent) 18%, transparent),
        0 10px 24px rgba(4, 7, 11, 0.26);
}

.job-view-flow-item.is-selected {
    border-color: color-mix(in srgb, var(--jv-accent, var(--accent)) 72%, transparent);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--jv-accent, var(--accent)) 38%, transparent),
        0 0 0 3px color-mix(in srgb, var(--jv-accent, var(--accent)) 10%, transparent),
        0 0 26px color-mix(in srgb, var(--jv-accent, var(--accent)) 18%, transparent),
        0 10px 24px rgba(4, 7, 11, 0.26);
}

.job-card.is-selected::after,
.job-card.active::after,
.job-view-flow-item.is-selected::after {
    opacity: 0.95 !important;
    animation: fx-selected-card-borderPulse 2.4s ease-in-out infinite !important;
    filter: saturate(1.12) brightness(1.04);
}

.job-card.is-selected::before,
.job-card.active::before,
.job-view-flow-item.is-selected::before {
    opacity: 1;
    animation: fx-selected-card-halo 2.8s ease-in-out infinite;
}

.job-card.is-selected::before,
.job-card.active::before {
    background:
        radial-gradient(
            220px circle at var(--fx-pointer-x) var(--fx-pointer-y),
            color-mix(in srgb, var(--accent) 28%, white 10%) 0%,
            color-mix(in srgb, var(--accent) 14%, transparent) 30%,
            transparent 66%
        ),
        radial-gradient(
            180px circle at 10% 0%,
            color-mix(in srgb, var(--accent) 12%, white 6%) 0%,
            transparent 70%
        ),
        linear-gradient(180deg, color-mix(in srgb, var(--surface-card-bg, transparent) 92%, white 3%) 0%, transparent 100%);
}

.job-view-flow-item.is-selected::before {
    background:
        radial-gradient(
            240px circle at var(--fx-pointer-x) var(--fx-pointer-y),
            color-mix(in srgb, var(--jv-accent, var(--accent)) 28%, white 10%) 0%,
            color-mix(in srgb, var(--jv-accent, var(--accent)) 14%, transparent) 32%,
            transparent 68%
        ),
        radial-gradient(
            190px circle at 8% 0%,
            color-mix(in srgb, var(--jv-accent, var(--accent)) 12%, white 6%) 0%,
            transparent 72%
        ),
        linear-gradient(180deg, color-mix(in srgb, var(--jv-widget-bg, transparent) 92%, white 2%) 0%, transparent 100%);
}

.job-card.dragging {
    animation: fx-drag-begindrag 0.36s ease-out both;
    transform-origin: var(--drag-origin-x, 50%) var(--drag-origin-y, 50%);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.28);
}

.drop-lane.drag-over {
    box-shadow:
        inset 0 0 0 1px color-mix(in srgb, var(--accent) 26%, transparent),
        inset 0 0 18px color-mix(in srgb, var(--accent) 14%, transparent);
    background:
        radial-gradient(circle at center, color-mix(in srgb, var(--accent) 8%, transparent) 0%, transparent 72%),
        color-mix(in srgb, var(--surface-panel-bg) 92%, transparent);
}

.drop-lane.drag-over::after,
.drop-lane.drop-landed::after {
    content: "";
    position: absolute;
    inset: 6px;
    border-radius: 10px;
    pointer-events: none;
    z-index: 3;
    padding: 2px;
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--accent) 14%, transparent) 0%,
            transparent 100%
        ),
        repeating-conic-gradient(
            from 0deg,
            color-mix(in srgb, var(--accent) 92%, white 8%) 0deg 12deg,
            transparent 12deg 24deg
        );
}

.drop-lane.drag-over::after {
    opacity: 0.85;
    animation: fx-drop-ready 1s linear infinite !important;
}

.drop-lane.drop-landed::after {
    opacity: 0.95;
    animation: fx-drop-landed 0.34s ease-out !important;
}

@keyframes fx-selected-border-spin {
    to {
        transform: rotate(360deg);
    }
}

@keyframes fx-selected-card-borderPulse {
    0% {
        opacity: 0.62;
        filter: saturate(1.06) brightness(1.01);
    }
    50% {
        opacity: 0.98;
        filter: saturate(1.18) brightness(1.08);
    }
    100% {
        opacity: 0.62;
        filter: saturate(1.06) brightness(1.01);
    }
}

@keyframes fx-selected-card-halo {
    0% {
        opacity: 0.72;
        transform: scale(1);
    }
    50% {
        opacity: 1;
        transform: scale(1.006);
    }
    100% {
        opacity: 0.72;
        transform: scale(1);
    }
}

@keyframes fx-hover-card-borderGlow {
    0% {
        transform: rotate(0deg) scale(1);
        opacity: 0.56;
    }
    35% {
        opacity: 0.96;
    }
    50% {
        transform: rotate(180deg) scale(1.003);
        opacity: 0.84;
    }
    85% {
        opacity: 0.98;
    }
    100% {
        transform: rotate(360deg) scale(1);
        opacity: 0.56;
    }
}

@keyframes fx-hover-card-borderSweep {
    0% {
        background-position: 185% 50%;
        opacity: 0.62;
    }
    25% {
        background-position: 120% 50%;
        opacity: 0.96;
    }
    50% {
        background-position: 50% 50%;
        opacity: 0.84;
    }
    75% {
        background-position: -20% 50%;
        opacity: 0.96;
    }
    100% {
        background-position: -95% 50%;
        opacity: 0.62;
    }
}

@keyframes fx-drag-begindrag {
    0% {
        transform: scale(1);
        filter: saturate(1);
    }
    40% {
        transform: rotateZ(3deg) scale(1.035);
    }
    70% {
        transform: rotateZ(-2deg) scale(0.995);
    }
    100% {
        transform: rotateZ(0deg) scale(1);
        filter: saturate(1.04);
    }
}

@keyframes fx-drop-ready {
    0% {
        opacity: 0.25;
        transform: scale(1);
    }
    50% {
        opacity: 0.9;
        transform: scale(1.01);
    }
    100% {
        opacity: 0.25;
        transform: scale(1);
    }
}

@keyframes fx-drop-landed {
    0% {
        opacity: 0;
        transform: scale(0.96);
    }
    35% {
        opacity: 1;
        transform: scale(1.01);
    }
    100% {
        opacity: 0;
        transform: scale(1);
    }
}

@media (max-width: 1200px) {
    .projects-page {
        height: auto;
        grid-template-rows: none;
    }

    .projects-results-card {
        height: auto;
    }

    .projects-results-card .board-card-body {
        overflow: visible;
    }

    .projects-cards-grid {
        overflow: visible;
        padding-right: 0;
    }

    .projects-type-header {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .projects-header-search {
        width: 100%;
        max-width: none;
        justify-self: stretch;
    }

    .projects-type-actions {
        justify-self: start;
    }

    .projects-results-card .board-card-header {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .projects-inline-filters {
        justify-self: stretch;
        flex-wrap: wrap;
        gap: 0.45rem;
    }

    .projects-inline-filter-field {
        flex: 1 1 220px;
    }

    .projects-inline-filter-field .form-select {
        min-width: 0;
        max-width: none;
        width: 100%;
    }

    .app-main:has(#projectDetailPage),
    .app-content:has(#projectDetailPage),
    body.project-detail-active .app-main,
    body.project-detail-active .app-content {
        height: auto;
        overflow: visible;
    }

    .app-content:has(#projectDetailPage),
    body.project-detail-active .app-content {
        padding-bottom: 1rem;
    }

    body.project-detail-active {
        overflow: auto;
    }

    .project-detail-page {
        height: auto;
    }

    .project-detail-shell-card {
        height: auto;
    }

    .project-detail-shell-card .board-card-body {
        overflow: visible;
    }

    .project-detail-shell-body {
        height: auto;
        overflow: visible;
        grid-template-rows: auto auto;
    }

    .project-detail-main-layout {
        grid-template-columns: 1fr;
    }

    .project-detail-shell-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.45rem;
    }

    .project-detail-header-context {
        position: static;
        transform: none;
        max-width: 100%;
        pointer-events: auto;
    }

    .project-detail-header-context .project-detail-heading-main {
        justify-content: flex-start;
        white-space: normal;
        font-size: 1rem;
    }

    .project-detail-sidebar {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-template-rows: minmax(0, 1fr);
    }

    .project-detail-process-list,
    .project-detail-job-list {
        max-height: 320px;
    }

    .project-detail-viewer-frame-wrap,
    .project-detail-job-frame,
    .project-detail-viewer-frame-wrap .flow-empty {
        min-height: 56vh;
    }
}

@media (max-width: 767.98px) {
    .projects-cards-grid {
        grid-template-columns: 1fr;
    }

    .projects-inline-filter-field {
        flex: 1 1 100%;
    }

    .project-detail-operation-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .project-detail-sidebar {
        grid-template-columns: 1fr;
    }

    .project-detail-job-row {
        grid-template-columns: 1fr;
    }

    .project-detail-viewer-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .project-detail-viewer-frame-wrap,
    .project-detail-job-frame,
    .project-detail-viewer-frame-wrap .flow-empty {
        min-height: 50vh;
    }
}

@media (prefers-reduced-motion: reduce) {
    .btn-theme-primary::before,
    .btn-theme-outline::before,
    .btn.btn-primary::before,
    .btn.btn-success::before,
    .btn.btn-outline-light::before,
    .btn.btn-outline-secondary::before,
    .btn.btn-outline-warning::before,
    .btn.btn-outline-danger::before {
        transition: none;
    }

    .job-card.is-selected::after,
    .job-card.active::after,
    .job-view-flow-item.is-selected::after,
    .job-card:hover::after,
    .job-card:focus-visible::after,
    .job-view-flow-item:hover::after,
    .job-view-flow-item:focus-visible::after,
    .job-card.is-selected::before,
    .job-card.active::before,
    .job-view-flow-item.is-selected::before,
    .job-card.dragging,
    .drop-lane.drag-over::after,
    .drop-lane.drop-landed::after {
        animation: none !important;
    }
}







