:root{--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-light: #dbeafe;--color-primary-bg: #eff6ff;--color-text-primary: #1a1a2e;--color-text-secondary: #374151;--color-text-tertiary: #6b7280;--color-text-muted: #9ca3af;--color-text-disabled: #bfbfbf;--color-border: #e5e7eb;--color-border-light: #f0f0f0;--color-divider: #f3f4f6;--color-bg-page: #f5f5f5;--color-bg-elevated: #ffffff;--color-bg-sunken: #f9fafb;--color-bg-hover: #f3f4f6;--color-danger: #ef4444;--color-danger-bg: #fef2f2;--color-danger-text: #dc2626;--color-success: #22c55e;--color-success-bg: #dcfce7;--color-success-text: #16a34a;--color-warning: #f59e0b;--color-warning-bg: #fef3c7;--color-warning-text: #d97706;--color-info: #3b82f6;--color-info-bg: #eff6ff;--color-info-text: #1d4ed8;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--shadow-1: 0 1px 2px rgba(0, 0, 0, .05);--shadow-2: 0 2px 8px rgba(0, 0, 0, .08);--shadow-3: 0 4px 16px rgba(0, 0, 0, .12);--shadow-hover: 0 2px 4px rgba(0, 0, 0, .1);--shadow-drag: 0 4px 12px rgba(0, 0, 0, .15);--shadow-fab: 0 4px 12px rgba(0, 0, 0, .2);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", "Monaco", "Inconsolata", "Fira Code", monospace;--text-xs: 10px;--text-sm: 12px;--text-base: 14px;--text-md: 15px;--text-lg: 16px;--text-xl: 18px;--text-2xl: 20px;--text-3xl: 24px;--weight-normal: 400;--weight-medium: 500;--weight-semi: 600;--weight-bold: 700;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.6;--transition-fast: .15s ease;--transition-normal: .2s ease;--color-q1-bg: #fef2f2;--color-q1-border: #fecaca;--color-q2-bg: #eff6ff;--color-q2-border: #bfdbfe;--color-q3-bg: #fffbeb;--color-q3-border: #fde68a;--color-q4-bg: #f9fafb;--color-q4-border: #e5e7eb;--sidebar-width: 240px;--sidebar-collapsed-width: 80px;--bottom-tabs-height: 56px;--header-height-mobile: 48px}[data-theme=dark]{--color-primary: #3b82f6;--color-primary-hover: #60a5fa;--color-primary-light: #1e3a5f;--color-primary-bg: #172554;--color-text-primary: #f1f5f9;--color-text-secondary: #cbd5e1;--color-text-tertiary: #94a3b8;--color-text-muted: #64748b;--color-text-disabled: #475569;--color-border: #334155;--color-border-light: #1e293b;--color-divider: #1e293b;--color-bg-page: #0f172a;--color-bg-elevated: #1e293b;--color-bg-sunken: #0f172a;--color-bg-hover: #334155;--color-danger: #f87171;--color-danger-bg: #451a1a;--color-danger-text: #fca5a5;--color-success: #4ade80;--color-success-bg: #14532d;--color-success-text: #86efac;--color-warning: #fbbf24;--color-warning-bg: #451a03;--color-warning-text: #fcd34d;--color-info: #60a5fa;--color-info-bg: #172554;--color-info-text: #93c5fd;--shadow-1: 0 1px 2px rgba(0, 0, 0, .3);--shadow-2: 0 2px 8px rgba(0, 0, 0, .4);--shadow-3: 0 4px 16px rgba(0, 0, 0, .5);--shadow-hover: 0 2px 4px rgba(0, 0, 0, .3);--shadow-drag: 0 4px 12px rgba(0, 0, 0, .5);--shadow-fab: 0 4px 12px rgba(0, 0, 0, .6);--color-q1-bg: #2d1b1b;--color-q1-border: #5c2d2d;--color-q2-bg: #1a2744;--color-q2-border: #2d4a7a;--color-q3-bg: #2d2510;--color-q3-border: #5c4a1a;--color-q4-bg: #1e293b;--color-q4-border: #334155}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--color-primary: #3b82f6;--color-primary-hover: #60a5fa;--color-primary-light: #1e3a5f;--color-primary-bg: #172554;--color-text-primary: #f1f5f9;--color-text-secondary: #cbd5e1;--color-text-tertiary: #94a3b8;--color-text-muted: #64748b;--color-text-disabled: #475569;--color-border: #334155;--color-border-light: #1e293b;--color-divider: #1e293b;--color-bg-page: #0f172a;--color-bg-elevated: #1e293b;--color-bg-sunken: #0f172a;--color-bg-hover: #334155;--color-danger: #f87171;--color-danger-bg: #451a1a;--color-danger-text: #fca5a5;--color-success: #4ade80;--color-success-bg: #14532d;--color-success-text: #86efac;--color-warning: #fbbf24;--color-warning-bg: #451a03;--color-warning-text: #fcd34d;--color-info: #60a5fa;--color-info-bg: #172554;--color-info-text: #93c5fd;--shadow-1: 0 1px 2px rgba(0, 0, 0, .3);--shadow-2: 0 2px 8px rgba(0, 0, 0, .4);--shadow-3: 0 4px 16px rgba(0, 0, 0, .5);--shadow-hover: 0 2px 4px rgba(0, 0, 0, .3);--shadow-drag: 0 4px 12px rgba(0, 0, 0, .5);--shadow-fab: 0 4px 12px rgba(0, 0, 0, .6);--color-q1-bg: #2d1b1b;--color-q1-border: #5c2d2d;--color-q2-bg: #1a2744;--color-q2-border: #2d4a7a;--color-q3-bg: #2d2510;--color-q3-border: #5c4a1a;--color-q4-bg: #1e293b;--color-q4-border: #334155}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}::-webkit-scrollbar{width:var(--space-2);height:var(--space-2)}::-webkit-scrollbar-track{background:var(--color-bg-hover);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.page-title{font-size:var(--text-3xl);font-weight:var(--weight-bold);color:var(--color-text-primary);line-height:var(--leading-tight)}.section-title{font-size:var(--text-xl);font-weight:var(--weight-semi);color:var(--color-text-primary)}.card-title{font-size:var(--text-md);font-weight:var(--weight-medium);color:var(--color-text-primary)}.text-meta{font-size:var(--text-sm);color:var(--color-text-tertiary)}.text-muted{color:var(--color-text-muted)}.text-mono{font-family:var(--font-mono)}.app-sidebar{background:var(--color-bg-elevated)!important;border-right:1px solid var(--color-border);height:100vh;position:fixed!important;left:0;top:0;z-index:100;display:flex;flex-direction:column;overflow:hidden}.sidebar-logo{height:56px;display:flex;align-items:center;justify-content:center;padding:0 var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0}.sidebar-logo-text{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--color-text-primary);white-space:nowrap}.sidebar-logo-icon{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--color-primary);width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-bg);border-radius:var(--radius-md)}.sidebar-action{padding:var(--space-3) var(--space-3);flex-shrink:0}.sidebar-menu{border:none!important;flex:1;overflow-y:auto;overflow-x:hidden}.sidebar-menu-secondary{flex:0;border-top:1px solid var(--color-border)!important;padding-top:var(--space-2)}.sidebar-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border);flex-shrink:0}.sidebar-footer-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.sidebar-user-name{font-weight:var(--weight-medium);font-size:var(--text-base);color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.app-content{padding:var(--space-6);min-height:100vh;background:var(--color-bg-page);margin-left:var(--sidebar-width);transition:margin-left var(--transition-normal)}.ant-layout-sider-collapsed~.ant-layout .app-content,.ant-layout-sider-collapsed+.ant-layout .app-content{margin-left:var(--sidebar-collapsed-width)}.mobile-header{height:var(--header-height-mobile);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4);position:sticky;top:0;z-index:100}.mobile-header-logo{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--color-text-primary)}.mobile-content{margin-left:0!important;padding:var(--space-4)!important;min-height:calc(100vh - var(--header-height-mobile) - var(--bottom-tabs-height))!important;padding-bottom:calc(var(--space-4) + var(--bottom-tabs-height))!important}.bottom-tabs{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-tabs-height);background:var(--color-bg-elevated);border-top:1px solid var(--color-border);display:flex;align-items:stretch;z-index:1000;padding-bottom:env(safe-area-inset-bottom)}.bottom-tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:none;background:none;color:var(--color-text-muted);font-size:var(--text-xs);cursor:pointer;padding:var(--space-1) 0;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent}.bottom-tab-item .anticon{font-size:var(--text-xl)}.bottom-tab-item.active{color:var(--color-primary)}.bottom-tab-item:active{background:var(--color-bg-hover)}.fab-above-tabs{display:flex!important;align-items:center;justify-content:center;position:fixed;bottom:calc(var(--bottom-tabs-height) + var(--space-4) + env(safe-area-inset-bottom));right:var(--space-4);width:52px!important;height:52px!important;z-index:1001;box-shadow:var(--shadow-fab)}.inbox-fab{position:fixed;bottom:var(--space-6);right:var(--space-6);width:56px;height:56px;border-radius:28px;background:var(--color-primary);color:var(--color-bg-elevated);box-shadow:var(--shadow-drag);cursor:pointer;z-index:100;border:none;display:flex;align-items:center;justify-content:center;font-size:var(--text-3xl);transition:all var(--transition-normal)}.inbox-fab:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-fab);transform:scale(1.05)}.inbox-fab .inbox-fab-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;background:var(--color-danger);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--weight-semi);display:flex;align-items:center;justify-content:center;padding:0 6px;color:var(--color-bg-elevated)}.quadrant{border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:var(--space-4);min-height:120px;overflow-y:auto;min-width:0;transition:all var(--transition-fast)}.task-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px var(--space-3);margin-bottom:var(--space-2);box-shadow:var(--shadow-1);transition:box-shadow var(--transition-fast),background-color var(--transition-fast);overflow:hidden;min-width:0}.task-card:hover{box-shadow:var(--shadow-hover);background-color:var(--color-bg-hover)}.task-card.is-dragging{opacity:.5;box-shadow:var(--shadow-drag)}.task-card.is-completed{opacity:.6}.task-card.is-in-progress{border-left:3px solid var(--color-info);background-color:var(--color-primary-light)}.drag-handle{cursor:grab;color:var(--color-text-muted);padding:var(--space-1);display:flex;align-items:center;touch-action:none}.drag-handle:hover{color:var(--color-text-tertiary)}.drag-handle:active{cursor:grabbing}.label-filter-panel{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4)}.inbox-item{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-2);box-shadow:var(--shadow-1);transition:all var(--transition-fast)}.inbox-item:hover{box-shadow:var(--shadow-hover)}.quick-triage-btn{border:1px solid var(--qt-color, var(--color-border));background:transparent;color:var(--qt-color, var(--color-text-secondary));border-radius:var(--radius-sm);padding:2px 8px;font-size:11px;font-weight:var(--weight-medium);cursor:pointer;transition:all var(--transition-fast);line-height:18px}.quick-triage-btn:hover{background:var(--qt-color, var(--color-primary));color:var(--color-bg-elevated)}.inbox-item.is-dragging{opacity:.5;box-shadow:var(--shadow-drag);border-color:var(--color-primary)}.matrix-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:65fr 35fr;gap:var(--space-4);width:100%;height:calc(100vh - 120px)}.quadrant-picker-btn{padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:left;cursor:pointer;transition:all var(--transition-fast);background:var(--color-bg-elevated)}.quadrant-picker-btn:hover{background:var(--color-bg-sunken)}.quadrant-picker-btn.selected{border-color:var(--color-primary);border-width:2px;background:var(--color-primary-bg)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg-page);padding:var(--space-4)}.auth-card{width:100%;max-width:400px}.settings-section{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-4)}.api-key-input{font-family:var(--font-mono)}.initials-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 6px;border-radius:var(--radius-full);background-color:var(--color-border);color:var(--color-text-secondary);font-size:var(--text-xs);font-weight:var(--weight-semi);flex-shrink:0}.initials-badge.shared{background-color:var(--color-primary-light);color:var(--color-info-text)}.task-attributes{display:flex;align-items:center;gap:var(--space-2);flex-wrap:nowrap;overflow:hidden}.board-selector{min-width:120px}.task-number{font-size:11px;color:var(--color-text-muted);font-family:var(--font-mono);flex-shrink:0}.task-date-badge{font-size:11px;padding:0 var(--space-1);margin:0;line-height:18px}.task-date-badge.scheduled{background:var(--color-info-bg);border-color:#adc6ff;color:var(--color-info-text)}.task-date-badge.created{background:transparent;border:none;color:var(--color-text-muted);font-size:var(--text-xs)}.quick-add-form{display:flex;flex-direction:column;gap:var(--space-2);width:260px}.kanban-wrapper{max-width:1400px;margin:0 auto}.kanban-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);flex-wrap:wrap;gap:var(--space-2)}.kanban-toolbar-title{display:flex;flex-direction:column;gap:2px}.kanban-toolbar-actions{display:flex;gap:var(--space-2)}.kanban-board{display:flex;gap:var(--space-3);overflow-x:auto;padding-bottom:var(--space-4);min-height:400px}.kanban-column{flex:1 1 0;min-width:260px;max-width:400px;background:var(--color-bg-page);border-radius:var(--radius-lg);padding:var(--space-3);display:flex;flex-direction:column;transition:background var(--transition-normal)}.kanban-column.is-over{background:var(--color-primary-bg)}.kanban-column.is-collapsed{flex:0 0 auto;min-width:auto;max-width:none;width:auto}.kanban-column-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border)}.kanban-column-color{width:10px;height:10px;border-radius:50%;flex-shrink:0}.kanban-column-name{font-weight:var(--weight-semi);font-size:var(--text-base);flex:1}.kanban-column-tasks{flex:1;display:flex;flex-direction:column;gap:var(--space-2);min-height:60px}.kanban-column-empty{color:var(--color-text-disabled);text-align:center;padding:var(--space-6) var(--space-2);font-size:var(--text-base)}.kanban-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px var(--space-3);cursor:grab;transition:box-shadow var(--transition-fast);-webkit-user-select:none;user-select:none}.kanban-card:hover{box-shadow:var(--shadow-2)}.kanban-card.is-dragging{box-shadow:var(--shadow-3);opacity:.9}.kanban-card-title{font-size:var(--text-base);font-weight:var(--weight-medium);line-height:var(--leading-normal);margin-bottom:6px;word-break:break-word}.kanban-card-meta{display:flex;align-items:center;gap:var(--space-1);flex-wrap:wrap}.kanban-card-date{font-size:11px;color:var(--color-text-muted)}.kanban-card-date.overdue{color:var(--color-danger);font-weight:var(--weight-medium)}.kanban-card-date.due-today{color:var(--color-danger);font-weight:var(--weight-semi)}.kanban-card-date.due-soon{color:var(--color-warning-text);font-weight:var(--weight-medium)}.kanban-card-date.due-week{color:var(--color-success-text)}.kanban-card-number{font-size:11px;color:var(--color-text-disabled);margin-left:auto}.kanban-settings-list{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.kanban-settings-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--color-bg-sunken);border:1px solid var(--color-border-light);border-radius:var(--radius-md)}.kanban-settings-drag{cursor:grab;color:var(--color-text-disabled);padding:0 var(--space-1)}.kanban-settings-add{padding:var(--space-3);background:var(--color-bg-sunken);border-radius:var(--radius-md);border:1px dashed var(--color-border)}.amount-negative{color:var(--color-danger-text)}.budget-row-stripe td{background-color:var(--color-bg-sunken)!important}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}button:focus-visible,a:focus-visible,.ant-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}[role=button],.task-card,.kanban-card,.inbox-item,.quadrant-picker-btn,.bottom-tab-item,.quick-triage-btn{cursor:pointer}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.task-card,.kanban-card,.inbox-item{animation:fadeSlideIn .2s ease}.quadrant,.kanban-column{transition:all var(--transition-normal)}.bottom-tab-item:active,.quick-triage-btn:active,.quadrant-picker-btn:active{transform:scale(.96)}@media (max-width: 639px){.matrix-grid{grid-template-columns:1fr;grid-template-rows:auto;height:auto}.quadrant{max-width:100%;overflow-x:hidden;max-height:none}.task-card{max-width:100%;overflow:hidden;padding:var(--space-3)}.drag-handle{padding:10px;margin:-6px}.inbox-item{padding:var(--space-4) var(--space-3)}.task-attributes{display:none}.matrix-organization-bar{flex-direction:column}.matrix-organization-bar .ant-select{width:100%!important;min-width:0!important}.board-selector{min-width:0;width:100%}#root{overflow-x:hidden}.ant-select{max-width:100%}input[type=text],input[type=search],input[type=password],input[type=email],input[type=number],textarea,select,.ant-input,.ant-select-selection-search-input{font-size:16px!important}.kanban-board{flex-direction:row;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.kanban-column{min-width:85vw;scroll-snap-align:start}.inbox-fab{bottom:calc(var(--bottom-tabs-height) + var(--space-4) + env(safe-area-inset-bottom))}}@media (min-width: 640px) and (max-width: 1023px){.app-content{margin-left:var(--sidebar-collapsed-width)}.matrix-grid{height:calc(100vh - 120px)}}
