.sidebar{position:fixed;left:0;top:0;bottom:0;width:240px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;overflow-y:auto}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:18px 20px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-logo-text{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.sidebar-nav{flex:1;padding:10px 8px;display:flex;flex-direction:column;gap:4px}.sidebar-group{margin-bottom:4px}.sidebar-group-label{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 10px;font-size:10px;font-weight:700;letter-spacing:.8px;color:var(--text-muted);background:none;border:none;cursor:pointer;border-radius:var(--radius-sm);text-transform:uppercase}.sidebar-group-label:hover{color:var(--text-secondary);background:var(--bg-hover)}.sidebar-link{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13.5px;font-weight:500;text-decoration:none;border-left:3px solid transparent;transition:all .12s ease;margin-bottom:1px}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-link.active{background:#6366f11a;color:var(--accent);border-left-color:var(--accent)}.sidebar-footer{padding:14px 20px;border-top:1px solid var(--border);flex-shrink:0}.sidebar-date{font-size:11px;color:var(--text-muted)}.sidebar-close{display:none;margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm)}.sidebar-close:hover{color:var(--text-primary);background:var(--bg-hover)}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}@media (max-width: 900px){.sidebar{transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow)}.sidebar--open{transform:translate(0)}.sidebar-close{display:flex}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}}.navbar{height:60px;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:20px;position:sticky;top:0;z-index:50}.navbar-title{font-size:16px;font-weight:600;color:var(--text-primary);min-width:120px}.navbar-search{flex:1;max-width:400px;position:relative;display:flex;align-items:center}.navbar-search-icon{position:absolute;left:10px;color:var(--text-muted);pointer-events:none}.navbar-search-input{width:100%;padding:7px 12px 7px 34px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px}.navbar-search-input::placeholder{color:var(--text-muted)}.navbar-search-input:focus{border-color:var(--accent);outline:none}.navbar-right{margin-left:auto;display:flex;align-items:center;gap:14px;flex-shrink:0}.navbar-greeting{font-size:13px;color:var(--text-secondary);white-space:nowrap}.navbar-user-info{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2;max-width:180px}.navbar-user{font-size:12px;font-weight:600;color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.navbar-user-email{font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.navbar-logout{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 8px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center}.navbar-logout:hover{color:var(--accent-red);border-color:var(--accent-red)}.theme-toggle{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;flex-shrink:0}.theme-toggle-track{position:relative;width:46px;height:26px;background:var(--bg-hover);border:1.5px solid var(--border-light);border-radius:13px;display:flex;align-items:center;padding:2px;transition:background .25s ease,border-color .25s ease}[data-theme=light] .theme-toggle-track{background:#6366f11f;border-color:#6366f14d}.theme-toggle-thumb{width:20px;height:20px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 1px 4px #00000059;transform:translate(0);transition:transform .25s cubic-bezier(.34,1.56,.64,1),background .25s ease}[data-theme=light] .theme-toggle-thumb{transform:translate(20px);background:var(--accent)}.theme-toggle:hover .theme-toggle-track{border-color:var(--accent)}.navbar-menu-btn{display:none;background:none;border:none;color:var(--text-secondary);padding:6px;border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0}.navbar-menu-btn:hover{background:var(--bg-hover);color:var(--text-primary)}@media (max-width: 900px){.navbar{padding:0 16px;gap:12px}.navbar-menu-btn{display:flex}.navbar-title{min-width:0;font-size:15px}.navbar-search,.navbar-greeting{display:none}}@media (max-width: 480px){.navbar{padding:0 12px}}.sticky-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:150}.sticky-float{position:fixed;width:200px;min-height:160px;background:var(--sticky-bg);border:2px solid var(--sticky-border);border-radius:4px;box-shadow:3px 5px 15px #00000040;display:flex;flex-direction:column;pointer-events:auto;transform:rotate(-1deg);transition:box-shadow .15s}.sticky-float:nth-child(2n){transform:rotate(1deg)}.sticky-float:nth-child(3n){transform:rotate(-.5deg)}.sticky-float:hover,.sticky-float.dragging{box-shadow:5px 8px 24px #00000059;transform:rotate(0) scale(1.02)}.sticky-float-header{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;cursor:grab;border-bottom:1px solid rgba(0,0,0,.08)}.sticky-float.dragging .sticky-float-header{cursor:grabbing}.sticky-float-colors{display:flex;gap:3px}.sticky-color-dot{width:12px;height:12px;border-radius:50%;padding:0;cursor:pointer;opacity:.7}.sticky-color-dot.selected{opacity:1;outline:1px solid rgba(0,0,0,.3)}.sticky-float-actions{display:flex;gap:2px}.sticky-pin,.sticky-delete{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:4px;color:var(--sticky-text);opacity:.6;background:none;border:none;cursor:pointer}.sticky-pin:hover,.sticky-delete:hover{opacity:1}.sticky-pin.pinned{opacity:1;color:#b45309}.sticky-float-content{flex:1;background:transparent;border:none;padding:8px 10px;font-size:13px;line-height:1.5;color:var(--sticky-text);resize:none;outline:none;font-family:Segoe UI,cursive,sans-serif;min-height:110px}.sticky-fab{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--accent-yellow);color:#713f12;border:2px solid #fde047;box-shadow:0 4px 16px #0000004d;display:flex;align-items:center;justify-content:center;z-index:160;cursor:pointer;transition:transform .15s}.sticky-fab:hover{transform:scale(1.1)}@media (max-width: 768px){.sticky-float{width:160px;min-height:130px}.sticky-fab{bottom:16px;right:16px;width:44px;height:44px}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg-primary)}.auth-card{width:100%;max-width:400px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px 28px;box-shadow:var(--shadow)}.auth-logo{display:flex;align-items:center;gap:10px;justify-content:center;margin-bottom:24px}.auth-logo h1{font-size:22px;font-weight:700}.auth-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--border)}.auth-tabs button{flex:1;padding:10px;font-size:13px;font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;margin-bottom:-1px}.auth-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-field{display:flex;align-items:center;gap:10px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 12px;color:var(--text-muted)}.auth-field input{flex:1;background:none;border:none;padding:11px 0;font-size:14px;outline:none}.auth-submit{width:100%;justify-content:center;margin-top:8px;padding:11px}.auth-hint{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:4px}.auth-link-btn{background:none;border:none;color:var(--accent);font-size:13px;cursor:pointer;text-align:center;padding:8px}.auth-footer-note{text-align:center;font-size:11px;color:var(--text-muted);margin-top:4px}.auth-loading-hint{text-align:center;font-size:12px;color:var(--text-muted);line-height:1.45;margin-top:8px;animation:fadeIn .2s ease}.stats-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;border-left:4px solid var(--card-color, var(--accent));transition:transform .15s ease,box-shadow .15s ease;cursor:default}.stats-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.stats-card-left{display:flex;align-items:center;gap:16px}.stats-card-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:#ffffff0d;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stats-card-info{display:flex;flex-direction:column;gap:2px}.stats-card-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1}.stats-card-label{font-size:13px;color:var(--text-secondary);font-weight:500}.stats-card-sublabel{font-size:11px;color:var(--text-muted)}.progress-ring{position:relative;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.progress-ring-label{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.progress-ring-percent{font-size:12px;font-weight:700;color:var(--text-primary);line-height:1}.progress-ring-text{font-size:9px;color:var(--text-muted);line-height:1;margin-top:2px}.recent-activity-list{list-style:none;display:flex;flex-direction:column;gap:2px}.recent-activity-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);transition:background .15s ease}.recent-activity-item:hover{background:var(--bg-hover)}.recent-activity-icon{width:28px;height:28px;border-radius:var(--radius-sm);background:#ffffff0d;display:flex;align-items:center;justify-content:center;flex-shrink:0}.recent-activity-content{flex:1;min-width:0;display:flex;flex-direction:column}.recent-activity-title{font-size:13px;color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-activity-action{font-size:11px;color:var(--text-muted)}.recent-activity-time{font-size:11px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.recent-activity-empty{padding:20px;text-align:center;color:var(--text-muted);font-size:13px}.quick-add{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.quick-add-label{font-size:13px;color:var(--text-muted);font-weight:500}.quick-add-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.quick-add-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.quick-add-modal{max-width:380px}.dashboard-charts{display:flex;flex-direction:column;gap:20px}.chart-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.chart-card--half{min-width:0}.chart-title{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.chart-tooltip{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:12px;display:flex;flex-direction:column;gap:2px}@media (max-width: 768px){.chart-row{grid-template-columns:1fr}}.dashboard{display:flex;flex-direction:column;gap:24px}.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media (max-width: 900px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}.dashboard-grid{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}@media (max-width: 1100px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-left,.dashboard-right{display:flex;flex-direction:column;gap:20px}.dashboard-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.section-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.in-progress-list{display:flex;flex-direction:column;gap:12px}.in-progress-item{display:flex;align-items:flex-start;gap:12px}.in-progress-cover{width:44px;height:60px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.in-progress-cover-placeholder{width:44px;height:60px;background:var(--bg-hover);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.in-progress-info{flex:1;display:flex;flex-direction:column;gap:3px}.in-progress-title{font-size:14px;font-weight:600;color:var(--text-primary)}.in-progress-sub{font-size:12px;color:var(--text-muted)}.in-progress-pct{font-size:11px;color:var(--text-muted)}.platform-badge--small{display:inline-block;font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px;background:#6366f126;color:var(--accent)}.projects-overview-list{display:flex;flex-direction:column;gap:12px}.projects-overview-item{display:flex;align-items:center;gap:14px;padding:10px 12px;border-radius:var(--radius-sm);transition:background .15s}.projects-overview-item:hover{background:var(--bg-hover)}.projects-overview-info{flex:1;min-width:0}.projects-overview-title{font-size:14px;font-weight:500;color:var(--text-primary);display:block;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.projects-overview-meta{display:flex;align-items:center;gap:8px}.projects-priority-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.project-card-v2{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:0;cursor:pointer;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;display:flex;flex-direction:column;min-height:220px}.project-card-v2:hover{transform:translateY(-4px);box-shadow:0 16px 40px #00000047;border-color:color-mix(in srgb,var(--card-accent) 40%,var(--border))}.project-card-v2-glow{position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--card-accent),color-mix(in srgb,var(--card-accent) 30%,transparent))}.project-card-v2-top{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 18px 0;gap:8px}.project-card-v2-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.project-shared-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;background:#6366f11f;color:var(--accent);text-transform:uppercase;letter-spacing:.3px}.project-card-v2-body{display:flex;gap:16px;padding:14px 18px 12px;flex:1}.project-card-v2-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.project-card-v2-title{font-size:18px;font-weight:700;color:var(--text-primary);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card-v2-desc{font-size:13px;color:var(--text-secondary);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card-v2-stats{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.project-stat-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--text-muted);background:var(--bg-hover);border:1px solid var(--border);padding:4px 10px;border-radius:20px}.project-card-v2-ring{position:relative;width:64px;height:64px;flex-shrink:0}.project-card-v2-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.project-card-v2-ring .ring-bg{fill:none;stroke:var(--border);stroke-width:3}.project-card-v2-ring .ring-fill{fill:none;stroke:var(--card-accent);stroke-width:3;stroke-linecap:round}.ring-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text-primary)}.project-card-v2-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 18px 16px;border-top:1px solid var(--border);background:color-mix(in srgb,var(--bg-secondary) 50%,transparent)}.project-card-v2-updated{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted)}.project-card-v2-open{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--card-accent);opacity:0;transform:translate(-4px);transition:opacity .15s,transform .15s}.project-card-v2:hover .project-card-v2-open{opacity:1;transform:translate(0)}.project-card-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.project-card-v2:hover .project-card-actions{opacity:1}.project-card-deadline{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.project-card-deadline.overdue{color:var(--accent-red)}.overdue-tag{font-size:10px;font-weight:700;padding:2px 6px;border-radius:8px;background:#ef444426;color:var(--accent-red)}.priority-badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:8px;font-size:10px;font-weight:700;text-transform:uppercase}.priority-high{background:#ef44441f;color:var(--accent-red)}.priority-medium{background:#f59e0b1f;color:var(--accent-yellow)}.priority-low{background:#10b9811f;color:var(--accent-green)}.confirm-delete{display:flex;gap:4px}.project-modal-card{max-width:600px}.project-modal-simple{max-width:440px}.pm-simple-hint{font-size:13px;color:var(--text-muted);margin:-12px 0 20px;line-height:1.5}.pm-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:0}.pm-tab{padding:8px 16px;font-size:13px;font-weight:500;color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .15s;margin-bottom:-1px}.pm-tab:hover{color:var(--text-primary)}.pm-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.color-picker{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.color-swatch{width:26px;height:26px;border-radius:50%;cursor:pointer;transition:transform .15s;padding:0}.color-swatch:hover{transform:scale(1.2)}.color-swatch.selected{outline:3px solid var(--accent);outline-offset:2px}.assignee-row{display:flex;gap:8px;margin-bottom:8px}.assignee-row input{flex:1}.assignee-list{display:flex;flex-wrap:wrap;gap:6px}.assignee-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;background:#6366f11f;color:var(--accent);border-radius:12px;font-size:12px}.assignee-chip button{background:none;border:none;cursor:pointer;color:var(--accent);display:flex;align-items:center;padding:0}.pm-tasks,.pm-links{padding:4px 0}.task-add-row{display:flex;gap:8px;margin-bottom:14px}.pm-empty{text-align:center;color:var(--text-muted);font-size:13px;padding:24px 0}.task-list{list-style:none;display:flex;flex-direction:column;gap:6px;max-height:260px;overflow-y:auto}.task-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--bg-hover);font-size:13px;color:var(--text-primary)}.task-item span{flex:1}.task-item.done span{text-decoration:line-through;color:var(--text-muted)}.task-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;opacity:0;transition:opacity .15s;display:flex}.task-item:hover .task-remove{opacity:1}.task-progress-bar{margin-top:12px;display:flex;align-items:center;gap:10px}.task-progress-label{font-size:12px;color:var(--text-muted);white-space:nowrap}.link-add-form{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.link-add-form input{flex:1;min-width:140px}.link-list{list-style:none;display:flex;flex-direction:column;gap:6px}.link-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--bg-hover);font-size:13px}.link-item a{flex:1;color:var(--accent-blue);text-decoration:underline;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.projects-page{min-width:0}.projects-invites-banner{margin-bottom:20px;padding:16px 18px;background:linear-gradient(135deg,#6366f11f,#8b5cf614);border:1px solid rgba(99,102,241,.25);border-radius:var(--radius)}.projects-invites-banner h3{font-size:14px;font-weight:700;margin-bottom:10px;color:var(--text-primary)}.projects-invite-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:8px 0;border-bottom:1px solid var(--border)}.projects-invite-row:last-child{border-bottom:none;padding-bottom:0}.projects-invite-info{font-size:13px;color:var(--text-secondary)}.projects-invite-info strong{color:var(--text-primary)}.projects-invite-actions{display:flex;gap:8px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}@media (max-width: 640px){.projects-grid{grid-template-columns:1fr}}.dynamic-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;min-width:0;max-width:100%}.dt-toolbar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-wrap:wrap;gap:8px}.dt-table-name{font-size:16px;font-weight:600;color:var(--text-primary)}.dt-toolbar-actions{display:flex;gap:8px;margin-left:auto}.add-col-panel-wrap{padding:16px 18px;border-bottom:1px solid var(--border);background:var(--bg-primary)}.add-col-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;max-width:360px}.add-col-panel-header{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:10px}.add-col-panel-header button{background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex}.add-col-input,.add-col-select{width:100%;margin-bottom:8px}.add-col-options{margin-bottom:8px}.add-col-opt-row{display:flex;gap:6px;margin-bottom:6px}.add-col-opt-row input{flex:1}.dropdown-opts-preview{display:flex;flex-wrap:wrap;gap:4px}.add-col-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:10px}.dt-scroll{overflow-x:auto;overflow-y:auto;max-height:min(70vh,600px);max-width:100%;width:100%;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.dt-table{width:max-content;min-width:100%;border-collapse:collapse;font-size:13px}.dt-th{background:var(--bg-secondary);border-bottom:1px solid var(--border);border-right:1px solid var(--border);padding:0;position:sticky;top:0;z-index:10;min-width:150px;white-space:nowrap}.dt-th:last-child{border-right:none}.dt-th-inner{display:flex;align-items:center;gap:6px;padding:10px 12px;color:var(--text-secondary);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px;position:relative}.dt-th-inner span{flex:1;overflow:hidden;text-overflow:ellipsis}.col-menu-trigger{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:3px;display:flex;align-items:center;flex-shrink:0;opacity:.7;transition:opacity .1s}.col-delete-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:3px;border-radius:3px;display:flex;align-items:center;flex-shrink:0;opacity:.75;transition:opacity .1s,color .1s}.col-delete-btn:hover{color:var(--accent-red);background:#ef44441a;opacity:1}.col-delete-btn:disabled{opacity:.35;cursor:not-allowed}.dt-th:hover .col-menu-trigger{opacity:1}.col-menu-trigger:hover{background:var(--bg-hover);color:var(--text-primary)}.col-menu-wrap{position:absolute;top:100%;right:0;z-index:100}.col-menu{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px;min-width:160px;box-shadow:0 8px 24px #0006}.col-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;background:none;border:none;cursor:pointer;text-align:left;transition:all .12s}.col-menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.col-menu-item.danger:hover{color:var(--accent-red)}.col-menu-rename{display:flex;gap:6px;padding:4px}.col-menu-input{flex:1;font-size:13px;padding:5px 8px}.col-menu-confirm{padding:8px;display:flex;flex-direction:column;gap:8px}.col-menu-confirm span{font-size:12px;color:var(--text-secondary);line-height:1.4}.col-menu-confirm-btns{display:flex;gap:6px}.dt-row-actions-th{width:36px;background:var(--bg-secondary);border-bottom:1px solid var(--border);border-right:1px solid var(--border);position:sticky;top:0;z-index:10}.dt-row{transition:background .1s}.dt-row:hover{background:var(--bg-hover)}.dt-row:hover .dt-row-delete{opacity:1}.dt-row-delete-cell{width:36px;border-right:1px solid var(--border);text-align:center;vertical-align:middle;padding:0 4px}.dt-row-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:3px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .1s,color .1s}.dt-row-delete:hover{color:var(--accent-red)}.dt-cell{border-bottom:1px solid var(--border);border-right:1px solid var(--border);padding:0;vertical-align:middle;cursor:text;min-height:38px;height:38px}.dt-cell:last-child{border-right:none}.dt-cell:hover{background:#6366f10a}.dt-cell-editing{padding:0}.cell-value{display:block;padding:9px 12px;color:var(--text-primary);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.cell-empty{display:block;padding:9px 12px;color:var(--text-muted);font-size:13px}.cell-input{width:100%;height:38px;padding:9px 12px;background:#6366f114;border:1px solid var(--accent);border-radius:0;color:var(--text-primary);font-size:13px;outline:none}.dt-cell-checkbox{text-align:center}.dt-cell-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent);margin:0;padding:0;background:none;border:none}.dt-cell-dropdown{padding:0}.cell-select{width:100%;height:38px;border:none;border-radius:0;padding:0 12px;background:transparent;color:var(--text-primary);font-size:13px;cursor:pointer}.cell-select:focus{background:#6366f114;outline:none}.dt-cell-image{text-align:center;padding:4px}.cell-image-wrap{display:flex;flex-direction:column;align-items:center;gap:2px}.cell-thumbnail{width:32px;height:32px;object-fit:cover;border-radius:4px}.cell-image-replace,.cell-image-upload{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--accent);cursor:pointer;padding:2px 6px;border-radius:3px;background:#6366f11a}.cell-image-replace:hover,.cell-image-upload:hover{background:#6366f133}.cell-link{display:block;padding:9px 12px;color:var(--accent-blue);font-size:13px;text-decoration:underline;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.dt-empty-row{text-align:center;padding:40px;color:var(--text-muted);font-size:13px}.table-board{display:flex;flex-direction:column;gap:16px;min-width:0;max-width:100%}.table-board-loading{min-height:200px}.table-board-empty{padding:48px 24px;text-align:center;color:var(--text-muted);background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius)}.table-board-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.table-board-count{font-size:13px;font-weight:600;color:var(--text-secondary)}.table-board-toolbar-actions{display:flex;gap:8px;flex-wrap:wrap}.table-board-stack{display:flex;flex-direction:column;gap:20px}.table-board-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 2px 8px #0000001f;transition:border-color .15s ease,box-shadow .15s ease}.table-board-section.is-open{border-color:var(--border-light);box-shadow:0 4px 20px #0000002e}.table-board-section-header{display:flex;align-items:center;gap:8px;padding:12px 14px;background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-card) 100%);border-bottom:1px solid transparent}.table-board-section.is-open .table-board-section-header{border-bottom-color:var(--border)}.table-board-toggle{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .15s}.table-board-toggle:hover{color:var(--accent);border-color:var(--accent)}.table-board-title-btn{flex:1;min-width:0;text-align:left;background:none;border:none;cursor:pointer;padding:2px 0}.table-board-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:4px;line-height:1.2}.table-board-title-btn:hover .table-board-title{color:var(--accent)}.table-board-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text-muted)}.table-board-meta span{display:inline-flex;align-items:center;gap:4px}.table-board-delete{flex-shrink:0;width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .15s}.table-board-delete:hover{color:var(--accent-red);border-color:#ef444466;background:#ef444414}.table-board-section-body{min-width:0;overflow:hidden}.table-board-section-body .dynamic-table-wrap{border:none;border-radius:0;box-shadow:none}.table-board-section-body .dt-toolbar{background:var(--bg-primary)}@media (max-width: 600px){.table-board-toolbar{flex-direction:column;align-items:stretch}.table-board-toolbar-actions{width:100%}.table-board-toolbar-actions .btn{flex:1;justify-content:center}}.project-detail{display:flex;flex-direction:column;gap:16px;max-width:100%;min-width:0;padding-bottom:24px}.pd-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:4px 0;align-self:flex-start}.pd-back:hover{color:var(--accent)}.pd-hero{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;display:flex;flex-direction:column;gap:14px}.pd-hero-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.pd-title{font-size:22px;font-weight:700;color:var(--text-primary);cursor:pointer;line-height:1.25;margin:0;flex:1;min-width:0;word-break:break-word}.pd-title:hover{color:var(--accent)}.pd-title-input{font-size:22px;font-weight:700;width:100%;flex:1;background:var(--bg-primary);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:6px 10px}.pd-delete-btn{flex-shrink:0}.pd-hero-chips{display:flex;flex-wrap:wrap;gap:8px}.pd-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;background:var(--bg-hover);border:1px solid var(--border);border-radius:20px;color:var(--text-secondary)}.pd-chip-deadline input[type=date]{border:none;background:transparent;font-size:12px;padding:0;color:var(--text-secondary);max-width:130px}.pd-chip-deadline span.overdue{color:var(--accent-red);font-weight:600}.pd-chip-status{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:24px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.pd-chip-progress{background:#10b9811f;border-color:#10b98140;color:var(--accent-green);font-weight:600}.pd-nav{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:6px;position:sticky;top:0;z-index:20}.pd-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 6px;font-size:11px;font-weight:600;color:var(--text-muted);background:transparent;border:none;border-radius:8px;cursor:pointer;transition:background .15s,color .15s;min-width:0}.pd-nav-item span:not(.pd-nav-count){white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.pd-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.pd-nav-item.active{background:var(--accent);color:#fff}.pd-nav-count{font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;background:#fff3}.pd-nav-item:not(.active) .pd-nav-count{background:var(--bg-hover);color:var(--text-muted)}.pd-content{min-width:0}.pd-section{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px 16px;min-width:0}.pd-panel-title{display:flex;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);color:var(--text-primary)}.pd-panel-title h3{font-size:15px;font-weight:700;margin:0}.pd-add-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.pd-add-bar input{flex:1;min-width:0}.pd-add-bar-email{position:relative}.pd-add-bar-email input{padding-left:36px}.pd-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;z-index:1}.pd-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:40px 16px;text-align:center;color:var(--text-muted);font-size:14px}.assignee-select{padding:8px 10px;font-size:13px;border-radius:var(--radius-sm);min-width:110px;max-width:100%}.pd-task-list{display:flex;flex-direction:column;gap:12px}.pd-task-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;overflow:hidden}.pd-task-card.done{opacity:.7}.pd-task-row{display:flex;align-items:center;gap:10px;padding:14px;flex-wrap:wrap}.pd-task-check{flex-shrink:0;display:flex;align-items:center}.pd-task-check input{width:18px;height:18px;cursor:pointer}.pd-task-text{flex:1;font-size:15px;font-weight:600;color:var(--text-primary);min-width:0;word-break:break-word;line-height:1.35}.pd-task-card.done .pd-task-text{text-decoration:line-through;color:var(--text-muted)}.pd-task-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;flex-wrap:wrap}.pd-discuss-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;font-size:12px;font-weight:600;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.pd-discuss-btn:hover,.pd-discuss-btn.active{color:var(--accent);border-color:var(--accent);background:#6366f114}.pd-discuss-label{display:inline}.pd-icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;flex-shrink:0}.pd-icon-btn.danger:hover{color:var(--accent-red);border-color:#ef444466;background:#ef444414}.pd-task-discussion{border-top:2px solid var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--bg-card));padding:14px}.pd-discussion-header{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:12px}.pd-discussion-messages{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto;margin-bottom:12px}.pd-discussion-empty{font-size:13px;color:var(--text-muted);text-align:center;padding:12px}.pd-discussion-bubble{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.pd-discussion-bubble-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.pd-discussion-author{font-size:12px;font-weight:700;color:var(--accent)}.pd-discussion-bubble time{font-size:10px;color:var(--text-muted)}.pd-discussion-bubble p{font-size:13px;color:var(--text-primary);line-height:1.45;margin:0}.pd-discussion-compose{display:flex;gap:8px}.pd-discussion-compose input{flex:1;min-width:0}.pd-table-presets{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.pd-section .table-board{margin-top:4px}.pd-invite-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 14px;margin-bottom:14px;background:#6366f11a;border:1px solid rgba(99,102,241,.25);border-radius:var(--radius);font-size:13px}.pd-members-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);-webkit-overflow-scrolling:touch}.pd-members-table{width:100%;border-collapse:collapse;font-size:13px;min-width:480px}.pd-members-table th,.pd-members-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--border)}.pd-members-table th{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted);background:var(--bg-secondary)}.pd-members-table tr:last-child td{border-bottom:none}.pd-team-avatar-inline{display:inline-flex;width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;align-items:center;justify-content:center;font-size:11px;font-weight:700;margin-right:8px;vertical-align:middle}.pd-member-status{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase}.pd-member-status.ms-accepted{background:#10b9811f;color:var(--accent-green)}.pd-member-status.ms-pending{background:#f59e0b1f;color:var(--accent-yellow)}.pd-member-status.ms-declined{background:#ef44441f;color:var(--accent-red)}.pd-chat-panel{display:flex;flex-direction:column;gap:12px;min-height:300px}.pd-chat-messages{flex:1;display:flex;flex-direction:column;gap:10px;max-height:50vh;overflow-y:auto;padding:4px}.pd-chat-bubble{background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;padding:12px 14px;max-width:90%}.pd-chat-bubble-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.pd-chat-author{font-size:12px;font-weight:700;color:var(--accent)}.pd-chat-bubble time{font-size:10px;color:var(--text-muted)}.pd-chat-bubble p{font-size:14px;color:var(--text-primary);line-height:1.45;margin:0}.pd-chat-compose{display:flex;gap:8px;padding-top:8px;border-top:1px solid var(--border)}.pd-chat-compose input{flex:1;min-width:0}@media (max-width: 768px){.project-detail{gap:12px}.pd-hero{padding:14px;border-radius:12px}.pd-hero-top{flex-direction:column;align-items:stretch}.pd-title,.pd-title-input{font-size:20px}.pd-delete-btn{align-self:flex-start}.pd-hero-chips{flex-direction:column;align-items:stretch}.pd-chip{width:100%;justify-content:flex-start}.pd-nav{grid-template-columns:repeat(4,1fr);gap:4px;padding:4px;border-radius:10px}.pd-nav-item{padding:8px 4px;font-size:10px}.pd-nav-item svg{width:18px;height:18px}.pd-section{padding:14px 12px;border-radius:12px}.pd-add-bar{flex-direction:column;align-items:stretch}.pd-add-bar .btn,.pd-add-bar .assignee-select{width:100%}.pd-task-row{flex-direction:column;align-items:stretch;gap:10px}.pd-task-text{font-size:14px}.pd-task-actions{width:100%;justify-content:space-between}.pd-task-actions .assignee-select{flex:1;min-width:0}.pd-discuss-label{display:none}.pd-discussion-compose{flex-direction:column}.pd-discussion-compose .btn{width:100%}.pd-chat-compose{flex-direction:column}.pd-chat-compose .btn{width:100%}.pd-members-table{min-width:0}.pd-members-table thead{display:none}.pd-members-table tr{display:block;padding:12px;border-bottom:1px solid var(--border)}.pd-members-table tr:last-child{border-bottom:none}.pd-members-table td{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 0;border:none;font-size:13px}.pd-members-table td:before{content:attr(data-label);font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-muted);flex-shrink:0}.pd-members-table td[data-label=""]:before{display:none}}@media (max-width: 400px){.pd-nav-item span:not(.pd-nav-count){font-size:9px}}.book-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;display:flex;flex-direction:column}.book-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.book-card-cover{height:160px;background:var(--bg-hover);position:relative;overflow:hidden}.book-card-cover img{width:100%;height:100%;object-fit:cover}.book-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.book-card-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px;opacity:0;transition:opacity .15s}.book-card:hover .book-card-actions{opacity:1}.book-card-body{padding:14px;display:flex;flex-direction:column;gap:6px;flex:1}.book-card-title{font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.3}.book-card-author{font-size:12px;color:var(--text-secondary)}.book-card-stars{display:flex;gap:2px}.book-progress{display:flex;flex-direction:column;gap:4px}.book-progress-label{font-size:11px;color:var(--text-muted)}.book-progress-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.book-page-btn{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;font-size:11px;font-weight:600;border-radius:12px;background:#10b98126;color:var(--accent-green);border:1px solid rgba(16,185,129,.3);cursor:pointer;white-space:nowrap}.book-page-btn:hover:not(:disabled){background:#10b98140}.book-page-btn:disabled{opacity:.4;cursor:not-allowed}.book-page-btn--solo{margin-top:4px;align-self:flex-start}.learning-line-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1100;padding:20px}.learning-line-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;width:100%;max-width:400px}.learning-line-box h4{font-size:16px;margin-bottom:6px}.learning-line-hint{font-size:12px;color:var(--text-muted);margin-bottom:12px}.learning-line-box textarea{width:100%;margin-bottom:12px;resize:vertical}.learning-line-actions{display:flex;gap:8px;justify-content:flex-end}.show-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;display:flex;flex-direction:column}.show-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.show-card-poster{height:180px;background:var(--bg-hover);position:relative;overflow:hidden}.show-card-poster img{width:100%;height:100%;object-fit:cover}.show-poster-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.show-platform-badge{position:absolute;bottom:8px;left:8px;font-size:10px;font-weight:700;padding:3px 8px;border-radius:10px;letter-spacing:.3px}.show-card-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px;opacity:0;transition:opacity .15s}.show-card:hover .show-card-actions{opacity:1}.show-card-body{padding:14px;display:flex;flex-direction:column;gap:6px;flex:1}.show-card-title{font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.3}.show-card-episode{font-size:12px;color:var(--text-secondary)}.show-card-stars{display:flex;gap:2px}.show-genre{font-size:11px;color:var(--text-muted);font-style:italic}.star-input{display:flex;align-items:center;gap:4px}.star-btn{background:none;border:none;cursor:pointer;padding:2px;display:flex;align-items:center}.clear-rating{margin-left:8px;font-size:12px;color:var(--text-muted);background:none;border:none;cursor:pointer;text-decoration:underline}.clear-rating:hover{color:var(--accent-red)}.file-input{width:100%;padding:6px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px}.shows-filters{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.table-modal-card{max-width:620px}.columns-builder{display:flex;flex-direction:column;gap:8px}.column-row{display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap}.col-name-input{flex:1;min-width:140px}.col-type-select{width:130px;flex-shrink:0}.col-remove-btn{width:32px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;flex-shrink:0}.col-remove-btn:hover:not(:disabled){color:var(--accent-red);border-color:var(--accent-red)}.col-remove-btn:disabled{opacity:.3;cursor:not-allowed}.dropdown-options{width:100%;margin-top:4px;margin-left:0;padding:10px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm)}.dropdown-option-input{display:flex;gap:6px;margin-bottom:8px}.dropdown-option-input input{flex:1}.dropdown-options-list{display:flex;flex-wrap:wrap;gap:5px}.dropdown-option-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#6366f126;color:var(--accent);border-radius:10px;font-size:12px}.dropdown-option-tag button{background:none;border:none;cursor:pointer;color:var(--accent);display:flex;align-items:center;padding:0}.add-col-btn{align-self:flex-start;margin-top:4px}.tables-page{min-width:0;max-width:100%;overflow-x:hidden}.tables-page-subtitle{font-size:13px;color:var(--text-muted);margin-top:4px;font-weight:400}.table-templates{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:20px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.table-templates-label{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;flex-shrink:0}.table-template-btn{padding:5px 12px;font-size:12px;font-weight:500;background:var(--bg-hover);border:1px solid var(--border);border-radius:20px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.table-template-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.table-template-btn:disabled{opacity:.5;cursor:not-allowed}.tables-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;position:relative}.table-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d;border-color:var(--border-light)}.table-card-icon{width:46px;height:46px;border-radius:var(--radius-sm);background:#3b82f61a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.table-card-info{flex:1;min-width:0}.table-card-name{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-card-meta{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.table-card-meta-item{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted)}.table-card-actions{flex-shrink:0;opacity:0;transition:opacity .15s}.table-card:hover .table-card-actions{opacity:1}.card-action-btn{width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:var(--bg-hover);border:none;cursor:pointer;transition:all .15s}.card-action-btn:hover{color:var(--text-primary)}.card-action-btn.danger:hover{color:var(--accent-red);background:#ef44441a}.notes-layout{display:grid;grid-template-columns:260px 1fr;height:calc(100vh - 108px);gap:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;position:relative}.notes-sidebar-toggle{display:none;position:absolute;top:10px;left:10px;z-index:10;padding:6px 12px;font-size:12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer}.notes-sidebar{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;background:var(--bg-secondary)}.notes-sidebar-header{padding:14px;display:flex;gap:8px;align-items:center;border-bottom:1px solid var(--border)}.notes-search{flex:1;display:flex;align-items:center;gap:6px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 9px;color:var(--text-muted)}.notes-search input{background:none;border:none;padding:0;font-size:12px;color:var(--text-primary);width:100%;outline:none}.notes-folders{display:flex;flex-wrap:wrap;gap:4px;padding:10px 12px;border-bottom:1px solid var(--border)}.notes-folder-btn{display:flex;align-items:center;gap:4px;padding:3px 9px;font-size:11px;border-radius:10px;background:none;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer}.notes-folder-btn:hover{border-color:var(--border-light);color:var(--text-primary)}.notes-folder-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.notes-list{flex:1;overflow-y:auto;list-style:none;padding:6px}.notes-list-empty{text-align:center;padding:30px 10px;font-size:12px;color:var(--text-muted)}.notes-list-item{padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;border-left:3px solid transparent;margin-bottom:2px;transition:background .12s}.notes-list-item:hover{background:var(--bg-hover)}.notes-list-item.active{background:#6366f114;border-left-color:var(--accent)}.notes-list-item-header{display:flex;align-items:center;justify-content:space-between;gap:4px;margin-bottom:3px}.notes-list-title{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notes-list-preview{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}.notes-list-date{font-size:10px;color:var(--text-muted)}.notes-editor{display:flex;flex-direction:column;overflow:hidden;padding:0}.notes-editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid var(--border);background:var(--bg-secondary);gap:12px}.notes-color-row{display:flex;gap:6px;align-items:center}.note-color-dot{width:18px;height:18px;border-radius:50%;cursor:pointer;padding:0;transition:transform .12s}.note-color-dot:hover{transform:scale(1.3)}.note-color-dot.selected{outline:2px solid var(--accent);outline-offset:2px}.notes-editor-actions{display:flex;align-items:center;gap:8px}.notes-saving{font-size:11px;color:var(--text-muted)}.notes-pin-btn,.notes-delete-btn{width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:none;border:1px solid var(--border);cursor:pointer;transition:all .12s}.notes-pin-btn:hover{color:var(--accent-yellow);border-color:var(--accent-yellow)}.notes-pin-btn.pinned{color:var(--accent-yellow)}.notes-delete-btn:hover{color:var(--accent-red);border-color:var(--accent-red)}.notes-title-input{font-size:22px;font-weight:700;color:var(--text-primary);background:none;border:none;padding:20px 24px 8px;outline:none;width:100%}.notes-meta-row{display:flex;gap:10px;padding:0 24px 12px;border-bottom:1px solid var(--border)}.notes-folder-input,.notes-tags-input{background:none;border:none;font-size:12px;color:var(--text-muted);padding:4px 0;outline:none;width:auto}.notes-folder-input{width:120px}.notes-tags-input{flex:1}.notes-folder-input:focus,.notes-tags-input:focus{color:var(--text-primary)}.notes-content{flex:1;resize:none;background:none;border:none;padding:18px 24px;font-size:14px;line-height:1.8;color:var(--text-primary);font-family:inherit;outline:none;overflow-y:auto}.notes-tree{flex:1;overflow-y:auto;list-style:none;padding:6px}.notes-tree-item{display:flex;align-items:center;gap:6px;padding:7px 8px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--text-secondary);margin-bottom:1px}.notes-tree-item:hover{background:var(--bg-hover);color:var(--text-primary)}.notes-tree-item.active{background:#6366f11a;color:var(--accent)}.notes-tree-section{font-size:10px;font-weight:700;letter-spacing:.6px;color:var(--text-muted);text-transform:uppercase;padding:10px 12px 4px;list-style:none}.tree-toggle,.tree-spacer{width:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);padding:0;cursor:pointer}.tree-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.learning-badge{font-size:10px}.blocks-editor{flex:1;overflow-y:auto;padding:16px 24px}.blocks-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);padding:40px}.block-item{margin-bottom:12px;border:1px solid transparent;border-radius:var(--radius-sm);transition:border-color .15s}.block-item:hover{border-color:var(--border)}.block-toolbar{display:flex;align-items:center;gap:4px;padding:4px 0;opacity:0;transition:opacity .15s}.block-item:hover .block-toolbar{opacity:1}.block-grip{color:var(--text-muted);cursor:grab}.block-tool-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;color:var(--text-muted);background:var(--bg-hover);border:none;cursor:pointer}.block-tool-btn:hover{color:var(--text-primary)}.block-tool-btn.danger:hover{color:var(--accent-red)}.block-text{width:100%;background:none;border:none;font-size:14px;line-height:1.8;color:var(--text-primary);resize:vertical;outline:none;padding:4px 0;min-height:60px}.block-image img{max-width:100%;border-radius:var(--radius-sm);display:block}.block-add-row{display:flex;gap:8px;padding:8px 0}.notebook-overview{padding:20px 24px;flex:1;overflow-y:auto}.notebook-hint{font-size:13px;color:var(--text-muted);margin-bottom:16px}.notebook-page-list{display:flex;flex-direction:column;gap:6px}.notebook-page-btn{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--text-primary);cursor:pointer;text-align:left}.notebook-page-btn:hover{border-color:var(--accent);color:var(--accent)}@media (max-width: 768px){.notes-layout{grid-template-columns:1fr;height:auto;min-height:calc(100vh - 108px)}.notes-sidebar-toggle{display:block}.notes-sidebar{position:absolute;left:0;top:0;bottom:0;width:260px;z-index:20;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow)}.notes-sidebar.open{transform:translate(0)}.notes-editor{min-height:400px}}.sticky-add-row{display:flex;gap:6px;align-items:center}.sticky-add-color-btn{width:30px;height:30px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s;padding:0}.sticky-add-color-btn:hover{transform:scale(1.2)}.sticky-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}.sticky-card{background:var(--sticky-bg, #fef9c3);border:1.5px solid var(--sticky-border, #fde047);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;min-height:200px;transition:transform .15s,box-shadow .15s;position:relative}.sticky-card:hover{transform:translateY(-2px) rotate(-.5deg);box-shadow:0 8px 24px #0000002e}.sticky-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.sticky-colors{display:flex;gap:4px}.sticky-color-dot{width:14px;height:14px;border-radius:50%;cursor:pointer;padding:0;transition:transform .12s}.sticky-color-dot:hover{transform:scale(1.3)}.sticky-color-dot.selected{outline:2px solid rgba(0,0,0,.4);outline-offset:1px}.sticky-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.sticky-card:hover .sticky-actions{opacity:1}.sticky-pin,.sticky-delete{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;background:#00000014;border:none;cursor:pointer;color:var(--sticky-text, #713f12);transition:background .12s}.sticky-pin:hover{background:#00000029}.sticky-pin.pinned{background:#0003}.sticky-delete:hover{background:#ef444433;color:#ef4444}.sticky-content{flex:1;background:none;border:none;resize:none;font-size:13.5px;line-height:1.65;color:var(--sticky-text, #713f12);font-family:inherit;outline:none;min-height:140px}.habits-table-wrap{overflow:auto;max-width:100%;max-height:min(70vh,520px);-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.habits-table{width:100%;border-collapse:collapse;font-size:13px}.habit-name-th{text-align:left;padding:12px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--bg-secondary);border-bottom:1px solid var(--border);min-width:200px;position:sticky;left:0;z-index:2}.habit-day-th{text-align:center;padding:6px 4px;background:var(--bg-secondary);border-bottom:1px solid var(--border);min-width:38px}.habit-day-th.today{background:#6366f114}.habit-day-label{display:flex;flex-direction:column;align-items:center;gap:1px}.habit-day-label span:first-child{font-size:9px;font-weight:700;text-transform:uppercase;color:var(--text-muted)}.habit-day-label span:last-child{font-size:12px;font-weight:600;color:var(--text-secondary)}.habit-day-th.today .habit-day-label span{color:var(--accent)}.habit-streak-th,.habit-actions-th{text-align:center;padding:12px 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--bg-secondary);border-bottom:1px solid var(--border)}.habit-row{transition:background .1s}.habit-row:hover{background:var(--bg-hover)}.habit-row:not(:last-child){border-bottom:1px solid var(--border)}.habit-name-cell{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-card);position:sticky;left:0;z-index:1;border-right:1px solid var(--border);transition:background .1s}.habit-row:hover .habit-name-cell{background:var(--bg-hover)}.habit-icon{font-size:20px;flex-shrink:0}.habit-info{display:flex;flex-direction:column}.habit-name{font-size:13px;font-weight:600;color:var(--text-primary)}.habit-desc{font-size:11px;color:var(--text-muted)}.habit-day-cell{text-align:center;padding:8px 4px}.habit-dot{width:28px;height:28px;border-radius:50%;background:var(--bg-hover);border:1.5px solid var(--border-light);cursor:pointer;font-size:13px;color:transparent;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}.habit-dot:hover:not(.future){background:#6366f126;border-color:var(--accent);transform:scale(1.15)}.habit-dot.done{background:var(--accent);border-color:var(--accent);color:#fff}.habit-dot.future{opacity:.25;cursor:not-allowed}.habit-streak-cell{text-align:center;padding:8px}.streak-badge{display:inline-flex;align-items:center;gap:3px;font-size:13px;font-weight:700;color:var(--text-primary)}.habit-actions-cell{text-align:center;padding:8px}.emoji-picker{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.emoji-btn{width:34px;height:34px;border-radius:var(--radius-sm);font-size:18px;display:flex;align-items:center;justify-content:center;background:var(--bg-hover);border:1.5px solid var(--border);cursor:pointer;transition:all .12s}.emoji-btn:hover{border-color:var(--accent);transform:scale(1.1)}.emoji-btn.selected{border-color:var(--accent);background:#6366f11f}.goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}@media (max-width: 480px){.goals-grid{grid-template-columns:1fr}}.goal-card{background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--goal-color, var(--accent));border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:12px;transition:transform .15s,box-shadow .15s}.goal-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000040}.goal-card-header{display:flex;align-items:center;justify-content:space-between}.goal-cat-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:10px;text-transform:uppercase;letter-spacing:.4px}.goal-card-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.goal-card:hover .goal-card-actions{opacity:1}.goal-title{font-size:15px;font-weight:600;color:var(--text-primary);line-height:1.3}.goal-desc{font-size:12px;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.goal-progress-row{display:flex;align-items:center;gap:10px}.goal-pct{font-size:12px;font-weight:600;color:var(--text-secondary);white-space:nowrap}.goal-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.goal-date{font-size:12px;color:var(--text-muted)}.goal-milestones{border-top:1px solid var(--border);padding-top:10px}.goal-ms-label{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:6px}.goal-ms-list{list-style:none;display:flex;flex-direction:column;gap:5px}.goal-ms-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-primary)}.goal-ms-item.done span{text-decoration:line-through;color:var(--text-muted)}.goal-ms-check{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border-light);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;color:#fff}.goal-ms-check:hover{border-color:var(--goal-color, var(--accent))}.goal-ms-check.done{background:var(--goal-color, var(--accent));border-color:var(--goal-color, var(--accent))}.progress-slider{width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-hover);border-radius:2px;outline:none;border:none;padding:0;cursor:pointer}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer}.task-add-row{display:flex;gap:8px}.task-add-row input{flex:1}.task-list{list-style:none;display:flex;flex-direction:column;gap:6px}.task-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--radius-sm);background:var(--bg-hover);font-size:13px}.task-item input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent);flex-shrink:0;background:none;border:none;padding:0}.task-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex}.task-remove:hover{color:var(--accent-red)}:root,[data-theme=dark]{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-card: #1e1e1e;--bg-hover: #252525;--border: #2a2a2a;--border-light: #333333;--text-primary: #e8e8e8;--text-secondary: #a0a0a0;--text-muted: #606060;--accent: #6366f1;--accent-hover: #4f46e5;--accent-green: #10b981;--accent-yellow: #f59e0b;--accent-red: #ef4444;--accent-blue: #3b82f6;--radius: 10px;--radius-sm: 6px;--shadow: 0 4px 20px rgba(0, 0, 0, .4)}[data-theme=light]{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-hover: #f0f0f0;--border: #e2e2e2;--border-light: #d0d0d0;--text-primary: #111111;--text-secondary: #555555;--text-muted: #999999;--accent: #6366f1;--accent-hover: #4f46e5;--accent-green: #10b981;--accent-yellow: #f59e0b;--accent-red: #ef4444;--accent-blue: #3b82f6;--radius: 10px;--radius-sm: 6px;--shadow: 0 4px 20px rgba(0, 0, 0, .08)}*,*:before,*:after{transition:background-color .25s ease,border-color .25s ease,color .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;line-height:1.5;min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}a,button,input,select,textarea{transition:background-color .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease,transform .15s ease,opacity .15s ease}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--accent)}a{color:inherit;text-decoration:none}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;display:flex;flex-direction:column;margin-left:240px;min-height:100vh}.app-content{flex:1;padding:24px;overflow-x:hidden;overflow-y:auto;min-width:0}.table-scroll-wrap{overflow:auto;max-width:100%;max-height:min(70vh,600px);-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease;padding:20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-header h2{font-size:18px;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:6px;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .15s ease}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover{color:var(--text-primary);border-color:var(--border-light)}.btn-danger{background:#ef444426;color:var(--accent-red);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444440}.btn-sm{padding:5px 10px;font-size:12px}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-active,.badge-watching{background:#10b98126;color:var(--accent-green)}.badge-completed{background:#3b82f626;color:var(--accent-blue)}.badge-paused,.badge-on-hold{background:#f59e0b26;color:var(--accent-yellow)}.badge-planned,.badge-dropped,.badge-want-to-read,.badge-want-to-watch{background:#60606033;color:var(--text-secondary)}.badge-reading{background:#6366f126;color:var(--accent)}.progress-bar{width:100%;height:6px;background:var(--bg-hover);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:3px;background:var(--accent);transition:width .3s ease}.spinner-container{display:flex;align-items:center;justify-content:center;min-height:200px}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-muted)}.empty-state svg{margin-bottom:16px;opacity:.4}.empty-state h3{font-size:16px;color:var(--text-secondary);margin-bottom:8px}.empty-state p{font-size:14px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header h1{font-size:22px;font-weight:700;color:var(--text-primary)}.filter-bar{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.filter-btn{padding:6px 14px;border-radius:20px;font-size:13px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer}.filter-btn:hover{border-color:var(--border-light);color:var(--text-primary)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.confirm-delete{display:flex;gap:6px;align-items:center}@media (max-width: 900px){.app-main{margin-left:0}.app-content{padding:16px}.page-header{flex-wrap:wrap;gap:12px}.page-header h1{font-size:18px}.form-row{grid-template-columns:1fr}.card-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.modal-card{padding:20px;max-height:85vh}.projects-filters{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}}@media (max-width: 480px){.app-content{padding:12px}.card-grid{grid-template-columns:1fr}.filter-bar{gap:6px;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;-webkit-overflow-scrolling:touch}.filter-btn{padding:5px 10px;font-size:12px;white-space:nowrap;flex-shrink:0}.table-scroll-wrap{max-height:min(55vh,400px)}}
