*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}.logo-for-dark{display:block}.logo-for-light,[data-theme=light] .logo-for-dark{display:none}[data-theme=light] .logo-for-light{display:block}:root{--bg: #121212;--s1: #181818;--s2: #1f1f1f;--s3: #282828;--s4: #333333;--s5: #3d3d3d;--sidebar-bg: #000000;--bd: rgba(255,255,255,.06);--bd2: rgba(255,255,255,.1);--bd3: rgba(255,255,255,.16);--bd4: rgba(255,255,255,.26);--text: #ffffff;--dim: rgba(255,255,255,.7);--muted: #b3b3b3;--faint: rgba(255,255,255,.22);--pink: #e01d4e;--pink-dim: rgba(224,29,78,.12);--pink-bd: rgba(224,29,78,.3);--green: #1db954;--green-dim: rgba(29,185,84,.12);--green-bd: rgba(29,185,84,.26);--blue: #4e9cf5;--blue-dim: rgba(78,156,245,.11);--blue-bd: rgba(78,156,245,.26);--yellow: #f5a623;--yellow-dim: rgba(245,166,35,.11);--yellow-bd: rgba(245,166,35,.26);--orange: #f97316;--orange-dim: rgba(249,115,22,.11);--red: #f04747;--red-dim: rgba(240,71,71,.11);--red-bd: rgba(240,71,71,.26);--purple: #b197fc;--purple-dim: rgba(177,151,252,.11);--purple-bd: rgba(177,151,252,.26);--cyan: #22d3ee;--hover: rgba(255,255,255,.08);--active: rgba(255,255,255,.14);--sidebar-w: 240px;--panel-w: 448px;--topbar-h: 64px;--page-px: 32px;--card-p: 20px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-7: 32px;--sp-8: 40px;--sp-9: 48px;--sp-10:64px;--r-xs: 3px;--r-sm: 4px;--r: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-2xl: 24px;--r-full:9999px;--radius: var(--r-md);--radius-sm: var(--r-sm);--radius-xs: var(--r-xs);--radius-lg: var(--r-lg);--radius-xl: var(--r-xl);--font: "Circular Std",-apple-system,BlinkMacSystemFont,"Helvetica Neue","Segoe UI",sans-serif;--display: "Circular Std",-apple-system,BlinkMacSystemFont,"Helvetica Neue","Segoe UI",sans-serif;--mono: "SF Mono","Fira Code","Cascadia Code",monospace;--shadow-xs: 0 2px 4px rgba(0,0,0,.5);--shadow-sm: 0 4px 12px rgba(0,0,0,.5);--shadow: 0 8px 24px rgba(0,0,0,.6);--shadow-md: 0 16px 40px rgba(0,0,0,.65);--shadow-lg: 0 24px 56px rgba(0,0,0,.7);--shadow-xl: 0 40px 80px rgba(0,0,0,.75);--surface: var(--s2);--surface-2: var(--s3);--surface-3: var(--s4);--overlay: rgba(0,0,0,.8);--text-dim: var(--dim);--text-muted: var(--muted);--text-sub: var(--faint)}[data-theme=light]{--bg: #f8f7f5;--s1: #f0ede9;--s2: #e6e3de;--s3: #dad6d0;--s4: #ccc8c2;--s5: #bfbbb5;--sidebar-bg: #f0ede9;--bd: rgba(0,0,0,.07);--bd2: rgba(0,0,0,.12);--bd3: rgba(0,0,0,.18);--bd4: rgba(0,0,0,.28);--text: #171614;--dim: rgba(23,22,20,.7);--muted: rgba(23,22,20,.5);--faint: rgba(23,22,20,.22);--pink: #c4143c;--pink-dim: rgba(196,20,60,.09);--pink-bd: rgba(196,20,60,.22);--hover: rgba(0,0,0,.04);--active: rgba(0,0,0,.076);--overlay: rgba(0,0,0,.45);--shadow-xs: 0 1px 2px rgba(0,0,0,.06);--shadow-sm: 0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);--shadow: 0 4px 12px rgba(0,0,0,.09),0 1px 4px rgba(0,0,0,.05);--shadow-md: 0 8px 24px rgba(0,0,0,.1),0 2px 8px rgba(0,0,0,.06);--shadow-lg: 0 20px 48px rgba(0,0,0,.13),0 4px 16px rgba(0,0,0,.08);--shadow-xl: 0 32px 72px rgba(0,0,0,.16),0 8px 24px rgba(0,0,0,.1);--green: #16a34a;--green-dim: rgba(22,163,74,.1);--green-bd: rgba(22,163,74,.22);--blue: #2563eb;--blue-dim: rgba(37,99,235,.1);--blue-bd: rgba(37,99,235,.22);--yellow: #b45309;--yellow-dim: rgba(180,83,9,.1);--yellow-bd: rgba(180,83,9,.22);--orange: #c2410c;--orange-dim: rgba(194,65,12,.1);--red: #dc2626;--red-dim: rgba(220,38,38,.1);--red-bd: rgba(220,38,38,.22);--purple: #6d28d9;--purple-dim: rgba(109,40,217,.1);--purple-bd: rgba(109,40,217,.22);--cyan: #0891b2;--sidebar-bg: var(--s1);--surface: var(--s2);--surface-2: var(--s3);--surface-3: var(--s4);--text-dim: var(--dim);--text-muted: var(--muted);--text-sub: var(--faint)}[data-theme=light] .badge-not_started,[data-theme=light] .badge-todo{background:#0000000a}html,body,#root{height:100%;overflow:hidden}html{background:var(--bg)}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;font-feature-settings:"kern" 1,"liga" 1}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:var(--font);font-size:inherit;color:inherit}input,textarea,select{font-family:var(--font)}img{display:block}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#fff3;border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}:focus-visible{outline:2px solid var(--pink);outline-offset:2px;border-radius:var(--r-xs)}:focus:not(:focus-visible){outline:none}.btn,.nav-item,.task-row,.board-card,.glass,.card,.dropdown-item,.theme-option,.topbar-icon-btn,.topbar-user-pill,.topbar-search-inp,.panel-tab,.sp-card{transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease,transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease}.input,.inp{transition:border-color .14s ease,box-shadow .14s ease,background-color .14s ease}.pbar-fill{transition:width .4s cubic-bezier(.22,1,.36,1)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 20px;height:36px;font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent;border-radius:var(--r-full);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;flex-shrink:0}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.38;cursor:not-allowed;transform:none!important;pointer-events:none}.btn-primary{background:var(--pink);color:#fff;border-color:transparent;box-shadow:0 2px 12px #e01d4e59}.btn-primary:hover:not(:disabled){background:#f02060;transform:scale(1.03);box-shadow:0 4px 20px #e01d4e73}.btn-secondary{background:transparent;color:var(--text);border:1.5px solid rgba(255,255,255,.3)}.btn-secondary:hover:not(:disabled){border-color:#fff;color:#fff}.btn-ghost{background:transparent;color:var(--muted);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--hover);color:var(--text);border-color:transparent}.btn-icon{padding:0;width:36px;height:36px;border-radius:var(--r-full);background:transparent;border-color:transparent;text-transform:none;letter-spacing:0}.btn-icon:hover:not(:disabled){background:var(--hover)}.btn-danger{background:var(--red-dim);color:var(--red);border-color:var(--red-bd)}.btn-danger:hover:not(:disabled){background:#f047472e}.btn-sm{height:32px;padding:0 16px;font-size:12px}.btn-xs{height:26px;padding:0 12px;font-size:11px;font-weight:700;gap:4px}.btn-sm.btn-icon{width:32px;height:32px}.btn-xs.btn-icon{width:26px;height:26px}.input,.inp{width:100%;height:40px;padding:0 14px;background:var(--s3);border:1.5px solid transparent;border-radius:var(--r-md);color:var(--text);font-size:13px;outline:none}.input:hover:not(:focus),.inp:hover:not(:focus){background:var(--s4)}.input:focus,.inp:focus{border-color:var(--pink);box-shadow:0 0 0 3px var(--pink-dim);background:var(--s3)}.input::placeholder,.inp::placeholder{color:var(--muted)}textarea.input,textarea.inp{height:auto;min-height:80px;padding:10px 14px;resize:vertical;line-height:1.6}select.input,select.inp{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.36)' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}[data-theme=light] select.input,[data-theme=light] select.inp{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='rgba(23,22,20,0.40)' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}.label,.lbl{display:block;margin-bottom:6px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.card{background:var(--s1);border-radius:var(--r-md);border:none}.card:hover{background:var(--s3)}.glass{background:var(--s2);border-radius:var(--r-md);border:none}.glass:hover{background:var(--s3);transform:translateY(-4px);box-shadow:var(--shadow)}.panel{background:var(--s1);border-left:1px solid var(--bd)}.sp-card{background:var(--s1);border-radius:var(--r-lg);padding:16px;cursor:pointer;border:none;position:relative}.sp-card:hover{background:var(--s3);transform:translateY(-4px);box-shadow:var(--shadow-md)}.sp-card-art{width:100%;aspect-ratio:1/1;border-radius:var(--r-md);overflow:hidden;margin-bottom:12px;box-shadow:0 8px 24px #00000080;position:relative}.sp-card-art-action{position:absolute;bottom:8px;right:8px;width:44px;height:44px;border-radius:50%;background:var(--pink);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 16px #0006;opacity:0;transform:translateY(6px);transition:opacity .2s ease,transform .2s cubic-bezier(.34,1.56,.64,1)}.sp-card:hover .sp-card-art-action{opacity:1;transform:translateY(0)}.sp-card-title{font-size:14px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px}.sp-card-sub{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.5}.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border-radius:var(--r-full);border:1px solid}.pill-pink{background:var(--pink-dim);color:var(--pink);border-color:var(--pink-bd)}.pill-yellow{background:var(--yellow-dim);color:var(--yellow);border-color:var(--yellow-bd)}.pill-cyan{background:#22d3ee17;color:var(--cyan);border-color:#22d3ee38}.pill-white{background:var(--hover);color:var(--dim);border-color:var(--bd2)}.pill-green{background:var(--green-dim);color:var(--green);border-color:var(--green-bd)}.pill-red{background:var(--red-dim);color:var(--red);border-color:var(--red-bd)}[data-theme=light] .pill-cyan{color:#0e7490}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--r-full);font-size:11px;font-weight:700;white-space:nowrap;border:none;letter-spacing:.02em}.badge-todo,.badge-not_started{background:#ffffff14;color:var(--muted)}.badge-doing,.badge-in_progress{background:var(--blue-dim);color:var(--blue)}.badge-review,.badge-awaiting_review{background:var(--yellow-dim);color:var(--yellow)}.badge-done,.badge-approved,.badge-client_approved{background:var(--green-dim);color:var(--green)}.badge-blocked,.badge-changes_requested{background:var(--red-dim);color:var(--red)}.badge-client_review{background:var(--purple-dim);color:var(--purple)}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--sidebar-bg);border-right:none;display:flex;flex-direction:column;height:100vh;overflow:hidden}.sidebar-section-header{padding:20px 16px 8px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.nav-item{display:flex;align-items:center;gap:12px;padding:0 12px;height:40px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;color:var(--muted);cursor:pointer;border:none;background:none;width:100%;text-align:left;-webkit-user-select:none;user-select:none;position:relative;flex-shrink:0}.nav-item:hover{color:var(--text);background:transparent}.nav-item.active{color:var(--text);font-weight:700;background:transparent}.nav-item .nav-count{margin-left:auto;font-size:11px;font-weight:700;color:#fff;background:var(--pink);padding:2px 7px;border-radius:var(--r-full);line-height:1.4;min-width:20px;text-align:center}.nav-item.active .nav-count{background:var(--pink)}.project-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.app-topbar{height:var(--topbar-h);background:#121212eb;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:10px;padding:0 var(--page-px);flex-shrink:0;position:sticky;top:0;z-index:200}[data-theme=light] .app-topbar{background:#f8f7f5eb}.topbar-nav-btn{width:32px;height:32px;border-radius:50%;background:#000000b3;border:none;display:flex;align-items:center;justify-content:center;color:var(--text);flex-shrink:0;cursor:pointer;transition:background .15s}.topbar-nav-btn:hover{background:#000000e6}.topbar-nav-btn:disabled{opacity:.4;cursor:default}.topbar-search-wrap{position:relative;flex:1;max-width:340px}.topbar-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none;display:flex}.topbar-search-inp{width:100%;background:var(--s3);border:none;border-radius:var(--r-full);padding:0 16px 0 40px;height:40px;font-size:14px;color:var(--text);outline:none;font-weight:500;transition:background .15s,box-shadow .15s}.topbar-search-inp::placeholder{color:var(--muted)}.topbar-search-inp:focus{background:var(--s4);box-shadow:0 0 0 2px var(--pink)}.search-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--s2);border:1px solid var(--bd2);border-radius:14px;box-shadow:0 16px 48px #00000080;z-index:500;overflow:hidden;padding:6px;animation:slideUp .15s cubic-bezier(.22,1,.36,1)}.search-group-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:6px 10px 4px}.search-result-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 12px;border-radius:8px;background:none;border:none;cursor:pointer;font-size:13.5px;font-weight:500;color:var(--text);transition:background .1s}.search-result-item:hover{background:var(--s3)}.topbar-user-pill{display:flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;border-radius:var(--r-full);background:var(--s3);border:none;cursor:pointer;flex-shrink:0}.topbar-user-pill:hover{background:var(--s4)}.topbar-user-avatar{width:28px;height:28px;border-radius:50%;background:var(--pink);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden}.topbar-user-name{font-size:13px;font-weight:700;color:var(--text)}.topbar-icon-btn{width:36px;height:36px;border-radius:50%;background:#000000b3;border:none;display:flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0;cursor:pointer;transition:background .15s,color .15s}.topbar-icon-btn:hover{background:#000000e6;color:var(--text)}.page-hero{padding:0 var(--page-px) 24px;margin-top:calc(-1 * var(--topbar-h));padding-top:calc(var(--topbar-h) + 24px);position:relative}.page-hero-title{font-size:52px;font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--text);font-family:var(--display)}.page-hero-sub{font-size:14px;color:var(--muted);margin-top:8px;font-weight:500}.shelf-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--page-px);margin-bottom:16px}.shelf-title{font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--text)}.shelf-link{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);cursor:pointer;background:none;border:none}.shelf-link:hover{color:var(--text);text-decoration:underline}.shelf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;padding:0 var(--page-px)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease both}.modal{background:var(--s2);border:1px solid var(--bd2);border-radius:var(--r-xl);width:100%;max-width:560px;max-height:92vh;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);animation:slideUp .22s cubic-bezier(.22,1,.36,1) both}.modal-lg{max-width:680px}.modal-hd{padding:24px 28px 16px;border-bottom:1px solid var(--bd);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-body{padding:20px 28px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.modal-ft{padding:16px 28px;border-top:1px solid var(--bd);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}.task-panel{position:fixed;right:0;top:0;bottom:0;width:var(--panel-w);background:var(--s1);border-left:1px solid var(--bd);display:flex;flex-direction:column;z-index:400;box-shadow:var(--shadow-xl);animation:slideIn .22s cubic-bezier(.22,1,.36,1)}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideUp{0%{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}.panel-hd{padding:12px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:6px;flex-shrink:0;min-height:52px;background:var(--s1)}.panel-top{flex-shrink:0;border-bottom:1px solid var(--bd);background:var(--s1)}.panel-breadcrumb{display:flex;align-items:center;gap:5px;padding:14px 24px 0;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}.panel-breadcrumb .proj-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.panel-title-input{display:block;width:100%;font-size:22px;font-weight:800;letter-spacing:-.03em;font-family:var(--display);color:var(--text);line-height:1.3;background:none;border:none;outline:none;resize:none;padding:8px 24px 12px}.panel-section{padding:20px 24px;border-bottom:1px solid var(--bd)}.panel-section:last-child{border-bottom:none}.panel-tabs{display:flex;border-top:1px solid var(--bd);padding:0 20px;flex-shrink:0;gap:0}.panel-tab{display:flex;align-items:center;gap:5px;padding:11px 12px;font-size:13px;font-weight:500;background:none;border:none;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;letter-spacing:.01em;transition:color .15s}.panel-tab:hover{color:var(--dim)}.panel-tab.active{color:var(--text);font-weight:700;border-bottom-color:var(--green)}.panel-tab .tab-badge{font-size:10px;font-weight:700;padding:2px 6px;border-radius:var(--r-full);background:var(--s3);color:var(--muted);line-height:1.4}.panel-tab.active .tab-badge{background:#1db95426;color:var(--green)}.panel-tab .tab-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.panel-tab-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.panel-scroll{flex:1;overflow-y:auto}.meta-table{border-top:1px solid var(--bd)}.meta-row{display:flex;align-items:flex-start;min-height:48px;border-bottom:1px solid var(--bd)}.meta-label{width:124px;flex-shrink:0;display:flex;align-items:center;gap:6px;padding:12px 8px 12px 24px;font-size:12px;font-weight:500;color:var(--muted)}.meta-value{flex:1;padding:10px 24px 10px 0;display:flex;align-items:center;flex-wrap:wrap;gap:4px;font-size:13px}.comment-feed{flex:1;overflow-y:auto;padding:20px 20px 12px;display:flex;flex-direction:column;gap:4px}.comment-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--muted);font-size:13px;padding-bottom:40px}.chat-msg{display:flex;align-items:flex-end;gap:10px;padding:3px 0}.chat-msg-body{display:flex;flex-direction:column;gap:3px;max-width:78%}.chat-msg-meta{display:flex;align-items:center;gap:6px;padding:0 2px}.chat-author{font-size:12px;font-weight:700;color:var(--text)}.chat-time{font-size:11px;color:var(--muted)}.client-badge{font-size:10px;color:var(--purple);background:#8b5cf61a;padding:1px 6px;border-radius:8px;border:1px solid rgba(139,92,246,.2)}.chat-bubble{font-size:13.5px;line-height:1.65;color:var(--text);background:var(--s3);border-radius:0 14px 14px;padding:10px 14px;word-break:break-word}.chat-bubble.own{background:#ff2d7824;border-radius:14px 14px 0}.chat-bubble p{margin:0;padding:0}.chat-bubble p+p{margin-top:6px}.chat-bubble strong{font-weight:700}.chat-bubble em{font-style:italic}.mention-highlight{color:var(--blue);font-weight:600}.chat-bubble-footer{display:flex;align-items:center;gap:6px;padding:0 2px;min-height:18px}.chat-msg-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s}.chat-msg:hover .chat-msg-actions{opacity:1}.chat-msg-actions button{background:none;border:none;cursor:pointer;padding:3px 5px;border-radius:4px;color:var(--muted);display:flex;align-items:center;transition:color .15s,background .15s}.chat-msg-actions button:hover{color:var(--text);background:var(--s4)}.comment-composer{flex-shrink:0;display:flex;align-items:flex-end;gap:10px;padding:12px 16px 14px;border-top:1px solid var(--bd);background:var(--s1)}.composer-input-wrap{flex:1;display:flex;align-items:flex-end;gap:8px;background:var(--s3);border:1px solid var(--bd2);border-radius:22px;padding:6px 6px 6px 14px;transition:border-color .15s}.composer-input-wrap:focus-within{border-color:var(--bd3)}.composer-send-btn{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:background .15s,color .15s,transform .1s}.composer-send-btn:not(:disabled){background:var(--pink);color:#fff}.composer-send-btn:not(:disabled):hover{background:#e0256b}.composer-send-btn:not(:disabled):active{transform:scale(.9)}.composer-send-btn:disabled{cursor:default}.rich-editor{display:flex;flex-direction:column;width:100%}.rich-toolbar{display:flex;align-items:center;gap:2px;padding:6px 10px;border-bottom:1px solid var(--bd);flex-shrink:0;flex-wrap:wrap}.rich-tool{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:none;border:none;cursor:pointer;color:var(--muted);transition:background .12s,color .12s}.rich-tool:hover{background:var(--s3);color:var(--text)}.rich-tool.active{background:var(--s3);color:var(--pink)}.rich-toolbar-sep{width:1px;height:18px;background:var(--bd);margin:0 4px;flex-shrink:0}.rich-mini-toolbar{display:flex;align-items:center;gap:2px;padding:2px 4px 4px;border-bottom:1px solid var(--bd);animation:slideUp .12s cubic-bezier(.22,1,.36,1)}.bubble-tool{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:5px;background:none;border:none;cursor:pointer;color:var(--muted);transition:background .1s,color .1s}.bubble-tool:hover{background:var(--s3);color:var(--text)}.bubble-tool.active{color:var(--pink)}.rich-editor .tiptap{flex:1;min-height:0;outline:none;font-size:13.5px;line-height:1.75;color:var(--text);font-family:var(--font);padding:10px 14px;word-break:break-word}.rich-editor.compact .tiptap{padding:8px 4px 8px 0;font-size:14px}.rich-editor .tiptap p{margin:0 0 4px}.rich-editor .tiptap p:last-child{margin-bottom:0}.rich-editor .tiptap ul,.rich-editor .tiptap ol{padding-left:20px;margin:4px 0}.rich-editor .tiptap li{margin:2px 0}.rich-editor .tiptap strong{font-weight:700;color:var(--text)}.rich-editor .tiptap em{font-style:italic}.rich-editor .tiptap s{opacity:.6}.rich-link{color:var(--green);text-decoration:underline;text-underline-offset:2px;cursor:pointer;transition:opacity .15s}.rich-link:hover{opacity:.8}.rich-editor .tiptap .is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--muted);pointer-events:none;float:left;height:0}.link-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:600;background:var(--s2);border:1px solid var(--bd2);border-radius:10px;padding:10px;min-width:260px;box-shadow:0 12px 36px #00000073;animation:slideUp .15s cubic-bezier(.22,1,.36,1)}.link-popover-input{width:100%;background:var(--s3);border:1px solid var(--bd2);border-radius:7px;padding:7px 10px;font-size:13px;color:var(--text);outline:none;font-family:var(--font);transition:border-color .15s}.link-popover-input:focus{border-color:var(--pink)}.link-popover-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--r-full);font-size:12px;font-weight:600;cursor:pointer;background:var(--pink);border:none;color:#fff;transition:background .15s}.link-popover-btn.ghost{background:var(--s3);color:var(--muted)}.link-popover-btn:hover{opacity:.88}.list-view{display:flex;flex-direction:column;height:100%;overflow:hidden}.list-header{padding:24px var(--page-px) 16px;background:var(--bg);flex-shrink:0}.list-cols{display:grid;grid-template-columns:1fr 140px 116px 96px 136px;padding:0 var(--page-px);border-bottom:1px solid var(--bd);background:var(--bg)}.list-col-hd{padding:12px 12px 12px 0;font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}.list-body{flex:1;overflow-y:auto}.task-group-header{display:flex;align-items:center;gap:6px;padding:0 var(--page-px);min-height:38px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);cursor:pointer;background:var(--bg);-webkit-user-select:none;user-select:none;position:sticky;top:0;z-index:1}.task-group-header:hover{background:var(--hover)}.task-row{display:grid;grid-template-columns:1fr 140px 116px 96px 136px;padding:0 var(--page-px);border-bottom:1px solid var(--bd);cursor:pointer;min-height:64px;align-items:center;background:transparent}.task-row:hover{background:var(--hover)}.task-row:hover .task-row-actions{opacity:1}.task-row-cell{padding:0 12px 0 0;display:flex;align-items:center}.task-row-name{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;color:var(--text);min-width:0;padding:16px 0}.task-row-name span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-row-actions{opacity:0;display:flex;align-items:center;gap:4px;flex-shrink:0}.add-task-row{display:flex;align-items:center;gap:10px;padding:0 var(--page-px);min-height:52px;font-size:13.5px;color:var(--muted);cursor:pointer;border-bottom:1px solid var(--bd)}.add-task-row:hover{background:var(--hover);color:var(--dim)}.add-task-input{background:transparent;border:none;padding:8px 4px;font-size:14px;font-weight:500;color:var(--text);outline:none;width:100%}.board-wrap{display:flex;gap:12px;overflow-x:auto;padding:24px var(--page-px) 32px;align-items:flex-start;flex:1}.board-col{flex-shrink:0;width:300px;background:var(--s1);border-radius:var(--r-xl);overflow:hidden;border:none}.board-col-hd{padding:14px 16px;display:flex;align-items:center;justify-content:space-between}.board-drop{min-height:64px;padding:8px;display:flex;flex-direction:column;gap:6px}.board-drop.drag-over{background:var(--pink-dim);border-radius:var(--r)}.board-card{background:var(--s2);border:none;border-radius:var(--r-md);padding:14px 16px;cursor:pointer}.board-card:hover{background:var(--s3);transform:translateY(-2px);box-shadow:var(--shadow)}.board-card.dragging{opacity:.4}.rich-content p{margin:0;padding:0}.rich-content p+p{margin-top:6px}.rich-content ul,.rich-content ol{margin:4px 0;padding-left:20px}.pbar{height:4px;background:#ffffff1a;border-radius:var(--r-full);overflow:hidden}.pbar-fill{height:100%;border-radius:var(--r-full)}.av{border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0;letter-spacing:.3px;-webkit-user-select:none;user-select:none;overflow:hidden}.dropdown{position:absolute;z-index:300;background:var(--s3);border:none;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);min-width:180px;padding:4px;overflow:hidden}.dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 12px;font-size:13px;font-weight:500;color:var(--dim);cursor:pointer;width:100%;background:none;border:none;text-align:left;border-radius:var(--r-sm)}.dropdown-item:hover{background:var(--s4);color:var(--text)}.dropdown-item.danger{color:var(--red)}.dropdown-item.danger:hover{background:var(--red-dim)}.dropdown-sep{height:1px;background:var(--bd);margin:4px -4px;width:calc(100% + 8px)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;padding:80px 32px;flex:1}.empty-icon{width:64px;height:64px;border-radius:var(--r-xl);background:var(--s3);display:flex;align-items:center;justify-content:center;color:var(--muted);margin-bottom:8px}.empty-state h3{font-size:20px;font-weight:800;color:var(--text);letter-spacing:-.02em}.empty-state p{font-size:14px;color:var(--muted);max-width:280px;line-height:1.6}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .45s cubic-bezier(.22,1,.36,1) both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .15s ease both}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .65s linear infinite;display:inline-flex}@keyframes landing-gradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes landing-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}@keyframes landing-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.divider{height:1px;background:var(--bd);margin:0}.approval-pending{border-color:var(--yellow-bd)!important}.approval-approved{border-color:var(--green-bd)!important;background:#1db9540a!important}.approval-changes{border-color:var(--red-bd)!important;background:#f047470a!important}.theme-option{flex:1;padding:14px 10px;border-radius:var(--r-md);cursor:pointer;border:2px solid var(--bd2);background:var(--s2);text-align:center;transition:background .14s,border-color .14s}.theme-option:hover{background:var(--s3);border-color:var(--bd3)}.theme-option.selected{border-color:var(--pink);background:var(--pink-dim)}.accent-swatch{width:36px;height:36px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:box-shadow .14s,border-color .14s}.accent-swatch.selected{border-color:var(--s1);box-shadow:0 0 0 3px currentColor}.section-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.stat-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;padding:16px var(--page-px)}.stat-card{background:var(--s1);border-radius:var(--r-lg);padding:16px 18px}.stat-card-val{font-size:28px;font-weight:800;color:var(--text);letter-spacing:-.03em;line-height:1}.stat-card-lbl{font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;margin-top:4px}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:56px;background:#000;border-top:1px solid rgba(255,255,255,.06);z-index:500;flex-shrink:0;padding:0 0 env(safe-area-inset-bottom,0);padding-bottom:calc(4px + env(safe-area-inset-bottom,0))}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;cursor:pointer;padding:6px 4px 2px;color:#ffffff80;transition:color .15s;-webkit-tap-highlight-color:transparent;position:relative}.bottom-nav-item.active{color:#fff}.bottom-nav-item.active .bottom-nav-icon:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--green)}.bottom-nav-icon{position:relative;display:flex}.bottom-nav-badge{position:absolute;top:-4px;right:-6px;min-width:15px;height:15px;border-radius:8px;background:var(--pink);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid #000}.bottom-nav-label{font-size:9px;font-weight:600;letter-spacing:.02em}.dash-hero-title{font-size:48px;font-weight:800;letter-spacing:-.04em;line-height:1;font-family:var(--display);color:var(--text)}.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 16px 20px}.quick-grid-item{display:flex;align-items:center;gap:10px;background:var(--s3);border-radius:6px;padding:0 12px;height:52px;overflow:hidden;cursor:pointer;font-size:13px;font-weight:700;color:var(--text);border:none;text-align:left;-webkit-tap-highlight-color:transparent;transition:background .12s}.quick-grid-item:active{background:var(--s4)}.quick-grid-icon{width:40px;height:40px;border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.mobile-topbar-title{position:absolute;left:50%;transform:translate(-50%);font-size:15px;font-weight:700;color:var(--text);white-space:nowrap;pointer-events:none;z-index:1;max-width:46%;text-overflow:ellipsis;overflow:hidden}@media (max-width:768px){:root{--sidebar-w:260px;--panel-w:100vw;--page-px:16px;--topbar-h:52px}.sidebar{position:fixed;left:calc(-1 * var(--sidebar-w));z-index:600;transition:left .28s cubic-bezier(.22,1,.36,1);width:var(--sidebar-w);padding-bottom:env(safe-area-inset-bottom,0)}.sidebar.open{left:0}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;z-index:599;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.sidebar-overlay.open{display:block}.bottom-nav{display:flex}.app-topbar{padding:0 12px;height:var(--topbar-h);background:#121212db;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.topbar-search-wrap,.topbar-nav-btn,.topbar-user-name{display:none}.topbar-user-pill{padding:4px;gap:0;background:transparent;border:none}.topbar-icon-btn{width:36px;height:36px}.content-area,.content-scroll{padding-bottom:calc(56px + env(safe-area-inset-bottom,0))}.task-panel{top:auto;bottom:0;height:93dvh;border-radius:20px 20px 0 0;border-top:1px solid var(--bd2);border-left:none;background:var(--s1);animation:sheetUp .32s cubic-bezier(.22,1,.36,1)}.task-panel:before{content:"";display:block;width:36px;height:4px;background:#ffffff2e;border-radius:2px;margin:10px auto 0;flex-shrink:0;position:absolute;top:0;left:50%;transform:translate(-50%);z-index:1}.panel-hd{padding-top:18px}@keyframes sheetUp{0%{transform:translateY(100%);opacity:.6}to{transform:translateY(0);opacity:1}}.modal{position:fixed;bottom:0;left:0;right:0;top:auto;transform:none;border-radius:20px 20px 0 0;width:100%;max-width:100%;animation:sheetUp .3s cubic-bezier(.22,1,.36,1);padding-bottom:env(safe-area-inset-bottom,16px)}.modal-body{padding:16px 20px}.list-cols{display:none}.task-row{display:flex;flex-direction:column;align-items:flex-start;padding:10px 16px;min-height:auto;gap:0;border-bottom:none}.task-row+.task-row{border-top:1px solid var(--bd)}.task-row-name{font-size:13px;font-weight:500;padding:0 0 4px;gap:8px;width:100%}.task-row-cell{display:none}.task-row-mobile-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}.page-hero{padding:24px 16px 18px}.page-hero-title{font-size:28px}.dash-hero-title{font-size:36px!important}.stat-strip{grid-template-columns:1fr 1fr;gap:8px;padding:12px 16px}.stat-card{padding:14px;border-radius:10px}.stat-card-val{font-size:24px}.stat-card-lbl{font-size:10px}.shelf-grid{display:flex;overflow-x:auto;gap:10px;padding-bottom:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-left:16px;padding-right:16px}.shelf-grid::-webkit-scrollbar{display:none}.shelf-grid .sp-card{flex-shrink:0;width:148px;scroll-snap-align:start}.shelf-header{padding:0 16px;margin-bottom:10px}.shelf-title{font-size:18px;font-weight:800;letter-spacing:-.02em}.label{font-size:10px}.hide-mobile{display:none!important}.panel-tab{padding:10px 8px}.panel-breadcrumb{padding:10px 16px 0}.panel-title-input{padding:6px 16px 10px;font-size:18px}.meta-label{padding:8px 8px 8px 16px;width:104px;font-size:11px}.meta-value{padding:8px 16px 8px 0;font-size:13px}.rich-editor .tiptap{padding:8px 10px}.rich-toolbar{padding:4px 8px}.comment-composer{padding:10px 12px}}@media (min-width:769px){.hide-desktop,.bottom-nav{display:none!important}}[data-theme=light] .bottom-nav{background:#f8f7f5f5}.sp-card:hover .sp-card-actions{opacity:1!important}.content-area{flex:1;overflow:hidden;position:relative;display:flex;flex-direction:column}.content-scroll{flex:1;overflow-y:auto;margin-top:calc(-1 * var(--topbar-h));padding-top:0}@keyframes notif-slide-in{0%{opacity:0;transform:translate(120%)}to{opacity:1;transform:translate(0)}}@keyframes notif-progress{0%{width:100%}to{width:0%}}.notif-banner-enter{animation:notif-slide-in .28s cubic-bezier(.22,1,.36,1) both}.notif-banner-bar{animation:notif-progress 9s linear both}
