*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f7f6f3;--surface: #ffffff;--surface2: #f0efe9;--surface3: #e8e7e1;--border: #e4e2da;--border-strong: #ccc8bc;--text: #1a1916;--text-2: #6b6760;--text-3: #a09d96;--accent: #2d5be3;--accent-bg: #eef1fd;--green: #18a058;--green-bg: #e8f7ef;--amber: #d97706;--amber-bg: #fef3e2;--red: #dc2626;--red-bg: #fef2f2;--sidebar-w: 264px;--r: 10px;--shadow: 0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.05);--shadow-lg: 0 8px 24px rgba(0,0,0,.12)}html,body{height:100%;font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.hidden{display:none!important}.tag{display:inline-block;font-size:11px;font-weight:500;padding:2px 8px;border-radius:20px;white-space:nowrap}.tag-outline{background:var(--surface2);border:1px solid var(--border);color:var(--text-2)}.cat-0{background:#dbeafe;color:#1d4ed8}.cat-1{background:#ede9fe;color:#6d28d9}.cat-2{background:#fef3c7;color:#92400e}.cat-3{background:#d1fae5;color:#065f46}.cat-4{background:#fce7f3;color:#9d174d}.cat-5{background:#fee2e2;color:#991b1b}.cat-6{background:#e0f2fe;color:#075985}.cat-7{background:#fdf4ff;color:#7e22ce}.cat-8{background:#f0fdf4;color:#166534}.cat-9{background:#fff7ed;color:#9a3412}.archived-badge{font-size:10px;padding:2px 7px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;color:var(--text-3)}.btn-sm{font-size:12px;font-weight:500;padding:6px 12px;border-radius:7px;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-family:inherit;display:flex;align-items:center;gap:5px;transition:all .15s;white-space:nowrap}.btn-sm:hover{background:var(--surface2);color:var(--text)}.btn-sm.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-sm.primary:hover{opacity:.85}.btn-sm.success{background:var(--green);color:#fff;border-color:var(--green)}.btn-sm.success:hover{opacity:.85}.btn-sm.danger:hover{background:var(--red-bg);color:var(--red);border-color:var(--red)}.icon-btn{background:none;border:none;cursor:pointer;color:var(--text-3);font-size:13px;padding:2px 4px;border-radius:4px;transition:all .12s;line-height:1}.icon-btn:hover{background:var(--surface2);color:var(--text)}.icon-btn.danger:hover{background:var(--red-bg);color:var(--red)}.f-label{display:block;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-2);margin-bottom:5px}.f-input{width:100%;border:1px solid var(--border-strong);border-radius:8px;padding:10px 14px;font-size:14px;font-family:inherit;background:var(--bg);color:var(--text);outline:none;transition:border .15s,background .15s}.f-input:focus{border-color:var(--accent);background:var(--surface)}.empty{text-align:center;padding:56px 20px;color:var(--text-3)}.empty-icon{font-size:34px;margin-bottom:10px}.empty-text{font-size:14px}#app{display:flex;height:100vh;overflow:hidden}#sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sb-head{padding:16px 14px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px}.sb-brand{font-size:15px;font-weight:600}.sb-brand span{color:var(--accent)}.sb-email{font-size:11px;color:var(--text-3);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-new{flex-shrink:0;width:28px;height:28px;background:var(--accent);color:#fff;border:none;border-radius:7px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s}.sb-new:hover{opacity:.82}.sb-scroll{flex:1;overflow-y:auto;padding:6px 0}.sb-group-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);padding:10px 14px 3px}.sb-item{padding:7px 12px;cursor:pointer;border-radius:8px;margin:1px 6px;display:flex;align-items:center;gap:8px;color:var(--text-2);transition:background .1s;position:relative}.sb-item:hover{background:var(--surface2);color:var(--text)}.sb-item.active{background:var(--accent-bg);color:var(--accent)}.sb-dot{width:7px;height:7px;border-radius:50%;background:var(--border-strong);flex-shrink:0}.sb-item.active .sb-dot{background:var(--accent)}.sb-item.archived .sb-dot{background:var(--border)}.sb-item.archived .sb-name{text-decoration:line-through;color:var(--text-3)}.sb-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.sb-meta{font-size:11px;color:var(--text-3)}.sb-bar{height:2px;background:var(--border);border-radius:1px;margin-top:3px}.sb-bar-fill{height:100%;background:var(--accent);border-radius:1px;transition:width .3s}.sb-foot{border-top:1px solid var(--border);padding:10px 12px}.logout-btn{width:100%;background:none;border:1px solid var(--border);border-radius:7px;padding:7px;font-size:12px;color:var(--text-2);cursor:pointer;font-family:inherit;transition:all .15s}.logout-btn:hover{background:var(--red-bg);color:var(--red);border-color:var(--red)}#main{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-width:0}#auth-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--bg);display:flex;align-items:center;justify-content:center}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px 36px;width:380px;box-shadow:var(--shadow-lg)}.auth-title{font-size:22px;font-weight:600;margin-bottom:4px}.auth-title span{color:var(--accent)}.auth-hint{color:var(--text-2);font-size:13px;margin-bottom:28px}.auth-form{display:flex;flex-direction:column;gap:10px}.otp-input{text-align:center;font-size:30px;font-family:DM Mono,monospace;letter-spacing:14px;font-weight:500}.btn-primary{width:100%;margin-top:16px;padding:11px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s}.btn-primary:hover{opacity:.87}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.auth-msg{margin-top:10px;font-size:13px;text-align:center;min-height:18px}.auth-msg.err{color:var(--red)}.auth-msg.ok{color:var(--green)}.resend-hint{margin-top:12px;text-align:center;font-size:12px;color:var(--text-3)}.resend-hint button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:12px;font-family:inherit}.auth-back{background:none;border:none;color:var(--text-3);font-size:12px;cursor:pointer;font-family:inherit;margin-top:8px;text-align:center;display:block;width:100%;transition:color .12s}.auth-back:hover{color:var(--text)}#dashboard-view{padding:32px 36px;max-width:960px}.page-title{font-size:22px;font-weight:600;margin-bottom:4px}.page-sub{color:var(--text-2);font-size:13px;margin-bottom:28px}.ds-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:30px}.ds-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px 22px}.ds-val{font-size:28px;font-weight:600;display:block}.ds-label{font-size:12px;color:var(--text-2);margin-top:2px;display:block}.section-title{font-size:13px;font-weight:600;margin-bottom:10px}.dash-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:12px 16px;margin-bottom:8px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:box-shadow .15s}.dash-row:hover{box-shadow:var(--shadow-lg)}.dr-info{flex:1;min-width:0}.dr-name{font-weight:500;font-size:13px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.dr-sub,.dr-owner{font-size:11px;color:var(--text-3);margin-top:2px}.dr-bar-wrap{min-width:80px;flex:0 0 120px}.dr-bar-bg{height:6px;background:var(--border);border-radius:3px}.dr-bar-fill{height:100%;border-radius:3px;background:var(--accent);transition:width .3s}.dr-pct{font-size:12px;font-weight:600;color:var(--text-2);min-width:34px;text-align:right}#project-view{display:flex;flex-direction:column;flex:1;min-height:0}.pv-head{padding:22px 30px 16px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.pv-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.pv-title{font-size:20px;font-weight:600;line-height:1.3}.pv-owner{font-size:12px;color:var(--text-3);margin-top:4px;display:flex;align-items:center;gap:6px}.pv-owner-chip{font-family:DM Mono,monospace;font-size:11px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:1px 8px;color:var(--text-2)}.pv-tags-row{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px}.pv-actions{display:flex;gap:6px;flex-shrink:0;margin-top:2px}.pv-stats{display:flex;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.pv-stat{padding:10px 24px;border-right:1px solid var(--border)}.pv-stat-val{font-size:20px;font-weight:600}.pv-stat-lbl{font-size:11px;color:var(--text-2)}.pv-filters{padding:10px 28px;border-bottom:1px solid var(--border);background:var(--bg);display:flex;align-items:center;gap:6px;flex-wrap:wrap;flex-shrink:0}.filter-lbl{font-size:12px;color:var(--text-2);margin-right:2px}.f-chip{font-size:12px;padding:3px 11px;border-radius:20px;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-family:inherit;transition:all .12s}.f-chip:hover{background:var(--surface2);color:var(--text)}.f-chip.active{background:var(--text);color:#fff;border-color:var(--text)}.toggle-completed{font-size:12px;padding:3px 11px;border-radius:20px;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-family:inherit;transition:all .12s;margin-left:auto;white-space:nowrap}.toggle-completed:hover{background:var(--surface2)}.toggle-completed.hiding{background:var(--amber-bg);color:var(--amber);border-color:#fcd34d}.pv-body{padding:20px 28px;flex:1;overflow-y:auto}.import-bar{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--amber-bg);border:1px solid #fcd34d;border-radius:var(--r);margin-bottom:16px;flex-wrap:wrap}.import-bar span{font-size:13px;color:var(--amber);flex:1}.stream-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);margin-bottom:14px;overflow:hidden}.stream-head{padding:12px 16px;display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--border);transition:background .12s}.stream-head:hover{background:var(--surface2)}.stream-icon{width:30px;height:30px;background:var(--accent-bg);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.stream-name{font-weight:600;font-size:14px;flex:1}.stream-name-input{font-weight:600;font-size:14px;border:none;background:transparent;font-family:inherit;color:var(--text);outline:none;width:100%;border-bottom:1px solid var(--accent)}.stream-count{font-size:12px;font-weight:500;color:var(--text-2);white-space:nowrap}.stream-chevron{color:var(--text-3);font-size:10px;transition:transform .2s}.stream-chevron.open{transform:rotate(180deg)}.stream-body.hidden{display:none}.stream-actions{display:flex;gap:2px}.btn-add-section{font-size:11px;font-weight:600;padding:3px 9px;border-radius:6px;cursor:pointer;border:1px solid var(--accent);background:var(--accent-bg);color:var(--accent);font-family:inherit;transition:all .12s;white-space:nowrap;flex-shrink:0}.btn-add-section:hover{background:var(--accent);color:#fff}.sec-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);padding:12px 16px 5px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.sec-label:hover{color:var(--text-2)}.sec-label-left{display:flex;align-items:center;gap:7px;flex:1;min-width:0}.sec-chevron{font-size:9px;transition:transform .18s;color:var(--text-3);flex-shrink:0}.sec-chevron.open{transform:rotate(180deg)}.sec-body.hidden{display:none}.sec-label-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s}.sec-label:hover .sec-label-actions{opacity:1}.task-row{display:flex;align-items:flex-start;gap:9px;padding:8px 16px;border-top:1px solid var(--border);transition:background .1s;position:relative}.task-row:hover{background:#fafaf8}.task-row:hover .task-row-actions{opacity:1}.task-cb{width:15px;height:15px;margin-top:3px;cursor:pointer;accent-color:var(--accent);flex-shrink:0}.task-body{flex:1;min-width:0}.task-title{font-size:13px;line-height:1.45;cursor:pointer}.task-title.done{text-decoration:line-through;color:var(--text-3)}.task-chips{display:flex;align-items:center;gap:5px;margin-top:4px;flex-wrap:wrap}.task-row-actions{opacity:0;display:flex;gap:2px;flex-shrink:0;padding-top:1px;transition:opacity .15s}.deadline-pill{font-size:10px;font-weight:500;padding:1px 7px;border-radius:20px;background:var(--surface2);color:var(--text-2);display:flex;align-items:center;gap:3px}.deadline-pill.overdue{background:var(--red-bg);color:var(--red)}.deadline-pill.soon{background:var(--amber-bg);color:var(--amber)}.pic-list{display:flex;gap:3px;align-items:center;flex-wrap:wrap}.pic-chip{font-size:10px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:1px 7px;color:var(--text-2)}.drag-handle{cursor:grab;color:var(--text-3);font-size:13px;line-height:1;padding:2px 3px;border-radius:3px;opacity:0;transition:opacity .12s;-webkit-user-select:none;user-select:none;flex-shrink:0;display:flex;align-items:center}.task-row:hover .drag-handle,.stream-head:hover .drag-handle,.sec-label:hover .drag-handle{opacity:1}.drag-handle:hover{color:var(--text-2);background:var(--surface2)}.drag-handle:active{cursor:grabbing}.sortable-ghost{opacity:.35;background:var(--accent-bg)!important;border-radius:var(--r)}.sortable-chosen{box-shadow:var(--shadow-lg)}.sortable-drag .task-body{pointer-events:none}.add-task-row{padding:6px 16px 10px;border-top:1px solid var(--border);display:flex;gap:9px;align-items:center}.add-task-spacer-drag,.add-task-spacer-cb{width:15px;flex-shrink:0}.add-task-inp{flex:1;border:none;background:transparent;font-family:inherit;font-size:13px;color:var(--text);outline:none;border-bottom:1px solid transparent;transition:border .15s;padding:2px 0}.add-task-inp:focus{border-color:var(--accent)}.add-task-inp::placeholder{color:var(--text-3)}.add-task-cat{border:1px solid var(--border);border-radius:6px;padding:3px 6px;font-size:12px;font-family:inherit;background:var(--bg);color:var(--text-2);outline:none;cursor:pointer;max-width:110px}.btn-ghost-sm{font-size:12px;padding:4px 10px;border-radius:6px;cursor:pointer;border:1px solid var(--accent);background:var(--accent-bg);color:var(--accent);font-family:inherit;font-weight:500;transition:all .12s;white-space:nowrap}.btn-ghost-sm:hover{background:var(--accent);color:#fff}.vis-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap;letter-spacing:.02em}.vis-shared{background:var(--accent-bg);color:var(--accent);border:1px solid #c7d4f9}.vis-personal{background:var(--surface2);color:var(--text-2);border:1px solid var(--border-strong)}.vis-private{background:var(--amber-bg);color:var(--amber);border:1px solid #fcd34d}.add-sec-inline{padding:8px 16px;border-bottom:1px solid var(--border);background:var(--accent-bg)}.add-sec-input{width:100%;border:none;border-bottom:1px solid var(--accent);background:transparent;font-family:inherit;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text);outline:none;padding:2px 0}.add-sec-input::placeholder{color:var(--text-3)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:100;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:14px;padding:26px 26px 22px;box-shadow:var(--shadow-lg);animation:slideUp .18s ease-out;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal.sm{width:420px;max-width:95vw}.modal.md{width:540px;max-width:95vw}.modal.lg{width:640px;max-width:95vw}@keyframes slideUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-scroll{overflow-y:auto;flex:1}.modal-title{font-size:16px;font-weight:600;margin-bottom:18px;flex-shrink:0}.modal-section{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);margin:16px 0 8px}.modal-section:first-of-type{margin-top:0}.m-field{margin-bottom:14px}.m-label{display:block;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-2);margin-bottom:5px}.m-input,.m-textarea,.m-select{width:100%;border:1px solid var(--border-strong);border-radius:8px;padding:9px 12px;font-size:13px;font-family:inherit;background:var(--bg);color:var(--text);outline:none;transition:border .15s,background .15s}.m-input:focus,.m-textarea:focus,.m-select:focus{border-color:var(--accent);background:var(--surface)}.m-textarea{resize:vertical;min-height:72px}.m-hint{font-size:11px;color:var(--text-3);margin-top:4px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;flex-shrink:0}.modal-cancel{background:none;border:1px solid var(--border);border-radius:8px;padding:8px 16px;font-size:13px;cursor:pointer;font-family:inherit;color:var(--text-2);transition:all .12s}.modal-cancel:hover{background:var(--surface2)}.modal-submit{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 18px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s}.modal-submit:hover{opacity:.86}.modal-submit:disabled{opacity:.45}.file-drop{border:2px dashed var(--border-strong);border-radius:9px;padding:20px;text-align:center;cursor:pointer;transition:all .15s}.file-drop:hover,.file-drop.drag{border-color:var(--accent);background:var(--accent-bg)}.file-drop-icon{font-size:24px;margin-bottom:5px}.file-drop-text{font-size:13px;color:var(--text-2)}.file-drop-hint{font-size:11px;color:var(--text-3);margin-top:4px}.file-chosen{font-size:12px;color:var(--green);margin-top:6px;font-weight:500}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.detail-full{grid-column:1/-1}.tags-input-wrap{display:flex;flex-wrap:wrap;gap:5px;align-items:center;border:1px solid var(--border-strong);border-radius:8px;padding:6px 10px;background:var(--bg);cursor:text;min-height:40px;transition:border .15s}.tags-input-wrap:focus-within{border-color:var(--accent);background:var(--surface)}.tag-pill{display:flex;align-items:center;gap:4px;background:var(--accent-bg);border:1px solid #c7d4f9;color:var(--accent);border-radius:20px;padding:2px 4px 2px 9px;font-size:12px;font-weight:500;white-space:nowrap}.tag-pill-x{background:none;border:none;cursor:pointer;color:var(--accent);font-size:14px;line-height:1;padding:0 2px}.tags-input-inner{border:none;background:transparent;font-family:inherit;font-size:13px;color:var(--text);outline:none;min-width:80px;flex:1}.pic-input-wrap{display:flex;flex-wrap:wrap;gap:5px;align-items:center;border:1px solid var(--border-strong);border-radius:8px;padding:6px 10px;background:var(--bg);cursor:text;min-height:40px;transition:border .15s}.pic-input-wrap:focus-within{border-color:var(--accent);background:var(--surface)}.pic-pill{display:flex;align-items:center;gap:4px;background:var(--surface2);border:1px solid var(--border-strong);color:var(--text-2);border-radius:20px;padding:2px 4px 2px 9px;font-size:12px;white-space:nowrap}.pic-pill-x{background:none;border:none;cursor:pointer;color:var(--text-3);font-size:14px;line-height:1;padding:0 2px}.pic-input-inner{border:none;background:transparent;font-family:inherit;font-size:13px;color:var(--text);outline:none;min-width:100px;flex:1}#toast-wrap,.toast-stack{position:fixed;bottom:22px;right:22px;z-index:300;display:flex;flex-direction:column;gap:7px}.toast{background:var(--text);color:#fff;padding:9px 15px;border-radius:9px;font-size:13px;box-shadow:var(--shadow-lg);animation:slideUp .2s;max-width:280px}.toast.ok{background:var(--green)}.toast.err{background:var(--red)}.admin-view{padding:32px 36px;max-width:900px;flex:1}.view-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.view-title{font-size:22px;font-weight:600;margin-bottom:4px}.user-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}.user-table thead{border-bottom:2px solid var(--border)}.user-table th{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-2);padding:10px 14px;text-align:left}.user-table td{padding:11px 14px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}.user-table tr:last-child td{border-bottom:none}.user-table tbody tr:hover td{background:var(--surface2)}.role-badge{display:inline-block;font-size:10px;font-weight:600;padding:2px 9px;border-radius:20px;white-space:nowrap}.role-super_admin{background:var(--accent-bg);color:var(--accent);border:1px solid #c7d4f9}.role-admin{background:var(--amber-bg);color:var(--amber);border:1px solid #fcd34d}.role-user{background:var(--surface2);color:var(--text-2);border:1px solid var(--border)}.status-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px;vertical-align:middle}.status-active{background:var(--green)}.status-inactive{background:var(--text-3)}
