*,: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:Plus Jakarta Sans,Noto Sans JP,system-ui,sans-serif;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:JetBrains Mono,ui-monospace,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}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.block{display:block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.break-all{word-break:break-all}.border{border-width:1px}.uppercase{text-transform:uppercase}.outline{outline-style:solid}.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)}:root{--bg: #f4f5fb;--bg-grad-a: #eef0fb;--bg-grad-b: #f7f4fc;--panel: #ffffff;--panel-2: #fafaff;--panel-3: #f2f3fb;--ink: #1d2030;--muted: #6b7088;--muted-2: #9499ad;--line: #e6e8f2;--line-soft: #eef0f7;--accent: #6366f1;--accent-2: #818cf8;--accent-dim: #4f46e5;--accent-soft: #eef0ff;--accent-glow: rgba(99, 102, 241, .18);--teal: #14b8a6;--amber: #f59e0b;--rose: #f43f5e;--blue: #3b82f6;--green: #10b981;--purple: #8b5cf6;--yellow: #eab308;--radius: 14px;--radius-sm: 9px;--shadow-sm: 0 1px 2px rgba(29, 32, 48, .04), 0 1px 3px rgba(29, 32, 48, .06);--shadow: 0 4px 16px rgba(40, 44, 80, .08);--shadow-lg: 0 24px 60px rgba(40, 44, 80, .18)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh}body{font-family:Inter,Noto Sans JP,system-ui,sans-serif;background:radial-gradient(820px 540px at 88% -8%,var(--bg-grad-a),transparent 60%),radial-gradient(700px 520px at -5% 108%,var(--bg-grad-b),transparent 55%),var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}.mono{font-family:JetBrains Mono,monospace}.display{font-family:Plus Jakarta Sans,sans-serif}.shell{display:flex;min-height:100vh}.sidebar{width:246px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--line);padding:20px 14px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 20px}.brand-mark{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;color:#fff;font-weight:800;font-family:Plus Jakarta Sans;box-shadow:0 6px 18px var(--accent-glow);font-size:18px}.brand-name{font-family:Plus Jakarta Sans;font-weight:800;font-size:17px;letter-spacing:-.4px}.brand-sub{font-size:10px;color:var(--muted-2);letter-spacing:1.6px;text-transform:uppercase;font-weight:600}.nav-label{font-size:10px;letter-spacing:1.3px;text-transform:uppercase;color:var(--muted-2);padding:14px 10px 8px;font-weight:700}.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--muted);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s;margin-bottom:2px;-webkit-user-select:none;-moz-user-select:none;user-select:none;text-decoration:none}.nav-item:hover{background:var(--panel-3);color:var(--ink)}.nav-item.active{background:var(--accent-soft);color:var(--accent-dim);font-weight:600}.nav-ico{width:18px;height:18px;flex-shrink:0}.nav-item.active .nav-ico{color:var(--accent)}.client-nav{overflow-y:auto;flex:1;margin:0 -4px;padding:0 4px}.client-nav::-webkit-scrollbar{width:6px}.client-nav::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}.cn-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--muted);transition:all .15s;text-decoration:none}.cn-item:hover{background:var(--panel-3);color:var(--ink)}.cn-item.active{background:var(--accent-soft);color:var(--accent-dim)}.cn-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.cn-item.cn-drop{box-shadow:inset 0 2px 0 var(--accent)}.cn-folder{margin-bottom:2px}.cn-folder-head{display:flex;align-items:center;gap:4px;padding:6px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.cn-folder-head:hover{background:var(--panel-3)}.cn-folder-toggle{display:inline-flex;cursor:pointer;color:var(--muted-2)}.cn-chev-open{transform:rotate(-90deg)}.cn-folder-name{flex:1;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cn-folder-actions{display:none;gap:2px}.cn-folder-head:hover .cn-folder-actions{display:flex}.cn-mini{border:none;background:transparent;color:var(--muted);cursor:pointer;padding:2px;border-radius:4px;display:grid;place-items:center}.cn-mini:hover{background:var(--line);color:var(--ink)}.cn-folder-body{padding-left:6px}.cn-empty{font-size:11px;color:var(--muted-2);padding:4px 10px}.cn-dropzone{font-size:11px;color:var(--accent-dim);border:1px dashed var(--accent-2);border-radius:7px;padding:6px 8px;margin:4px 0;text-align:center;background:var(--accent-soft)}.cn-dropzone.cn-drop{background:#e9ebff;border-color:var(--accent)}.cn-add-folder{display:flex;align-items:center;gap:6px;width:100%;border:1px dashed var(--line);background:transparent;color:var(--muted);font-size:12px;font-weight:600;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;margin-top:6px}.cn-add-folder:hover{border-color:var(--accent-2);color:var(--accent-dim)}.mobile-bar,.sidebar-backdrop{display:none}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:14px;padding:14px 28px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.page-title{font-family:Plus Jakarta Sans;font-size:20px;font-weight:800;letter-spacing:-.5px}.page-crumb{font-size:12.5px;color:var(--muted);margin-top:1px}.spacer{flex:1}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:var(--radius-sm);font-family:Inter;font-size:13.5px;font-weight:600;cursor:pointer;border:1px solid var(--line);transition:all .15s;white-space:nowrap;background:var(--panel);color:var(--ink);box-shadow:var(--shadow-sm)}.btn:hover{border-color:var(--accent-2);color:var(--accent-dim)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-dim));color:#fff;border:none;box-shadow:0 4px 14px var(--accent-glow)}.btn-primary:hover{filter:brightness(1.06);color:#fff}.btn-ghost{background:var(--panel-2)}.btn-sm{padding:6px 11px;font-size:12.5px}.btn svg{width:16px;height:16px}.btn-danger{color:var(--rose);border-color:var(--rose)}.content{padding:24px 28px 60px}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.stat:after{content:"";position:absolute;right:-18px;top:-18px;width:72px;height:72px;border-radius:50%;opacity:.1;background:var(--sc, var(--accent))}.stat-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:700}.stat-value{font-family:Plus Jakarta Sans;font-size:27px;font-weight:800;margin-top:6px;letter-spacing:-.6px}.stat-meta{font-size:12px;color:var(--muted);margin-top:3px}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}.seg{display:inline-flex;background:var(--panel-3);border:1px solid var(--line);border-radius:var(--radius-sm);padding:3px}.seg button{padding:7px 14px;border:none;background:transparent;color:var(--muted);font-family:Inter;font-size:13px;font-weight:600;border-radius:6px;cursor:pointer;transition:all .15s}.seg button.on{background:var(--panel);color:var(--accent-dim);box-shadow:var(--shadow-sm)}.select,.input{background:var(--panel);border:1px solid var(--line);color:var(--ink);padding:8px 12px;border-radius:var(--radius-sm);font-family:Inter;font-size:13.5px;outline:none;box-shadow:var(--shadow-sm)}.select:focus,.input:focus{border-color:var(--accent)}.input::-moz-placeholder{color:var(--muted-2)}.input::placeholder{color:var(--muted-2)}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.panel-head{display:flex;align-items:center;gap:12px;padding:15px 20px;border-bottom:1px solid var(--line-soft)}.panel-title{font-family:Plus Jakarta Sans;font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px}.gantt-wrap{overflow-x:auto}.gantt-wrap::-webkit-scrollbar{height:9px}.gantt-wrap::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}.gantt{min-width:900px}.gantt-timeline{display:grid;border-bottom:1px solid var(--line)}.gantt-corner{padding:10px 16px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:700;border-right:1px solid var(--line);position:sticky;left:0;background:var(--panel);z-index:5}.gantt-day{padding:7px 0;text-align:center;font-size:10.5px;color:var(--muted);border-right:1px solid var(--line-soft)}.gantt-day.weekend{background:var(--panel-3)}.gantt-day .dnum{font-family:JetBrains Mono;font-size:13px;color:var(--ink);font-weight:600;display:block}.gantt-day.today{background:var(--accent-soft)}.gantt-day.today .dnum{color:var(--accent-dim)}.gantt-group-label{padding:9px 16px;font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);background:var(--panel-3);border-bottom:1px solid var(--line-soft);border-top:1px solid var(--line-soft);position:sticky;left:0}.gantt-row{display:grid;border-bottom:1px solid var(--line-soft);min-height:44px}.gantt-row:hover{background:var(--panel-2)}.gantt-rowlabel{padding:8px 16px;border-right:1px solid var(--line);position:sticky;left:0;background:var(--panel);z-index:4;display:flex;flex-direction:column;justify-content:center}.gantt-row:hover .gantt-rowlabel{background:var(--panel-2)}.grl-task{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.grl-sub{font-size:11px;color:var(--muted);margin-top:1px}.gantt-track{grid-column:2 / -1;position:relative}.gantt-bar{position:absolute;top:9px;height:26px;border-radius:7px;display:flex;align-items:center;padding:0 10px;font-size:11.5px;font-weight:600;cursor:pointer;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .12s,filter .12s;white-space:nowrap;color:#fff}.gantt-bar:hover{transform:translateY(-1px);filter:brightness(1.05)}.gantt-bar .bar-prog{position:absolute;left:0;top:0;bottom:0;background:#ffffff47}.gantt-bar span{position:relative;z-index:2}.gantt-handle{position:absolute;top:0;bottom:0;width:9px;cursor:ew-resize;z-index:3;touch-action:none}.gantt-handle-l{left:0;border-top-left-radius:7px;border-bottom-left-radius:7px}.gantt-handle-r{right:0;border-top-right-radius:7px;border-bottom-right-radius:7px}.gantt-bar:hover .gantt-handle{background:#ffffff73}.gantt-bar{touch-action:none}.deliver-marker{position:absolute;top:0;bottom:0;width:2px;background:var(--rose);z-index:6}.deliver-marker:before{content:"◆";position:absolute;top:-2px;left:-5px;color:var(--rose);font-size:11px}.ttable{width:100%;border-collapse:collapse}.ttable th{text-align:left;padding:11px 16px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;border-bottom:1px solid var(--line)}.ttable td{padding:12px 16px;font-size:13.5px;border-bottom:1px solid var(--line-soft);vertical-align:middle}.ttable tr:hover td{background:var(--panel-2)}.ttable tr:last-child td{border-bottom:none}.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:600;border:none;cursor:pointer}.chip-dot{width:6px;height:6px;border-radius:50%}.st-todo{background:#eef0f5;color:#6b7088}.st-todo .chip-dot{background:#6b7088}.st-progress{background:#e7f0fe;color:var(--blue)}.st-progress .chip-dot{background:var(--blue)}.st-review{background:#fef3e2;color:#d97706}.st-review .chip-dot{background:var(--amber)}.st-done{background:#e3f7ef;color:#059669}.st-done .chip-dot{background:var(--green)}.pri{font-size:11px;font-weight:700;padding:2px 7px;border-radius:5px}.pri-high{background:#fee4e8;color:#e11d48}.pri-mid{background:#fef3e2;color:#d97706}.pri-low{background:#eef0f5;color:#6b7088}.bill-tag{display:inline-flex;align-items:center;gap:5px;font-family:JetBrains Mono;font-size:12.5px;font-weight:600;color:var(--accent-dim)}.avatar{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.avatar-stack{display:flex}.avatar-stack .avatar{margin-left:-7px;border:2px solid var(--panel)}.avatar-stack .avatar:first-child{margin-left:0}.row-actions{display:flex;gap:6px;opacity:0;transition:opacity .15s}.ttable tr:hover .row-actions{opacity:1}.icon-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--line);background:var(--panel);color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:all .15s}.icon-btn:hover{background:var(--panel-3);color:var(--ink)}.icon-btn.danger:hover{color:var(--rose);border-color:var(--rose)}.icon-btn svg{width:15px;height:15px}.project-header{display:flex;align-items:center;gap:18px;padding:22px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:18px;box-shadow:var(--shadow-sm)}.project-emoji{width:66px;height:66px;border-radius:16px;display:grid;place-items:center;font-size:32px;flex-shrink:0;background:linear-gradient(135deg,var(--accent-soft),#fff);border:1px solid var(--line)}.project-info{flex:1;min-width:0}.project-name{font-family:Plus Jakarta Sans;font-size:23px;font-weight:800;letter-spacing:-.5px;line-height:1.2}.project-meta{display:flex;gap:18px;margin-top:8px;flex-wrap:wrap;color:var(--muted);font-size:13px}.project-meta strong{color:var(--ink);font-weight:700}.project-stats{display:flex;gap:10px}.pstat{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:12px 18px;text-align:center;min-width:76px}.pstat-num{font-family:Plus Jakarta Sans;font-size:24px;font-weight:800;letter-spacing:-.5px}.pstat-label{font-size:11px;color:var(--muted);margin-top:2px;font-weight:600}.flow-section{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;margin-bottom:18px;box-shadow:var(--shadow-sm)}.flow-title{font-size:12.5px;color:var(--muted);font-weight:600;margin-bottom:14px}.flow{display:flex;align-items:stretch;gap:4px;overflow-x:auto;padding-bottom:4px}.flow-node{flex-shrink:0;min-width:96px;padding:12px 10px;border-radius:12px;background:var(--panel-2);border:1px solid var(--line);text-align:center;cursor:pointer;transition:all .15s;text-decoration:none;color:var(--ink)}.flow-node:hover{border-color:var(--accent-2);transform:translateY(-2px);box-shadow:var(--shadow)}.flow-node.active{border-color:var(--accent);background:var(--accent-soft)}.flow-node .icon{font-size:22px}.flow-node .label{font-size:12.5px;font-weight:700;margin-top:5px}.flow-node .sub{font-size:10.5px;color:var(--muted);margin-top:2px}.flow-arrow{display:flex;align-items:center;color:var(--muted-2);font-size:16px;flex-shrink:0}.workflow-tabs{display:flex;gap:4px;margin-bottom:18px;border-bottom:1px solid var(--line)}.wf-tab{padding:11px 16px;font-size:13.5px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;display:inline-flex;align-items:center;gap:7px;background:none;border-top:none;border-left:none;border-right:none}.wf-tab:hover{color:var(--ink)}.wf-tab.active{color:var(--accent-dim);border-bottom-color:var(--accent)}.wf-tab .badge{background:var(--accent-soft);color:var(--accent-dim);font-size:11px;font-weight:700;padding:1px 7px;border-radius:10px}.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.lane{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius);padding:10px;min-height:220px;transition:all .15s}.lane.drop-hover{border-color:var(--accent);background:#e9ebff}.lane-header{display:flex;align-items:center;justify-content:space-between;padding:4px 6px 12px}.lane-title{font-size:12.5px;font-weight:700;display:flex;align-items:center;gap:7px}.lane-dot{width:9px;height:9px;border-radius:50%}.lane-count{font-size:11px;color:var(--muted);background:var(--panel);border:1px solid var(--line);padding:1px 8px;border-radius:10px;font-weight:600}.topic-card{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:12px;margin-bottom:9px;cursor:grab;transition:all .15s;position:relative;box-shadow:var(--shadow-sm)}.topic-card:hover{border-color:var(--accent-2);transform:translateY(-1px);box-shadow:var(--shadow)}.topic-card.dragging{opacity:.4}.topic-name{font-size:13.5px;font-weight:700;line-height:1.35;margin-bottom:7px;padding-right:24px}.topic-meta-row{font-size:11px;color:var(--muted);margin-bottom:9px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.topic-stage-select{width:100%;font-size:12px;padding:6px 8px;border-radius:7px;border:1px solid var(--line);background:var(--panel-2);color:var(--ink);font-family:Inter;cursor:pointer;outline:none}.topic-stage-select:focus{border-color:var(--accent)}.add-topic{text-align:center;padding:10px;font-size:12.5px;color:var(--muted);border:1px dashed var(--line);border-radius:9px;cursor:pointer;transition:all .15s;font-weight:600}.add-topic:hover{border-color:var(--accent-2);color:var(--accent-dim);background:var(--panel)}.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.proj-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm)}.proj-card:hover{border-color:var(--accent-2);transform:translateY(-2px);box-shadow:var(--shadow)}.proj-card.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.pc-name{font-family:Plus Jakarta Sans;font-size:15px;font-weight:700;margin-bottom:4px}.pc-bar{height:6px;background:var(--panel-3);border-radius:3px;overflow:hidden;margin:12px 0 8px}.pc-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:3px}.perm-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:7px;font-size:11.5px;font-weight:700}.role-admin{background:#ede9fe;color:#6d28d9}.role-member{background:#e7f0fe;color:#1d4ed8}.role-client{background:#e3f7ef;color:#047857}.role-guest{background:#fef3e2;color:#b45309}.member-row{display:flex;align-items:center;gap:12px;padding:13px 14px;border:1px solid var(--line);border-radius:11px;margin-bottom:10px;background:var(--panel-2)}.member-info{flex:1;min-width:0}.member-name{font-size:14px;font-weight:700}.member-mail{font-size:12px;color:var(--muted)}.share-box{background:var(--panel-2);border:1px solid var(--line);border-radius:11px;padding:14px}.share-link{display:flex;gap:8px;align-items:center}.share-link input{flex:1;font-family:JetBrains Mono;font-size:12px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1d203066;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:grid;place-items:center;padding:20px;animation:fade .18s}@keyframes fade{0%{opacity:0}}.modal{background:var(--panel);border:1px solid var(--line);border-radius:18px;width:100%;max-width:540px;box-shadow:var(--shadow-lg);animation:pop .2s cubic-bezier(.2,.8,.3,1.2);max-height:90vh;overflow-y:auto}@keyframes pop{0%{transform:scale(.95) translateY(10px);opacity:0}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--line-soft)}.modal-title{font-family:Plus Jakarta Sans;font-size:18px;font-weight:800}.modal-body{padding:22px 24px}.modal-foot{padding:16px 24px;border-top:1px solid var(--line-soft);display:flex;justify-content:flex-end;gap:10px}.field{margin-bottom:16px}.field-label{display:block;font-size:11.5px;font-weight:700;color:var(--muted);margin-bottom:7px;text-transform:uppercase;letter-spacing:.4px}.field input,.field select,.field textarea{width:100%;background:var(--panel-2);border:1px solid var(--line);color:var(--ink);padding:10px 12px;border-radius:var(--radius-sm);font-family:Inter;font-size:14px;outline:none}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);background:var(--panel)}.field textarea{resize:vertical;min-height:70px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.check-row{display:flex;align-items:center;gap:9px;padding:11px 13px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer}.check-row input{width:auto}.assignee-pick{display:flex;flex-wrap:wrap;gap:8px}.ap-chip{display:flex;align-items:center;gap:7px;padding:6px 11px 6px 7px;border:1px solid var(--line);border-radius:20px;cursor:pointer;font-size:13px;transition:all .15s;background:var(--panel)}.ap-chip:hover{border-color:var(--accent-2)}.ap-chip.sel{border-color:var(--accent);background:var(--accent-soft)}.bill-summary{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:22px}.bill-total-card{background:linear-gradient(140deg,var(--accent-soft),var(--panel));border:1px solid var(--accent-2);border-radius:var(--radius);padding:22px}.bill-total-val{font-family:Plus Jakarta Sans;font-size:38px;font-weight:800;letter-spacing:-1px;margin:8px 0;color:var(--accent-dim)}.empty{text-align:center;padding:50px 20px;color:var(--muted)}.empty svg{width:44px;height:44px;margin-bottom:12px;opacity:.4}.toast{position:fixed;bottom:26px;left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:12px 20px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;box-shadow:var(--shadow-lg);z-index:200;animation:toastin .25s;display:flex;align-items:center;gap:9px}@keyframes toastin{0%{transform:translate(-50%) translateY(20px);opacity:0}}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-card{background:var(--panel);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:34px 32px}.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:26px}.auth-title{font-family:Plus Jakarta Sans;font-size:20px;font-weight:800;margin-bottom:4px}.auth-sub{font-size:13px;color:var(--muted);margin-bottom:22px}.auth-err{background:#fee4e8;color:#e11d48;border-radius:var(--radius-sm);padding:10px 13px;font-size:13px;margin-bottom:16px}.auth-ok{background:#e3f7ef;color:#047857;border-radius:var(--radius-sm);padding:10px 13px;font-size:13px;margin-bottom:16px}.toggle{position:relative;width:42px;height:24px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--line);border-radius:24px;cursor:pointer;transition:.2s}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(18px)}.loading-screen{min-height:100vh;display:grid;place-items:center;color:var(--muted);font-size:14px}@media (max-width: 1100px){.stat-row,.kanban{grid-template-columns:repeat(2,1fr)}.bill-summary{grid-template-columns:1fr}.project-header{flex-wrap:wrap}}@media (max-width: 860px){.stat-row{grid-template-columns:repeat(2,1fr)}.kanban{grid-template-columns:1fr}.content{padding:16px 14px 60px}.topbar{padding:12px 14px}.page-title{font-size:17px}.mobile-bar{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:45;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.mobile-bar .brand-name{font-size:15px}.hamburger{width:38px;height:38px;border-radius:9px;border:1px solid var(--line);background:var(--panel);display:grid;place-items:center;cursor:pointer;color:var(--ink);flex-shrink:0}.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:60;transform:translate(-100%);transition:transform .22s ease;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#1d203066;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:55}.topbar{top:58px}.bill-summary,.field-row{grid-template-columns:1fr}.project-header,.project-stats{flex-wrap:wrap}}
