.profile-page{max-width:100%}.profile-head{display:flex;align-items:center;gap:20px;margin-bottom:18px}.profile-head-avatar{position:relative;width:84px;height:84px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--accent-subtle);color:var(--accent);font-size:28px;font-weight:700;cursor:pointer;overflow:hidden;border:1px solid var(--border-default);border-radius:var(--radius-xl)}.profile-head-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.profile-head-avatar .profile-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:var(--transition)}.profile-head-avatar:hover .profile-avatar-overlay{opacity:1}.profile-head-info{flex:1;min-width:0}.profile-head-name{font-size:20px;font-weight:700;color:var(--text-primary)}.profile-head-sub{font-size:13px;color:var(--text-secondary);margin-top:2px}.profile-head-actions{display:flex;gap:8px;margin-top:10px}.profile-readonly{display:grid;grid-template-columns:1fr 1fr;gap:14px 24px}.profile-ro-item{display:flex;flex-direction:column;gap:3px}.profile-ro-label{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary)}.profile-ro-value{font-size:13px;color:var(--text-primary);font-weight:500}.profile-email-item{grid-column:1 / -1}.profile-email-value{display:flex;align-items:center;gap:10px}.profile-email-edit{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:7px;background:var(--blue-bg, rgba(33, 112, 228, .1));color:var(--blue, #2170e4);cursor:pointer;transition:background .12s ease,color .12s ease}.profile-email-edit:hover{background:var(--blue, #2170e4);color:#fff}.profile-email-pending{margin-top:12px;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg-subtle, rgba(0, 0, 0, .02));display:flex;flex-direction:column;gap:8px}.profile-pending-row{display:flex;flex-direction:column;gap:3px}.profile-pending-status{display:flex;flex-direction:column;gap:4px}.profile-pending-status p{font-size:12px;color:var(--text-secondary);margin:0}.profile-pending-actions{display:flex;gap:8px}.profile-cancel-link{color:var(--red, #dc2626)}.profile-section-desc{font-size:13px;color:var(--text-secondary);margin:-6px 0 16px}.pw-rules{list-style:none;margin:10px 0 4px;padding:0;display:grid;gap:6px}.pw-rule{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-tertiary)}.pw-rule.ok{color:var(--green)}.pw-rule .dot{width:14px;height:14px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.acct-activity-list{display:flex;flex-direction:column;gap:0;padding:6px 0 8px}.acct-activity-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-subtle)}.acct-activity-row:last-child{border-bottom:none}.acct-activity-icon{width:22px;height:22px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--accent-subtle);color:var(--accent);padding:5px}.acct-activity-icon.login{background:var(--blue-bg);color:var(--blue)}.acct-activity-icon.password{background:var(--orange-bg);color:var(--orange)}.acct-activity-icon.profile,.acct-activity-icon.avatar{background:var(--green-bg);color:var(--green)}.acct-activity-msg{flex:1;font-size:11px;color:var(--text-primary);font-weight:500}.acct-activity-time{font-size:12px;color:var(--text-tertiary);white-space:nowrap}.acct-activity-empty{padding:28px 8px;text-align:center;color:var(--text-tertiary);font-size:13px}.pref-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--border-subtle)}.pref-row:last-child{border-bottom:none}.pref-row-text{flex:1}.pref-row-title{font-size:13px;font-weight:500;color:var(--text-primary)}.pref-row-desc{font-size:12px;color:var(--text-tertiary);margin-top:2px}.profile-banner{display:flex;align-items:center;gap:8px;background:var(--orange-bg);color:var(--orange);border:1px solid rgba(234,134,0,.25);border-radius:var(--radius-md);padding:10px 12px;font-size:12.5px;font-weight:500;margin-bottom:16px}@media (max-width: 640px){.profile-readonly{grid-template-columns:1fr}}.notif-grid{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}.notif-col{flex:1 1 420px;min-width:0}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.resize{resize:both}.border{border-width:1px}.border-none{border-style:none}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--bg-base: #f7f9fb;--bg-surface: #ffffff;--bg-elevated: #ffffff;--bg-hover: #eceef0;--bg-subtle: #f2f4f6;--bg-glass: rgba(247,249,251,.85);--border-subtle: #edf0f3;--border-default:#F1EDF6;--border-strong: #c6c6cd;--text-primary: #191c1e;--text-secondary: #45464d;--text-tertiary: #76777d;--text-inverted: #ffffff;--accent: #2170e4;--accent-hover: #0058be;--accent-glow: rgba(33,112,228,.22);--accent-subtle: rgba(33,112,228,.1);--red: #dc2626;--red-bg: rgba(220,38,38,.1);--orange: #ea8600;--orange-bg: rgba(234,134,0,.12);--yellow: #d99e00;--yellow-bg: rgba(217,158,0,.12);--green: #16a34a;--green-bg: rgba(22,163,74,.12);--blue: #2170e4;--blue-bg: rgba(33,112,228,.1);--purple: #7c3aed;--purple-bg: rgba(124,58,237,.1);--p-critical: #dc2626;--p-high: #ea8600;--p-normal: #2170e4;--p-low: #16a34a;--shadow-sm: 0 1px 2px rgba(15,23,42,.06);--shadow-md: 0 4px 12px rgba(15,23,42,.06);--shadow-glow: 0 0 0 3px var(--accent-subtle);--font-sans: "Inter", -apple-system, sans-serif;--font-serif: "Source Serif 4", Georgia, "Times New Roman", serif;--font-mono: "Inter", -apple-system, sans-serif;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--transition: all .15s ease;--transition-slow: all .3s ease}[data-theme=dark]{--bg-base: #0a0b0f;--bg-surface: #111318;--bg-elevated: #1a1d24;--bg-hover: #20242d;--bg-subtle: #16181f;--bg-glass: rgba(10,11,15,.8);--border-subtle: rgba(255,255,255,.06);--border-default:rgba(255,255,255,.1);--border-strong: rgba(255,255,255,.16);--text-primary: #f0f1f3;--text-secondary: #8b8fa8;--text-tertiary: #55596a;--text-inverted: #0a0b0f;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 16px rgba(0,0,0,.5)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg-base);color:var(--text-primary);font-family:var(--font-sans);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);font-weight:600;letter-spacing:-.02em;line-height:1.3}h1,h2{font-size:24px}h3{font-size:18px}h4{font-size:16px}h5{font-size:14px}h6{font-size:12px}input,textarea,select,button{font-family:var(--font-sans)}a{color:var(--accent);text-decoration:none}.card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;transition:var(--transition)}.card:hover{border-color:var(--border-default);background:var(--bg-elevated)}.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{background:transparent;border:1px solid var(--border-default);color:var(--text-secondary);border-radius:var(--radius-sm);padding:7px 14px;font-size:13px;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{background:var(--red-bg);border:1px solid rgba(248,113,113,.25);color:var(--red);border-radius:var(--radius-sm);padding:7px 14px;font-size:13px;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}.btn-danger:hover{background:#f871712e;border-color:#f8717166}.btn-sm{padding:5px 10px;font-size:12px}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:6px;font-size:11px;font-weight:500;border:1px solid transparent}.badge-red{background:var(--red-bg);color:var(--red);border-color:#f8717133}.badge-orange{background:var(--orange-bg);color:var(--orange);border-color:#fb923c33}.badge-yellow{background:var(--yellow-bg);color:var(--yellow);border-color:#fbbf2433}.badge-green{background:var(--green-bg);color:var(--green);border-color:#4ade8033}.badge-blue{background:var(--blue-bg);color:var(--blue);border-color:#60a5fa33}.badge-purple{background:var(--purple-bg);color:var(--purple);border-color:#c084fc33}.badge-ai{background:linear-gradient(135deg,#d9775726,#c084fc26);color:var(--purple);border-color:#c084fc40}.field{margin-bottom:16px}.field label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.input,.textarea,.select{width:100%;background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:9px 12px;font-size:13px;color:var(--text-primary);outline:none;transition:var(--transition)}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.password-field{position:relative}.password-field input{padding-right:40px}.password-toggle{position:absolute;top:50%;right:7px;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:none;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition)}.password-toggle:hover{color:var(--text-secondary);background:var(--bg-subtle)}.textarea{resize:vertical;min-height:80px}.select option{background:var(--bg-elevated)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);width:480px;max-width:calc(100vw - 40px);max-height:calc(100vh - 80px);overflow-y:auto;padding:24px;box-shadow:var(--shadow-md)}.modal-lg{width:600px;padding:28px}.form-grid{display:grid;grid-template-columns:1fr 1fr;-moz-column-gap:16px;column-gap:16px;align-items:start}.field-error{display:block;margin-top:5px;font-size:11px;color:var(--red)}.input-error,.input-error:focus{border-color:var(--red);box-shadow:none}@media (max-width: 560px){.form-grid{grid-template-columns:1fr}}.modal-title{font-size:16px;font-weight:600;margin:0 0 18px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.toggle{position:relative;width:36px;height:20px;border-radius:20px;background:var(--bg-hover);border:1px solid var(--border-default);cursor:pointer;transition:var(--transition);flex-shrink:0}.toggle.on{background:var(--green-bg);border-color:#4ade8066}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--text-tertiary);transition:var(--transition)}.toggle.on:after{left:18px;background:var(--green)}.ai-panel{background:linear-gradient(135deg,#d977570d,#c084fc0d);border:1px solid rgba(217,119,87,.2);border-radius:var(--radius-md);padding:16px;margin-top:16px}.ai-panel-header{display:flex;align-items:center;gap:8px;margin-bottom:14px;font-size:13px;font-weight:500;color:var(--purple)}.ai-panel-header .spacer{margin-left:auto}.ai-section{margin-bottom:12px}.ai-section label{display:block;font-size:11px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.ai-section p{font-size:13px;color:var(--text-secondary);line-height:1.6;margin:0}.code-block{background:var(--bg-base);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:12px;font-family:var(--font-mono);font-size:12px;color:var(--green);overflow-x:auto;margin:0;line-height:1.7;white-space:pre-wrap}.test-steps{list-style:none;padding:0;margin:0}.test-steps li{display:flex;align-items:flex-start;gap:6px;font-size:13px;color:var(--text-secondary);padding:3px 0}.test-steps li svg{margin-top:4px;flex-shrink:0;color:var(--green)}.ai-meta{display:flex;align-items:center;gap:10px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle)}.ai-confidence{font-size:12px;color:var(--text-tertiary);margin-left:auto}.task-ai-strip{display:flex;align-items:center;gap:5px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-subtle);font-size:11px;color:var(--text-tertiary)}.ai-dot{width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--purple));flex-shrink:0}.duplicate-warn{color:var(--orange)}.sidebar{--bg-subtle: #0f1117;--bg-surface: #1a1d24;--bg-hover: rgba(255,255,255,.06);--text-primary: #f1f2f4;--text-secondary: #9aa0b0;--text-tertiary: #6b7180;--border-subtle: rgba(255,255,255,.07);--border-default: rgba(255,255,255,.12);--accent-subtle: rgba(33,112,228,.2);width:240px;min-height:100vh;background:var(--bg-subtle);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;padding:0;position:fixed;left:0;top:0;bottom:0;z-index:20}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:20px 16px 16px;border-bottom:1px solid var(--border-subtle)}.brand-icon{display:flex;align-items:center;justify-content:center;color:var(--accent)}.brand-name{font-size:14px;font-weight:600;color:var(--text-primary)}.brand-logo{height:45px;width:auto;display:block}.sidebar-project-selector{padding:12px 12px 4px}.project-badge{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary);cursor:pointer;transition:var(--transition)}.project-badge:hover{border-color:var(--border-default);color:var(--text-primary)}.project-badge span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0}.sidebar-nav{flex:1;padding:8px;overflow-y:auto;display:flex;flex-direction:column}.sidebar-admin{margin-top:auto}.nav-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);font-size:13px;color:var(--text-secondary);text-decoration:none;transition:var(--transition);margin-bottom:1px}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent);color:#fff;font-weight:500}.nav-item.active:hover{background:var(--accent-hover);color:#fff}.nav-count{margin-left:auto;background:var(--accent-subtle);color:var(--accent);font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px}.nav-badge-ai{margin-left:auto;background:var(--purple-bg);color:var(--purple);font-size:10px;padding:2px 7px;border-radius:10px;border:1px solid rgba(192,132,252,.2)}.sidebar-section-label{font-size:10px;font-weight:600;color:var(--text-tertiary);letter-spacing:.08em;padding:16px 10px 6px}.sidebar-footer{display:flex;align-items:center;gap:10px;padding:14px;border-top:1px solid var(--border-subtle)}.user-trigger{display:flex;align-items:center;gap:10px;flex:1;min-width:0;background:transparent;border:none;padding:4px;margin:-4px;cursor:pointer;text-align:left;transition:background .15s ease}.user-trigger:hover{background:var(--bg-hover)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-subtle);border:1px solid var(--accent-glow);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--accent);flex-shrink:0;overflow:hidden}.user-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.task-assignee,.comment-user-avatar,.activity-avatar{overflow:hidden}.task-assignee img,.comment-user-avatar img,.activity-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.user-info{display:flex;flex-direction:column;line-height:1.3;flex:1;min-width:0}.user-name{font-size:13px;font-weight:500;color:var(--text-primary)}.user-role{font-size:11px;color:var(--text-tertiary)}.profile-avatar-row{display:flex;align-items:center;gap:16px;margin:8px 0 20px}.profile-avatar{position:relative;width:72px;height:72px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--accent-subtle);color:var(--accent);font-size:24px;font-weight:700;cursor:pointer;overflow:hidden;border:1px solid var(--border-default)}.profile-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.profile-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#20180f73;color:#fff;opacity:0;transition:opacity .15s ease}.profile-avatar:hover .profile-avatar-overlay{opacity:1}.profile-avatar-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.app-main{margin-left:240px;min-height:100vh;display:flex;flex-direction:column}.app-main.no-sidebar{margin-left:0}.topbar{display:flex;align-items:center;gap:14px;padding:14px 28px;border-bottom:1px solid var(--border-default);background:#fcf8ff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:60px;z-index:10}.global-topbar{display:flex;align-items:center;gap:12px;height:60px;padding:10px 28px;background:#fcf8ff;border-bottom:1px solid var(--border-default);position:sticky;top:0;z-index:30}.gt-project{position:relative;flex-shrink:0}.gt-project-btn{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;font-size:13px;font-weight:600;color:var(--text-primary);background:transparent;border:1px solid var(--border-default);border-radius:7px;cursor:pointer;white-space:nowrap;min-width:200px;transition:var(--transition)}.gt-project-btn:hover{background:var(--bg-subtle)}.gt-project-btn>svg:first-child{color:var(--accent)}.gt-project-btn>svg:last-child{margin-left:auto}.gt-right{flex:1 1 auto;display:flex;align-items:center;justify-content:flex-end;gap:15px}.gt-project-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:220px;max-height:320px;overflow-y:auto;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001f;padding:6px;z-index:40}.gt-project-item{display:block;width:100%;text-align:left;padding:8px 10px;font-size:13px;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer}.gt-project-item:hover{background:var(--bg-subtle);color:var(--text-primary)}.gt-project-item.active{color:var(--accent);font-weight:600}.gt-divider{width:1px;height:24px;background:var(--border-default);flex-shrink:0}.gt-icon{position:relative;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;transition:var(--transition)}.gt-icon:hover{background:var(--bg-subtle);color:var(--text-primary)}.gt-profile{display:inline-flex;align-items:center;gap:15px;padding:0;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;transition:var(--transition)}.gt-avatar{width:32px;height:32px}.gt-profile-info{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.gt-profile-name{font-size:13px;font-weight:600;color:var(--text-primary)}.gt-profile-role{font-size:11px;color:var(--text-tertiary);text-transform:capitalize}.gt-profile-wrap{position:relative}.gt-profile-menu{left:auto;right:0;min-width:190px}.gt-menu-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 10px;font-size:13px;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer}.gt-menu-item:hover{background:var(--bg-subtle);color:var(--text-primary)}.gt-menu-item.danger{color:var(--red)}.gt-menu-item.danger:hover{background:var(--red-bg);color:var(--red)}.gt-menu-sep{height:1px;background:var(--border-subtle);margin:6px 4px}@media (max-width: 720px){.gt-project-btn span,.gt-profile-info{display:none}}.proj-breadcrumb{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--text-tertiary);margin-top:2px}.proj-breadcrumb .current{color:var(--accent);font-weight:500}.stat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:20px}.stat-card{display:flex;align-items:center;gap:14px;padding:18px;text-align:left;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition)}.stat-card:hover{border-color:var(--border-strong)}.stat-card.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.stat-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;flex-shrink:0}.stat-icon.blue{background:var(--blue-bg);color:var(--blue)}.stat-icon.orange{background:var(--orange-bg);color:var(--orange)}.stat-icon.green{background:var(--green-bg);color:var(--green)}.stat-icon.red{background:var(--red-bg);color:var(--red)}.stat-label{font-size:12px;color:var(--text-secondary);margin-bottom:2px}.stat-value{font-size:24px;font-weight:700;color:var(--text-primary);line-height:1.1}.proj-table-card{padding:0;overflow:hidden}.proj-table-wrap{overflow-x:auto}.proj-table{width:100%;border-collapse:collapse}.proj-table thead{background:var(--bg-subtle)}.proj-table th{text-align:left;font-size:14px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);padding:14px 16px;border-bottom:1px solid var(--border-default);white-space:nowrap}.proj-table td{padding:12px 16px;border-bottom:1px solid var(--border-subtle);font-size:13px;vertical-align:middle}.proj-table tbody tr:last-child td{border-bottom:none}.proj-row{cursor:pointer;transition:background .15s ease}.proj-row:hover{background:#f2f4f64d}.proj-empty{text-align:center;color:var(--text-tertiary);padding:32px 0!important}.proj-muted{color:var(--text-tertiary)}.proj-cell{display:flex;align-items:center;gap:12px}.proj-avatar{width:38px;height:38px;border-radius:50%;font-size:13px}.proj-name{font-size:13px;font-weight:600;color:var(--text-primary)}.proj-code{font-size:11px;color:var(--text-tertiary)}.client-cell{display:flex;align-items:center;gap:8px}.creator-avatar{width:26px;height:26px;border-radius:50%;font-size:11px}.member-stack{display:inline-flex;align-items:center}.member-avatar{width:28px;height:28px;border-radius:50%;font-size:11px;border:2px solid var(--bg-surface);margin-left:-12px;font-weight:700;box-shadow:1px 0 2px #cacaca}.member-stack .member-avatar:first-child{margin-left:0}.member-more{margin-left:8px;font-size:12px;font-weight:500;color:var(--text-secondary)}.client-badge{width:24px;height:24px;border-radius:6px;background:var(--bg-subtle);color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block;flex-shrink:0}.progress-cell{display:flex;flex-direction:column;gap:6px;min-width:120px}.progress-pct{font-size:12px;font-weight:600;letter-spacing:.01em}.progress-track{width:120px;height:7px;border-radius:var(--radius-full);background:#eef0f3;overflow:hidden}.progress-fill{display:block;height:100%;border-radius:var(--radius-full);box-shadow:inset 0 1px 1px #ffffff40;transition:width .45s cubic-bezier(.4,0,.2,1)}.proj-pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-top:1px solid var(--border-default);flex-wrap:wrap}.proj-count{font-size:13px;color:var(--text-secondary)}.proj-pager{display:flex;align-items:center;gap:6px}.page-btn{min-width:32px;height:32px;padding:0 8px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.page-btn:hover:not(:disabled){background:var(--bg-subtle)}.page-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.page-btn:disabled{opacity:.45;cursor:not-allowed}.page-size{width:auto;min-width:110px;margin-left:6px}@media (max-width: 1100px){.stat-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 680px){.stat-grid{grid-template-columns:repeat(2,1fr)}}.view-toggle{display:inline-flex;flex-shrink:0;border:1px solid var(--border-default);border-radius:var(--radius-sm);overflow:hidden}.view-toggle button{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--bg-surface);border:none;color:var(--text-tertiary);cursor:pointer;transition:var(--transition)}.view-toggle button+button{border-left:1px solid var(--border-default)}.view-toggle button:hover{background:var(--bg-subtle);color:var(--text-primary)}.view-toggle button.active{background:var(--accent);color:#fff}.proj-grid-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:16px}.proj-grid-card{display:flex;flex-direction:column;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:var(--transition)}.proj-grid-card:hover{border-color:var(--border-strong);box-shadow:0 4px 12px #0000000f}.proj-grid-thumb{position:relative;height:150px;background:var(--bg-subtle);overflow:hidden}.proj-grid-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.proj-grid-thumb-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);background:#fbf6fd}.proj-grid-thumb-badge{position:absolute;top:10px;right:10px;background:#fff;box-shadow:0 1px 4px #0000001f}.proj-grid-body{display:flex;flex-direction:column;gap:14px;padding:16px}.proj-grid-head{display:flex;align-items:center;gap:12px}.proj-grid-head .proj-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-grid-foot{display:flex;align-items:center;justify-content:space-between}.proj-grid-pager{padding:0}.proj-grid-pager .proj-pagination{border-top:none}.topbar h1{font-weight:600;margin:0}.topbar .spacer{margin-left:auto}.topbar .user-search{margin-bottom:0;width:400px}.topbar-center{flex:1 1 auto;min-width:0;display:flex;align-items:center;justify-content:flex-end}.topbar-center .board-filters{margin-bottom:0;width:100%;margin-left:auto;justify-content:end}.page-content{padding:28px;flex:1}.page-content.board-page{background:#f4f5f8;padding:20px 28px 15px}.board-filters{display:flex;align-items:center;gap:10px;margin-bottom:20px}.board-filter-combo{position:relative;display:flex;flex-wrap:wrap;align-items:center;gap:6px;flex:1 1 auto;min-height:36px;padding:3px 38px 3px 10px;background:#fff;border:1px solid var(--border-default);border-radius:var(--radius-sm);cursor:text;transition:var(--transition)}.board-filter-combo:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.board-filter-chip{display:inline-flex;align-items:center;gap:5px;background:var(--bg-hover);color:var(--text-primary);border:none;padding:4px 8px;font-size:12px;white-space:nowrap}.board-filter-chip strong{font-weight:700;letter-spacing:.02em}.board-filter-chip button{display:inline-flex;align-items:center;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:0;line-height:1}.board-filter-chip button:hover{color:var(--text-primary)}.board-filter-chip-active{background:var(--accent-subtle);color:var(--accent)}.board-filter-chip-active button{color:var(--accent)}.board-filter-input{flex:1 1 120px;min-width:80px;border:none;outline:none;background:transparent;padding:3px 0;font-size:12.5px;color:var(--text-primary);font-family:var(--font-sans)}.board-filter-searchicon{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.board-filter-menu{position:absolute;top:calc(100% + 4px);left:0;right:auto;width:260px;max-width:100%;z-index:20;margin:0;padding:4px;list-style:none;max-height:248px;overflow-y:auto;background:var(--bg-elevated);border:1px solid var(--border-default);box-shadow:var(--shadow-lg, 0 10px 28px rgba(0,0,0,.16))}.board-filter-menu li{padding:6px 10px;font-size:12.5px;line-height:1.35;color:var(--text-primary);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.board-filter-menu li.active{background:var(--accent);color:#fff}.board-filter-funnel{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:36px;height:36px;background:transparent;border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition)}.board-filter-funnel:hover{background:var(--bg-hover);color:var(--text-primary)}.board-filter-funnel.has-active{color:var(--accent);border-color:var(--accent)}.board-filter-funnel.open{background:var(--bg-hover);color:var(--text-primary)}.board-filter-clearall{flex:0 0 auto;background:transparent;border:none;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;padding:4px 6px}.board-filter-clearall:hover{color:var(--accent);text-decoration:underline}.dept-select{position:relative}.dept-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;gap:8px;background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:9px 12px;font-size:13px;color:var(--text-primary);cursor:pointer;transition:var(--transition)}.dept-trigger:hover{border-color:var(--border-strong)}.dept-placeholder{color:var(--text-tertiary)}.dept-menu{z-index:1000;background:var(--bg-elevated);border:1px solid var(--border-default);box-shadow:var(--shadow-lg, 0 10px 28px rgba(0,0,0,.16))}.dept-search{display:flex;align-items:center;gap:6px;padding:8px 10px;border-bottom:1px solid var(--border-subtle);color:var(--text-tertiary)}.dept-search input{flex:1 1 auto;min-width:0;border:none;outline:none;background:transparent;font-size:13px;color:var(--text-primary);font-family:var(--font-sans)}.dept-list{list-style:none;margin:0;padding:4px;min-height:111px;max-height:222px;overflow-y:auto}.dept-empty{padding:8px 10px;font-size:12px;color:var(--text-tertiary)}.dept-item{display:flex;align-items:center;justify-content:space-between;gap:8px}.dept-item:hover{background:var(--bg-hover)}.dept-name{display:flex;align-items:center;gap:6px;flex:1 1 auto;background:transparent;border:none;text-align:left;padding:8px 10px;font-size:13px;color:var(--text-primary);cursor:pointer}.dept-item.active .dept-name{color:var(--accent);font-weight:600}.dept-inuse{flex:0 0 auto;margin-right:10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary)}.dept-del{flex:0 0 auto;margin-right:6px;display:inline-flex;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px}.dept-del:hover{color:var(--red, #C0563F)}.dept-add{display:flex;gap:6px;padding:8px;border-top:1px solid var(--border-subtle)}.dept-add input{flex:1 1 auto;min-width:0;border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--bg-base);padding:7px 10px;font-size:13px;color:var(--text-primary);outline:none;font-family:var(--font-sans)}.dept-add input:focus{border-color:var(--accent)}.dept-add-btn{flex:0 0 auto;display:inline-flex;align-items:center;gap:4px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:0 12px;font-size:12px;font-weight:600;cursor:pointer}.dept-add-btn:disabled{opacity:.5;cursor:not-allowed}.archive-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:14px}.archive-search{margin-left:auto;display:flex;align-items:center;gap:6px;flex:1 1 260px;max-width:360px;background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:0 10px;color:var(--text-tertiary);transition:var(--transition)}.archive-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.archive-search input{flex:1 1 auto;border:none;outline:none;background:transparent;padding:8px 0;font-size:13px;color:var(--text-primary);font-family:var(--font-sans)}.archive-search button{display:inline-flex;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:0}.archive-search button:hover{color:var(--text-primary)}.archive-selectall{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary);padding:4px 6px 10px;cursor:pointer}.archive-check,.archive-selectall input[type=checkbox]{flex:0 0 auto;width:16px;height:16px;margin:0;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);cursor:pointer;position:relative;transition:background .12s ease,border-color .12s ease}.archive-check:hover,.archive-selectall input[type=checkbox]:hover{border-color:var(--accent)}.archive-check:checked,.archive-selectall input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.archive-check:checked:after,.archive-selectall input[type=checkbox]:checked:after{content:"";position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.archive-check:focus-visible,.archive-selectall input[type=checkbox]:focus-visible{outline:none;box-shadow:var(--shadow-glow)}.archive-list{display:flex;flex-direction:column;margin-top:4px}.archive-row{display:flex;align-items:center;gap:14px;padding:10px 6px;border-bottom:1px solid var(--border-subtle);cursor:pointer}.archive-row:last-child{border-bottom:none}.archive-row:hover{background:var(--bg-hover)}.archive-num{flex:0 0 auto;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;font-family:var(--font-mono);border-radius:var(--radius-sm)}.archive-title{flex:1 1 auto;min-width:0;font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.archive-restore{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;opacity:0;transition:opacity .15s ease}.archive-row:hover .archive-restore,.archive-restore:focus{opacity:1}.archive-restore:hover{text-decoration:underline}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}.project-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:var(--transition-slow);position:relative}.project-card:hover{border-color:var(--border-default);transform:translateY(-2px);box-shadow:var(--shadow-md)}.project-card:hover .card-glow{opacity:1}.card-glow{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-lg);background:radial-gradient(ellipse at 50% 0%,var(--accent-glow) 0%,transparent 70%);opacity:0;pointer-events:none;transition:var(--transition-slow)}.project-thumbnail{height:140px;background:var(--bg-base);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.project-thumbnail img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:top center;object-position:top center;opacity:1;transition:transform .4s ease}.project-card:hover .project-thumbnail img{transform:scale(1.04)}.thumb-placeholder{font-size:28px;font-weight:700;color:var(--text-tertiary);font-family:var(--font-mono)}.bug-count-badge{position:absolute;top:10px;right:10px;background:#f87171e6;color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:20px;display:flex;align-items:center;gap:4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1)}.project-card-body{padding:14px 16px}.project-name{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.project-env{font-size:11px;color:var(--text-tertiary);margin-bottom:10px}.project-meta{display:flex;align-items:center;gap:12px;font-size:11px;color:var(--text-tertiary)}.board{display:flex;gap:10px;align-items:flex-start;overflow-x:auto;padding-bottom:0}.add-column-btn{width:240px;flex-shrink:0;align-self:flex-start;display:flex;align-items:center;justify-content:center;gap:6px;padding:14px;font-size:13px;font-weight:600;color:var(--text-secondary);background:transparent;border:1.5px dashed var(--border-strong);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition)}.add-column-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-subtle)}.kanban-column{width:290px;flex-shrink:0;background:transparent;border:1px solid #f1edf6;border-radius:var(--radius-lg);max-height:calc(100vh - 165px);display:flex;flex-direction:column;min-height:calc(100vh - 165px);padding:5px}.kanban-column-header{display:flex;align-items:center;gap:8px;padding:4px 0 12px;font-size:13px;font-weight:900;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-subtle);margin-bottom:10px;font-family:var(--font-mono)}.col-drag-handle{background:transparent;border:none;padding:2px;margin:-2px 0 -2px -2px;color:var(--text-tertiary);cursor:grab;display:flex;align-items:center;border-radius:var(--radius-sm);opacity:1;transition:opacity .15s ease,color .15s ease,background .15s ease;touch-action:none}.kanban-column:hover .col-drag-handle{opacity:1}.col-drag-handle:hover{color:var(--text-primary);background:var(--bg-hover)}.col-drag-handle:active{cursor:grabbing}.kanban-column.col-dragging{opacity:.4;outline:1.5px dashed var(--accent);outline-offset:-1px}.kanban-column.col-dragging-overlay{cursor:grabbing;box-shadow:var(--shadow-md);transform:rotate(1.5deg);background:var(--bg-subtle);opacity:.97}.column-count{background:var(--bg-hover);color:var(--text-tertiary);font-size:12px;padding:1px 7px;border-radius:10px}.kanban-column-body{overflow-y:auto;flex:1;min-height:60px;border-radius:var(--radius-sm);padding:5px}.task-drop-placeholder{height:60px;border:1.5px dashed var(--accent);border-radius:var(--radius-md);background:var(--accent-subtle);margin-bottom:6px;animation:placeholder-in .15s ease}@keyframes placeholder-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.col-menu-wrap{margin-left:auto;position:relative}.col-menu-btn{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:3px 5px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:var(--transition)}.col-menu-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.col-menu{position:absolute;top:calc(100% + 4px);right:0;width:180px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:5px;z-index:40}.col-menu-item{display:flex;align-items:center;gap:9px;width:100%;background:transparent;border:none;color:var(--text-secondary);font-size:13px;font-family:inherit;text-align:left;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);text-transform:none;letter-spacing:normal;font-weight:500}.col-menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.col-menu-item.danger{color:var(--red)}.col-menu-item.danger:hover{background:var(--red-bg)}.bulk-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:10px 14px;box-shadow:var(--shadow-md);z-index:60}.bulk-count{font-size:13px;font-weight:600;color:var(--text-primary);margin-right:4px;white-space:nowrap}.bulk-bar .select{width:auto}.task-card.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.task-card.active{border-color:var(--accent);box-shadow:0 0 0 1.5px var(--accent)}.task-card.active[data-priority=critical]{border-color:var(--red);box-shadow:0 0 0 1.5px var(--red)}.task-card.active[data-priority=high]{border-color:var(--orange);box-shadow:0 0 0 1.5px var(--orange)}.task-card.active[data-priority=normal]{border-color:var(--blue);box-shadow:0 0 0 1.5px var(--blue)}.task-card.active[data-priority=low]{border-color:var(--green);box-shadow:0 0 0 1.5px var(--green)}.task-check{position:absolute;top:10px;right:10px;width:17px;height:17px;border-radius:50%;border:1.5px solid var(--border-strong);background:var(--bg-base);color:#fff;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.task-check.on{background:var(--accent);border-color:var(--accent)}.task-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:14px;cursor:pointer;transition:var(--transition);position:relative;margin-bottom:10px;box-shadow:var(--shadow-sm)}.task-card:not(.active):hover{border-color:transparent;box-shadow:0 6px 5px #0000000d;transition:all .3s!important}.task-card.dragging{opacity:1;background:var(--accent-subtle);border:1.5px dashed var(--accent);box-shadow:none}.task-card.dragging>*{visibility:hidden}.task-card.dragging:before{opacity:0}.task-card.dragging-overlay{cursor:grabbing;background:var(--bg-surface);border-color:var(--accent);box-shadow:var(--shadow-md);transform:rotate(2deg) scale(1.03)}.task-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.task-number{font-size:14px;color:var(--accent);font-weight:600;font-family:var(--font-mono)}.task-title{font-size:13px;font-weight:500;color:var(--text-primary);line-height:1.4;margin-bottom:6px}.task-desc{font-size:13px;font-weight:500;color:var(--text-primary);line-height:1.4;letter-spacing:-.01em;margin:0 0 10px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;white-space:pre-wrap;word-break:break-word;min-height:40px}.task-priority{display:inline-flex;align-items:center;padding:3px 9px;font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border-radius:6px}.task-priority[data-priority=critical]{background:var(--red-bg);color:var(--red)}.task-priority[data-priority=high]{background:var(--orange-bg);color:var(--orange)}.task-priority[data-priority=normal]{background:var(--blue-bg);color:var(--blue)}.task-priority[data-priority=low]{background:var(--green-bg);color:var(--green)}.task-footer{display:flex;align-items:center;gap:8px;margin-top:5px;font-weight:500}.task-meta-date{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:#a8a8a8}.task-meta-right{display:inline-flex;align-items:center;gap:12px;margin-left:auto}.task-meta{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--text-secondary)}.task-meta svg{color:var(--text-tertiary)}.task-tags{display:flex;flex-wrap:wrap;gap:5px;min-width:0}.task-tag{font-size:10px;color:var(--text-tertiary);background:var(--bg-elevated);padding:2px 7px;border-radius:var(--radius-full);border:1px solid var(--border-subtle)}.task-assignee{width:22px;height:22px;border-radius:50%;background:var(--accent-subtle);color:var(--accent);font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center}.task-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;z-index:50}.task-panel{position:fixed;top:0;right:0;bottom:0;width:550px;max-width:100vw;background:var(--bg-elevated);border-left:1px solid var(--border-default);box-shadow:var(--shadow-md);z-index:51;overflow-y:auto;padding:0 24px 24px}.task-panel-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px}.task-panel h2{font-size:17px;font-weight:600;margin:4px 0 0;line-height:1.4;flex:1}.panel-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:var(--transition)}.panel-close:hover{background:var(--bg-hover);color:var(--text-primary)}.panel-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px 0}.panel-section{margin:18px 0}.panel-section>label{display:block;font-size:11px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.panel-desc{font-size:13px;color:var(--text-secondary);line-height:1.6;white-space:pre-wrap}.panel-screenshot{width:100%;border-radius:var(--radius-sm);border:1px solid var(--border-subtle)}.meta-line{font-size:12px;color:var(--text-tertiary);display:flex;align-items:center;gap:6px;margin-bottom:4px;word-break:break-all}.comment{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-subtle)}.comment-body{flex:1}.comment-author{font-size:12px;font-weight:600;color:var(--text-primary)}.comment-time{font-size:11px;color:var(--text-tertiary);margin-left:8px}.comment-text{font-size:13px;color:var(--text-secondary);margin-top:2px}.comment-form{display:flex;gap:8px;margin-top:12px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:18px 20px;transition:var(--transition)}.stat-card:hover{border-color:var(--border-strong);box-shadow:0 2px 10px #0f172a0d;transform:translateY(-1px)}.stat-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.stat-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-weight:600;line-height:1.35;padding-top:3px}.stat-header .stat-icon{width:38px;height:38px;border-radius:var(--radius-md)}.stat-icon.color-accent{color:var(--accent);background:var(--accent-subtle)}.stat-icon.color-green{color:var(--green);background:var(--green-bg)}.stat-icon.color-red{color:var(--red);background:var(--red-bg)}.stat-icon.color-blue{color:var(--blue);background:var(--blue-bg)}.stat-icon.color-amber{color:var(--orange);background:var(--orange-bg)}.analytics-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.data-table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);padding:8px 12px;border-bottom:1px solid var(--border-strong);white-space:nowrap}.data-table td{padding:10px 12px;border-bottom:1px solid var(--border-subtle);color:var(--text-primary)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table-user{display:flex;align-items:center;gap:8px;font-weight:500}.data-table-empty{text-align:center;color:var(--text-tertiary);padding:24px 12px}.stat-value{font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);line-height:1;margin-bottom:0}.stat-delta{font-size:12px;margin-top:8px}.stat-delta.up{color:var(--green)}.stat-delta.down{color:var(--red)}.chart-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:16px}@media (max-width: 1100px){.chart-grid{grid-template-columns:1fr}}.chart-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.chart-header h3{font-size:14px;font-weight:600;margin:0}.health-score{display:flex;flex-direction:column;align-items:center;gap:2px}.health-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.priority-bars{display:flex;flex-direction:column;gap:12px}.priority-bar-row{display:flex;align-items:center;gap:10px;font-size:12px}.priority-bar-label{width:60px;color:var(--text-secondary)}.priority-bar-track{flex:1;height:8px;background:var(--bg-elevated);border-radius:4px;overflow:hidden}.priority-bar-fill{height:100%;border-radius:4px;transition:width .6s ease}.priority-bar-count{width:30px;text-align:right;color:var(--text-tertiary);font-family:var(--font-mono)}.insight-list{list-style:none;margin:0;padding:0}.insight-list li{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--text-secondary);padding:6px 0}.insight-list li:before{content:"✦";color:var(--purple);flex-shrink:0}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 600px 400px at 50% -10%,var(--accent-glow),transparent),var(--bg-base)}.auth-card{width:380px;max-width:calc(100vw - 40px);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow-md)}.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:22px}.auth-logo{height:60px;width:auto;display:block}.reopen-count-link{background:none;border:none;padding:0;font:inherit;font-weight:600;color:var(--accent);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.reopen-count-link:hover{opacity:.8}.drill-modal{max-width:480px}.reopen-task-list{display:flex;flex-direction:column;gap:6px;max-height:420px;overflow-y:auto;margin:0 -4px;padding:0 4px}.reopen-task-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:11px 14px;background:var(--bg-subtle);border:1px solid var(--border-subtle);border-radius:9px;cursor:pointer;transition:var(--transition)}.reopen-task-item:hover{background:var(--accent-subtle, rgba(33,112,228,.08));border-color:var(--accent);transform:translate(2px)}.reopen-task-dot{flex-shrink:0;width:9px;height:9px;border-radius:50%}.reopen-task-id{font-weight:700;color:var(--accent);flex-shrink:0;font-variant-numeric:tabular-nums}.reopen-task-title{flex:1;color:var(--text-primary);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reopen-task-count{flex-shrink:0;font-size:11px;font-weight:700;color:var(--accent);background:var(--accent-subtle, rgba(33,112,228,.12));border-radius:999px;padding:2px 9px}.reopen-task-go{flex-shrink:0;color:var(--text-tertiary);opacity:0;transition:opacity .15s ease}.reopen-task-item:hover .reopen-task-go{opacity:1}.auth-card h1{font-size:20px;font-weight:600;margin:0 0 4px}.auth-sub{font-size:13px;color:var(--text-secondary);margin:0 0 22px}.auth-switch{font-size:13px;color:var(--text-secondary);text-align:center;margin-top:18px}.snippet{background:#000;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px;font-family:var(--font-mono);font-size:12px;color:var(--green);white-space:pre-wrap;word-break:break-all;line-height:1.7;position:relative}.empty-state{text-align:center;color:var(--text-tertiary);padding:60px 20px;font-size:13px}.section-title{font-size:14px;font-weight:600;margin:0 0 14px}.member-row{display:flex;align-items:center;gap:12px;padding:12px;margin:0 -12px;border-radius:10px;border-bottom:1px solid var(--border-subtle);transition:background .15s ease}.member-row:last-child{border-bottom:none}.member-row:hover{background:var(--bg-subtle)}.user-controls{display:flex;align-items:center;justify-content:flex-end;gap:14px;flex-wrap:wrap;row-gap:8px}.user-controls>*{flex-shrink:0}.member-main{flex:1;min-width:0}.page-content.narrow{max-width:720px}.setting-card{display:flex;align-items:center;gap:14px}.setting-card .setting-main{flex:1;min-width:0}.card-stack{display:flex;flex-direction:column;gap:16px}.card-grid{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-start}.card-grid>.card{min-width:0}.card-grid>.card.col-wide{flex:2 1 420px}.card-grid>.card.col-narrow{flex:1 1 280px}.status-toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer}.status-label{font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary);min-width:50px;text-align:right}.status-label.active{color:var(--green)}.role-select{width:132px}.icon-btn-danger,.icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:7px;line-height:0}.badge-neutral{background:var(--bg-subtle);color:var(--text-secondary);border-color:var(--border-subtle)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.page-header h2{font-size:24px;font-weight:700;line-height:1.2;margin:0 0 4px;color:var(--text-primary)}.page-header .page-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.member-name{font-size:12px;font-weight:600;text-transform:capitalize}.member-email{font-size:12px;color:var(--text-tertiary)}.role-seg{display:inline-flex;gap:5px}.role-seg button{padding:4px 12px;font-size:10px;font-weight:500;border-radius:5px;border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.role-seg button:hover:not(.is-active){background:var(--bg-subtle);color:var(--text-primary)}.role-seg button.is-active{background:var(--accent);border-color:var(--accent);color:#fff}.admin-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}.info-card-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:var(--blue-bg);color:var(--blue);margin-bottom:12px}.info-card h4{font-size:15px;font-weight:600;margin:0 0 6px;color:var(--text-primary)}.info-card p{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0 0 14px}.info-card-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--accent);background:none;border:none;padding:0;cursor:pointer}.info-card-link:hover{text-decoration:underline}@media (max-width: 640px){.admin-info-grid{grid-template-columns:1fr}}.user-search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:0 12px;margin-bottom:12px;color:var(--text-tertiary);transition:var(--transition)}.user-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.user-search input{flex:1 1 auto;border:none;outline:none;background:transparent;padding:9px 0;font-size:13px;color:var(--text-primary);font-family:var(--font-sans)}.user-search button{display:inline-flex;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:0}.user-search button:hover{color:var(--text-primary)}.user-empty{text-align:center;padding:28px 0;font-size:13px;color:var(--text-tertiary)}.page-header-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.page-header-actions .user-search{width:280px;margin-bottom:0}.filter-select{width:auto;min-width:120px;flex-shrink:0}.btn-create-user{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;cursor:pointer;box-shadow:0 1px 2px #00000014;transition:var(--transition)}.btn-create-user:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 2px 6px #2170e440}@media (max-width: 720px){.page-header{flex-direction:column;align-items:stretch}.page-header-actions{flex-wrap:wrap}.page-header-actions .user-search{width:100%}}.task-panel{background-color:#fff!important;transition:width .3s cubic-bezier(.4,0,.2,1)}.task-panel.expanded{width:760px}.task-panel-header{display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;padding-top:20px;padding-bottom:20px;margin-bottom:18px;z-index:1}.task-panel-header:before{content:"";position:absolute;bottom:0;top:0;left:-24px;width:calc(100% + 48px);border-bottom:1px solid #f1edf6;pointer-events:none;z-index:1}.task-badge-container{display:flex;align-items:center}.task-badge{background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:12px;letter-spacing:.04em}.task-badge[data-priority=critical]{background:var(--red);color:#fff}.task-badge[data-priority=high]{background:var(--orange);color:#fff}.task-badge[data-priority=normal]{background:var(--blue);color:#fff}.task-badge[data-priority=low]{background:var(--green);color:#fff}.task-panel-actions{display:flex;align-items:center;gap:6px}.panel-action-btn{background:transparent;border:none;color:#64748b;cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease}.panel-action-btn:hover{background:#f1f5f9;color:#334155}.panel-action-btn.text-danger:hover{background:#fef2f2;color:#ef4444}.task-card{background:#fff;border:1px solid var(--border-default);border-radius:6px;padding:10px;box-shadow:0 1px 3px #0000000d;margin-bottom:10px}.task-title-input{width:100%;background:transparent;border:none;font-size:18px;font-weight:700;color:var(--text-primary);outline:none;margin-bottom:8px;padding:4px 0}.task-title-input:focus{border-bottom:1px solid var(--border-strong)}.task-desc-textarea{width:100%;background:transparent;border:none;font-size:13px;color:var(--text-secondary);outline:none;resize:none;line-height:1.5}.main-inputs-card{display:flex;flex-direction:column}.task-desc-region{flex:1 1 auto;min-height:72px;cursor:text}.task-desc-display{width:100%;font-size:13px;color:var(--text-secondary);line-height:1.5;white-space:pre-wrap;word-break:break-word;cursor:text;min-height:130px}.task-desc-display.clamped{display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}.task-desc-empty{color:var(--text-tertiary);font-style:italic;cursor:pointer}.desc-link{color:var(--accent);text-decoration:none;word-break:break-all}.desc-link:hover{text-decoration:underline}.desc-toggle{display:block;width:100%;text-align:center;background:none;border:none;color:var(--accent);font-weight:600;font-size:13px;cursor:pointer;padding:6px 0 2px}.desc-toggle:hover{text-decoration:underline}.status-transition-bar{display:flex;align-items:center;gap:8px;margin-bottom:16px;position:relative}.status-button-group{display:flex;position:relative}.btn-status-primary{background:var(--accent);color:#fff;border:none;border-top-left-radius:6px;border-bottom-left-radius:6px;padding:7px 10px;font-size:11px;font-weight:700;cursor:pointer;display:flex;align-items:center;transition:background .15s ease}.btn-status-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-status-primary:disabled{background:var(--border-strong);color:var(--text-tertiary);cursor:default}.btn-status-arrow{background:var(--accent);color:#fff;border:none;border-top-right-radius:6px;border-bottom-right-radius:6px;padding:6px 10px;border-left:1px solid rgba(255,255,255,.2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.btn-status-arrow:hover{background:var(--accent-hover)}.status-dropdown-menu{position:absolute;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid var(--border-default);border-radius:6px;box-shadow:0 4px 12px #00000014;z-index:100;display:flex;flex-direction:column;padding:4px;min-width:165px}.status-menu-item{display:flex;align-items:center;background:transparent;border:none;text-align:left;padding:8px 12px;font-size:13px;color:var(--text-primary);cursor:pointer;border-radius:4px;transition:background .1s ease;width:100%}.status-menu-item:hover{background:var(--border-subtle);color:var(--text-primary)}.status-menu-item.active{background:var(--accent-subtle);color:var(--accent-hover);font-weight:600}.more-actions-group{position:relative}.btn-status-secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border-default);border-radius:6px;padding:6px 12px;font-size:11px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:4px;box-shadow:0 1px 2px #0000000d;transition:background .15s ease}.btn-status-secondary:hover{background:var(--bg-hover);border-color:var(--border-strong)}.more-dropdown-menu{position:absolute;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid var(--border-default);border-radius:6px;box-shadow:0 4px 12px #00000014;z-index:100;display:flex;flex-direction:column;padding:4px;min-width:140px}.more-menu-item{background:transparent;border:none;text-align:left;padding:8px 12px;font-size:13px;color:var(--text-primary);cursor:pointer;border-radius:4px;display:flex;align-items:center;transition:background .1s ease;width:100%}.more-menu-item:hover{background:var(--border-subtle);color:var(--text-primary)}.more-menu-item.text-danger{color:#dc2626}.more-menu-item.text-danger:hover{background:#fef2f2}.tp-header-left{display:flex;align-items:center;gap:6px}.tp-task-id{font-size:13px;font-weight:800;letter-spacing:.04em;color:var(--text-primary)}.tp-header-divider{width:1px;height:18px;background:var(--border-strong);margin:0 4px}.tp-title-input{width:100%;background:transparent;border:none;outline:none;font-size:26px;font-weight:800;line-height:1.2;color:var(--text-primary);padding:0;margin:6px 0 14px}.tp-title-input::-moz-placeholder{color:var(--text-tertiary)}.tp-title-input::placeholder{color:var(--text-tertiary)}.tp-tabs{display:flex;align-items:center;gap:24px;border-bottom:1px solid var(--border-default);margin-bottom:18px}.tp-tab{position:relative;background:none;border:none;cursor:pointer;padding:8px 0 12px;font-size:14px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.tp-tab:hover{color:var(--text-primary)}.tp-tab.active{color:var(--accent);font-weight:700}.tp-tab.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--accent);border-radius:2px}.tp-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--bg-hover);color:var(--text-secondary);font-size:11px;font-weight:700}.tp-section-label{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.tp-tabpanel .task-desc-region{margin-bottom:16px}.tp-tabpanel .task-desc-display{font-size:15px;color:var(--text-secondary)}.tp-tabpanel .task-desc-textarea{background:#fff;border:1px solid var(--border-default);border-radius:8px;padding:10px 12px;font-size:15px;margin-bottom:16px}.severity-pill{display:inline-flex;align-items:center;padding:7px 12px;border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.04em}.severity-pill[data-priority=critical]{background:#f8dde2;color:#9f2540}.severity-pill[data-priority=high]{background:var(--orange-bg);color:#b45c00}.severity-pill[data-priority=normal]{background:var(--blue-bg);color:var(--accent)}.severity-pill[data-priority=low]{background:var(--green-bg);color:#15803d}.reopened-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.02em;background:red;color:#fff;margin-left:auto}.reopen-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:20px}.reopen-modal{background:var(--surface, #fff);border-radius:12px;width:100%;max-width:440px;box-shadow:0 20px 50px #00000040;padding:20px}.reopen-modal-header{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:10px}.reopen-modal-close{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--text-secondary);display:inline-flex;padding:4px}.reopen-modal-close:hover{color:var(--text-primary)}.reopen-modal-hint{font-size:13px;color:var(--text-secondary);margin:0 0 12px}.reopen-reason-input{width:100%;box-sizing:border-box;border:1px solid var(--border, #e2e8f0);border-radius:8px;padding:10px 12px;font-size:13px;font-family:inherit;resize:vertical;margin-bottom:16px}.reopen-reason-input:focus{outline:none;border-color:var(--accent)}.reopen-modal-actions{display:flex;justify-content:flex-end;gap:10px}.reopen-modal-actions .btn-status-primary,.reopen-modal-actions .btn-status-secondary{border-radius:8px;padding:9px 18px}.task-reporter-line{font-size:12px;color:var(--text-secondary);margin-bottom:20px;padding-left:2px}.screenshot-section{margin-top:16px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.section-title{font-weight:700;color:var(--text-secondary);letter-spacing:.05em}.slide-in-right .section-title{font-size:11px}.section-actions{display:flex;align-items:center;gap:12px}.action-icon-btn{background:transparent;border:none;color:var(--accent);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .15s ease}.action-icon-btn:hover{background:var(--accent-subtle)}.focus-toggle-container{display:flex;align-items:center;gap:6px}.focus-toggle-label{font-size:11px;font-weight:700;color:var(--accent);letter-spacing:.02em}.focus-switch{position:relative;display:inline-block;width:32px;height:18px}.focus-switch input{opacity:0;width:0;height:0}.focus-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background-color:var(--border-strong);transition:.3s;border-radius:34px}.focus-slider:before{position:absolute;content:"";height:12px;width:12px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.focus-switch input:checked+.focus-slider{background-color:var(--accent)}.focus-switch input:checked+.focus-slider:before{transform:translate(14px)}.screenshot-card{background:#fff;border:1px dashed var(--border-strong);border-radius:8px;padding:12px;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;overflow:hidden}.screenshot-img-wrapper{width:100%;overflow:hidden;border-radius:6px;display:flex;justify-content:center;background:var(--bg-hover);position:relative;cursor:zoom-in}.screenshot-zoom-hint{position:absolute;top:8px;right:8px;display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:#20180f8c;color:#fff;opacity:0;transition:opacity .15s ease;pointer-events:none}.screenshot-img-wrapper:hover .screenshot-zoom-hint{opacity:1}.activity-section{margin-top:4px}.activity-header{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:none;padding:10px 0;cursor:pointer;color:var(--text-secondary)}.activity-header .section-title{margin:0;font-size:11px}.activity-count{font-size:10px;font-weight:600;color:var(--text-tertiary);background:var(--bg-hover);padding:1px 7px}.activity-chevron{margin-left:auto;color:var(--text-tertiary);transition:transform .18s ease}.activity-chevron.open{transform:rotate(180deg)}.activity-list{display:flex;flex-direction:column;gap:22px;padding:6px 0 8px}.activity-empty{font-size:12px;color:var(--text-tertiary);padding:6px 0}.activity-row{display:flex;gap:14px;align-items:flex-start}.activity-avatar{width:30px;height:30px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--accent-subtle);color:var(--accent);font-size:13px;font-weight:700;letter-spacing:.02em;border-radius:50%;overflow:hidden}.activity-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.activity-content{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}.activity-meta{font-size:10px;color:var(--text-tertiary)}.activity-line{font-size:12px;color:var(--text-secondary);line-height:1.45}.activity-actor{color:var(--text-primary);font-weight:700}.activity-toggle{align-self:flex-start;margin-top:3px;padding:0;background:transparent;border:none;color:var(--accent);font-size:12px;font-weight:600;cursor:pointer}.activity-toggle:hover{text-decoration:underline}.activity-detail{margin:6px 0 0;padding:12px 14px;background:var(--bg-surface);border:1px solid var(--border-default);font-family:var(--font-sans);font-size:12px;line-height:1.5;color:var(--text-primary);white-space:pre-wrap;word-break:break-word;box-shadow:var(--shadow-sm)}.activity-diff{margin:8px 0 0;display:flex;flex-direction:column;gap:12px;padding:14px;background:var(--bg-surface);border:1.5px dotted var(--border-strong);border-radius:10px}.diff-row{display:block;padding:16px 20px;border-radius:10px}.diff-tag{display:block;margin-bottom:10px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.diff-val{display:block;font-family:var(--font-sans);font-size:14px;line-height:1.55;color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.diff-from{background:#f871711f}.diff-from .diff-tag{color:var(--red)}.diff-to{background:#4ade801f}.diff-to .diff-tag{color:var(--green)}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;background:#14100adb;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:40px;cursor:zoom-out;animation:fadeIn .15s ease}.lightbox-img{max-width:96vw;max-height:92vh;-o-object-fit:contain;object-fit:contain;box-shadow:0 20px 60px #00000080;cursor:default}.lightbox-close{position:fixed;top:18px;right:22px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.25);cursor:pointer;transition:background .15s ease}.lightbox-close:hover{background:#ffffff40}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.ss-editor-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:4000;background:#120e0ae6;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px 84px 24px 24px;animation:fadeIn .15s ease}.ss-editor-stage{max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center}.ss-editor-canvas{max-width:100%;max-height:calc(100vh - 48px);-o-object-fit:contain;object-fit:contain;background:#fff;border-radius:6px;box-shadow:0 20px 60px #00000080;touch-action:none}.ss-editor-canvas.tool-select{cursor:default}.ss-editor-canvas.tool-text{cursor:text}.ss-editor-canvas.tool-rect,.ss-editor-canvas.tool-arrow,.ss-editor-canvas.tool-pen{cursor:crosshair}.ss-toolbar{position:fixed;top:50%;right:16px;transform:translateY(-50%);display:flex;flex-direction:column;gap:6px;padding:8px;background:#fff;border-radius:12px;box-shadow:0 10px 30px #00000059}.ss-tool{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:background .15s ease,color .15s ease}.ss-tool:hover{background:var(--bg-hover);color:var(--text-primary)}.ss-tool.active{background:var(--accent-subtle);color:var(--accent)}.ss-tool.primary{background:var(--accent);color:#fff}.ss-tool.primary:hover{background:var(--accent-hover)}.ss-tool:disabled{opacity:.5;cursor:default}.ss-toolbar-spacer{height:1px;background:var(--border-default);margin:4px 0}.ss-color-wrap{position:relative;display:flex;justify-content:center}.ss-color-dot{width:26px;height:26px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--border-strong);cursor:pointer;margin:6px 0}.ss-palette{position:absolute;right:calc(100% + 10px);top:50%;transform:translateY(-50%);display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:8px;background:#fff;border-radius:10px;box-shadow:0 10px 30px #00000040}.ss-swatch{width:24px;height:24px;border-radius:50%;border:2px solid transparent;box-shadow:0 0 0 1px var(--border-default);cursor:pointer}.ss-swatch.active{border-color:var(--accent)}.attach-preview-overlay{flex-direction:column;cursor:default;padding:16px;gap:14px}.attach-preview-bar{width:min(96vw,1100px);display:flex;align-items:center;justify-content:space-between;gap:12px;color:#fff}.attach-preview-name{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attach-preview-actions{display:flex;align-items:center;gap:8px}.attach-preview-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;background:#ffffff24;color:#fff;border:1px solid rgba(255,255,255,.25);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease}.attach-preview-btn:hover{background:#ffffff47}.attach-preview-btn.icon{padding:8px}.attach-preview-body{display:flex;align-items:center;justify-content:center;max-width:96vw;max-height:82vh}.attach-preview-media{max-width:96vw;max-height:82vh;-o-object-fit:contain;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px #00000080;background:#000}.screenshot-img{width:100%;height:auto;max-height:180px;-o-object-fit:contain;object-fit:contain;transition:transform .3s cubic-bezier(.4,0,.2,1),object-fit .3s ease;transition:transform .3s cubic-bezier(.4,0,.2,1),object-fit .3s ease,-o-object-fit .3s ease}.screenshot-card.focused .screenshot-img{transform:scale(1.8);-o-object-fit:cover;object-fit:cover}.screenshot-indicator-bar{width:100%;height:4px;background:var(--accent);border-radius:2px;margin-top:10px}.meta-info-section{background:#fcf8ff;border:1px solid var(--border-default);border-radius:8px;padding:8px 16px;box-shadow:none;margin-top:20px}.meta-row{display:flex;align-items:center;padding:10px 0}.meta-row.border-none{border-bottom:none}.meta-label{width:130px;font-size:11px;font-weight:700;color:var(--text-secondary);flex-shrink:0}.meta-val-wrapper{flex:1;display:flex;align-items:center;justify-content:space-between;position:relative;gap:8px}.location-link{display:flex;align-items:center;gap:6px;color:var(--accent);font-weight:600;font-size:13px;text-decoration:none;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.location-link:hover{color:var(--accent-hover);text-decoration:underline}.location-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meta-select-flat{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;border:none;outline:none;color:var(--text-secondary);font-size:13px;font-weight:500;padding-right:24px;width:100%;cursor:pointer}.meta-select-chevron{position:absolute;right:0;pointer-events:none;color:var(--text-tertiary)}.btn-meta-action{background:transparent;border:none;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;padding:4px 8px;margin-left:-8px;border-radius:4px;transition:background .15s ease}.btn-meta-action:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-meta-link{background:transparent;border:none;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;padding:0}.btn-meta-link:hover{text-decoration:underline}.meta-inline-input{flex:1;border:1px solid var(--border-strong);border-radius:4px;padding:4px 8px;font-size:13px;outline:none}.meta-inline-input:focus{border-color:var(--accent)}.btn-save-loc{background:#10b981;color:#fff;border:none;border-radius:4px;padding:6px;display:flex;align-items:center;justify-content:center;cursor:pointer}.btn-save-loc:hover{background:#059669}.tech-info-expanded-details{background:var(--bg-hover);border-top:1px solid var(--bg-hover);margin:0 -16px -8px;padding:12px 16px;font-size:12px;font-family:var(--font-mono);color:var(--text-secondary);display:flex;flex-direction:column;gap:6px}.tech-detail-line{display:flex;gap:8px}.tech-detail-label{font-weight:700;color:var(--text-secondary);width:125px;flex-shrink:0}.tech-detail-val{word-break:break-all}.tags-list-wrapper{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:flex-start}.tag-pill{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-default);border-radius:4px;padding:2px 6px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:4px}.tag-remove-btn{background:transparent;border:none;color:var(--text-tertiary);font-size:14px;line-height:1;cursor:pointer;padding:0 2px}.tag-remove-btn:hover{color:#ef4444}.btn-add-tag-pill{background:transparent;border:1px dashed var(--border-strong);color:var(--text-secondary);border-radius:4px;padding:2px 6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-add-tag-pill:hover{background:var(--bg-hover);border-color:var(--text-tertiary);color:var(--text-primary)}.meta-inline-tag-input{border:1px solid var(--border-strong);border-radius:4px;padding:2px 6px;font-size:12px;outline:none;width:90px}.meta-inline-tag-input:focus{border-color:var(--accent)}.tags-section{margin-top:20px}.tp-tags-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.tp-tag-pill{display:inline-flex;align-items:center;gap:4px;background:var(--accent-subtle);color:var(--text-primary);border-radius:999px;padding:5px 14px;font-size:12px;font-weight:500;border:1px solid #f1edf6}.tp-tag-remove{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:0;margin-left:2px}.tp-tag-remove:hover{color:#ef4444}.tp-tag-add{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:transparent;border:1.5px dashed var(--border-strong);color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.tp-tag-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.tp-tag-input{border:1px solid var(--border-strong);border-radius:999px;padding:5px 14px;font-size:12px;outline:none;width:130px}.tp-tag-input:focus{border-color:var(--accent)}.tp-tag-input-wrap{position:relative;display:inline-block}.tp-tag-suggest{position:absolute;top:calc(100% + 4px);left:0;min-width:150px;max-height:180px;overflow-y:auto;display:flex;flex-direction:column;background:#fff;border:1px solid var(--border-default);border-radius:8px;box-shadow:0 6px 18px #0000001a;z-index:20;padding:4px}.tp-tag-suggest-item{text-align:left;background:transparent;border:none;cursor:pointer;padding:6px 10px;border-radius:6px;font-size:13px;color:var(--text-primary)}.tp-tag-suggest-item:hover{background:var(--accent-subtle);color:var(--accent)}.assignee-wrapper{justify-content:flex-start;gap:12px}.assignee-avatar{width:24px;height:24px;flex-shrink:0;border-radius:50%;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;background:var(--accent-subtle);color:var(--accent);font-size:12px;font-weight:700}.assignee-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.assignee-select{width:auto;padding-right:0;font-size:13px;font-weight:500;color:var(--text-primary)}.comments-section{margin-top:32px}.comments-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.comments-title-label{font-size:11px;font-weight:700;color:var(--text-secondary);letter-spacing:.05em}.btn-comments-log-link{background:transparent;border:none;color:var(--accent);font-size:12px;font-weight:600;cursor:pointer;padding:0}.btn-comments-log-link:hover{text-decoration:underline}.comment-form-container{background:#fff;border:1px solid var(--border-default);border-radius:8px;padding:12px;box-shadow:0 1px 3px #0000000d;margin-bottom:16px}.comment-textarea{width:100%;border:none;outline:none;resize:vertical;font-size:13px;color:var(--text-primary);background:transparent;margin-bottom:8px;line-height:1.5}.comment-actions-bar{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border-subtle);padding-top:8px}.comment-actions-left{display:flex;gap:8px}.btn-comment-add{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:6px 16px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s ease}.btn-comment-add:hover:not(:disabled){background:var(--accent-hover)}.btn-comment-add:disabled{background:var(--accent-subtle);color:var(--accent-subtle);cursor:not-allowed}.btn-comment-cancel{background:transparent;border:none;color:var(--text-secondary);padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;border-radius:6px;transition:background .15s ease}.btn-comment-cancel:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-comment-cancel:disabled{opacity:.5;cursor:default}.comment-actions-right{display:flex;align-items:center;gap:6px}.all-users-toggle-label{font-size:12px;color:var(--text-secondary);font-weight:600}.comments-list{display:flex;flex-direction:column;gap:6px}.premium-comment{display:flex;gap:12px;background:#fff;border:1px solid var(--border-default);border-radius:8px;padding:12px;box-shadow:0 1px 2px #00000005}.comment-user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-subtle);color:var(--accent);font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--accent-subtle)}.comment-content-block{flex:1}.comment-meta-row{display:flex;align-items:center;gap:8px;margin-bottom:2px}.comment-user-name{font-size:12px;font-weight:700;color:var(--text-primary)}.comment-timestamp{font-size:11px;color:var(--text-tertiary)}.comment-text-body{font-size:13px;color:var(--text-secondary);line-height:1.5;white-space:pre-wrap;word-break:break-word;margin-bottom:12px}.comment-composer{position:relative;background:#fff;border:1px solid var(--border-default);border-radius:8px;padding:12px;box-shadow:0 1px 3px #0000000d;margin-bottom:16px}.comment-composer .comment-actions-bar{justify-content:flex-start;gap:8px}.comment-reply-box,.comment-content-block>.comment-composer{margin-top:10px;margin-bottom:0}.mention-dropdown{display:flex;flex-direction:column;border:1px solid var(--border-default);border-radius:8px;background:#fff;box-shadow:0 6px 18px #0000001a;overflow:hidden;margin-bottom:8px}.mention-option{display:flex;align-items:center;gap:8px;padding:7px 10px;background:transparent;border:none;cursor:pointer;font-size:13px;color:var(--text-primary);text-align:left}.mention-option:hover,.mention-option.active{background:var(--accent-subtle)}.mention-avatar{width:22px;height:22px;flex-shrink:0;border-radius:50%;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;background:var(--accent-subtle);color:var(--accent);font-size:10px;font-weight:700}.mention-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.mention-tag{color:var(--accent);font-weight:600;background:var(--accent-subtle);border-radius:4px;padding:0 3px}.btn-comment-attach{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:transparent;border:1px solid var(--border-default);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.btn-comment-attach:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--border-strong)}.composer-attach-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.pending-attach{display:inline-flex;align-items:center;gap:5px;max-width:200px;padding:3px 8px;border-radius:6px;background:var(--bg-hover);font-size:12px;color:var(--text-secondary)}.pending-attach-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pending-attach button{display:inline-flex;background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:0}.pending-attach button:hover{color:#ef4444}.comment-attachments{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 12px}.attach-chips{display:flex;flex-wrap:wrap;gap:8px}.attach-chip{display:inline-flex;align-items:center;max-width:200px;background:var(--bg-hover);border-radius:8px;overflow:hidden}.attach-chip-main{display:inline-flex;align-items:center;gap:6px;min-width:0;padding:6px 4px 6px 10px;background:transparent;border:none;cursor:pointer;color:var(--text-secondary);font-size:13px;font-family:inherit}.attach-chip-main:hover{color:var(--accent)}.attach-chip-main svg{flex-shrink:0}.attach-chip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attach-chip-x{display:inline-flex;align-items:center;justify-content:center;padding:6px 8px;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;flex-shrink:0}.attach-chip-x:hover{color:#ef4444}.attach-wrap{position:relative;display:inline-flex}.attach-remove{position:absolute;top:-7px;right:-7px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#111827;color:#fff;border:2px solid #fff;cursor:pointer;padding:0;opacity:0;transition:opacity .15s ease}.attach-wrap:hover .attach-remove{opacity:1}.attach-remove:hover{background:#ef4444}.comment-attach-img{display:block;width:88px;height:88px;border-radius:8px;overflow:hidden;border:1px solid var(--border-default);padding:0;background:none;cursor:pointer}.comment-attach-img img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.comment-attach-video-tile{position:relative;width:120px;height:88px;border-radius:8px;overflow:hidden;border:1px solid var(--border-default);padding:0;background:#000;cursor:pointer}.comment-attach-video-tile video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.attach-play-badge{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;background:#00000040}.attach-play-badge svg{background:#0000008c;border-radius:50%;padding:6px;width:32px;height:32px}.comment-attach-file{display:inline-flex;align-items:center;gap:6px;max-width:220px;padding:5px 8px;border-radius:5px;border:1px solid var(--border-default);background:#fcf8ff;color:var(--text-secondary);font-size:10px;font-weight:500;text-decoration:none;cursor:pointer;font-family:inherit}.comment-attach-file:hover{border-color:var(--accent);color:var(--accent)}.comment-attach-file span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-reactions{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.reaction-pill{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:999px;border:1px solid var(--border-default);background:#fff;cursor:pointer;font-size:12px;line-height:1.6;transition:background .15s ease,border-color .15s ease}.reaction-pill:hover{border-color:var(--border-strong)}.reaction-pill.reacted{background:var(--accent-subtle);border-color:var(--accent)}.reaction-emoji{font-size:13px}.reaction-count{font-weight:600;color:var(--text-secondary)}.reaction-pill.reacted .reaction-count{color:var(--accent)}.reaction-add-wrap{position:relative}.emoji-picker{position:absolute;bottom:100%;left:0;margin-bottom:6px;display:flex;gap:2px;padding:6px;background:#fff;border:1px solid var(--border-default);border-radius:10px;box-shadow:0 6px 18px #0000001f;z-index:10}.emoji-choice{background:transparent;border:none;cursor:pointer;font-size:18px;line-height:1;padding:4px;border-radius:6px;transition:background .12s ease}.emoji-choice:hover{background:var(--bg-hover)}.comment-row-actions{display:flex;gap:14px;margin-top:6px;align-items:center}.comment-action-link{display:inline-flex;align-items:center;gap:4px;background:transparent;border:none;padding:0;cursor:pointer;font-size:12px;font-weight:600;color:var(--text-tertiary);transition:color .15s ease}.comment-action-link:hover{color:var(--accent)}.comment-action-link.danger:hover{color:#ef4444}.comment-replies{display:flex;flex-direction:column;gap:10px;margin-top:12px;padding-left:14px;border-left:2px solid var(--border-default)}.premium-comment.is-reply{background:var(--bg-subtle, #faf9fc);box-shadow:none;padding:10px}.comments-empty{font-size:13px;color:var(--text-tertiary);padding:10px 2px}.ai-badge-section{background:#fff;border:1px solid var(--border-default);border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000000d;margin-top:16px;display:flex;flex-direction:column;align-items:flex-start}.label-hint{color:var(--text-tertiary);font-weight:400;text-transform:none;letter-spacing:0}.color-swatches{display:flex;flex-wrap:wrap;gap:10px}.color-swatch{width:26px;height:26px;border:2px solid transparent;cursor:pointer;padding:0;transition:transform .12s ease,box-shadow .12s ease}.color-swatch:hover{transform:scale(1.12)}.color-swatch.selected{border-color:var(--bg-surface);box-shadow:0 0 0 2px var(--text-primary)}.feedback-row{display:flex;align-items:center;gap:12px;padding:10px 8px;border-radius:8px;transition:background .12s ease}.feedback-row:hover{background:var(--bg-hover, #f3f4f6)}.feedback-num{flex-shrink:0;min-width:30px;height:26px;padding:0 7px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;color:#fff;font-size:12px;font-weight:600}.feedback-title{flex:1;font-size:14px;color:var(--text-primary)}.feedback-move{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;color:var(--accent, #2563eb);font-size:13px;font-weight:600;white-space:nowrap}.feedback-move:hover{text-decoration:underline}.feedback-row .feedback-move{opacity:0}.feedback-row:hover .feedback-move{opacity:1}.gt-menu{display:none;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;border-radius:var(--radius-sm)}.gt-menu:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-backdrop{display:none}@media (max-width: 1024px){.global-topbar{padding:10px 20px}.topbar{padding:12px 20px}.page-content{padding:20px}}@media (max-width: 768px){.gt-menu{display:inline-flex}.sidebar{transform:translate(-100%);transition:transform .25s ease;z-index:40;box-shadow:var(--shadow-md)}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:39}.app-main{margin-left:0}.global-topbar{padding:10px 12px;gap:8px}.gt-divider,.gt-profile-info{display:none}.topbar{padding:10px 12px;gap:8px}.topbar h1{font-size:16px}.page-content{padding:14px 12px}.page-header{flex-direction:column;align-items:stretch;gap:12px}.page-header-actions{flex-wrap:wrap;gap:8px}.user-search{flex:1;min-width:0}.archive-head{flex-direction:column;align-items:stretch;gap:10px}.archive-search{width:100%}.task-panel,.task-panel.expanded{width:100vw;max-width:100vw;padding:0 14px 16px}.modal{width:100%}.bulk-bar{left:12px;right:12px;transform:none;width:auto;justify-content:center;flex-wrap:wrap}.kanban-column{width:84vw;max-width:300px}}@media (max-width: 480px){.gt-project-btn span{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal,.modal-lg{padding:18px}}.task-panel-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:50}@media (min-width: 769px){.task-panel.expanded{top:50%;left:50%;right:auto;bottom:auto;transform:translate(-50%,-50%);width:min(1200px,94vw);height:90vh;max-height:90vh;border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}}.tp-detail-grid,.tp-detail-main,.tp-detail-side{display:contents}@media (min-width: 769px){.task-panel.expanded .tp-detail-grid{display:grid;grid-template-columns:minmax(0,1fr) 530px;gap:24px;align-items:start}.task-panel.expanded .tp-tabs,.task-panel.expanded .tp-section-label{display:none}.task-panel.expanded .tp-detail-main,.task-panel.expanded .tp-detail-side{display:block;min-width:0}.task-panel.expanded .tp-detail-side{background:var(--bg-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:16px;margin-top:-50px}.task-panel.expanded .tp-detail-side .task-panel-section:first-child{margin-top:0}}.stat-card{position:relative;display:flex;flex-direction:row;align-items:center;gap:14px;padding:18px 20px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:0 1px 2px #1018280a;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #10182814}.stat-body{display:flex;flex-direction:column;gap:6px;min-width:0}.stat-label{padding-top:0;margin:0}.stat-value{font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1;margin:0}.stat-icon{box-sizing:border-box;width:40px;height:40px;padding:10px;border-radius:12px;flex-shrink:0}.stat-icon.color-blue{background:#2170e41f;color:#2170e4}.stat-icon.color-red{background:#dc26261f;color:#dc2626}.stat-icon.color-green{background:#15a34a1f;color:#15a34a}.stat-icon.color-amber{background:#d977061f;color:#d97706}.stat-icon.color-accent{background:#2170e41f;color:#2170e4}.chart-card{box-shadow:0 1px 2px #1018280a}.chart-header h3{font-size:15px;font-weight:650;letter-spacing:-.01em}.analytics-tabs{gap:6px;padding-bottom:14px;margin-bottom:20px;border-bottom:1px solid var(--border-default)}.notif-wrap{position:relative;display:inline-flex}.notif-bell{position:relative}.notif-badge{position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#dc2626;color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center;box-shadow:0 0 0 2px var(--bg-surface, #fff)}.notif-menu{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-width:calc(100vw - 24px);background:var(--bg-elevated, #fff);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:60;overflow:hidden}.notif-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;font-weight:650;font-size:14px;border-bottom:1px solid var(--border-subtle)}.notif-mark-all{display:inline-flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;color:var(--accent, #2563eb);font-size:12px;font-weight:600}.notif-mark-all:hover{text-decoration:underline}.notif-list{max-height:420px;overflow-y:auto}.notif-empty{padding:28px 14px;text-align:center;color:var(--text-tertiary);font-size:13px}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background .12s ease}.notif-item:hover{background:var(--bg-hover, #f3f4f6)}.notif-item.unread{background:#2170e40d}.notif-dot{width:7px;height:7px;border-radius:50%;background:var(--accent, #2563eb);margin-top:6px;flex-shrink:0}.notif-item:not(.unread) .notif-body{margin-left:17px}.notif-body{flex:1;min-width:0}.notif-title{font-size:13px;font-weight:600;color:var(--text-primary)}.notif-msg{font-size:12px;color:var(--text-secondary);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-time{font-size:11px;color:var(--text-tertiary);margin-top:3px}.notif-del{background:none;border:none;cursor:pointer;color:var(--text-tertiary);padding:2px;opacity:0;flex-shrink:0}.notif-item:hover .notif-del{opacity:1}.notif-del:hover{color:#dc2626}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:none}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-sm)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.slide-in-right{animation:slideInRight .2s ease forwards}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.ai-pulse{animation:pulse 2s ease-in-out infinite}
