/* =============================================================================
 * sudoplan — application stylesheet
 * =============================================================================
 * A small, hand-rolled CSS file. No frameworks, no build step. CSS custom
 * properties drive the theme so dark mode is a single :root override away.
 * ===========================================================================*/

/* ---------------------------------------------------------------------------
 * Design tokens
 * ------------------------------------------------------------------------ */
:root {
    /* Color palette */
    --color-bg:           #f7f8fa;
    --color-bg-elevated:  #ffffff;
    --color-bg-subtle:    #eef0f4;
    --color-border:       #e1e5ec;
    --color-border-strong:#cbd2dc;

    --color-text:         #1f2430;
    --color-text-muted:   #5b6573;
    --color-text-subtle:  #8a93a3;
    --color-text-inverse: #ffffff;

    --color-primary:      #4a6cf7;
    --color-primary-hover:#3a5ce0;
    --color-primary-soft: #e8edfe;

    --color-success:      #2f9e6b;
    --color-success-soft: #e6f5ee;

    --color-danger:       #d6443a;
    --color-danger-soft:  #fbeae8;

    --color-warning:      #c98a17;
    --color-warning-soft: #fbf2dd;

    /* Spacing */
    --space-1:  4px;
    --space-2:  8px;
    --space-3:  12px;
    --space-4:  16px;
    --space-5:  24px;
    --space-6:  32px;
    --space-7:  48px;
    --space-8:  64px;

    /* Radii */
    --radius-sm: 4px;
    --radius-md: 6px;
    --radius-lg: 10px;

    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
    --shadow-md: 0 4px 12px rgba(15, 23, 42, 0.08);
    --shadow-lg: 0 12px 28px rgba(15, 23, 42, 0.10);

    /* Type */
    --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --font-mono: ui-monospace, SFMono-Regular, "JetBrains Mono", Menlo, Consolas, "Liberation Mono", monospace;

    /* Layout */
    --topbar-height: 56px;
    --max-content:   1200px;
}

@media (prefers-color-scheme: dark) {
    :root {
        --color-bg:           #0f1218;
        --color-bg-elevated:  #181c25;
        --color-bg-subtle:    #1f2430;
        --color-border:       #2a3140;
        --color-border-strong:#3a4252;

        --color-text:         #e6e9ef;
        --color-text-muted:   #9ba5b5;
        --color-text-subtle:  #6b7587;
        --color-text-inverse: #0f1218;

        --color-primary:      #6a87fa;
        --color-primary-hover:#7d97fb;
        --color-primary-soft: #1a2547;

        --color-success-soft: #15281f;
        --color-danger-soft:  #2a1715;
        --color-warning-soft: #2a210f;

        --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.30);
        --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.40);
        --shadow-lg: 0 12px 28px rgba(0, 0, 0, 0.50);
    }
}

/* ---------------------------------------------------------------------------
 * Reset + base
 * ------------------------------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    height: 100%;
}

body {
    background: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-sans);
    font-size: 14px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

a {
    color: var(--color-primary);
    text-decoration: none;
}
a:hover { text-decoration: underline; }

code {
    font-family: var(--font-mono);
    font-size: 0.92em;
    background: var(--color-bg-subtle);
    padding: 1px 5px;
    border-radius: var(--radius-sm);
}

h1, h2, h3, h4 {
    margin: 0 0 var(--space-3) 0;
    font-weight: 600;
    letter-spacing: -0.01em;
}

p { margin: 0 0 var(--space-3) 0; }
p:last-child { margin-bottom: 0; }

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

/* ---------------------------------------------------------------------------
 * Topbar
 * ------------------------------------------------------------------------ */
.topbar {
    height: var(--topbar-height);
    background: var(--color-bg-elevated);
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 50;
}

.topbar-inner {
    height: 100%;
    max-width: var(--max-content);
    margin: 0 auto;
    padding: 0 var(--space-5);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-5);
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-text);
    font-weight: 600;
    text-decoration: none;
}
.brand:hover { text-decoration: none; }

.brand-mark {
    display: inline-grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border-radius: var(--radius-sm);
    background: var(--color-primary);
    color: var(--color-text-inverse);
    font-family: var(--font-mono);
    font-weight: 700;
    font-size: 14px;
}

.brand-name { letter-spacing: -0.01em; }

.topbar-nav {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.topbar-user {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-text-muted);
}

.topbar-user-link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-text-muted);
    text-decoration: none;
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    transition: background 0.1s, color 0.1s;
}
.topbar-user-link:hover {
    background: var(--color-primary-soft);
    color: var(--color-text);
}

.avatar {
    display: inline-grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--color-primary-soft);
    color: var(--color-primary);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.04em;
}

.logout-form { margin: 0; }

/* ---------------------------------------------------------------------------
 * Layout
 * ------------------------------------------------------------------------ */
.main {
    max-width: var(--max-content);
    margin: 0 auto;
    padding: var(--space-6) var(--space-5);
}

.footer {
    max-width: var(--max-content);
    margin: var(--space-7) auto var(--space-5);
    padding: 0 var(--space-5);
    color: var(--color-text-subtle);
    text-align: center;
}

.page {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
}

.page-header h1 {
    font-size: 24px;
    margin: 0 0 var(--space-1);
}

.page-sub {
    color: var(--color-text-muted);
    margin: 0;
}

/* ---------------------------------------------------------------------------
 * Cards
 * ------------------------------------------------------------------------ */
.card {
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
}

.empty-state h2 {
    font-size: 18px;
    margin-bottom: var(--space-2);
}

/* ---------------------------------------------------------------------------
 * Stats
 * ------------------------------------------------------------------------ */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--space-4);
}

.stat-card {
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-4) var(--space-5);
    box-shadow: var(--shadow-sm);
}

.stat-label {
    color: var(--color-text-muted);
    font-size: 12px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: var(--space-2);
}

.stat-value {
    font-size: 28px;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--color-text);
}

/* ---------------------------------------------------------------------------
 * Buttons
 * ------------------------------------------------------------------------ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: 8px 14px;
    font: inherit;
    font-size: 14px;
    font-weight: 500;
    border: 1px solid transparent;
    border-radius: var(--radius-md);
    cursor: pointer;
    background: transparent;
    color: var(--color-text);
    transition: background-color 0.12s ease, border-color 0.12s ease, color 0.12s ease;
    text-decoration: none;
}
.btn:hover { text-decoration: none; }
.btn:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.btn-primary {
    background: var(--color-primary);
    color: var(--color-text-inverse);
    border-color: var(--color-primary);
}
.btn-primary:hover {
    background: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
    color: var(--color-text-inverse);
}

.btn-ghost {
    background: transparent;
    color: var(--color-text-muted);
    border-color: var(--color-border);
}
.btn-ghost:hover {
    background: var(--color-bg-subtle);
    color: var(--color-text);
}

.btn-block {
    width: 100%;
}

/* ---------------------------------------------------------------------------
 * Forms
 * ------------------------------------------------------------------------ */
.form {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.form-row {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.form-row label {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-muted);
}

.form-row input[type="text"],
.form-row input[type="email"],
.form-row input[type="password"],
.form-row textarea,
.form-row select {
    width: 100%;
    padding: 9px 12px;
    font: inherit;
    font-size: 14px;
    color: var(--color-text);
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    transition: border-color 0.12s ease, box-shadow 0.12s ease;
}
.form-row input:focus,
.form-row textarea:focus,
.form-row select:focus {
    border-color: var(--color-primary);
    outline: none;
    box-shadow: 0 0 0 3px var(--color-primary-soft);
}

.form-actions {
    display: flex;
    justify-content: stretch;
    gap: var(--space-3);
}

.form-errors {
    background: var(--color-danger-soft);
    border: 1px solid var(--color-danger);
    color: var(--color-danger);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
}
.form-errors ul {
    margin: 0;
    padding-left: var(--space-5);
}

/* ---------------------------------------------------------------------------
 * Flash messages
 * ------------------------------------------------------------------------ */
.flash-host {
    max-width: var(--max-content);
    margin: var(--space-3) auto 0;
    padding: 0 var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.flash {
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    border: 1px solid transparent;
    font-size: 14px;
}

.flash-success {
    background: var(--color-success-soft);
    border-color: var(--color-success);
    color: var(--color-success);
}

.flash-error {
    background: var(--color-danger-soft);
    border-color: var(--color-danger);
    color: var(--color-danger);
}

/* ---------------------------------------------------------------------------
 * Auth pages
 * ------------------------------------------------------------------------ */
.auth-body {
    background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-subtle) 100%);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-5);
}

.auth-shell {
    width: 100%;
    max-width: 400px;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.auth-brand {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    font-size: 20px;
    font-weight: 600;
    margin-bottom: var(--space-2);
}

.auth-brand .brand-mark {
    width: 32px;
    height: 32px;
    font-size: 16px;
}

.auth-card {
    padding: var(--space-6) var(--space-5);
    box-shadow: var(--shadow-md);
}

.auth-title {
    font-size: 20px;
    margin-bottom: var(--space-2);
}

.auth-sub {
    color: var(--color-text-muted);
    margin-bottom: var(--space-5);
}

.auth-footer {
    text-align: center;
    color: var(--color-text-subtle);
    margin: 0;
}

/* ---------------------------------------------------------------------------
 * Errors
 * ------------------------------------------------------------------------ */
.error-page {
    text-align: center;
    padding: var(--space-7) var(--space-5);
}
.error-page h1 {
    font-size: 72px;
    color: var(--color-text-subtle);
    margin: 0 0 var(--space-3);
    letter-spacing: -0.04em;
}

/* ---------------------------------------------------------------------------
 * Phase 2: shared utilities
 * ------------------------------------------------------------------------ */
[x-cloak] { display: none !important; }

.topbar-link {
    color: var(--color-text-muted);
    font-weight: 500;
    text-decoration: none;
    padding: 6px 10px;
    border-radius: var(--radius-sm);
}
.topbar-link:hover {
    color: var(--color-text);
    background: var(--color-bg-subtle);
    text-decoration: none;
}

.page-narrow { max-width: 720px; margin: 0 auto; }

.page-header-row {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--space-4);
}

.breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-text-muted);
    font-size: 13px;
    margin: 0 0 var(--space-2);
}
.breadcrumb a {
    color: var(--color-text-muted);
}
.breadcrumb a:hover { color: var(--color-text); }
.breadcrumb code { background: transparent; padding: 0; }

.btn-sm {
    padding: 4px 10px;
    font-size: 13px;
}

.btn-danger {
    color: var(--color-danger);
}
.btn-danger:hover {
    background: var(--color-danger-soft);
    color: var(--color-danger);
    border-color: var(--color-danger);
}

.form-hint {
    color: var(--color-text-subtle);
    font-size: 12px;
    font-weight: 400;
}

.form-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
}
.form-grid-3 {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: var(--space-4);
}
@media (max-width: 640px) {
    .form-grid-2, .form-grid-3 { grid-template-columns: 1fr; }
}

.form-fieldset {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-4);
}
.form-fieldset legend {
    padding: 0 var(--space-2);
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-muted);
}

.card-header-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    margin-bottom: var(--space-3);
}
.card-header-row h2 {
    margin: 0;
    font-size: 16px;
}

.badge {
    display: inline-block;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-radius: 999px;
    background: var(--color-bg-subtle);
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
}
.badge-warn {
    background: var(--color-warning-soft);
    color: var(--color-warning);
    border-color: var(--color-warning);
}

/* ---------------------------------------------------------------------------
 * Project list / card
 * ------------------------------------------------------------------------ */
.project-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--space-4);
}
.project-grid-compact {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}

.project-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-4);
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    color: var(--color-text);
    text-decoration: none;
    transition: border-color 0.12s ease, transform 0.12s ease, box-shadow 0.12s ease;
}
.project-card:hover {
    text-decoration: none;
    border-color: var(--color-border-strong);
    box-shadow: var(--shadow-md);
}

.project-card-head {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}
.project-card-title h3 {
    margin: 0 0 2px;
    font-size: 15px;
    font-weight: 600;
}

.project-mark {
    display: inline-grid;
    place-items: center;
    width: 32px; height: 32px;
    border-radius: var(--radius-sm);
    font-family: var(--font-mono);
    font-weight: 700;
    color: #fff;
}
.project-mark-lg {
    width: 44px; height: 44px;
    font-size: 18px;
    border-radius: var(--radius-md);
}

.project-key {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--color-text-subtle);
    background: transparent;
    padding: 0;
}

.project-desc {
    color: var(--color-text-muted);
    font-size: 13px;
    margin: 0;
}
.project-card-stats {
    display: flex;
    gap: var(--space-4);
    color: var(--color-text-subtle);
    font-size: 12px;
}
.project-card-stats strong {
    color: var(--color-text);
    font-weight: 600;
    margin-right: 2px;
}

/* ---------------------------------------------------------------------------
 * Project header (detail page)
 * ------------------------------------------------------------------------ */
.project-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
}
.project-header-main {
    display: flex;
    align-items: center;
    gap: var(--space-4);
}
.project-header-main h1 {
    margin: 0 0 4px;
    font-size: 22px;
}
.project-header-actions {
    display: flex;
    gap: var(--space-2);
    flex-shrink: 0;
}

/* ---------------------------------------------------------------------------
 * Filter bar
 * ------------------------------------------------------------------------ */
.filter-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-2) var(--space-3);
}
.filter-input {
    flex: 1 1 220px;
    min-width: 180px;
    padding: 6px 10px;
    font: inherit;
    font-size: 13px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    color: var(--color-text);
}
.filter-select {
    padding: 6px 10px;
    font: inherit;
    font-size: 13px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    color: var(--color-text);
}

/* ---------------------------------------------------------------------------
 * Issue list (Linear-style grouped by status)
 * ------------------------------------------------------------------------ */
.status-group {
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: var(--space-3);
}
.status-group-head {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--color-bg-subtle);
    border-bottom: 1px solid var(--color-border);
}
.status-count {
    color: var(--color-text-subtle);
    font-size: 12px;
    font-weight: 500;
}

.status-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 2px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    color: var(--color-text);
    background: var(--color-bg);
    border: 1px solid var(--color-border);
}
.status-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-text-subtle);
}

.status-cat-backlog   { color: #6b7280; }
.status-cat-unstarted { color: #4b5563; }
.status-cat-todo      { color: #4b5563; }
.status-cat-started   { color: #4a90e2; }
.status-cat-in_progress { color: #4a90e2; }
.status-cat-completed { color: #2f9e6b; }
.status-cat-done      { color: #2f9e6b; }
.status-cat-cancelled { color: #9ca3af; }

.issue-list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.issue-row {
    display: grid;
    grid-template-columns: 28px 100px 1fr auto;
    align-items: center;
    gap: var(--space-3);
    padding: 10px var(--space-4);
    border-bottom: 1px solid var(--color-border);
    transition: background-color 0.1s ease;
}
.issue-row:last-child { border-bottom: 0; }
.issue-row:hover { background: var(--color-bg-subtle); }

.issue-type {
    display: inline-grid;
    place-items: center;
    width: 22px;
    height: 22px;
    border-radius: var(--radius-sm);
    font-family: var(--font-mono);
    font-weight: 700;
    font-size: 11px;
    background: var(--color-bg-subtle);
    border: 1px solid var(--color-border);
}

.issue-key {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--color-text-subtle);
    text-decoration: none;
}
.issue-key:hover { color: var(--color-text); text-decoration: none; }

.issue-summary {
    color: var(--color-text);
    text-decoration: none;
    font-size: 14px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.issue-summary:hover { text-decoration: underline; }

.issue-meta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
}

.priority-badge {
    display: inline-grid;
    place-items: center;
    width: 28px;
    height: 20px;
    border-radius: var(--radius-sm);
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 600;
    background: var(--color-bg-subtle);
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
}
.priority-1 { color: #d6443a; border-color: #d6443a; }
.priority-2 { color: #c98a17; border-color: #c98a17; }
.priority-3 { color: var(--color-text-muted); }
.priority-4 { color: var(--color-text-subtle); }
.priority-5 { color: var(--color-text-subtle); opacity: 0.7; }

.assignee-pill {
    display: inline-grid;
    place-items: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--color-primary-soft);
    color: var(--color-primary);
    font-size: 11px;
    font-weight: 600;
}
.assignee-empty {
    background: var(--color-bg-subtle);
    color: var(--color-text-subtle);
    border: 1px dashed var(--color-border-strong);
}

/* ---------------------------------------------------------------------------
 * Issue detail page
 * ------------------------------------------------------------------------ */
.issue-page { gap: var(--space-3); }

.issue-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: var(--space-4);
}
@media (max-width: 900px) {
    .issue-layout { grid-template-columns: 1fr; }
}

.issue-main { padding: var(--space-5); }

.issue-summary-line {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    margin-bottom: var(--space-2);
}
.issue-summary-text {
    margin: 0;
    font-size: 22px;
    line-height: 1.3;
    font-weight: 600;
}

.issue-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    font-size: 13px;
    margin-bottom: var(--space-5);
}

.issue-description h3,
.issue-activity h3 {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-muted);
    margin: var(--space-5) 0 var(--space-3);
}
.issue-description h3:first-child { margin-top: 0; }
.issue-description-body {
    line-height: 1.6;
    color: var(--color-text);
}

.activity-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.activity-item {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    align-items: baseline;
    padding: var(--space-2) 0;
    border-bottom: 1px dashed var(--color-border);
    font-size: 13px;
}
.activity-item:last-child { border-bottom: 0; }
.activity-actor { font-weight: 600; color: var(--color-text); }
.activity-time { font-size: 12px; }

.issue-side {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}
.issue-side-card { padding: var(--space-4); }
.side-title {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-muted);
    margin: 0 0 var(--space-3);
}
.side-row {
    display: grid;
    grid-template-columns: 90px 1fr;
    gap: var(--space-3);
    align-items: center;
    padding: 6px 0;
    border-bottom: 1px solid var(--color-border);
    font-size: 13px;
}
.side-row:last-child { border-bottom: 0; }
.side-label { color: var(--color-text-muted); }
.side-value { color: var(--color-text); }
.side-desc { font-size: 12px; margin: 0 0 var(--space-3); }

.inline-edit { display: inline-block; width: 100%; }
.inline-select {
    width: 100%;
    padding: 4px 6px;
    font: inherit;
    font-size: 13px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    color: var(--color-text);
}

/* Commit snippet card */
.commit-card { display: flex; flex-direction: column; gap: var(--space-2); }
.commit-tabs {
    display: inline-flex;
    background: var(--color-bg-subtle);
    border-radius: var(--radius-sm);
    padding: 2px;
    align-self: flex-start;
}
.commit-tab {
    padding: 4px 10px;
    font: inherit;
    font-size: 12px;
    border: 0;
    background: transparent;
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
    cursor: pointer;
}
.commit-tab.active {
    background: var(--color-bg-elevated);
    color: var(--color-text);
    box-shadow: var(--shadow-sm);
}
.commit-snippet {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: var(--space-2) var(--space-3);
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--color-text);
    overflow-x: auto;
    white-space: pre-wrap;
    word-break: break-word;
    margin: 0;
}

.danger-zone { border-color: var(--color-danger-soft); }

/* ---------------------------------------------------------------------------
 * Tabs
 * ------------------------------------------------------------------------ */
.tabs {
    display: flex;
    gap: var(--space-1);
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--space-4);
}
.tab {
    padding: 10px var(--space-4);
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
}
.tab:hover { color: var(--color-text); text-decoration: none; }
.tab-active {
    color: var(--color-text);
    border-bottom-color: var(--color-primary);
}

/* ---------------------------------------------------------------------------
 * Data list (settings rows)
 * ------------------------------------------------------------------------ */
.data-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
    background: var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.data-list-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--color-bg-elevated);
}
.data-list-name {
    font-weight: 500;
    color: var(--color-text);
}
.data-list-key {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--color-text-subtle);
    background: transparent;
    padding: 0;
}
.data-list-desc { flex: 1 1 200px; font-size: 13px; }

.type-mark {
    display: inline-grid;
    place-items: center;
    width: 22px;
    height: 22px;
    border-radius: var(--radius-sm);
    font-family: var(--font-mono);
    font-weight: 700;
    font-size: 11px;
    background: var(--color-bg-subtle);
    border: 1px solid var(--color-border);
}

.form-inline-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
    flex: 1 1 auto;
    margin: 0;
}
.form-inline-tail { margin: 0; }

.inline-text {
    flex: 1 1 160px;
    min-width: 140px;
    padding: 5px 8px;
    font: inherit;
    font-size: 13px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    color: var(--color-text);
}
.inline-color {
    width: 32px;
    height: 28px;
    padding: 0;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    cursor: pointer;
}
.inline-number {
    width: 60px;
    padding: 5px 6px;
    font: inherit;
    font-size: 13px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    color: var(--color-text);
}
.inline-check {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--color-text-muted);
}

/* ---------------------------------------------------------------------------
 * Phase 3: markdown body styles
 * ------------------------------------------------------------------------ */
.markdown-body {
    line-height: 1.6;
    color: var(--color-text);
}
.markdown-body h1,
.markdown-body h2,
.markdown-body h3,
.markdown-body h4 {
    margin: var(--space-5) 0 var(--space-2);
    font-weight: 600;
}
.markdown-body h1 { font-size: 20px; }
.markdown-body h2 { font-size: 17px; }
.markdown-body h3 { font-size: 15px; }
.markdown-body h4 { font-size: 14px; }
.markdown-body :first-child { margin-top: 0; }
.markdown-body p { margin: 0 0 var(--space-3); }
.markdown-body ul,
.markdown-body ol { margin: 0 0 var(--space-3) var(--space-5); padding: 0; }
.markdown-body li { margin: 4px 0; }
.markdown-body blockquote {
    margin: var(--space-3) 0;
    padding: 4px var(--space-4);
    border-left: 3px solid var(--color-border-strong);
    color: var(--color-text-muted);
    background: var(--color-bg-subtle);
}
.markdown-body code {
    font-family: var(--font-mono);
    font-size: 0.92em;
    background: var(--color-bg-subtle);
    padding: 1px 5px;
    border-radius: var(--radius-sm);
}
.markdown-body pre {
    background: var(--color-bg-subtle);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    overflow-x: auto;
    margin: var(--space-3) 0;
    font-size: 13px;
    line-height: 1.5;
}
.markdown-body pre code {
    background: transparent;
    padding: 0;
}
.markdown-body table {
    border-collapse: collapse;
    margin: var(--space-3) 0;
    font-size: 13px;
}
.markdown-body th,
.markdown-body td {
    border: 1px solid var(--color-border);
    padding: 6px 10px;
    text-align: left;
}
.markdown-body th {
    background: var(--color-bg-subtle);
    font-weight: 600;
}
.markdown-body a {
    color: var(--color-primary);
}
.markdown-body img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
}
.markdown-body input[type="checkbox"] {
    margin-right: 4px;
}
.markdown-body hr {
    border: 0;
    border-top: 1px solid var(--color-border);
    margin: var(--space-4) 0;
}

/* ---------------------------------------------------------------------------
 * Comments
 * ------------------------------------------------------------------------ */
.issue-comments,
.issue-attachments {
    margin-top: var(--space-5);
}
.issue-comments h3,
.issue-attachments h3 {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-muted);
    margin: 0 0 var(--space-3);
}
.comments-thread {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}
.comments-empty {
    padding: var(--space-3) 0;
    font-size: 13px;
}
.comment {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
}
.comment-head {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-2);
    flex-wrap: wrap;
}
.avatar-sm {
    width: 22px;
    height: 22px;
    font-size: 10px;
}
.comment-author { font-weight: 600; color: var(--color-text); }
.comment-time { font-size: 12px; }
.comment-edited {
    font-size: 11px;
    font-style: italic;
}
.comment-actions {
    margin-left: auto;
    display: inline-flex;
    gap: var(--space-1);
    align-items: center;
}
.comment-body { font-size: 14px; }
.comment-edit-form { display: flex; flex-direction: column; gap: var(--space-2); }
.comment-edit-actions { display: flex; gap: var(--space-2); justify-content: flex-end; }

.comment-textarea {
    width: 100%;
    padding: var(--space-3);
    font: inherit;
    font-family: var(--font-mono);
    font-size: 13px;
    color: var(--color-text);
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    resize: vertical;
}
.comment-textarea:focus {
    border-color: var(--color-primary);
    outline: none;
    box-shadow: 0 0 0 3px var(--color-primary-soft);
}

.comment-composer {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3);
}
.comment-composer-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
    flex-wrap: wrap;
}

/* ---------------------------------------------------------------------------
 * Attachments
 * ------------------------------------------------------------------------ */
.attachments-list { margin-bottom: var(--space-3); }
.attachments-empty { font-size: 13px; padding: var(--space-2) 0; }

.attachment-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--space-3);
    list-style: none;
    padding: 0;
    margin: 0 0 var(--space-3);
}
.attachment-item {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    padding: var(--space-2);
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}
.attachment-thumb {
    display: block;
    aspect-ratio: 1.4 / 1;
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--color-bg-subtle);
}
.attachment-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.attachment-icon {
    display: grid;
    place-items: center;
    aspect-ratio: 1.4 / 1;
    border-radius: var(--radius-sm);
    background: var(--color-bg-subtle);
    color: var(--color-text-muted);
    text-decoration: none;
    font-family: var(--font-mono);
    font-weight: 700;
}
.attachment-ext {
    font-size: 14px;
    letter-spacing: 0.05em;
}
.attachment-meta {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 12px;
}
.attachment-name {
    font-weight: 500;
    color: var(--color-text);
    text-decoration: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.attachment-size {
    color: var(--color-text-subtle);
    font-size: 11px;
}
.attachment-item .form-inline-tail {
    position: absolute;
    top: 6px;
    right: 6px;
}
.attachment-item .btn-sm {
    padding: 0 6px;
    font-size: 14px;
    line-height: 18px;
}

.attachment-upload {
    display: block;
}
.attachment-upload-label {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: var(--space-5) var(--space-4);
    border: 2px dashed var(--color-border-strong);
    border-radius: var(--radius-md);
    text-align: center;
    cursor: pointer;
    transition: border-color 0.12s, background-color 0.12s;
}
.attachment-upload-label:hover {
    border-color: var(--color-primary);
    background: var(--color-primary-soft);
}
.attachment-upload-drag .attachment-upload-label {
    border-color: var(--color-primary);
    background: var(--color-primary-soft);
}
.attachment-upload-cta strong { color: var(--color-primary); }
.attachment-upload-hint { font-size: 12px; }

/* ---------------------------------------------------------------------------
 * User picker
 * ------------------------------------------------------------------------ */
.user-picker {
    position: relative;
    width: 100%;
}
.user-picker-button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 6px 10px;
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    font: inherit;
    font-size: 13px;
    color: var(--color-text);
    cursor: pointer;
    text-align: left;
    gap: var(--space-2);
    /* Keep button locked to its column width; long names get ellipsized
     * in the button itself but show in full in the popover. */
    overflow: hidden;
}
.user-picker-button > span:not(.user-picker-caret) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}
.user-picker-button:hover {
    border-color: var(--color-primary);
}
.user-picker-caret {
    color: var(--color-text-subtle);
    margin-left: var(--space-2);
    flex-shrink: 0;
}
.user-picker-popover {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    /* No `right: 0` — let the popover grow to fit its content. */
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    padding: var(--space-2);
    z-index: 30;
    max-height: 320px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    /* Anchor to the button width but allow expansion to fit names. The
     * widest sensible value before we start clipping the page chrome
     * is ~320px, plenty for "firstname lastname @username" rows. */
    min-width: 100%;
    width: max-content;
    max-width: min(360px, 90vw);
}
.user-picker-search {
    width: 100%;
    padding: 6px 10px;
    font: inherit;
    font-size: 13px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    color: var(--color-text);
    box-sizing: border-box;
}
.user-picker-search:focus {
    outline: none;
    border-color: var(--color-primary);
}
.user-picker-results {
    min-height: 30px;
}
.user-picker-hint {
    font-size: 12px;
    padding: var(--space-2);
    margin: 0;
}
.user-picker-options {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.user-picker-option {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: 6px var(--space-2);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: 13px;
}
.user-picker-option:hover {
    background: var(--color-bg-subtle);
}
.user-picker-name {
    flex: 1;
    color: var(--color-text);
}
.user-picker-username {
    font-size: 11px;
    font-family: var(--font-mono);
}
.user-picker-clear {
    padding: 6px var(--space-2);
    background: transparent;
    border: 0;
    border-top: 1px solid var(--color-border);
    color: var(--color-text-muted);
    font: inherit;
    font-size: 12px;
    cursor: pointer;
    text-align: left;
}
.user-picker-clear:hover {
    color: var(--color-danger);
}

/* ---------------------------------------------------------------------------
 * Phase 4: Markdown editor toolbar
 * ------------------------------------------------------------------------ */
.md-editor {
    display: flex;
    flex-direction: column;
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.md-editor:focus-within {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-primary-soft);
}
.md-editor-tabs {
    display: flex;
    gap: var(--space-1);
    background: var(--color-bg-subtle);
    border-bottom: 1px solid var(--color-border);
    padding: 4px var(--space-2);
    flex-wrap: wrap;
    align-items: center;
}
.md-tab {
    padding: 4px 10px;
    background: transparent;
    border: 0;
    font: inherit;
    font-size: 12px;
    color: var(--color-text-muted);
    border-radius: var(--radius-sm);
    cursor: pointer;
}
.md-tab.active {
    background: var(--color-bg-elevated);
    color: var(--color-text);
    box-shadow: var(--shadow-sm);
}
.md-toolbar {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    margin-left: var(--space-3);
    padding-left: var(--space-3);
    border-left: 1px solid var(--color-border);
}
.md-btn {
    display: inline-grid;
    place-items: center;
    width: 26px;
    height: 26px;
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
    font: inherit;
    font-size: 12px;
    cursor: pointer;
}
.md-btn:hover {
    background: var(--color-bg-elevated);
    color: var(--color-text);
}
.md-sep {
    display: inline-block;
    width: 1px;
    height: 18px;
    background: var(--color-border);
    margin: 0 4px;
}
.md-textarea, .md-editor .comment-textarea {
    border: 0;
    border-radius: 0;
    box-shadow: none;
}
.md-textarea:focus { box-shadow: none; outline: none; }
.md-preview {
    padding: var(--space-3) var(--space-4);
    min-height: 80px;
    font-size: 14px;
}

/* ---------------------------------------------------------------------------
 * Phase 4: Kanban board
 * ------------------------------------------------------------------------ */
.board-page {
    /* Use full width for the board */
    max-width: none;
}
.board {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: var(--space-3);
    padding-bottom: var(--space-3);
}
.board-col {
    display: flex;
    flex-direction: column;
    background: var(--color-bg-subtle);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    min-height: 200px;
    /* Each column gets its own scroll region — no global max-height that
     * forced the whole board to stay in viewport */
    max-height: 70vh;
}
.board-col-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3);
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
}
.board-col-count {
    font-size: 12px;
    font-weight: 500;
    color: var(--color-text-subtle);
}
.board-col-overwip {
    color: var(--color-danger);
    font-weight: 700;
}
.board-col-body {
    flex: 1;
    overflow-y: auto;
    padding: var(--space-2);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    min-height: 100px;
}
.board-card {
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-2) var(--space-3);
    cursor: grab;
    transition: box-shadow 0.12s ease, border-color 0.12s ease;
    box-shadow: var(--shadow-sm);
}
.board-card:hover {
    border-color: var(--color-border-strong);
    box-shadow: var(--shadow-md);
}
.board-card-head {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: 4px;
}
.board-card-key {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--color-text-subtle);
    text-decoration: none;
}
.board-card-summary {
    display: block;
    color: var(--color-text);
    text-decoration: none;
    font-size: 13px;
    line-height: 1.35;
    margin-bottom: var(--space-2);
}
.board-card-summary:hover { text-decoration: underline; }
.board-card-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
}

/* SortableJS classes */
.board-card-ghost {
    opacity: 0.4;
    background: var(--color-primary-soft);
    border-color: var(--color-primary);
}
.board-card-chosen { cursor: grabbing; }
.board-card-drag {
    box-shadow: var(--shadow-md);
    transform: rotate(2deg);
}

/* ---------------------------------------------------------------------------
 * Phase 4: Sprints
 * ------------------------------------------------------------------------ */
.section-h {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-muted);
    margin: var(--space-5) 0 var(--space-2);
}
.section-h:first-child { margin-top: 0; }

.sprint-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}
.sprint-grid-completed { opacity: 0.85; }

.sprint-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    box-shadow: var(--shadow-sm);
}
.sprint-state-active { border-left: 3px solid var(--color-primary); }
.sprint-state-completed { opacity: 0.85; }
.sprint-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
}
.sprint-card-name {
    color: var(--color-text);
    font-weight: 600;
    text-decoration: none;
    font-size: 15px;
}
.sprint-state-badge {
    display: inline-block;
    padding: 1px 8px;
    background: var(--color-bg-subtle);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-muted);
    margin-left: var(--space-2);
}
.sprint-state-badge.sprint-state-active {
    background: var(--color-primary-soft);
    border-color: var(--color-primary);
    color: var(--color-primary);
}
.sprint-state-badge.sprint-state-completed {
    background: var(--color-success-soft, var(--color-bg-subtle));
    border-color: transparent;
    color: var(--color-success, var(--color-text-muted));
}
.sprint-goal,
.sprint-dates {
    margin: 0;
    font-size: 13px;
}

.sprint-progress {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-top: var(--space-1);
}
.sprint-progress-bar {
    flex: 1;
    height: 6px;
    background: var(--color-bg-subtle);
    border-radius: 999px;
    overflow: hidden;
}
.sprint-progress-fill {
    height: 100%;
    background: var(--color-primary);
    transition: width 0.2s ease;
}
.sprint-progress-label {
    font-size: 11px;
    color: var(--color-text-subtle);
    white-space: nowrap;
}

.sprint-stats-row {
    display: grid;
    grid-template-columns: repeat(4, auto) 1fr;
    gap: var(--space-4);
    align-items: center;
}
.sprint-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.sprint-stat strong {
    font-size: 24px;
    font-weight: 600;
    color: var(--color-text);
}
.sprint-stat span {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-subtle);
}
.sprint-stat-progress {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--space-2);
    align-items: center;
}

.modal {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    padding: var(--space-5);
    max-width: 480px;
    width: 90vw;
    background: var(--color-bg-elevated);
    color: var(--color-text);
}
.modal::backdrop {
    background: rgba(0, 0, 0, 0.4);
}
.modal h2 { margin-top: 0; }
.modal label {
    display: block;
    padding: 4px 0;
    font-size: 13px;
    cursor: pointer;
}

/* ---------------------------------------------------------------------------
 * Backlog
 * ------------------------------------------------------------------------ */
.backlog-toolbar {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-2) var(--space-3);
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-3);
    flex-wrap: wrap;
}
.backlog-list .backlog-row {
    grid-template-columns: 22px 100px 1fr auto;
}
.backlog-check {
    width: 16px;
    height: 16px;
}

/* ---------------------------------------------------------------------------
 * Versions
 * ------------------------------------------------------------------------ */
.version-row {
    flex-wrap: wrap;
}
.version-progress {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    min-width: 160px;
}
.version-bar {
    width: 80px;
    flex: 0 0 auto;
}

/* ---------------------------------------------------------------------------
 * Phase 5: Notifications
 * ------------------------------------------------------------------------ */
.notif-bell-wrap {
    position: relative;
    display: inline-block;
    margin-right: var(--space-2);
}
.notif-bell {
    position: relative;
    display: inline-grid;
    place-items: center;
    width: 36px;
    height: 36px;
    background: transparent;
    border: 0;
    border-radius: var(--radius-md);
    cursor: pointer;
    color: var(--color-text-muted);
}
.notif-bell:hover {
    background: var(--color-bg-subtle);
    color: var(--color-text);
}
.notif-bell-icon {
    font-size: 16px;
    line-height: 1;
}
.notif-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    background: var(--color-danger, #d94c4c);
    color: #fff;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 600;
    line-height: 16px;
    text-align: center;
}

.notif-dropdown {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    width: 360px;
    max-height: 480px;
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    z-index: 50;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.notif-dropdown-body {
    flex: 1;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
}
.notif-dropdown-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3);
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
    font-size: 13px;
}
.notif-dropdown-foot {
    padding: var(--space-2) var(--space-3);
    border-top: 1px solid var(--color-border);
    text-align: center;
    flex-shrink: 0;
}
.notif-see-all {
    font-size: 12px;
    color: var(--color-text-muted);
    text-decoration: none;
}
.notif-see-all:hover { color: var(--color-primary); }
.notif-empty {
    padding: var(--space-5) var(--space-3);
    margin: 0;
    text-align: center;
    font-size: 13px;
}

.notif-list {
    list-style: none;
    margin: 0;
    padding: 0;
    overflow-y: auto;
}
.notif-list li {
    border-bottom: 1px solid var(--color-border);
}
.notif-list li:last-child { border-bottom: 0; }

.notif-row {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    padding: var(--space-3);
    text-decoration: none;
    color: inherit;
    transition: background-color 0.1s;
}
.notif-row:hover {
    background: var(--color-bg-subtle);
}
.notif-row-dot {
    flex: 0 0 auto;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: transparent;
    margin-top: 6px;
}
.notif-row-unread .notif-row-dot {
    background: var(--color-primary);
}
.notif-row-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.notif-row-line {
    font-size: 13px;
    line-height: 1.4;
    color: var(--color-text);
}
.notif-row-line strong { font-weight: 600; }
.notif-row-line em { font-style: normal; color: var(--color-primary); }
.notif-row-summary {
    font-size: 12px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.notif-row-time {
    font-size: 11px;
}

.notif-inbox {
    padding: 0;
    overflow: hidden;
}
.notif-inbox .notif-list { max-height: none; }
.notif-pager {
    margin-top: var(--space-4);
    display: flex;
    justify-content: space-between;
    gap: var(--space-2);
}

/* ---------------------------------------------------------------------------
 * Phase 6: Issue links sidebar
 * ------------------------------------------------------------------------ */
.issue-links-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}
.link-group + .link-group { margin-top: var(--space-2); }
.link-group-head {
    margin: 0 0 var(--space-1);
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-subtle);
}
.link-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.link-row {
    display: grid;
    grid-template-columns: 8px auto 1fr auto;
    gap: var(--space-2);
    align-items: center;
    font-size: 13px;
    line-height: 1.3;
}
.link-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    display: inline-block;
}
.link-key {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--color-text-subtle);
    text-decoration: none;
    white-space: nowrap;
}
.link-summary {
    color: var(--color-text);
    text-decoration: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}
.link-summary:hover { text-decoration: underline; }
.link-add-form {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--space-2);
    margin-top: var(--space-3);
    padding-top: var(--space-3);
    border-top: 1px solid var(--color-border);
    align-items: center;
}
.link-add-form .filter-select {
    font-size: 12px;
    padding: 4px 8px;
}
.link-add-key {
    font: inherit;
    font-family: var(--font-mono);
    font-size: 12px;
    padding: 5px 8px;
    background: var(--color-bg);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-sm);
    color: var(--color-text);
    text-transform: uppercase;
    min-width: 0;
}
.link-add-key:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px var(--color-primary-soft);
}

/* ---------------------------------------------------------------------------
 * Phase 7: Burndown chart
 * ------------------------------------------------------------------------ */
.burndown-card {
    /* Allow the SVG to breathe */
}
.burndown-chart {
    width: 100%;
    height: auto;
    display: block;
    max-width: 720px;
    margin: 0 auto;
}
.burndown-grid line {
    stroke: var(--color-border);
    stroke-dasharray: 2 2;
    stroke-width: 1;
}
.burndown-axis-label {
    fill: var(--color-text-subtle);
    font-size: 11px;
    font-family: var(--font-sans);
}
.burndown-ideal {
    fill: none;
    stroke: var(--color-text-subtle);
    stroke-width: 1.5;
    stroke-dasharray: 4 4;
}
.burndown-actual {
    fill: none;
    stroke: var(--color-primary);
    stroke-width: 2;
    stroke-linejoin: round;
    stroke-linecap: round;
}
.burndown-legend-label {
    fill: var(--color-text-muted);
    font-size: 11px;
    font-family: var(--font-sans);
}

/* ---------------------------------------------------------------------------
 * Phase 8: Slack settings banner + test row
 * ------------------------------------------------------------------------ */
.warning-banner {
    background: #fef3c7;
    border: 1px solid #fcd34d;
    color: #78350f;
    padding: var(--space-3);
    border-radius: var(--radius-sm);
    margin: var(--space-3) 0;
    font-size: 13px;
    line-height: 1.5;
}
.warning-banner code {
    background: rgba(0,0,0,0.06);
    padding: 1px 4px;
    border-radius: 3px;
    font-family: var(--font-mono);
    font-size: 12px;
}
.slack-test-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    margin-top: var(--space-3);
}

/* ---------------------------------------------------------------------------
 * Phase 8: Issue link graph
 * ------------------------------------------------------------------------ */
.link-graph-wrap {
    margin: 0 -8px var(--space-3);
}
.link-graph-svg {
    width: 100%;
    height: auto;
    display: block;
    user-select: none;
}
.link-graph-edges line {
    transition: stroke-width 0.1s;
}
.link-graph-nodes a {
    cursor: pointer;
    transition: opacity 0.1s;
}
.link-graph-nodes a:hover circle {
    stroke: var(--color-primary);
    stroke-width: 3;
}
.link-graph-node {
    transition: stroke 0.1s, stroke-width 0.1s;
}
.link-graph-node-label {
    fill: #fff;
    font-size: 9px;
    font-family: var(--font-mono);
    font-weight: 600;
    pointer-events: none;
}
.link-graph-focus circle {
    /* keep static; no hover affordance on the focus */
}
.link-graph-focus-label {
    fill: #fff;
    font-size: 10px;
    font-family: var(--font-mono);
    font-weight: 700;
    pointer-events: none;
}
.link-graph-overflow {
    fill: var(--color-text-subtle);
    font-size: 11px;
    font-family: var(--font-sans);
}

/* ---------------------------------------------------------------------------
 * Phase 9: Backlog drag handle + sortable states
 * ------------------------------------------------------------------------ */
.backlog-drag-handle {
    cursor: grab;
    color: var(--color-text-subtle);
    font-size: 14px;
    line-height: 1;
    user-select: none;
    padding: 0 4px;
    letter-spacing: -2px;
    flex: 0 0 auto;
}
.backlog-drag-handle:active {
    cursor: grabbing;
}
.backlog-row-ghost {
    opacity: 0.4;
    background: var(--color-primary-soft);
}
.backlog-row-chosen {
    background: var(--color-bg-elevated);
}
.backlog-row-drag {
    box-shadow: 0 8px 16px rgba(0,0,0,0.18);
    background: var(--color-bg-elevated);
}

/* ---------------------------------------------------------------------------
 * Phase 10: Profile expansion — avatar, setup panels, code blocks
 * ------------------------------------------------------------------------ */
.avatar-row {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    margin-top: var(--space-3);
}
.avatar-preview {
    flex: 0 0 auto;
}
.avatar-preview-img {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--color-border);
    background: var(--color-bg-elevated);
    display: block;
}
.avatar-large {
    width: 96px;
    height: 96px;
    font-size: 28px;
}
.avatar-img {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    object-fit: cover;
    background: var(--color-primary-soft);
}
.avatar-controls {
    flex: 1;
    min-width: 0;
}

.setup-panel {
    margin: var(--space-3) 0;
    padding: var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg-elevated);
}
.setup-panel summary {
    cursor: pointer;
    font-weight: 500;
    color: var(--color-text);
    user-select: none;
    list-style: none;
    padding-left: 18px;
    position: relative;
}
.setup-panel summary::-webkit-details-marker { display: none; }
.setup-panel summary::before {
    content: '▸';
    position: absolute;
    left: 0;
    color: var(--color-text-subtle);
    transition: transform 0.15s;
}
.setup-panel[open] summary::before {
    transform: rotate(90deg);
}
.setup-panel ol,
.setup-panel ul {
    margin-top: var(--space-2);
    padding-left: 24px;
    line-height: 1.6;
    color: var(--color-text-muted);
}
.setup-panel li {
    margin-bottom: var(--space-1);
}
.setup-panel code {
    background: rgba(0,0,0,0.06);
    padding: 1px 4px;
    border-radius: 3px;
    font-family: var(--font-mono);
    font-size: 12px;
}
.setup-panel .code-block {
    display: block;
    background: rgba(0,0,0,0.06);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-sm);
    margin: var(--space-1) 0;
    font-family: var(--font-mono);
    font-size: 12px;
    white-space: pre-wrap;
    word-break: break-all;
}

.hint-inline {
    color: var(--color-text-subtle);
    font-size: 13px;
}
.form-inline-tail {
    margin-top: var(--space-2);
}

/* ---------------------------------------------------------------------------
 * Phase 11: Inline-edit hover affordance on issue page
 * ------------------------------------------------------------------------ */

/* Wrap the H1 summary so the editable hover area is just the title. */
.issue-summary-wrap {
    display: block;
    flex: 1;
}

/* All editable display blocks get a faint hover hint that says "click me". */
.editable-display {
    position: relative;
    cursor: pointer;
    border-radius: var(--radius-sm);
    padding: 4px 8px;
    margin: -4px -8px;
    transition: background 0.12s;
}
.editable-display:hover {
    background: var(--color-primary-soft);
}
.editable-pencil {
    position: absolute;
    top: 50%;
    right: 8px;
    transform: translateY(-50%);
    color: var(--color-text-subtle);
    font-size: 14px;
    opacity: 0;
    transition: opacity 0.12s;
    pointer-events: none;
}
.editable-display:hover .editable-pencil {
    opacity: 0.7;
}

.editable-h1 {
    margin: 0;
    display: inline-block;
}

.editable-edit {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    margin: 4px 0;
}
.editable-input {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    font: inherit;
}
.editable-input:focus {
    outline: 2px solid var(--color-primary);
    outline-offset: -1px;
    border-color: transparent;
}
.editable-input-h1 {
    font-size: 1.5rem;
    font-weight: 700;
}
.editable-textarea {
    min-height: 120px;
    resize: vertical;
    font-family: var(--font-mono);
    font-size: 13px;
    line-height: 1.5;
}
.editable-actions {
    display: flex;
    gap: var(--space-2);
}

/* Inline-edit selectors and date inputs (Status / Assignee / Priority /
 * Type / Due Date) — apply hover styling so the affordance is visible
 * even when no value is set. */
.inline-edit {
    display: inline-block;
    width: 100%;
}
.inline-select {
    width: 100%;
    padding: 4px 6px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg-elevated);
    font: inherit;
    color: var(--color-text);
    cursor: pointer;
    transition: background 0.12s, border-color 0.12s;
    /* Show the native dropdown arrow in both light and dark mode */
    appearance: auto;
}
.inline-select option {
    background: var(--color-bg-elevated);
    color: var(--color-text);
}
.inline-select:hover {
    background: var(--color-primary-soft);
    border-color: var(--color-primary);
}
.inline-select:focus {
    outline: none;
    background: var(--color-bg);
    border-color: var(--color-primary);
}
.inline-date-input {
    padding: 4px 6px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg-elevated);
    color: var(--color-text);
    font: inherit;
    cursor: pointer;
    transition: background 0.12s, border-color 0.12s;
}
.inline-date-input:hover {
    background: var(--color-primary-soft);
    border-color: var(--color-primary);
}
.inline-date-input:focus {
    outline: none;
    background: var(--color-bg);
    border-color: var(--color-primary);
}
/* Dark-mode: force the date input's calendar icon visible */
@media (prefers-color-scheme: dark) {
    .inline-date-input::-webkit-calendar-picker-indicator {
        filter: invert(0.85);
    }
}
.btn-link-small {
    background: none;
    border: none;
    color: var(--color-text-subtle);
    cursor: pointer;
    padding: 0 4px;
    font-size: 16px;
    line-height: 1;
}
.btn-link-small:hover {
    color: var(--color-text);
}

/* Alpine x-cloak — hide elements until Alpine initializes */
[x-cloak] { display: none !important; }


/* ---------------------------------------------------------------------------
 * Phase 11: Admin pages
 * ------------------------------------------------------------------------ */

.admin-page {
    /* The outer .main wrapper already constrains max-width; don't double-cap. */
    width: 100%;
}

.admin-layout {
    display: grid;
    grid-template-columns: 200px minmax(0, 1fr);
    gap: var(--space-6);
    align-items: start;
}

.admin-nav {
    position: sticky;
    top: 80px;
    padding: var(--space-3);
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
}
.admin-nav-title {
    margin: 0 0 var(--space-3) 0;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-subtle);
}
.admin-nav-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.admin-nav-link {
    display: block;
    padding: 6px 10px;
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
    text-decoration: none;
    transition: background 0.1s, color 0.1s;
}
.admin-nav-link:hover {
    background: var(--color-primary-soft);
    color: var(--color-text);
}
.admin-nav-active {
    background: var(--color-primary-soft);
    color: var(--color-text);
    font-weight: 500;
}

.admin-main {
    min-width: 0;  /* let tables overflow with scroll instead of stretching grid */
}
.admin-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-3);
    flex-wrap: wrap;
}
.admin-header-actions {
    display: flex;
    gap: var(--space-2);
    flex-shrink: 0;
}

/* Data tables */
.data-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    overflow: hidden;
}
.data-table th,
.data-table td {
    padding: 10px 14px;
    text-align: left;
    border-bottom: 1px solid var(--color-border);
    vertical-align: middle;
}
.data-table th {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-subtle);
    background: var(--color-bg-elevated);
    font-weight: 600;
}
.data-table tbody tr:last-child td {
    border-bottom: none;
}
.data-table tbody tr:hover {
    background: var(--color-bg-elevated);
}
.row-actions {
    width: 1%;
    white-space: nowrap;
}

/* Role pills — small colored labels */
.role-pill {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    color: white;
    text-shadow: 0 1px 0 rgba(0,0,0,0.18);
    margin-right: 4px;
    vertical-align: middle;
}

.role-checkboxes {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.role-checkbox {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
    padding: 6px 8px;
    border-radius: var(--radius-sm);
    transition: background 0.12s;
}
.role-checkbox:hover {
    background: var(--color-bg-elevated);
}
.role-checkbox input[type="checkbox"] {
    margin: 0;
}

/* Status badges */
.status-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
    margin-right: 4px;
}
.status-active {
    background: #dcfce7;
    color: #15803d;
}
.status-inactive {
    background: #f3f4f6;
    color: #6b7280;
}
.status-deleted {
    background: #fee2e2;
    color: #b91c1c;
}
.status-admin {
    background: #ddd6fe;
    color: #6d28d9;
}

.role-user-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.btn-danger {
    background: #dc2626;
    color: white;
    border: 1px solid #b91c1c;
}
.btn-danger:hover {
    background: #b91c1c;
}
.btn-sm {
    padding: 4px 10px;
    font-size: 13px;
}

.danger-zone {
    border-color: #fecaca;
}
.danger-zone h2 {
    color: #991b1b;
}

@media (max-width: 720px) {
    .admin-layout {
        grid-template-columns: 1fr;
    }
    .admin-nav {
        position: static;
    }
}

/* ---------------------------------------------------------------------------
 * Phase 12: Copy issue link button
 * ------------------------------------------------------------------------ */
.copy-link-btn {
    margin-left: var(--space-2);
    padding: 2px 8px;
    font-size: 12px;
    color: var(--color-text-muted);
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.copy-link-btn:hover {
    background: var(--color-bg-elevated);
    color: var(--color-text);
    border-color: var(--color-border);
}

/* ---------------------------------------------------------------------------
 * Phase 12: Recently viewed list
 * ------------------------------------------------------------------------ */
.recent-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.recent-item a {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: 8px 12px;
    border-radius: var(--radius-sm);
    color: var(--color-text);
    text-decoration: none;
    transition: background 0.12s;
}
.recent-item a:hover {
    background: var(--color-bg-elevated);
}
.recent-item .issue-key {
    flex: 0 0 auto;
    font-size: 12px;
    color: var(--color-text-muted);
}
.recent-item .recent-title {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ---------------------------------------------------------------------------
 * Phase 12: Modals (cheat sheet, quick search)
 * ------------------------------------------------------------------------ */
.modal {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    z-index: 1000;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 80px 16px 16px;
    overflow-y: auto;
}
.modal[hidden] { display: none; }
.modal-panel {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    width: 100%;
    max-width: 560px;
    max-height: calc(100vh - 96px);
    display: flex;
    flex-direction: column;
}
.modal-panel-narrow { max-width: 600px; }
.modal-head {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--color-border);
}
.modal-head h2 {
    margin: 0;
    flex: 1;
    font-size: 16px;
}
.modal-close {
    background: none;
    border: none;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    color: var(--color-text-subtle);
    padding: 0 4px;
}
.modal-close:hover {
    color: var(--color-text);
}
.modal-body {
    padding: var(--space-4);
    overflow-y: auto;
}
.modal-foot {
    padding: var(--space-2) var(--space-4);
    border-top: 1px solid var(--color-border);
}
.footer-link {
    background: none;
    border: none;
    color: var(--color-primary);
    padding: 0;
    margin-left: 4px;
    cursor: pointer;
    font: inherit;
}
.footer-link:hover { text-decoration: underline; }

/* Cheat sheet */
.cheatsheet-table {
    width: 100%;
    border-collapse: collapse;
}
.cheatsheet-table td {
    padding: 6px 8px;
    border-bottom: 1px solid var(--color-border-subtle, transparent);
    vertical-align: middle;
}
.cheatsheet-table td:first-child {
    width: 1%;
    white-space: nowrap;
}
kbd {
    display: inline-block;
    padding: 2px 6px;
    font: 12px var(--font-mono);
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-bottom-width: 2px;
    border-radius: var(--radius-sm);
    color: var(--color-text);
}

/* Quick search */
.quicksearch-input {
    flex: 1;
    border: none;
    outline: none;
    font-size: 16px;
    background: transparent;
    color: var(--color-text);
    padding: 4px 0;
}
.quicksearch-hint {
    padding: var(--space-3);
    margin: 0;
    text-align: center;
}
.quicksearch-results {
    min-height: 200px;
}
.quicksearch-group {
    margin-top: var(--space-3);
}
.quicksearch-group:first-child { margin-top: 0; }
.quicksearch-group-title {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-subtle);
    padding: 4px var(--space-2);
    margin: 0 0 4px 0;
}
.quicksearch-result {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: 8px var(--space-2);
    border-radius: var(--radius-sm);
    color: var(--color-text);
    text-decoration: none;
}
.quicksearch-result:hover {
    background: var(--color-bg-elevated);
}
.quicksearch-result .quicksearch-key {
    font-size: 12px;
    color: var(--color-text-muted);
    flex: 0 0 auto;
}
.quicksearch-result .quicksearch-title {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

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

/* Phase 12: Activity log from → to formatting */
.activity-changes {
    color: var(--color-text-muted);
}
.activity-from {
    color: var(--color-text-subtle);
    text-decoration: line-through;
    text-decoration-color: var(--color-text-subtle);
}
.activity-to {
    color: var(--color-text);
    font-weight: 500;
}

/* Phase 12: Filter bar */
.filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    align-items: center;
    padding: var(--space-3);
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-3);
}
.filter-bar .filter-search {
    flex: 1;
    min-width: 200px;
    padding: 6px 10px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    color: var(--color-text);
    font: inherit;
}
.filter-bar select {
    padding: 6px 10px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    color: var(--color-text);
    font: inherit;
}
.filter-multi {
    position: relative;
}
.filter-multi summary {
    list-style: none;
    cursor: pointer;
    padding: 6px 10px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg);
    color: var(--color-text);
}
.filter-multi summary::-webkit-details-marker { display: none; }
.filter-multi[open] summary {
    border-color: var(--color-primary);
}
.filter-multi-options {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 8px;
    box-shadow: var(--shadow-md);
    z-index: 20;
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 160px;
}
.filter-multi-options label {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    padding: 4px;
}
.filter-multi-options label:hover { background: var(--color-bg-elevated); }

.issues-table tbody tr {
    cursor: pointer;
}

/* Phase 12: drag-drop target highlight */
textarea.attach-drop-active {
    outline: 2px dashed var(--color-primary);
    outline-offset: -1px;
    background: var(--color-primary-soft);
}
