html,body,#root{min-height:100%;margin:0}body{min-height:100vh}a{color:inherit}:root{--bg:#f0f4f8;--surface:#fff;--surface2:#e8eef4;--border:#d0dbe6;--text-primary:#0a1929;--text-secondary:#546e7a;--text-muted:#90a4ae;--accent:#1976d2;--accent-soft:#e3f2fd;--accent2:#42a5f5;--accent2-soft:#e3f2fd;--green:#3daa74;--amber:#e8a23c;--red:#e85252;--purple:#5c6bc0;--sidebar-w:252px;--radius:12px;--shadow:0 8px 32px #00000014;--font-display:Inter, system-ui, sans-serif;--font-body:Inter, system-ui, sans-serif}*{box-sizing:border-box}body{font-family:var(--font-body);background:var(--bg);color:var(--text-primary)}body,#root{min-height:100vh}button,input,textarea,select{font:inherit}.app-shell{min-height:100vh;display:flex}.landing-shell{background:radial-gradient(circle at top,#e8f0fe 0%,#f0f4f8 52%);place-items:center;min-height:100vh;padding:24px;display:grid}.landing-card{background:var(--surface);border:1px solid var(--border);width:min(520px,100%);box-shadow:var(--shadow);border-radius:20px;padding:28px}.landing-logo{flex:0 0 44px;width:44px;height:40px;margin:0;font-size:14px}.landing-heading{justify-content:center;align-items:center;gap:10px;margin:0 0 10px;display:flex}.landing-copy{color:var(--text-secondary);text-align:center;margin-bottom:18px;line-height:1.6}.landing-form{gap:14px;display:grid}.landing-actions{gap:10px;display:grid}.landing-actions .secondary-btn{width:100%}.landing-form label{gap:8px;display:grid}.landing-form input,.landing-form select{border:1px solid var(--border);background:var(--surface2);border-radius:10px;padding:10px 12px}.landing-tabs{margin-bottom:16px}.landing-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.login-btn{text-align:center;width:100%;text-decoration:none}.login-error{color:var(--red);font-size:14px}.toast-notice{z-index:1000;box-shadow:var(--shadow);color:#fff;border-radius:12px;padding:12px 16px;position:fixed;bottom:24px;right:24px}.toast-notice.success{background:var(--green)}.toast-notice.error{background:var(--red)}.field-error{color:var(--red);font-size:12px}.demo-accounts{color:var(--text-secondary);gap:8px;margin-top:18px;font-size:14px;display:grid}.sidebar{width:var(--sidebar-w);border-right:1px solid var(--border);background:var(--surface);flex-direction:column;display:flex}.sidebar-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:18px 16px;display:flex}.logo{isolation:isolate;clip-path:polygon(50% 0,93% 25%,93% 75%,50% 100%,7% 75%,7% 25%);color:#4b88f3;letter-spacing:.02em;text-shadow:0 0 10px #4b88f359;filter:drop-shadow(0 0 6px #1f57cf73);background:linear-gradient(#071d49 0%,#031332 100%);border:2px solid #1f57cf;place-items:center;width:52px;height:46px;font-size:16px;font-weight:800;line-height:1;display:grid;position:relative;overflow:visible}.logo:before,.logo:after{content:"";clip-path:polygon(50% 0,93% 25%,93% 75%,50% 100%,7% 75%,7% 25%);pointer-events:none;position:absolute;inset:0}.logo:before{filter:blur(.2px);z-index:-2;border:1px solid #387eff8c;inset:-3px}.logo:after{z-index:-1;border:1px dashed #2770ea8c;inset:3px}.logo-text{font-family:var(--font-display);font-weight:700}.logo-subtext{color:var(--text-muted);font-size:12px}.nav-block{padding:4px 8px 10px}.nav-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.08em;align-items:center;gap:6px;padding:8px 8px 6px;font-size:12px;font-weight:700;display:flex}.nav-label-icon{flex-shrink:0;width:14px;height:14px}.nav-item,.project-item{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:0;border-radius:10px;justify-content:flex-start;align-items:center;gap:10px;padding:10px 12px;display:flex}.project-item>span:last-child{text-align:left;flex:1;min-width:0}.nav-item:hover,.project-item:hover,.project-item.active,.nav-item.active{background:var(--accent-soft);color:var(--accent)}.nav-badge{background:var(--accent);color:#fff;border-radius:999px;margin-left:auto;padding:2px 8px;font-size:11px}.project-dot{border-radius:999px;flex-shrink:0;width:10px;height:10px}.project-name{align-items:baseline;gap:6px;min-width:0;display:inline-flex}.project-item.child{padding-left:20px}.project-item.parent{font-weight:700}.project-item.child .project-dot,.project-item.parent .project-dot{display:none}.project-child-marker{color:var(--text-secondary);flex-shrink:0;font-weight:700}.sidebar-footer{border-top:1px solid var(--border);align-items:center;gap:12px;margin-top:auto;padding:16px;display:flex}.avatar,.mini-avatar{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;border-radius:999px;place-items:center;font-weight:700;display:grid;overflow:hidden}.avatar img,.mini-avatar img{object-fit:cover;border-radius:999px;width:100%;height:100%;display:block}.avatar-fallback{place-items:center;width:100%;height:100%;display:grid}.avatar{width:36px;height:36px}.small-avatar{width:30px;height:30px;font-size:12px}.footer-name{font-weight:600}.footer-role{color:var(--text-muted);font-size:12px}.main-panel{flex-direction:column;flex:1;min-width:0;height:100vh;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;gap:16px;min-height:64px;padding:12px 24px;display:flex}.topbar-title{font-family:var(--font-display);font-size:20px;font-weight:700}.topbar-subtitle{color:var(--text-muted);font-size:12px}.topbar-search{flex:1;justify-content:center;display:flex}.topbar-search-field{width:min(620px,100%);position:relative}.topbar-search-icon{width:18px;height:18px;color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.topbar-search input{border:1px solid var(--border);background:var(--surface2);box-sizing:border-box;border-radius:10px;width:100%;padding:10px 14px 10px 38px}.tab-group{background:#1976d233;border-radius:10px;gap:4px;padding:4px;display:inline-flex}.tab{background:var(--accent-soft);cursor:pointer;color:var(--accent);border:1px solid #1976d247;border-radius:8px;padding:8px 14px}.tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.content{flex-direction:column;flex:1;min-height:0;padding:24px;display:flex;overflow:hidden auto}.topbar-actions{align-items:center;gap:12px;display:flex}.primary-btn,.secondary-btn{border:1px solid var(--border);cursor:pointer;border-radius:10px;padding:10px 14px}.primary-btn{background:var(--accent);color:#fff;border-color:var(--accent)}.secondary-btn{background:var(--accent-soft);color:var(--accent);border-color:#1976d247}.stats-row{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin-bottom:10px;display:grid}.refreshing-banner{color:var(--accent2);background:#42a5f51f;border:1px solid #42a5f54d;border-radius:999px;align-items:center;gap:10px;margin-bottom:12px;padding:8px 12px;font-size:13px;font-weight:600;display:inline-flex}.refreshing-dot{background:var(--accent2);border-radius:999px;width:8px;height:8px;animation:1.1s ease-in-out infinite refreshing-pulse}@keyframes refreshing-pulse{0%,to{opacity:1}50%{opacity:.35}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:left;cursor:pointer;padding:8px 10px;transition:border-color .14s,box-shadow .14s,transform .14s}.stat-card:hover{border-color:var(--accent2);box-shadow:0 2px 8px #00000014}.stat-card:active{transform:translateY(1px)}.stat-card.active{box-shadow:0 0 0 2px var(--accent-soft)}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:700}.stat-value{margin-top:2px;font-size:18px;font-weight:700}.stat-value.blue{color:var(--accent2)}.stat-value.green{color:var(--green)}.stat-value.accent{color:var(--accent)}.stat-sub{color:var(--text-muted);margin-top:1px;font-size:10px}.filter-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:18px;display:flex}.filter-actions{align-items:center;gap:12px;margin-left:auto;display:flex}.filter-chip,.refresh-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:8px 12px}.filter-select{border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);border-radius:999px;min-width:140px;padding:8px 12px}.filter-chip.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.refresh-btn{cursor:pointer}.board-view{flex:1;gap:16px;min-height:0;padding-bottom:12px;display:flex;overflow:auto}.column{flex-direction:column;gap:10px;min-width:320px;max-width:320px;transition:transform .12s,box-shadow .12s;display:flex}.column.drag-over .column-header{border-color:var(--accent);box-shadow:0 0 0 2px #1976d22e}.column-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-sizing:border-box;align-items:center;gap:8px;min-height:44px;padding:10px 12px;display:flex;position:relative}.column-dot{border-radius:999px;width:10px;height:10px}.column-dot-btn{cursor:pointer;background:0 0;border:0;border-radius:6px;justify-content:center;align-items:center;padding:2px;display:inline-flex}.column-dot-btn:hover{background:var(--surface2)}.column-color-popover{z-index:20;background:var(--surface);border:1px solid var(--border);border-radius:10px;min-width:170px;padding:10px;position:absolute;top:calc(100% + 8px);left:10px;box-shadow:0 10px 24px #0f172a2e}.column-color-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:11px;font-weight:700}.column-color-grid{grid-template-columns:repeat(6,1fr);gap:6px;display:grid}.column-color-swatch{cursor:pointer;border:1px solid #0f172a38;border-radius:999px;width:20px;height:20px;padding:0}.column-color-swatch.active{box-shadow:0 0 0 2px #fff, 0 0 0 4px var(--accent)}.column-title{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-weight:700;overflow:hidden}.column-count{color:var(--text-muted);background:var(--surface2);border-radius:999px;margin-left:auto;padding:1px 7px;font-size:11px}.column-cards{flex-direction:column;flex:1;gap:8px;min-height:0;display:flex;overflow-y:auto}.card{text-align:left;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);cursor:pointer;padding:10px;position:relative}.card:hover{box-shadow:var(--shadow)}.card.dragging{opacity:.55;cursor:grabbing}.card-priority{border-radius:var(--radius) var(--radius) 0 0;height:4px;position:absolute;top:0;left:0;right:0}.card-tags{flex-wrap:wrap;gap:4px;margin-bottom:6px;display:flex}.tag{color:var(--purple);background:#e3f2fd;border-radius:999px;padding:3px 6px;font-size:10px;font-weight:600}.tag.muted{background:var(--surface2);color:var(--text-secondary)}.child-count-tag{border:1px solid var(--border);font-weight:700}.card-title{margin-bottom:8px;font-size:13px;font-weight:700;line-height:1.4}.card-meta{color:var(--text-secondary);justify-content:space-between;align-items:center;gap:10px;font-size:11px;display:flex}.card-due.overdue,.overdue{color:var(--red)}.mini-avatar{width:20px;height:20px;font-size:9px}.unassigned{color:var(--text-muted)}.progress-wrap{margin-top:8px}.progress-meta{color:var(--text-muted);justify-content:space-between;margin-bottom:4px;font-size:10px;display:flex}.progress-bar{background:var(--surface2);border-radius:999px;height:4px;overflow:hidden}.progress-fill{border-radius:999px;height:100%}.add-card-btn{border:1.5px dashed var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;background:0 0;padding:12px}.list-table{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:visible}.list-head,.list-row{grid-template-columns:1.8fr .9fr 1fr 1fr .6fr;align-items:center;gap:12px;padding:14px 16px;display:grid}.list-head{background:var(--surface2);color:var(--text-muted);text-transform:uppercase;font-size:12px;font-weight:700}.list-row{background:var(--surface);border:0;border-top:1px solid var(--border);text-align:left;cursor:pointer;width:100%}.list-row-child{background:#f5f8fc;padding-left:34px}.subtask-toggle-btn{border:1px solid var(--border);background:var(--surface2);color:var(--text-secondary);cursor:pointer;border-radius:6px;place-items:center;width:22px;height:22px;margin-right:8px;display:inline-grid}.list-row:hover{background:#f5f8fc}.list-title-wrap{gap:4px;display:grid}.list-title-line{align-items:center;display:inline-flex}.list-title{font-weight:600}.list-subtitle{color:var(--text-muted);font-size:12px}.status-pill{background:var(--accent2-soft,#e3f2fd);width:fit-content;color:var(--accent2);border-radius:999px;justify-content:center;padding:5px 10px;font-size:12px;font-weight:700;display:inline-flex}.status-select{border:1px solid var(--border);background:var(--surface2);box-sizing:border-box;border-radius:999px;max-width:100%;padding:6px 10px}.progress-editor{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;max-width:100%;display:grid;overflow:hidden}.progress-editor input[type=range]{width:100%;min-width:0}.task-detail-editor{flex-direction:column;gap:14px;display:flex}.task-detail-editor .composer-actions{justify-content:flex-end;margin-top:auto}.task-detail-editor input,.task-detail-editor textarea,.task-detail-editor select{border:1px solid var(--border);background:var(--surface2);border-radius:10px;width:100%;padding:10px 12px}.task-detail-editor input,.task-detail-editor textarea,.task-detail-editor select,.composer-form input,.composer-form textarea,.composer-form select{box-sizing:border-box}.rich-text-editor{border:1px solid var(--border);background:var(--surface);border-radius:12px;overflow:hidden}.rich-text-editor.drag-over{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.rich-text-toolbar{border-bottom:1px solid var(--border);background:#f5f8fc;align-items:center;gap:6px;padding:10px 12px;display:flex}.toolbar-btn{color:var(--text-primary);cursor:pointer;background:0 0;border:0;border-radius:8px;place-items:center;min-width:28px;height:28px;display:grid}.toolbar-btn:hover{background:var(--surface2)}.toolbar-btn.active{background:var(--accent-soft);color:var(--accent)}.toolbar-underline{text-decoration:underline}.toolbar-strike{text-decoration:line-through}.rich-text-content{min-height:140px}.rich-text-content .ProseMirror{white-space:pre-wrap;outline:none;min-height:140px;padding:12px}.rich-text-content .ProseMirror p{margin:0}.rich-text-content .ProseMirror p+p{margin-top:10px}.rich-text-content .ProseMirror ul,.rich-text-content .ProseMirror ol{margin:10px 0;padding-left:22px}.editor-helper{color:var(--text-secondary);padding:0 12px 12px;font-size:13px;font-style:italic}.rich-text-content .ProseMirror img{border-radius:4px;max-width:100%;height:auto;margin:.5em 0;display:block}.rich-text-content .ProseMirror img.ProseMirror-selectednode{outline:2px solid var(--accent,#2563eb);outline-offset:2px}.task-detail-attachments{gap:12px;display:grid}.task-detail-attachments label{gap:8px;display:grid}.progress-editor input[type=number]{border:1px solid var(--border);background:var(--surface2);box-sizing:border-box;border-radius:10px;width:70px;padding:8px 10px}.empty-state{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px}.empty-state h1{margin:0 0 12px;font-size:28px}.user-admin-layout{gap:16px;display:grid}.empty-state p{color:var(--text-secondary)}.error-state{border-color:#f5c2c2}.modal-overlay{background:#00000059;place-items:center;padding:12px;display:grid;position:fixed;inset:0}.modal{background:var(--surface);width:min(1120px,67vw);max-height:calc(100vh - 24px);box-shadow:var(--shadow);border-radius:16px;flex-direction:column;display:flex;overflow:hidden}.modal:not(.modal-compact){font-size:14px}.modal-compact{width:min(760px,100%)}.modal-compact .composer-form{overscroll-behavior:contain;min-height:0;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;padding:20px 24px;display:flex}.modal-header-main{flex:1;min-width:0}.modal-op-id{color:var(--text);white-space:nowrap;flex-shrink:0;justify-content:center;align-items:center;padding:0 14px;font-size:24px;font-weight:700;line-height:1;text-decoration:none;display:flex}.modal-op-id:hover{color:var(--primary);text-decoration:underline}.modal-op-divider{background:var(--border);flex-shrink:0;align-self:stretch;width:1px;margin:2px 0}.modal-header-actions{align-items:center;gap:10px;margin-left:auto;display:flex}.modal-priority{border-radius:999px;align-self:stretch;width:6px}.modal-header h2{margin:0 0 6px}.modal-header p{color:var(--text-muted)}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:0;margin-left:auto;font-size:28px}.modal-body{overscroll-behavior:contain;grid-template-columns:1fr;gap:24px;min-height:0;padding:20px;display:grid;overflow-y:auto}.task-modal-layout{grid-template-columns:1fr;grid-auto-flow:row;align-items:stretch;gap:24px;min-height:0}.task-modal-layout>*{min-width:0;min-height:0}.task-modal-top{grid-template-columns:1fr;gap:24px;min-height:0;padding-right:0;display:grid;overflow:visible}.task-modal-top input,.task-modal-top textarea,.task-modal-top select{box-sizing:border-box;max-width:100%}.task-modal-top .composer-grid,.task-modal-top .meta-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.modal:not(.modal-compact) .modal-header{gap:10px;padding:14px 16px}.modal:not(.modal-compact) .modal-header h2{margin:0 0 4px}.modal:not(.modal-compact) .modal-body{gap:16px;padding:14px}.modal:not(.modal-compact) .task-modal-layout,.modal:not(.modal-compact) .task-modal-top,.modal:not(.modal-compact) .modal-main-stack{gap:16px}.modal:not(.modal-compact) .task-detail-editor{gap:10px}.modal:not(.modal-compact) .task-detail-editor input,.modal:not(.modal-compact) .task-detail-editor textarea,.modal:not(.modal-compact) .task-detail-editor select,.modal:not(.modal-compact) .comment-composer textarea,.modal:not(.modal-compact) .subtask-item,.modal:not(.modal-compact) .subtask-linked-item,.modal:not(.modal-compact) .attachment-item{border-radius:8px;padding:7px 9px}.modal:not(.modal-compact) .rich-text-toolbar{padding:7px 9px}.modal:not(.modal-compact) .rich-text-content,.modal:not(.modal-compact) .rich-text-content .ProseMirror{min-height:100px}.modal:not(.modal-compact) .meta-grid{gap:14px 10px}.modal:not(.modal-compact) .section-label{margin-bottom:5px;font-size:10px}.modal:not(.modal-compact) .comments-section{gap:8px;min-height:600px;padding:14px 0 0}.modal:not(.modal-compact) .comment-composer{gap:7px;padding-bottom:8px}.section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:11px;font-weight:700}.description{color:var(--text-secondary);line-height:1.7}.meta-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px 16px;display:grid}.meta-grid>div{overflow-wrap:anywhere;min-width:0;overflow:hidden}.meta-grid select,.meta-grid input,.meta-grid textarea{box-sizing:border-box;max-width:100%}.meta-grid-actions{grid-column:1/-1;justify-content:flex-end;align-items:flex-end;padding-top:8px;display:flex}.meta-grid-actions .primary-btn{min-width:96px}.modal-main-stack{gap:20px;display:grid;overflow:visible}.modal-side-stack{gap:20px;min-height:0;display:grid}.subtask-list,.attachment-list,.comment-list,.activity-list{gap:10px;display:grid}.comment-list{grid-auto-rows:max-content;align-content:start}.activity-day-group{gap:10px;display:grid}.activity-day-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.activity-day-label{color:var(--text-primary);font-size:14px;font-weight:700}.subtask-item,.subtask-linked-item,.attachment-item{border:1px solid var(--border);background:var(--surface2);color:var(--text-primary);border-radius:10px;align-items:center;gap:10px;padding:10px 12px;text-decoration:none;display:flex}.subtask-linked-item{flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:12px}.subtask-linked-item span:first-child{overflow-wrap:anywhere;flex:auto;min-width:0}.subtask-linked-item .attachment-meta{flex-shrink:0}.attachment-item{justify-content:space-between;align-items:flex-start}.attachment-image-button{border:1px solid var(--border);background:var(--surface2);cursor:pointer;border-radius:10px;padding:0;display:block;overflow:hidden}.attachment-image{object-fit:cover;width:min(220px,100%);max-height:180px;display:block}.pending-image-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;display:grid}.pending-image-grid .attachment-image{width:100%;height:96px;max-height:none}.attachment-item span:first-child{overflow-wrap:anywhere;min-width:0}.deployment-attachments{gap:8px;margin-top:14px;display:grid}.deployment-attachments .attachment-list{grid-template-columns:repeat(3,minmax(0,1fr))}.deployment-attachments .attachment-item{flex-direction:column;align-items:flex-start;gap:4px;padding:8px 10px}.comments-section{border-top:1px solid var(--border);background:0 0;border-left:0;flex-direction:column;align-self:stretch;gap:12px;width:100%;min-height:200px;padding:20px 0 0;display:flex;position:static;overflow:hidden auto}.comments-section-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.comments-section-header .section-label{margin-bottom:0}.activity-sort-toggle{border:1px solid var(--border);background:var(--surface2);color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:600;line-height:1;transition:border-color .2s,color .2s,background .2s}.activity-sort-toggle:hover{border-color:var(--primary);color:var(--primary);background:var(--surface)}.comment-item,.activity-item{border:1px solid var(--border);background:var(--surface2);border-radius:12px;align-self:start;gap:10px;padding:12px;display:grid}.comment-header,.comment-author{align-items:center;gap:10px;display:flex}.activity-header{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.activity-author-line{gap:4px;display:grid}.activity-sequence{color:var(--text-muted);white-space:nowrap;font-weight:600}.activity-details{color:var(--text-secondary);gap:6px;margin:0;padding-left:18px;line-height:1.5;display:grid}.activity-comment-body{color:var(--text-secondary);line-height:1.6}.activity-comment-body img{border:1px solid var(--border);object-fit:cover;cursor:pointer;border-radius:10px;max-width:100%;max-height:260px}.activity-comment-body a:has(img){cursor:pointer}.activity-comment-body p{margin:0}.comment-header{justify-content:space-between}.comment-body{color:var(--text-secondary);white-space:pre-wrap;line-height:1.6}.comment-composer{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;gap:10px;padding-bottom:12px;display:grid}.scrollable-comments{flex:auto;min-height:0;padding-right:4px;overflow-y:auto}.comment-attachments{gap:10px;display:grid}.comment-image-link{cursor:pointer;background:0 0;border:0;padding:0;display:block}.comment-image{border:1px solid var(--border);object-fit:cover;border-radius:12px;max-width:100%;max-height:220px;display:block}.comment-upload{gap:8px;display:grid}.lightbox-overlay{z-index:3200;background:#000000d1;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.lightbox-image{object-fit:contain;border-radius:10px;max-width:min(1200px,92vw);max-height:90vh;box-shadow:0 14px 48px #00000059}.lightbox-close{color:#0f172a;cursor:pointer;background:#fffffff2;border:1px solid #00000040;border-radius:999px;justify-content:center;align-items:center;width:48px;height:48px;font-size:34px;line-height:1;display:inline-flex;position:absolute;top:18px;right:18px;box-shadow:0 6px 20px #00000047}.lightbox-close:hover{background:#fff}.attachment-viewer-modal{flex-direction:column;width:min(980px,92vw);max-height:calc(100vh - 36px);display:flex}.attachment-viewer-content{flex-direction:column;gap:10px;padding:14px 18px 18px;display:flex;overflow:auto}.attachment-download-prompt{text-align:center;align-content:center;justify-items:center;gap:12px;min-height:420px;display:grid}.attachment-download-actions{justify-content:center;align-items:center;gap:10px;display:flex}.attachment-download-prompt input[type=file]{max-width:100%}.attachment-text-preview{white-space:pre-wrap;word-break:break-word;border:1px solid var(--border);background:var(--surface2);border-radius:10px;min-height:320px;max-height:calc(100vh - 220px);margin:0;padding:10px 12px;font:12px/1.45 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;overflow:auto}.attachment-markdown-preview{border:1px solid var(--border);background:var(--surface2);border-radius:10px;min-height:320px;max-height:calc(100vh - 220px);padding:12px 14px;font-size:13px;line-height:1.45;overflow:auto}.attachment-markdown-preview h1,.attachment-markdown-preview h2,.attachment-markdown-preview h3,.attachment-markdown-preview h4,.attachment-markdown-preview h5,.attachment-markdown-preview h6{margin:.6em 0 .3em;line-height:1.3}.attachment-markdown-preview h1{font-size:1.4em}.attachment-markdown-preview h2{font-size:1.2em}.attachment-markdown-preview h3{font-size:1.05em}.attachment-markdown-preview p,.attachment-markdown-preview ul,.attachment-markdown-preview ol,.attachment-markdown-preview blockquote,.attachment-markdown-preview pre,.attachment-markdown-preview table{margin:0 0 .5em}.attachment-markdown-preview table{border-collapse:collapse;width:100%}.attachment-markdown-preview th,.attachment-markdown-preview td{border:1px solid var(--border);vertical-align:top;padding:4px 6px;font-size:12px}.attachment-markdown-preview code{background:#0f172a14;border-radius:4px;padding:1px 4px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px}.attachment-markdown-preview pre code{padding:8px 10px;display:block;overflow:auto}.attachment-markdown-preview a{color:#2563eb}.user-selection-list{gap:8px;display:grid}.user-selection-item{border:1px solid var(--border);background:var(--surface2);border-radius:10px;align-items:center;gap:10px;padding:10px 12px;display:flex}.user-selection-item input{width:16px;height:16px;margin:0}.comment-composer textarea{border:1px solid var(--border);background:var(--surface2);border-radius:10px;width:100%;padding:10px 12px}.attachment-meta{color:var(--text-muted);white-space:nowrap;font-size:12px}.subtask-item{text-align:left;cursor:pointer;width:100%}.subtask-item.done{color:var(--text-muted);text-decoration:line-through}.subtask-item:disabled{cursor:default;opacity:.8}.subtask-check{border:1px solid var(--border);border-radius:999px;flex:0 0 18px;place-items:center;width:18px;height:18px;font-size:11px;display:inline-grid}code{background:var(--surface2);border-radius:6px;padding:2px 6px}.composer-form{gap:16px;padding:24px;display:grid}.composer-form.no-pad{padding:0}.composer-form label{gap:8px;display:grid}.composer-form input,.composer-form textarea,.composer-form select{border:1px solid var(--border);background:var(--surface2);border-radius:10px;width:100%;padding:10px 12px}.composer-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.composer-grid-wide{grid-template-columns:repeat(3,minmax(0,1fr))}.composer-actions{justify-content:flex-end;gap:12px;display:flex}.modal-compact .composer-actions{background:var(--surface);border-top:1px solid var(--border);padding-top:10px;position:sticky;bottom:0}.add-card-btn:disabled,.primary-btn:disabled,.secondary-btn:disabled{cursor:not-allowed;opacity:.55}@media (width<=1100px){.composer-grid-wide{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=980px){.sidebar{display:none}.stats-row{grid-template-columns:repeat(2,minmax(0,1fr))}.modal-body,.meta-grid,.composer-grid,.composer-grid-wide{grid-template-columns:1fr}.list-head,.list-row{grid-template-columns:1.8fr 1fr}.list-head span:nth-child(n+3),.list-row span:nth-child(n+3){display:none}}
