:root{--bg: #f1f5f9;--panel: #ffffff;--ink: #0f172a;--muted: #64748b;--line: #e2e8f0;--brand: #0ea5a4;--brand-d: #0d9488;--danger: #ef4444;--shadow: 0 1px 3px rgba(15, 23, 42, .08), 0 8px 24px rgba(15, 23, 42, .06);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ink)}.center{display:grid;place-items:center;height:100%}.muted{color:var(--muted)}.small{font-size:12px}.pad{padding:12px}.error{color:var(--danger);font-size:13px}.app{display:flex;flex-direction:column;height:100%}.topbar{height:62px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;background:linear-gradient(180deg,#143452,#0f2942);border-bottom:1px solid #0b2032;color:#fff;flex:none;z-index:20}.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;cursor:pointer}.brand.big{font-size:22px;color:var(--ink);flex-direction:column}.brand-name{display:flex;flex-direction:column;line-height:1.1;letter-spacing:.2px}.brand-name small{font-size:11px;font-weight:500;color:#7dd3c8;letter-spacing:.3px;margin-top:2px}.topbar-right{display:flex;align-items:center;gap:12px}.topbar .btn.ghost{color:#e2e8f0}.topbar .btn.ghost:hover{background:#ffffff1f}.lang-switch{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:6px 8px;font-size:13px;font-weight:600;cursor:pointer}.lang-switch option{color:#0f2942}.bell-btn{position:relative;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:38px;height:34px;border-radius:8px;cursor:pointer;font-size:16px}.bell-btn:hover{background:#fff3}.bell-badge{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:999px;padding:0 4px;display:grid;place-items:center;border:2px solid #0f2942}.notif-panel{position:fixed;top:0;left:0;height:100%;width:420px;max-width:92vw;background:var(--panel);z-index:31;box-shadow:8px 0 30px #0f172a26;display:flex;flex-direction:column}.notif-head{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--line)}.notif-head h3{margin:0}.notif-tabs{display:flex;gap:4px;padding:10px 12px;border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center}.notif-tabs button{border:none;background:transparent;padding:6px 10px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer}.notif-tabs button.active{background:#ecfeff;color:var(--brand-d)}.notif-markall{margin-left:auto;color:var(--brand-d)!important}.notif-list{flex:1;overflow:auto}.notif-group{padding:12px 16px 4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.notif-item{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line);position:relative}.notif-item.unread{background:#f0f9ff}.notif-item.mention{border-left:3px solid var(--brand)}.notif-av{flex:none;width:36px;height:36px;border-radius:50%;background:#1d9e75;color:#fff;display:grid;place-items:center;font-weight:700}.notif-body{min-width:0;flex:1}.notif-line{font-size:14px}.notif-line b{font-weight:700}.notif-snip{font-size:13px;color:#334155;background:#f8fafc;border:1px solid var(--line);border-radius:8px;padding:6px 9px;margin:5px 0}.notif-meta{margin-top:2px}.notif-dot{position:absolute;top:16px;right:14px;width:9px;height:9px;border-radius:50%;background:#3b82f6}@media (max-width: 760px){.notif-panel{width:100%}}.mode-badge{font-size:11px;padding:3px 9px;border-radius:999px;font-weight:600;background:#ecfeff;color:var(--brand-d);border:1px solid #a5f3fc}.mode-badge.local{background:#fef9c3;color:#854d0e;border-color:#fde68a}.mode-badge.azure{background:#e0f2fe;color:#075985;border-color:#7dd3fc}.main{flex:1;min-height:0;overflow:auto}.btn{border:1px solid var(--line);background:var(--panel);color:var(--ink);padding:9px 14px;border-radius:9px;font-weight:600;cursor:pointer;font-size:14px;transition:all .15s}.btn:hover{border-color:#cbd5e1}.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn.primary:hover{background:var(--brand-d)}.btn.ghost{background:transparent;border-color:transparent}.btn.ghost:hover{background:#f1f5f9}.btn.small{padding:5px 10px;font-size:13px}.btn.danger-outline{color:var(--danger);border-color:#fecaca;background:#fff}.btn.danger-outline:hover{background:#fef2f2}.btn:disabled{opacity:.6;cursor:default}.icon-btn{border:1px solid var(--line);background:#fff;width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:15px;line-height:1;display:grid;place-items:center}.icon-btn:hover{background:#f8fafc}.icon-btn.danger{color:var(--danger)}.auth-wrap{display:grid;place-items:center;height:100%}.auth-card{width:360px;background:var(--panel);padding:28px;border-radius:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px}.auth-card input{padding:11px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px}.auth-form{display:flex;flex-direction:column;gap:12px}.copyright{text-align:center;color:var(--muted);font-size:11px;line-height:1.5;padding:18px 12px;border-top:1px solid var(--line);margin-top:22px}.copyright b{color:var(--ink)}.auth-card .copyright{border-top:none;margin-top:8px;padding-bottom:0}.auth-wrap.embedded{height:auto}.auth-wrap.embedded .auth-card{box-shadow:0 12px 40px #0f29422e}.landing{min-height:100%;background:#fff;color:var(--ink);scroll-behavior:smooth}.lnav{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:12px 5vw;background:#0f2942eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff}.lnav .brand-name small{color:#7dd3c8}.lnav .btn.primary{text-decoration:none}.hero{display:grid;grid-template-columns:1.15fr .85fr;gap:32px;align-items:center;padding:64px 5vw;background:linear-gradient(160deg,#0f2942,#143452 60%,#0d9488 160%);color:#fff}.hero .eyebrow{font-size:13px;font-weight:700;letter-spacing:.5px;color:#7dd3c8;text-transform:uppercase}.hero h1{font-size:clamp(28px,4vw,46px);line-height:1.1;margin:10px 0 14px}.hero p{font-size:17px;line-height:1.6;color:#d7e3ee;max-width:620px}.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin:22px 0 18px}.btn.lg{padding:13px 22px;font-size:15px;text-decoration:none}.hero .btn.ghost{color:#fff;border-color:#ffffff59}.hero .btn.ghost:hover{background:#ffffff1f}.creds{display:flex;flex-direction:column;gap:4px;margin-top:10px}.cred{font-size:13.5px;color:#bfe9e4}.hero-art{display:flex;justify-content:center}.hero-art img{width:100%;max-width:380px;filter:drop-shadow(0 20px 40px rgba(0,0,0,.35))}.services{padding:64px 5vw;max-width:1200px;margin:0 auto}.services h2,.how h2,.login-copy h2{font-size:28px;margin:0 0 24px}.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}.svc-card{border:1px solid var(--line);border-radius:16px;padding:22px;background:#fff;box-shadow:var(--shadow);transition:transform .12s}.svc-card:hover{transform:translateY(-3px)}.svc-icon{font-size:30px;margin-bottom:8px}.svc-card h3{margin:0 0 6px;font-size:17px}.svc-card p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.55}.how{background:#f1f5f9;padding:64px 5vw}.how-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.2fr .8fr;gap:36px;align-items:center}.how ul{padding-left:18px;line-height:1.9;color:#334155}.how p{color:#334155;line-height:1.6;font-size:16px}.how-art{display:flex;flex-direction:column;align-items:center;gap:10px}.pinrow{display:flex;gap:14px}.pindot{width:54px;height:54px;border-radius:50%;color:#fff;font-weight:800;font-size:18px;display:grid;place-items:center;border:3px solid #fff;box-shadow:0 6px 16px #0003}.login-section{padding:64px 5vw;max-width:900px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}.login-copy p{color:var(--muted);font-size:16px;line-height:1.6}.landing-foot{background:#0f2942;color:#cbd5e1;text-align:center;padding:28px 5vw;line-height:1.7}.landing-foot b{color:#fff}@media (max-width: 820px){.hero,.how-inner,.login-section{grid-template-columns:1fr}.hero-art{order:-1}.hero-art img{max-width:240px}.how-art{margin-top:8px}}.google-btn-holder{display:flex;justify-content:center;min-height:44px}.btn.google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;background:#fff;border:1px solid #dadce0;color:#3c4043;font-weight:600;padding:11px}.btn.google:hover{background:#f8faff;border-color:#c6d2f0}.divider{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--line)}.container{max-width:1100px;margin:0 auto;padding:28px 22px}.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:22px}.page-head h1{margin:0;font-size:26px}.inline-form{display:flex;gap:8px;flex:1;max-width:560px}.inline-form input{flex:1;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);position:relative;overflow:hidden}.project-card{cursor:pointer;transition:transform .12s,box-shadow .12s}.project-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px #0f172a1f}.card-body{padding:18px}.card-body h3{margin:0 0 6px;font-size:17px}.project-card .card-body{padding-right:92px}.card-actions{position:absolute;top:10px;right:10px;display:flex;gap:6px;z-index:2}.card-actions .members-icon{opacity:1;background:#ecfeff;border-color:#a5f3fc;font-size:16px}.card-actions .members-icon:hover{background:#cffafe;border-color:var(--brand)}.card-actions .card-del{opacity:0}.project-card:hover .card-del{opacity:1}.empty{text-align:center;padding:60px 20px}.project-view{display:flex;height:100%}.sidebar{width:var(--sidebar-w, 30vw);min-width:300px;max-width:760px;flex:none;background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;height:100%}.sidebar-resizer{flex:none;width:7px;margin-left:-4px;cursor:col-resize;z-index:6;background:transparent;position:relative}.sidebar-resizer:before{content:"";position:absolute;top:0;right:3px;bottom:0;left:3px;border-radius:3px;transition:background .12s}.sidebar-resizer:hover:before{background:var(--brand)}body.resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}body.resizing iframe{pointer-events:none}.sidebar-head{padding:14px 16px 10px;border-bottom:1px solid var(--line)}.sidebar-head h2{margin:8px 0 0;font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-summary{display:flex;flex-wrap:wrap;gap:6px;padding:12px 14px}.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:5px 9px;border-radius:999px;border:1px solid var(--line);background:#fff;cursor:pointer}.chip .dot{width:9px;height:9px;border-radius:50%;background:var(--c)}.chip.active{border-color:var(--c);background:color-mix(in srgb,var(--c) 12%,#fff)}.chip b{font-weight:700}.sidebar-filters{display:flex;gap:8px;padding:0 14px 12px}.sidebar-filters .search{flex:1}.sidebar-filters input,.sidebar-filters select{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:13px;min-width:0}.task-list{flex:1;overflow:auto;border-top:1px solid var(--line)}.task-row{display:flex;gap:12px;padding:13px 16px;border-bottom:1px solid var(--line);cursor:pointer;align-items:flex-start}.task-row:hover{background:#f8fafc}.task-row.active{background:#ecfeff;box-shadow:inset 3px 0 0 var(--brand)}.task-row .num{flex:none;width:32px;height:32px;border-radius:8px;color:#fff;font-weight:700;font-size:13px;display:grid;place-items:center}.task-row-body{min-width:0}.task-row-title{font-weight:600;font-size:15px;line-height:1.3;white-space:normal;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.task-row-meta{font-size:12.5px;color:var(--muted);margin-top:3px}.sidebar-foot{padding:10px 14px;border-top:1px solid var(--line)}.table-view{flex:1;display:flex;flex-direction:column;min-width:0;height:100%;background:var(--panel)}.table-topbar{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--line);flex:none;flex-wrap:wrap}.tv-title{margin:0;font-size:17px;flex:1;min-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tv-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.tv-search{padding:7px 11px;border:1px solid var(--line);border-radius:8px;font-size:13px;width:200px;max-width:44vw}.view-toggle{display:inline-flex;border:1px solid var(--line);border-radius:9px;overflow:hidden}.view-toggle button{border:none;background:#fff;padding:7px 12px;font-size:13px;font-weight:600;cursor:pointer;color:var(--muted)}.view-toggle button.active{background:var(--brand);color:#fff}.plan-view-toggle{margin-right:10px}.tv-filterbar{display:flex;gap:6px;padding:10px 16px;border-bottom:1px solid var(--line);flex-wrap:wrap;flex:none}.task-table-wrap{flex:1;overflow:auto}.task-table{width:100%;border-collapse:collapse;font-size:14px}.task-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;text-align:left;font-size:12px;color:var(--muted);font-weight:700;padding:10px 12px;border-bottom:1px solid var(--line)}.task-table td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:top}.task-table tbody tr{cursor:pointer}.task-table tbody tr:hover{background:#f8fafc}.task-table tbody tr.active{background:#ecfeff;box-shadow:inset 3px 0 0 var(--brand)}.task-table .c-dot{width:34px;text-align:center}.task-table .c-id{width:60px;font-weight:700;color:var(--brand-d)}.task-table .c-title{font-weight:600;max-width:260px}.task-table .c-desc{color:var(--muted);max-width:380px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-table .c-list{white-space:nowrap;color:var(--ink);font-size:13px}.tdot{display:inline-block;width:13px;height:13px;border-radius:50%;vertical-align:middle}.tdot.ring{background:transparent!important;border:3px solid var(--c);box-sizing:border-box}.tv-foot{padding:10px 16px;border-top:1px solid var(--line);flex:none;display:flex;align-items:center;justify-content:space-between;gap:10px}.clear-filters{border:1px solid #fecaca;background:#fef2f2;color:var(--danger);border-radius:999px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer}.clear-filters:hover{background:#fee2e2}@media (max-width: 760px){.task-table .c-desc,.task-table .c-list{display:none}.tv-search{width:140px}.table-view{position:absolute;top:0;right:0;bottom:0;left:0}}.canvas-area{flex:1;display:flex;flex-direction:column;min-width:0;background:#e2e8f0}.canvas-toolbar{background:var(--panel);border-bottom:1px solid var(--line);padding:8px 12px;flex:none}.plan-tabs{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.tab{border:1px solid var(--line);background:#fff;padding:6px 12px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600}.tab.active{background:var(--brand);color:#fff;border-color:var(--brand)}.tab.add{border-style:dashed;color:var(--brand-d)}.tab.danger{color:var(--danger);border-color:#fecaca}.deck-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:8px}.deck-label{font-size:12px;font-weight:700;color:#0f2942;margin-right:2px}.deck-chip{display:inline-flex;align-items:center;border:1px solid var(--line);background:#fff;border-radius:999px;font-size:12px;font-weight:600;cursor:pointer;overflow:hidden}.deck-chip>button,.deck-chip.add,.deck-chip:not(.wrap){padding:5px 11px}.deck-chip.wrap{padding:0}.deck-chip .deck-pick{border:none;background:transparent;cursor:pointer;font:inherit;padding:5px 8px 5px 11px;color:inherit}.deck-chip .deck-pick b{margin-left:4px;color:var(--brand-d)}.deck-chip .deck-edit,.deck-chip .deck-del{border:none;background:transparent;cursor:pointer;color:#94a3b8;padding:5px 6px;font-size:11px}.deck-chip .deck-edit:hover{color:var(--brand-d)}.deck-chip .deck-del:hover{color:var(--danger)}.deck-chip.active{border-color:#0f2942;background:#0f2942;color:#fff}.deck-chip.active .deck-pick b{color:#5eead4}.deck-chip.add{border-style:dashed;color:var(--brand-d)}.active-deck-flag{position:absolute;top:14px;left:14px;z-index:5;background:#0f2942;color:#fff;font-size:12px;font-weight:600;padding:5px 12px;border-radius:999px;box-shadow:var(--shadow)}.canvas{flex:1;position:relative;min-height:0}.canvas-scroll{position:absolute;top:0;right:0;bottom:0;left:0;overflow:auto;padding:24px;display:grid;place-items:start center}.plan-stage{transform-origin:top center;transition:transform .1s}.plan-img-wrap{position:relative;display:inline-block;line-height:0;cursor:crosshair;box-shadow:var(--shadow)}.plan-img-wrap.readonly{cursor:default}.plan-img-wrap.readonly .pin{cursor:pointer}.plan-img-wrap img{max-width:100%;display:block;-webkit-user-select:none;user-select:none}.zoom-controls{position:absolute;top:14px;right:14px;z-index:5;display:flex;align-items:center;gap:6px;background:var(--panel);padding:5px 8px;border-radius:10px;box-shadow:var(--shadow);font-size:13px}.pin{position:absolute;transform:translate(-50%,-50%);width:28px;height:28px;background:var(--pin, var(--brand));color:#fff;border:2px solid #fff;border-radius:50%;cursor:grab;box-shadow:0 2px 6px #00000059;padding:0;display:grid;place-items:center;font-size:12px;font-weight:700;line-height:1;touch-action:none}.pin:active{cursor:grabbing}.pin.selected{box-shadow:0 0 0 4px var(--pin),0 0 0 6px #fff,0 2px 8px #0006;z-index:4}.empty-canvas{display:grid;place-items:center}.dropzone{border:2px dashed #94a3b8;border-radius:16px;background:#fff;padding:48px;max-width:460px;text-align:center;cursor:pointer}.dropzone:hover{border-color:var(--brand)}.dropzone-inner{display:flex;flex-direction:column;align-items:center;gap:8px}.dropzone-inner .hero{width:260px;max-width:100%;margin-bottom:6px}.panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a4d;z-index:30}.task-panel{position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:var(--panel);z-index:31;box-shadow:-8px 0 30px #0f172a26;display:flex;flex-direction:column}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line)}.panel-head-actions{display:flex;align-items:center;gap:8px}.task-nav{display:flex;gap:4px}.task-nav .icon-btn{font-size:20px;font-weight:700;line-height:1}.copy-link{color:var(--brand-d);font-weight:700;white-space:nowrap}.panel-num{font-weight:800;font-size:18px;color:var(--brand-d)}.panel-body{flex:1;overflow:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.title-input{font-size:18px;font-weight:700;border:none;border-bottom:2px solid var(--line);padding:6px 2px}.title-input:focus{outline:none;border-color:var(--brand)}.field-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}label{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--muted);min-width:0}label.block{gap:6px}label input,label select,label textarea{padding:9px 10px;border:1px solid var(--line);border-radius:8px;font-size:14px;color:var(--ink);font-weight:400;font-family:inherit;width:100%;min-width:0;box-sizing:border-box}label input:focus,label select:focus,label textarea:focus{outline:2px solid #a5f3fc;border-color:var(--brand)}.section{border-top:1px solid var(--line);padding-top:14px}.section-head{display:flex;align-items:center;gap:10px}.section-head h4{margin:0;flex:1}.section h4{margin:0 0 10px;font-size:14px}.mini-map{position:relative;border:1px solid var(--line);border-radius:10px;overflow:hidden;cursor:zoom-in;background:#fff;line-height:0}.mini-map img{width:100%;display:block}.mini-pin{position:absolute;transform:translate(-50%,-50%);min-width:22px;height:22px;padding:0 4px;background:var(--c, var(--brand));color:#fff;border:2px solid #fff;border-radius:999px;font:700 10px/1 sans-serif;display:grid;place-items:center;box-shadow:0 0 0 3px var(--c),0 1px 5px #00000080;animation:pinPulse 1.6s ease-out infinite}@keyframes pinPulse{0%{box-shadow:0 0 0 2px var(--c),0 0 0 4px #0ea5a480}70%{box-shadow:0 0 0 2px var(--c),0 0 0 12px #0ea5a400}to{box-shadow:0 0 0 2px var(--c),0 0 0 4px #0ea5a400}}.mini-loc{margin-top:6px}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.photo-thumb{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;border:1px solid var(--line)}.photo-thumb img{width:100%;height:100%;object-fit:cover;cursor:zoom-in}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#09111ceb;display:flex;align-items:center;justify-content:center;padding:3vh 2vw}.lb-img{max-width:92vw;max-height:80vh;object-fit:contain;border-radius:6px;box-shadow:0 10px 40px #00000080}.lb-close{position:absolute;top:14px;right:16px;width:40px;height:40px;border-radius:50%;background:#ffffff26;color:#fff;border:none;font-size:18px;cursor:pointer}.lb-close:hover{background:#ffffff47}.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:64px;background:#ffffff1f;color:#fff;border:none;font-size:40px;line-height:1;cursor:pointer;border-radius:10px;display:grid;place-items:center}.lb-nav:hover{background:#ffffff40}.lb-prev{left:12px}.lb-next{right:12px}.lb-count{position:absolute;top:18px;left:50%;transform:translate(-50%);color:#fff;font-size:13px;font-weight:600;background:#0006;padding:4px 12px;border-radius:999px}.lb-strip{position:absolute;bottom:12px;left:0;right:0;display:flex;gap:8px;justify-content:center;padding:0 12px;overflow-x:auto}.lb-strip img{width:56px;height:44px;object-fit:cover;border-radius:6px;cursor:pointer;opacity:.55;border:2px solid transparent;flex:none}.lb-strip img.active{opacity:1;border-color:#5eead4}@media (max-width: 760px){.lb-nav{width:40px;height:54px;font-size:32px}.lb-img{max-height:68vh}}.photo-del{position:absolute;top:4px;right:4px;border:none;background:#0000008c;color:#fff;border-radius:6px;width:22px;height:22px;cursor:pointer}.comments{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}.comment{background:#f8fafc;border:1px solid var(--line);border-radius:10px;padding:8px 10px;font-size:14px}.comment-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:3px}.comment-form{display:flex;gap:8px}.mention-wrap{position:relative;flex:1}.comment-form .mention-wrap input{width:100%;padding:9px 10px;border:1px solid var(--line);border-radius:8px;font-size:14px}.mention-drop{position:absolute;bottom:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);overflow:hidden;z-index:5}.mention-drop button{display:flex;align-items:center;gap:8px;width:100%;border:none;background:#fff;padding:8px 10px;font-size:13px;text-align:left;cursor:pointer;color:var(--ink)}.mention-drop button:hover{background:#ecfeff}.mention-av{width:22px;height:22px;border-radius:50%;background:#1d9e75;color:#fff;display:grid;place-items:center;font-weight:700;font-size:11px;flex:none}.panel-foot{padding:12px 16px;border-top:1px solid var(--line)}.task-fields{border:none;padding:0;margin:0;min-width:0;display:flex;flex-direction:column;gap:16px}.task-fields:disabled{opacity:.85}.readonly-note{background:#fffbeb;border:1px solid #fde68a;color:#854d0e;border-radius:8px;padding:8px 10px;font-size:12px;font-weight:600}.role-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap;background:#f1f5f9;color:#475569;border:1px solid var(--line)}.role-badge.admin{background:#ecfeff;color:#0e7490;border-color:#a5f3fc}.role-badge.editor{background:#eef2ff;color:#4338ca;border-color:#c7d2fe}.role-badge.viewer{background:#f8fafc;color:#64748b;border-color:#e2e8f0}.sidebar-head-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.sidebar-head-actions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.btn.members-btn{background:#ecfeff;color:var(--brand-d);border-color:#a5f3fc;font-weight:700}.btn.members-btn:hover{background:#cffafe;border-color:var(--brand)}.export-btn{color:var(--brand-d);font-weight:700}.task-meta-line{margin:-4px 0 0}.members-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:31;width:480px;max-width:94vw;max-height:88vh;background:var(--panel);border-radius:16px;box-shadow:0 20px 60px #0f172a4d;display:flex;flex-direction:column;overflow:hidden}.members-modal .panel-head h3{margin:0}.members-body{padding:16px;overflow:auto;display:flex;flex-direction:column;gap:10px}.member-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:10px}.member-row.owner{background:#f8fafc}.member-info{flex:1;min-width:0;display:flex;flex-direction:column}.member-info b{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-row select{padding:6px 8px;border:1px solid var(--line);border-radius:7px;font-size:13px}.invite-form{border-top:1px solid var(--line);padding-top:14px;margin-top:6px}.invite-form h4,.view-as h4{margin:0 0 4px}.invite-fields{display:flex;gap:8px;margin-top:8px}.invite-fields input{flex:1;padding:9px 10px;border:1px solid var(--line);border-radius:8px;font-size:14px;min-width:0}.invite-fields select{padding:9px 8px;border:1px solid var(--line);border-radius:8px;font-size:13px}.role-help{margin:6px 0 0}.view-as{border-top:1px solid var(--line);padding-top:14px;margin-top:6px}.view-as-btns{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.chip2{border:1px solid var(--line);background:#fff;border-radius:999px;padding:5px 11px;font-size:12px;font-weight:600;cursor:pointer}.chip2.active{background:#0f2942;color:#fff;border-color:#0f2942}.invite-info{margin-top:8px;color:#0f766e;font-weight:600}.member-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;margin-top:2px}.member-status .status-dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto}.member-status.active{color:#15803d}.member-status.active .status-dot{background:#22c55e;box-shadow:0 0 0 3px #dcfce7}.member-status.pending{color:#b45309}.member-status.pending .status-dot{background:#f59e0b;box-shadow:0 0 0 3px #fef3c7}.invite-link-box{margin-top:10px;padding:10px;background:#f0fdfa;border:1px solid #99f6e4;border-radius:10px}.invite-link-box p{margin:0 0 6px}.invite-link-row{display:flex;gap:6px}.invite-link-row input{flex:1;min-width:0;padding:7px 9px;border:1px solid var(--line);border-radius:8px;font-size:12px;background:#fff;color:#334155}.invite-link-row .btn{white-space:nowrap}.upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:8;background:#0f29428c;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:#fff;font-weight:600;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.spinner{width:38px;height:38px;border-radius:50%;border:4px solid rgba(255,255,255,.3);border-top-color:#5eead4;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.upload-error{position:absolute;top:14px;left:50%;transform:translate(-50%);z-index:9;background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:10px;padding:8px 12px;font-size:13px;font-weight:600;box-shadow:var(--shadow);display:flex;align-items:center;gap:10px;max-width:90%}.upload-error button{border:none;background:none;color:#b91c1c;cursor:pointer;font-size:14px}.mobile-switch{display:none}@media (max-width: 760px){.topbar{height:56px;padding:0 12px}.brand{font-size:16px;gap:8px}.brand-name small,.mode-badge{display:none}.page-head{flex-direction:column;align-items:stretch;gap:12px}.page-head h1{font-size:22px}.inline-form{max-width:none}.grid{grid-template-columns:1fr}.container{padding:18px 14px}.project-view{position:relative}.sidebar,.canvas-area{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;padding-bottom:56px}.sidebar{border-right:none}.sidebar-resizer,.project-view[data-view=plan] .sidebar,.project-view[data-view=list] .canvas-area{display:none}.plan-tabs,.deck-bar{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.plan-tabs::-webkit-scrollbar,.deck-bar::-webkit-scrollbar{height:0}.tab,.deck-chip{flex:none}.task-panel{width:100%;max-width:100%}.field-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.table-topbar{padding:8px 12px;gap:8px}.tv-title{font-size:15px;order:-1;flex-basis:calc(100% - 90px)}.tv-right{width:100%}.tv-search{flex:1;width:auto;max-width:none}.view-toggle button{padding:8px 12px}.tv-filterbar{padding:8px 12px;gap:5px}.mobile-switch{display:flex;position:absolute;left:0;right:0;bottom:0;height:56px;z-index:12;background:var(--panel);border-top:1px solid var(--line)}.mobile-switch button{flex:1;border:none;background:transparent;font-size:15px;font-weight:700;color:var(--muted);cursor:pointer}.mobile-switch button.active{color:var(--brand-d);background:#ecfeff}.upload-overlay{padding-bottom:56px}.zoom-controls{top:auto;bottom:64px}.dropzone{padding:28px 20px}}.act-toggle{background:none;border:none;cursor:pointer;font-size:14px;font-weight:700;color:var(--ink, #0f2942);padding:0;display:flex;align-items:center;gap:6px}.act-list{margin-top:10px;display:flex;flex-direction:column;gap:10px}.act-row{display:flex;gap:10px;align-items:flex-start}.act-avatar{width:26px;height:26px;border-radius:50%;flex:0 0 26px;background:#e2e8f0;color:#334155;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}.act-body{font-size:13px;min-width:0;overflow-wrap:anywhere}.bulk-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px 14px;background:#eff6ff;border-bottom:1px solid #bfdbfe;font-size:13px}.bulk-bar select,.bulk-bar input{padding:5px 8px;border:1px solid #cbd5e1;border-radius:8px;font-size:13px;background:#fff;min-width:0;max-width:150px}.task-table .c-check{width:30px;text-align:center}.task-table .c-check input{cursor:pointer}.dash-wrap{padding:18px;overflow-y:auto;flex:1}.dash-cards{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}.dash-stat{flex:1;min-width:110px;background:#fff;border:1px solid #e2e8f0;border-left:4px solid var(--c);border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:2px}.dash-num{font-size:26px;font-weight:800;color:var(--c)}.dash-name{font-size:12px;color:#64748b}.dash-progress{height:6px;background:#e2e8f0;border-radius:3px;margin-top:6px;overflow:hidden}.dash-progress span{display:block;height:100%;background:var(--c)}.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.dash-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px}.dash-card h4{margin:0 0 10px;font-size:14px}.dash-rows{display:flex;flex-direction:column;gap:8px}.dash-row-head{display:flex;justify-content:space-between;font-size:12px;margin-bottom:2px}.dash-label{color:#475569;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:75%}.dash-bar{display:flex;height:14px;border-radius:4px;overflow:hidden;min-width:24px}.dash-seg{display:block;height:100%}.dash-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:16px;font-size:12px;color:#475569}.dash-legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:4px}@media (max-width: 700px){.dash-cards{display:grid;grid-template-columns:repeat(2,1fr)}}.annot-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:#0a0f19f5;display:flex;flex-direction:column}.annot-toolbar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#0f172a;flex-wrap:wrap}.annot-btn{width:38px;height:38px;border-radius:8px;border:1px solid #334155;background:#1e293b;color:#e2e8f0;font-size:17px;cursor:pointer}.annot-btn.active{background:#2563eb;border-color:#2563eb}.annot-btn:disabled{opacity:.4;cursor:default}.annot-color{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent;padding:0}.annot-color.active{border-color:#60a5fa;box-shadow:0 0 0 2px #0f172a inset}.annot-sep{width:1px;height:26px;background:#334155;margin:0 4px}.annot-flex{flex:1}.annot-canvas-wrap{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:12px}.annot-canvas-wrap canvas{max-width:100%;max-height:100%;touch-action:none;cursor:crosshair;border-radius:6px;background:#000}.lb-annotate{position:absolute;top:14px;left:14px;z-index:5;background:#1e293be6;color:#fff;border:1px solid #475569;border-radius:10px;padding:8px 12px;cursor:pointer;font-size:13px}
