:root{--color-bg: #f1f5f9;--color-surface: #ffffff;--color-card: #ffffff;--color-border: #e2e8f0;--color-border-hover: #cbd5e1;--color-bg-hover: #f8fafc;--color-text: #0f172a;--color-text-secondary: #475569;--color-text-muted: #94a3b8;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-light: #eff6ff;--color-primary-subtle: rgba(37, 99, 235, .08);--color-primary-bg: rgba(37, 99, 235, .06);--color-danger: #dc2626;--color-danger-hover: #b91c1c;--color-danger-light: #fef2f2;--color-success: #16a34a;--color-success-bg: #f0fdf4;--color-error-bg: #fef2f2;--color-warning: #f59e0b;--color-warning-bg: #fffbeb;--color-info: #0ea5e9;--color-info-bg: #f0f9ff;--color-sidebar: #0f172a;--color-sidebar-text: #cbd5e1;--color-sidebar-hover: #1e293b;--color-sidebar-active: #2563eb;--radius-sm: 4px;--radius: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--shadow-xs: 0 1px 2px rgba(0,0,0,.03);--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px -1px rgba(0,0,0,.03);--shadow-md: 0 4px 8px -2px rgba(0,0,0,.08), 0 2px 4px -2px rgba(0,0,0,.04);--shadow-lg: 0 12px 24px -4px rgba(0,0,0,.1), 0 4px 8px -2px rgba(0,0,0,.04);--shadow-xl: 0 20px 40px -8px rgba(0,0,0,.12), 0 8px 16px -4px rgba(0,0,0,.06);--shadow-focus: 0 0 0 3px rgba(37, 99, 235, .16);--shadow-focus-danger: 0 0 0 3px rgba(220, 38, 38, .14);--shadow-card-hover: 0 8px 24px -6px rgba(0,0,0,.1), 0 2px 6px -2px rgba(0,0,0,.05);--transition: .18s cubic-bezier(.4, 0, .2, 1);--transition-slow: .28s cubic-bezier(.4, 0, .2, 1);--transition-fast: .1s cubic-bezier(.4, 0, .2, 1);--layout-max-width: 1160px;--control-height: 36px;--control-height-sm: 32px;--surface-soft: color-mix(in srgb, var(--color-surface) 84%, var(--color-bg));--text-secondary: var(--color-text-secondary);--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", ui-monospace, monospace;--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-optical-sizing:auto;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth}::selection{background:#2563eb2e;color:var(--color-text)}*{box-sizing:border-box;margin:0}body{margin:0;min-width:320px;overflow-x:hidden}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition)}a:hover{text-decoration:underline}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:var(--shadow-focus)}.nav-link:focus-visible{outline-offset:-2px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px);max-height:0}to{opacity:1;transform:translateY(0);max-height:600px}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes toastIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.5}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.fade-in{animation:fadeIn .35s ease-out}.fade-in-up{animation:fadeInUp .4s ease-out}.slide-down{animation:slideDown .3s ease-out;overflow:hidden}.slide-up{animation:slideUp .25s ease-out}.scale-in{animation:scaleIn .2s ease-out}.skeleton{background:linear-gradient(90deg,var(--color-bg) 25%,#e2e8f0 37%,var(--color-bg) 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite;border-radius:var(--radius)}.skeleton-text{height:.85rem;border-radius:4px;margin-bottom:.5rem}.skeleton-text:last-child{width:60%}.skeleton-title{height:1.2rem;width:40%;border-radius:4px;margin-bottom:.75rem}.skeleton-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem;display:flex;flex-direction:column;gap:.6rem}.skeleton-avatar{width:32px;height:32px;border-radius:50%}.skeleton-row{display:flex;align-items:center;gap:.75rem}.app-shell{display:flex;min-height:100vh}.sidebar{width:264px;background:var(--color-sidebar);color:var(--color-sidebar-text);display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:30;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.08) transparent;border-right:1px solid rgba(255,255,255,.04)}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar-brand{padding:1.35rem 1.25rem 1.15rem;border-bottom:1px solid rgba(255,255,255,.06)}.brand-logo{display:flex;align-items:center;gap:.6rem}.brand-logo svg{color:var(--color-primary)}.brand-text{font-size:1.2rem;font-weight:700;color:#fff;letter-spacing:-.01em}.sidebar-section-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffff4d;padding:1rem 1.25rem .4rem}.sidebar-nav{flex:1;padding:.25rem 0}.nav-link{display:flex;align-items:center;gap:.7rem;padding:.6rem 1.25rem;color:var(--color-sidebar-text);text-decoration:none;font-size:.87rem;transition:all var(--transition);border-left:3px solid transparent;margin:1px 0;letter-spacing:.005em;position:relative}.nav-link:hover{background:var(--color-sidebar-hover);color:#f1f5f9;text-decoration:none}.nav-link.active{background:#2563eb1f;color:#fff;border-left-color:var(--color-sidebar-active);font-weight:500}.nav-link.active:after{content:"";position:absolute;right:0;top:15%;bottom:15%;width:2px;background:var(--color-sidebar-active);border-radius:2px;opacity:.4}.nav-link.active svg{opacity:1;color:#60a5fa}.nav-link svg{width:18px;height:18px;flex-shrink:0;opacity:.6;transition:opacity var(--transition-fast),color var(--transition-fast)}.nav-link:hover svg{opacity:.85}.nav-label{white-space:nowrap}.sidebar-footer{padding:.75rem 1rem;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;gap:.5rem}.user-card{display:flex;align-items:center;gap:.6rem}.user-card-info{flex:1;min-width:0;display:flex;flex-direction:column}.user-card-info strong{color:#fff;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card-info .muted{font-size:.75rem;color:#ffffff73}.sidebar-logout{padding:.45rem;background:none;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);color:var(--color-sidebar-text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);width:32px;height:32px}.sidebar-logout:hover{background:#dc262633;border-color:#dc26264d;color:#fca5a5}.main-area{flex:1;min-width:0;display:flex;flex-direction:column}.top-bar{height:52px;background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;flex-shrink:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffeb;position:relative;z-index:100}.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.88rem}.breadcrumb-page{color:var(--color-text-muted);font-weight:500}.breadcrumb-sub{color:var(--color-text);font-weight:600}.workspace-badge{display:inline-flex;align-items:center;gap:.35rem;background:var(--color-primary-light);color:var(--color-primary);font-size:.78rem;font-weight:500;padding:.3rem .7rem;border-radius:999px}.workspace-badge svg{width:14px;height:14px}.top-bar-right{display:flex;align-items:center;gap:.5rem}.tb-widgets{display:flex;align-items:center;gap:2px;position:relative}.tb-widget-group{position:relative}.tb-widget-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .55rem;border:none;background:transparent;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.78rem;font-weight:500;color:var(--color-text-muted);transition:background .18s,color .18s;white-space:nowrap;line-height:1}.tb-widget-btn:hover,.tb-widget-btn.active{background:var(--color-bg-hover, rgba(0, 0, 0, .04));color:var(--color-text)}.tb-widget-icon{opacity:.65;flex-shrink:0}.tb-widget-btn:hover .tb-widget-icon,.tb-widget-btn.active .tb-widget-icon{opacity:1}.tb-chevron{opacity:.4;transition:transform .2s ease,opacity .2s;flex-shrink:0}.tb-chevron.open{transform:rotate(180deg);opacity:.7}.tb-time-display{cursor:default;font-variant-numeric:tabular-nums}.tb-time-text{letter-spacing:.02em}.tb-ampm{font-size:.65rem;font-weight:600;text-transform:uppercase;opacity:.5;margin-left:1px}.tb-weather-icon-wrap{display:inline-flex;align-items:center;color:var(--color-primary)}.tb-weather-temp{font-weight:600;color:var(--color-text)}.tb-weather-loading{animation:tb-pulse 1.8s ease-in-out infinite}@keyframes tb-pulse{0%,to{opacity:.3}50%{opacity:.8}}.tb-widgets .tb-widget-group+.tb-widget-group:before{content:"";display:block;position:absolute;left:-1px;top:50%;transform:translateY(-50%);width:1px;height:18px;background:var(--color-border);opacity:.5}.tb-popover{position:absolute;top:calc(100% + 8px);right:0;z-index:9999;background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;box-shadow:0 12px 40px #0000001f,0 2px 8px #0000000f;animation:tb-pop-in .18s ease-out;overflow:hidden}@keyframes tb-pop-in{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.tb-popover-calendar{width:320px;padding:0;overflow:hidden}.tb-cal-smart{-webkit-user-select:none;user-select:none}.tb-cal-nav{display:flex;align-items:center;gap:.4rem;padding:.85rem 1rem .55rem;border-bottom:1px solid var(--color-border)}.tb-cal-nav-btn{display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;padding:5px;border-radius:8px;transition:all .15s}.tb-cal-nav-btn:hover{background:var(--color-bg-hover, rgba(0,0,0,.04));color:var(--color-text);transform:scale(1.1)}.tb-cal-month-label{flex:1;text-align:center;font-weight:600;font-size:.88rem;color:var(--color-text);letter-spacing:-.01em}.tb-cal-today-btn{font-size:.68rem;font-weight:600;padding:3px 10px;border:none;background:var(--color-primary);color:#fff;border-radius:999px;cursor:pointer;transition:all .15s;letter-spacing:.02em;text-transform:uppercase}.tb-cal-today-btn:hover{background:var(--color-primary-dark, #4338ca);transform:scale(1.05)}.tb-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center;padding:.65rem .75rem .55rem}.tb-cal-head{font-size:.62rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;padding:2px 0 8px;opacity:.6}.tb-cal-day{position:relative;font-size:.78rem;color:var(--color-text);padding:0;border:none;background:transparent;border-radius:10px;line-height:1;cursor:pointer;width:36px;height:36px;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto;transition:all .15s;font-family:inherit;font-weight:450;gap:2px}.tb-cal-day:hover:not(.empty){background:var(--color-bg-hover, rgba(0,0,0,.04));transform:scale(1.08)}.tb-cal-day.empty{visibility:hidden;cursor:default}.tb-cal-day.has-tasks{font-weight:600}.tb-cal-day.today{background:var(--color-primary);color:#fff;font-weight:700;border-radius:50%;box-shadow:0 2px 8px #6366f159}.tb-cal-day.today:hover{background:var(--color-primary-dark, #4338ca);transform:scale(1.12)}.tb-cal-day.selected:not(.today){background:var(--color-primary-light);color:var(--color-primary);font-weight:600;border-radius:10px}.tb-cal-day.today.selected{background:var(--color-primary);color:#fff;box-shadow:0 0 0 2px var(--color-primary-light),0 2px 8px #6366f159}.tb-cal-dots{display:flex;gap:2px;position:absolute;bottom:3px;left:50%;transform:translate(-50%)}.tb-cal-dot{width:4px;height:4px;border-radius:50%;flex-shrink:0;box-shadow:0 0 2px #00000026}.tb-cal-dot.overdue{animation:tb-dot-pulse 1.5s ease-in-out infinite}@keyframes tb-dot-pulse{0%,to{opacity:1}50%{opacity:.35}}.tb-cal-btn-wrap{position:relative;display:inline-flex;align-items:center}.tb-cal-badge{position:absolute;top:-6px;right:-8px;min-width:15px;height:15px;background:#ef4444;color:#fff;font-size:.58rem;font-weight:700;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1;box-shadow:0 1px 4px #ef444466;animation:tb-badge-pop .3s ease-out}@keyframes tb-badge-pop{0%{transform:scale(0)}to{transform:scale(1)}}.tb-cal-tasks,.tb-cal-section{border-top:1px solid var(--color-border);padding:.55rem 0 .45rem;max-height:200px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.tb-cal-tasks-header,.tb-cal-section-header{display:flex;align-items:center;gap:.35rem;padding:0 .85rem .4rem;font-size:.68rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.tb-cal-section.overdue .tb-cal-section-header{color:#ef4444}.tb-cal-section.upcoming .tb-cal-section-header{color:var(--color-primary)}.tb-cal-task-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .85rem;font-size:.78rem;color:var(--color-text);text-decoration:none;transition:all .12s;cursor:pointer;border-radius:0}.tb-cal-task-item:hover{background:var(--color-bg-hover, rgba(0,0,0,.03));padding-left:1rem}.tb-cal-task-item.overdue{color:var(--color-text)}.tb-task-icon{flex-shrink:0}.tb-task-icon.done{color:#22c55e}.tb-task-icon.progress{color:#3b82f6}.tb-task-icon.todo{color:#94a3b8}.tb-cal-task-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.tb-cal-task-priority{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;padding:1px 6px;border-radius:999px;background:currentColor;background-clip:padding-box;-webkit-background-clip:padding-box}.tb-cal-task-priority{background:none}.tb-cal-task-due{font-size:.68rem;color:var(--color-text-muted);flex-shrink:0;white-space:nowrap;font-weight:500}.tb-cal-empty{text-align:center;padding:1rem .85rem;font-size:.78rem;color:var(--color-text-muted);border-top:1px solid var(--color-border)}.tb-cal-empty:before{content:"📋";display:block;font-size:1.2rem;margin-bottom:.3rem}.tb-cal-empty-day{padding:.8rem .9rem;font-size:.76rem;color:var(--color-text-muted);border-top:1px solid var(--color-border);background:color-mix(in srgb,var(--color-surface) 85%,transparent)}.tb-popover-weather{width:280px}.tb-weather-header{padding:1.1rem 1rem .85rem;background:linear-gradient(135deg,var(--color-primary-light) 0%,rgba(255,255,255,0) 100%)}.tb-weather-main{display:flex;align-items:center;gap:.75rem;margin-bottom:.35rem}.tb-weather-icon-lg{color:var(--color-primary);flex-shrink:0;display:flex;align-items:center}.tb-weather-temp-lg{font-size:1.75rem;font-weight:700;color:var(--color-text);line-height:1}.tb-weather-feels{font-size:.72rem;color:var(--color-text-muted);margin-top:2px}.tb-weather-desc{font-size:.82rem;font-weight:500;color:var(--color-text);margin-bottom:.25rem}.tb-weather-location{display:inline-flex;align-items:center;gap:.25rem;font-size:.72rem;color:var(--color-text-muted)}.tb-weather-mode{margin-top:.55rem;display:flex;flex-direction:column;align-items:flex-start;gap:.35rem}.tb-weather-mode-note{font-size:.68rem;color:var(--color-text-muted)}.tb-weather-mode-warning{margin-top:.45rem;font-size:.68rem;color:var(--color-warning)}.tb-weather-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--color-border);border-top:1px solid var(--color-border)}.tb-weather-stat{display:flex;align-items:center;gap:.5rem;padding:.65rem .85rem;background:var(--color-surface)}.tb-ws-icon{flex-shrink:0;opacity:.7}.tb-ws-icon.humidity{color:#3b82f6}.tb-ws-icon.wind{color:#6366f1}.tb-ws-icon.visibility{color:#8b5cf6}.tb-ws-icon.pressure{color:#ec4899}.tb-ws-val{display:block;font-size:.82rem;font-weight:600;color:var(--color-text);line-height:1.2}.tb-ws-label{display:block;font-size:.65rem;color:var(--color-text-muted);line-height:1.2}.tb-weather-sun{display:flex;justify-content:space-around;padding:.65rem .85rem;border-top:1px solid var(--color-border);background:var(--color-surface)}.tb-sun-item{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--color-text-muted);font-weight:500}.tb-sun-icon.rise{color:#f59e0b}.tb-sun-icon.set{color:#ef4444}@media(max-width:768px){.tb-widgets{display:none}}@media(max-width:1024px){.tb-widget-text,.tb-ampm,.tb-chevron{display:none}}.main-content{flex:1;min-width:0;padding:1.75rem 2rem;overflow-y:auto;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.main-content::-webkit-scrollbar{width:6px}.main-content::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:6px}.main-content::-webkit-scrollbar-track{background:transparent}.page{max-width:1100px}.page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-header h1{font-size:1.6rem;font-weight:700;letter-spacing:-.01em}.page-header-left{display:flex;align-items:center;gap:.65rem}.page-header-left svg{color:var(--color-text-muted)}.header-count{display:inline-flex;align-items:center;justify-content:center;background:var(--color-primary-light);color:var(--color-primary);font-size:.75rem;font-weight:600;min-width:24px;height:24px;padding:0 .4rem;border-radius:999px}.page-header-actions{display:flex;gap:.5rem;align-items:center}.page-loading{display:flex;align-items:center;justify-content:center;padding:6rem 1rem;flex-direction:column;gap:1rem;animation:fadeIn .3s ease}.auth-container{display:flex;min-height:100vh}.auth-hero{flex:1;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);display:flex;flex-direction:column;justify-content:center;padding:3rem;color:#fff;position:relative;overflow:hidden}.auth-hero:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at 30% 50%,rgba(37,99,235,.08) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(99,102,241,.06) 0%,transparent 50%);pointer-events:none}.auth-hero-logo{display:flex;align-items:center;gap:.6rem;margin-bottom:2rem}.auth-hero-logo svg{color:var(--color-primary)}.auth-hero-logo span{font-size:1.3rem;font-weight:700;letter-spacing:-.01em}.auth-hero h1{font-size:2.25rem;font-weight:800;line-height:1.2;margin-bottom:.75rem;letter-spacing:-.02em}.auth-subtitle{font-size:1.05rem;color:#94a3b8;margin-bottom:2rem;line-height:1.6}.auth-hero-features{display:flex;flex-direction:column;gap:1rem}.auth-feature{display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:#cbd5e1}.auth-feature svg{color:var(--color-primary);flex-shrink:0}.auth-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--color-surface)}.auth-form-panel .auth-card{width:100%;max-width:420px}.auth-form-panel form{width:100%}.auth-form-panel h2{font-size:1.5rem;font-weight:700;margin-bottom:.35rem;letter-spacing:-.01em}.auth-form-panel .auth-subtitle{color:var(--color-text-secondary);font-size:.92rem;margin-bottom:1.75rem}.auth-footer{text-align:center;margin-top:1.5rem;font-size:.88rem;color:var(--color-text-secondary)}.auth-footer a{font-weight:500}.auth-page{min-height:100vh}.auth-hero-content{max-width:480px}.auth-card{width:100%;max-width:420px}.form-group{margin-bottom:1rem}.form-hint{display:block;font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem}.form-group label{display:block;font-size:.82rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.35rem}label{font-size:.82rem;font-weight:600;color:var(--color-text-secondary)}input,select,textarea{width:100%;border:1px solid var(--color-border);border-radius:var(--radius);padding:.58rem .75rem;font:inherit;font-size:.875rem;color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition),box-shadow var(--transition),background var(--transition)}input:hover:not(:focus):not(:disabled),select:hover:not(:focus):not(:disabled),textarea:hover:not(:focus):not(:disabled){border-color:var(--color-border-hover)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}textarea{resize:vertical}.input-with-icon{position:relative}.input-with-icon input{padding-right:2.75rem}.input-icon-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.25rem;display:flex;border-radius:4px;width:auto;transition:color var(--transition)}.input-icon-btn:hover{color:var(--color-text)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.create-form{margin-bottom:1.5rem;padding:1.25rem}.form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1.15rem;border-radius:var(--radius);font:inherit;font-size:.85rem;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all var(--transition);white-space:nowrap;text-decoration:none;width:auto;position:relative;-webkit-user-select:none;user-select:none}.btn svg{flex-shrink:0}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:0 2px 8px #2563eb40}.btn-primary:active{transform:scale(.98);box-shadow:none}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover{border-color:var(--color-border-hover);background:var(--color-bg);box-shadow:var(--shadow-xs)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover{background:var(--color-danger-hover);box-shadow:0 2px 8px #dc262640}.btn-danger:active{transform:scale(.98);box-shadow:none}.btn-block{width:100%}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-lg{padding:.7rem 1.5rem;font-size:.95rem;border-radius:var(--radius)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important;pointer-events:none}.btn-link{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:0;font:inherit;font-size:.85rem;width:auto}.btn-link:hover{text-decoration:underline}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0;border-radius:var(--radius);border:1px solid transparent;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition)}.btn-icon:hover{background:var(--color-bg);color:var(--color-text)}.btn-icon-danger:hover{background:var(--color-danger-light);color:var(--color-danger)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-xs);transition:border-color var(--transition),box-shadow var(--transition-slow),transform var(--transition-slow)}.card:hover{border-color:var(--color-border-hover)}.card h3{font-size:1rem;font-weight:600;margin-bottom:.75rem}.welcome-banner{background:linear-gradient(135deg,#1e293b,#0f172a);color:#fff;border-radius:var(--radius-xl);padding:2rem 2.25rem;margin-bottom:1.75rem;display:flex;align-items:center;gap:1.25rem;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.welcome-banner:before{content:"";position:absolute;top:-50%;right:-20%;width:300px;height:300px;background:radial-gradient(circle,rgba(37,99,235,.12) 0%,transparent 70%);pointer-events:none}.welcome-banner h1{font-size:1.5rem;font-weight:700;margin-bottom:.25rem;letter-spacing:-.01em}.welcome-banner p{color:#94a3b8;font-size:.92rem}.welcome-date{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;color:#94a3b8a6;margin-top:.5rem}.welcome-text{flex:1}.welcome-icon{background:#2563eb26;border-radius:var(--radius-lg);padding:.75rem;display:flex;align-items:center;justify-content:center;color:#60a5fa}.stats-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:1.75rem}.stat-card-interactive{display:flex;align-items:center;gap:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-xs);text-decoration:none;color:inherit;transition:all var(--transition-slow)}.stat-card-interactive:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-card-hover);text-decoration:none;transform:translateY(-2px)}.stat-card-interactive:hover .stat-card-icon{transform:scale(1.1)}.stat-card-interactive:active{transform:translateY(0) scale(.99);box-shadow:var(--shadow-sm)}.stat-card-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform var(--transition-slow)}.stat-card-icon.documents{background:#eff6ff;color:#2563eb}.stat-card-icon.tasks{background:#f0fdf4;color:#16a34a}.stat-card-icon.files{background:#fef3c7;color:#d97706}.stat-card-icon.members{background:#f5f3ff;color:#7c3aed}.stat-body{display:flex;flex-direction:column}.stat-value{font-size:1.75rem;font-weight:700;line-height:1.2}.stat-label{font-size:.82rem;color:var(--color-text-secondary)}.rc-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:1.75rem;overflow:hidden;box-shadow:var(--shadow-xs)}.rc-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);background:var(--color-bg);gap:1rem;flex-wrap:wrap}.rc-header h2{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;margin:0;color:var(--color-text);white-space:nowrap}.rc-tabs{display:flex;gap:4px;background:#0000000a;border-radius:10px;padding:3px}.rc-tab{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border:none;background:transparent;color:var(--color-text-muted);font-family:inherit;font-size:.78rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .18s;white-space:nowrap}.rc-tab:hover{color:var(--color-text);background:#ffffff80}.rc-tab.active{background:var(--color-surface);color:var(--color-primary);font-weight:600;box-shadow:0 1px 3px #00000014}.rc-tab-count{font-size:.65rem;font-weight:700;background:var(--color-primary-light);color:var(--color-primary);padding:1px 5px;border-radius:999px;line-height:1.3}.rc-tab.active .rc-tab-count{background:var(--color-primary);color:#fff}.rc-body{min-height:80px}.rc-list{padding:.5rem 0}.rc-item{display:flex;align-items:center;gap:.85rem;padding:.65rem 1.25rem;text-decoration:none;color:inherit;transition:all .15s;cursor:pointer;border-left:3px solid transparent}.rc-item:hover{background:var(--color-bg-hover, rgba(0, 0, 0, .02));border-left-color:var(--color-primary);text-decoration:none}.rc-item-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem}.rc-item-icon.docs{background:#eff6ff;color:#2563eb}.rc-item-icon.tasks{background:#f0fdf4;color:#16a34a}.rc-item-icon.files{background:#fef3c7;color:#d97706}.rc-file-emoji{font-size:1.15rem;line-height:1}.rc-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.rc-item-title-row{display:flex;align-items:center;gap:.4rem}.rc-item-title{font-size:.88rem;font-weight:500;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rc-item:hover .rc-item-title{color:var(--color-primary)}.rc-item-meta{display:flex;align-items:center;gap:.3rem;font-size:.72rem;color:var(--color-text-muted);flex-wrap:wrap}.rc-meta-sep{opacity:.4}.rc-item-arrow{color:var(--color-text-muted);opacity:0;transition:all .15s;flex-shrink:0}.rc-item:hover .rc-item-arrow{opacity:1;transform:translate(2px);color:var(--color-primary)}.rc-status-badge{display:inline-flex;align-items:center;font-size:.62rem;font-weight:600;padding:1px 6px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em;line-height:1.5}.rc-status-badge.todo{background:#f1f5f9;color:#64748b}.rc-status-badge.progress{background:#dbeafe;color:#2563eb}.rc-status-badge.done{background:#dcfce7;color:#16a34a}.rc-priority-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.rc-view-all{display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.65rem 1rem;font-size:.78rem;font-weight:500;color:var(--color-primary);text-decoration:none;border-top:1px solid var(--color-border);transition:background .12s}.rc-view-all:hover{background:var(--color-primary-light);text-decoration:none}.rc-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem 1rem;color:var(--color-text-muted);text-align:center}.rc-empty span{font-size:.85rem}.rc-empty .btn{margin-top:.35rem}.dashboard-columns{display:grid;grid-template-columns:1fr;gap:1rem}.quick-actions-card{margin-bottom:1.5rem}.quick-actions-card h2{font-size:1.1rem;font-weight:600;margin-bottom:1rem}.quick-actions{display:grid;gap:.75rem}.quick-action{display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);text-decoration:none;color:inherit;transition:all var(--transition-slow)}.quick-action:hover{border-color:var(--color-primary);background:var(--color-primary-light);text-decoration:none;box-shadow:var(--shadow-sm)}.quick-action-icon{width:36px;height:36px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;background:var(--color-bg);color:var(--color-primary);flex-shrink:0}.quick-action:hover .quick-action-icon{background:var(--color-primary);color:#fff}.quick-action-info{flex:1;min-width:0}.quick-action-info strong{display:block;font-size:.9rem;font-weight:600}.quick-action-info span{font-size:.8rem;color:var(--color-text-secondary)}.quick-action-arrow{color:var(--color-text-muted);transition:transform var(--transition)}.quick-action:hover .quick-action-arrow{transform:translate(3px);color:var(--color-primary)}.quick-action-icon.documents{background:#eff6ff;color:#2563eb}.quick-action-icon.tasks{background:#f0fdf4;color:#16a34a}.quick-action-icon.files{background:#fef3c7;color:#d97706}.quick-action-icon.members{background:#f5f3ff;color:#7c3aed}.table-wrapper{overflow-x:auto;margin-bottom:1rem}.table-wrapper.card{padding:0;overflow:hidden}table{width:100%;border-collapse:collapse}thead{background:var(--color-bg);position:sticky;top:0;z-index:2}th{text-align:left;padding:.65rem 1rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap}.th-actions{width:80px}td{padding:.7rem 1rem;font-size:.88rem;border-bottom:1px solid var(--color-border);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background var(--transition)}tbody tr:hover{background:#2563eb08}.table-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--color-text);font-weight:500;transition:color var(--transition)}.table-link:hover{color:var(--color-primary);text-decoration:none}.table-icon{color:var(--color-text-muted);flex-shrink:0}.row-actions{display:flex;gap:.25rem;justify-content:flex-end}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem;border-radius:999px;font-size:.72rem;font-weight:500;white-space:nowrap;background:var(--color-bg);color:var(--color-text-secondary);letter-spacing:.01em}.badge-critical{background:#fef2f2;color:#991b1b}.badge-high{background:#fff7ed;color:#9a3412}.badge-medium{background:#fffbeb;color:#92400e}.badge-low,.badge-active{background:#f0fdf4;color:#166534}.badge-suspended{background:#fef2f2;color:#991b1b}.badge-pending{background:#fffbeb;color:#92400e}.alert{padding:.75rem 1rem;border-radius:var(--radius);font-size:.88rem;margin-bottom:1rem;display:flex;align-items:center;gap:.6rem;line-height:1.5}.alert-error{background:var(--color-error-bg);color:var(--color-danger);border:1px solid #fecaca}.alert-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid #bbf7d0}.alert-info{background:var(--color-info-bg);color:var(--color-info);border:1px solid #bae6fd}.spinner-wrapper{display:inline-flex;flex-direction:column;align-items:center;gap:.6rem}.spinner-icon{animation:spin 1s linear infinite;color:var(--color-primary)}.spinner-label{font-size:.85rem;color:var(--color-text-secondary)}.avatar{border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:600;color:#fff;flex-shrink:0;-webkit-user-select:none;user-select:none;text-transform:uppercase}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:3.5rem 1.5rem;color:var(--color-text-secondary)}.empty-state-icon{width:72px;height:72px;border-radius:50%;background:var(--color-bg);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);margin-bottom:1.25rem;opacity:.8}.empty-state-title{font-size:1.1rem;font-weight:600;color:var(--color-text);margin-bottom:.3rem}.empty-state-subtitle{font-size:.88rem;margin-bottom:1.25rem;max-width:320px;color:var(--color-text-secondary);line-height:1.5}.empty-state-action{margin-top:.25rem}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem;border-radius:var(--radius);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);font-size:.875rem;pointer-events:auto;animation:toastIn .3s cubic-bezier(.4,0,.2,1);min-width:280px;max-width:420px}.toast svg:first-child{flex-shrink:0}.toast-icon{display:flex;align-items:center;flex-shrink:0}.toast-message{flex:1}.toast-close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.2rem;display:flex;width:auto;border-radius:4px;transition:color var(--transition)}.toast-close:hover{color:var(--color-text)}.toast.success{border-left:3px solid var(--color-success)}.toast.success .toast-icon{color:var(--color-success)}.toast.error{border-left:3px solid var(--color-danger)}.toast.error .toast-icon{color:var(--color-danger)}.toast.warning{border-left:3px solid var(--color-warning)}.toast.warning .toast-icon{color:var(--color-warning)}.toast.info{border-left:3px solid var(--color-info)}.toast.info .toast-icon{color:var(--color-info)}.confirm-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem;animation:fadeIn .15s ease-out}.confirm-dialog{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:420px;padding:1.5rem;animation:slideUp .2s ease-out}.confirm-dialog-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.confirm-dialog-header .btn-icon{margin-left:auto;flex-shrink:0;color:var(--color-text-muted)}.confirm-icon-wrap{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.confirm-icon-wrap.danger{background:var(--color-danger-light);color:var(--color-danger)}.confirm-icon-wrap.default{background:var(--color-primary-light);color:var(--color-primary)}.confirm-dialog h3{font-size:1.05rem;font-weight:600;margin-bottom:.25rem}.confirm-dialog p{font-size:.88rem;color:var(--color-text-secondary);line-height:1.5}.confirm-dialog-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1.25rem}.task-list{display:grid;gap:.75rem}.task-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem;border-left:4px solid var(--color-border);transition:all var(--transition)}.task-card:hover{box-shadow:var(--shadow-md)}.task-card.status-todo{border-left-color:var(--color-text-muted)}.task-card.status-in_progress{border-left-color:var(--color-primary)}.task-card.status-done{border-left-color:var(--color-success)}.task-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.task-card-title{display:flex;align-items:center;gap:.5rem}.task-card-title h3{font-size:.92rem;font-weight:600;margin:0}.status-dot{display:inline-flex;align-items:center;justify-content:center}.status-dot.status-todo{color:var(--color-text-muted)}.status-dot.status-in_progress{color:var(--color-primary)}.status-dot.status-done{color:var(--color-success)}.task-card-footer{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;flex-wrap:wrap}.status-select,.filter-select{padding:.3rem .5rem;font-size:.8rem;border-radius:var(--radius);border:1px solid var(--color-border);width:auto;background:var(--color-surface);cursor:pointer}.task-due{display:inline-flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--color-text-secondary)}.task-assignees{font-size:.8rem;color:var(--color-text-secondary)}.file-name-cell{display:flex;align-items:center;gap:.5rem}.file-icon{color:var(--color-text-muted);flex-shrink:0}.file-icon.img{color:#7c3aed}.file-icon.video{color:#dc2626}.file-icon.audio{color:#d97706}.file-icon.doc{color:#2563eb}.file-icon.archive{color:#059669}.upload-btn{cursor:pointer}.member-list{display:grid;gap:.75rem}.member-card{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;transition:border-color var(--transition),box-shadow var(--transition)}.member-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md)}.member-card-left{display:flex;align-items:center;gap:.75rem}.member-card-info{display:flex;flex-direction:column}.member-name{font-weight:600;font-size:.92rem}.member-role{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;color:var(--color-text-secondary);text-transform:capitalize}.member-role.role-owner{color:#d97706}.member-role.role-admin{color:var(--color-primary)}.audit-timeline{position:relative;padding-left:1.5rem}.audit-timeline:before{content:"";position:absolute;left:7px;top:0;bottom:0;width:2px;background:var(--color-border)}.audit-item{position:relative;margin-bottom:1rem}.audit-dot{position:absolute;left:-1.5rem;top:1rem;width:12px;height:12px;border-radius:50%;background:var(--color-primary);border:2px solid var(--color-surface);z-index:1}.audit-content{margin-left:.5rem;padding:.85rem 1rem;transition:border-color var(--transition),box-shadow var(--transition-slow)}.audit-content:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-sm)}.audit-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.3rem;flex-wrap:wrap}.audit-action{font-weight:600}.audit-user{display:inline-flex;align-items:center;gap:.3rem;font-size:.82rem;color:var(--color-text-secondary)}.audit-details{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:.3rem}.audit-time{display:inline-flex;align-items:center;gap:.25rem;font-size:.78rem;color:var(--color-text-muted)}.settings-grid{display:grid;gap:1.5rem;max-width:560px}.settings-section h2{font-size:1.05rem;font-weight:600;margin-bottom:1rem}.settings-section-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.settings-section-header svg{color:var(--color-text-muted)}.settings-section-header h2{margin:0}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .25s cubic-bezier(.4,0,.2,1)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border)}.modal-header h3{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1rem}.modal-body{padding:1.25rem;overflow-y:auto}.not-found-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,var(--color-bg) 0%,#e2e8f0 100%)}.not-found-content{text-align:center;max-width:440px}.not-found-illustration{display:flex;justify-content:center;margin-bottom:1.5rem}.not-found-circle{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary-light),#dbeafe);display:flex;align-items:center;justify-content:center;color:var(--color-primary);box-shadow:0 8px 32px #2563eb26;animation:pulse-soft 3s ease-in-out infinite}.not-found-icon{color:var(--color-text-muted);margin-bottom:1rem}.not-found-content h1{font-size:5rem;font-weight:800;color:var(--color-text);margin-bottom:.25rem;letter-spacing:-.04em;line-height:1;background:linear-gradient(135deg,var(--color-text),var(--color-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.not-found-content h2{font-size:1.25rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.5rem}.not-found-content p{color:var(--color-text-muted);font-size:.95rem;margin-bottom:2rem;line-height:1.6}.not-found-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.pagination{display:flex;align-items:center;gap:.25rem;justify-content:center;margin-top:1.5rem}.pagination button{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);padding:.4rem .75rem;border-radius:var(--radius);cursor:pointer;font-size:.82rem;font-weight:500;width:auto;transition:all var(--transition);min-width:36px;display:inline-flex;align-items:center;justify-content:center}.pagination button:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary)}.pagination button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination-ellipsis{padding:0 .5rem;color:var(--color-text-muted)}.muted{color:var(--color-text-secondary);font-size:.85rem}@media(max-width:768px){.app-shell{flex-direction:column}.sidebar{width:100%;height:auto;position:sticky;top:0;z-index:50;flex-direction:row;flex-wrap:wrap;align-items:center}.sidebar-brand{padding:.75rem 1rem;border-bottom:none}.sidebar-section-label,.sidebar-workspace{display:none}.sidebar-nav{display:flex;gap:0;overflow-x:auto;padding:0;width:100%;-webkit-overflow-scrolling:touch;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.nav-link{padding:.5rem .75rem;font-size:.8rem;border-left:none;border-bottom:3px solid transparent;flex-shrink:0}.nav-link.active{border-left-color:transparent;border-bottom-color:var(--color-sidebar-active)}.nav-link.active:after{display:none}.nav-label{display:none}.sidebar-footer{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;border-top:none;margin-left:auto}.user-card-info,.top-bar{display:none}.main-content{padding:1rem}.main-area{min-height:0}.form-row,.form-row-3{grid-template-columns:1fr}.auth-container{flex-direction:column}.auth-hero{display:none}.auth-form-panel{min-height:100vh}.welcome-banner{padding:1.25rem}.welcome-banner h1{font-size:1.25rem}.welcome-banner:before{display:none}.stats-grid{grid-template-columns:1fr 1fr}.modal-content{max-width:95vw;margin:1rem}.confirm-overlay{padding:1rem}.file-preview-overlay{padding:.5rem}.file-preview-modal{max-height:95vh}.task-detail-layout,.task-edit-form .form-row{grid-template-columns:1fr}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:stretch}.page-header-actions{justify-content:flex-end}.welcome-banner{flex-direction:column;text-align:center}.welcome-icon{display:none}.not-found-content h1{font-size:3.5rem}.not-found-actions{flex-direction:column}.not-found-actions .btn{width:100%}.admin-summary-row{flex-direction:column}}.search-input-wrapper{position:relative;flex:1;max-width:380px}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.search-input{width:100%;padding:.5rem 2rem .5rem 2.25rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);font-size:.875rem;transition:border-color var(--transition),box-shadow var(--transition)}.search-input:focus{border-color:var(--color-primary);outline:none;box-shadow:var(--shadow-focus)}.search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:2px;border-radius:50%}.search-clear:hover{color:var(--color-text)}.view-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.view-toggle-btn{display:flex;align-items:center;gap:.3rem;padding:.45rem .75rem;font-size:.8rem;border:none;background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:all .15s}.view-toggle-btn.active{background:var(--color-primary);color:#fff}.view-toggle-btn:not(.active):hover{background:var(--color-bg)}.task-toolbar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.task-filter-toggle{position:relative;white-space:nowrap}.task-filter-toggle.has-filters{border-color:var(--color-primary);color:var(--color-primary)}.filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;font-size:.68rem;font-weight:700;background:var(--color-primary);color:#fff;border-radius:99px;margin-left:4px}.task-filters-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:.85rem 1rem;margin-bottom:1rem}.task-filters-row{display:flex;align-items:flex-end;gap:.75rem;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.task-filters{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.task-filters select,.filter-select{padding:.45rem .6rem;font-size:.82rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;transition:border-color var(--transition)}.filter-select:focus{border-color:var(--color-primary);outline:none;box-shadow:var(--shadow-focus)}.kanban-stats-bar{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.kanban-stat{display:flex;align-items:center;gap:.35rem;padding:.4rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);font-size:.78rem;color:var(--color-text-muted);border-left:3px solid var(--stat-color, var(--color-border))}.kanban-stat-label{font-weight:500}.kanban-stat-count{font-weight:700;color:var(--color-text)}.kanban-stat-pct{opacity:.6;font-size:.72rem}.kanban-board{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;min-height:450px;align-items:start}.kanban-column{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:visible;box-shadow:var(--shadow-xs);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.kanban-column-dragover{border-color:var(--color-primary);box-shadow:0 0 0 3px #60a5fa33,var(--shadow-md);background:#60a5fa08}.kanban-column-collapsed .kanban-column-header{border-bottom:none}.kanban-column-header{display:flex;justify-content:space-between;align-items:center;padding:.65rem .85rem;border-bottom:3px solid var(--column-color, var(--color-border));font-weight:600;font-size:.82rem;-webkit-user-select:none;user-select:none;background:var(--color-bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.kanban-column-title,.kanban-column-actions{display:flex;align-items:center;gap:.35rem}.kanban-column-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;font-size:.72rem;font-weight:700;background:var(--color-surface);border:1px solid var(--color-border);border-radius:99px;color:var(--color-text-muted)}.kanban-collapse-btn{opacity:.5;transition:opacity var(--transition)}.kanban-column-header:hover .kanban-collapse-btn{opacity:1}.kanban-column-header .badge{font-size:.72rem;min-width:1.5rem;text-align:center}.kanban-column-body{padding:.65rem;display:flex;flex-direction:column;gap:.5rem;flex:1;overflow-y:auto;min-height:80px;transition:background .2s ease}.kanban-column-dragover .kanban-column-body{background:#60a5fa0f;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.kanban-empty{display:flex;align-items:center;justify-content:center;padding:2rem 1rem;color:var(--color-text-muted);font-size:.82rem;opacity:.7}.kanban-empty-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem 1rem;color:var(--color-text-muted);font-size:.8rem;opacity:.4;border:2px dashed var(--color-border);border-radius:var(--radius);min-height:100px;transition:opacity .25s,border-color .25s,background .25s,transform .25s}.kanban-column-dragover .kanban-empty-drop{opacity:1;border-color:var(--color-primary);color:var(--color-primary);background:#60a5fa0a;transform:scale(1.02)}.task-card-v2{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:visible;transition:border-color var(--transition),box-shadow var(--transition-slow),opacity .2s,transform .15s;cursor:default}.task-card-v2:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-sm);z-index:1}.task-card-v2[draggable=true]{cursor:grab}.task-card-v2[draggable=true]:active{cursor:grabbing}.task-card-v2.task-dragging{opacity:.45;transform:scale(.97);box-shadow:var(--shadow-lg);border-color:var(--color-primary);outline:2px dashed var(--color-primary);outline-offset:2px;background:color-mix(in srgb,var(--color-primary) 5%,var(--color-surface));transition:opacity .15s ease,transform .15s ease}.task-card-priority-stripe{position:absolute;left:0;top:0;bottom:0;width:3px;opacity:.7;transition:opacity var(--transition)}.task-card-v2:hover .task-card-priority-stripe{opacity:1}.task-card-v2-content{padding:.75rem .85rem .75rem .95rem}.task-card-delete{opacity:0;transition:opacity var(--transition);flex-shrink:0}.task-card-v2:hover .task-card-delete{opacity:1}.task-card-v2-header{display:flex;align-items:flex-start;gap:.4rem;margin-bottom:.35rem}.drag-handle{color:var(--color-text-muted);opacity:.35;flex-shrink:0;margin-top:2px;transition:opacity var(--transition)}.task-card-v2:hover .drag-handle{opacity:.7}.task-card-v2-title{font-size:.88rem;font-weight:600;line-height:1.35;flex:1;color:var(--color-text);text-decoration:none}.task-card-v2-title:hover{color:var(--color-primary)}.task-card-v2-desc{font-size:.78rem;color:var(--color-text-muted);margin-bottom:.45rem;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.task-card-v2-tags{display:flex;gap:.3rem;flex-wrap:wrap;margin-bottom:.45rem;align-items:center}.task-card-v2-footer{display:flex;align-items:center;justify-content:space-between;gap:.4rem;font-size:.75rem;color:var(--color-text-muted)}.task-card-v2-meta{display:flex;align-items:center;gap:.5rem}.task-card-v2-people{display:flex;align-items:center;gap:.35rem}.priority-tag{display:inline-flex;align-items:center;gap:.2rem;font-size:.68rem;font-weight:600;padding:.15rem .45rem;border-radius:99px;text-transform:uppercase;letter-spacing:.03em;background:color-mix(in srgb,var(--tag-color, var(--color-text-muted)) 10%,transparent);color:var(--tag-color, var(--color-text-muted))}.status-tag{display:inline-flex;align-items:center;gap:.2rem;font-size:.68rem;font-weight:500;padding:.15rem .45rem;border-radius:99px;background:color-mix(in srgb,var(--tag-color, var(--color-text-muted)) 10%,transparent);color:var(--tag-color, var(--color-text-muted))}.status-select-inline{padding:.2rem .4rem;font-size:.72rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;transition:border-color var(--transition)}.status-select-inline:focus{border-color:var(--color-primary);outline:none}.task-due-v2{display:inline-flex;align-items:center;gap:.25rem;font-size:.73rem}.task-overdue .task-card-priority-stripe{background:var(--color-danger)!important;opacity:1}.task-overdue{border-color:#ef444433}.task-comments-badge{display:inline-flex;align-items:center;gap:.2rem}.task-assignee-avatars{display:flex;align-items:center}.task-assignee-avatars>*+*{margin-left:-6px}.more-assignees{font-size:.7rem;color:var(--color-text-muted);margin-left:2px}.task-assign-menu{position:relative}.task-assign-trigger{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1.5px dashed var(--color-border);background:none;color:var(--color-text-muted);opacity:0;cursor:pointer;transition:all .2s ease}.task-assign-trigger.has-assignees{border-style:solid;border-color:var(--color-primary);color:var(--color-primary);opacity:.6}.task-card-v2:hover .task-assign-trigger{opacity:1}.task-assign-trigger:hover{border-color:var(--color-primary);color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 8%,transparent);transform:scale(1.1)}.task-assign-popover{position:absolute;right:0;top:calc(100% + 8px);z-index:200;width:280px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 12px 40px #0000001f,0 4px 12px #0000000f;animation:assignPopIn .2s cubic-bezier(.16,1,.3,1);overflow:hidden}@keyframes assignPopIn{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.assign-pop-header{display:flex;align-items:center;justify-content:space-between;padding:.7rem .85rem;border-bottom:1px solid var(--color-border);background:color-mix(in srgb,var(--color-primary) 3%,var(--color-surface))}.assign-pop-title{font-size:.8rem;font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:.4rem}.assign-pop-title svg{color:var(--color-primary)}.assign-pop-close{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;border:none;background:none;color:var(--color-text-muted);cursor:pointer;transition:all .15s ease}.assign-pop-close:hover{background:var(--color-bg);color:var(--color-text)}.assign-pop-search{padding:.5rem .75rem;border-bottom:1px solid var(--color-border)}.assign-pop-search input{width:100%;padding:.4rem .6rem;font-size:.78rem;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg);color:var(--color-text);outline:none;transition:border-color .2s ease,box-shadow .2s ease}.assign-pop-search input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #60a5fa1a}.assign-pop-search input::placeholder{color:var(--color-text-muted);opacity:.6}.assign-pop-list{max-height:240px;overflow-y:auto;padding:.35rem 0}.assign-pop-list::-webkit-scrollbar{width:4px}.assign-pop-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.assign-pop-section-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);padding:.5rem .85rem .25rem;opacity:.6}.assign-member-row{display:flex;align-items:center;gap:.55rem;padding:.45rem .75rem;cursor:pointer;border:none;background:none;width:100%;text-align:left;color:var(--color-text);transition:background .15s ease;position:relative}.assign-member-row:hover{background:color-mix(in srgb,var(--color-primary) 5%,transparent)}.assign-member-row.is-assigned{background:color-mix(in srgb,var(--color-primary) 4%,transparent)}.assign-member-row.is-assigned:hover{background:color-mix(in srgb,var(--color-danger) 5%,transparent)}.assign-member-row.is-loading{opacity:.45;pointer-events:none}.assign-avatar-wrap{position:relative;flex-shrink:0}.assign-check-badge{position:absolute;bottom:-2px;right:-2px;width:14px;height:14px;border-radius:50%;background:var(--color-primary);border:2px solid var(--color-surface);display:flex;align-items:center;justify-content:center;color:#fff}.is-assigned:hover .assign-check-badge{background:var(--color-danger)}.assign-member-info{flex:1;min-width:0}.assign-member-name{font-size:.82rem;font-weight:600;line-height:1.3;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.assign-member-handle{font-size:.7rem;color:var(--color-text-muted);line-height:1.2}.assign-action-icon{flex-shrink:0;opacity:0;transition:opacity .15s ease,transform .15s ease}.assign-member-row:hover .assign-action-icon{opacity:1}.assign-action-icon.add-icon{color:var(--color-success)}.assign-action-icon.remove-icon{color:var(--color-danger)}.assign-pop-empty{padding:1.5rem 1rem;text-align:center;color:var(--color-text-muted);font-size:.78rem}.assign-pop-empty svg{display:block;margin:0 auto .5rem;opacity:.3}.assign-pop-footer{padding:.45rem .85rem;border-top:1px solid var(--color-border);font-size:.7rem;color:var(--color-text-muted);background:color-mix(in srgb,var(--color-primary) 2%,var(--color-surface));display:flex;align-items:center;gap:.3rem}.assign-pop-footer .count{font-weight:700;color:var(--color-primary)}.create-task-form{padding:1.25rem;margin-bottom:1.25rem}.create-task-heading{display:flex;align-items:center;gap:.4rem;font-size:1rem;font-weight:600;margin-bottom:.85rem;color:var(--color-text)}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}.required{color:var(--color-danger)}.assign-members-area{display:flex;flex-direction:column;gap:.5rem}.selected-assignees{display:flex;flex-wrap:wrap;gap:.35rem}.assignee-chip-sm{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .5rem .2rem .25rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:99px;font-size:.78rem;font-weight:500}.chip-remove{display:inline-flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;color:var(--color-text-muted);padding:0;margin-left:2px;transition:color var(--transition)}.chip-remove:hover{color:var(--color-danger)}.assign-picker-dropdown{border:1px solid var(--color-border);border-radius:var(--radius);max-height:180px;overflow-y:auto;background:var(--color-surface)}.assign-picker-empty{padding:.75rem;text-align:center;font-size:.8rem}.task-list-v2{display:flex;flex-direction:column;gap:0;margin-bottom:1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:visible;background:var(--color-surface)}.task-list-v2 .task-card-v2{border-radius:0;border:none;border-bottom:1px solid var(--color-border);overflow:visible}.task-list-v2 .task-card-v2:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.task-list-v2 .task-card-v2:last-child{border-bottom:none;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.task-list-v2 .task-card-v2:only-child{border-radius:var(--radius-lg)}.task-list-v2 .task-card-v2:hover{background:color-mix(in srgb,var(--color-primary) 2%,var(--color-surface));box-shadow:none;z-index:2}.task-list-v2 .task-card-v2-content{display:grid;grid-template-columns:3px 1fr auto;gap:0;padding:0;align-items:center}.task-list-v2 .task-card-priority-stripe{position:relative;width:3px;min-height:100%;align-self:stretch}.task-list-v2 .task-card-v2-inner{display:flex;flex-direction:column;gap:.2rem;padding:.65rem .85rem;min-width:0}.task-list-v2 .task-card-v2-right{display:flex;align-items:center;gap:.75rem;padding-right:.85rem;flex-shrink:0}.task-list-v2 .task-card-v2-header{margin-bottom:0}.task-list-v2 .task-card-v2-desc{margin-bottom:0;-webkit-line-clamp:1}.task-list-v2 .task-card-v2-tags{margin-bottom:0}.task-list-v2 .task-card-v2-footer{font-size:.73rem}.task-detail-layout{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:start}.task-detail-main{display:flex;flex-direction:column;gap:1.25rem}.task-detail-sidebar{display:flex;flex-direction:column;gap:1rem}.task-detail-card{padding:1.25rem}.task-detail-title{font-size:1.4rem;font-weight:700;margin-bottom:.25rem}.task-detail-description{font-size:.95rem;line-height:1.6;color:var(--color-text-muted);white-space:pre-wrap}.task-detail-meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:var(--color-text-muted)}.task-edit-form{display:flex;flex-direction:column;gap:1rem}.task-edit-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.sidebar-section{padding:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.sidebar-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.6rem}.sidebar-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}.status-pills,.priority-pills{display:flex;gap:.35rem;flex-wrap:wrap}.status-pill,.priority-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .65rem;font-size:.75rem;font-weight:500;border-radius:99px;border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;transition:all .15s}.status-pill.active,.priority-pill.active{color:#fff;border-color:transparent}.status-pill:not(.active):hover,.priority-pill:not(.active):hover{background:var(--color-bg)}.sidebar-due{font-size:.9rem;display:flex;align-items:center;gap:.4rem}.overdue{color:var(--color-danger)}.overdue-badge{font-size:.65rem;padding:.1rem .4rem;background:var(--color-danger);color:#fff;border-radius:99px;font-weight:600}.assignee-list{display:flex;flex-direction:column;gap:.4rem}.assignee-chip{display:flex;align-items:center;gap:.4rem;padding:.25rem .4rem;background:var(--color-bg);border-radius:var(--radius);font-size:.82rem}.assignee-chip .btn-icon-xs{margin-left:auto;opacity:0;transition:opacity .15s}.assignee-chip:hover .btn-icon-xs{opacity:1}.assign-dropdown{margin-top:.4rem;border:1px solid var(--color-border);border-radius:var(--radius);max-height:150px;overflow-y:auto;background:var(--color-surface)}.assign-option{display:flex;align-items:center;gap:.4rem;padding:.4rem .6rem;font-size:.82rem;cursor:pointer;border:none;background:none;width:100%;text-align:left}.assign-option:hover{background:var(--color-bg)}.comments-section{margin-top:.5rem}.section-heading{font-size:1rem;font-weight:600;margin-bottom:.75rem;display:flex;align-items:center;gap:.4rem}.comments-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.comment-item{display:flex;gap:.6rem;padding:.75rem;background:var(--color-bg);border-radius:var(--radius)}.comment-body{flex:1}.comment-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.25rem}.comment-author{font-weight:600;font-size:.82rem}.comment-date{font-size:.72rem;color:var(--color-text-muted)}.comment-text{font-size:.88rem;line-height:1.5;color:var(--color-text)}.comment-delete{margin-left:auto;opacity:0;transition:opacity .15s}.comment-item:hover .comment-delete{opacity:1}.comment-form{display:flex;gap:.5rem}.comment-input{flex:1}.comment-form input{width:100%;padding:.55rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.88rem}.comment-form button{white-space:nowrap}.comments-list-side{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem;max-height:400px;overflow-y:auto}.comment-item-side{padding:.5rem;background:var(--color-bg);border-radius:var(--radius)}.comment-item-side-header{display:flex;align-items:center;gap:.35rem;margin-bottom:.2rem;font-size:.78rem}.comment-text-side{font-size:.82rem;line-height:1.4;margin:0;padding-left:1.9rem}.comment-form-side{display:flex;gap:.4rem;margin-top:.5rem}.comment-form-side input{flex:1;padding:.4rem .6rem;font-size:.82rem;border:1px solid var(--color-border);border-radius:var(--radius)}.doc-editor-layout{display:flex;gap:1.25rem}.doc-editor-main{flex:1;min-width:0}.document-editor{padding:0;display:flex;flex-direction:column;overflow:hidden}.doc-toolbar-bar{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:color-mix(in srgb,var(--color-bg) 92%,transparent);border-bottom:1px solid var(--color-border);flex-wrap:wrap;position:sticky;top:0;z-index:8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.doc-toolbar-group{display:flex;align-items:center;gap:.25rem}.doc-toolbar-hint{margin-left:auto}.doc-toolbar-hint .muted{display:flex;align-items:center;gap:.25rem;font-size:.72rem}.doc-toolbar-hint kbd{display:inline-flex;align-items:center;padding:.05rem .35rem;font-family:inherit;font-size:.72rem;font-weight:600;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;box-shadow:0 1px 0 var(--color-border);line-height:1.4}.doc-tool-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .6rem;border:1px solid transparent;border-radius:var(--radius);background:transparent;font-size:.78rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:all .15s}.doc-tool-btn:hover{background:var(--color-bg);color:var(--color-text)}.doc-tool-btn.active{background:var(--color-primary-bg);color:var(--color-primary);border-color:var(--color-primary)}.doc-toolbar-shortcuts{display:inline-flex;align-items:center;gap:.35rem}.doc-toolbar-shortcuts kbd{display:inline-flex;align-items:center;padding:.05rem .35rem;font-size:.7rem;font-weight:600;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px}.doc-dir-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.doc-dir-toggle .doc-tool-btn{border:none;border-radius:0;padding:.25rem .5rem}.doc-dir-toggle .doc-tool-btn+.doc-tool-btn{border-left:1px solid var(--color-border)}.doc-dir-badge{font-size:.65rem;font-weight:700;padding:.1rem .4rem;border-radius:99px;letter-spacing:.04em;text-transform:uppercase}.doc-dir-badge.rtl{background:#fef3c7;color:#92400e}.doc-title-input{font-size:1.4rem;font-weight:700;border:none;border-bottom:2px solid var(--color-border);padding:1rem 1.25rem .6rem;background:transparent;width:100%;transition:border-color .2s;letter-spacing:-.01em}.doc-title-input:focus{outline:none;border-color:var(--color-primary)}[dir=rtl] .doc-title-input{text-align:right;font-family:Inter,Noto Sans Arabic,system-ui,sans-serif}.doc-title-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem .75rem;padding:.45rem 1.25rem .65rem;font-size:.74rem;color:var(--color-text-muted);border-bottom:1px dashed var(--color-border);background:color-mix(in srgb,var(--color-surface) 78%,transparent)}.doc-title-meta-item{display:inline-flex;align-items:center;gap:.25rem}.doc-title-meta-item strong{color:var(--color-text);font-weight:600}.doc-body-wrapper{position:relative;flex:1}.doc-body-editor{min-height:480px;border:none;padding:1rem 1.25rem;font-size:.95rem;line-height:1.8;background:transparent;font-family:Inter,system-ui,-apple-system,sans-serif;width:100%;outline:none;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;cursor:text;transition:background .15s}.doc-body-editor:focus{background:#ffffff59}.doc-body-editor[data-empty]:before{content:attr(data-placeholder);color:var(--color-text-muted);pointer-events:none;position:absolute;opacity:.7}[dir=rtl] .doc-body-editor{text-align:right;font-family:Inter,Noto Sans Arabic,system-ui,sans-serif}.mention-inline{display:inline-flex;align-items:center;gap:.15rem;padding:.05rem .4rem;border-radius:99px;font-size:.85em;font-weight:600;vertical-align:baseline;cursor:default;-webkit-user-select:all;user-select:all}.mention-inline.mention-user{background:#dbeafe;color:#1e40af}.mention-inline.mention-task{background:#d1fae5;color:#065f46}.mention-inline.mention-file{background:#fef3c7;color:#92400e}.doc-body-preview{min-height:480px;padding:1rem 1.25rem;font-size:.95rem;line-height:1.8;font-family:Inter,system-ui,sans-serif;word-wrap:break-word;overflow-wrap:break-word}.doc-body-preview>p{white-space:pre-wrap}.doc-body-preview p{margin:0 0 .15rem}.doc-body-preview .empty-line{min-height:1.8em}.doc-editor-footer{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;padding:.6rem 1.25rem;border-top:1px solid var(--color-border);background:var(--color-bg);gap:.75rem;flex-wrap:wrap}.doc-stats-group{display:flex;align-items:center;gap:.75rem;font-weight:500;color:var(--color-text-muted)}.doc-stat-item{display:inline-flex;align-items:center;gap:.2rem}.doc-stat-rtl{color:#92400e;font-weight:700}.doc-meta{text-align:right}.mention-chip{display:inline-flex;align-items:center;gap:.2rem;padding:.1rem .45rem;border-radius:99px;font-size:.82rem;font-weight:600;text-decoration:none;vertical-align:baseline;transition:background .15s,box-shadow .15s}.mention-chip svg{flex-shrink:0}.mention-user{background:#dbeafe;color:#1e40af}.mention-user:hover{background:#bfdbfe;text-decoration:none;color:#1e40af}.mention-task{background:#d1fae5;color:#065f46}.mention-task:hover{background:#a7f3d0;text-decoration:none;color:#065f46}.mention-file{background:#fef3c7;color:#92400e;border:none;cursor:pointer;font-family:inherit;line-height:inherit}.mention-file:hover{background:#fde68a;color:#92400e}.mention-popover{z-index:9999;width:300px;max-height:340px;overflow-y:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:.25rem}.mention-pop-header{display:flex;align-items:center;gap:.3rem;padding:.5rem .65rem .35rem;font-size:.7rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.mention-pop-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.45rem .65rem;border:none;border-radius:var(--radius);background:transparent;cursor:pointer;text-align:left;font-size:.82rem;transition:background .1s}.mention-pop-item:hover,.mention-pop-item.active{background:var(--color-bg)}.mention-pop-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.mention-type-task .mention-pop-icon{color:var(--color-success)}.mention-pop-info{flex:1;min-width:0;display:flex;flex-direction:column}.mention-pop-label{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mention-pop-secondary{font-size:.72rem;color:var(--color-text-muted)}.mention-type-badge{font-size:.62rem;font-weight:600;padding:.1rem .35rem;border-radius:99px;text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}.mention-type-badge.user{background:#dbeafe;color:#1e40af}.mention-type-badge.task{background:#d1fae5;color:#065f46}.mention-type-badge.file{background:#fef3c7;color:#92400e}.mention-type-file .mention-pop-icon{color:#d97706}.mention-pop-empty{padding:.65rem .75rem;font-size:.78rem;color:var(--color-text-muted)}.doc-save-status{font-size:.82rem}.save-indicator{display:inline-flex;align-items:center;gap:.3rem}.save-indicator.saving{color:var(--color-primary)}.save-indicator.unsaved{color:var(--color-warning)}.save-indicator.saved{color:var(--color-success)}.doc-side-panel{width:340px;flex-shrink:0;display:flex;flex-direction:column;gap:1rem;position:sticky;top:86px;max-height:calc(100vh - 108px);overflow-y:auto;padding-right:2px}.side-panel-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.side-panel-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);font-weight:600}.side-panel-header h3{display:flex;align-items:center;gap:.4rem;font-size:.9rem;margin:0}.side-panel-body{padding:.75rem 1rem}.version-list-v2{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem;max-height:350px;overflow-y:auto}.version-item-v2{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.45rem .5rem;border-radius:var(--radius);font-size:.8rem}.version-item-v2.current{background:var(--color-bg)}.version-info{display:flex;align-items:center;gap:.4rem}.version-author{font-weight:500}.version-date{color:var(--color-text-muted);font-size:.72rem}.badge-current{font-size:.65rem;background:var(--color-primary);color:#fff;padding:.1rem .4rem;border-radius:99px}.doc-toolbar{display:flex;gap:.75rem;margin-bottom:1.25rem}.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-bottom:1.25rem}.doc-card{display:flex;flex-direction:column;gap:.6rem;padding:1rem;text-decoration:none;color:inherit;transition:border-color var(--transition),box-shadow var(--transition-slow),transform var(--transition-slow)}.doc-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-card-hover);text-decoration:none;transform:translateY(-2px)}.doc-card:hover .doc-card-icon{color:var(--color-primary-hover)}.doc-card-header{display:flex;align-items:flex-start;gap:.5rem}.doc-card-icon{color:var(--color-primary);flex-shrink:0;margin-top:2px}.doc-card-title{font-size:.95rem;font-weight:600;line-height:1.3;margin:0}.doc-card-meta{display:flex;align-items:center;justify-content:space-between}.doc-card-meta-left{display:flex;align-items:center;gap:.35rem;font-size:.8rem}.doc-card-footer{display:flex;align-items:center;gap:.75rem;font-size:.75rem;color:var(--color-text-muted)}.doc-card-time{display:inline-flex;align-items:center;gap:.25rem}.doc-card-comments{display:inline-flex;align-items:center;gap:.2rem;color:var(--color-primary)}.doc-card-delete{margin-left:auto;opacity:0;transition:opacity .15s}.doc-card:hover .doc-card-delete{opacity:1}.doc-card-assignee{display:flex;align-items:center;gap:.35rem;font-size:.72rem;color:var(--color-text-muted);padding:.25rem .55rem;background:color-mix(in srgb,var(--color-primary) 8%,transparent);border-radius:99px;width:fit-content}.doc-card-assignee svg:first-child{color:var(--color-primary)}.doc-card-assignee span{font-weight:500;color:var(--color-text)}.doc-card-open-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;color:var(--color-text-muted);padding:.25rem .55rem;background:color-mix(in srgb,var(--color-success) 10%,transparent);border-radius:99px;width:fit-content}.doc-card-open-badge svg{color:var(--color-success)}.doc-card-updated-by{display:inline-flex;align-items:center;color:var(--color-text-muted)}.doc-conflict-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:#fbbf2414;border:1px solid rgba(251,191,36,.25);border-radius:8px;margin-bottom:.75rem;animation:fadeIn .3s ease}.doc-conflict-info{display:flex;align-items:flex-start;gap:.5rem;color:#fbbf24}.doc-conflict-info svg{flex-shrink:0;margin-top:2px}.doc-conflict-info div strong{display:block;font-weight:600;color:var(--color-text)}.doc-conflict-info div p{margin:.125rem 0 0;font-size:.85rem;color:var(--color-text-muted)}.doc-conflict-info div p em{font-style:normal;font-weight:600;color:#fbbf24}.doc-conflict-actions{display:flex;gap:.5rem;flex-shrink:0}.doc-compare-meta{font-size:.85rem;color:var(--color-text-muted);padding:.5rem 0;border-bottom:1px solid var(--color-border);margin-bottom:.75rem}.doc-compare-section{margin-bottom:.75rem}.doc-compare-section label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin-bottom:.25rem}.doc-compare-value{background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;padding:.625rem .75rem;font-size:.9rem;line-height:1.6;white-space:pre-wrap;word-break:break-word}.doc-compare-content{max-height:60vh;overflow-y:auto}.doc-compare-content p{margin:0}.doc-assignment-bar{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:.75rem;gap:.75rem;flex-wrap:wrap}.doc-assignment-info{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.doc-assignment-info>svg:first-child{color:var(--color-text-muted)}.doc-assignee-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .6rem .2rem .25rem;background:color-mix(in srgb,var(--color-primary) 10%,transparent);border-radius:99px;font-size:.82rem}.doc-assignee-chip strong{font-weight:600}.doc-readonly-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;background:color-mix(in srgb,var(--color-warning) 15%,transparent);color:#92400e;border-radius:99px;font-size:.75rem;font-weight:600}.doc-assignment-actions{display:flex;align-items:center;gap:.5rem;position:relative}.doc-readonly .doc-title-input{background:var(--color-bg);cursor:default;opacity:.85}.doc-readonly .doc-body-editor{background:var(--color-bg);cursor:default;opacity:.9}.doc-readonly .doc-toolbar-bar{opacity:.6;pointer-events:none}.assign-dropdown{position:absolute;top:calc(100% + 4px);right:0;width:280px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:200;overflow:hidden;animation:slideDown .15s ease-out}.assign-dropdown-search{padding:.5rem;border-bottom:1px solid var(--color-border)}.assign-dropdown-search input{width:100%;padding:.45rem .6rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.82rem;background:var(--color-bg);color:var(--color-text)}.assign-dropdown-search input:focus{outline:none;border-color:var(--color-primary)}.assign-dropdown-list{max-height:220px;overflow-y:auto;padding:.25rem}.assign-dropdown-item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.5rem .6rem;background:none;border:none;border-radius:var(--radius);color:var(--color-text);cursor:pointer;text-align:left;transition:background var(--transition);font-size:.82rem}.assign-dropdown-item:hover{background:var(--color-bg-hover)}.assign-dropdown-item.active{background:color-mix(in srgb,var(--color-primary) 10%,transparent)}.assign-dropdown-item-info{display:flex;flex-direction:column;flex:1;min-width:0}.assign-dropdown-item-info span:first-child{font-weight:500}.assign-dropdown-item-info .muted{font-size:.72rem}.assign-check{color:var(--color-primary)}.assign-dropdown-empty{padding:1rem;text-align:center;font-size:.82rem;color:var(--color-text-muted)}.btn-xs{padding:.2rem .5rem;font-size:.72rem;border-radius:var(--radius)}.btn-sm{padding:.35rem .65rem;font-size:.8rem}.btn-icon-xs{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:.15rem;border-radius:50%;color:var(--color-text-muted)}.btn-icon-xs:hover{color:var(--color-danger)}.btn-danger-outline{border:1px solid var(--color-danger);color:var(--color-danger);background:transparent}.btn-danger-outline:hover{background:var(--color-danger);color:#fff}@keyframes slideInRight{0%{transform:translate(30px);opacity:0}to{transform:translate(0);opacity:1}}.slide-in-right{animation:slideInRight .2s ease-out}.task-list-v2{display:flex;flex-direction:column;gap:.6rem}.kanban-column-title{display:inline-flex;align-items:center;gap:.4rem}.kanban-column-count{display:inline-flex;align-items:center;justify-content:center;background:var(--color-bg);font-size:.72rem;font-weight:600;min-width:22px;height:22px;padding:0 .35rem;border-radius:999px}.kanban-column:nth-child(1) .kanban-column-header{border-bottom-color:var(--color-text-muted)}.kanban-column:nth-child(2) .kanban-column-header{border-bottom-color:var(--color-primary)}.kanban-column:nth-child(3) .kanban-column-header{border-bottom-color:var(--color-success)}.priority-tag{background:color-mix(in srgb,var(--tag-color, var(--color-text-muted)) 12%,transparent);color:var(--tag-color, var(--color-text-muted));border:1px solid color-mix(in srgb,var(--tag-color, var(--color-text-muted)) 25%,transparent)}.status-pill.active,.priority-pill.active{background:var(--pill-color, var(--color-primary));border-color:var(--pill-color, var(--color-primary))}.task-card-v2{border-left:3px solid var(--color-border)}.task-card-v2.priority-low{border-left-color:var(--color-text-muted)}.task-card-v2.priority-medium{border-left-color:var(--color-info)}.task-card-v2.priority-high{border-left-color:var(--color-warning)}.task-card-v2.priority-urgent{border-left-color:var(--color-danger)}.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem;margin-bottom:1.25rem}.file-card{display:flex;align-items:center;gap:.85rem;padding:.85rem 1rem;transition:border-color var(--transition),box-shadow var(--transition-slow),transform var(--transition-slow)}.file-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.file-card:hover .file-card-icon{transform:scale(1.06)}.file-card-icon{width:42px;height:42px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform var(--transition-slow)}.file-card-icon.img{background:#f5f3ff;color:#7c3aed}.file-card-icon.video{background:#fef2f2;color:#dc2626}.file-card-icon.audio{background:#fffbeb;color:#d97706}.file-card-icon.doc{background:#eff6ff;color:#2563eb}.file-card-icon.archive{background:#f0fdf4;color:#059669}.file-card-icon.generic{background:var(--color-bg);color:var(--color-text-muted)}.file-card-info{flex:1;min-width:0}.file-card-name{font-weight:600;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-card-meta{font-size:.75rem;color:var(--color-text-muted);display:flex;align-items:center;gap:.5rem;margin-top:.15rem}.file-card-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .15s}.file-card:hover .file-card-actions{opacity:1}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding:2rem;border:2px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg);cursor:pointer;transition:all var(--transition-slow);margin-bottom:1.25rem;color:var(--color-text-muted);font-size:.875rem}.upload-zone:hover{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary);box-shadow:var(--shadow-focus)}.upload-zone.dragging{border-color:var(--color-primary);background:var(--color-primary-light)}.member-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.75rem}.member-card-v2{display:flex;flex-direction:column;gap:.6rem;padding:.85rem 1rem;transition:border-color var(--transition),box-shadow var(--transition-slow),transform var(--transition-slow)}.member-card-v2:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.member-card-v2.member-suspended{opacity:.6;border-color:var(--color-danger)}.member-card-v2-top{display:flex;align-items:center;gap:.85rem}.member-card-v2-info{flex:1;min-width:0;display:flex;flex-direction:column}.member-card-v2-name{font-weight:600;font-size:.92rem}.member-card-v2-username{font-size:.78rem;color:var(--color-text-muted)}.member-card-v2-email{font-size:.72rem;color:var(--color-text-muted)}.member-card-v2-bottom{display:flex;align-items:center;justify-content:space-between}.member-card-v2-badges{display:flex;gap:.35rem;align-items:center}.member-card-v2-actions{display:flex;gap:.35rem;flex-shrink:0;align-items:center}.badge-role{display:inline-flex;align-items:center;gap:.2rem;padding:.15rem .5rem;border-radius:999px;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-role.owner{background:#fef3c7;color:#92400e}.badge-role.admin{background:#eff6ff;color:#1d4ed8}.badge-role.member{background:var(--color-bg);color:var(--color-text-secondary)}.badge-status{display:inline-flex;align-items:center;gap:.2rem;padding:.15rem .5rem;border-radius:999px;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-status.active{background:#f0fdf4;color:#166534}.badge-status.suspended{background:#fef2f2;color:#991b1b}.badge-status.invited{background:#fffbeb;color:#92400e}.member-status-bar{display:flex;gap:.5rem;margin-bottom:.75rem}.member-status-chip{padding:.25rem .65rem;border-radius:999px;font-size:.72rem;font-weight:600}.member-status-chip.active{background:#f0fdf4;color:#166534}.member-status-chip.invited{background:#fffbeb;color:#92400e}.member-status-chip.suspended{background:#fef2f2;color:#991b1b}.invite-form-card{margin-bottom:1rem;padding:1.25rem}.invite-form-title{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1rem}.invite-result p{margin:.5rem 0}.invite-token-box{display:flex;align-items:center;gap:.5rem;margin:.75rem 0;padding:.6rem .85rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md)}.invite-token-value{flex:1;font-family:var(--font-mono);font-size:.82rem;word-break:break-all;color:var(--color-primary)}.member-role-menu-wrap{position:relative}.btn-xs{font-size:.72rem;padding:.2rem .5rem;gap:.25rem}.member-role-dropdown{position:absolute;top:100%;right:0;z-index:30;min-width:160px;margin-top:.25rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden}.member-role-dropdown button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.55rem .85rem;font-size:.82rem;background:none;border:none;cursor:pointer;color:var(--color-text);text-align:left}.member-role-dropdown button:hover{background:var(--color-bg-hover)}.member-role-dropdown button.active{background:var(--color-primary-subtle);color:var(--color-primary);font-weight:600}.ws-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.75rem;margin-bottom:1.5rem}.ws-stat-card{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:1rem;text-align:center}.ws-stat-card .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.ws-stat-card .stat-label{font-size:.78rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.ws-storage-bar-track{height:10px;background:var(--color-bg);border-radius:5px;overflow:hidden;margin:.75rem 0}.ws-storage-bar-fill{height:100%;border-radius:5px;transition:width .4s ease}.ws-storage-details{display:flex;justify-content:space-between;font-size:.78rem;color:var(--color-text-muted)}.settings-danger{border:1px solid var(--color-danger);border-radius:var(--radius-lg);padding:1.25rem;margin-top:2rem}.settings-danger h3{color:var(--color-danger);display:flex;align-items:center;gap:.4rem;margin:0 0 .35rem}.settings-danger p{color:var(--color-text-muted);font-size:.85rem;margin:0 0 .85rem}.confirm-delete-input{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);font-size:.85rem;margin-top:.5rem}.ws-role-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .85rem;border-radius:var(--radius-md);font-weight:600;font-size:.85rem;margin-bottom:1rem}.ws-role-badge.owner{background:#fef3c7;color:#92400e}.ws-role-badge.admin{background:#eff6ff;color:#1d4ed8}.ws-role-badge.member-role{background:var(--color-bg);color:var(--color-text-secondary)}.member-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:1rem}.member-tab{display:flex;align-items:center;gap:.4rem;padding:.65rem 1.2rem;border:none;background:none;cursor:pointer;font-size:.88rem;font-weight:500;color:var(--color-text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color var(--transition),border-color var(--transition)}.member-tab:hover{color:var(--color-text)}.member-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.tab-count{background:var(--color-bg);padding:.1rem .5rem;border-radius:999px;font-size:.72rem;font-weight:600}.member-tab.active .tab-count{background:var(--color-primary-subtle);color:var(--color-primary)}.invite-tokens-section{padding-top:.25rem}.invite-section-heading{display:flex;align-items:center;gap:.4rem;font-size:.9rem;font-weight:600;margin:0 0 .65rem;color:var(--color-text-secondary)}.invite-tokens-list{display:flex;flex-direction:column;gap:.5rem}.invite-token-card{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;transition:border-color var(--transition)}.invite-token-card:hover{border-color:var(--color-border-hover)}.invite-token-card.used{opacity:.7}.invite-token-card.expired{opacity:.5}.invite-token-card-left{display:flex;align-items:center;gap:.75rem;min-width:0}.invite-token-icon{flex-shrink:0}.invite-token-icon.pending{color:var(--color-warning)}.invite-token-icon.used{color:var(--color-success)}.invite-token-icon.expired{color:var(--color-text-muted)}.invite-token-label{font-weight:600;font-size:.88rem}.invite-token-meta{display:flex;align-items:center;gap:.5rem;margin-top:.15rem;font-size:.75rem;flex-wrap:wrap}.invite-token-time{color:var(--color-warning);font-weight:500}.audit-dot.action-create{background:var(--color-success)}.audit-dot.action-update{background:var(--color-primary)}.audit-dot.action-delete{background:var(--color-danger)}.audit-dot.action-auth{background:var(--color-warning)}.audit-filter-bar{display:flex;gap:.5rem;margin-bottom:1.25rem;flex-wrap:wrap}.audit-filter-bar select{padding:.45rem .6rem;font-size:.82rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface)}.audit-target-detail{font-size:.82rem;color:var(--color-text-secondary);margin-bottom:.3rem;word-break:break-all}.audit-action{font-weight:600;font-size:.85rem}.settings-grid{max-width:600px}.settings-section .form-group label{margin-bottom:.3rem}.settings-section form{display:flex;flex-direction:column;gap:0}.page{max-width:1120px}.filter-select{padding:.45rem .65rem;font-size:.82rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;transition:border-color .15s}.filter-select:hover{border-color:var(--color-border-hover)}.badge.action-create{background:color-mix(in srgb,#22c55e 15%,transparent);color:#16a34a}.badge.action-update{background:color-mix(in srgb,#3b82f6 15%,transparent);color:#2563eb}.badge.action-delete{background:color-mix(in srgb,#ef4444 15%,transparent);color:#dc2626}.badge.action-auth{background:color-mix(in srgb,#a855f7 15%,transparent);color:#9333ea}.audit-target-detail{display:flex;align-items:center;gap:.5rem}.audit-target-type{font-weight:600;text-transform:capitalize}.audit-target-id{font-family:var(--font-mono, monospace);font-size:.75rem;background:var(--color-bg);padding:.15rem .45rem;border-radius:var(--radius-sm, 4px);color:var(--color-text-secondary)}.settings-profile-banner{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;margin-bottom:1.5rem;background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 6%,var(--color-surface)),var(--color-surface))}.settings-profile-info{display:flex;flex-direction:column;gap:.25rem}.settings-profile-name{font-size:1.25rem;font-weight:700;color:var(--color-text);margin:0}.settings-profile-meta{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--color-text-secondary)}@media(max-width:900px){.kanban-board{grid-template-columns:1fr;gap:1.5rem}.task-detail-layout{grid-template-columns:1fr}.doc-editor-layout{flex-direction:column}.doc-side-panel{width:100%;position:static;max-height:none;overflow:visible;padding-right:0}.doc-grid,.file-grid,.member-grid{grid-template-columns:1fr}}.page-loading{display:flex;align-items:center;justify-content:center;padding:6rem 1rem;flex-direction:column;gap:1rem}.main-content::-webkit-scrollbar{width:5px}.main-content::-webkit-scrollbar-thumb{background:#94a3b859;border-radius:6px}.main-content::-webkit-scrollbar-thumb:hover{background:#94a3b88c}.breadcrumb-sub{max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.alert-info{padding:1.5rem;text-align:center;font-weight:500}.task-card-v2-title a{transition:color var(--transition-fast)}.doc-card-icon{transition:color var(--transition)}.btn-icon{transition:all var(--transition)}.btn-icon:hover{background:var(--color-bg);color:var(--color-text);box-shadow:var(--shadow-xs)}.settings-section{padding:1.5rem}.auth-hero{background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a)}.page.fade-in{animation:fadeIn .3s cubic-bezier(.4,0,.2,1)}.sidebar-workspace{padding:.5rem .75rem .25rem;position:relative}.ws-switcher-btn{width:100%;display:flex;align-items:center;gap:.6rem;padding:.5rem .6rem;background:var(--color-sidebar-hover);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);color:#fff;cursor:pointer;transition:all var(--transition);text-align:left}.ws-switcher-btn:hover{background:#ffffff1f;border-color:#ffffff26}.ws-switcher-avatar{width:28px;height:28px;border-radius:6px;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0}.ws-switcher-info{flex:1;min-width:0;display:flex;flex-direction:column}.ws-switcher-name{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-switcher-role{font-size:.68rem;color:#ffffff73;text-transform:capitalize}.ws-switcher-chevron{flex-shrink:0;opacity:.5;transition:transform .2s}.ws-switcher-chevron.open{transform:rotate(180deg)}.ws-dropdown{position:absolute;top:calc(100% + 4px);left:.75rem;right:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:200;overflow:hidden;animation:slideDown .15s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.ws-dropdown-header{padding:.6rem .75rem .35rem;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.ws-dropdown-list{max-height:220px;overflow-y:auto;padding:.25rem}.ws-dropdown-item{width:100%;display:flex;align-items:center;gap:.6rem;padding:.5rem .6rem;background:none;border:none;border-radius:var(--radius);color:var(--color-text);cursor:pointer;text-align:left;transition:background var(--transition)}.ws-dropdown-item:hover{background:var(--color-bg-hover)}.ws-dropdown-item.active{background:color-mix(in srgb,var(--color-primary) 12%,transparent)}.ws-dropdown-item-avatar{width:26px;height:26px;border-radius:6px;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.7rem;flex-shrink:0}.ws-dropdown-item-info{flex:1;min-width:0;display:flex;flex-direction:column}.ws-dropdown-item-name{font-size:.82rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-dropdown-item-role{font-size:.68rem;color:var(--color-text-muted);text-transform:capitalize}.ws-dropdown-check{color:var(--color-primary);font-weight:700;font-size:.85rem}.ws-dropdown-footer{border-top:1px solid var(--color-border);padding:.35rem}.ws-dropdown-create{width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem .6rem;background:none;border:none;border-radius:var(--radius);color:var(--color-primary);cursor:pointer;font-size:.82rem;font-weight:500;transition:background var(--transition)}.ws-dropdown-create:hover{background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:480px;animation:slideUp .25s cubic-bezier(.4,0,.2,1)}.modal-content .modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border)}.modal-content .modal-header h2{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1rem}.modal-close{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.25rem;border-radius:var(--radius);transition:all var(--transition)}.modal-close:hover{background:var(--color-bg-hover);color:var(--color-text)}.modal-content form{padding:1.25rem}.modal-content .form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.btn-ghost{background:none;border:1px solid var(--color-border);color:var(--color-text);padding:.5rem 1rem;border-radius:var(--radius);cursor:pointer;font-size:.85rem;transition:all var(--transition)}.btn-ghost:hover{background:var(--color-bg-hover)}.btn-outline{background:none;border:1px solid var(--color-primary);color:var(--color-primary);padding:.5rem 1rem;border-radius:var(--radius);cursor:pointer;font-size:.85rem;font-weight:500;display:inline-flex;align-items:center;gap:.4rem;transition:all var(--transition)}.btn-outline:hover{background:color-mix(in srgb,var(--color-primary) 10%,transparent)}.btn-danger-text{color:var(--color-danger)!important}.btn-danger-text:hover{background:color-mix(in srgb,var(--color-danger) 10%,transparent)!important}.admin-summary-row{display:flex;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.admin-summary-card{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex:1;min-width:160px}.admin-summary-card svg{color:var(--color-primary);flex-shrink:0}.admin-summary-card div{display:flex;flex-direction:column}.admin-summary-card strong{font-size:1.25rem;font-weight:700;line-height:1.2}.admin-summary-card span{font-size:.75rem;color:var(--color-text-muted)}.admin-ws-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.search-input-wrap{display:flex;align-items:center;gap:.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:0 .75rem;flex:1;max-width:360px;transition:border-color var(--transition)}.search-input-wrap:focus-within{border-color:var(--color-primary)}.search-input-wrap svg{color:var(--color-text-muted);flex-shrink:0}.search-input-wrap .search-input{border:none;background:none;padding:.55rem 0;font-size:.85rem;color:var(--color-text);width:100%;outline:none}.admin-ws-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.admin-ws-card{padding:1.25rem;display:flex;flex-direction:column;gap:.85rem;transition:box-shadow var(--transition),border-color var(--transition)}.admin-ws-card:hover{border-color:var(--color-primary);box-shadow:0 4px 16px #00000014}.admin-ws-card-header{display:flex;align-items:center;gap:.7rem}.admin-ws-card-avatar{width:36px;height:36px;border-radius:8px;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}.admin-ws-card-title{flex:1;min-width:0}.admin-ws-card-title h3{margin:0;font-size:1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-ws-slug{font-size:.75rem;color:var(--color-text-muted)}.admin-ws-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.admin-ws-stat{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.4rem 0;background:var(--color-bg);border-radius:var(--radius)}.admin-ws-stat svg{color:var(--color-text-muted)}.admin-ws-stat span{font-size:.9rem;font-weight:600}.admin-ws-stat label{font-size:.65rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.admin-ws-storage{display:flex;flex-direction:column;gap:.3rem}.admin-ws-storage-bar{height:4px;background:var(--color-border);border-radius:2px;overflow:hidden}.admin-ws-storage-fill{height:100%;border-radius:2px;transition:width .4s ease}.admin-ws-storage-label{font-size:.72rem;color:var(--color-text-muted)}.admin-ws-meta{display:flex;align-items:center;gap:.4rem}.admin-ws-meta .muted{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem}.admin-ws-actions{display:flex;justify-content:flex-end;gap:.5rem;border-top:1px solid var(--color-border);padding-top:.75rem;margin-top:.25rem}.file-preview-overlay{position:fixed;inset:0;z-index:10000;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:2rem;animation:fadeIn .2s ease}.file-preview-modal{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:0 25px 60px #00000059;width:100%;max-width:880px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .25s ease;transition:max-width .3s ease,max-height .3s ease}.file-preview-modal.expanded{max-width:98vw;max-height:96vh}.file-preview-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;border-bottom:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0}.file-preview-title{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1}.file-preview-title svg{flex-shrink:0;color:var(--color-primary)}.file-preview-name{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-preview-size{font-size:.78rem;color:var(--color-text-muted);flex-shrink:0;background:var(--color-surface);padding:.1rem .45rem;border-radius:99px;border:1px solid var(--color-border)}.file-preview-actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0;margin-left:1rem}.file-preview-body{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;min-height:300px;background:var(--color-bg)}.file-preview-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem;color:var(--color-text-muted)}.file-preview-unsupported{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem;text-align:center;color:var(--color-text-muted)}.file-preview-unsupported h3{font-size:1.1rem;color:var(--color-text);margin:0}.file-preview-unsupported p{margin:0;font-size:.9rem;max-width:320px}.file-preview-image{display:flex;align-items:center;justify-content:center;padding:1rem;width:100%;height:100%}.file-preview-image img{max-width:100%;max-height:70vh;object-fit:contain;border-radius:var(--radius);box-shadow:0 2px 12px #0000001a}.file-preview-modal.expanded .file-preview-image img{max-height:90vh}.file-preview-video{width:100%;display:flex;align-items:center;justify-content:center;padding:1rem}.file-preview-video video{max-width:100%;max-height:70vh;border-radius:var(--radius)}.file-preview-audio{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:3rem;width:100%}.file-preview-audio-art{width:140px;height:140px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 30px #6366f14d}.file-preview-audio audio{width:100%;max-width:420px}.file-preview-pdf{width:100%;height:100%;min-height:600px}.file-preview-pdf iframe{width:100%;height:100%;min-height:600px;border:none}.file-preview-modal.expanded .file-preview-pdf,.file-preview-modal.expanded .file-preview-pdf iframe{min-height:85vh}.file-preview-text{width:100%;height:100%;overflow:auto;padding:1.25rem}.file-preview-text pre{margin:0;font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.85rem;line-height:1.65;white-space:pre-wrap;word-break:break-word;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem 1.25rem}@keyframes slideUp{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse-soft{0%,to{transform:scale(1);box-shadow:0 8px 32px #2563eb26}50%{transform:scale(1.05);box-shadow:0 12px 40px #2563eb40}}.skeleton{background:linear-gradient(90deg,var(--color-bg) 25%,#e2e8f0 37%,var(--color-bg) 63%);background-size:200% 100%;animation:shimmer 1.8s ease-in-out infinite;border-radius:var(--radius)}.skeleton-card{display:flex;flex-direction:column;gap:.65rem;padding:1.15rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.skeleton-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0}.skeleton-title{height:1rem;width:75%;border-radius:6px}.skeleton-text{height:.75rem;width:100%;border-radius:4px;margin-bottom:.25rem}.skeleton-row{display:flex;align-items:center;gap:.65rem}*::-webkit-scrollbar{width:6px;height:6px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:6px}*::-webkit-scrollbar-thumb:hover{background:#94a3b880}@media print{.sidebar,.top-bar,.sidebar-footer,.btn,.toast-container{display:none!important}.main-content{padding:0!important}.app-shell{display:block!important}}.doc-todo-group{background:var(--color-surface);border:1px solid color-mix(in srgb,var(--color-border) 45%,transparent);border-radius:14px;margin:1.15rem 0;overflow:hidden;box-shadow:0 1px 3px #0000000a,0 4px 14px #00000005;transition:box-shadow .2s}.doc-todo-group:hover{box-shadow:0 2px 6px #0000000f,0 6px 20px #00000008}.doc-todo-group-header{display:flex;flex-direction:column;gap:.45rem;padding:.7rem .95rem .6rem;background:color-mix(in srgb,var(--color-primary) 3%,var(--color-bg));border-bottom:1px solid color-mix(in srgb,var(--color-border) 35%,transparent)}.doc-todo-group-title{display:flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary)}.doc-todo-group-title svg{color:var(--color-primary)}.doc-todo-group-count{margin-left:auto;font-weight:600;font-size:.68rem;color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,transparent);padding:.1rem .45rem;border-radius:99px;letter-spacing:.02em}.doc-todo-progress{width:100%;height:4px;background:color-mix(in srgb,var(--color-border) 40%,transparent);border-radius:99px;overflow:hidden}.doc-todo-progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary),#8b5cf6);border-radius:99px;transition:width .45s cubic-bezier(.4,0,.2,1);min-width:0}.doc-todo-list{padding:.2rem 0}.doc-todo-item{display:flex;align-items:flex-start;gap:.7rem;padding:.55rem .95rem;cursor:pointer;transition:background .12s;font-size:.9rem;line-height:1.55;position:relative}.doc-todo-item+.doc-todo-item{border-top:1px solid color-mix(in srgb,var(--color-border) 18%,transparent)}.doc-todo-item:hover{background:color-mix(in srgb,var(--color-primary) 3%,transparent)}.doc-todo-item.checked{background:color-mix(in srgb,var(--color-primary) 1.5%,transparent)}.doc-todo-check{position:relative;width:20px;height:20px;min-width:20px;margin-top:1px}.doc-todo-check input[type=checkbox]{appearance:none;-webkit-appearance:none;width:20px;height:20px;border:2px solid color-mix(in srgb,var(--color-text) 18%,transparent);border-radius:6px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);background:var(--color-surface);margin:0}.doc-todo-check input[type=checkbox]:disabled{cursor:default;opacity:.65}.doc-todo-item:hover .doc-todo-check input[type=checkbox]:not(:checked){border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 8%,transparent)}.doc-todo-check input[type=checkbox]:checked{background:linear-gradient(135deg,var(--color-primary),#7c3aed);border-color:transparent;box-shadow:0 2px 6px color-mix(in srgb,var(--color-primary) 30%,transparent)}.doc-todo-tick{position:absolute;top:3px;left:3px;width:14px;height:14px;pointer-events:none;fill:none;stroke:#fff;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;opacity:0;transform:scale(.5);transition:all .2s cubic-bezier(.34,1.56,.64,1)}.doc-todo-check input[type=checkbox]:checked~.doc-todo-tick{opacity:1;transform:scale(1)}.doc-todo-text{flex:1;transition:all .25s;padding-top:1px}.doc-todo-item.checked .doc-todo-text{text-decoration:line-through;opacity:.35;color:var(--color-text-secondary)}.doc-table-wrap{margin:1.15rem 0;border-radius:14px;border:1px solid color-mix(in srgb,var(--color-border) 45%,transparent);background:var(--color-surface);box-shadow:0 1px 3px #0000000a,0 4px 14px #00000005;overflow:hidden;transition:box-shadow .2s}.doc-table-wrap:hover{box-shadow:0 2px 6px #0000000f,0 6px 20px #00000008}.doc-table-chrome{display:flex;align-items:center;gap:.6rem;padding:.5rem .85rem;background:color-mix(in srgb,var(--color-bg) 80%,var(--color-surface));border-bottom:1px solid color-mix(in srgb,var(--color-border) 35%,transparent)}.doc-table-chrome-dots{display:flex;gap:5px}.doc-table-chrome-dots span{width:8px;height:8px;border-radius:50%}.doc-table-chrome-dots span:nth-child(1){background:#ef4444}.doc-table-chrome-dots span:nth-child(2){background:#eab308}.doc-table-chrome-dots span:nth-child(3){background:#22c55e}.doc-table-chrome-title{display:flex;align-items:center;gap:.35rem;font-size:.68rem;font-weight:600;color:var(--color-text-secondary);letter-spacing:.02em}.doc-table-chrome-title svg{color:var(--color-primary);opacity:.7}.doc-table-scroll{overflow-x:auto}.doc-table{width:100%;border-collapse:collapse;font-size:.85rem}.doc-table th{padding:.6rem .85rem;text-align:left;font-weight:650;font-size:.76rem;color:var(--color-text);background:color-mix(in srgb,var(--color-bg) 50%,var(--color-surface));border-bottom:2px solid color-mix(in srgb,var(--color-primary) 18%,var(--color-border));white-space:nowrap}.doc-table-row-num{width:36px;min-width:36px;text-align:center!important;color:var(--color-text-secondary)!important;font-size:.7rem!important;font-weight:500!important;opacity:.5;background:color-mix(in srgb,var(--color-bg) 60%,var(--color-surface))!important;border-right:1px solid color-mix(in srgb,var(--color-border) 25%,transparent)!important;-webkit-user-select:none;user-select:none}.doc-table td{padding:.55rem .85rem;text-align:left;border-bottom:1px solid color-mix(in srgb,var(--color-border) 22%,transparent);color:var(--color-text)}.doc-table tbody tr:last-child td{border-bottom:none}.doc-table tbody tr{transition:background .1s}.doc-table tbody tr:nth-child(2n) td:not(.doc-table-row-num){background:color-mix(in srgb,var(--color-bg) 25%,transparent)}.doc-table tbody tr:hover td:not(.doc-table-row-num){background:color-mix(in srgb,var(--color-primary) 5%,transparent)}.doc-divider{border:none;height:1px;background:linear-gradient(90deg,transparent 5%,var(--color-border) 50%,transparent 95%);margin:1.5rem 0}.doc-body-preview h2.doc-heading,.ai-sb-result-text h2.doc-heading{font-size:1.4rem;font-weight:700;margin:1.5rem 0 .5rem;color:var(--color-text);letter-spacing:-.02em;line-height:1.3;position:relative;padding-bottom:.3rem}.doc-body-preview h2.doc-heading:after,.ai-sb-result-text h2.doc-heading:after{content:"";position:absolute;bottom:0;left:0;width:28px;height:3px;border-radius:2px;background:linear-gradient(90deg,var(--color-primary),#a855f7)}.doc-body-preview h3.doc-heading,.ai-sb-result-text h3.doc-heading{font-size:1.1rem;font-weight:600;margin:1.15rem 0 .35rem;color:var(--color-text);letter-spacing:-.01em}.doc-blockquote{border-left:3px solid linear-gradient(to bottom,var(--color-primary),#a855f7);border-left:3px solid var(--color-primary);padding:.65rem 1rem;margin:1rem 0;background:color-mix(in srgb,var(--color-primary) 4%,var(--color-surface));border-radius:0 10px 10px 0;color:var(--color-text-secondary);font-size:.92rem;line-height:1.6;position:relative}.doc-blockquote:before{content:'"';position:absolute;top:-4px;left:8px;font-size:2rem;font-family:Georgia,serif;color:color-mix(in srgb,var(--color-primary) 25%,transparent);line-height:1}.doc-blockquote p{margin:.15rem 0;padding-left:.75rem}[dir=rtl] .doc-body-preview h2.doc-heading:after{left:auto;right:0}[dir=rtl] .doc-blockquote{border-left:none;border-right:3px solid var(--color-primary);border-radius:10px 0 0 10px}[dir=rtl] .doc-blockquote:before{left:auto;right:8px}[dir=rtl] .doc-blockquote p{padding-left:0;padding-right:.75rem}[dir=rtl] .doc-table th,[dir=rtl] .doc-table td{text-align:right}[dir=rtl] .doc-table-row-num{border-right:none!important;border-left:1px solid color-mix(in srgb,var(--color-border) 25%,transparent)!important}[dir=rtl] .doc-todo-group-count{margin-left:0;margin-right:auto}[dir=rtl] .doc-code-block:before{right:auto;left:10px}.doc-code-block{background:#1e1e2e;border:1px solid color-mix(in srgb,var(--color-border) 40%,transparent);border-radius:10px;padding:1.6rem 1.15rem 1rem;margin:1rem 0;overflow-x:auto;font-size:.82rem;line-height:1.7;position:relative}.doc-code-block code{font-family:JetBrains Mono,Fira Code,Cascadia Code,SF Mono,monospace;color:#cdd6f4}.doc-code-block:before{content:attr(data-lang,"CODE");position:absolute;top:6px;right:10px;font-size:.6rem;font-weight:700;letter-spacing:.08em;color:#585b70;font-family:var(--font-sans);text-transform:uppercase}.doc-code-block:not([data-lang]):before{content:"CODE"}.doc-code-block[data-lang]:before{content:attr(data-lang);color:#89b4fa;background:#89b4fa14;padding:.1rem .4rem;border-radius:4px}.doc-block-btns{gap:.1rem!important;border-left:1px solid var(--color-border);padding-left:.4rem;margin-left:.15rem}.doc-block-btns .doc-tool-btn{padding:.3rem .35rem;min-width:28px;border-radius:6px}.doc-block-btns .doc-tool-btn:hover{background:color-mix(in srgb,var(--color-primary) 10%,transparent);color:var(--color-primary)}.doc-toolbar-right{margin-left:auto!important;gap:.5rem!important}.doc-ai-trigger{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .6rem;border-radius:99px;border:1px solid color-mix(in srgb,#8b5cf6 30%,transparent);background:linear-gradient(135deg,#8b5cf614,#a855f714);color:#8b5cf6;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;letter-spacing:.01em}.doc-ai-trigger:hover{background:linear-gradient(135deg,#8b5cf626,#a855f726);border-color:#8b5cf6;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf633}.doc-ai-trigger.active{background:linear-gradient(135deg,#8b5cf6,#a855f7);color:#fff;border-color:transparent;box-shadow:0 4px 16px #8b5cf659}.doc-ai-trigger:hover svg{animation:sparkle .5s ease}@keyframes sparkle{0%,to{transform:scale(1) rotate(0)}30%{transform:scale(1.2) rotate(-12deg)}60%{transform:scale(.9) rotate(8deg)}}.ai-overlay{position:fixed;inset:0;z-index:9998;background:#00000014;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);animation:aiFadeIn .2s ease}@keyframes aiFadeIn{0%{opacity:0}to{opacity:1}}.ai-sidebar{position:fixed;top:0;right:0;bottom:0;width:340px;max-width:90vw;z-index:9999;background:var(--color-surface);border-left:1px solid var(--color-border);box-shadow:-8px 0 40px #00000014;display:flex;flex-direction:column;animation:aiSlideIn .3s cubic-bezier(.4,0,.2,1)}@keyframes aiSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ai-sb-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,color-mix(in srgb,#8b5cf6 4%,var(--color-surface)),color-mix(in srgb,#a855f7 4%,var(--color-surface)));flex-shrink:0}.ai-sb-title{display:flex;align-items:center;gap:.4rem;font-weight:700;font-size:.9rem;color:#8b5cf6}.ai-sb-title svg{color:#8b5cf6}.ai-sb-quota{font-size:.65rem;font-weight:500;background:color-mix(in srgb,#8b5cf6 10%,transparent);color:#8b5cf6;padding:.1rem .4rem;border-radius:99px;margin-left:.25rem}.ai-sb-cached{font-size:.65rem;font-weight:600;background:color-mix(in srgb,var(--color-success) 16%,transparent);color:var(--color-success);padding:.1rem .42rem;border-radius:99px;margin-left:.12rem}.ai-sb-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.ai-sb-close:hover{background:color-mix(in srgb,var(--color-text) 8%,transparent);color:var(--color-text)}.ai-sb-body{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.65rem}.ai-sb-section{display:flex;flex-direction:column;gap:.3rem}.ai-sb-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);padding:0 .15rem}.ai-sb-actions{display:flex;flex-wrap:wrap;gap:.25rem}.ai-sb-context{display:grid;grid-template-columns:1fr 1fr;gap:.3rem}.ai-sb-context-btn{border:1px solid color-mix(in srgb,var(--color-border) 80%,transparent);background:var(--color-surface);color:var(--color-text-secondary);border-radius:8px;font-size:.74rem;font-weight:600;padding:.32rem .55rem;cursor:pointer;transition:all .15s}.ai-sb-context-btn:hover:not(:disabled){border-color:#8b5cf6;color:#8b5cf6}.ai-sb-context-btn.active{border-color:transparent;background:linear-gradient(135deg,#8b5cf6,#a855f7);color:#fff}.ai-sb-context-btn:disabled{opacity:.45;cursor:not-allowed}.ai-sb-context-note{font-size:.72rem;color:var(--color-text-secondary);background:color-mix(in srgb,var(--color-bg) 70%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 55%,transparent);border-radius:8px;padding:.35rem .5rem}.ai-sb-context-preview{font-size:.75rem;color:var(--color-text);background:color-mix(in srgb,#8b5cf6 5%,var(--color-surface));border:1px solid color-mix(in srgb,#8b5cf6 25%,var(--color-border));border-radius:8px;padding:.42rem .55rem;line-height:1.45;max-height:5.8rem;overflow-y:auto;white-space:pre-wrap}.ai-sb-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.28rem .5rem;border-radius:7px;border:1px solid color-mix(in srgb,var(--color-border) 80%,transparent);background:var(--color-surface);font-size:.74rem;font-weight:500;color:var(--color-text);cursor:pointer;transition:all .18s;white-space:nowrap}.ai-sb-btn:hover:not(:disabled){border-color:#8b5cf6;background:color-mix(in srgb,#8b5cf6 8%,transparent);color:#8b5cf6;transform:translateY(-1px);box-shadow:0 2px 8px #8b5cf61a}.ai-sb-btn:disabled{opacity:.45;cursor:not-allowed}.ai-sb-btn.loading{border-color:#8b5cf6;background:linear-gradient(135deg,#8b5cf61a,#a855f71a);color:#8b5cf6;animation:pulseChip 1.5s ease infinite}@keyframes pulseChip{0%,to{opacity:1}50%{opacity:.6}}.ai-sb-custom{display:flex;gap:.3rem;padding-top:.15rem;border-top:1px solid color-mix(in srgb,var(--color-border) 40%,transparent)}.ai-sb-input{flex:1;padding:.4rem .65rem;border:1px solid var(--color-border);border-radius:8px;font-size:.8rem;background:var(--color-bg);color:var(--color-text);transition:all .15s}.ai-sb-input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.ai-sb-input::placeholder{color:var(--color-text-secondary);opacity:.5}.ai-sb-send{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;border:none;background:linear-gradient(135deg,#8b5cf6,#a855f7);color:#fff;cursor:pointer;transition:all .15s;flex-shrink:0}.ai-sb-send:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.ai-sb-send:disabled{opacity:.35;cursor:not-allowed}.ai-sb-loading{display:flex;align-items:center;gap:.5rem;padding:.75rem .5rem;color:#8b5cf6;font-size:.8rem;font-weight:500}.ai-sb-dots{display:flex;gap:3px}.ai-sb-dots span{width:6px;height:6px;border-radius:50%;background:#8b5cf6;animation:aiDotBounce 1.4s ease infinite}.ai-sb-dots span:nth-child(2){animation-delay:.2s}.ai-sb-dots span:nth-child(3){animation-delay:.4s}@keyframes aiDotBounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.ai-sb-error{display:flex;align-items:center;gap:.35rem;padding:.4rem .6rem;border-radius:8px;background:color-mix(in srgb,var(--color-danger) 8%,transparent);border:1px solid color-mix(in srgb,var(--color-danger) 20%,transparent);color:var(--color-danger);font-size:.78rem}.ai-sb-result{border-radius:10px;border:1px solid color-mix(in srgb,#8b5cf6 15%,var(--color-border));overflow:hidden;background:var(--color-surface);animation:aiResultIn .3s ease}@keyframes aiResultIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ai-sb-result-text{padding:.65rem .75rem;max-height:340px;overflow-y:auto;font-size:.83rem;line-height:1.65;color:var(--color-text);background:color-mix(in srgb,#8b5cf6 3%,transparent)}.ai-sb-result-text p{margin:.15rem 0}.ai-sb-result-text .doc-todo-group,.ai-sb-result-text .doc-table-wrap{margin:.5rem 0;font-size:.8rem}.ai-sb-result-text .doc-todo-group-header{padding:.4rem .65rem .35rem}.ai-sb-result-text .doc-todo-group-title{font-size:.62rem}.ai-sb-result-text .doc-todo-item{padding:.35rem .65rem;font-size:.8rem}.ai-sb-result-text .doc-table-chrome{padding:.35rem .65rem}.ai-sb-result-text .doc-code-block{margin:.5rem 0;font-size:.75rem;padding:1.4rem .85rem .6rem}.ai-sb-result-text .doc-heading{font-size:.95rem;margin:.5rem 0 .25rem}.ai-sb-result-text .doc-blockquote{margin:.5rem 0;font-size:.8rem;padding:.4rem .7rem}.ai-sb-result-text .doc-divider{margin:.75rem 0}.ai-sb-result-bar{display:flex;gap:.25rem;padding:.4rem .5rem;border-top:1px solid color-mix(in srgb,var(--color-border) 50%,transparent);background:var(--color-surface)}.ai-sb-action-btn{display:inline-flex;align-items:center;gap:.2rem;padding:.25rem .5rem;border-radius:6px;border:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);background:transparent;font-size:.72rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.ai-sb-action-btn:hover{background:color-mix(in srgb,var(--color-text) 6%,transparent);color:var(--color-text);border-color:var(--color-border)}.ai-sb-action-btn.primary{background:linear-gradient(135deg,#8b5cf6,#a855f7);color:#fff;border:none}.ai-sb-action-btn.primary:hover{box-shadow:0 2px 8px #8b5cf640;transform:translateY(-1px)}@media(max-width:640px){.ai-sidebar{width:100%;max-width:100vw}}body{background:radial-gradient(circle at 14% -16%,rgba(37,99,235,.08) 0%,transparent 46%),radial-gradient(circle at 88% -22%,rgba(14,165,233,.07) 0%,transparent 44%),var(--color-bg)}.main-area{background:linear-gradient(180deg,#ffffff9e,#fff3)}.main-content{padding:clamp(1rem,2.1vw,1.9rem) clamp(.9rem,2.2vw,2rem);scrollbar-gutter:stable}.page{width:min(var(--layout-max-width),100%);margin-inline:auto;display:flex;flex-direction:column;gap:1rem}.page-header{margin-bottom:0;padding:.1rem 0 .95rem;border-bottom:1px solid color-mix(in srgb,var(--color-border) 76%,transparent)}.page-header h1{font-size:clamp(1.3rem,1.2vw + 1rem,1.72rem);letter-spacing:-.018em}.page-header-actions{gap:.45rem;flex-wrap:wrap}.top-bar{border-bottom:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);background:#ffffffe0}.workspace-badge{border:1px solid color-mix(in srgb,var(--color-primary) 20%,transparent);box-shadow:inset 0 1px #ffffffd9}.btn{min-height:var(--control-height);border-radius:10px;font-weight:600}.btn-sm{min-height:var(--control-height-sm)}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn-icon{width:36px;height:36px;border-radius:10px;border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent)}.btn-icon:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-icon:active{transform:translateY(0)}.search-input-wrapper{max-width:430px;min-width:min(300px,100%)}.search-input,.filter-select,.status-select,.search-input-wrap .search-input{min-height:var(--control-height);border-radius:10px}.search-input{background:color-mix(in srgb,var(--color-surface) 90%,var(--color-bg))}.search-input-wrap{min-height:var(--control-height);border-radius:10px}:is(.doc-toolbar,.task-toolbar,.admin-ws-toolbar){display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;padding:.55rem .65rem;border:1px solid color-mix(in srgb,var(--color-border) 82%,transparent);border-radius:12px;background:var(--surface-soft);box-shadow:var(--shadow-xs);margin-bottom:1rem}.doc-toolbar-right{margin-left:auto;display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.audit-filter-bar{margin-bottom:0;align-items:center}.card{border-color:color-mix(in srgb,var(--color-border) 78%,transparent);box-shadow:var(--shadow-xs)}.card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.table-wrapper.card{border:1px solid color-mix(in srgb,var(--color-border) 80%,transparent);border-radius:14px;box-shadow:var(--shadow-xs)}thead{background:color-mix(in srgb,var(--color-surface) 78%,var(--color-bg));-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}tbody tr:nth-child(2n){background:color-mix(in srgb,var(--color-bg) 42%,transparent)}tbody tr:hover{background:color-mix(in srgb,var(--color-primary) 7%,transparent)}.empty-state{border:1px dashed color-mix(in srgb,var(--color-border) 70%,transparent);border-radius:16px;background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface) 95%,transparent),color-mix(in srgb,var(--color-bg) 65%,transparent))}.empty-state-icon{background:color-mix(in srgb,var(--color-primary) 9%,var(--color-bg))}.pagination button{min-width:34px;min-height:34px;border-radius:9px}.modal-content{border:1px solid color-mix(in srgb,var(--color-border) 72%,transparent);overflow:hidden}.modal-content .modal-header{background:color-mix(in srgb,var(--color-surface) 84%,var(--color-bg))}@media(max-width:1024px){.page{width:100%}:is(.doc-toolbar,.task-toolbar,.admin-ws-toolbar){padding:.5rem;border-radius:10px}.search-input-wrapper{max-width:none;min-width:0;flex:1 1 220px}}@media(max-width:640px){.page-header-actions,.doc-toolbar-right{width:100%}.page-header-actions>.btn,.doc-toolbar-right>.btn,.doc-toolbar-right>.filter-select{flex:1 1 auto}.search-input-wrapper{flex-basis:100%}}
