:root {
    color-scheme: light;
    --radius-lg: 14px;
    --radius-md: 11px;
    --radius-pill: 9999px;
    --radius-dropdown: 14px;
    --topbar-height: 62px;
    --color-primary: #004cff;
    --color-secondary: #fa5800;
    --color-title: #101317;
    --color-text: #262c37;
    --color-muted: #5b6474;
    --color-background: #fafafa;
    --color-surface: rgba(255, 255, 255, 0.8);
    --color-surface-strong: #ffffff;
    --color-surface-soft: #f7f7f6;
    --color-surface-raised: #f7f7f6;
    --color-surface-input: #ffffff;
    --color-surface-muted-alt: #f5f3ef;
    --color-surface-quiet: #efefec;
    --color-border: rgba(15, 23, 42, 0.08);
    --color-border-strong: rgba(15, 23, 42, 0.14);
    --color-shadow: rgba(15, 23, 42, 0.08);
    --color-overlay: rgba(255, 255, 255, 0.72);
    --color-inverse: #ffffff;
    --color-success: #129a58;
    --color-danger: #d9485f;
    --color-warning: #fa5800;
    --color-avatar-accent: #c7688b;
    --color-kanban-column: #f2f2f2;
    --hero-background: linear-gradient(145deg, #081227 0%, #004cff 52%, #0c1730 100%);
    --hero-border: rgba(255, 255, 255, 0.14);
    --hero-text: rgba(255, 255, 255, 0.92);
    --hero-muted: rgba(226, 232, 240, 0.72);
    --hero-surface: rgba(255, 255, 255, 0.06);
    --hero-surface-border: rgba(255, 255, 255, 0.1);
    --theme-toggle-bg: rgba(255, 255, 255, 0.74);
    --theme-toggle-text: #101317;
}

:root[data-theme='dark'] {
    color-scheme: dark;
    --color-title: #f3f6fb;
    --color-text: #d6deee;
    --color-muted: #95a3ba;
    --color-background: #131313;
    --color-surface: #101010;
    --color-surface-strong: #101010;
    --color-surface-soft: #161616;
    --color-surface-raised: #171717;
    --color-surface-input: #1b1b1b;
    --color-surface-muted-alt: #151515;
    --color-surface-quiet: #1d1d1d;
    --color-border: rgba(148, 163, 184, 0.18);
    --color-border-strong: rgba(148, 163, 184, 0.26);
    --color-shadow: rgba(2, 6, 23, 0.34);
    --color-overlay: rgba(8, 16, 29, 0.78);
    --color-inverse: #08101d;
    --color-success: #2dbf74;
    --color-danger: #ff6b81;
    --color-avatar-accent: #e4b2c5;
    --color-kanban-column: #181818;
    --hero-background: linear-gradient(145deg, #050b17 0%, #004cff 58%, #111b31 100%);
    --theme-toggle-bg: rgba(10, 17, 31, 0.78);
    --theme-toggle-text: #f3f6fb;
}

@font-face {
    font-family: 'Geist';
    src: url('https://cdn.jsdelivr.net/npm/geist@1.7.0/dist/fonts/geist-sans/Geist-Variable.woff2') format('woff2');
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Geist';
    src: url('https://cdn.jsdelivr.net/npm/geist@1.7.0/dist/fonts/geist-sans/Geist-Italic[wght].woff2') format('woff2');
    font-weight: 100 900;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Geist Mono';
    src: url('https://cdn.jsdelivr.net/npm/geist@1.7.0/dist/fonts/geist-mono/GeistMono-Variable.woff2') format('woff2');
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

html {
    font-family: 'Geist', ui-sans-serif, system-ui, sans-serif;
    font-size: 15px;
}

body {
    color: var(--color-text);
    background: var(--color-background);
    transition: background-color 180ms ease, color 180ms ease;
}

:where(
    a[href],
    button:not(:disabled),
    [type='button']:not(:disabled),
    [type='submit']:not(:disabled),
    [type='reset']:not(:disabled),
    summary,
    [role='button']:not([aria-disabled='true'])
) {
    cursor: pointer;
}

:where(
    button:disabled,
    [type='button']:disabled,
    [type='submit']:disabled,
    [type='reset']:disabled,
    [aria-disabled='true']
) {
    cursor: not-allowed;
}

code,
kbd,
pre,
samp {
    font-family: 'Geist Mono', ui-monospace, SFMono-Regular, monospace;
}

.app-bg {
    background: var(--color-background);
}

:root[data-page-ready='false'] {
    overflow: hidden;
}

:root[data-page-ready='false'][data-skeleton-scope='content'] {
    overflow: auto;
}

:root[data-skeleton-scope='content'] .ds-shell__content > * {
    transition: opacity 100ms ease;
}

:root[data-page-ready='false'][data-skeleton-scope='content'] .ds-shell__content > * {
    opacity: 0;
    pointer-events: none;
}

.ds-page-loader {
    position: fixed;
    inset: 0;
    z-index: 999;
    display: flex;
    width: 100%;
    min-height: 100vh;
    background: var(--color-background);
    opacity: 1;
    visibility: visible;
    transition: opacity 120ms ease, visibility 120ms ease;
}

:root[data-page-ready='true'] .ds-page-loader {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.ds-page-loader__viewport {
    display: flex;
    flex-direction: column;
    width: 100%;
    min-height: 100vh;
}

.ds-page-loader[data-scope='content'] {
    --loader-sidebar-width: 248px;
    top: var(--topbar-height);
    right: 0;
    bottom: 0;
    left: var(--loader-sidebar-width);
    min-height: calc(100vh - var(--topbar-height));
    padding: 14px 14px 0;
    background: var(--color-background);
}

:root[data-sidebar-collapsed='true'] .ds-page-loader[data-scope='content'] {
    --loader-sidebar-width: 60px;
}

.ds-page-loader__viewport--content {
    min-height: calc(100vh - var(--topbar-height));
}

.ds-page-loader__main--content {
    display: flex;
    flex-direction: column;
    gap: 0.95rem;
    min-width: 0;
}

.ds-page-loader[data-variant='kanban'][data-scope='content'] {
    overflow: hidden;
}

.ds-page-loader[data-variant='kanban'][data-scope='content'] .ds-page-loader__viewport--content {
    width: 100%;
    max-width: 1800px;
    margin: 0 auto;
    min-height: calc(100dvh - var(--topbar-height) - 14px);
}

.ds-page-loader[data-variant='kanban'][data-scope='content'] .ds-page-loader__main--content {
    height: 100%;
}

.ds-page-loader__viewport--shell {
    background: var(--color-background);
}

.ds-page-loader[data-variant='app-shell'] {
    --sidebar-width: 248px;
}

:root[data-sidebar-collapsed='true'] .ds-page-loader[data-variant='app-shell'] {
    --sidebar-width: 60px;
}

.ds-page-loader__topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: var(--topbar-height);
    padding: 0.72rem 1.2rem;
    border-bottom: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-surface) 92%, transparent);
}

.ds-page-loader__group {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.ds-page-loader__group--leading {
    min-width: 0;
}

.ds-page-loader__group--trailing {
    flex-shrink: 0;
}

.ds-page-loader__group--between {
    justify-content: space-between;
    align-items: flex-start;
}

.ds-page-loader__stack {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.ds-page-loader__stack--wide {
    gap: 0.75rem;
}

.ds-page-loader__shell {
    display: grid;
    grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
    min-height: calc(100vh - var(--topbar-height));
}

.ds-page-loader__sidebar {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 0.9rem;
    border-right: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-surface-strong) 88%, transparent);
}

.ds-page-loader__nav-list {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    gap: 0.45rem;
}

.ds-page-loader__nav-item {
    display: flex;
    align-items: center;
    gap: 0.78rem;
    padding: 0.7rem 0.8rem;
    border-radius: var(--radius-md);
}

.ds-page-loader__sidebar-footer {
    display: flex;
    padding-top: 0.9rem;
    border-top: 1px solid var(--color-border);
}

.ds-page-loader__main {
    display: flex;
    flex-direction: column;
    gap: 0.95rem;
    min-width: 0;
    padding: 14px 14px 0;
}

.ds-page-loader__content-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.ds-page-loader__panel,
.ds-page-loader__default-card,
.ds-page-loader__auth-panel {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: color-mix(in srgb, var(--color-surface) 94%, transparent);
    box-shadow: 0 18px 48px color-mix(in srgb, var(--color-shadow) 42%, transparent);
}

.ds-page-loader__panel {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.1rem;
}

.ds-page-loader__panel--hero {
    min-height: 158px;
    justify-content: space-between;
}

.ds-page-loader__panel--card {
    min-height: 280px;
}

.ds-page-loader__panel--tall {
    min-height: 332px;
    grid-column: 1 / -1;
}

.ds-page-loader__rows {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.ds-page-loader__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
}

.ds-page-loader__row--align-start {
    justify-content: flex-start;
}

.ds-page-loader__chips-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.ds-page-loader__shimmer {
    position: relative;
    display: block;
    overflow: hidden;
    background: color-mix(in srgb, var(--color-surface-soft) 88%, var(--color-surface-strong));
}

.ds-page-loader__shimmer::after {
    content: '';
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent 0%, color-mix(in srgb, var(--color-inverse) 18%, transparent) 48%, transparent 100%);
    animation: ds-skeleton-shimmer 1.3s ease-in-out infinite;
}

.ds-page-loader__logo {
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 0.8rem;
}

.ds-page-loader__avatar {
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 999px;
}

.ds-page-loader__icon,
.ds-page-loader__dot {
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 0.85rem;
}

.ds-page-loader__dot {
    width: 0.9rem;
    height: 0.9rem;
    border-radius: 999px;
}

.ds-page-loader__line {
    height: 0.78rem;
    border-radius: 999px;
}

.ds-page-loader__line--xs {
    width: 5.5rem;
}

.ds-page-loader__line--sm {
    width: 8.5rem;
}

.ds-page-loader__line--md {
    width: 12.5rem;
}

.ds-page-loader__line--lg {
    width: min(24rem, 56vw);
    height: 1rem;
}

.ds-page-loader__chip {
    width: 6.5rem;
    height: 2rem;
    border-radius: 999px;
}

.ds-page-loader__chip--compact {
    width: 4.2rem;
    height: 1.1rem;
}

.ds-page-loader__chip--long {
    width: 8.5rem;
}

.ds-page-loader__metric {
    width: 9.5rem;
    height: 3rem;
    border-radius: 1.1rem;
}

.ds-page-loader__tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.ds-page-loader__tab {
    width: 7rem;
    height: 2rem;
    border-radius: 999px;
}

.ds-page-loader__dot--soft {
    width: 1.2rem;
    height: 1.2rem;
}

.ds-page-loader__line--lg-soft {
    width: min(20rem, 42vw);
}

.ds-page-loader__content-grid--dashboard {
    align-items: start;
}

.ds-page-loader__panel--dashboard-main {
    min-height: 420px;
}

.ds-page-loader__panel--dashboard-side {
    min-height: 420px;
}

.ds-page-loader__row--task {
    justify-content: flex-start;
}

.ds-page-loader__project-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.ds-page-loader__project-card {
    display: grid;
    grid-template-columns: 3.4rem minmax(0, 1fr);
    gap: 0.8rem;
    align-items: start;
    padding: 0.75rem;
    border-radius: calc(var(--radius-lg) - 4px);
    background: color-mix(in srgb, var(--color-surface-soft) 78%, transparent);
}

.ds-page-loader__project-tile {
    width: 3.4rem;
    height: 3.4rem;
    border-radius: 1rem;
}

.ds-page-loader__kanban-shell {
    position: relative;
    flex: 1 1 auto;
    display: flex;
    min-height: 0;
}

.ds-page-loader__kanban-canvas {
    position: relative;
    flex: 1 1 auto;
    min-height: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 0;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.ds-page-loader__kanban-canvas::-webkit-scrollbar {
    width: 0;
    height: 0;
}

.ds-page-loader__kanban-columns {
    display: inline-flex;
    align-items: stretch;
    flex-wrap: nowrap;
    gap: 1rem;
    min-width: max-content;
    height: 100%;
}

.ds-page-loader__kanban-inserter {
    display: none;
}

.ds-page-loader__kanban-column {
    display: flex;
    flex: 0 0 340px;
    flex-direction: column;
    gap: 0.85rem;
    width: 340px;
    min-width: 340px;
    max-width: 340px;
    height: 100%;
    min-height: 0;
    padding: 0.95rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 78%, transparent);
    border-radius: 14px;
    background: var(--color-kanban-column);
    scroll-snap-align: start;
}

.ds-page-loader__kanban-cards {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    gap: 0.95rem;
    min-height: 0;
    overflow: hidden;
}

.ds-page-loader__kanban-card {
    display: flex;
    flex-direction: column;
    gap: 0.95rem;
    padding: 0.9rem;
    border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--color-border) 86%, transparent);
    background: color-mix(in srgb, var(--color-surface-strong) 98%, transparent);
}

.ds-page-loader__kanban-add {
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
}

.ds-page-loader__kanban-composer {
    display: grid;
    gap: 0.75rem;
    padding: 1rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 88%, transparent);
    border-radius: 24px;
    background: color-mix(in srgb, var(--color-surface-strong) 96%, transparent);
}

.ds-page-loader__panel--billing-hero {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    min-height: 136px;
}

.ds-page-loader__button--cta {
    width: 9rem;
    flex-shrink: 0;
}

.ds-page-loader__billing-list {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.ds-page-loader__billing-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.15rem;
    border: 1px solid var(--color-border);
    border-radius: calc(var(--radius-lg) - 2px);
    background: color-mix(in srgb, var(--color-surface) 94%, transparent);
}

.ds-page-loader__billing-meta {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.ds-page-loader__profile-wrap {
    display: flex;
    justify-content: center;
    padding-top: 0.5rem;
}

.ds-page-loader__panel--profile {
    width: min(100%, 64rem);
    min-height: 280px;
}

.ds-page-loader__profile-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.ds-page-loader__profile-card {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    padding: 1rem;
    border-radius: calc(var(--radius-lg) - 4px);
    background: color-mix(in srgb, var(--color-surface-soft) 78%, transparent);
}

.ds-page-loader__viewport--auth {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
    gap: 0;
    padding: 1.2rem;
}

.ds-page-loader__auth-media {
    border-radius: calc(var(--radius-lg) + 8px);
    background: linear-gradient(145deg, color-mix(in srgb, var(--color-primary) 24%, var(--color-surface-soft)) 0%, color-mix(in srgb, var(--color-background) 18%, var(--color-surface-soft)) 100%);
}

.ds-page-loader__auth-panel {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 2rem;
    padding: clamp(1.4rem, 2.2vw, 2.4rem);
    margin-left: 1.2rem;
}

.ds-page-loader__auth-logo {
    width: 10rem;
    height: 4.8rem;
    border-radius: 1.25rem;
}

.ds-page-loader__auth-form {
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
    width: min(100%, 22rem);
}

.ds-page-loader__fields {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.ds-page-loader__field,
.ds-page-loader__button {
    width: 100%;
    height: 2.9rem;
    border-radius: 1rem;
}

.ds-page-loader__button {
    height: 3rem;
}

.ds-page-loader__switch {
    width: 2.6rem;
    height: 1.45rem;
    border-radius: 999px;
}

.ds-page-loader__viewport--default {
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
}

.ds-page-loader__default-card {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    width: min(100%, 48rem);
    padding: 1.4rem;
}

@keyframes ds-skeleton-shimmer {
    100% {
        transform: translateX(100%);
    }
}

@media (prefers-reduced-motion: reduce) {
    .ds-page-loader,
    .ds-page-loader__shimmer::after {
        animation: none;
        transition: none;
    }
}

.ds-shell {
    --sidebar-width: 248px;
    display: flex;
    flex-direction: column;
    min-height: 100dvh;
    height: 100dvh;
    overflow: hidden;
    background: var(--color-background);
}

:root[data-sidebar-collapsed='true'] .ds-shell,
.ds-shell[data-sidebar-collapsed='true'] {
    --sidebar-width: 60px;
}

.ds-shell__layout {
    display: grid;
    grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
    min-height: 0;
    height: calc(100dvh - var(--topbar-height));
    transition: grid-template-columns 240ms cubic-bezier(0.22, 1, 0.36, 1);
}

.ds-sidebar {
    position: relative;
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
    padding: 0.9rem;
    border-right: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-surface-strong) 88%, transparent);
    overflow: hidden;
    transition: padding 240ms cubic-bezier(0.22, 1, 0.36, 1);
}

.ds-sidebar__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 1.15rem;
}

.ds-brand {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-width: 0;
}

.ds-brand--topbar {
    flex-shrink: 0;
}

.ds-brand__logo {
    width: 2rem;
    height: 2rem;
    flex-shrink: 0;
}

.ds-brand__meta {
    display: flex;
    flex-direction: column;
    min-width: 0;
    max-width: 120px;
    overflow: hidden;
    transition: max-width 220ms ease, opacity 180ms ease, transform 220ms ease;
}

.ds-brand__title {
    color: var(--color-title);
    font-size: 0.88rem;
    font-weight: 600;
    line-height: 1.1;
}

.ds-brand__subtitle {
    color: var(--color-muted);
    font-size: 0.66rem;
}

.ds-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.15rem;
    height: 2.15rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    background: var(--color-surface-soft);
    color: var(--color-title);
    transition: background 160ms ease, border-color 160ms ease, transform 160ms ease;
}

.ds-icon-button:hover {
    background: var(--color-surface-strong);
    border-color: var(--color-border-strong);
    transform: translateY(-1px);
}

.ds-sidebar__nav {
    display: flex;
    flex: 1 1 auto;
    min-height: 0;
    flex-direction: column;
    gap: 0.3rem;
    overflow-y: auto;
    padding-right: 0.15rem;
}

.ds-nav-item {
    position: relative;
    isolation: isolate;
    display: flex;
    align-items: center;
    gap: 0.78rem;
    min-width: 0;
    width: 100%;
    border-radius: var(--radius-md);
    padding: 0.7rem 0.8rem;
    overflow: hidden;
    color: var(--color-text);
    transition: color 180ms ease;
}

.ds-nav-item::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: color-mix(in srgb, var(--color-primary) 3%, transparent);
    opacity: 0;
    transform: scaleX(0.72);
    transform-origin: left center;
    transition: opacity 180ms ease, transform 240ms cubic-bezier(0.22, 1, 0.36, 1);
    z-index: -1;
}

.ds-nav-item:hover {
    color: var(--color-text);
}

.ds-nav-item:hover::before {
    opacity: 1;
    transform: scaleX(1);
}

.ds-nav-item.is-active {
    color: var(--color-primary);
}

.ds-nav-item.is-active::before {
    opacity: 1;
    transform: scaleX(1);
}

.ds-nav-item__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.ds-nav-item__label {
    min-width: 0;
    overflow: hidden;
    font-size: 0.92rem;
    font-weight: 500;
    white-space: nowrap;
    transition: max-width 220ms ease, opacity 180ms ease, transform 220ms ease;
}

.ds-sidebar__footer {
    margin-top: auto;
    padding-top: 0.9rem;
    display: flex;
    justify-content: flex-start;
    border-top: 1px solid var(--color-border);
}

.ds-theme-switch {
    color: var(--color-primary);
}

.ds-shell__body {
    min-width: 0;
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
}

.ds-topbar {
    position: relative;
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-shrink: 0;
    min-height: var(--topbar-height);
    padding: 0.72rem 1.2rem;
    border-bottom: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--color-surface) 92%, transparent);
    backdrop-filter: blur(16px);
}

.ds-topbar__leading {
    display: flex;
    align-items: center;
    gap: 0.95rem;
    min-width: 0;
}

.ds-topbar__breadcrumbs {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
}

.ds-breadcrumb {
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--color-title);
    white-space: nowrap;
}

.ds-breadcrumb--parent {
    opacity: 0.48;
}

.ds-breadcrumb__divider {
    color: var(--color-muted);
    opacity: 0.55;
}

.ds-project-menu {
    --project-accent: var(--color-primary);
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
}

.ds-project-menu__main {
    position: relative;
    display: flex;
    align-items: center;
    gap: 1rem;
    min-width: 0;
}

.ds-project-menu__name-input {
    min-width: 0;
    width: auto;
    flex: 0 1 auto;
    field-sizing: content;
    max-width: min(520px, 100%);
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-title);
    font-size: 0.98rem;
    font-weight: 600;
    letter-spacing: normal;
    line-height: 1.1;
}

.ds-project-menu__name-input[readonly] {
    cursor: pointer;
}

.ds-project-menu__name-input:focus {
    outline: none;
}

.ds-project-menu__controls {
    position: relative;
    flex-shrink: 0;
}

.ds-project-menu__trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    background: color-mix(in srgb, var(--project-accent) 12%, var(--color-surface-soft));
    color: var(--color-title);
    transition: transform 160ms ease, border-color 160ms ease;
}

.ds-project-menu__trigger:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--project-accent) 28%, var(--color-border-strong));
}

.ds-project-menu__trigger svg {
    width: 1rem;
    height: 1rem;
}

.ds-options-dropdown,
.ds-project-menu__dropdown {
    position: absolute;
    top: calc(100% + 0.55rem);
    right: 0;
    z-index: 60;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    width: 220px;
    padding: 0.55rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-dropdown);
    background: var(--color-surface-strong);
    box-shadow: 0 24px 64px var(--color-shadow);
}

.ds-options-dropdown__form {
    width: 100%;
}

.ds-options-dropdown__action,
.ds-project-menu__action {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 2.3rem;
    padding: 0.56rem 0.72rem;
    border-radius: var(--radius-md);
    color: var(--color-title);
    font-size: 0.82rem;
    font-weight: 500;
    text-align: left;
    transition: background 160ms ease;
}

.ds-options-dropdown__action:hover,
.ds-project-menu__action:hover {
    background: var(--color-surface-soft);
}

.ds-options-dropdown__action--danger,
.ds-project-menu__action--danger {
    color: var(--color-danger);
}

.ds-options-dropdown--tabbed {
    gap: 0.8rem;
    width: min(360px, calc(100vw - 2rem));
    padding: 0.7rem;
}

.ds-options-tabs {
    display: grid;
    gap: 0.75rem;
}

.ds-options-tabs__list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.35rem;
    padding: 0.2rem;
    border-radius: var(--radius-md);
    background: var(--color-surface-soft);
}

.ds-options-tabs__tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2rem;
    padding: 0.4rem 0.7rem;
    border: 0;
    border-radius: calc(var(--radius-md) - 3px);
    background: transparent;
    color: var(--color-muted);
    font-size: 0.8rem;
    font-weight: 500;
}

.ds-options-tabs__tab[data-state='active'] {
    background: var(--color-surface-strong);
    color: var(--color-title);
}

.ds-options-tabs__panel {
    display: grid;
    gap: 0.75rem;
}

.ds-project-menu__color-picker {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.ds-project-menu__color-chip {
    width: 0.8rem;
    height: 0.8rem;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    flex-shrink: 0;
}

.ds-project-menu__color-panel {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0.45rem;
    padding: 0 0.35rem 0.35rem;
}

.ds-project-menu__color-option {
    width: 1.5rem;
    height: 1.5rem;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.3);
}

.ds-project-menu__color-option.is-active {
    outline: 2px solid var(--color-title);
    outline-offset: 1px;
}

.ds-has-modal-open {
    overflow: hidden;
}

.ds-project-modal-portal {
    position: fixed;
    inset: 0;
    z-index: 100;
    pointer-events: none;
}

.ds-project-modal {
    position: fixed;
    inset: 0;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    pointer-events: auto;
}

.ds-project-modal__backdrop {
    display: none;
}

.ds-project-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(560px, calc(100vw - 2rem));
    max-height: min(calc(100dvh - var(--topbar-height) - 40px), 760px);
    overflow: auto;
    padding: 1.35rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
    border-radius: 14px;
    background: color-mix(in srgb, var(--color-surface-input) 84%, var(--color-surface-raised));
    box-shadow: 0 26px 70px var(--color-shadow);
}

.ds-project-modal__dialog--members {
    width: min(780px, calc(100vw - 2rem));
}

.ds-project-modal__dialog--tags {
    width: min(720px, calc(100vw - 2rem));
}

.ds-project-modal__dialog--settings {
    width: min(760px, calc(100vw - 2rem));
}

.ds-project-modal__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.ds-project-modal__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 999px;
    border: 1px solid var(--color-border);
    background: var(--color-surface-soft);
    color: var(--color-title);
}

.ds-project-modal__close svg {
    width: 0.95rem;
    height: 0.95rem;
}

.ds-project-modal__body {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1.1rem;
}

.ds-project-modal__actions {
    display: flex;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.ds-project-billing__topbar-heading {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-width: 0;
}

.ds-project-billing-page {
    display: grid;
    gap: 1rem;
}

.ds-project-billing__hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.1rem 0 0.35rem;
}

.ds-project-billing__hero-copy {
    display: grid;
    gap: 0.35rem;
}

.ds-project-billing__hero-actions {
    display: inline-flex;
    flex-shrink: 0;
}

.ds-project-billing__list-section {
    display: grid;
    gap: 0.85rem;
}

.ds-project-billing__list {
    display: grid;
    gap: 0;
}

.ds-project-billing__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    width: 100%;
    border: 0;
    padding: 1rem 0;
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
    background: transparent;
    text-align: left;
}

.ds-project-billing__item:first-child {
    border-top: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
}

.ds-project-billing__item-main {
    display: flex;
    align-items: center;
    min-width: 0;
}

.ds-project-billing__item-title {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.45rem;
    min-width: 0;
    color: var(--color-title);
    font-size: 0.96rem;
    font-weight: 600;
}

.ds-project-billing__item-title span {
    min-width: 0;
    font: inherit;
}

.ds-project-billing__item-title span:last-child {
    color: var(--color-title);
}

.ds-project-billing__item-meta {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 0.85rem;
    color: var(--color-title);
    font-size: 0.82rem;
}

.ds-project-billing__status {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.35rem 0.72rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-warning) 14%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-warning) 78%, var(--color-title));
    font-size: 0.72rem;
    font-weight: 600;
}

.ds-project-billing__status--paid {
    background: color-mix(in srgb, var(--color-success) 14%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-success) 72%, var(--color-title));
}

.ds-project-billing__empty {
    display: grid;
    gap: 0.35rem;
    padding: 1rem 0;
    border-top: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
}

.ds-project-billing__report-dialog {
    width: min(860px, calc(100vw - 2rem));
}

.ds-project-billing__report-title {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
    line-height: 1.3;
}

.ds-project-billing__detail-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1fr);
}

.ds-project-billing__detail-section {
    display: grid;
    gap: 0.85rem;
    min-width: 0;
    padding: 1rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 88%, transparent);
    border-radius: 14px;
    background: color-mix(in srgb, var(--color-surface-soft) 92%, transparent);
}

.ds-project-billing__summary-list {
    display: grid;
    gap: 0.55rem;
}

.ds-project-billing__summary-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding-bottom: 0.55rem;
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
}

.ds-project-billing__summary-row span {
    color: var(--color-muted);
    font-size: 0.8rem;
}

.ds-project-billing__summary-row strong {
    color: var(--color-title);
    font-size: 0.84rem;
    font-weight: 600;
    text-align: right;
}

.ds-project-billing__detail-actions {
    justify-content: flex-start;
}

.ds-project-billing__create-form {
    gap: 1rem;
}

.ds-project-billing__date-picker {
    width: 100%;
}

.ds-project-billing__date-picker .ds-date-range__trigger--inline {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    min-height: 3.2rem;
    padding: 0.95rem 1rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 88%, transparent);
    border-radius: 18px;
    background: color-mix(in srgb, var(--color-surface-strong) 96%, transparent);
    color: var(--color-title);
    box-shadow: inset 0 0 0 1px transparent;
}

.ds-project-billing__date-picker .ds-date-range__trigger--inline svg {
    order: 2;
    width: 1rem;
    height: 1rem;
    color: var(--color-title);
}

.ds-project-billing__date-picker .ds-date-range__trigger-text {
    color: var(--color-title);
    font-size: 0.8rem;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ds-project-billing__date-picker .ds-date-range__trigger--inline:hover,
.ds-project-billing__date-picker .ds-date-range__trigger--inline:focus-visible {
    border-color: color-mix(in srgb, var(--color-primary) 28%, var(--color-border-strong));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 12%, transparent);
}

.ds-project-billing__payment-stack {
    display: grid;
    gap: 0.85rem;
    min-height: 100%;
    align-content: start;
}

.ds-project-billing__payment-form,
.ds-project-billing__delete-form {
    display: grid;
    gap: 0.85rem;
}

.ds-project-billing__payment-actions {
    justify-content: flex-start;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.ds-project-billing__payment-actions .ds-button {
    min-width: 0;
}

.ds-project-billing__delete-form {
    display: block;
}

.ds-project-members {
    display: flex;
    flex-direction: column;
    gap: 1.15rem;
}

.ds-project-settings {
    display: grid;
    gap: 1rem;
}

.ds-project-settings__tabs {
    display: grid;
    gap: 0.95rem;
}

.ds-project-settings__panel {
    display: grid;
    gap: 1rem;
}

.ds-project-settings__form {
    display: grid;
    gap: 0.85rem;
}

.ds-project-settings__grid {
    display: grid;
    gap: 0.85rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ds-project-settings__field {
    display: grid;
    gap: 0.4rem;
}

.ds-project-settings__field--full {
    grid-column: 1 / -1;
}

.ds-project-settings__textarea {
    min-height: 120px;
    resize: vertical;
}

.ds-project-settings__metrics {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.ds-project-settings__metric {
    display: grid;
    gap: 0.35rem;
    padding: 0.9rem 1rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 86%, transparent);
    border-radius: 16px;
    background: color-mix(in srgb, var(--color-surface-soft) 92%, transparent);
}

.ds-project-settings__metric span {
    color: var(--color-muted);
    font-size: 0.74rem;
}

.ds-project-settings__metric strong {
    color: var(--color-title);
    font-size: 1rem;
    font-weight: 600;
}

.ds-project-members__section {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.ds-project-members__list {
    display: flex;
    flex-direction: column;
}

.ds-project-members__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.95rem 0;
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 86%, transparent);
}

.ds-project-members__item:first-child {
    border-top: 1px solid color-mix(in srgb, var(--color-border) 86%, transparent);
}

.ds-project-members__item--pending .ds-project-members__avatar {
    background: color-mix(in srgb, var(--color-warning) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-warning) 82%, var(--color-title));
}

.ds-project-members__identity {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
}

.ds-project-members__avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 999px;
    background: var(--avatar-background, color-mix(in srgb, var(--project-accent) 18%, var(--color-surface-soft)));
    color: var(--avatar-color, color-mix(in srgb, var(--project-accent) 68%, #1f2937));
    font-size: 0.74rem;
    font-weight: 600;
}

.ds-project-members__item-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.ds-project-members__role-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 2rem;
    padding: 0.35rem 0.78rem;
    border: 1px solid var(--color-border-strong);
    border-radius: 999px;
    background: var(--color-surface-soft);
    color: var(--color-title);
    font-size: 0.76rem;
    font-weight: 600;
}

.ds-project-members__role-badge svg {
    width: 0.82rem;
    height: 0.82rem;
}

.ds-project-members__menu {
    min-width: 180px;
}

.ds-project-members__menu-divider {
    height: 1px;
    margin: 0.2rem 0;
    background: color-mix(in srgb, var(--color-border) 86%, transparent);
}

.ds-project-members__menu-action--active {
    color: var(--color-title);
    font-weight: 600;
    background: color-mix(in srgb, var(--project-accent) 10%, var(--color-surface-soft));
}

.ds-project-members__status {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.35rem 0.72rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-warning) 14%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-warning) 78%, var(--color-title));
    font-size: 0.72rem;
    font-weight: 600;
}

.ds-project-members__form {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.75rem;
}

.ds-project-members__form-field {
    display: flex;
    flex: 1 1 260px;
    flex-direction: column;
    gap: 0.4rem;
}

.ds-project-members__form-field--search {
    min-width: min(420px, 100%);
}

.ds-project-members__form-field--role {
    flex: 0 0 190px;
}

.ds-project-members__form-label {
    color: var(--color-muted);
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: normal;
}

.ds-project-members__combobox {
    position: relative;
}

.ds-project-members__options {
    position: absolute;
    top: calc(100% + 0.4rem);
    left: 0;
    right: 0;
    z-index: 3;
    display: flex;
    flex-direction: column;
    max-height: 220px;
    overflow: auto;
    border: 1px solid color-mix(in srgb, var(--color-border) 88%, transparent);
    border-radius: 18px;
    background: color-mix(in srgb, var(--color-surface-input) 96%, var(--color-surface-raised));
    box-shadow: 0 20px 45px rgba(15, 23, 42, 0.12);
}

.ds-project-members__option {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    width: 100%;
    padding: 0.8rem 0.95rem;
    border: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
    background: transparent;
    color: var(--color-title);
    text-align: left;
}

.ds-project-members__option:last-child {
    border-bottom: 0;
}

.ds-project-members__option:hover {
    background: color-mix(in srgb, var(--project-accent) 8%, var(--color-surface-soft));
}

.ds-project-members__option--empty {
    color: var(--color-muted);
    cursor: default;
}

.ds-project-members__option-name {
    font-size: 0.88rem;
    font-weight: 600;
}

.ds-project-members__option-email {
    font-size: 0.74rem;
    color: var(--color-muted);
}

.ds-project-members__hint {
    color: var(--color-muted);
    font-size: 0.76rem;
    line-height: 1.5;
}

.ds-project-tags {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.ds-project-tags__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: start;
}

.ds-project-tags__item {
    min-width: 0;
    max-width: 100%;
}

.ds-project-tags__chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2rem;
    padding: 0.38rem 0.78rem;
    border-radius: 999px;
    font-size: 0.88rem;
    font-weight: 400;
}

.ds-project-tags__chip--interactive {
    width: auto;
    max-width: 100%;
    justify-content: center;
    border: 0;
    text-align: left;
    cursor: pointer;
}

.ds-project-tags__chip-label {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ds-project-tags__menu {
    min-width: 280px;
}

.ds-project-tags__edit-form {
    display: grid;
    gap: 0.75rem;
}

.ds-project-tags__name-input {
    min-height: 2.7rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
    border-radius: 14px;
    padding: 0 0.9rem;
    background: var(--color-surface-input);
    color: var(--color-title);
}

.ds-project-tags__name-input:focus {
    outline: none;
}

.ds-project-tags__color-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(30px, 30px));
    gap: 0.55rem;
}

.ds-project-tags__color-option {
    position: relative;
    display: inline-flex;
}

.ds-project-tags__color-option input {
    position: absolute;
    inset: 0;
    opacity: 0;
}

.ds-project-tags__color-option span {
    width: 30px;
    height: 30px;
    border-radius: 10px;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-border) 82%, transparent);
}

.ds-project-tags__color-option input:checked + span {
    box-shadow: inset 0 0 0 2px var(--color-surface-input), 0 0 0 2px var(--color-title);
}

.ds-project-tags__submit {
    min-height: 2.5rem;
    border: 0;
    border-radius: 14px;
    background: var(--color-title);
    color: var(--color-surface-raised);
    font-size: 0.82rem;
    font-weight: 600;
}

.ds-project-tags__menu-divider {
    height: 1px;
    margin: 0.2rem 0;
    background: color-mix(in srgb, var(--color-border) 86%, transparent);
}

.ds-inline-create-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.55rem;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-muted);
    font-size: 0.88rem;
    font-weight: 500;
}

.ds-inline-create-trigger__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 999px;
    background: var(--color-surface-quiet);
    color: var(--color-muted);
    font-size: 1.1rem;
    line-height: 1;
}

.ds-inline-create-trigger--compact {
    margin-top: 0.85rem;
}

.ds-project-tags__create-shell {
    display: grid;
    width: 100%;
    justify-items: stretch;
}

.ds-project-tags__create {
    display: grid;
    gap: 0.75rem;
    margin-top: 0.85rem;
    padding-top: 0.95rem;
    border-top: 1px solid color-mix(in srgb, var(--color-border) 86%, transparent);
}

.ds-topbar__account {
    position: relative;
    z-index: 40;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.ds-topbar__session-indicator {
    display: inline-flex;
    align-items: stretch;
    gap: 0.45rem;
    min-width: 0;
}
.ds-topbar__session-link {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    min-width: 0;
    min-height: 2.2rem;
    padding: 0.3rem 0.72rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-secondary) 15%, transparent);
    color: var(--color-title);
}

.ds-topbar__session-copy {
    display: grid;
    min-width: 0;
}

.ds-topbar__session-copy strong {
    color: var(--color-title);
    font-size: 0.76rem;
    font-weight: 500;
    line-height: 1.1;
}

.ds-topbar__session-elapsed {
    color: var(--color-title);
    font-family: var(--font-mono);
    font-size: 0.8rem;
    font-weight: 500;
    white-space: nowrap;
}
.ds-topbar__session-stop-form {
    display: inline-flex;
}
.ds-topbar__session-stop {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: var(--color-title);
    color: var(--color-inverse);
}

.ds-topbar__session-stop svg {
    width: 1rem;
    height: 1rem;
}

.ds-person-avatar {
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
}

.ds-person-avatar__image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ds-person-avatar__initials {
    line-height: 1;
}

.ds-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.3rem;
    height: 2.3rem;
    border-radius: 9999px;
    background: var(--avatar-background, color-mix(in srgb, var(--color-primary) 18%, var(--color-surface-soft)));
    color: var(--avatar-color, var(--color-primary));
    font-size: 0.8rem;
    font-weight: 600;
}

.ds-avatar--compact {
    width: 2.2rem;
    height: 2.2rem;
    font-size: 0.78rem;
}

.ds-avatar--large {
    width: 2.8rem;
    height: 2.8rem;
    font-size: 0.94rem;
}

.ds-avatar-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 0;
    background: transparent;
    border-radius: var(--radius-pill);
}

.ds-avatar-button:focus-visible {
    outline: none;
    box-shadow: 0 0 0 4px rgba(0, 76, 255, 0.14);
}

.ds-topbar__account-meta {
    display: flex;
    flex-direction: column;
}

.ds-topbar__account-name {
    color: var(--color-title);
    font-size: 0.92rem;
    font-weight: 500;
    line-height: 1.1;
}

.ds-topbar__logout {
    padding-inline: 0.9rem;
}

.ds-account-modal {
    position: absolute;
    right: 0;
    top: calc(100% + 0.55rem);
    z-index: 120;
}

.ds-account-modal__panel {
    width: min(288px, calc(100vw - 1.5rem));
    border-radius: var(--radius-dropdown);
    border: 1px solid var(--color-border);
    background: var(--color-surface-strong);
    box-shadow: 0 24px 80px var(--color-shadow);
    padding: 0.9rem;
    opacity: 0;
    transform: translateY(-10px) scale(0.985);
    transform-origin: top right;
    transition: opacity 180ms ease, transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.ds-account-modal[data-state='open'] .ds-account-modal__panel {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.ds-account-modal__header {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid var(--color-border);
}

.ds-account-modal__identity {
    min-width: 0;
}

.ds-account-modal__actions {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    padding-top: 0.8rem;
}

.ds-modal-link {
    display: inline-flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;
    border-radius: var(--radius-md);
    padding: 0.68rem 0.78rem;
    color: var(--color-title);
    font-size: 0.85rem;
    font-weight: 400;
    transition: background 160ms ease, color 160ms ease;
}

.ds-modal-link:hover {
    background: var(--color-surface-soft);
}

.ds-modal-link--button {
    border: 0;
    background: transparent;
    text-align: left;
}

.ds-shell__content {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
    height: 100%;
    padding: 14px 14px 0;
    overflow-y: auto;
    overscroll-behavior: contain;
}

.ds-shell__content:has(> .ds-kanban-page--board) {
    padding-right: 0;
}

:root[data-sidebar-collapsed='true'] .ds-shell .ds-sidebar__footer,
.ds-shell[data-sidebar-collapsed='true'] .ds-sidebar__footer {
    justify-content: center;
}

:root[data-sidebar-collapsed='true'] .ds-shell .ds-sidebar .ds-nav-item,
.ds-shell[data-sidebar-collapsed='true'] .ds-sidebar .ds-nav-item {
    justify-content: center;
}

:root[data-sidebar-collapsed='true'] .ds-shell .ds-nav-item__label,
.ds-shell[data-sidebar-collapsed='true'] .ds-nav-item__label {
    max-width: 0;
    opacity: 0;
    position: absolute;
    transform: translateX(-6px);
}

:root[data-sidebar-collapsed='true'] .ds-shell .ds-nav-item,
.ds-shell[data-sidebar-collapsed='true'] .ds-nav-item {
    width: 2.5rem;
    height: 2.5rem;
    padding: 0;
    gap: 0;
}

:root[data-sidebar-collapsed='true'] .ds-shell .ds-sidebar,
.ds-shell[data-sidebar-collapsed='true'] .ds-sidebar {
    padding-inline: 0.5rem;
}

:root[data-sidebar-collapsed='true'] .ds-shell .ds-sidebar__nav,
.ds-shell[data-sidebar-collapsed='true'] .ds-sidebar__nav {
    align-items: center;
    padding-right: 0;
}

:root[data-sidebar-collapsed='true'] .ds-shell [data-sidebar-toggle] svg,
.ds-shell[data-sidebar-collapsed='true'] [data-sidebar-toggle] svg {
    transform: rotate(180deg);
}

[data-sidebar-toggle] svg {
    transition: transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.ds-panel {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    backdrop-filter: blur(18px);
}

.ds-dashboard {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.ds-dashboard__hero {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.ds-dashboard__hero-copy {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.ds-dashboard__date {
    color: var(--color-muted);
    font-size: 0.88rem;
    font-weight: 400;
}

.ds-dashboard__title {
    color: var(--color-primary);
    font-size: clamp(1.45rem, 2vw, 2rem);
    font-weight: 500;
    letter-spacing: normal;
    line-height: 0.95;
}

.ds-dashboard__summary {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.75rem;
}

.ds-dashboard__summary-bar {
    display: inline-flex;
    align-items: center;
    gap: 0;
    overflow: hidden;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-surface-strong) 88%, transparent);
}

.ds-dashboard__summary-item {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.72rem 0.95rem;
    color: var(--color-muted);
    font-size: 0.84rem;
    font-weight: 400;
}

.ds-dashboard__summary-item + .ds-dashboard__summary-item {
    border-left: 1px solid var(--color-border);
}

.ds-dashboard__summary-item strong {
    color: var(--color-title);
    font-weight: 500;
}

.ds-dashboard__summary-item svg {
    width: 1rem;
    height: 1rem;
    color: var(--color-muted);
    flex-shrink: 0;
}

.ds-dashboard__summary-action {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.72rem 0.95rem;
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    color: var(--color-title);
    background: color-mix(in srgb, var(--color-surface-strong) 92%, transparent);
    font-size: 0.84rem;
    font-weight: 400;
}

.ds-dashboard__summary-action svg {
    width: 1rem;
    height: 1rem;
    color: var(--color-primary);
}

.ds-dashboard__grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ds-dashboard-card {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.ds-dashboard-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.15rem 1.2rem 0.95rem;
}

.ds-dashboard-card__header--compact {
    align-items: center;
    padding-top: 0.95rem;
    padding-bottom: 0.8rem;
}

.ds-dashboard-card__header-main {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    min-width: 0;
}

.ds-dashboard-card__titlebar {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
}

.ds-dashboard-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-primary) 16%, var(--color-surface-soft));
    color: var(--color-primary);
    flex-shrink: 0;
}

.ds-dashboard-card__icon svg {
    width: 1.35rem;
    height: 1.35rem;
}

.ds-dashboard-card__title {
    color: var(--color-title);
    font-size: 0.98rem;
    font-weight: 500;
}

.ds-dashboard-card__subtitle {
    color: var(--color-muted);
    font-size: 0.8rem;
    margin-top: 0.15rem;
}

.ds-dashboard-card__menu {
    color: var(--color-muted);
    font-size: 1.3rem;
    line-height: 1;
}

.ds-dashboard-tabs {
    display: inline-flex;
    align-items: center;
    gap: 1.25rem;
    padding: 0 1.2rem;
    border-bottom: 1px solid var(--color-border);
}

.ds-dashboard-tab {
    position: relative;
    padding: 0 0 0.8rem;
    color: var(--color-muted);
    font-size: 0.8rem;
    font-weight: 500;
}

.ds-dashboard-tab.is-active {
    color: var(--color-title);
}

.ds-dashboard-tab.is-active::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 2px;
    border-radius: 999px;
    background: var(--color-title);
}

.ds-dashboard-tasklist {
    display: flex;
    flex-direction: column;
}

.ds-dashboard-tasklist__item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.8rem;
    padding: 0.78rem 1.2rem;
    border-bottom: 1px solid var(--color-border);
    text-decoration: none;
    transition: background 160ms ease, color 160ms ease;
}

.ds-dashboard-tasklist__item:hover {
    background: color-mix(in srgb, var(--color-primary) 4%, var(--color-surface));
}

.ds-dashboard-tasklist__content {
    min-width: 0;
}

.ds-dashboard-tasklist__title {
    color: var(--color-title);
    font-size: 0.84rem;
    font-weight: 400;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ds-dashboard-tasklist__meta {
    color: var(--color-muted);
    font-size: 0.76rem;
    margin-top: 0.12rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ds-dashboard-tasklist__tag {
    display: inline-flex;
    align-items: center;
    border-radius: var(--radius-md);
    padding: 0.38rem 0.55rem;
    background: color-mix(in srgb, var(--color-primary) 7%, var(--color-surface-soft));
    color: var(--color-title);
    font-size: 0.76rem;
    white-space: nowrap;
}

.ds-dashboard-tasklist__footer-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.9rem 1.2rem 1.05rem;
}

.ds-dashboard-tasklist__footer {
    display: inline-flex;
    align-items: center;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-muted);
    font-size: 0.82rem;
    font-weight: 500;
    cursor: pointer;
}

.ds-dashboard-tasklist__footer:hover {
    color: var(--color-title);
}

.ds-dashboard-projects {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    padding: 0 1.2rem 1.2rem;
}

.ds-dashboard-project {
    display: flex;
    align-items: flex-start;
    gap: 0.9rem;
    min-width: 0;
    padding: 0.35rem;
    border-radius: calc(var(--radius-md) + 4px);
    color: inherit;
    text-decoration: none;
    transition: background 160ms ease;
}

.ds-dashboard-project:hover {
    background: color-mix(in srgb, var(--color-surface-soft) 88%, transparent);
}

.ds-dashboard-project--create {
    align-items: stretch;
}

.ds-dashboard-project__tile {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-primary) 16%, white);
    color: #11203d;
    flex-shrink: 0;
}

.ds-dashboard-project__tile--alt {
    background: color-mix(in srgb, var(--color-secondary) 20%, white);
    color: #492211;
}

.ds-dashboard-project__tile--mint {
    background: #b7eee5;
    color: #163d37;
}

.ds-dashboard-project__tile--create {
    background: transparent;
    border: 1px dashed var(--color-border-strong);
    color: var(--color-muted);
}

.ds-dashboard-project__tile svg {
    width: 1.6rem;
    height: 1.6rem;
}

.ds-dashboard-project__body {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.28rem;
    justify-content: center;
    align-self: center;
}

.ds-dashboard-project__form {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    margin-top: 0.35rem;
}

.ds-dashboard-project__input {
    padding: 0.58rem 0.72rem;
    font-size: 0.8rem;
}

.ds-dashboard-project__submit {
    align-self: flex-start;
}

.ds-dashboard-project__title {
    color: var(--color-title);
    font-size: 0.94rem;
    font-weight: 500;
    line-height: 1.35;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ds-dashboard-project__meta,
.ds-dashboard-project__description {
    color: var(--color-muted);
    font-size: 0.8rem;
    line-height: 1.45;
}

.ds-dashboard-project__meta {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
}

.ds-dashboard-project__meta svg {
    width: 0.85rem;
    height: 0.85rem;
}

.ds-dashboard-project__description {
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ds-dashboard-project__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-top: 0.1rem;
}

.ds-dashboard-project__chip {
    display: inline-flex;
    align-items: center;
    min-height: 1.55rem;
    border-radius: var(--radius-pill);
    padding: 0.18rem 0.48rem;
    background: color-mix(in srgb, var(--color-primary) 7%, var(--color-surface-soft));
    color: var(--color-title);
    font-size: 0.7rem;
    font-weight: 500;
}

.ds-dashboard-projects__empty {
    grid-column: 1 / -1;
    color: var(--color-muted);
    font-size: 0.84rem;
}

.ds-profile-panel {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    padding: 1.1rem;
}

.ds-profile-panel__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.ds-profile-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.ds-profile-photo-field {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: color-mix(in srgb, var(--color-surface-soft) 88%, transparent);
}

.ds-profile-photo-field__avatar,
.ds-profile-photo-field__image {
    width: 5rem;
    height: 5rem;
    border-radius: 999px;
    flex-shrink: 0;
}

.ds-profile-photo-field__avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
}

.ds-profile-photo-field__image {
    object-fit: cover;
    border: 1px solid var(--color-border);
    background: var(--color-surface-strong);
}

.ds-profile-photo-field__copy {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    gap: 0.45rem;
    min-width: 0;
}

.ds-profile-form__actions {
    display: flex;
    justify-content: flex-start;
}

.ds-profile-form__error {
    color: var(--color-danger);
    font-size: 0.72rem;
    line-height: 1.35;
}

.ds-panel-strong {
    background: var(--color-surface-strong);
    border: 1px solid var(--color-border);
    box-shadow: 0 18px 60px rgba(15, 23, 42, 0.08);
}

.ds-surface-soft {
    background: var(--color-surface-soft);
    border: 1px solid var(--color-border);
}

.ds-column {
    background: color-mix(in srgb, var(--color-surface-soft) 92%, transparent);
    border: 1px solid var(--color-border);
    box-shadow: 0 18px 60px var(--color-shadow);
}

.ds-hero {
    background: var(--hero-background);
    color: var(--hero-text);
    border: 1px solid var(--hero-border);
    box-shadow: 0 32px 120px rgba(2, 6, 23, 0.3);
}

.ds-hero-card {
    background: var(--hero-surface);
    border: 1px solid var(--hero-surface-border);
    backdrop-filter: blur(16px);
}

.ds-hero-kicker,
.ds-kicker {
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: normal;
}

.ds-hero-kicker {
    color: var(--hero-muted);
}

.ds-kicker {
    color: var(--color-muted);
}

.ds-title {
    color: var(--color-title);
}

.ds-text {
    color: var(--color-text);
}

.ds-muted {
    color: var(--color-muted);
}

.ds-inverse-text {
    color: var(--hero-text);
}

.ds-chip {
    display: inline-flex;
    align-items: center;
    border-radius: var(--radius-pill);
    padding: 0.48rem 0.82rem;
    border: 1px solid var(--color-border);
    background: var(--color-overlay);
    color: var(--color-muted);
    font-size: 0.66rem;
    font-weight: 500;
    letter-spacing: normal;
}

.ds-chip-inverse {
    border-color: var(--hero-surface-border);
    background: var(--hero-surface);
    color: var(--hero-muted);
}

.ds-input {
    width: 100%;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-strong);
    background: var(--color-surface-soft);
    color: var(--color-title);
    font-size: 0.9rem;
    transition: border-color 160ms ease, background 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.ds-input::placeholder {
    color: var(--color-muted);
}

.ds-input:focus {
    outline: none;
    border-color: rgba(0, 76, 255, 0.42);
    background: var(--color-surface-strong);
    box-shadow: 0 0 0 4px rgba(0, 76, 255, 0.12);
}

.ds-input-group {
    position: relative;
}

.ds-input-group .ds-input {
    padding-right: 4.1rem;
}

.ds-input-action {
    position: absolute;
    right: 0.65rem;
    top: 50%;
    transform: translateY(-50%);
    border: 0;
    background: transparent;
    color: var(--color-muted);
    font-size: 0.68rem;
    font-weight: 500;
    line-height: 1;
    cursor: pointer;
    transition: color 160ms ease;
}

.ds-input-action:hover {
    color: var(--color-title);
}

.ds-input-action:focus-visible {
    outline: none;
    color: var(--color-primary);
}

.ds-checkbox {
    accent-color: var(--color-primary);
}

.ds-switch {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    color: var(--color-muted);
    font-size: 0.72rem;
    line-height: 1.2;
}

.ds-switch__input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.ds-switch__control {
    position: relative;
    display: inline-flex;
    align-items: center;
    width: 2.2rem;
    height: 1.3rem;
    border-radius: var(--radius-pill);
    background: color-mix(in srgb, var(--color-muted) 28%, transparent);
    transition: background 160ms ease, box-shadow 160ms ease;
    flex-shrink: 0;
}

.ds-switch__thumb {
    position: absolute;
    left: 2px;
    width: 0.95rem;
    height: 0.95rem;
    border-radius: var(--radius-pill);
    background: #ffffff;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.18);
    transition: transform 160ms ease;
}

.ds-switch__input:focus-visible + .ds-switch__control {
    box-shadow: 0 0 0 4px rgba(0, 76, 255, 0.14);
}

.ds-switch__input:checked + .ds-switch__control {
    background: var(--color-primary);
}

.ds-switch__input:checked + .ds-switch__control .ds-switch__thumb {
    transform: translateX(0.9rem);
}

.ds-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    padding: 0.62rem 0.9rem;
    font-size: 0.82rem;
    font-weight: 500;
    transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.ds-button:hover {
    transform: translateY(-1px);
}

.ds-button:disabled {
    cursor: not-allowed;
    opacity: 0.55;
    transform: none;
}

.ds-button-primary {
    background: var(--color-primary);
    color: #ffffff;
}

.ds-button-secondary {
    background: var(--color-secondary);
    color: #ffffff;
}

.ds-button-neutral {
    background: var(--color-title);
    color: var(--color-inverse);
}

.ds-button-success {
    background: var(--color-success);
    color: #ffffff;
}

.ds-button-danger {
    background: var(--color-danger);
    color: #ffffff;
}

.ds-alert {
    border: 1px solid rgba(217, 72, 95, 0.22);
    background: rgba(217, 72, 95, 0.09);
    color: var(--color-danger);
}

.ds-metric {
    background: var(--color-surface-soft);
    border: 1px solid var(--color-border);
}

.ds-subtask {
    background: var(--color-surface-soft);
    color: var(--color-text);
}

.ds-comment-list {
    background: var(--color-surface-soft);
}

.ds-kanban-page .ds-project-page {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    width: 100%;
    min-width: 0;
    min-height: 0;
    height: 100%;
    overflow: hidden;
}

.ds-kanban-page--board {
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: calc(100dvh - var(--topbar-height) - 14px);
    overflow: hidden;
}

.ds-project-page__description {
    max-width: 52rem;
    color: var(--color-muted);
    font-size: 0.95rem;
    line-height: 1.65;
}

.ds-project-page__hero-meta {
    min-width: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.ds-project-page__hero-stats {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ds-project-page__stat {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 0.45rem;
    min-height: 108px;
    padding: 1rem 1.05rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    height: 100%;
}

.ds-project-page__stat span {
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 400;
}

.ds-project-page__stat strong {
    color: var(--color-title);
    font-size: clamp(1.3rem, 2vw, 1.8rem);
    font-weight: 500;
    letter-spacing: normal;
}

.ds-project-toolbar {
    display: grid;
    gap: 1rem;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
}

.ds-project-toolbar__views {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 0.3rem;
    background: color-mix(in srgb, var(--color-surface-strong) 94%, transparent);
}

.ds-project-toolbar__view-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.5rem;
    padding: 0.62rem 0.95rem;
    border-radius: calc(var(--radius-md) - 2px);
    color: var(--color-muted);
    font-size: 0.82rem;
    font-weight: 500;
}

.ds-project-toolbar__view-link.is-active {
    background: var(--color-title);
    color: var(--color-inverse);
}

.ds-project-toolbar__selectors {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ds-project-toolbar__field {
    display: flex;
    flex-direction: column;
    gap: 0.42rem;
}

.ds-project-toolbar__label {
    color: var(--color-muted);
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: normal;
}

.ds-project-toolbar__actions {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.65rem;
}

.ds-project-overview {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1.15fr 0.95fr 0.95fr;
}

.ds-project-overview__card {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    min-height: 100%;
}

.ds-project-overview__metrics {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ds-project-overview__metric {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 0.95rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-surface-soft) 88%, transparent);
}

.ds-project-overview__metric span,
.ds-project-overview__note {
    color: var(--color-muted);
    font-size: 0.8rem;
    line-height: 1.55;
}

.ds-project-overview__metric strong {
    color: var(--color-title);
    font-size: 0.94rem;
    font-weight: 500;
}

.ds-project-overview__context {
    margin-top: auto;
}

.ds-project-board {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.ds-project-board__header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
}

.ds-project-board__switcher {
    display: flex;
    gap: 0.65rem;
    overflow-x: auto;
    padding-bottom: 0.25rem;
}

.ds-project-board__switcher-item {
    display: inline-flex;
    flex-direction: column;
    gap: 0.18rem;
    min-width: 180px;
    padding: 0.85rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-surface-strong) 92%, transparent);
    color: var(--color-title);
    transition: border-color 160ms ease, background 160ms ease, transform 160ms ease;
}

.ds-project-board__switcher-item:hover {
    transform: translateY(-1px);
    border-color: var(--color-border-strong);
}

.ds-project-board__switcher-item span {
    font-size: 0.85rem;
    font-weight: 500;
}

.ds-project-board__switcher-item small {
    color: var(--color-muted);
    font-size: 0.74rem;
}

.ds-project-board__switcher-item.is-active {
    border-color: color-mix(in srgb, var(--project-accent, var(--color-primary)) 36%, var(--color-border-strong));
    background: color-mix(in srgb, var(--project-accent, var(--color-primary)) 10%, var(--color-surface-strong));
}

.ds-project-board__column-form {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: minmax(220px, 280px) auto;
}

.ds-project-board__canvas {
    position: relative;
}

.ds-project-board__columns {
    display: flex;
    align-items: flex-start;
}

.ds-project-column {
    display: flex;
    flex-direction: column;
    gap: 0.95rem;
}

.ds-project-column__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    cursor: grab;
}

.ds-project-column__heading {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    min-width: 0;
}

.ds-project-column__marker {
    width: 0.78rem;
    height: 2.5rem;
    border-radius: 999px;
    background: var(--column-accent, var(--color-primary));
    flex-shrink: 0;
}

.ds-project-column__meta {
    color: var(--color-muted);
    font-size: 0.78rem;
    margin-top: 0.12rem;
}

.ds-project-column__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    height: 2rem;
    padding: 0 0.65rem;
    border-radius: var(--radius-pill);
    background: color-mix(in srgb, var(--column-accent, var(--color-primary)) 16%, var(--color-surface-strong));
    color: var(--color-title);
    font-size: 0.78rem;
    font-weight: 600;
}

.ds-project-column__composer {
    border-color: color-mix(in srgb, var(--column-accent, var(--color-primary)) 16%, var(--color-border));
}

.ds-project-column__composer-title {
    color: var(--color-title);
    font-size: 0.82rem;
    font-weight: 500;
}

.ds-project-column__composer-actions {
    display: grid;
    gap: 0.6rem;
    grid-template-columns: minmax(0, 1fr) auto;
}

.ds-project-column__cards {
    min-height: 120px;
}

.ds-project-column__empty {
    border: 1px dashed var(--color-border-strong);
    background: color-mix(in srgb, var(--color-surface) 70%, transparent);
    color: var(--color-muted);
}

.ds-project-column--azure {
    --column-accent: #4c85ff;
}

.ds-project-column--amber {
    --column-accent: #fa9b32;
}

.ds-project-column--mint {
    --column-accent: #2dbf74;
}

.ds-project-column--slate {
    --column-accent: #73839b;
}

.ds-project-card {
    overflow: hidden;
}

.ds-project-card[open] {
    box-shadow: 0 24px 64px var(--color-shadow);
}

.ds-project-card__summary {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    padding: 0.95rem;
    cursor: pointer;
    list-style: none;
}

.ds-project-card__summary::-webkit-details-marker {
    display: none;
}

.ds-project-card__summary-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
}

.ds-project-card__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.ds-project-card__badge {
    display: inline-flex;
    align-items: center;
    min-height: 1.6rem;
    padding: 0.25rem 0.55rem;
    border-radius: var(--radius-pill);
    background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface-soft));
    color: var(--color-title);
    font-size: 0.66rem;
    font-weight: 600;
    letter-spacing: normal;
}

.ds-project-card__badge--success {
    background: color-mix(in srgb, var(--color-success) 14%, var(--color-surface-soft));
    color: var(--color-success);
}

.ds-project-card__toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.9rem;
    height: 1.9rem;
    border-radius: var(--radius-pill);
    border: 1px solid var(--color-border);
    color: var(--color-muted);
    background: var(--color-surface-soft);
    flex-shrink: 0;
    transition: transform 180ms ease;
}

.ds-project-card[open] .ds-project-card__toggle {
    transform: rotate(180deg);
}

.ds-project-card__toggle svg {
    width: 0.95rem;
    height: 0.95rem;
}

.ds-project-card__summary-main {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.ds-project-card__title {
    color: var(--color-title);
    font-size: 0.95rem;
    font-weight: 500;
    line-height: 1.35;
}

.ds-project-card__description {
    color: var(--color-muted);
    font-size: 0.8rem;
    line-height: 1.55;
}

.ds-project-card__summary-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.ds-project-card__summary-stats span {
    display: inline-flex;
    align-items: center;
    border-radius: var(--radius-pill);
    padding: 0.3rem 0.58rem;
    background: var(--color-surface-soft);
    color: var(--color-muted);
    font-size: 0.72rem;
    font-weight: 500;
}

.ds-project-card__body {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    padding: 0 0.95rem 0.95rem;
}

.ds-kanban-reference {
    position: relative;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
}

.ds-kanban-reference__canvas {
    position: relative;
    flex: 1 1 auto;
    width: 100%;
    min-height: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 0.35rem;
    scroll-snap-type: x proximity;
}

.ds-kanban-page--board .ds-kanban-reference__canvas {
    height: 100%;
    padding-bottom: 0.35rem;
}

.ds-kanban-reference__columns {
    display: flex;
    align-items: stretch;
    gap: 0;
    min-width: max-content;
    min-height: 100%;
    height: 100%;
}

.ds-kanban-column-inserter {
    position: relative;
    display: flex;
    flex: 0 0 0;
    flex-direction: column;
    align-items: center;
    height: 100%;
    margin: 0 -0.375rem;
    z-index: 2;
    pointer-events: none;
    overflow: visible;
}

.ds-kanban-column-inserter__hitbox {
    position: absolute;
    top: 0;
    left: 50%;
    width: 3rem;
    height: calc(1.15rem + 1.5rem + 50px);
    transform: translateX(-50%);
    pointer-events: auto;
}

.ds-kanban-column-inserter__button {
    position: relative;
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.5rem;
    height: 1.5rem;
    margin-top: 1.15rem;
    border: 0;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-surface-strong) 0%, transparent);
    color: var(--color-muted);
    font-size: 1.1rem;
    line-height: 1;
    cursor: pointer;
    pointer-events: auto;
    opacity: 0;
    transition: opacity 180ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.ds-kanban-column-inserter__button:hover,
.ds-kanban-column-inserter__button:focus-visible {
    opacity: 1;
    background: color-mix(in srgb, var(--color-surface-strong) 100%, transparent);
    color: var(--color-title);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-border-strong) 90%, transparent);
}

.ds-kanban-column-inserter__button:hover:active {
    transform: translateY(-1px);
    background: color-mix(in srgb, var(--project-accent, var(--color-primary)) 16%, var(--color-surface-strong));
    color: var(--project-accent, var(--color-primary));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--project-accent, var(--color-primary)) 50%, transparent);
}

.ds-kanban-column-inserter__button--visible {
    width: 1.75rem;
    height: 1.75rem;
    margin-top: 0;
    opacity: 1;
    background: color-mix(in srgb, var(--color-surface-strong) 100%, transparent);
    color: var(--color-title);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-border-strong) 90%, transparent);
    flex-shrink: 0;
}

.ds-kanban-column-inserter__button--visible:hover,
.ds-kanban-column-inserter__button--visible:focus-visible {
    opacity: 1;
}

.ds-kanban-column-inserter__line {
    position: absolute;
    top: 0;
    left: 50%;
    width: 2px;
    height: 100%;
    background: var(--project-accent, var(--color-primary));
    border-radius: 1px;
    transform: translateX(-50%);
    opacity: 0;
    transition: opacity 180ms ease;
    pointer-events: none;
}

.ds-kanban-column-inserter.is-expanding .ds-kanban-column-inserter__button {
    opacity: 1;
    background: color-mix(in srgb, var(--color-surface-strong) 100%, transparent);
    color: var(--color-title);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--project-accent, var(--color-primary)) 38%, transparent);
}

.ds-kanban-column-inserter.is-expanding .ds-kanban-column-inserter__line {
    opacity: 0.35;
}

.ds-kanban-column {
    display: flex;
    flex: 0 0 340px;
    flex-direction: column;
    gap: 0.9rem;
    width: 340px;
    min-width: 340px;
    max-width: 340px;
    height: 100%;
    min-height: 0;
    padding: 0.95rem 0.95rem 0;
    border: 1px solid color-mix(in srgb, var(--color-border) 78%, transparent);
    border-radius: 14px;
    background: var(--color-kanban-column);
    scroll-snap-align: start;
}

.ds-kanban-column__header {
    display: flex;
    flex: 0 0 auto;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 0.15rem 0.1rem 0;
}

.ds-kanban-column__name-input {
    min-width: 0;
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-title);
    font-size: 1.02rem;
    font-weight: 500;
    line-height: 1.35;
}

.ds-kanban-column__name-input[readonly] {
    cursor: pointer;
}

.ds-kanban-column__name-input:focus {
    outline: none;
}

.ds-kanban-column__actions {
    position: relative;
    z-index: 4;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.ds-kanban-column__context-menu {
    width: 190px;
}

.ds-kanban-column__add {
    position: relative;
    z-index: 4;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: 0;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-surface-strong) 92%, transparent);
    color: var(--color-title);
    font-size: 1.2rem;
    line-height: 1;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-border) 86%, transparent);
    transition: transform 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.ds-kanban-column__add:hover {
    transform: translateY(-1px);
    background: color-mix(in srgb, var(--color-surface-strong) 100%, transparent);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-border-strong) 90%, transparent);
}

.ds-kanban-column__composer {
    display: block;
    flex: 0 0 auto;
}

.ds-kanban-card--draft {
    cursor: text;
}

.ds-kanban-card--draft:focus-within {
    border-color: color-mix(in srgb, var(--project-accent, var(--color-primary)) 34%, var(--color-border));
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--project-accent, var(--color-primary)) 14%, transparent);
}

.ds-kanban-card__open--draft {
    cursor: text;
}

.ds-kanban-card__draft-title {
    display: block;
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-title);
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.45;
}

.ds-kanban-card__draft-title::placeholder {
    color: color-mix(in srgb, var(--color-muted) 82%, transparent);
}

.ds-kanban-card__draft-title:focus {
    outline: none;
}

.ds-kanban-card__footer--draft {
    align-items: center;
}

.ds-kanban-card__assignee-picker--draft {
    pointer-events: none;
}

.ds-kanban-card__metrics--draft {
    min-height: 2rem;
}

.ds-kanban-column__cards {
    position: relative;
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    gap: 0.95rem;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.ds-kanban-column__cards::after {
    content: '';
    position: sticky;
    right: 0;
    bottom: 0;
    left: 0;
    display: block;
    flex: 0 0 auto;
    min-height: 2.75rem;
    margin-top: auto;
    background: linear-gradient(to bottom, rgba(242, 242, 242, 0), var(--color-kanban-column) 88%);
    pointer-events: none;
    z-index: 1;
}

:root[data-theme='dark'] .ds-kanban-column__cards::after {
    background: linear-gradient(to bottom, rgba(24, 24, 24, 0), var(--color-kanban-column) 88%);
}

.ds-kanban-column__cards > * {
    flex: 0 0 auto;
}

.ds-kanban-column__cards::-webkit-scrollbar {
    width: 0;
    height: 0;
}

.ds-kanban-column__empty {
    padding: 1.15rem 1rem;
    border: 1px dashed color-mix(in srgb, var(--color-border-strong) 82%, transparent);
    border-radius: 14px;
    background: color-mix(in srgb, var(--color-surface-strong) 64%, transparent);
    color: var(--color-muted);
    font-size: 0.85rem;
}

.ds-kanban-card {
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--color-border) 86%, transparent);
    border-radius: 14px;
    background: color-mix(in srgb, var(--color-surface-strong) 98%, transparent);
    box-shadow: none;
    transition: border-color 180ms ease;
}

.ds-kanban-card__frame {
    position: relative;
}

.ds-kanban-card__open {
    display: flex;
    width: 100%;
    flex-direction: column;
    gap: 11px;
    padding: 1rem;
    background: transparent;
    cursor: pointer;
    text-align: left;
}

.ds-kanban-card__open:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--project-accent, var(--color-primary)) 65%, transparent);
    outline-offset: -2px;
}

.ds-kanban-card[open] {
    border-color: color-mix(in srgb, var(--project-accent, var(--color-primary)) 20%, var(--color-border));
    box-shadow: none;
}

.ds-kanban-card__context-menu {
    width: 180px;
}

.ds-kanban-card__rename-form {
    padding: 0.55rem 0.75rem;
}

.ds-kanban-card__rename-input {
    width: 100%;
    padding: 0.45rem 0.6rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-surface);
    color: var(--color-title);
    font-size: 0.88rem;
    font-weight: 500;
    line-height: 1.4;
    outline: none;
}

.ds-kanban-card__rename-input:focus {
    border-color: var(--project-accent, var(--color-primary));
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--project-accent, var(--color-primary)) 25%, transparent);
}

.ds-kanban-card__summary {
    display: flex;
    flex-direction: column;
    gap: 11px;
    padding: 1rem;
    cursor: pointer;
    list-style: none;
}

.ds-kanban-card__summary::-webkit-details-marker {
    display: none;
}

.ds-kanban-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.ds-kanban-card__tag {
    display: inline-flex;
    align-items: center;
    min-height: 1.20rem;
    padding: 0.20rem 0.50rem;
    border-radius: 999px;
    font-size: 0.68rem;
    font-weight: 400;
    letter-spacing: normal;
}

.ds-kanban-card__tag {
    border: 0;
}

.ds-kanban-card__title {
    color: var(--color-title);
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.45;
}

.ds-kanban-card__subline {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.8rem;
    flex-wrap: wrap;
}

.ds-kanban-card__subline .ds-date-range--inline {
    display: inline-flex;
    align-items: center;
    align-self: center;
}

.ds-kanban-card__priority {
    display: inline-flex;
    align-items: center;
    min-height: 1.20rem;
    padding: 0.20rem 0.50rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 400;
}

.ds-kanban-card__priority--baixa {
    background: color-mix(in srgb, var(--color-success) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-success) 82%, var(--color-title));
}

.ds-kanban-card__priority--media {
    background: color-mix(in srgb, var(--color-muted) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-muted) 88%, var(--color-title));
}

.ds-kanban-card__priority--alta {
    background: color-mix(in srgb, var(--color-warning) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-warning) 80%, var(--color-title));
}

.ds-kanban-card__priority--urgente {
    background: color-mix(in srgb, var(--color-danger) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-danger) 80%, var(--color-title));
}

.ds-kanban-card__footer {
    display: flex;
    align-items: flex-end;
    gap: 0.72rem;
    flex-wrap: wrap;
    padding-top: 8px;
}

.ds-kanban-card__metrics {
    display: inline-flex;
    align-items: center;
    gap: 0.72rem;
    margin-left: auto;
    flex-wrap: wrap;
}

.ds-kanban-card__metric {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    color: var(--color-muted);
    font-size: 0.72rem;
    font-weight: 500;
}

.ds-kanban-card__metric svg {
    display: block;
    width: 1rem;
    height: 1rem;
    flex-shrink: 0;
    overflow: visible;
}

.ds-kanban-card__assignees {
    display: inline-flex;
    align-items: center;
}

.ds-kanban-card__assignee-picker {
    margin-left: 0;
}

.ds-assignee-picker {
    position: relative;
}

.ds-assignee-picker__trigger {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    min-height: 2rem;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-title);
}

.ds-assignee-picker__trigger.is-empty {
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-surface-soft) 94%, transparent);
    color: var(--color-muted);
    opacity: 0.52;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-border) 88%, transparent);
}

.ds-assignee-picker__trigger:disabled {
    cursor: default;
}

.ds-assignee-picker__empty-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.ds-assignee-picker__empty-icon svg {
    width: 1rem;
    height: 1rem;
}

.ds-kanban-card__assignee {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    background: var(--avatar-background, color-mix(in srgb, var(--color-avatar-accent) 20%, var(--color-surface-soft)));
    color: var(--avatar-color, color-mix(in srgb, var(--color-avatar-accent) 84%, var(--color-title)));
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: normal;
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-surface-input) 95%, transparent);
}

.ds-kanban-card__assignee + .ds-kanban-card__assignee {
    margin-left: -0.35rem;
}

.ds-kanban-card__assignee--more {
    background: color-mix(in srgb, var(--color-muted) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-muted) 88%, var(--color-title));
}

.ds-assignee-picker__panel {
    position: absolute;
    right: 0;
    top: calc(100% + 0.55rem);
    z-index: 120;
    width: min(280px, calc(100vw - 2rem));
    padding: 0.8rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
    border-radius: var(--radius-dropdown);
    background: color-mix(in srgb, var(--color-surface-strong) 98%, transparent);
    box-shadow: 0 18px 42px var(--color-shadow);
}

.ds-assignee-picker__header {
    display: grid;
    gap: 0.18rem;
    padding: 0.15rem 0.15rem 0.65rem;
}

.ds-assignee-picker__header strong {
    color: var(--color-title);
    font-size: 0.86rem;
    font-weight: 600;
}

.ds-assignee-picker__header span {
    color: var(--color-muted);
    font-size: 0.74rem;
    font-weight: 400;
}

.ds-assignee-picker__list {
    display: grid;
    gap: 0.45rem;
}

.ds-assignee-picker__option {
    display: grid;
    grid-template-columns: auto auto minmax(0, 1fr);
    align-items: center;
    gap: 0.55rem;
    min-height: 2.7rem;
    padding: 0.5rem 0.65rem;
    border: 1px solid var(--color-border);
    border-radius: 14px;
    background: var(--color-surface);
    color: var(--color-title);
}

.ds-assignee-picker__option input {
    width: 0.95rem;
    height: 0.95rem;
    accent-color: var(--color-primary);
}

.ds-assignee-picker__name {
    min-width: 0;
    color: var(--color-title);
    font-size: 0.8rem;
    font-weight: 500;
}

.ds-assignee-picker__empty {
    padding: 0.2rem 0.15rem 0;
    color: var(--color-muted);
    font-size: 0.74rem;
}

.ds-assignee-picker__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: 0.8rem;
}

.ds-assignee-picker__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2rem;
    padding: 0.45rem 0.78rem;
    border-radius: 999px;
    color: var(--color-muted);
    font-size: 0.76rem;
    font-weight: 600;
}

.ds-assignee-picker__action--primary {
    background: color-mix(in srgb, var(--project-accent, var(--color-primary)) 12%, var(--color-surface-soft));
    color: var(--color-title);
}

.ds-task-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    right: auto;
    bottom: auto;
    z-index: 70;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    height: min(calc(100dvh - var(--topbar-height) - 40px), 820px);
    transform: translate(-50%, -50%);
    width: min(1120px, calc(100vw - 2rem));
    pointer-events: none;
}

.ds-task-modal__dialog {
    position: relative;
    width: 100%;
    height: 100%;
    max-height: none;
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding: 1.6rem;
    pointer-events: auto;
    border: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
    border-radius: 30px;
    background: color-mix(in srgb, var(--color-surface-input) 84%, var(--color-surface-raised));
    box-shadow: 0 26px 70px var(--color-shadow);
}

.ds-task-modal__dialog::-webkit-scrollbar {
    width: 0;
    height: 0;
}

.ds-task-modal__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.ds-task-modal__header-copy {
    display: grid;
    gap: 0.24rem;
    min-width: 0;
}

.ds-task-modal__title-input {
    width: 100%;
    min-width: 0;
    border: 0;
    padding: 0;
    background: transparent;
    color: var(--color-title);
    font-size: 1.35rem;
    font-weight: 600;
    line-height: 1.2;
}

.ds-task-modal__title-input:focus {
    outline: none;
}

.ds-task-modal__header-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 500;
}

.ds-task-modal__header-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.65rem;
}

.ds-task-modal__autosave {
    display: inline-flex;
    align-items: center;
    min-height: 2.1rem;
    padding: 0.38rem 0.78rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-surface-soft) 92%, transparent);
    color: var(--color-muted);
    font-size: 0.74rem;
    font-weight: 600;
}

.ds-task-modal__autosave[data-state='saving'] {
    color: var(--color-primary);
}

.ds-task-modal__autosave[data-state='error'] {
    color: var(--color-danger);
}

.ds-task-modal__status {
    display: inline-flex;
    align-items: center;
    min-height: 2.2rem;
    padding: 0.45rem 0.85rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-success) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-success) 82%, var(--color-title));
    font-size: 0.78rem;
    font-weight: 600;
}

.ds-task-modal__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 999px;
    border: 1px solid var(--color-border);
    background: var(--color-surface-soft);
    color: var(--color-title);
}

.ds-task-modal__close svg {
    width: 1rem;
    height: 1rem;
}

.ds-task-modal__body {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1.1rem;
}

.ds-task-sheet {
    color: var(--color-title);
}

.ds-task-sheet__topbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.ds-task-sheet__context {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.ds-task-sheet__context-chip {
    display: inline-flex;
    align-items: center;
    min-height: 2.1rem;
    padding: 0.4rem 0.8rem;
    border-radius: 999px;
    font-size: 0.96rem;
    font-weight: 500;
}

.ds-task-sheet__context-chip--project {
    background: color-mix(in srgb, var(--color-primary) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-primary) 82%, var(--color-title));
}

.ds-task-sheet__context-chip--column {
    background: color-mix(in srgb, var(--color-secondary) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-secondary) 80%, var(--color-title));
}

.ds-task-sheet__topbar-actions {
    display: flex;
    align-items: center;
    gap: 0.55rem;
}

.ds-task-sheet__autosave {
    color: var(--color-muted);
    font-size: 0.76rem;
    font-weight: 500;
    white-space: nowrap;
}

.ds-task-sheet__autosave[data-state='saving'] {
    color: var(--color-primary);
}

.ds-task-sheet__autosave[data-state='error'] {
    color: var(--color-danger);
}

.ds-task-sheet__icon-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border: 1px solid color-mix(in srgb, var(--color-border-strong) 82%, transparent);
    border-radius: 999px;
    background: var(--color-surface-muted-alt);
    color: var(--color-muted);
}

.ds-task-sheet__icon-action svg {
    width: 1rem;
    height: 1rem;
}

.ds-task-sheet__icon-action--success {
    background: var(--color-surface-quiet);
    color: var(--color-muted);
}

.ds-task-sheet__icon-action--static {
    border-color: color-mix(in srgb, var(--color-success) 22%, transparent);
    background: color-mix(in srgb, var(--color-success) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-success) 82%, var(--color-title));
}

.ds-task-sheet__title-input {
    font-size: clamp(2rem, 3vw, 3rem);
    font-weight: 400;
    line-height: 1.08;
    letter-spacing: normal;
}

.ds-task-sheet__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    color: var(--color-muted);
    font-size: 0.86rem;
    font-weight: 400;
}

.ds-task-sheet__form {
    display: grid;
    gap: 1rem;
}

.ds-task-sheet__toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
}

.ds-task-sheet__priority-wrap,
.ds-task-sheet__spent-time,
.ds-task-sheet__toolbar .ds-date-range__trigger--inline,
.ds-task-select--toolbar .ds-task-select__trigger {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    min-height: 2.45rem;
    padding: 0.45rem 0.85rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 86%, transparent);
    border-radius: 999px;
    background: var(--color-surface-muted-alt);
    box-shadow: none;
}

.ds-task-sheet__priority-wrap--urgent {
    background: color-mix(in srgb, var(--color-danger) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-danger) 80%, var(--color-title));
}

.ds-task-sheet__priority-wrap--high {
    background: color-mix(in srgb, var(--color-warning) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-warning) 80%, var(--color-title));
}

.ds-task-sheet__priority-wrap--medium {
    background: color-mix(in srgb, var(--color-primary) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-primary) 80%, var(--color-title));
}

.ds-task-sheet__priority-wrap--low,
.ds-task-sheet__priority-wrap--neutral {
    background: color-mix(in srgb, var(--color-muted) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-muted) 88%, var(--color-title));
}

.ds-task-sheet__priority-select,
.ds-task-sheet__spent-time-value {
    border: 0;
    padding: 0;
    background: transparent;
    color: inherit;
    font-size: 0.95rem;
    font-weight: 500;
}

.ds-task-sheet__priority-select {
    min-width: 6.8rem;
}

.ds-task-sheet__spent-time {
    color: var(--color-muted);
}

.ds-task-sheet__spent-time svg {
    width: 0.95rem;
    height: 0.95rem;
    color: var(--color-primary);
}

.ds-task-sheet__spent-time-value {
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
}

.ds-task-sheet__priority-select:focus,
.ds-task-sheet__description-input:focus,
.ds-task-sheet__subtask-input:focus,
.ds-task-sheet__comment-input:focus {
    outline: none;
}

.ds-task-sheet__toolbar .ds-date-range__trigger--inline {
    color: var(--color-title);
}

.ds-task-sheet__toolbar .ds-date-range__trigger--inline svg {
    color: var(--color-primary);
}

.ds-task-sheet__toolbar .ds-date-range__trigger-text {
    font-size: 0.95rem;
    font-weight: 400;
}

.ds-task-sheet__toolbar-item {
    display: inline-flex;
    align-items: center;
}

.ds-task-select--toolbar .ds-task-select__trigger {
    min-height: 2.45rem;
    padding-block: 0.45rem;
    border-color: color-mix(in srgb, var(--color-border) 86%, transparent);
}

.ds-task-select--toolbar .ds-task-select__summary {
    color: var(--color-title);
    font-size: 0.95rem;
    font-weight: 400;
}

.ds-task-sheet__panel {
    padding: 1.25rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 78%, transparent);
    border-radius: 28px;
    background: var(--color-surface-raised);
}

.ds-task-sheet__panel--description {
    min-height: 300px;
}

.ds-task-sheet__panel-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.ds-task-sheet__panel-title {
    color: var(--color-title);
    font-size: 1.02rem;
    font-weight: 400;
}

.ds-task-sheet__panel-meta {
    margin-top: 0.2rem;
    color: var(--color-muted);
    font-size: 0.82rem;
    font-weight: 400;
}

.ds-task-sheet__panel-counter {
    color: var(--color-muted);
    font-size: 0.9rem;
    font-weight: 500;
}

.ds-task-sheet__panel-counter--progress {
    font-variant-numeric: tabular-nums;
}

.ds-task-sheet__description-input {
    width: 100%;
    min-height: 220px;
    margin-top: 0.9rem;
    border: 0;
    padding: 0;
    background: transparent;
    color: var(--color-title);
    font-size: 1rem;
    line-height: 1.7;
    resize: vertical;
}

.ds-task-sheet__subtask-input {
    width: 100%;
    border: 0;
    border-radius: 18px;
    background: var(--color-surface-input);
    color: var(--color-title);
}

.ds-task-sheet__subtask-input {
    min-height: 3.1rem;
    padding: 0 1rem;
    font-size: 0.98rem;
}

.ds-task-sheet__subtask-list {
    display: grid;
    gap: 0.28rem;
    margin-top: 1rem;
}

.ds-task-sheet__subtask-item {
    display: grid;
    align-items: center;
    grid-template-columns: auto auto minmax(0, 1fr) auto;
    gap: 0;
    min-height: 2.7rem;
    padding: 0.12rem 0;
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 78%, transparent);
    color: var(--color-text);
    font-size: 0.98rem;
}

.ds-task-sheet__subtask-item.is-multiline {
    align-items: flex-start;
}

.ds-task-sheet__subtask-item--draft {
    width: 100%;
}

.ds-task-sheet__subtask-item--pending {
    opacity: 0.76;
}

.ds-task-sheet__subtask-item--pending .ds-task-sheet__subtask-title-input {
    pointer-events: none;
}

.ds-task-sheet__subtask-toggle-form {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    align-self: center;
    margin: 0;
}

.ds-task-sheet__subtask-toggle {
    flex: 0 0 auto;
    width: 1.3rem;
    height: 1.3rem;
    border: 1px solid color-mix(in srgb, var(--color-border-strong) 92%, transparent);
    border-radius: 999px;
    background: var(--color-surface-muted-alt);
}

.ds-task-sheet__subtask-toggle.is-complete {
    background: color-mix(in srgb, var(--color-success) 16%, var(--color-surface-soft));
    border-color: color-mix(in srgb, var(--color-success) 22%, transparent);
}

.ds-task-sheet__subtask-toggle--draft {
    pointer-events: none;
    opacity: 0.72;
}

.ds-task-sheet__subtask-drag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    align-self: center;
    width: 1.85rem;
    height: 1.85rem;
    padding: 0;
    border: 0;
    border-radius: 10px;
    background: transparent;
    color: var(--color-muted);
    cursor: grab;
}

.ds-task-sheet__subtask-drag svg {
    width: 1rem;
    height: 1rem;
}

.ds-task-sheet__subtask-drag:active {
    cursor: grabbing;
}

.ds-task-sheet__subtask-drag--placeholder {
    cursor: default;
    opacity: 0.72;
}

.ds-task-sheet__subtask-title-input {
    display: block;
    align-self: center;
    width: 100%;
    min-width: 0;
    min-height: 0;
    margin: 0;
    padding: 0.22rem 0.55rem;
    border: 0;
    border-radius: 10px;
    background: transparent;
    color: var(--color-text);
    font-size: 0.95rem;
    line-height: 1.35;
    box-sizing: border-box;
    resize: none;
    overflow: hidden;
    white-space: pre-wrap;
}

.ds-task-sheet__subtask-title-input[readonly] {
    cursor: text;
    background: transparent;
}

.ds-task-sheet__subtask-item.is-multiline .ds-task-sheet__subtask-drag,
.ds-task-sheet__subtask-item.is-multiline .ds-task-sheet__subtask-toggle-form,
.ds-task-sheet__subtask-item.is-multiline .ds-task-sheet__subtask-side,
.ds-task-sheet__subtask-item.is-multiline .ds-task-sheet__subtask-title-input[readonly] {
    align-self: flex-start;
}

.ds-task-sheet__subtask-title-input:not([readonly]),
.ds-task-sheet__subtask-title-input--draft {
    background: var(--color-surface-input);
}

.ds-task-sheet__subtask-title-input:focus {
    outline: none;
}

.ds-task-sheet__subtask-title-input.is-complete {
    color: var(--color-muted);
    text-decoration: line-through;
}

.ds-task-sheet__subtask-side {
    display: inline-flex;
    align-self: center;
    align-items: center;
    justify-content: flex-end;
    gap: 0.55rem;
}

.ds-task-sheet__subtask-assignee-picker {
    position: relative;
}

.ds-task-sheet__subtask-assignee-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    min-height: 2rem;
    padding: 0.2rem;
    border: 0;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-surface-muted-alt) 92%, transparent);
    color: var(--color-title);
}

.ds-task-sheet__subtask-assignee-trigger.is-empty {
    color: var(--color-muted);
}

.ds-task-sheet__subtask-assignee-trigger svg {
    width: 0.95rem;
    height: 0.95rem;
}

.ds-task-sheet__subtask-assignee-list {
    display: inline-flex;
    align-items: center;
}

.ds-task-sheet__subtask-assignee-panel {
    width: min(300px, calc(100vw - 2rem));
}

.ds-task-sheet__subtask-menu {
    width: 180px;
    padding: 0.35rem;
    gap: 0.15rem;
}

.ds-task-sheet__subtask-menu .ds-options-dropdown__action {
    min-height: 2.15rem;
    font-size: 0.8rem;
}

.ds-task-sheet__subtask-create {
    display: grid;
    width: 100%;
    justify-items: stretch;
    gap: 0;
    margin-top: 0;
}

.ds-task-sheet__subtask-create-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.55rem;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-muted);
    font-size: 0.88rem;
    font-weight: 500;
    margin-top: 0.55rem;
}

.ds-task-sheet__subtask-header-row {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.7rem;
}

.ds-task-sheet__subtask-create-trigger--icon {
    gap: 0;
    margin-top: 0;
}

.ds-task-sheet__section {
    display: grid;
    gap: 0;
}

.ds-task-sheet__section--time,
.ds-task-sheet__section--attachments,
.ds-task-sheet__section--comments {
    margin-top: 1rem;
}

.ds-task-sheet__section--attachments {
    position: relative;
}

.ds-task-sheet__time-summary {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: minmax(0, 3fr) minmax(0, 3.5fr) minmax(0, 3.5fr);
    align-items: stretch;
    margin-top: 1rem;
}

.ds-task-sheet__stat-grid {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 1rem;
}

.ds-task-sheet__stat-card {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.45rem;
    min-height: 2.7rem;
    padding: 0 0.95rem;
    border-radius: 20px;
    border: 1px solid color-mix(in srgb, var(--color-border) 78%, transparent);
    background: var(--color-surface-raised);
}

.ds-task-sheet__stat-card span {
    color: var(--color-muted);
    font-size: 0.88rem;
    font-weight: 500;
    letter-spacing: normal;
    white-space: nowrap;
}

.ds-task-sheet__stat-card strong {
    color: var(--color-title);
    font-size: 0.88rem;
    font-weight: 500;
    white-space: nowrap;
}


.ds-task-sheet__timer-actions {
    display: flex;
    margin-top: 0;
}

.ds-task-sheet__timer-actions form {
    width: 100%;
    display: flex;
}

.ds-task-sheet__timer-button,
.ds-task-sheet__comment-submit {
    width: 100%;
    min-height: 2.7rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    padding: 0 0.95rem;
    border: 0;
    border-radius: 18px;
    font-size: 0.9rem;
    font-weight: 500;
}

.ds-task-sheet__timer-button--start {
    background: var(--color-title);
    color: var(--color-inverse);
}

.ds-task-sheet__timer-button--running {
    background: var(--color-surface-quiet);
    color: var(--color-title);
}

.ds-task-sheet__timer-button-value {
    font-family: var(--font-mono);
    font-size: 0.94rem;
    font-weight: 600;
}

.ds-task-sheet__timer-button-separator {
    opacity: 0.6;
}

.ds-task-sheet__manual-session {
    display: grid;
    width: 100%;
    justify-items: stretch;
    gap: 0;
    margin-top: 0.25rem;
}

.ds-task-sheet__manual-session-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.55rem;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-muted);
    font-size: 0.88rem;
    font-weight: 500;
    margin-top: 0.55rem;
}

.ds-task-sheet__manual-session-form {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    align-items: center;
    margin-top: 0.85rem;
    width: auto;
    max-width: 100%;
    padding: 0.95rem 1rem;
    border-radius: 20px;
    background: color-mix(in srgb, var(--color-surface-soft) 72%, var(--color-surface-strong));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-border-strong) 92%, transparent);
}

.ds-task-sheet__manual-session-fields {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    align-items: center;
}

.ds-task-sheet__manual-session-field {
    min-width: 0;
    flex: 0 0 auto;
}

.ds-task-sheet__manual-session-picker,
.ds-task-sheet__manual-session-picker .ds-date-range {
    width: auto;
    max-width: 100%;
}

.ds-task-sheet__manual-session-picker .ds-date-range__trigger--inline {
    width: auto;
    min-height: 2.45rem;
    padding: 0.45rem 0.85rem;
    justify-content: flex-start;
    border: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
    border-radius: 999px;
    background: var(--color-surface-muted-alt);
    color: var(--color-muted);
}

.ds-task-sheet__manual-session-actions {
    display: flex;
    align-items: stretch;
    flex: 0 0 auto;
}

.ds-task-sheet__manual-session-submit,
.ds-task-sheet__comment-submit {
    width: 100%;
    min-height: 2.8rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 18px;
    font-size: 0.9rem;
    font-weight: 500;
}

.ds-task-sheet__manual-session-submit {
    width: auto;
    min-width: max-content;
    padding-inline: 1rem;
    min-height: 2.45rem;
    border: 0;
    border-radius: 18px;
    background: var(--color-title);
    color: var(--color-inverse);
}

.ds-task-sheet__activity-list,
.ds-task-sheet__comment-list {
    display: grid;
    margin-top: 1rem;
}

.ds-task-sheet__activity-list {
    gap: 0;
}

.ds-task-sheet__comment-list {
    gap: 0.75rem;
}

.ds-task-sheet__activity-item,
.ds-task-sheet__comment-item {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 1rem;
}

.ds-task-sheet__activity-item {
    min-height: 2.7rem;
    padding: 0.12rem 0;
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 78%, transparent);
}

.ds-task-sheet__comment-item {
    align-items: stretch;
    gap: 0.85rem;
    padding: 0.95rem 1rem;
    border-radius: 20px;
    border: 1px solid color-mix(in srgb, var(--color-border) 78%, transparent);
    background: var(--color-surface-raised);
}

.ds-task-sheet__comment-head {
    display: grid;
    gap: 0.2rem;
}

.ds-task-sheet__activity-item strong,
.ds-task-sheet__comment-head strong {
    color: var(--color-title);
    font-size: 0.86rem;
    font-weight: 500;
}

.ds-task-sheet__activity-item span,
.ds-task-sheet__comment-head span,
.ds-task-sheet__comment-item p,
.ds-task-sheet__comment-actions span,
.ds-task-sheet__empty-copy {
    color: var(--color-muted);
    font-size: 0.82rem;
    line-height: 1.6;
}

.ds-task-sheet__activity-cell {
    min-width: 0;
    white-space: nowrap;
}

.ds-task-sheet__activity-cell--timeline,
.ds-task-sheet__activity-cell--duration {
    white-space: nowrap;
    color: var(--color-title);
    font-weight: 500;
}

.ds-task-sheet__activity-cell--timeline {
    overflow: hidden;
    text-overflow: ellipsis;
}

.ds-task-sheet__activity-cell--status {
    color: var(--color-muted);
}

.ds-task-sheet__activity-cell--duration {
    color: var(--color-primary);
}

.ds-task-sheet__activity-item form {
    margin-left: auto;
}

.ds-task-sheet__activity-delete {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--color-muted);
}

.ds-task-sheet__activity-delete svg {
    width: 1rem;
    height: 1rem;
}

.ds-task-sheet__activity-toggle {
    margin-top: 0.8rem;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-muted);
    font-size: 0.82rem;
    font-weight: 600;
}

.ds-task-sheet__attachment-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(112px, 1fr));
    gap: 0.85rem;
    margin-top: 1rem;
}

.ds-task-sheet__attachment-tile {
    display: grid;
    gap: 0.55rem;
    min-width: 0;
}

.ds-task-sheet__attachment-launch {
    display: grid;
    gap: 0.55rem;
    min-width: 0;
    padding: 0;
    border: 0;
    background: transparent;
    text-align: inherit;
    color: inherit;
}

.ds-task-sheet__attachment-header.is-empty {
    justify-content: flex-start;
}

.ds-task-sheet__attachment-title-row {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.7rem;
}

.ds-task-sheet__attachment-add {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-muted);
}

.ds-task-sheet__attachment-add .ds-task-sheet__plus-button {
    flex-shrink: 0;
}

.ds-task-sheet__attachment-controls {
    position: relative;
}

.ds-task-sheet__attachment-dropdown {
    width: min(368px, calc(100vw - 2rem));
}

.ds-task-sheet__attachment-form {
    display: grid;
    gap: 0.75rem;
}

.ds-task-sheet__attachment-field {
    display: grid;
    gap: 0.35rem;
}

.ds-task-sheet__attachment-field span {
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 500;
}

.ds-task-sheet__attachment-field input {
    width: 100%;
    min-height: 2.6rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 86%, transparent);
    border-radius: 14px;
    padding: 0.7rem 0.85rem;
    background: var(--color-surface-input);
    color: var(--color-title);
    font-size: 0.86rem;
}

.ds-task-sheet__attachment-field--file input {
    padding: 0.55rem 0.75rem;
}

.ds-task-sheet__attachment-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.45rem;
    padding: 0.65rem 0.95rem;
    border: 0;
    border-radius: 14px;
    background: var(--color-title);
    color: var(--color-inverse);
    font-size: 0.84rem;
    font-weight: 500;
}

.ds-task-sheet__attachment-thumb {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: 18px;
    background: color-mix(in srgb, var(--color-surface-input) 86%, transparent);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-border) 84%, transparent);
}

.ds-task-sheet__attachment-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ds-task-sheet__attachment-file-mark {
    display: grid;
    justify-items: center;
    gap: 0.45rem;
    color: var(--color-title);
}

.ds-task-sheet__attachment-file-mark svg {
    width: 1.35rem;
    height: 1.35rem;
    color: var(--color-primary);
}

.ds-task-sheet__attachment-file-mark strong {
    color: var(--color-muted);
    font-size: 0.76rem;
    font-weight: 600;
    letter-spacing: 0.06em;
}

.ds-task-sheet__attachment-name {
    display: -webkit-box;
    overflow: hidden;
    color: var(--color-title);
    font-size: 0.78rem;
    font-weight: 500;
    line-height: 1.35;
    text-align: center;
    text-wrap: balance;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.ds-task-sheet__attachment-title-form {
    display: block;
}

.ds-task-sheet__attachment-title-input {
    width: 100%;
    min-height: 2rem;
    border: 0;
    padding: 0;
    background: transparent;
    color: var(--color-title);
    font-size: 0.78rem;
    font-weight: 500;
    line-height: 1.35;
    text-align: center;
}

.ds-task-sheet__attachment-title-input:focus {
    outline: none;
}

.ds-task-sheet__attachment-item-menu {
    width: 180px;
}

.ds-task-sheet__attachment-preview {
    position: absolute;
    inset: 0;
    z-index: 12;
    overflow: visible;
    pointer-events: none;
}

.ds-task-sheet__attachment-preview-backdrop {
    display: none;
}

.ds-task-sheet__attachment-preview-dialog {
    position: absolute;
    z-index: 1;
    display: grid;
    gap: 0.85rem;
    top: var(--attachment-preview-top, 1rem);
    left: var(--attachment-preview-left, 1rem);
    width: var(--attachment-preview-width, min(420px, calc(100% - 2rem)));
    max-width: calc(100% - 2rem);
    max-height: min(540px, calc(100dvh - 8rem));
    padding: 0.9rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 78%, transparent);
    border-radius: 20px;
    background: color-mix(in srgb, var(--color-surface-raised) 94%, var(--color-surface-input));
    box-shadow: 0 16px 40px color-mix(in srgb, var(--color-shadow) 34%, transparent);
    overflow: hidden;
    pointer-events: auto;
}

.ds-task-sheet__attachment-preview-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.ds-task-sheet__attachment-preview-header strong {
    min-width: 0;
    color: var(--color-title);
    font-size: 0.92rem;
    font-weight: 600;
}

.ds-task-sheet__attachment-preview-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
}

.ds-task-sheet__attachment-preview-link,
.ds-task-sheet__attachment-preview-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-muted);
    font-size: 0.8rem;
    font-weight: 500;
}

.ds-task-sheet__attachment-preview-close {
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
}

.ds-task-sheet__attachment-preview-close svg {
    width: 1rem;
    height: 1rem;
}

.ds-task-sheet__attachment-preview-body {
    display: grid;
    place-items: center;
    min-height: 0;
    overflow: hidden;
}

.ds-task-sheet__attachment-preview-body img {
    max-width: 100%;
    max-height: min(440px, calc(100dvh - 12rem));
    object-fit: contain;
    border-radius: 14px;
}

.ds-task-sheet__comment-form {
    margin-top: 1rem;
}

.ds-task-sheet__comment-input {
    width: 100%;
    min-height: 3.4rem;
    max-height: 120px;
    border: 0;
    padding: 0;
    background: transparent;
    color: var(--color-title);
    font-size: 1rem;
    line-height: 1.7;
    resize: none;
    overflow-y: hidden;
}

.ds-task-sheet__comment-body {
    min-width: 0;
}

.ds-task-sheet__comment-item {
    flex-direction: column;
}

.ds-task-sheet__comment-item p {
    margin: 0;
    color: var(--color-text);
    white-space: pre-wrap;
    word-break: break-word;
}

.ds-task-sheet__comment-edit-form {
    display: block;
}

.ds-task-sheet__comment-edit-input {
    width: 100%;
    min-height: 3.4rem;
    max-height: 120px;
    border: 0;
    padding: 0;
    background: transparent;
    color: var(--color-title);
    font-size: 1rem;
    line-height: 1.7;
    resize: none;
    overflow-y: hidden;
}

.ds-task-sheet__comment-edit-input:focus {
    outline: none;
}

.ds-task-sheet__comment-footer {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.ds-task-sheet__comment-author {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    min-width: 0;
}

.ds-task-sheet__comment-meta {
    display: inline-flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 0.45rem;
    min-width: 0;
}

.ds-task-sheet__comment-meta strong {
    color: var(--color-title);
    font-size: 0.84rem;
    font-weight: 500;
}

.ds-task-sheet__comment-meta span {
    color: var(--color-muted);
    font-size: 0.8rem;
    line-height: 1.4;
    white-space: nowrap;
}

.ds-task-modal__dialog.ds-task-sheet {
    border-radius: 14px;
}

.ds-task-sheet__topbar {
    align-items: center;
}

.ds-task-sheet__tag-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.55rem;
    min-width: 0;
}

.ds-task-sheet__tag-chip {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.38rem 0.78rem;
    border-radius: 999px;
    font-size: 0.88rem;
    font-weight: 400;
}

.ds-task-sheet__tag-picker {
    display: inline-flex;
}

.ds-task-sheet__plus-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: 0;
    border-radius: 999px;
    background: var(--color-surface-quiet);
    color: var(--color-muted);
    font-size: 1.25rem;
    line-height: 1;
}

.ds-task-sheet__plus-button--inline {
    width: 1.75rem;
    height: 1.75rem;
    font-size: 1.1rem;
}

.ds-task-sheet__dropdown-head {
    display: grid;
    gap: 0.18rem;
    margin-bottom: 0.75rem;
}

.ds-task-sheet__dropdown-head strong {
    color: var(--color-title);
    font-size: 0.88rem;
    font-weight: 600;
}

.ds-task-sheet__dropdown-head span {
    color: var(--color-muted);
    font-size: 0.75rem;
}

.ds-task-sheet__tag-search {
    margin-bottom: 0.8rem;
}

.ds-task-sheet__tag-search-input {
    width: 100%;
    min-height: 2.55rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
    border-radius: 14px;
    padding: 0 0.9rem;
    background: var(--color-surface-input);
    color: var(--color-title);
    font-size: 0.84rem;
}

.ds-task-sheet__tag-search-input:focus {
    outline: none;
}

.ds-task-sheet__tag-sections {
    display: grid;
    gap: 0.85rem;
}

.ds-task-sheet__tag-section {
    display: grid;
    gap: 0.55rem;
}

.ds-task-sheet__tag-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.ds-task-sheet__tag-section-head strong {
    color: var(--color-title);
    font-size: 0.78rem;
    font-weight: 600;
}

.ds-task-sheet__tag-section-head span {
    color: var(--color-muted);
    font-size: 0.72rem;
}

.ds-task-sheet__tag-grid {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.55rem;
}

.ds-task-sheet__tag-choice {
    position: relative;
    display: inline-flex;
    flex: 0 0 auto;
    min-width: 0;
    cursor: pointer;
}

.ds-task-sheet__tag-choice input {
    position: absolute;
    inset: 0;
    opacity: 0;
    pointer-events: none;
}

.ds-task-sheet__tag-choice-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 500;
    line-height: 1.2;
    text-align: center;
    transition: box-shadow 140ms ease, transform 140ms ease, opacity 140ms ease;
    white-space: nowrap;
}

.ds-task-sheet__tag-choice[data-selected="true"] .ds-task-sheet__tag-choice-chip {
    box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--color-surface-input) 92%, transparent), 0 0 0 2px color-mix(in srgb, var(--color-title) 26%, transparent);
    transform: translateY(-1px);
}

.ds-task-sheet__tag-choice[data-selected="false"] .ds-task-sheet__tag-choice-chip {
    opacity: 0.94;
}

.ds-task-sheet__tag-create {
    display: grid;
    gap: 0.75rem;
    margin-top: 0.85rem;
    padding-top: 0.85rem;
    border-top: 1px solid color-mix(in srgb, var(--color-border) 78%, transparent);
}

.ds-task-sheet__tag-create-shell {
    display: grid;
    width: 100%;
    justify-items: stretch;
}

.ds-task-sheet__tag-name-input {
    min-height: 2.7rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
    border-radius: 14px;
    padding: 0 0.9rem;
    background: var(--color-surface-input);
    color: var(--color-title);
}

.ds-task-sheet__tag-name-input:focus {
    outline: none;
}

.ds-task-sheet__color-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.55rem;
}

.ds-task-sheet__color-option {
    position: relative;
    display: inline-flex;
}

.ds-task-sheet__color-option input {
    position: absolute;
    inset: 0;
    opacity: 0;
}

.ds-task-sheet__color-option span {
    width: 100%;
    aspect-ratio: 1;
    border-radius: 10px;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-border) 82%, transparent);
}

.ds-task-sheet__color-option input:checked + span {
    box-shadow: inset 0 0 0 2px var(--color-surface-input), 0 0 0 2px var(--color-title);
}

.ds-task-sheet__inline-submit {
    min-height: 2.6rem;
    border: 0;
    border-radius: 14px;
    background: var(--color-title);
    color: var(--color-inverse);
    font-size: 0.86rem;
    font-weight: 500;
}

.ds-task-sheet__title-input {
    font-size: clamp(1.6rem, 2.3vw, 2.15rem);
}

.ds-task-sheet__icon-action {
    width: 2.1rem;
    height: 2.1rem;
}

.ds-task-sheet__entity-row {
    display: grid;
    gap: 0.55rem;
}

.ds-task-sheet__entity-label {
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: normal;
}

.ds-task-sheet__assignee-picker {
    justify-self: flex-start;
}

.ds-task-sheet__assignee-trigger {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    min-height: 2.2rem;
    padding: 0.2rem 0.1rem 0.2rem 0;
    border: 0;
    background: transparent;
    color: var(--color-title);
}

.ds-task-sheet__assignee-trigger.is-empty {
    padding: 0;
}

.ds-task-sheet__assignee-list {
    display: inline-flex;
    align-items: center;
}

.ds-task-sheet__date-wrap {
    display: inline-flex;
    align-items: center;
}

.ds-task-sheet__date-wrap .ds-date-range__trigger--inline {
    border-radius: 999px;
    background: var(--color-surface-muted-alt);
}

.ds-task-sheet__toolbar {
    gap: 0.85rem;
}

.ds-task-sheet__priority-picker {
    display: inline-flex;
}

.ds-task-sheet__priority-trigger {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    min-height: 2.45rem;
    padding: 0.45rem 0.85rem;
    border: 0;
    border-radius: 999px;
    font-size: 0.94rem;
    font-weight: 500;
}

.ds-task-sheet__priority-summary {
    white-space: nowrap;
}

.ds-task-sheet__priority-badge--neutral {
    background: color-mix(in srgb, var(--color-muted) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-muted) 88%, var(--color-title));
}

.ds-task-sheet__priority-badge--baixa {
    background: color-mix(in srgb, var(--color-success) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-success) 82%, var(--color-title));
}

.ds-task-sheet__priority-badge--media {
    background: color-mix(in srgb, var(--color-primary) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-primary) 80%, var(--color-title));
}

.ds-task-sheet__priority-badge--alta {
    background: color-mix(in srgb, var(--color-warning) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-warning) 80%, var(--color-title));
}

.ds-task-sheet__priority-badge--urgente {
    background: color-mix(in srgb, var(--color-danger) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-danger) 80%, var(--color-title));
}

.ds-task-select__list--compact {
    gap: 0.45rem;
}

.ds-task-sheet__priority-option {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.55rem 0.75rem;
    border-radius: 14px;
    font-size: 0.84rem;
    font-weight: 500;
}

.ds-task-sheet__priority-option input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.ds-task-sheet__priority-dot {
    width: 0.7rem;
    height: 0.7rem;
    border-radius: 999px;
    background: currentColor;
}

.ds-task-sheet__priority-option--neutral {
    background: color-mix(in srgb, var(--color-muted) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-muted) 88%, var(--color-title));
}

.ds-task-sheet__priority-option--baixa {
    background: color-mix(in srgb, var(--color-success) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-success) 82%, var(--color-title));
}

.ds-task-sheet__priority-option--media {
    background: color-mix(in srgb, var(--color-primary) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-primary) 80%, var(--color-title));
}

.ds-task-sheet__priority-option--alta {
    background: color-mix(in srgb, var(--color-warning) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-warning) 80%, var(--color-title));
}

.ds-task-sheet__priority-option--urgente {
    background: color-mix(in srgb, var(--color-danger) 16%, var(--color-surface-soft));
    color: color-mix(in srgb, var(--color-danger) 80%, var(--color-title));
}

.ds-task-sheet__panel,
.ds-task-sheet__subtask-input,
.ds-task-sheet__stat-card,
.ds-task-sheet__comment-item,
.ds-task-sheet__attachment-thumb {
    border-radius: 14px;
}

.ds-task-modal {
    width: min(920px, calc(100vw - 2rem));
}

.ds-task-modal__dialog.ds-task-sheet {
    padding: 1.25rem;
    border-radius: 14px;
}

.ds-task-modal__body {
    gap: 1rem;
}

.ds-task-sheet__topbar {
    align-items: flex-start;
    gap: 0.85rem;
}

.ds-task-sheet__tag-bar {
    flex: 1 1 auto;
}

.ds-task-sheet__topbar-actions {
    flex: 0 0 auto;
    align-items: center;
}

.ds-task-sheet__title-input {
    font-size: clamp(1.35rem, 2vw, 1.8rem);
    line-height: 1.15;
}

.ds-task-sheet__meta {
    gap: 0.4rem 0.85rem;
}

.ds-task-sheet__assignee-picker,
.ds-task-sheet__date-wrap,
.ds-task-sheet__priority-picker,
.ds-task-sheet__tag-picker {
    min-width: 0;
}

.ds-task-sheet__assignee-trigger {
    min-height: 2.45rem;
    padding: 0.28rem 0.42rem;
    justify-content: flex-start;
    border-radius: 999px;
    background: var(--color-surface-muted-alt);
}

.ds-task-sheet__assignee-list {
    min-width: 0;
}

.ds-task-sheet__assignee-picker .ds-assignee-picker__panel {
    width: min(320px, calc(100vw - 2rem));
}

.ds-task-sheet__priority-trigger,
.ds-task-sheet__date-wrap .ds-date-range__trigger--inline {
    min-height: 2.45rem;
}

.ds-task-sheet__priority-trigger {
    border: 0;
}

.ds-task-sheet__tag-panel {
    width: min(420px, calc(100vw - 2rem));
}

.ds-task-sheet__priority-panel {
    width: min(280px, calc(100vw - 2rem));
}

.ds-task-sheet__toolbar {
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.ds-task-sheet__toolbar > * {
    flex: 0 0 auto;
}

.ds-task-sheet__date-wrap .ds-date-range__trigger--inline,
.ds-task-sheet__priority-trigger,
.ds-task-sheet__spent-time,
.ds-task-sheet__assignee-trigger {
    min-height: 2.45rem;
}

.ds-task-sheet__date-wrap .ds-date-range__trigger--inline,
.ds-task-sheet__priority-trigger,
.ds-task-sheet__spent-time {
    padding-inline: 0.85rem;
}

.ds-task-sheet__assignee-trigger.is-empty {
    padding: 0;
    width: 2.45rem;
    height: 2.45rem;
    justify-content: center;
}

.ds-task-sheet__description-input {
    min-height: 180px;
}

.ds-task-sheet__panel,
.ds-task-sheet__stat-card,
.ds-task-sheet__comment-item,
.ds-task-sheet__subtask-input,
.ds-task-sheet__attachment-thumb {
    border-radius: 14px;
}

.ds-task-sheet__panel {
    padding: 1rem;
}

.ds-task-sheet__panel--description {
    min-height: 240px;
}

.ds-task-sheet__description-input {
    min-height: 160px;
}

.ds-task-sheet__subtask-item {
    min-height: 2.7rem;
}

.ds-task-sheet__stat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ds-task-sheet__inline-submit {
    border-radius: 14px;
}

.ds-task-panel__form {
    display: grid;
    gap: 0.9rem;
}

.ds-task-panel__grid {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ds-task-panel__grid--stacked {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ds-task-panel__field {
    display: grid;
    gap: 0.42rem;
}

.ds-task-panel__field--span-2 {
    grid-column: span 2;
}

.ds-task-panel__field--compact .ds-date-range {
    width: fit-content;
}

.ds-task-panel__label {
    color: var(--color-muted);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: normal;
}

.ds-task-panel__textarea {
    min-height: 112px;
    resize: vertical;
}

.ds-task-select {
    position: relative;
}

.ds-task-select__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    width: 100%;
    min-height: 2.8rem;
    padding: 0.7rem 0.85rem;
    border: 1px solid var(--color-border);
    border-radius: 14px;
    background: color-mix(in srgb, var(--color-surface-strong) 96%, transparent);
    color: var(--color-title);
    text-align: left;
}

.ds-task-select__summary {
    min-width: 0;
    overflow: hidden;
    color: var(--color-text);
    font-size: 0.84rem;
    font-weight: 500;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ds-task-select__chevron {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1rem;
    height: 1rem;
    color: var(--color-muted);
}

.ds-task-select__chevron svg {
    width: 1rem;
    height: 1rem;
}

.ds-task-select__panel {
    z-index: 120;
    width: min(360px, calc(100vw - 2rem));
    padding: 0.9rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
    border-radius: var(--radius-dropdown);
    background: color-mix(in srgb, var(--color-surface-strong) 98%, transparent);
    box-shadow: 0 18px 42px var(--color-shadow);
}

.ds-task-select__list {
    display: grid;
    gap: 0.55rem;
    max-height: 240px;
    overflow-y: auto;
}

.ds-task-select__option {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-height: 2.55rem;
    padding: 0.55rem 0.7rem;
    border: 1px solid var(--color-border);
    border-radius: 14px;
    background: var(--color-surface);
    color: var(--color-title);
    font-size: 0.84rem;
    font-weight: 500;
}

.ds-task-select__option input {
    width: 0.95rem;
    height: 0.95rem;
    accent-color: var(--color-primary);
}

.ds-task-select__option--tag {
    gap: 0.55rem;
}

.ds-task-select__tag-chip {
    width: 0.75rem;
    height: 0.75rem;
    border-radius: 999px;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-surface-input) 82%, transparent);
}

.ds-task-panel__metrics {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ds-task-modal__assignees-panel {
    display: grid;
    gap: 0.65rem;
    padding: 0.9rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-surface-soft) 84%, transparent);
}

.ds-task-modal__assignees-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.ds-task-modal__assignee-option {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    min-height: 2.45rem;
    padding: 0.45rem 0.7rem;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    background: var(--color-surface-soft);
    color: var(--color-title);
}

.ds-task-modal__assignee-option input {
    width: 0.95rem;
    height: 0.95rem;
    accent-color: var(--color-primary);
}

.ds-task-modal__assignee-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.8rem;
    height: 1.8rem;
    border-radius: 999px;
    background: var(--avatar-background, color-mix(in srgb, var(--color-avatar-accent) 20%, var(--color-surface-soft)));
    color: var(--avatar-color, color-mix(in srgb, var(--color-avatar-accent) 84%, var(--color-title)));
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: normal;
}

.ds-task-modal__assignee-name {
    font-size: 0.82rem;
    font-weight: 500;
}

.ds-task-panel__attachment-empty {
    display: grid;
    place-items: center;
    min-height: 84px;
    border: 1px dashed color-mix(in srgb, var(--color-border) 84%, transparent);
    border-radius: 14px;
    background: color-mix(in srgb, var(--color-surface) 92%, transparent);
    color: var(--color-muted);
    font-size: 0.8rem;
    font-weight: 500;
    text-align: center;
    padding: 1rem;
}

.ds-date-range {
    position: relative;
}

.ds-date-range__trigger {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.42rem;
    width: auto;
    height: auto;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--color-primary);
}

.ds-date-range__trigger svg {
    width: 1rem;
    height: 1rem;
}

.ds-date-range__trigger--inline {
    width: auto;
    min-height: 0;
    padding: 0;
    border-radius: 0;
    color: var(--color-muted);
}

.ds-date-range__trigger--inline svg {
    width: 0.92rem;
    height: 0.92rem;
    color: var(--color-primary);
}

.ds-date-range__trigger-text {
    color: inherit;
    font-size: 0.78rem;
    font-weight: 500;
    white-space: nowrap;
}

.ds-date-range.is-overdue .ds-date-range__trigger,
.ds-date-range.is-overdue .ds-date-range__trigger--inline,
.ds-date-range.is-overdue .ds-date-range__trigger-text,
.ds-date-range.is-overdue .ds-date-range__trigger svg,
.ds-date-range.is-overdue .ds-date-range__trigger--inline svg {
    color: var(--color-danger);
}

.ds-date-range.is-overdue .ds-date-range__trigger:hover,
.ds-date-range.is-overdue .ds-date-range__trigger:focus-visible {
    color: var(--color-danger);
}

.ds-date-range__panel {
    position: absolute;
    right: 0;
    top: calc(100% + 0.25rem);
    z-index: 120;
    width: min(360px, calc(100vw - 2rem));
    padding: 0.9rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
    border-radius: var(--radius-dropdown);
    background: color-mix(in srgb, var(--color-surface-strong) 98%, transparent);
    box-shadow: 0 18px 42px var(--color-shadow);
    transform: none;
}

.ds-date-range--with-time .ds-date-range__panel {
    width: min(420px, calc(100vw - 2rem));
}

.ds-date-range__panel-body {
    display: grid;
}

.ds-date-range--single.ds-date-range--with-time .ds-date-range__panel {
    width: min(540px, calc(100vw - 2rem));
}

.ds-date-range--single.ds-date-range--with-time .ds-date-range__panel-body {
    grid-template-columns: minmax(0, 1fr) 168px;
    gap: 1rem;
    align-items: start;
}

.ds-date-range__summary {
    display: grid;
    gap: 0.55rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ds-date-range__summary-item {
    display: flex;
    min-width: 0;
    align-items: center;
    gap: 0.4rem;
    padding: 0.78rem 0.85rem;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    background: var(--color-surface);
    text-align: left;
    transition: border-color 160ms ease, background 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.ds-date-range__summary-fields {
    display: grid;
    gap: 0.45rem;
    min-width: 0;
    flex: 1 1 auto;
}

.ds-date-range__summary-item[data-state='active'] {
    border-color: color-mix(in srgb, var(--project-accent, var(--color-primary)) 36%, var(--color-border-strong));
    background: color-mix(in srgb, var(--project-accent, var(--color-primary)) 10%, var(--color-surface-strong));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--project-accent, var(--color-primary)) 18%, transparent);
}

.ds-date-range__summary-item:focus-visible {
    outline: none;
    transform: translateY(-1px);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--project-accent, var(--color-primary)) 16%, transparent);
}

.ds-date-range__summary-input {
    width: 100%;
    min-width: 0;
    border: 0;
    padding: 0;
    background: transparent;
    color: var(--color-title);
    font-size: 0.86rem;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ds-date-range__summary-input::placeholder {
    color: var(--color-muted);
}

.ds-date-range__summary-input:focus {
    outline: none;
}

.ds-date-range__summary-time-input {
    width: 100%;
    min-width: 0;
    border: 0;
    padding: 0;
    background: transparent;
    color: var(--color-title);
    font-size: 0.8rem;
    font-weight: 500;
}

.ds-date-range__summary-time-input:focus {
    outline: none;
}

.ds-date-range__summary-clear {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.15rem;
    height: 1.15rem;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--color-muted);
    font-size: 1.5rem;
    line-height: 1;
    flex-shrink: 0;
}

.ds-date-range__summary-item[data-state='active'] .ds-date-range__summary-input,
.ds-date-range__summary-item[data-state='active'] .ds-date-range__summary-clear {
    color: var(--color-title);
}

.ds-date-range__calendar {
    margin-top: 0.85rem;
}

.ds-date-range--single .ds-date-range__calendar {
    margin-top: 0;
}

.ds-date-range__calendar-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.ds-date-range__month {
    color: var(--color-title);
    font-size: 0.95rem;
    font-weight: 600;
    text-transform: capitalize;
}

.ds-date-range__nav {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--color-muted);
}

.ds-date-range__nav svg {
    width: 1rem;
    height: 1rem;
}

.ds-date-range__weekdays,
.ds-date-range__days {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.ds-date-range__weekdays {
    margin-top: 0.8rem;
    color: var(--color-muted);
    font-size: 0.74rem;
    font-weight: 600;
    text-align: center;
}

.ds-date-range__days {
    gap: 0.2rem;
    margin-top: 0.55rem;
}

.ds-date-range__day {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 1;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--color-title);
    font-size: 0.84rem;
    font-weight: 400;
}

.ds-date-range__day.is-outside {
    color: color-mix(in srgb, var(--color-muted) 52%, transparent);
}

.ds-date-range__day.is-disabled {
    color: color-mix(in srgb, var(--color-muted) 34%, transparent);
    cursor: not-allowed;
    opacity: 0.45;
}

.ds-date-range__day.is-in-range {
    background: color-mix(in srgb, var(--project-accent, var(--color-primary)) 22%, transparent);
}

.ds-date-range__day.is-start,
.ds-date-range__day.is-end {
    box-shadow: inset 0 0 0 1px var(--color-primary);
}

.ds-date-range__day.is-start,
.ds-date-range__day.is-end {
    background: color-mix(in srgb, var(--project-accent, var(--color-primary)) 18%, transparent);
}

.ds-date-range__day.is-selected {
    background: color-mix(in srgb, var(--project-accent, var(--color-primary)) 18%, transparent);
    box-shadow: inset 0 0 0 1px var(--color-primary);
}

.ds-date-range__day.is-today:not(.is-start):not(.is-end) {
    color: var(--color-secondary);
    box-shadow: inset 0 0 0 1px var(--color-secondary);
}

.ds-date-range__time-panel {
    display: grid;
    align-content: start;
    gap: 0.85rem;
    min-width: 0;
    padding-left: 1rem;
    border-left: 1px solid color-mix(in srgb, var(--color-border) 78%, transparent);
}

.ds-date-range__time-panel-date {
    color: var(--color-title);
    font-size: 0.9rem;
    font-weight: 600;
    line-height: 1.4;
}

.ds-date-range__time-field {
    display: grid;
    gap: 0.45rem;
}

.ds-date-range__time-field > span {
    color: var(--color-muted);
    font-size: 0.74rem;
    font-weight: 600;
}

.ds-date-range__time-input-shell {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.6rem;
    min-height: 3rem;
    padding: 0.78rem 0.85rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 84%, transparent);
    border-radius: 16px;
    background: color-mix(in srgb, var(--color-surface) 90%, transparent);
}

.ds-date-range__time-input-shell svg {
    width: 1rem;
    height: 1rem;
    color: var(--color-muted);
}

.ds-date-range__panel-time-input {
    width: 100%;
    min-width: 0;
    border: 0;
    padding: 0;
    background: transparent;
    color: var(--color-title);
    font-size: 1rem;
    font-weight: 600;
    appearance: none;
    -webkit-appearance: none;
}

.ds-date-range__panel-time-input:focus {
    outline: none;
}

.ds-date-range__summary-time-input,
.ds-date-range__panel-time-input {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: textfield;
}

.ds-date-range__summary-time-input::-webkit-calendar-picker-indicator,
.ds-date-range__summary-time-input::-webkit-clear-button,
.ds-date-range__summary-time-input::-webkit-inner-spin-button,
.ds-date-range__summary-time-input::-webkit-outer-spin-button,
.ds-date-range__panel-time-input::-webkit-calendar-picker-indicator,
.ds-date-range__panel-time-input::-webkit-clear-button,
.ds-date-range__panel-time-input::-webkit-inner-spin-button,
.ds-date-range__panel-time-input::-webkit-outer-spin-button {
    display: none;
    -webkit-appearance: none;
}

.ds-date-range__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: 0.85rem;
    padding-top: 0.8rem;
    border-top: 1px solid color-mix(in srgb, var(--color-border) 72%, transparent);
}

.ds-date-range__footer-action {
    border: 0;
    background: transparent;
    color: var(--color-muted);
    font-size: 0.84rem;
    font-weight: 500;
}

.ds-date-range__footer-action--primary {
    color: var(--color-title);
}

.ds-project-card__edit {
    padding-top: 0.15rem;
}

.ds-project-card__detail-grid {
    display: grid;
    gap: 0.8rem;
}

.ds-project-card__section {
    padding: 0.9rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-surface-soft) 84%, transparent);
}

.ds-task-panel__comment-form {
    display: grid;
    gap: 0.65rem;
}

.ds-task-panel__comment-textarea {
    min-height: 92px;
    resize: vertical;
}

.ds-task-panel__comment-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.ds-task-panel__comment-hint {
    color: var(--color-muted);
    font-size: 0.72rem;
    font-weight: 500;
}

.ds-task-panel__comment {
    display: grid;
    gap: 0.28rem;
    padding: 0.75rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 80%, transparent);
    border-radius: 14px;
    background: color-mix(in srgb, var(--color-surface-strong) 94%, transparent);
}

.ds-task-panel__comment-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    color: var(--color-muted);
    font-size: 0.72rem;
}

.ds-task-panel__comment-meta strong {
    color: var(--color-title);
    font-size: 0.76rem;
}

.ds-task-panel__comment-content {
    color: var(--color-text);
    font-size: 0.8rem;
    line-height: 1.55;
}

.ds-project-card__section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.ds-project-card__section-title {
    color: var(--color-title);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: normal;
}

.ds-project-card__section-meta {
    color: var(--color-muted);
    font-size: 0.72rem;
    font-weight: 500;
}

[class~='rounded-[28px]'],
[class~='rounded-[26px]'],
[class~='rounded-[24px]'],
[class~='rounded-[22px]'],
[class~='rounded-[20px]'],
[class~='rounded-[18px]'],
[class~='rounded-2xl'] {
    border-radius: var(--radius-lg) !important;
}

[class~='rounded-[13px]'],
[class~='rounded-xl'] {
    border-radius: var(--radius-md) !important;
}

.ds-divider {
    border-color: var(--color-border);
}

.ds-selection {
    color: var(--color-title);
}

.ds-logo-mark {
    color: var(--color-primary);
}

::selection {
    background: rgba(0, 76, 255, 0.22);
    color: var(--color-title);
}

[data-theme='dark'] .theme-light-only {
    display: none;
}

[data-theme='light'] .theme-dark-only {
    display: none;
}

@media (max-width: 1024px) {
    .ds-task-modal {
        left: 14px;
        right: 14px;
        width: auto;
        transform: translateY(-50%);
    }

    .ds-task-sheet__stat-grid {
        grid-template-columns: 1fr;
    }

    .ds-task-sheet__time-summary {
        grid-template-columns: 1fr;
    }

    .ds-task-sheet__topbar,
    .ds-task-sheet__comment-actions {
        flex-direction: column;
        align-items: flex-start;
    }

    .ds-task-sheet__topbar-actions {
        width: 100%;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .ds-topbar__session-indicator {
        width: 100%;
    }
    .ds-topbar__session-link {
        flex: 1 1 auto;
    }

    .ds-task-sheet__entity-row,
    .ds-task-sheet__stat-grid {
        grid-template-columns: 1fr;
    }

    .ds-task-panel__metrics {
        grid-template-columns: 1fr;
    }

    .ds-task-sheet__attachment-dropdown {
        width: min(100vw - 2rem, 368px);
    }

    .ds-task-sheet__attachment-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ds-task-panel__grid {
        grid-template-columns: 1fr;
    }

    .ds-task-panel__grid--stacked {
        grid-template-columns: 1fr;
    }

    .ds-task-panel__field--span-2 {
        grid-column: auto;
    }

    .ds-page-loader__topbar {
        padding-inline: 0.9rem;
    }

    .ds-page-loader[data-scope='content'] {
        --loader-sidebar-width: 60px;
    }

    .ds-page-loader__content-grid,
    .ds-page-loader__viewport--auth {
        grid-template-columns: 1fr;
    }

    .ds-page-loader__project-grid,
    .ds-page-loader__profile-grid {
        grid-template-columns: 1fr;
    }

    .ds-page-loader[data-variant='kanban'][data-scope='content'] .ds-page-loader__viewport--content {
        width: 100%;
        max-width: none;
    }

    .ds-page-loader__kanban-columns {
        gap: 1rem;
    }

    .ds-page-loader__kanban-inserter {
        display: none;
    }

    .ds-page-loader__kanban-column {
        flex-basis: min(290px, calc(100vw - 1.5rem));
        width: min(290px, calc(100vw - 1.5rem));
        min-width: min(290px, calc(100vw - 1.5rem));
        max-width: min(290px, calc(100vw - 1.5rem));
    }

    .ds-page-loader__panel--billing-hero,
    .ds-page-loader__billing-item {
        flex-direction: column;
        align-items: flex-start;
    }

    .ds-page-loader__billing-meta {
        justify-content: flex-start;
    }

    .ds-page-loader__auth-media {
        min-height: 28vh;
    }

    .ds-page-loader__auth-panel {
        margin-left: 0;
        margin-top: 1rem;
    }

    .ds-page-loader__line--lg {
        width: min(18rem, 72vw);
    }

    .ds-shell__layout {
        --sidebar-width: 60px;
    }

    .ds-nav-item__label {
        max-width: 0;
        opacity: 0;
        transform: translateX(-6px);
    }

    .ds-sidebar__footer,
    .ds-nav-item {
        justify-content: center;
    }

    .ds-topbar {
        padding-inline: 0.9rem;
    }

    .ds-topbar__leading {
        min-width: 0;
    }

    .ds-project-menu {
        min-width: 0;
    }

    .ds-project-menu__name-input {
        max-width: 180px;
    }

    .ds-project-menu__dropdown {
        left: 0;
        right: auto;
        width: min(220px, calc(100vw - 2rem));
    }

    .ds-project-modal__dialog {
        width: min(560px, calc(100vw - 1.25rem));
    }

    .ds-project-modal__dialog--members {
        width: min(780px, calc(100vw - 1.25rem));
    }

    .ds-project-modal__dialog--settings {
        width: min(760px, calc(100vw - 1.25rem));
    }

    .ds-project-billing__hero,
    .ds-project-billing__item,
    .ds-project-billing__detail-grid {
        grid-template-columns: none;
        flex-direction: column;
        align-items: stretch;
    }

    .ds-project-billing__item-meta {
        justify-content: flex-start;
    }

    .ds-project-billing__report-dialog {
        width: min(100%, calc(100vw - 1.25rem));
    }

    .ds-project-members__item,
    .ds-project-members__item-actions,
    .ds-project-members__form {
        align-items: stretch;
    }

    .ds-project-members__item,
    .ds-project-members__form {
        flex-direction: column;
    }

    .ds-project-members__form-field--search,
    .ds-project-members__form-field--role {
        min-width: 0;
        flex-basis: auto;
    }

    .ds-project-settings__grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .ds-project-settings__field--full {
        grid-column: auto;
    }

    .ds-topbar__account {
        flex-shrink: 0;
    }

    .ds-account-modal__panel {
        width: min(288px, calc(100vw - 1.5rem));
    }

    .ds-dashboard__summary {
        width: 100%;
        justify-content: flex-start;
    }

    .ds-project-page__hero,
    .ds-project-overview,
    .ds-project-toolbar {
        grid-template-columns: 1fr;
    }

    .ds-project-page__hero-stats,
    .ds-project-overview__metrics,
    .ds-project-toolbar__selectors {
        grid-template-columns: 1fr;
    }

    .ds-project-toolbar__actions {
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .ds-project-board__column-form,
    .ds-project-column__composer-actions {
        grid-template-columns: 1fr;
    }

    .ds-dashboard__summary-bar {
        width: 100%;
        flex-wrap: wrap;
    }

    .ds-dashboard__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ds-dashboard-projects {
        grid-template-columns: 1fr;
    }

    .ds-dashboard-tasklist__item {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .ds-dashboard-tasklist__tag,
    .ds-dashboard-tasklist__ghost {
        display: none;
    }

    .ds-project-card__summary,
    .ds-project-card__body,
    .ds-kanban-card__summary,
    .ds-kanban-card__body {
        padding-inline: 0.85rem;
    }

    .ds-date-range__panel {
        left: 0;
        right: auto;
        transform-origin: top left;
    }

    .ds-kanban-reference__columns {
        gap: 1rem;
    }

    .ds-kanban-column {
        flex-basis: min(290px, calc(100vw - 1.5rem));
        width: min(290px, calc(100vw - 1.5rem));
        min-width: min(290px, calc(100vw - 1.5rem));
        max-width: min(290px, calc(100vw - 1.5rem));
    }
}

@media (max-width: 720px) {
    .ds-task-modal {
        top: calc(var(--topbar-height) + 10px);
        right: 10px;
        bottom: 10px;
        left: 10px;
        height: auto;
        transform: none;
    }

    .ds-task-modal__dialog {
        padding: 1rem;
        border-radius: 24px;
    }

    .ds-task-sheet__title-input {
        font-size: 1.7rem;
    }

    .ds-task-sheet__toolbar,
    .ds-task-sheet__timer-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .ds-task-sheet__manual-session-fields {
        display: grid;
        width: 100%;
        grid-template-columns: 1fr;
    }

    .ds-task-sheet__manual-session-form {
        display: grid;
        width: 100%;
        grid-template-columns: 1fr;
    }

    .ds-task-sheet__manual-session-actions,
    .ds-task-sheet__manual-session-submit {
        width: 100%;
    }

    .ds-task-sheet__topbar,
    .ds-task-sheet__manual-session-picker {
        width: 100%;
        align-items: flex-start;
        flex-direction: column;
    }

    .ds-task-sheet__manual-session-picker .ds-date-range {
        width: 100%;
    }

    .ds-task-sheet__manual-session-picker .ds-date-range__trigger--inline {
        width: 100%;
        min-height: 2.45rem;
        padding: 0.45rem 0.85rem;
        justify-content: flex-start;
    }

    .ds-task-sheet__assignee-picker,
    .ds-task-sheet__date-wrap {
        width: 100%;
    }

    .ds-task-sheet__manual-session-picker .ds-date-range__trigger-text {
        font-size: 0.84rem;
    }

    .ds-date-range--single.ds-date-range--with-time .ds-date-range__panel-body {
        grid-template-columns: 1fr;
    }

    .ds-date-range__time-panel {
        padding-top: 0.9rem;
        padding-left: 0;
        border-top: 1px solid color-mix(in srgb, var(--color-border) 78%, transparent);
        border-left: 0;
    }

    .ds-task-sheet__assignee-trigger {
        width: 100%;
        justify-content: space-between;
    }

    .ds-task-sheet__plus-button {
        align-self: flex-start;
    }

    .ds-task-sheet__color-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .ds-task-sheet__toolbar-item,
    .ds-task-sheet__priority-wrap,
    .ds-task-sheet__spent-time,
    .ds-task-sheet__toolbar .ds-date-range,
    .ds-task-select--toolbar {
        width: 100%;
    }

    .ds-task-select--toolbar .ds-task-select__trigger,
    .ds-task-sheet__toolbar .ds-date-range__trigger--inline,
    .ds-task-sheet__priority-wrap,
    .ds-task-sheet__spent-time {
        width: 100%;
        justify-content: space-between;
    }

    .ds-task-sheet__subtask-item,
    .ds-task-sheet__subtask-item--draft {
        grid-template-columns: auto auto minmax(0, 1fr);
        align-items: flex-start;
    }

    .ds-task-sheet__subtask-side {
        grid-column: 1 / -1;
        width: 100%;
        justify-content: space-between;
        padding-left: 3.35rem;
    }

    .ds-task-sheet__comment-submit {
        width: 100%;
    }

    .ds-task-sheet__activity-item {
        flex-wrap: wrap;
        align-items: flex-start;
    }

    .ds-task-sheet__activity-item form {
        margin-left: 0;
    }

    .ds-task-sheet__activity-cell--status {
        text-align: left;
    }

    .ds-task-modal__header-actions,
    .ds-task-panel__comment-actions,
    .ds-task-panel__comment-meta {
        align-items: flex-start;
        flex-direction: column;
    }
}