:root {
    color-scheme: dark;

    --color-bg: #121212;
    --color-surface: #1a1a1a;
    --color-surface-raised: #252525;
    --color-border: #333333;
    --color-border-subtle: #2a2a2a;
    --color-text: #e8e8e8;
    --color-text-muted: #999999;
    --color-text-emphasis: #f5f5f5;
    --color-hover: #2a2a2a;
    --color-link-active-bg: #1e293b;
    --color-success: #86efac;
    --color-error: #f87171;
    --color-info: #93c5fd;
    --color-overlay: rgba(0, 0, 0, 0.55);
    --color-shadow-sidebar: 2px 0 8px rgba(0, 0, 0, 0.35);
    --color-input-border: #444444;
    --color-button-border: #444444;
    --color-focus-ring: #60a5fa;

    /* Semantic action buttons (DEFO-inspired; contrast-adjusted) */
    --action-positive: #1e8449;
    --action-positive-hover: #196f3d;
    --action-communication: #2471a3;
    --action-communication-hover: #1f618d;
    --action-destructive: #c0392b;
    --action-destructive-hover: #a93226;
    --action-caution: #f39c12;
    --action-caution-hover: #e67e22;
    --action-neutral: #95a5a6;

    --action-positive-text: #fff;
    --action-communication-text: #fff;
    --action-destructive-text: #fff;
    --action-caution-text: #222;

    /* Semantic status colours (design-language.md §10) */
    --semantic-completed: #27ae60;
    --semantic-completed-bg: rgba(39, 174, 96, 0.15);
    --semantic-active: #2980b9;
    --semantic-active-bg: rgba(41, 128, 185, 0.15);
    --semantic-waiting: #e67e22;
    --semantic-waiting-bg: rgba(230, 126, 34, 0.15);
    --semantic-destructive: #c0392b;
    --semantic-destructive-bg: rgba(192, 57, 43, 0.12);
    --semantic-info: #8e44ad;
    --semantic-info-bg: rgba(142, 68, 173, 0.12);

    /* Workspace density and motion */
    --workspace-gap: 1.25rem;
    --workspace-rail-width: 18rem;
    --density-control-gap: 0.35rem;
    --transition-fast: 150ms ease;
    --transition-panel: 200ms ease;
}

html {
    font-size: 100%;
}

html[data-font-scale="md"] {
    font-size: 112.5%;
}

html[data-font-scale="lg"] {
    font-size: 125%;
}

html[data-font-scale="xl"] {
    font-size: 137.5%;
}

[data-theme="light"] {
    color-scheme: light;

    --color-bg: #fafafa;
    --color-surface: #ffffff;
    --color-surface-raised: #ffffff;
    --color-border: #e5e5e5;
    --color-border-subtle: #f0f0f0;
    --color-text: #1a1a1a;
    --color-text-muted: #666666;
    --color-text-emphasis: #111111;
    --color-hover: #f5f5f5;
    --color-link-active-bg: #eef2ff;
    --color-success: #166534;
    --color-error: #b91c1c;
    --color-info: #1d4ed8;
    --color-overlay: rgba(0, 0, 0, 0.35);
    --color-shadow-sidebar: 2px 0 8px rgba(0, 0, 0, 0.08);
    --color-input-border: #e5e5e5;
    --color-button-border: #cccccc;
    --color-focus-ring: #2563eb;

    --semantic-completed: #166534;
    --semantic-completed-bg: rgba(22, 101, 52, 0.1);
    --semantic-active: #1d4ed8;
    --semantic-active-bg: rgba(29, 78, 216, 0.1);
    --semantic-waiting: #c2410c;
    --semantic-waiting-bg: rgba(194, 65, 12, 0.1);
    --semantic-destructive: #b91c1c;
    --semantic-destructive-bg: rgba(185, 28, 28, 0.08);
    --semantic-info: #6b21a8;
    --semantic-info-bg: rgba(107, 33, 168, 0.08);
}

body {
    font-family: system-ui, sans-serif;
    line-height: 1.5;
    margin: 0;
    color: var(--color-text);
    background: var(--color-bg);
}

summary {
    cursor: pointer;
}

.layout-app .app-shell {
    display: grid;
    grid-template-columns: 0 1fr;
    grid-template-rows: auto 1fr;
    grid-template-areas:
        "topbar topbar"
        "sidebar main";
    min-height: 100vh;
}

.layout-app.sidebar-open .app-shell {
    grid-template-columns: 15rem 1fr;
}

.layout-app.sidebar-collapsed .app-shell {
    grid-template-columns: 0 1fr;
}

.app-topbar {
    grid-area: topbar;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 30;
}

.app-topbar-title {
    font-weight: 600;
    font-size: inherit;
    margin: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
    min-width: 0;
}

.app-topbar-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
    margin-left: auto;
}

.user-menu {
    position: relative;
}

.user-menu__toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    max-width: min(14rem, 55vw);
    padding: 0.35rem 0.5rem;
    background: var(--color-surface);
    border: 1px solid var(--color-button-border);
    border-radius: 4px;
    cursor: pointer;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    line-height: 1.2;
}

.user-menu__email {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}

.user-menu__chevron {
    flex-shrink: 0;
    color: var(--color-text-muted);
    transition: transform 0.15s ease;
}

.user-menu--open .user-menu__chevron {
    transform: rotate(180deg);
}

.user-menu__panel {
    position: absolute;
    top: calc(100% + 0.35rem);
    right: 0;
    min-width: 14rem;
    max-width: min(18rem, 85vw);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    box-shadow: 0 4px 16px var(--color-overlay);
    padding: 0.5rem;
    z-index: 40;
}

.user-menu__org {
    padding: 0.15rem 0.25rem 0.5rem;
    margin-bottom: 0.25rem;
    border-bottom: 1px solid var(--color-border-subtle);
}

.user-menu__org-name {
    display: block;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.user-menu__panel[hidden] {
    display: none;
}

.user-menu__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.35rem 0.25rem;
}

.user-menu__row-label {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    flex-shrink: 0;
}

.user-menu__row-label--aa {
    font-weight: 600;
    color: var(--color-text);
}

.user-menu__footer {
    margin-top: 0.35rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--color-border-subtle);
}

.user-menu__logout {
    margin: 0;
}

.user-menu__sign-out {
    width: 100%;
    justify-content: center;
}

.nav-toggle,
.theme-toggle,
.font-scale__option {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.35rem;
    background: var(--color-surface);
    border: 1px solid var(--color-button-border);
    border-radius: 4px;
    cursor: pointer;
    color: var(--color-text);
}

.font-scale {
    display: flex;
    align-items: center;
}

.font-scale__options {
    display: inline-flex;
    align-items: stretch;
    gap: 0;
}

.font-scale__option {
    min-width: 1.65rem;
    padding: 0.3rem 0.35rem;
    font-size: 0.7rem;
    font-weight: 600;
    line-height: 1;
    border-radius: 0;
    margin-left: -1px;
}

.font-scale__option:first-child {
    margin-left: 0;
    border-top-left-radius: 4px;
    border-bottom-left-radius: 4px;
}

.font-scale__option:last-child {
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px;
}

.font-scale__option[aria-checked="true"] {
    background: var(--color-link-active-bg);
    border-color: var(--color-focus-ring);
    z-index: 1;
}

/* Dark: sun = switch to light; light: moon = switch to dark */
.theme-toggle .theme-icon--moon {
    display: none;
}

html[data-theme="light"] .theme-toggle .theme-icon--sun {
    display: none;
}

html[data-theme="light"] .theme-toggle .theme-icon--moon {
    display: block;
}

.nav-toggle:focus-visible,
.user-menu__toggle:focus-visible,
.theme-toggle:focus-visible,
.font-scale__option:focus-visible,
button:focus-visible,
a:focus-visible {
    outline: 2px solid var(--color-focus-ring);
    outline-offset: 2px;
}

.site-sidebar {
    grid-area: sidebar;
    background: var(--color-surface);
    border-right: 1px solid var(--color-border);
    padding: 1rem 0;
    overflow-y: auto;
    position: sticky;
    top: 3rem;
    align-self: start;
    max-height: calc(100vh - 3rem);
    z-index: 20;
}

.layout-app.sidebar-collapsed .site-sidebar {
    transform: translateX(-100%);
    visibility: hidden;
}

.layout-app.sidebar-open .site-sidebar {
    transform: translateX(0);
    visibility: visible;
}

.nav-link--primary {
    border-bottom: 1px solid var(--color-border-subtle);
}

.nav-group {
    border-bottom: 1px solid var(--color-border-subtle);
}

.nav-group-title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.6rem 1rem;
    font-weight: 600;
    cursor: pointer;
    list-style: none;
}

.nav-group-title::-webkit-details-marker {
    display: none;
}

.nav-group ul {
    list-style: none;
    margin: 0;
    padding: 0 0 0.5rem;
}

.nav-link {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.45rem 1rem 0.45rem 1.75rem;
    color: inherit;
    text-decoration: none;
    font-size: 0.95rem;
}

.nav-link:hover {
    background: var(--color-hover);
}

.nav-link.is-active {
    background: var(--color-link-active-bg);
    font-weight: 600;
}

.nav-icon {
    flex-shrink: 0;
}

.nav-overlay {
    display: none;
}

.layout-app .site-main {
    grid-area: main;
    max-width: none;
    margin: 0;
    padding: 1.5rem;
    min-width: 0;
}

/* Page title is shown in the top bar */
.layout-app .site-main h1 {
    display: none;
}

.layout-public {
    min-height: 100vh;
}

.public-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
}

.public-header__signin.btn-neutral {
    padding: 0.35rem 0.75rem;
}

/* Semantic action buttons — classes must be applied explicitly in templates */
button.btn-positive,
button.btn-communication,
button.btn-destructive,
button.btn-caution,
button.btn-neutral,
button.btn-archive,
a.btn-positive,
a.btn-communication,
a.btn-destructive,
a.btn-caution,
a.btn-neutral,
a.btn-archive {
    display: inline-block;
    padding: 0.5rem 1rem;
    font: inherit;
    line-height: inherit;
    border-radius: 4px;
    cursor: pointer;
    text-decoration: none;
    box-sizing: border-box;
}

.btn-positive {
    color: var(--action-positive-text);
    background: var(--action-positive);
    border: 1px solid var(--action-positive-hover);
}

.btn-positive:hover {
    background: var(--action-positive-hover);
    border-color: var(--action-positive-hover);
}

.btn-positive:focus-visible {
    outline-color: var(--action-positive);
}

.btn-communication {
    color: var(--action-communication-text);
    background: var(--action-communication);
    border: 1px solid var(--action-communication-hover);
}

.btn-communication:hover {
    background: var(--action-communication-hover);
    border-color: var(--action-communication-hover);
}

.btn-communication:focus-visible {
    outline-color: var(--action-communication);
}

.btn-destructive {
    color: var(--action-destructive-text);
    background: var(--action-destructive);
    border: 1px solid var(--action-destructive-hover);
}

.btn-destructive:hover {
    background: var(--action-destructive-hover);
    border-color: var(--action-destructive-hover);
}

.btn-destructive:focus-visible {
    outline-color: var(--action-destructive);
}

.btn-caution {
    color: var(--action-caution-text);
    background: var(--action-caution);
    border: 1px solid var(--action-caution-hover);
}

.btn-caution:hover {
    background: var(--action-caution-hover);
    border-color: var(--action-caution-hover);
}

.btn-caution:focus-visible {
    outline-color: var(--action-caution);
}

.btn-neutral {
    color: var(--color-text);
    background: transparent;
    border: 1px solid var(--action-neutral);
}

.btn-neutral:hover {
    background: color-mix(in srgb, var(--action-neutral) 18%, transparent);
}

.btn-neutral:focus-visible {
    outline-color: var(--action-neutral);
}

.btn-archive {
    padding: 0.15rem 0.45rem;
    font-size: 0.75rem;
    border-radius: 3px;
    color: var(--color-text-muted);
    background: transparent;
    border: 1px solid var(--color-button-border);
}

.btn-archive:hover {
    color: var(--color-text);
    background: var(--color-hover);
    border-color: var(--color-button-border);
}

.btn-archive:focus-visible {
    outline-color: var(--color-button-border);
}

button.btn-positive:disabled,
button.btn-communication:disabled,
button.btn-destructive:disabled,
button.btn-caution:disabled,
button.btn-neutral:disabled,
button.btn-archive:disabled {
    opacity: 0.7;
    cursor: not-allowed;
}

.btn-sm {
    padding: 0.15rem 0.45rem;
    font-size: 0.75rem;
    border-radius: 3px;
}

.site-main--public {
    max-width: 36rem;
    margin: 0 auto;
    padding: 1.5rem 1rem;
}

.site-main--minimal {
    max-width: 24rem;
    margin: 2rem auto;
    padding: 1.5rem;
}

.contacts-section {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border);
}

.contacts-section h2 {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
}

.tax-rate-fieldset {
    border: 1px solid var(--color-border);
    padding: 0.75rem 1rem 1rem;
    margin-bottom: 1rem;
    border-radius: 4px;
}

.tax-rate-fieldset legend {
    font-weight: 600;
    padding: 0 0.25rem;
}

@media (max-width: 767px) {
    /* Single full-width column; sidebar/overlay must not occupy grid tracks */
    .layout-app .app-shell,
    .layout-app.sidebar-open .app-shell,
    .layout-app.sidebar-collapsed .app-shell {
        grid-template-columns: minmax(0, 1fr);
        grid-template-areas:
            "topbar"
            "main";
        width: 100%;
    }

    .layout-app .site-main {
        width: 100%;
        max-width: none;
        min-width: 0;
    }

    .layout-app .site-sidebar,
    .layout-app .nav-overlay {
        grid-area: unset;
        grid-column: unset;
        grid-row: unset;
    }

    .site-sidebar {
        position: fixed;
        top: 3rem;
        left: 0;
        bottom: 0;
        width: min(15rem, 85vw);
        max-height: none;
        box-shadow: var(--color-shadow-sidebar);
        z-index: 25;
    }

    .layout-app.sidebar-collapsed .site-sidebar {
        transform: translateX(-100%);
        visibility: hidden;
        pointer-events: none;
    }

    .layout-app.sidebar-open .site-sidebar {
        transform: translateX(0);
        visibility: visible;
        pointer-events: auto;
    }

    .layout-app.sidebar-open .nav-overlay {
        display: block;
        position: fixed;
        inset: 3rem 0 0 0;
        background: var(--color-overlay);
        z-index: 15;
    }
}

@media (min-width: 768px) {
    .layout-app.sidebar-collapsed .nav-overlay {
        display: none !important;
    }
}

label {
    display: block;
    margin-bottom: 1rem;
}

input[type="email"],
input[type="text"],
input[type="password"],
input[type="url"],
input[type="tel"],
input[type="search"],
input[type="number"],
input[type="datetime-local"],
input[type="month"],
input[type="date"],
input[type="time"],
select,
textarea {
    display: block;
    width: 100%;
    max-width: 24rem;
    box-sizing: border-box;
    padding: 0.5rem;
    margin-top: 0.25rem;
    font: inherit;
    color: var(--color-text);
    background: var(--color-surface-raised);
    border: 1px solid var(--color-input-border);
    border-radius: 4px;
}

select option {
    font: inherit;
}

select,
textarea {
    margin-bottom: 1rem;
}

button {
    padding: 0.5rem 1rem;
    cursor: pointer;
    color: var(--color-text);
    background: var(--color-surface-raised);
    border: 1px solid var(--color-button-border);
    border-radius: 4px;
}

table {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0;
}

th, td {
    text-align: left;
    padding: 0.5rem;
    border-bottom: 1px solid var(--color-border);
}

.inline-form {
    display: inline;
}

.pagination {
    margin: 1rem 0;
}

.pagination a {
    margin-right: 1rem;
    color: var(--color-text);
}

.flash {
    margin: 0 0 1rem;
    padding: 0.75rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: var(--color-surface-raised);
}

.flash-success {
    color: var(--color-success);
    border-color: var(--color-success);
    background: color-mix(in srgb, var(--color-success) 12%, var(--color-surface-raised));
}

.flash-error,
.error {
    color: var(--color-error);
    border-color: var(--color-error);
    background: color-mix(in srgb, var(--color-error) 12%, var(--color-surface-raised));
}

.flash-info {
    color: var(--color-info);
    border-color: var(--color-info);
    background: color-mix(in srgb, var(--color-info) 12%, var(--color-surface-raised));
}

.filter-chips {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin: 0 0 1rem;
}

.filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.25rem 0.5rem;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    background: var(--color-surface-raised);
    font-size: 0.875rem;
    text-decoration: none;
    color: inherit;
}

.filter-chip:hover {
    background: var(--color-hover);
}

.filter-chip__label {
    color: var(--color-text-muted);
}

.filter-chip__remove {
    font-size: 1.1em;
    line-height: 1;
    color: var(--color-text-muted);
}

.filter-chips__clear {
    font-size: 0.875rem;
    color: var(--color-text-muted);
}

.invoice-payment-processing {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    margin: 1.5rem 0;
    padding: 1.5rem;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    text-align: center;
}

.invoice-payment-processing__spinner {
    width: 2rem;
    height: 2rem;
    border: 3px solid var(--color-border);
    border-top-color: var(--color-text);
    border-radius: 50%;
    animation: invoice-payment-spin 0.8s linear infinite;
}

.invoice-payment-processing__message {
    margin: 0;
    font-weight: 600;
}

.invoice-payment-processing__hint {
    margin: 0;
    max-width: 28rem;
}

@keyframes invoice-payment-spin {
    to {
        transform: rotate(360deg);
    }
}

.timer-elapsed {
    font-size: 2.5rem;
    font-variant-numeric: tabular-nums;
    font-weight: 600;
    margin: 0.5rem 0 1rem;
}

.timer-status {
    color: var(--color-text-muted);
    margin-bottom: 1rem;
}

.timer-continue-hint {
    margin: 0 0 1rem;
    padding: 0.6rem 0.75rem;
    font-size: 0.9rem;
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: 4px;
}

.timer-manual {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border);
}

.timer-manual summary {
    cursor: pointer;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.timer-manual-hint {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    margin: 0.5rem 0 1rem;
}

.status-bucket-group {
    margin-bottom: 2rem;
}

.status-bucket-group h2 {
    margin-bottom: 0.25rem;
}

.status-bucket-help {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    margin: 0 0 0.75rem;
}

.status-bucket-fieldset {
    border: 1px solid var(--color-border);
    border-radius: 6px;
    margin: 0 0 1rem;
    padding: 0.75rem 1rem;
}

.status-bucket-option {
    display: block;
    margin: 0.35rem 0;
}

.status-default-form {
    margin: 0;
}

.status-default-radio {
    margin: 0;
}

.project-description__text {
    white-space: pre-wrap;
    font-family: inherit;
    font-size: inherit;
    margin: 0;
    padding: 0.75rem 1rem;
    background: var(--color-bg-subtle, transparent);
    border: 1px solid var(--color-border);
    border-radius: 6px;
}

.engagement-projects {
    margin-bottom: 2rem;
}

.engagement-projects__list {
    list-style: none;
    padding: 0;
    margin: 0.5rem 0 0;
}

.engagement-projects__list li {
    margin: 0.35rem 0;
}

.project-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.project-milestones,
.project-tasks-placeholder {
    margin-bottom: 2rem;
}

.project-task-lists {
    margin-bottom: 2rem;
}

.project-task-sort {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 1rem;
}

.project-task-sort__option {
    padding: 0.35rem 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    text-decoration: none;
    color: var(--color-text);
    background: var(--color-surface-raised);
}

.project-task-sort__option:hover {
    background: var(--color-hover);
}

.project-task-sort__option--active {
    border-color: var(--color-accent);
    font-weight: 600;
}

.project-task-section {
    margin-bottom: 1.75rem;
}

.project-task-section__details {
    border: 1px solid var(--color-border-subtle);
    border-radius: 6px;
    background: var(--color-surface);
}

.project-task-section__details > summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.55rem 0.75rem;
    list-style: none;
    cursor: pointer;
    user-select: none;
}

.project-task-section__details > summary::-webkit-details-marker {
    display: none;
}

.project-task-section__details > summary::before {
    content: "▸";
    margin-right: 0.4rem;
    color: var(--color-text-muted);
    transition: transform var(--transition-fast);
}

.project-task-section__details[open] > summary::before {
    transform: rotate(90deg);
}

.project-task-section__title {
    font-size: 1.05rem;
    margin: 0;
    font-weight: 600;
    flex: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.75rem;
}

.project-task-section__count {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-text-muted);
}

.project-task-section__body {
    padding: 0 0.75rem 0.75rem;
}

.project-task-row--highlight {
    animation: project-task-highlight 2s ease-out;
}

@keyframes project-task-highlight {
    0% {
        background: var(--semantic-active-bg);
    }
    100% {
        background: transparent;
    }
}

@media (prefers-reduced-motion: reduce) {
    .project-task-row--highlight {
        animation: none;
        background: var(--semantic-active-bg);
    }

    .project-task-section__details > summary::before {
        transition: none;
    }
}

.project-task-table__handle-col {
    width: 2.25rem;
    padding-left: 0.35rem;
    padding-right: 0.35rem;
}

.project-task-handle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.25rem;
    border: none;
    background: transparent;
    color: var(--color-text-muted);
    cursor: grab;
    border-radius: 4px;
}

.project-task-handle:hover {
    color: var(--color-text);
    background: var(--color-hover);
}

.project-task-handle:active {
    cursor: grabbing;
}

.project-task-row--archived {
    opacity: 0.65;
}

.project-task-reorder-status {
    margin-top: 0.75rem;
    color: var(--color-text-muted);
    font-size: 0.9rem;
}

.project-task-reorder-status--error {
    color: var(--color-error);
}

/* Project task list — status groups and readable rows */
.project-task-status-group {
    margin-bottom: 1.25rem;
}

.project-task-status-group:last-child {
    margin-bottom: 0;
}

.project-task-status-group__heading {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.75rem;
    margin: 0 0 0.5rem;
    font-size: 0.9375rem;
    font-weight: 600;
}

.project-task-status-group__count {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-text-muted);
}

.project-task-estimate-total {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-text-muted);
}

.project-task-estimate-total--project {
    margin: 0 0 1rem;
}

.project-task-table--list {
    width: 100%;
    min-width: 36rem;
    border-collapse: collapse;
    table-layout: auto;
}

.project-task-table--list .project-task-table__handle-col {
    width: 2.75rem;
    white-space: nowrap;
}

.project-task-table--list thead th {
    padding: 0.45rem 0.75rem;
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    border-bottom: 1px solid var(--color-border);
    text-align: left;
    white-space: nowrap;
}

.project-task-table--list .project-task-table__name-col {
    min-width: 12rem;
    width: 100%;
    text-align: left;
}

.project-task-table--list .project-task-table__due-col,
.project-task-table--list .project-task-table__priority-col,
.project-task-table--list .project-task-table__estimate-col {
    width: 1%;
    min-width: 4.75rem;
    white-space: nowrap;
    text-align: right;
}

.project-task-table--list tbody tr.project-task-row {
    border-bottom: 1px solid var(--color-border-subtle);
    transition: background-color var(--transition-fast);
}

.project-task-table--list tbody tr.project-task-row:hover {
    background: var(--color-hover);
}

.project-task-table--list tbody tr.project-task-row:last-child {
    border-bottom: none;
}

.project-task-table--list td {
    padding: 0.7rem 0.75rem;
    vertical-align: middle;
    overflow: hidden;
}

.project-task-table--list .project-task-table__due-col,
.project-task-table--list .project-task-table__priority-col,
.project-task-table--list .project-task-table__estimate-col {
    text-align: right;
}

.project-task-row__name {
    --project-task-title-font-size: 0.9375rem;
    --project-task-title-line-height: 1.35;
    --project-task-title-line-box: calc(var(--project-task-title-font-size) * var(--project-task-title-line-height));
    --project-task-status-size: calc(var(--project-task-title-line-box) * 1.5);
    display: flex;
    align-items: flex-start;
    gap: 0.4rem;
    min-width: 0;
    justify-content: flex-start;
}

.project-task-status-trigger {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: content-box;
    padding: 0.15rem;
    margin: calc((var(--project-task-title-line-box) - var(--project-task-status-size)) / 2 - 0.15rem) -0.15rem -0.15rem;
    border: none;
    background: transparent;
    cursor: pointer;
    border-radius: 4px;
}

.project-task-status-trigger:focus-visible {
    outline: 2px solid var(--color-focus-ring);
    outline-offset: 2px;
}

.project-task-status-dot {
    flex-shrink: 0;
    box-sizing: border-box;
    width: var(--project-task-status-size);
    height: var(--project-task-status-size);
    margin-top: calc((var(--project-task-title-line-box) - var(--project-task-status-size)) / 2);
    border-radius: 50%;
    border: 2px solid currentColor;
    background: transparent;
}

.project-task-status-trigger.project-task-status-dot {
    width: var(--project-task-status-size);
    height: var(--project-task-status-size);
    margin-top: calc((var(--project-task-title-line-box) - var(--project-task-status-size)) / 2 - 0.15rem);
}

.project-task-status-dot.status-chip--inbox,
.project-task-status-trigger.status-chip--inbox {
    color: var(--semantic-info);
}

.project-task-status-dot.status-chip--active,
.project-task-status-trigger.status-chip--active {
    color: var(--semantic-active);
}

.project-task-status-dot.status-chip--waiting,
.project-task-status-trigger.status-chip--waiting {
    color: var(--semantic-waiting);
}

.project-task-status-dot.status-chip--completed,
.project-task-status-trigger.status-chip--completed {
    color: var(--semantic-completed);
}

.project-task-row__title {
    color: var(--color-text-emphasis);
    font-weight: 500;
    font-size: 0.9375rem;
    line-height: 1.35;
    text-decoration: none;
    overflow-wrap: break-word;
    white-space: normal;
    text-align: left;
}

.project-task-row__title:hover {
    text-decoration: underline;
}

.project-task-row__title:focus-visible {
    outline: 2px solid var(--color-focus-ring);
    outline-offset: 2px;
    border-radius: 2px;
}

.project-task-field-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
    min-height: 1.75rem;
    padding: 0.2rem 0.35rem;
    margin: -0.2rem -0.35rem;
    border: none;
    background: transparent;
    color: inherit;
    font: inherit;
    cursor: pointer;
    border-radius: 4px;
    max-width: 100%;
}

.project-task-field-trigger:focus-visible {
    outline: 2px solid var(--color-focus-ring);
    outline-offset: 2px;
}

.project-task-field-trigger.task-list-chip {
    padding: 0.15rem 0.5rem;
    margin: 0;
}

.project-task-due-trigger__inner,
.project-task-estimate-trigger__inner {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
}

.project-task-field-icon {
    flex-shrink: 0;
    color: var(--color-text-muted);
}

.project-task-due__label--mobile,
.project-task-estimate__label--mobile {
    display: none;
}

.task-list-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    max-width: 100%;
    box-sizing: border-box;
    padding: 0.3rem 0.55rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font: inherit;
    font-size: 0.8125rem;
    font-weight: 500;
    line-height: 1.45;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    background: var(--color-surface-raised);
    color: var(--color-text-emphasis);
}

.task-list-chip.status-chip--inbox {
    border-color: var(--semantic-info);
}

.task-list-chip.status-chip--active {
    border-color: var(--semantic-active);
}

.task-list-chip.status-chip--waiting {
    border-color: var(--semantic-waiting);
}

.task-list-chip.status-chip--completed {
    border-color: var(--semantic-completed);
}

.task-list-chip.priority-chip--low {
    border-color: var(--color-border);
    color: var(--color-text-muted);
}

.task-list-chip.priority-chip--medium {
    border-color: var(--semantic-active);
}

.task-list-chip.priority-chip--high {
    border-color: var(--semantic-waiting);
}

.task-list-chip.priority-chip--urgent {
    border-color: var(--semantic-destructive);
}

.project-task-due,
.project-task-estimate {
    font-size: 0.875rem;
    line-height: 1.35;
}

.project-task-due--set,
.project-task-estimate--set {
    color: var(--color-text-emphasis);
}

.project-task-due--empty,
.project-task-estimate--empty {
    color: var(--color-text-muted);
}

.project-task-field-popover.property-popover {
    z-index: 250;
}

@media (max-width: 640px) {
    .project-task-table--list {
        min-width: 34rem;
    }

    .project-task-table--list thead {
        display: table-header-group;
    }

    .data-table.project-task-table--list thead {
        display: table-header-group;
    }

    .project-task-table--list thead th {
        padding: 0.35rem 0.4rem;
        font-size: 0.625rem;
    }

    .project-task-table--list tbody tr.project-task-row {
        display: table-row;
        padding: 0;
        margin: 0;
        border: none;
        border-bottom: 1px solid var(--color-border-subtle);
        border-radius: 0;
        background: transparent;
    }

    .data-table.project-task-table--list tbody tr.project-task-row {
        display: table-row;
        margin-bottom: 0;
        border: none;
        border-bottom: 1px solid var(--color-border-subtle);
        border-radius: 0;
        background: transparent;
    }

    .data-table.project-task-table--list td {
        display: table-cell;
        justify-content: unset;
        align-items: unset;
        gap: unset;
        padding: 0.35rem 0.4rem;
        border-bottom: none;
    }

    .data-table.project-task-table--list td::before {
        content: none;
        display: none;
    }

    .project-task-table--list td {
        display: table-cell;
        padding: 0.35rem 0.4rem;
        border: none;
        vertical-align: middle;
    }

    .project-task-table--list td::before {
        content: none;
        display: none;
    }

    .project-task-table--list thead .project-task-table__handle-col {
        width: 1.5rem;
        max-width: 1.5rem;
        padding: 0.35rem 0.1rem;
    }

    .project-task-table--list .project-task-table__handle-col {
        display: table-cell;
        width: 1.5rem;
        max-width: 1.5rem;
        padding: 0.35rem 0.1rem 0.35rem 0.2rem;
    }

    .project-task-table--list .project-task-table__name-col {
        min-width: 10rem;
        width: 100%;
        padding-left: 0.15rem;
        text-align: left;
    }

    .project-task-table--list .project-task-table__due-col,
    .project-task-table--list .project-task-table__priority-col,
    .project-task-table--list .project-task-table__estimate-col {
        width: 1%;
        min-width: 4.25rem;
        white-space: nowrap;
        text-align: right;
    }

    .project-task-row__name {
        --project-task-title-font-size: 0.875rem;
        --project-task-title-line-height: 1.3;
        gap: 0.35rem;
    }

    .project-task-row__title {
        font-size: var(--project-task-title-font-size);
        line-height: var(--project-task-title-line-height);
    }

    .project-task-handle {
        padding: 0.1rem;
    }

    .project-task-field-trigger {
        min-width: 0;
        min-height: 0;
        padding: 0.1rem 0.2rem;
        margin: -0.1rem -0.2rem;
        gap: 0.25rem;
    }

    .project-task-field-trigger.task-list-chip {
        min-width: 0;
        padding: 0.12rem 0.35rem;
    }

    .project-task-due-trigger__inner,
    .project-task-estimate-trigger__inner {
        gap: 0.25rem;
    }

    .project-task-field-icon {
        width: 0.75rem;
        height: 0.75rem;
    }

    .project-task-due__label--desktop,
    .project-task-estimate__label--desktop {
        display: inline;
        font-size: 0.75rem;
    }

    .project-task-due__label--mobile,
    .project-task-estimate__label--mobile {
        display: none;
    }

    .project-task-priority-trigger {
        font-size: 0.6875rem;
        padding: 0.12rem 0.35rem;
    }

    .project-task-status-group .table-scroll {
        margin-inline: -0.25rem;
        scroll-padding-inline: 0.25rem;
    }
}

.sortable-ghost {
    opacity: 0.45;
}

.work-task-status-aging {
    display: block;
    margin-top: 0.25rem;
    color: var(--color-text-muted);
    font-size: 0.92rem;
}

.timer-manual[open] summary {
    margin-bottom: 0.75rem;
}

.timer-actions button {
    margin-right: 0.5rem;
}

.timer-error {
    color: var(--color-error);
}

.combo-results {
    list-style: none;
    margin: 0;
    padding: 0;
    border: 1px solid var(--color-border);
    background: var(--color-surface-raised);
    max-width: 24rem;
    max-height: 12rem;
    overflow-y: auto;
}

.combo-results li {
    padding: 0.4rem 0.5rem;
    cursor: pointer;
}

.combo-results li:hover,
.combo-results li:focus {
    background: var(--color-hover);
}

.combo-results li.combo-hint {
    color: var(--color-text-muted);
    font-style: italic;
    cursor: default;
}

.combo-results li.combo-hint:hover,
.combo-results li.combo-hint:focus {
    background: var(--color-surface-raised);
}

.checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.checkbox-label input {
    width: auto;
    margin: 0;
}

.line-tax-rates {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.checkbox-label--compact {
    font-size: 0.875rem;
}

.save-status {
    margin-left: 0.75rem;
    font-size: 0.875rem;
    color: var(--color-text-muted);
}

.save-status--saving {
    color: var(--color-text-muted);
}

.save-status--saved {
    color: var(--color-positive, #2d6a4f);
}

.save-status--error {
    color: var(--color-destructive, #b42318);
}

.markdown-content {
    line-height: 1.6;
}

.markdown-content > :first-child {
    margin-top: 0;
}

.markdown-content > :last-child {
    margin-bottom: 0;
}

.markdown-content p,
.markdown-content ul,
.markdown-content ol,
.markdown-content pre {
    margin: 0.75rem 0;
}

.markdown-content ul,
.markdown-content ol {
    padding-left: 1.5rem;
}

.markdown-content pre {
    overflow-x: auto;
    padding: 0.75rem 1rem;
    border-radius: 0.375rem;
    background: var(--color-surface-muted, #f4f4f5);
}

.markdown-content code {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 0.9em;
}

.markdown-content :not(pre) > code {
    padding: 0.1em 0.35em;
    border-radius: 0.25rem;
    background: var(--color-surface-muted, #f4f4f5);
}

.markdown-editor__fallback--hidden {
    display: none;
}

.work-task-description-editor {
    margin-top: 1rem;
}

.work-task-edit-actions {
    margin-top: 1.5rem;
}

.timer-work-context {
    margin: 1rem 0 1.25rem;
    padding: 0.875rem 1rem;
    border: 1px solid var(--color-border, #e4e4e7);
    border-radius: 0.5rem;
    background: var(--color-surface-muted, #fafafa);
}

.timer-work-context__list {
    display: grid;
    gap: 0.5rem 1.5rem;
    margin: 0;
}

.timer-work-context__item {
    display: grid;
    grid-template-columns: 5rem 1fr;
    gap: 0.75rem;
    align-items: baseline;
}

.timer-work-context__item dt {
    margin: 0;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.timer-work-context__item dd {
    margin: 0;
}

.work-task-time-logged {
    margin-top: 2rem;
}

.timer-footer {
    margin-top: 2rem;
    color: var(--color-text-muted);
}

.report-filters label {
    display: inline-block;
    margin-right: 1rem;
    vertical-align: top;
}

.report-filters select,
.report-filters input[type="date"],
.report-filters input[type="month"],
.report-filters input[type="number"] {
    display: block;
    max-width: 12rem;
}

.report-summary {
    margin: 1rem 0 1.5rem;
    padding: 1rem;
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: 4px;
}

.report-summary__heading {
    margin: 0 0 0.5rem;
    font-size: 1.15rem;
}

.report-summary__estimate {
    margin: 0 0 0.5rem;
    font-size: 0.85rem;
}

.report-summary__totals {
    margin: 0;
}

.report-mode-toggle {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: 0;
    padding: 0;
    border: none;
}

.report-mode-toggle .btn-neutral.is-active {
    background: var(--color-link-active-bg);
    border-color: var(--color-focus-ring);
}

.report-section {
    margin: 1.5rem 0;
}

.report-section h2 {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.report-task {
    margin: 0.75rem 0 1rem 1rem;
}

.report-task h4 {
    margin: 0.5rem 0;
    font-size: 1rem;
}

.report-date-heading {
    margin: 0.75rem 0 0.25rem 0.5rem;
    font-weight: 600;
    font-size: 0.9rem;
}

.report-log-table {
    margin-bottom: 1rem;
}

.report-col-check {
    width: auto;
    min-width: 2.75rem;
    padding-right: 0.5rem;
}

.report-entries-form input[type="checkbox"] {
    width: 1.35rem;
    height: 1.35rem;
    min-width: 1.35rem;
    min-height: 1.35rem;
    margin: 0;
    cursor: pointer;
    vertical-align: middle;
}

.report-engagement__heading {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 1rem;
}

.report-engagement-select-all {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.875rem;
    font-weight: normal;
    cursor: pointer;
    user-select: none;
}

.report-col-note,
.report-col-hours {
    min-width: 8rem;
}

.report-col-amounts {
    font-size: 0.9rem;
}

.report-amount-line {
    display: block;
}

.report-amount-total {
    font-weight: 600;
}

.report-copy-actions .btn-neutral {
    margin-left: 0.5rem;
}

.time-log-date-link {
    color: inherit;
    text-decoration: none;
    font-weight: 600;
}

.time-log-date-link:hover {
    text-decoration: underline;
}

.status-badge {
    display: inline-block;
    padding: 0.1rem 0.4rem;
    font-size: 0.8rem;
    border-radius: 3px;
    text-transform: capitalize;
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
}

.status-draft {
    color: var(--color-text-muted);
}

.status-approved {
    border-color: #6366f1;
    color: #6366f1;
}

.status-open {
    border-color: #0891b2;
    color: #0891b2;
}

.status-active {
    border-color: #16a34a;
    color: #16a34a;
}

.status-paused {
    border-color: #d97706;
    color: #d97706;
}

.status-stopped {
    border-color: var(--color-border);
    color: var(--color-text-muted);
}

.status-sent {
    border-color: #3b82f6;
    color: #3b82f6;
}

.status-partially_paid {
    border-color: #d97706;
    color: #d97706;
}

.status-paid {
    border-color: #16a34a;
    color: #16a34a;
}

.status-void {
    border-color: var(--color-border);
    color: var(--color-text-muted);
    text-decoration: line-through;
}

.empty-state {
    margin: 1.5rem 0;
    padding: 1.25rem 1rem;
    border: 1px dashed var(--color-border);
    border-radius: 4px;
    background: var(--color-surface-raised);
}

.report-bulk-actions {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border);
}

.report-bulk-actions__group {
    margin: 0.75rem 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.report-engagement h3 {
    margin-top: 1.5rem;
}

.muted {
    color: var(--color-text-muted);
    font-weight: normal;
    font-size: 0.9em;
}

.status-legend {
    margin: 1.25rem 0 0;
    padding: 0.75rem 1rem;
    font-size: 0.9rem;
    border: 1px solid var(--color-border-subtle);
    border-radius: 4px;
    background: var(--color-surface-raised);
}

.status-legend__heading {
    margin: 0 0 0.5rem;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-text);
}

.status-legend ul {
    margin: 0 0 0.5rem;
    padding-left: 1.25rem;
}

.status-legend li {
    margin-bottom: 0.25rem;
}

.status-legend__note {
    margin: 0;
    font-size: 0.85rem;
}

.budget-panel {
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    padding: 1rem;
    margin: 1rem 0;
    border-radius: 4px;
}

.budget-panel__heading {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
}

.budget-progress__scope {
    margin: 0 0 0.5rem;
    font-size: 0.95rem;
}

.budget-progress__track {
    height: 0.5rem;
    background: var(--color-border-subtle);
    border-radius: 4px;
    overflow: hidden;
}

.budget-progress__fill {
    height: 100%;
    background: var(--color-focus-ring);
    border-radius: 4px;
    min-width: 0;
    transition: width 0.2s ease;
}

.budget-progress__labels {
    margin: 0.5rem 0 0;
    font-size: 0.9rem;
}

.dashboard-stat {
    margin: 0 0 1.5rem;
    padding: 1rem;
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: 4px;
}

.dashboard-stat__label {
    margin: 0 0 0.25rem;
    font-size: 1rem;
    font-weight: 600;
}

.dashboard-stat__value {
    margin: 0;
    font-size: 1.75rem;
    font-weight: 700;
}

.dashboard-stat__meta {
    margin: 0.25rem 0 0;
}

.dashboard-receivables {
    margin-bottom: 2rem;
}

.dashboard-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
    margin: 0 0 1rem;
}

.dashboard-stat__help {
    margin-left: 0.25rem;
    font-weight: normal;
    font-size: 0.85em;
    text-decoration: none;
    cursor: help;
    border-bottom: 1px dotted var(--color-text-muted);
}

.dashboard-attention {
    margin-top: 0.5rem;
}

.dashboard-attention__section-label {
    margin: 0 0 0.5rem;
    font-size: 0.95rem;
    font-weight: 600;
}

.dashboard-attention-list {
    list-style: none;
    margin: 0;
    padding: 0;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: var(--color-surface-raised);
}

.dashboard-attention-list__item + .dashboard-attention-list__item {
    border-top: 1px solid var(--color-border);
}

.dashboard-attention-list__link {
    display: grid;
    grid-template-columns: 1.5fr 0.9fr 1fr 1fr;
    gap: 0.75rem;
    padding: 0.65rem 0.85rem;
    color: inherit;
    text-decoration: none;
}

.dashboard-attention-list__link:hover {
    background: var(--color-surface-hover, rgba(0, 0, 0, 0.03));
}

.dashboard-attention-list__client {
    font-weight: 600;
}

.dashboard-attention-list__amount {
    text-align: right;
}

.dashboard-attention__empty {
    margin: 0 0 1rem;
}

.dashboard-receivables__report-link {
    margin: 1rem 0 0;
}

.dashboard-section--operations {
    padding-top: 0.5rem;
    border-top: 1px solid var(--color-border);
}

.dashboard-section__heading {
    margin: 0 0 1rem;
    font-size: 1.15rem;
}

.dashboard-subsection h3 {
    margin: 0 0 0.75rem;
    font-size: 1.05rem;
}

@media (max-width: 720px) {
    .dashboard-summary-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-attention-list__link {
        grid-template-columns: 1fr 1fr;
        gap: 0.35rem 0.75rem;
    }

    .dashboard-attention-list__amount {
        text-align: left;
        grid-column: 1 / -1;
    }
}

.payment-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
    gap: 0.75rem;
    margin: 0 0 1.5rem;
}

.payment-activity-filters__month-nav {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    margin-bottom: 0.75rem;
}

.btn-sm.is-disabled {
    opacity: 0.55;
    cursor: not-allowed;
    pointer-events: none;
}

.payment-activity-table__details {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    font-size: 0.9rem;
}

.payment-activity-table__message {
    color: var(--color-text-muted);
}

.payment-activity-table__stripe-id {
    font-size: 0.75rem;
    word-break: break-all;
}

.dashboard-section {
    margin-bottom: 1.5rem;
}

.dashboard-section h2 {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
}

.dashboard-engagement-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dashboard-engagement-card {
    margin-bottom: 1rem;
    padding: 1rem;
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    border-radius: 4px;
}

.dashboard-engagement-card__title {
    margin: 0 0 0.5rem;
}

.dashboard-links__heading {
    margin: 0 0 0.5rem;
    font-size: 1rem;
}

.dashboard-links ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
}

.table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin: 0.5rem 0 1rem;
}

@media (max-width: 767px) {
    .layout-app .site-main,
    .layout-public .site-main {
        padding: 1rem;
    }

    .layout-public .site-main--public {
        max-width: none;
        width: 100%;
    }

    .layout-app label,
    .layout-public label,
    .layout-app .combo-results,
    .layout-public .combo-results,
    .layout-app input,
    .layout-public input,
    .layout-app select,
    .layout-public select,
    .layout-app textarea,
    .layout-public textarea,
    .layout-app .report-filters input,
    .layout-app .report-filters select {
        max-width: 100%;
    }

    .report-filters label {
        display: block;
        width: 100%;
        margin-right: 0;
        margin-bottom: 0.75rem;
    }

    .report-filters select,
    .report-filters input[type="date"],
    .report-filters input[type="month"],
    .report-filters input[type="number"] {
        max-width: 100%;
    }

    .dashboard-links ul {
        flex-direction: column;
        gap: 0.35rem;
    }
}

.report-actions {
    margin: 0.5rem 0 1.5rem;
}

.report-client {
    margin-bottom: 1rem;
    border-bottom: 1px solid var(--color-border-subtle);
}

.report-client summary {
    margin: 0;
    padding: 0.75rem 0;
    font-size: 1.25rem;
    font-weight: 600;
    cursor: pointer;
}

.report-client[open] summary {
    margin-bottom: 0.5rem;
}

.report-client[open] .report-engagement h3:first-child {
    margin-top: 0;
}

.time-list-groups {
    margin: 1rem 0 1.5rem;
}

.time-list-client {
    margin-bottom: 1rem;
    border-bottom: 1px solid var(--color-border-subtle);
}

.time-list-client summary {
    margin: 0;
    padding: 0.75rem 0;
    font-size: 1.15rem;
    font-weight: 600;
    cursor: pointer;
}

.time-list-client[open] summary {
    margin-bottom: 0.5rem;
}

.time-list-table {
    margin-bottom: 0.75rem;
}

.time-list-note {
    max-width: 20rem;
    white-space: normal;
    word-break: break-word;
}

.report-engagement {
    margin-left: 0.5rem;
    margin-bottom: 1rem;
}

.engagement-time-logs {
    margin: 1.5rem 0;
    padding: 1rem 0;
    border-top: 1px solid var(--color-border-subtle);
}

.engagement-time-logs__heading {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
}

.engagement-time-logs__status {
    margin: 0.5rem 0 0;
}

.engagement-time-logs__panel {
    margin-top: 0.75rem;
}

.engagement-time-logs__summary {
    margin: 0 0 0.75rem;
}

.engagement-time-logs__table {
    margin-bottom: 0.75rem;
}

.invoice-email-activity {
    margin: 1.5rem 0;
    padding: 1rem 0;
    border-top: 1px solid var(--color-border-subtle);
}

.invoice-form-details .invoice-email-activity,
.invoice-form-details .invoice-public-view-stats {
    margin: 0;
    padding: 0;
    border-top: none;
}

.invoice-form-details .invoice-email-activity + .invoice-public-view-stats,
.invoice-form-details .invoice-public-view-stats + .invoice-email-activity,
.invoice-form-details .invoice-late-fee-settings + .invoice-late-fee-history {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--color-border-subtle);
}

.invoice-form-details__subheading {
    margin: 0 0 0.75rem;
    font-size: 1rem;
    font-weight: 600;
}

.invoice-form-details__body {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.invoice-email-activity__heading {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
}

.invoice-email-activity__status {
    margin: 0.5rem 0 0;
}

.invoice-email-activity__panel {
    margin-top: 0.75rem;
}

.invoice-email-activity__table {
    margin-bottom: 0.75rem;
}

.invoice-email-activity__note {
    margin: 0 0 0.75rem;
}

.invoice-public-view-stats {
    margin: 1.5rem 0;
    padding: 1rem 0;
    border-top: 1px solid var(--color-border-subtle);
}

.invoice-public-view-stats__heading {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
}

.invoice-public-view-stats__note {
    margin: 0 0 0.75rem;
}

.invoice-public-view-stats__summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
    gap: 0.75rem 1.5rem;
    margin: 0 0 1rem;
}

.invoice-public-view-stats__summary dt {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin: 0 0 0.15rem;
}

.invoice-public-view-stats__summary dd {
    margin: 0;
    font-weight: 600;
}

.invoice-public-view-stats__table {
    margin-bottom: 0;
}

.invoice-scheduled-email-banner__heading {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
}

.invoice-scheduled-email-banner__details {
    margin: 0 0 0.75rem;
}

.invoice-scheduled-email-banner__actions {
    margin: 0;
}

.invoice-email-form__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.email-activity-row--bounce td[data-label="Bounced"] {
    color: var(--color-danger, #c0392b);
    font-weight: 600;
}

.email-activity-row--complaint td[data-label="Complained"] {
    color: var(--color-warning, #d68910);
    font-weight: 600;
}

.open-entries {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border);
}

.entry-context {
    margin-bottom: 1rem;
}

@media (max-width: 640px) {
    .data-table:not(.project-task-table--list) thead {
        display: none;
    }

    .data-table:not(.project-task-table--list) tbody tr {
        display: block;
        margin-bottom: 1rem;
        border: 1px solid var(--color-border);
        background: var(--color-surface-raised);
        border-radius: 4px;
    }

    .data-table:not(.project-task-table--list) td {
        display: flex;
        justify-content: space-between;
        gap: 1rem;
        align-items: flex-start;
        border-bottom: 1px solid var(--color-border-subtle);
        padding: 0.5rem 0.75rem;
    }

    .data-table:not(.project-task-table--list) td:last-child {
        border-bottom: none;
    }

    .data-table:not(.project-task-table--list) td::before {
        content: attr(data-label);
        font-weight: 600;
        flex-shrink: 0;
    }

    .data-table:not(.project-task-table--list) td[data-label=""]::before {
        content: none;
    }

    .open-entries .data-table td:has(input[type="checkbox"]) {
        flex-wrap: wrap;
    }

    .open-entries .data-table td:has(input[type="checkbox"])::before {
        width: 100%;
    }

    .data-table--responsive td[data-priority="optional"],
    .data-table--responsive th[data-priority="optional"] {
        display: none;
    }

    .data-table--responsive.report-log-table .report-amount-detail {
        display: none;
    }

    .data-table--responsive.report-log-table .report-copy-actions {
        display: none;
    }

    .data-table--responsive.report-log-table .report-note-text {
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .data-table--responsive tbody tr {
        padding: 0;
    }

    .data-table--responsive td[data-priority="primary"],
    .data-table--responsive td[data-priority="secondary"] {
        border-bottom: none;
    }

    .data-table--responsive td[data-priority="primary"]::before,
    .data-table--responsive td[data-priority="secondary"]::before {
        content: none;
    }

    .data-table--responsive td[data-priority="primary"]:not(.data-table__actions) {
        padding-top: 0.35rem;
        padding-bottom: 0.15rem;
    }

    .data-table--responsive td[data-priority="secondary"] {
        padding-top: 0;
        padding-bottom: 0.35rem;
        font-size: 0.9rem;
    }

    .data-table--responsive td.data-table__actions {
        padding-top: 0.25rem;
        border-bottom: 1px solid var(--color-border-subtle);
    }

    .data-table--responsive td.data-table__actions::before {
        content: none;
    }

    .invoice-lines-table td[data-cell="title"],
    .invoice-lines-table td[data-cell="description"] {
        display: block;
        text-align: left;
        border-bottom: none;
        padding: 0.5rem 0.75rem;
    }

    .invoice-lines-table td[data-cell="title"] {
        padding-bottom: 0.15rem;
    }

    .invoice-lines-table td[data-cell="title"]::before,
    .invoice-lines-table td[data-cell="description"]::before,
    .invoice-lines-table td[data-cell="actions"]::before {
        content: none;
    }

    .invoice-lines-table td[data-cell="title"] small.muted {
        display: block;
        margin-top: 0.15rem;
    }

    .invoice-lines-table td[data-cell="description"] {
        padding-top: 0;
        padding-bottom: 0.5rem;
        border-bottom: 1px solid var(--color-border-subtle);
    }

    .invoice-lines-table td[data-cell="title"] input,
    .invoice-lines-table td[data-cell="description"] textarea {
        width: 100%;
        max-width: 100%;
    }

    .invoice-lines-table td[data-cell="metric"] {
        display: flex;
        justify-content: flex-end;
        align-items: baseline;
        gap: 0.35rem;
        border-bottom: none;
        padding: 0.2rem 0.75rem;
    }

    .invoice-lines-table td[data-cell="metric"]::before {
        content: attr(data-label) ':';
        font-weight: 600;
        flex-shrink: 0;
    }

    .invoice-lines-table td[data-cell="metric"] input {
        width: auto;
        min-width: 5rem;
        max-width: 8rem;
        text-align: right;
    }

    .invoice-lines-table td[data-cell="metric"] .line-tax-rates {
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-end;
        gap: 0.25rem 0.75rem;
    }

    .invoice-lines-table td[data-cell="actions"] {
        display: block;
        border-top: 1px solid var(--color-border-subtle);
        border-bottom: none;
        padding: 0.5rem 0.75rem;
    }
}

.invoice-public-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.invoice-public__pay-button {
    margin-top: 0.25rem;
    padding: 0.85rem 1.75rem;
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1.3;
    border-radius: 6px;
    box-shadow: 0 2px 4px color-mix(in srgb, var(--action-positive) 25%, transparent);
}

.invoice-header-preview {
    margin: 1.25rem 0;
    padding: 1rem;
    border: 1px solid var(--color-border-subtle);
    border-radius: 0.5rem;
}

.invoice-header-preview__label {
    margin: 0 0 0.75rem;
    font-size: 0.875rem;
    color: var(--color-text-muted);
}

.invoice-header-preview__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.5rem;
}

.invoice-header-preview__block h3 {
    margin: 0 0 0.5rem;
    font-size: 0.95rem;
}

.invoice-header-preview__block-heading {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.75rem;
    margin-bottom: 0.5rem;
}

.invoice-header-preview__block-heading h3 {
    margin: 0;
}

.invoice-header-preview__refresh {
    margin: 0;
}

.invoice-header-preview__address {
    margin: 0;
    font-family: inherit;
    white-space: pre-wrap;
}

.invoice-header-preview__logo {
    max-width: 160px;
    max-height: 64px;
    margin-bottom: 0.5rem;
}

.invoice-form-toolbar {
    margin-top: 1rem;
}

.invoice-action-list {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    align-items: flex-start;
}

.invoice-action-list > li {
    margin: 0;
}

.invoice-action-form {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.5rem;
}

.invoice-action-form label {
    margin-bottom: 0;
}

.invoice-stripe-mode-details {
    margin: 0 0 1rem;
    padding: 0.75rem 0;
    border-top: 1px solid var(--color-border);
}

.recurring-form-details {
    margin: 0 0 0.5rem;
    padding: 0.5rem 0;
    border-top: 1px solid var(--color-border);
}

.recurring-form-details summary {
    cursor: pointer;
    font-weight: 600;
}

.recurring-form-details[open] summary {
    margin-bottom: 0.75rem;
}

.invoice-stripe-mode-details summary {
    cursor: pointer;
    font-weight: 600;
}

.invoice-stripe-mode-details[open] summary {
    margin-bottom: 0.75rem;
}

.invoice-settings-form {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.invoice-settings-details {
    margin: 0 0 0.5rem;
    padding: 0.75rem 0;
    border-top: 1px solid var(--color-border);
}

.invoice-settings-details summary {
    cursor: pointer;
    font-weight: 600;
    list-style: none;
}

.invoice-settings-details summary::-webkit-details-marker {
    display: none;
}

.invoice-settings-details summary::before {
    content: '▸ ';
    display: inline-block;
    width: 1rem;
}

.invoice-settings-details[open] summary::before {
    content: '▾ ';
}

.invoice-settings-details[open] > summary {
    margin-bottom: 0.75rem;
}

.invoice-settings-details--nested {
    margin-top: 0.75rem;
    padding-top: 0.5rem;
    border-top: 1px dashed var(--color-border);
}

.invoice-settings-details--nested summary {
    font-weight: 500;
    font-size: 0.95rem;
}

.email-footer-preview-block {
    margin-top: 1rem;
}

.email-footer-preview-block__heading {
    margin: 0 0 0.5rem;
    font-size: 1rem;
    font-weight: 600;
}

.email-footer-preview {
    margin: 0.5rem 0 0;
    padding: 0.75rem 1rem;
    background: var(--color-surface-muted, rgba(0, 0, 0, 0.04));
    border: 1px solid var(--color-border-subtle);
    border-radius: 4px;
    white-space: pre-wrap;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 0.9rem;
    line-height: 1.45;
}

.email-template-placeholders {
    margin: 0.75rem 0 1rem;
}

.email-template-placeholders__heading {
    margin: 0 0 0.5rem;
}

.email-template-placeholders__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.email-template-placeholders__chip {
    appearance: none;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    background: var(--color-surface, #fff);
    color: inherit;
    cursor: pointer;
    font: inherit;
    font-size: 0.85rem;
    line-height: 1.2;
    padding: 0.2rem 0.55rem;
}

.email-template-placeholders__chip:hover {
    border-color: var(--color-accent, #666);
}

.email-template-placeholders__chip:focus-visible {
    outline: 2px solid var(--color-accent, #666);
    outline-offset: 2px;
}

.email-template-placeholders__chip--copied {
    border-color: var(--color-positive, #2e7d32);
    background: color-mix(in srgb, var(--color-positive, #2e7d32) 12%, transparent);
}

.email-template-placeholders__status {
    margin: 0.5rem 0 0;
    min-height: 1.25rem;
}

.invoice-stripe-mode-fieldset {
    border: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 1rem;
}

.invoice-form-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border);
}

.invoice-form-footer__left,
.invoice-form-footer__right {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.invoice-form-footer__right {
    margin-left: auto;
}

.invoice-void-form {
    margin: 0;
}

.invoice-summary-table {
    width: 100%;
    max-width: 24rem;
    margin-left: auto;
    border-collapse: collapse;
}

.invoice-summary-table th {
    font-weight: normal;
    text-align: left;
    padding: 0.35rem 1rem 0.35rem 0;
}

.invoice-summary-table__amount {
    text-align: right;
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.invoice-totals__grand th,
.invoice-totals__grand td {
    font-weight: 600;
    border-top: 1px solid var(--color-border-subtle);
    padding-top: 0.5rem;
}

.invoice-payment-summary__due td {
    font-weight: 600;
    color: #e67e22;
}

.invoice-payment-summary__paid td {
    color: var(--color-success);
}

.invoice-payment-summary__history-heading {
    margin: 1.25rem 0 0.5rem;
    font-size: 0.95rem;
    font-weight: 600;
}

.invoice-lines__currency {
    margin: 0 0 0.75rem;
    font-size: 0.9rem;
}

.invoice-public__header {
    margin-bottom: 0.25rem;
}

.invoice-public__header h1 {
    margin: 0 0 0.35rem;
}

.invoice-public__meta {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
}

.invoice-public__status {
    color: #e67e22;
    font-weight: 600;
}

.invoice-public > .flash,
.invoice-public > .invoice-payment-processing {
    margin-bottom: 0;
}

.invoice-public > section + section,
.invoice-public > .invoice-header-preview + section,
.invoice-public > section + .invoice-public__paid-banner,
.invoice-public > section + .invoice-public__payment,
.invoice-public > .invoice-public__paid-banner + .invoice-public__payment {
    margin-top: 1.75rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border-subtle);
}

.invoice-public__paid-banner {
    margin-top: 1.75rem;
    padding: 1rem 1.25rem;
    border: 1px solid var(--color-border-subtle);
    border-radius: 0.5rem;
    background: color-mix(in srgb, var(--color-success) 12%, var(--color-surface-raised));
    text-align: center;
}

.invoice-public__paid-banner p {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--color-success);
}

.invoice-public__payment--card {
    padding: 1.25rem;
    border: 1px solid var(--color-border-subtle);
    border-radius: 0.5rem;
    background: var(--color-surface-raised);
}

.invoice-public__payment--card h2 {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
}

.invoice-public__payment--card p {
    margin: 0 0 1rem;
}

.invoice-public__payment--card p:last-child {
    margin-bottom: 0;
}

.invoice-public__payment--secondary {
    background: var(--color-surface);
}

.invoice-public .invoice-payment-summary .invoice-summary-table,
.invoice-public .invoice-totals__table {
    margin-left: auto;
}

.form-row {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.invoice-void-form {
    margin-top: 1rem;
}

.global-search-trigger {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.55rem;
    background: var(--color-surface);
    border: 1px solid var(--color-button-border);
    border-radius: 4px;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    cursor: pointer;
    line-height: 1.2;
}

.global-search-trigger__label {
    display: none;
}

.global-search-trigger__kbd {
    display: none;
    font-size: 0.7rem;
    padding: 0.1rem 0.35rem;
    border: 1px solid var(--color-border);
    border-radius: 3px;
    color: var(--color-text-muted);
    background: var(--color-bg);
}

@media (min-width: 48rem) {
    .global-search-trigger__label {
        display: inline;
    }

    .global-search-trigger__kbd {
        display: inline;
    }
}

.global-search {
    position: fixed;
    inset: 0;
    z-index: 100;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 10vh 1rem 1rem;
}

.global-search[hidden] {
    display: none;
}

.global-search__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
}

.global-search__panel {
    position: relative;
    width: min(36rem, 100%);
    max-height: min(70vh, 32rem);
    display: flex;
    flex-direction: column;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
    overflow: hidden;
}

.global-search__input-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--color-border);
}

.global-search__icon {
    flex-shrink: 0;
    color: var(--color-text-muted);
}

.global-search__input {
    flex: 1;
    min-width: 0;
    border: 0;
    background: transparent;
    color: var(--color-text);
    font: inherit;
    outline: none;
}

.global-search__input::-webkit-search-cancel-button {
    display: none;
}

.global-search__hint {
    flex-shrink: 0;
    font-size: 0.7rem;
    padding: 0.1rem 0.35rem;
    border: 1px solid var(--color-border);
    border-radius: 3px;
    color: var(--color-text-muted);
}

.global-search__results {
    overflow-y: auto;
    padding: 0.35rem 0;
}

.global-search__group-label {
    padding: 0.45rem 1rem 0.25rem;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.global-search__item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.15rem;
    width: 100%;
    padding: 0.55rem 1rem;
    border: 0;
    background: transparent;
    color: var(--color-text);
    text-align: left;
    cursor: pointer;
    font: inherit;
}

.global-search__item:hover,
.global-search__item--selected {
    background: var(--color-bg);
}

.global-search__item-title {
    font-weight: 500;
}

.global-search__item-context {
    font-size: 0.82rem;
    color: var(--color-text-muted);
}

.global-search__empty,
.global-search__footer {
    padding: 0.75rem 1rem;
    font-size: 0.85rem;
    color: var(--color-text-muted);
    border-top: 1px solid var(--color-border);
}

.global-search__empty[hidden],
.global-search__footer[hidden] {
    display: none;
}

.document-scope-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.document-scope-chip {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    font-size: 0.82rem;
    background: var(--color-bg);
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
}

.document-scope-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
}

.document-scope-breadcrumb__sep {
    color: var(--color-text-muted);
}

.document-favorite-star {
    border: 0;
    background: transparent;
    color: var(--color-text-muted);
    cursor: pointer;
    font-size: 1.1rem;
    line-height: 1;
    padding: 0 0.35rem 0 0;
    vertical-align: middle;
}

.document-favorite-star.is-favorite {
    color: #c99700;
}

.document-scope-fields legend .field-optional {
    font-weight: normal;
    color: var(--color-text-muted);
    font-size: 0.9rem;
}

.document-index-tabs,
.document-index-sort {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: 1rem 0;
}

.document-index-tab,
.document-index-sort-link {
    display: inline-block;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: 0.9rem;
}

.document-index-tab.is-active,
.document-index-sort-link.is-active {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}

.document-index-favorite-col {
    width: 2rem;
}

.document-panel {
    margin: 2rem 0;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border);
}

.document-panel__header {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.document-panel__header h2 {
    margin: 0;
}

.document-panel__actions {
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
}

.document-panel__secondary {
    margin: 0.75rem 0 0;
    color: var(--color-text-muted);
    font-size: 0.9rem;
}

.document-scope-archived {
    display: inline-block;
    margin-left: 0.35rem;
    padding: 0.05rem 0.4rem;
    border-radius: 999px;
    font-size: 0.75rem;
    text-transform: lowercase;
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
    background: var(--color-bg);
}

.document-related {
    margin: 2rem 0 0;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border);
}

.document-related h2 {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
}

.document-related__list {
    margin: 0;
}

.document-related__row {
    display: grid;
    grid-template-columns: minmax(7rem, 10rem) 1fr;
    gap: 0.5rem 1rem;
    margin-bottom: 0.65rem;
}

.document-related__row dt {
    margin: 0;
    color: var(--color-text-muted);
    font-weight: normal;
}

.document-related__row dd {
    margin: 0;
}

.document-related__sep {
    color: var(--color-text-muted);
}

@media (max-width: 640px) {
    .document-related__row {
        grid-template-columns: 1fr;
        gap: 0.15rem;
    }
}

/* --- Workspace layout (design-language.md) --- */

.layout-workspace.layout-app .app-shell,
.layout-workspace.layout-app.sidebar-open .app-shell,
.layout-workspace.layout-app.sidebar-collapsed .app-shell {
    grid-template-columns: 1fr;
    grid-template-areas:
        "topbar"
        "main";
}

.layout-workspace .site-main > .flash {
    margin: 0.75rem 1.25rem 0;
}

@media (min-width: 768px) {
    .layout-workspace #site-sidebar,
    .layout-workspace #nav-overlay {
        display: none;
    }
}

.layout-workspace .app-topbar-title {
    visibility: hidden;
    width: 0;
    overflow: hidden;
    padding: 0;
    margin: 0;
}

.layout-workspace .app-topbar {
    position: sticky;
    top: 0;
    z-index: 40;
}

.layout-workspace .site-main {
    max-width: none;
    padding: 0;
    position: relative;
    z-index: 1;
}

.workspace {
    min-height: calc(100vh - 3.5rem);
    display: flex;
    flex-direction: column;
}

.layout-workspace .workspace-header {
    top: 3.5rem;
}

.workspace-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--workspace-gap);
    padding: 0.75rem 1.25rem;
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 20;
}

.workspace-header__start {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    min-width: 0;
    flex: 1;
}

.workspace-header__end {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    gap: 0.5rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.workspace-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    background: var(--color-surface-raised);
    color: var(--color-text-muted);
    text-decoration: none;
    flex-shrink: 0;
    line-height: 1;
    font-size: 1.25rem;
}

.workspace-close:hover {
    color: var(--color-text);
    background: var(--color-hover);
}

.workspace-close:focus-visible {
    outline: 2px solid var(--color-focus-ring);
    outline-offset: 2px;
}

.breadcrumbs {
    min-width: 0;
}

.breadcrumbs__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.25rem 0;
    list-style: none;
    margin: 0;
    padding: 0;
    font-size: 0.875rem;
    line-height: 1.4;
}

.breadcrumbs__item {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
}

.breadcrumbs__item:not(:last-child)::after {
    content: "›";
    margin: 0 0.35rem;
    color: var(--color-text-muted);
}

.breadcrumbs__item a {
    color: var(--color-text-muted);
    text-decoration: none;
}

.breadcrumbs__item a:hover {
    color: var(--color-text);
    text-decoration: underline;
}

.breadcrumbs__item span[aria-current="page"] {
    color: var(--color-text);
    font-weight: 500;
}

.workspace-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.workspace-actions .inline-form {
    margin: 0;
}

.workspace-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) var(--workspace-rail-width);
    gap: 0;
    flex: 1;
    align-items: start;
}

.workspace-grid--single {
    grid-template-columns: minmax(0, 1fr);
}

.workspace-main {
    padding: 1.25rem;
    min-width: 0;
}

.workspace-rail {
    padding: 1.25rem 1.25rem 1.25rem 0;
    border-left: 1px solid var(--color-border-subtle);
    min-width: 0;
}

.workspace-title {
    margin: 0 0 1rem;
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.25;
}

.workspace-title-label {
    display: block;
    margin: 0 0 0.75rem;
}

.workspace-title-input {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0.15rem 0;
    border: none;
    border-bottom: 1px solid transparent;
    border-radius: 0;
    background: transparent;
    color: var(--color-text);
    font: inherit;
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.25;
}

.workspace-title-input:hover {
    border-bottom-color: var(--color-border-subtle);
}

.workspace-title-input:focus {
    outline: none;
    border-bottom-color: var(--color-focus-ring);
}

.property-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-bottom: 1rem;
}

.property-chip {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    margin: 0;
    padding: 0.3rem 0.65rem;
    border: 1px solid var(--color-border-subtle);
    border-radius: 999px;
    background: var(--color-surface);
    color: var(--color-text);
    font: inherit;
    font-size: 0.8125rem;
    line-height: 1.45;
    cursor: pointer;
    gap: 0.35rem;
    box-sizing: border-box;
    transition: border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);
}

.property-chip:active {
    transform: scale(0.98);
}

.property-chip__icon {
    display: inline-flex;
    flex-shrink: 0;
    color: var(--color-text-muted);
}

.property-chip__icon svg {
    display: block;
}

.property-chip:hover {
    border-color: var(--color-border);
    background: var(--color-surface-raised, var(--color-surface));
}

.property-chip:focus-visible {
    outline: 2px solid var(--color-focus-ring);
    outline-offset: 2px;
}

.property-chip[aria-expanded="true"] {
    border-color: var(--color-focus-ring);
}

.property-chip--pending {
    opacity: 0.72;
}

.property-chip__value {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.status-chip--inbox {
    border-color: var(--semantic-info);
    background: var(--semantic-info-bg);
    color: var(--semantic-info);
}

.status-chip--active {
    border-color: var(--semantic-active);
    background: var(--semantic-active-bg);
    color: var(--semantic-active);
}

.status-chip--waiting {
    border-color: var(--semantic-waiting);
    background: var(--semantic-waiting-bg);
    color: var(--semantic-waiting);
}

.status-chip--completed {
    border-color: var(--semantic-completed);
    background: var(--semantic-completed-bg);
    color: var(--semantic-completed);
}

.status-chip {
    box-sizing: border-box;
    border: 1px solid transparent;
    font: inherit;
    font-weight: 500;
    line-height: 1.45;
}

.priority-chip--low {
    border-color: var(--color-border-subtle);
    background: var(--color-surface);
    color: var(--color-text-muted);
}

.priority-chip--medium {
    border-color: var(--semantic-active);
    background: var(--semantic-active-bg);
    color: var(--semantic-active);
}

.priority-chip--high {
    border-color: var(--semantic-waiting);
    background: var(--semantic-waiting-bg);
    color: var(--semantic-waiting);
}

.priority-chip--urgent {
    border-color: var(--semantic-destructive);
    background: var(--semantic-destructive-bg);
    color: var(--semantic-destructive);
}

.property-popover {
    position: absolute;
    z-index: 200;
    width: min(18rem, calc(100vw - 2rem));
    border: 1px solid var(--color-border-subtle);
    border-radius: 8px;
    background: var(--color-surface);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    animation: property-popover-in var(--transition-fast) ease-out;
}

@keyframes property-popover-in {
    from {
        opacity: 0;
        transform: translateY(-4px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.property-popover__inner {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 0.5rem;
    max-height: 16rem;
    overflow: auto;
}

.property-popover__group-label {
    margin: 0.35rem 0 0.15rem;
    padding: 0 0.25rem;
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.property-popover__option {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0.45rem 0.65rem;
    border: 1px solid transparent;
    border-radius: 6px;
    background: transparent;
    color: inherit;
    font: inherit;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.45;
    text-align: left;
    cursor: pointer;
    box-sizing: border-box;
}

.property-popover__option.status-chip,
.property-popover__option.task-list-chip,
.property-popover__option[class*="status-chip--"],
.property-popover__option[class*="priority-chip--"] {
    display: flex;
    align-items: center;
    min-block-size: calc(1.45em + 0.9rem + 2px);
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
}

.property-popover__option:hover,
.property-popover__option[aria-current="true"] {
    background: var(--color-surface-raised, rgba(0, 0, 0, 0.04));
}

.property-popover__option.status-chip--inbox:hover,
.property-popover__option.status-chip--inbox[aria-current="true"] {
    background: var(--semantic-info-bg);
}

.property-popover__option.status-chip--active:hover,
.property-popover__option.status-chip--active[aria-current="true"] {
    background: var(--semantic-active-bg);
}

.property-popover__option.status-chip--waiting:hover,
.property-popover__option.status-chip--waiting[aria-current="true"] {
    background: var(--semantic-waiting-bg);
}

.property-popover__option.status-chip--completed:hover,
.property-popover__option.status-chip--completed[aria-current="true"] {
    background: var(--semantic-completed-bg);
}

.property-popover__option.priority-chip--low:hover,
.property-popover__option.priority-chip--low[aria-current="true"] {
    background: var(--color-surface);
}

.property-popover__option.priority-chip--medium:hover,
.property-popover__option.priority-chip--medium[aria-current="true"] {
    background: var(--semantic-active-bg);
}

.property-popover__option.priority-chip--high:hover,
.property-popover__option.priority-chip--high[aria-current="true"] {
    background: var(--semantic-waiting-bg);
}

.property-popover__option.priority-chip--urgent:hover,
.property-popover__option.priority-chip--urgent[aria-current="true"] {
    background: var(--semantic-destructive-bg);
}

.property-popover__input {
    width: 100%;
    box-sizing: border-box;
}

.property-popover__clear {
    margin-top: 0.25rem;
    width: 100%;
}

.workspace-sort-label {
    display: block;
    font-size: 0.9rem;
}

.workspace-sort-label input {
    display: block;
    width: 100%;
    margin-top: 0.25rem;
}

.work-task-noscript-form {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border-subtle);
}

.workspace-section {
    margin-bottom: 1.5rem;
}

.workspace-section__heading {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0 0 0.65rem;
    font-size: 1rem;
    font-weight: 600;
}

.workspace-section__heading svg {
    color: var(--color-text-muted);
    flex-shrink: 0;
}

.workspace-section > h2:not(.workspace-section__heading),
.workspace-section > h3 {
    margin: 0 0 0.65rem;
    font-size: 1rem;
    font-weight: 600;
}

.workspace-footer {
    margin-top: auto;
    padding: 0.5rem 1.25rem;
    border-top: 1px solid var(--color-border-subtle);
    background: var(--color-surface);
}

.workspace-shortcuts {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem 1rem;
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

.workspace-shortcuts__item {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.workspace-shortcuts__help {
    margin-left: auto;
    padding: 0.1rem 0.45rem;
    border: 1px solid var(--color-border-subtle);
    border-radius: 4px;
    background: transparent;
    color: var(--color-text-muted);
    font-size: 0.75rem;
    cursor: pointer;
}

.workspace-shortcuts__help:hover {
    color: var(--color-text);
    border-color: var(--color-border);
}

.workspace-shortcuts-dialog {
    position: fixed;
    right: 1.25rem;
    bottom: 3rem;
    z-index: 210;
    width: min(16rem, calc(100vw - 2rem));
    padding: 0.75rem 1rem;
    border: 1px solid var(--color-border-subtle);
    border-radius: 8px;
    background: var(--color-surface);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.workspace-shortcuts-dialog__title {
    margin: 0 0 0.5rem;
    font-size: 0.8125rem;
    font-weight: 600;
}

.workspace-shortcuts-dialog__list {
    margin: 0;
    padding: 0;
    list-style: none;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

.workspace-shortcuts-dialog__list li {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin-bottom: 0.35rem;
}

.workspace-shortcuts-dialog__list li:last-child {
    margin-bottom: 0;
}

.kbd {
    display: inline-block;
    min-width: 1.25rem;
    padding: 0.1rem 0.35rem;
    border: 1px solid var(--color-border-subtle);
    border-radius: 4px;
    background: var(--color-surface);
    font-family: inherit;
    font-size: 0.6875rem;
    line-height: 1.3;
    color: var(--color-text-muted);
}

.workspace-panel {
    border: 1px solid var(--color-border-subtle);
    border-radius: 6px;
    background: var(--color-surface);
    margin-bottom: 0.65rem;
}

.workspace-panel > summary {
    padding: 0.55rem 0.75rem;
    font-size: 0.875rem;
    font-weight: 600;
    list-style: none;
    user-select: none;
}

.workspace-panel > summary::-webkit-details-marker {
    display: none;
}

.workspace-panel > summary::before {
    content: "▸";
    display: inline-block;
    margin-right: 0.4rem;
    color: var(--color-text-muted);
    transition: transform var(--transition-fast);
}

.workspace-panel[open] > summary::before {
    transform: rotate(90deg);
}

.workspace-panel--enhanced > .workspace-panel__body {
    transition: max-height var(--transition-panel);
}

.workspace-panel--enhanced > summary {
    cursor: pointer;
    transition: background var(--transition-fast);
}

.workspace-panel--enhanced > summary:hover {
    background: var(--color-surface-raised, rgba(127, 127, 127, 0.06));
}

.workspace-panel--enhanced[open] > summary {
    border-bottom: 1px solid var(--color-border-subtle);
}

.workspace-panel__body {
    padding: 0 0.75rem 0.75rem;
    font-size: 0.9rem;
}

.workspace-meta {
    display: grid;
    grid-template-columns: minmax(6rem, auto) 1fr;
    gap: 0.35rem 1rem;
    margin: 0 0 1.25rem;
    font-size: 0.9rem;
}

.workspace-meta dt {
    margin: 0;
    color: var(--color-text-muted);
    font-weight: normal;
}

.workspace-meta dd {
    margin: 0;
}

.workspace-context-links {
    margin: 0;
    padding: 0;
    list-style: none;
}

.workspace-context-links__item {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    margin-bottom: 0.65rem;
}

.workspace-context-links__item:last-child {
    margin-bottom: 0;
}

.workspace-context-links__label {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.workspace-context-links__item a {
    font-size: 0.9rem;
    text-decoration: none;
}

.workspace-context-links__item a:hover {
    text-decoration: underline;
}

.work-task-activity__feed {
    margin: 0 0 1rem;
    padding: 0;
    list-style: none;
}

.work-task-activity__entry {
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--color-border-subtle);
}

.work-task-activity__entry:last-child {
    border-bottom: none;
}

.work-task-activity__entry--pending {
    opacity: 0.75;
}

.work-task-activity__meta {
    margin: 0 0 0.35rem;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

.work-task-activity__form-status {
    margin: 0.35rem 0 0;
    font-size: 0.875rem;
    color: var(--color-text-muted);
}

.work-task-activity__form-status--error {
    color: var(--color-destructive, #b42318);
}

.work-task-checklist__items {
    margin: 0 0 1rem;
    padding: 0;
    list-style: none;
}

.work-task-checklist__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.35rem 0;
    border-bottom: 1px solid var(--color-border-subtle);
}

.work-task-checklist__item:last-child {
    border-bottom: none;
}

.work-task-checklist__item--checked .checkbox-label {
    color: var(--color-text-muted);
    text-decoration: line-through;
}

.empty-state {
    margin: 0.5rem 0;
    color: var(--color-text-muted);
    font-size: 0.9rem;
}

.empty-state__action {
    margin-top: 0.35rem;
}

/* Narrow phones — workspace header, breadcrumbs, and actions */
@media (max-width: 480px) {
    .layout-workspace .app-topbar {
        padding: 0.5rem 0.65rem;
        gap: 0.35rem;
    }

    .layout-workspace .user-menu__email {
        max-width: 6.5rem;
    }

    .workspace-header {
        flex-direction: column;
        align-items: stretch;
        gap: 0.65rem;
        padding: 0.65rem 0.75rem;
    }

    .workspace-header__start {
        align-items: center;
        gap: 0.5rem;
        min-width: 0;
    }

    .workspace-header__end {
        width: 100%;
        flex-shrink: 1;
    }

    .workspace-close {
        width: 2.75rem;
        height: 2.75rem;
        font-size: 1.35rem;
    }

    .workspace-header .breadcrumbs {
        flex: 1;
        min-width: 0;
        overflow: hidden;
    }

    .workspace-header .breadcrumbs__list {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        gap: 0;
        padding-bottom: 1px;
    }

    .workspace-header .breadcrumbs__list::-webkit-scrollbar {
        display: none;
    }

    .workspace-header .breadcrumbs__item {
        flex-shrink: 0;
    }

    .workspace-header .breadcrumbs__item a,
    .workspace-header .breadcrumbs__item span[aria-current="page"] {
        display: inline-block;
        max-width: 7.5rem;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        vertical-align: bottom;
    }

    .workspace-header .breadcrumbs__item span[aria-current="page"] {
        max-width: 9rem;
    }

    .workspace-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.5rem;
        width: 100%;
    }

    .workspace-actions .save-status {
        grid-column: 1 / -1;
        margin: 0;
        text-align: center;
    }

    .workspace-actions .inline-form {
        display: block;
        width: 100%;
    }

    .workspace-actions #work-task-start-timer,
    .workspace-actions .inline-form button {
        width: 100%;
        min-height: 2.75rem;
        padding-left: 0.5rem;
        padding-right: 0.5rem;
        text-align: center;
    }

    .workspace-title-input {
        font-size: 1.125rem;
    }

    .property-bar {
        gap: 0.35rem;
    }

    .property-chip {
        min-height: 2.25rem;
        padding-top: 0.35rem;
        padding-bottom: 0.35rem;
    }

    .workspace-footer {
        padding: 0.5rem 0.75rem;
    }

    .workspace-shortcuts {
        gap: 0.35rem 0.5rem;
    }

    .workspace-shortcuts__item:nth-child(3) {
        display: none;
    }
}

@media (max-width: 960px) {
    .workspace-grid {
        grid-template-columns: 1fr;
    }

    .workspace-main,
    .workspace-rail {
        padding: 0.75rem;
    }

    .workspace-rail {
        border-left: none;
        border-top: 1px solid var(--color-border-subtle);
    }
}

@media (prefers-reduced-motion: reduce) {
    .workspace-panel > summary::before {
        transition: none;
    }

    .property-popover {
        animation: none;
    }

    .property-chip {
        transition: none;
    }

    .property-chip:active {
        transform: none;
    }
}
