@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-app:#07070d;--bg-sidebar:#0a0a13;--bg-content:#0c0c17;--bg-surface:#11111d;--bg-surface-2:#161624;--bg-elevated:#1a1a2a;--border:#ffffff0d;--border-strong:#ffffff17;--text:#f2f2f7;--text-soft:#c0c0d0;--text-muted:#6f6f88;--primary:#8b5cf6;--primary-2:#6d28d9;--primary-3:#a78bfa;--primary-soft:#8b5cf624;--primary-soft-2:#8b5cf642;--success:#34d399;--success-soft:#34d39924;--warning:#fbbf24;--warning-soft:#fbbf2424;--danger:#f87171;--danger-soft:#f8717124;--info:#60a5fa;--info-soft:#60a5fa24;--pink:#ec4899;--pink-soft:#ec489924;--orange:#fb923c;--orange-soft:#fb923c29;--teal:#2dd4bf;--teal-soft:#2dd4bf24;--shadow-card:0 1px 0 #ffffff0a inset, 0 12px 32px -20px #000000a6;--radius:14px;--radius-sm:10px;--radius-lg:18px;--sidebar-w:268px}*{box-sizing:border-box}html,body,#root{height:100%}body{color:var(--text);background:var(--bg-app);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;font-size:14px;line-height:1.5;overflow:hidden}h1,h2,h3,h4,p{margin:0}a{color:inherit;text-decoration:none}button{font-family:inherit}.app-shell{grid-template-columns:var(--sidebar-w) 1fr;background:var(--bg-app);height:100vh;display:grid;overflow:hidden}.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);isolation:isolate;flex-direction:column;gap:.9rem;height:100vh;padding:1.1rem .75rem 1rem;display:flex;position:sticky;top:0;overflow:hidden}.sidebar:before{content:"";pointer-events:none;z-index:-1;background:radial-gradient(60% 40% at 50% -10%,#8b5cf61a,#0000 70%);position:absolute;inset:0}.sidebar>*{position:relative}.sidebar-brand{align-items:center;gap:.85rem;padding:.25rem .55rem .7rem;display:flex}.sidebar-brand-mark{width:64px;height:64px;box-shadow:none;background:0 0;border-radius:0;flex-shrink:0;place-items:center;display:grid}.sidebar-brand-mark img{object-fit:contain;filter:none;width:100%;height:100%}.sidebar-brand-name{letter-spacing:-.01em;font-size:1.22rem;font-weight:700;line-height:1.05}.sidebar-brand-sub{letter-spacing:.22em;text-transform:uppercase;color:var(--text-muted);margin-top:.15rem;font-size:.62rem;font-weight:600}.sidebar-nav{scrollbar-width:thin;scrollbar-color:#ffffff14 transparent;flex-direction:column;flex:1;gap:.85rem;padding-right:.15rem;display:flex;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}.sidebar-group{flex-direction:column;gap:.1rem;display:flex}.sidebar-group-title{letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);padding:.5rem .7rem .35rem;font-size:.62rem;font-weight:700}.nav-link{color:var(--text-soft);border:1px solid #0000;border-radius:9px;align-items:center;gap:.7rem;padding:.52rem .7rem;font-size:.86rem;font-weight:500;transition:background .15s,color .15s;display:flex;position:relative}.nav-link .nav-label{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.nav-link:hover{color:var(--text);background:#ffffff08}.nav-link.active{color:var(--text);background:linear-gradient(90deg,#8b5cf62e,#8b5cf60f);border-color:#8b5cf647}.nav-link.active .nav-icon{color:var(--primary-3)}.nav-icon{width:18px;height:18px;color:var(--text-muted);place-items:center;display:inline-grid}.nav-badge{background:var(--primary);color:#fff;letter-spacing:.02em;text-align:center;border-radius:999px;min-width:18px;padding:.05rem .4rem;font-size:.64rem;font-weight:700}.nav-project{padding-left:.55rem}.project-mark{color:#fff;border-radius:6px;flex-shrink:0;place-items:center;width:22px;height:22px;display:grid}.project-violet{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}.project-pink{background:linear-gradient(135deg,#ec4899,#be185d)}.project-blue{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.project-green{background:linear-gradient(135deg,#22c55e,#15803d)}.project-amber{background:linear-gradient(135deg,#f59e0b,#b45309)}.project-teal{background:linear-gradient(135deg,#14b8a6,#0f766e)}.sidebar-group-head{justify-content:space-between;align-items:center;padding-right:.3rem;display:flex}.sidebar-group-head .sidebar-group-title{padding-right:0}.sidebar-group-action{width:24px;height:24px;color:var(--text-muted);border:1px solid var(--border);background:#ffffff05;border-radius:7px;place-items:center;font-weight:700;display:grid}.sidebar-group-action:hover{color:var(--text);border-color:var(--primary-soft-2)}.sidebar-project-list{gap:.1rem;display:grid}.sidebar-project-list.is-scrollable{max-height:330px;padding-right:.15rem;overflow-y:auto}.nav-mini-count{color:var(--text-muted);border:1px solid var(--border);border-radius:999px;padding:.02rem .38rem;font-size:.72rem}.sidebar-user{border-top:1px solid var(--border);flex-direction:column;gap:.4rem;padding-top:.7rem;display:flex}.sidebar-settings{color:var(--text-soft);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:9px;align-items:center;gap:.7rem;width:100%;padding:.55rem .7rem;font-size:.86rem;font-weight:500;transition:background .15s,color .15s;display:flex}.sidebar-settings:hover{color:var(--text);background:#ffffff08}.sidebar-settings.active{color:var(--text);background:linear-gradient(90deg,#8b5cf62e,#8b5cf60f);border-color:#8b5cf647}.sidebar-settings .nav-label{flex:1}.sidebar-settings svg:last-child{color:var(--text-muted)}.user-chip{border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border);align-items:center;gap:.7rem;padding:.5rem;display:flex}.user-avatar{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:.78rem;font-weight:600;display:grid}.user-chip-info{flex:1;gap:.1rem;min-width:0;display:grid}.user-chip-info strong{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.user-chip-info span{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.logout-btn{width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:9px;align-items:center;gap:.55rem;padding:.55rem .7rem;font-size:.8rem;font-weight:500;transition:all .15s;display:inline-flex}.logout-btn:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-soft)}.main-area{background:var(--bg-content);border-left:1px solid var(--border);scrollbar-width:thin;scrollbar-color:#ffffff14 transparent;border-top-left-radius:18px;border-bottom-left-radius:18px;flex-direction:column;min-width:0;height:100vh;margin:0;display:flex;overflow:hidden auto}.main-area::-webkit-scrollbar{width:8px}.main-area::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}.topbar{-webkit-backdrop-filter:blur(14px)saturate(140%);backdrop-filter:blur(14px)saturate(140%);z-index:10;background:#0c0c17b8;border-bottom:1px solid #0000;justify-content:space-between;align-items:flex-start;gap:1.25rem;padding:1.4rem 2rem .9rem;transition:border-color .2s,background .2s;display:flex;position:sticky;top:0}.main-area.is-scrolled .topbar{border-bottom-color:var(--border);background:#0a0a13d1}.topbar-left{flex-direction:column;gap:.5rem;min-width:0;display:flex}.breadcrumbs{color:var(--text-muted);align-items:center;gap:.4rem;font-size:.82rem;font-weight:500;display:inline-flex}.breadcrumbs .crumb{align-items:center;gap:.4rem;display:inline-flex}.breadcrumbs .crumb-sep{color:var(--text-muted);opacity:.6}.breadcrumbs .crumb-current{color:var(--text);font-weight:600}.crumb-chevron{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;place-items:center;padding:.15rem;display:inline-grid}.crumb-chevron:hover{color:var(--text);background:#ffffff0a}.page-title-xl{letter-spacing:-.025em;color:var(--text);font-size:2rem;font-weight:700;line-height:1.05}.topbar-actions{align-items:center;gap:.6rem;padding-top:.25rem;display:flex}.search-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;align-items:center;gap:.55rem;width:320px;height:40px;padding:.55rem .85rem;display:flex}.kbd{color:var(--text-muted);background:var(--bg-surface-2);border:1px solid var(--border-strong);letter-spacing:.05em;border-radius:5px;padding:.1rem .35rem;font-size:.72rem;font-weight:600}.icon-btn.has-dot{position:relative}.icon-dot{background:var(--danger);border:2px solid var(--bg-content);border-radius:50%;width:7px;height:7px;position:absolute;top:9px;right:10px}.topbar-avatar{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff;cursor:pointer;border:2px solid #ffffff0f;border-radius:50%;flex-shrink:0;place-items:center;width:40px;height:40px;font-size:.82rem;font-weight:700;display:grid;overflow:hidden}.topbar-avatar img{object-fit:cover;width:100%;height:100%}.topbar-user{align-items:center;gap:.65rem;display:inline-flex}.topbar-user-copy{text-align:right;gap:.05rem;min-width:0;display:grid}.topbar-user-copy strong{white-space:nowrap;text-overflow:ellipsis;max-width:170px;font-size:.82rem;font-weight:700;overflow:hidden}.topbar-user-copy span{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:190px;font-size:.72rem;overflow:hidden}.notification-wrap{position:relative}.notification-panel{background:var(--bg-elevated);border:1px solid var(--border-strong);z-index:30;border-radius:12px;width:min(360px,100vw - 2rem);padding:.65rem;position:absolute;top:calc(100% + .55rem);right:0;box-shadow:0 24px 70px -30px #000000bf}.notification-panel-head{justify-content:space-between;align-items:center;gap:1rem;padding:.3rem .35rem .65rem;display:flex}.notification-panel-head button{color:var(--primary-3);cursor:pointer;background:0 0;border:none;font-size:.75rem}.notification-empty{color:var(--text-muted);padding:1rem .35rem}.notification-item{text-align:left;width:100%;color:var(--text-soft);cursor:pointer;background:0 0;border:none;border-radius:9px;grid-template-columns:8px 1fr;gap:.65rem;padding:.65rem .35rem;display:grid}.notification-item:hover{background:#ffffff0a}.notification-item span:last-child{gap:.12rem;display:grid}.notification-item strong{color:var(--text);font-size:.84rem}.notification-item em{color:var(--text-soft);font-size:.78rem;font-style:normal}.notification-item small{color:var(--text-muted);font-size:.72rem}.notification-dot{background:0 0;border-radius:50%;width:7px;height:7px;margin-top:.45rem}.notification-item.unread .notification-dot{background:var(--primary)}.search-box input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:0;font-size:.88rem}.search-box input::placeholder,.search-icon{color:var(--text-muted)}.icon-btn{background:var(--bg-surface);border:1px solid var(--border);width:40px;height:40px;color:var(--text-soft);cursor:pointer;border-radius:10px;place-items:center;transition:all .15s;display:grid;position:relative}.icon-btn:hover{background:var(--bg-surface-2);color:var(--text)}.icon-btn-badge{background:var(--primary);color:#fff;border:2px solid var(--bg-app);border-radius:9px;place-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.66rem;font-weight:600;display:grid;position:absolute;top:-4px;right:-4px}.btn{border-radius:var(--radius-sm);cursor:pointer;background:var(--bg-surface);color:var(--text);border:1px solid #0000;justify-content:center;align-items:center;gap:.45rem;padding:.6rem 1rem;font-size:.86rem;font-weight:500;transition:all .15s;display:inline-flex}.btn:hover{background:var(--bg-surface-2)}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff;border-color:#0000;font-weight:600;box-shadow:0 4px 12px -4px #8b5cf680}.btn-primary:hover{filter:brightness(1.08);background:linear-gradient(135deg, var(--primary), var(--primary-2))}.btn-ghost{border-color:var(--border-strong);color:var(--text-soft);background:0 0}.btn-ghost:hover{background:var(--bg-surface);color:var(--text)}.btn-danger{background:var(--danger-soft);color:var(--danger);border-color:#f8717166}.btn-sm{padding:.4rem .7rem;font-size:.8rem}.content{gap:1.25rem;padding:1.25rem 2rem 2rem;display:grid}.page-header h1{letter-spacing:-.01em;font-size:1.55rem;font-weight:700}.page-header p{color:var(--text-muted);margin-top:.25rem;font-size:.9rem}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.25rem}.card-header{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.card-header h2,.card-header h3{letter-spacing:-.01em;font-size:1rem;font-weight:600}.card-link{color:var(--primary);font-size:.82rem;font-weight:500}.card-link:hover{text-decoration:underline}.stat-grid{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);flex-direction:column;gap:.35rem;padding:1.25rem;display:flex;position:relative}.stat-card-top{justify-content:space-between;align-items:flex-start;margin-bottom:.35rem;display:flex}.stat-card-icon{border-radius:10px;flex-shrink:0;place-items:center;width:38px;height:38px;display:grid}.stat-card-icon.violet{background:var(--primary-soft);color:var(--primary)}.stat-card-icon.cyan{background:var(--info-soft);color:var(--info)}.stat-card-icon.green{background:var(--success-soft);color:var(--success)}.stat-card-icon.amber{background:var(--warning-soft);color:var(--warning)}.stat-card-label{color:var(--text-muted);font-size:.85rem;font-weight:500}.stat-card-value{letter-spacing:-.02em;font-size:1.65rem;font-weight:700}.stat-card-foot{color:var(--text-muted);align-items:center;gap:.25rem;margin-top:.25rem;font-size:.78rem;display:flex}.stat-card-foot.up{color:var(--success)}.stat-card-foot.down{color:var(--danger)}.stat-card-foot.accent{color:var(--primary)}.dashboard-grid{grid-template-columns:minmax(0,1fr) 320px;gap:1.25rem;display:grid}.dashboard-main{gap:1.25rem;min-width:0;display:grid}.dashboard-side{gap:1.25rem;display:grid}.bottom-grid{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}input,textarea,select{background:var(--bg-surface);border:1px solid var(--border-strong);color:var(--text);border-radius:var(--radius-sm);font:inherit;outline:none;width:100%;padding:.6rem .8rem;font-size:.88rem;transition:border-color .15s,box-shadow .15s}input::placeholder,textarea::placeholder{color:var(--text-muted)}input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}textarea{resize:vertical;min-height:80px}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%237a7a90' d='M5 6L0 0h10z'/%3E%3C/svg%3E");background-position:right .85rem center;background-repeat:no-repeat;padding-right:2rem}label.field{color:var(--text-soft);gap:.35rem;font-size:.78rem;font-weight:500;display:grid}.task-table{border-collapse:collapse;width:100%}.task-table th{text-align:left;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:.7rem .75rem;font-size:.7rem;font-weight:600}.task-table td{border-bottom:1px solid var(--border);color:var(--text-soft);vertical-align:middle;padding:.85rem .75rem;font-size:.88rem}.task-table tr:last-child td{border-bottom:none}.task-table tr:hover td{background:var(--bg-surface-2)}.task-title{align-items:center;gap:.7rem;display:flex}.task-checkbox{border:1.5px solid var(--border-strong);cursor:pointer;background:0 0;border-radius:4px;flex-shrink:0;place-items:center;width:16px;height:16px;transition:all .15s;display:grid}.task-checkbox.checked{background:var(--primary);border-color:var(--primary);color:#fff}.task-name{color:var(--text);font-weight:500}.empty-state{text-align:center;color:var(--text-muted);padding:2rem;font-size:.9rem}.tabs{border-bottom:1px solid var(--border);gap:.25rem;margin-bottom:1rem;display:flex}.tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.65rem .85rem;font-size:.88rem;font-weight:500;transition:all .15s}.tab:hover{color:var(--text-soft)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.pill{letter-spacing:.01em;border:1px solid #0000;border-radius:999px;align-items:center;padding:.2rem .55rem;font-size:.72rem;font-weight:600;display:inline-flex}.pill-violet{background:var(--primary-soft);color:var(--primary)}.pill-cyan{background:var(--info-soft);color:var(--info)}.pill-green{background:var(--success-soft);color:var(--success)}.pill-amber{background:var(--warning-soft);color:var(--warning)}.pill-red{background:var(--danger-soft);color:var(--danger)}.pill-muted{background:var(--bg-surface-2);color:var(--text-soft);border-color:var(--border-strong)}.priority-low{background:var(--info-soft);color:var(--info)}.priority-medium{background:var(--warning-soft);color:var(--warning)}.priority-high{background:var(--primary-soft);color:var(--primary)}.priority-urgent{background:var(--danger-soft);color:var(--danger)}.list-item{border-bottom:1px solid var(--border);align-items:center;gap:.75rem;padding:.7rem 0;display:flex}.list-item:last-child{border-bottom:none}.list-avatar{background:var(--primary-soft);width:36px;height:36px;color:var(--primary);text-transform:uppercase;border-radius:9px;flex-shrink:0;place-items:center;font-size:.85rem;font-weight:600;display:grid}.list-avatar.cyan{background:var(--info-soft);color:var(--info)}.list-avatar.green{background:var(--success-soft);color:var(--success)}.list-avatar.amber{background:var(--warning-soft);color:var(--warning)}.list-avatar.red{background:var(--danger-soft);color:var(--danger)}.list-body{flex:1;min-width:0}.list-body strong{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;display:block;overflow:hidden}.list-body span{color:var(--text-muted);align-items:center;gap:.35rem;font-size:.78rem;display:flex}.list-body .status-dot{background:var(--success);border-radius:50%;width:6px;height:6px;display:inline-block}.list-body .status-dot.amber{background:var(--warning)}.list-body .status-dot.muted{background:var(--text-muted)}.list-meta{text-align:right;color:var(--text-muted);gap:.1rem;font-size:.78rem;display:grid}.list-meta strong{color:var(--text);font-size:.88rem;font-weight:600}.project-row{border-bottom:1px solid var(--border);grid-template-columns:1fr auto;align-items:center;gap:.6rem .75rem;padding:.65rem 0;display:grid}.project-row:last-child{border-bottom:none}.project-name{color:var(--text);font-size:.88rem;font-weight:500}.project-pct{color:var(--text-muted);font-size:.85rem;font-weight:600}.progress-bar{background:var(--bg-surface-2);border-radius:999px;grid-column:1/-1;height:6px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--primary), var(--primary-2));border-radius:999px;height:100%;transition:width .3s}.promo-card{border:1px solid var(--primary-soft-2);border-radius:var(--radius);background:linear-gradient(135deg,#8b5cf62e,#7c3aed14);flex-direction:column;gap:.85rem;padding:1.25rem;display:flex;position:relative;overflow:hidden}.promo-card-icon{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff;border-radius:12px;place-items:center;width:48px;height:48px;display:grid}.promo-card h3{letter-spacing:-.01em;font-size:1rem;font-weight:700}.promo-card p{color:var(--text-soft);font-size:.82rem}.activity-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:.75rem;padding:.7rem 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-text{min-width:0;color:var(--text-soft);flex:1;font-size:.85rem}.activity-text strong{color:var(--text);font-weight:600}.activity-time{color:var(--text-muted);white-space:nowrap;font-size:.76rem}.banner{border-radius:var(--radius-sm);border:1px solid #0000;padding:.75rem 1rem;font-size:.86rem}.banner-error{background:var(--danger-soft);color:var(--danger);border-color:#f871714d}.banner-success{background:var(--success-soft);color:var(--success);border-color:#34d3994d}.banner-warning{color:#92400e;background:#fbbf241f;border-color:#fbbf2452}.form-grid{gap:.75rem;display:grid}.form-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;display:grid}.kanban{grid-template-columns:repeat(5,1fr);align-items:stretch;gap:1rem;display:grid}.kanban-col{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.65rem;min-height:180px;padding:.85rem;display:flex}.kanban-col.is-droppable{border-color:var(--primary-soft-2);box-shadow:0 0 0 2px var(--primary-soft)}.kanban-col-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:.5rem;display:flex}.kanban-col-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft);font-size:.78rem;font-weight:600}.kanban-col-count{color:var(--text-muted);background:var(--bg-surface-2);border-radius:999px;padding:.1rem .45rem;font-size:.78rem;font-weight:600}.kanban-card{background:var(--bg-surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:.4rem;padding:.75rem;transition:border-color .15s;display:flex}.kanban-card:hover{border-color:var(--primary-soft-2)}.kanban-card-title{color:var(--text);font-size:.88rem;font-weight:600}.kanban-card-desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.78rem;display:-webkit-box;overflow:hidden}.kanban-card-foot{justify-content:space-between;align-items:center;margin-top:.25rem;display:flex}.kanban-empty{color:var(--text-muted);text-align:center;padding:.85rem .25rem;font-size:.8rem}.kanban-expanded .kanban-col{min-height:calc(100vh - 280px)}.kanban-col-body{gap:.65rem;padding-bottom:.8rem;padding-right:.2rem;display:grid;overflow-y:auto}.task-link-btn{appearance:none;color:var(--text);text-align:left;cursor:pointer;background:0 0;border:none;padding:0;font-weight:600;line-height:1.3}.task-link-btn:hover{color:var(--primary)}.task-meta-grid{color:var(--text-muted);grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem .75rem;font-size:.76rem;display:grid}.overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:30;background:#04040a9e;place-items:start center;padding:4.5rem 1.5rem 2rem;animation:.18s ease-out overlay-in;display:grid;position:fixed;inset:0;overflow-y:auto}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:12px;flex-direction:column;width:min(720px,100%);max-height:calc(100vh - 6rem);padding:0;animation:.22s cubic-bezier(.16,1,.3,1) modal-in;display:flex;overflow:hidden;box-shadow:0 28px 80px -28px #000000a6}@keyframes modal-in{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-wide{width:min(880px,100%)}.modal-xwide{width:min(1080px,100%)}.modal-header{border-bottom:1px solid var(--border);background:var(--bg-surface);flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.modal-header h3{letter-spacing:-.01em;color:var(--text);font-size:1.05rem;font-weight:600;line-height:1.2}.modal-header .modal-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.2rem;font-size:.66rem;font-weight:600}.modal-header p{color:var(--text-muted);margin-top:.2rem;font-size:.82rem;line-height:1.4}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:1.15rem;line-height:1;transition:all .12s;display:grid}.modal-close:hover{color:var(--text);background:#ffffff0f}.modal-body{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;flex-direction:column;padding:.5rem 1.5rem 1.25rem;display:flex;overflow:auto}.modal-body::-webkit-scrollbar{width:8px}.modal-body::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}.modal-footer{border-top:1px solid var(--border);background:var(--bg-surface);flex-shrink:0;justify-content:flex-end;align-items:center;gap:.55rem;padding:.85rem 1.5rem;display:flex}.modal-footer.between{justify-content:space-between}.modal-section{border:none;border-top:1px solid var(--border);background:0 0;border-radius:0;gap:.85rem;padding:1.1rem 0;display:grid}.modal-section:first-child{border-top:none;padding-top:.85rem}.modal-section-head{align-items:center;gap:.5rem;margin:0;display:flex}.modal-section-head .section-icon{width:22px;height:22px;color:var(--primary-3);background:#8b5cf61f;border-radius:5px;flex-shrink:0;place-items:center;display:grid}.modal-section-title{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-size:.7rem;font-weight:600}.modal-section-sub{color:var(--text-muted);margin-top:.1rem;font-size:.76rem}.modal-body .field{color:var(--text-soft);gap:.35rem;font-size:.78rem;font-weight:500}.modal-body .field input,.modal-body .field textarea,.modal-body .field select{background:var(--bg-app);border:1px solid var(--border-strong);color:var(--text);border-radius:6px;height:36px;padding:.55rem .75rem;font-size:.86rem;transition:border-color .12s,box-shadow .12s}.modal-body .field textarea{height:auto;min-height:80px;padding:.6rem .75rem;line-height:1.5}.modal-body .field input:focus,.modal-body .field textarea:focus,.modal-body .field select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #8b5cf626}.modal-body .field input:disabled,.modal-body .field select:disabled{opacity:.5;cursor:not-allowed}.modal-body .form-row{gap:.85rem 1rem}.modal-footer .btn{border-radius:6px;height:34px;padding:0 .95rem;font-size:.84rem}.modal-footer .btn-ghost{color:var(--text-soft);background:0 0;border-color:#0000}.modal-footer .btn-ghost:hover{color:var(--text);background:#ffffff0a}.modal-footer .btn-primary{box-shadow:0 6px 16px -8px #8b5cf68c}.modal-footer .btn-danger{color:var(--text-muted);background:0 0;border-color:#0000}.modal-footer .btn-danger:hover{background:var(--danger-soft);color:var(--danger);border-color:#0000}@media (width<=720px){.overlay{padding:1rem}.modal-card{border-radius:10px;max-height:calc(100vh - 2rem)}.modal-header,.modal-body,.modal-footer{padding-left:1rem;padding-right:1rem}}.filter-bar{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:.6rem;padding:.75rem .9rem;display:flex}.filter-bar .filter-search{flex:280px;min-width:240px;position:relative}.filter-bar .filter-search input{padding-left:2.2rem}.filter-bar .filter-search-icon{color:var(--text-muted);place-items:center;display:grid;position:absolute;top:50%;left:.8rem;transform:translateY(-50%)}.filter-bar select{flex:none;width:auto;min-width:150px}.filter-bar .filter-spacer{flex:1}.filter-chip-row{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.filter-chip{background:var(--bg-surface);border:1px solid var(--border-strong);color:var(--text-soft);cursor:pointer;border-radius:999px;align-items:center;gap:.4rem;padding:.42rem .75rem;font-size:.78rem;font-weight:500;transition:all .15s;display:inline-flex}.filter-chip:hover{border-color:var(--primary-soft-2);color:var(--text)}.filter-chip.active{background:var(--primary-soft);border-color:var(--primary-soft-2);color:var(--primary)}.filter-chip .chip-count{background:#ffffff0f;border-radius:999px;padding:0 .45rem;font-size:.7rem;font-weight:600}.filter-chip.active .chip-count{background:#8b5cf638}.page-actions-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;display:flex}.page-title{letter-spacing:-.01em;font-size:1.15rem;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:.15rem;font-size:.86rem}.editor-tabs{background:var(--bg-surface);border:1px solid var(--border);border-radius:999px;flex-wrap:wrap;align-items:center;gap:.25rem;padding:.3rem;display:inline-flex}.editor-tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:999px;align-items:center;gap:.45rem;padding:.5rem .95rem;font-size:.84rem;font-weight:500;transition:all .18s;display:inline-flex}.editor-tab:hover{color:var(--text)}.editor-tab.active{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff;font-weight:600;box-shadow:0 6px 16px -8px #8b5cf68c}.editor-tab .editor-tab-count{background:#ffffff14;border-radius:999px;padding:0 .45rem;font-size:.72rem;font-weight:600}.editor-tab.active .editor-tab-count{background:#ffffff38}.section-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:0;display:grid;overflow:hidden}.section-card-head{border-bottom:1px solid var(--border);background:linear-gradient(180deg, #8b5cf60f, transparent 90%), var(--bg-surface);justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.1rem 1.25rem;display:flex}.section-card-head h2,.section-card-head h3{letter-spacing:-.01em;font-size:1rem;font-weight:700}.section-card-eyebrow{letter-spacing:.16em;text-transform:uppercase;color:var(--primary);margin-bottom:.2rem;font-size:.7rem;font-weight:600}.section-card-head p{color:var(--text-muted);max-width:60ch;margin-top:.2rem;font-size:.82rem}.section-card-body{gap:1rem;padding:1.25rem;display:grid}.section-card-foot{border-top:1px solid var(--border);background:var(--bg-sidebar);justify-content:flex-end;gap:.55rem;padding:.85rem 1.25rem;display:flex}.plan-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);gap:.85rem;padding:1.1rem 1.15rem;transition:border-color .18s,box-shadow .18s;display:grid;position:relative}.plan-card.is-featured{border-color:var(--primary-soft-2);background:linear-gradient(180deg, #8b5cf612, transparent 60%), var(--bg-elevated);box-shadow:0 0 0 2px #8b5cf61f}.plan-card-head{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.plan-card-index{letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft);align-items:center;gap:.55rem;font-size:.78rem;font-weight:700;display:inline-flex}.plan-card-index .index-dot{background:var(--primary-soft);width:26px;height:26px;color:var(--primary);letter-spacing:0;border-radius:7px;place-items:center;font-size:.78rem;font-weight:700;display:grid}.plan-card.is-featured .plan-card-index .index-dot{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff}.plan-card-actions{align-items:center;gap:.4rem;display:flex}.toggle{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-soft);align-items:center;gap:.55rem;font-size:.82rem;display:inline-flex}.toggle input{display:none}.toggle-track{background:var(--bg-surface-2);border:1px solid var(--border-strong);border-radius:999px;width:36px;height:20px;transition:all .18s;position:relative}.toggle-track:after{content:"";background:var(--text-soft);border-radius:50%;width:14px;height:14px;transition:all .18s;position:absolute;top:2px;left:2px}.toggle input:checked+.toggle-track{background:linear-gradient(135deg, var(--primary), var(--primary-2));border-color:#0000}.toggle input:checked+.toggle-track:after{background:#fff;left:18px}.social-row{grid-template-columns:180px 1fr auto;align-items:center;gap:.55rem;display:grid}@media (width<=720px){.social-row{grid-template-columns:1fr}}.project-row-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);grid-template-columns:80px 1fr auto;align-items:center;gap:1rem;padding:.75rem;display:grid}.project-row-thumb{border:1px solid var(--border-strong);background:linear-gradient(135deg,#8b5cf640,#60a5fa2e) 50%/cover;border-radius:8px;width:80px;height:60px}.task-detail-grid{grid-template-columns:1.25fr 1fr;gap:1rem;margin-top:.45rem;display:grid}.task-detail-box h4{color:var(--text-soft);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.55rem;font-size:.86rem}.task-detail-box p{color:var(--text-soft);margin:0}.task-stream{max-height:320px;overflow:auto}.task-stream-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:.7rem;padding:.55rem 0;display:flex}.task-stream-item:last-child{border-bottom:none}.task-stream-item strong{font-size:.84rem;display:block}.task-stream-item p{color:var(--text-soft);margin:.15rem 0 .2rem;font-size:.82rem}.task-stream-item span{color:var(--text-muted);font-size:.74rem}.finance-filters{flex-wrap:wrap}.finance-filters input{flex:1;min-width:260px}.finance-stats{grid-template-columns:repeat(4,minmax(0,1fr))}.calendar-layout{grid-template-columns:2fr 1fr;gap:1rem;display:grid}.calendar-grid-header{grid-template-columns:repeat(7,minmax(0,1fr));gap:.45rem;margin-bottom:.45rem;display:grid}.calendar-grid-header div{text-align:center;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:.35rem 0;font-size:.74rem}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:.45rem;display:grid}.calendar-day{border:1px solid var(--border);background:var(--bg-surface-2);border-radius:10px;grid-template-rows:auto 1fr;gap:.35rem;min-height:110px;padding:.45rem;display:grid}.calendar-day.is-out{opacity:.45}.calendar-day.is-today{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-soft)}.calendar-day-head{justify-content:space-between;align-items:center;font-size:.78rem;display:flex}.calendar-day-head span{background:var(--bg-surface);border:1px solid var(--border);min-width:18px;height:18px;color:var(--text-muted);border-radius:9px;place-items:center;font-size:.7rem;display:grid}.calendar-day-events{align-content:start;gap:.25rem;display:grid}.calendar-pill{white-space:nowrap;text-overflow:ellipsis;border:1px solid #0000;border-radius:7px;padding:.2rem .35rem;font-size:.7rem;overflow:hidden}.calendar-pill.task{background:var(--info-soft);color:var(--info);border-color:#60a5fa52}.calendar-pill.expense{background:var(--warning-soft);color:var(--warning);border-color:#fbbf2452}.calendar-pill.more{background:var(--bg-surface);color:var(--text-muted);border-color:var(--border)}.calendar-upcoming{gap:.45rem;display:grid}.calendar-upcoming-item{border-bottom:1px solid var(--border);justify-content:space-between;gap:.7rem;padding:.55rem 0;display:flex}.calendar-upcoming-item:last-child{border-bottom:none}.calendar-upcoming-item strong{font-size:.84rem;display:block}.calendar-upcoming-item span{color:var(--text-muted);font-size:.76rem}.auth-shell{background:var(--bg-app);grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.auth-visual{background:radial-gradient(40rem 30rem at 30% 30%, #8b5cf640, transparent 60%), radial-gradient(35rem 25rem at 70% 80%, #60a5fa26, transparent 60%), var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;justify-content:center;gap:1.25rem;padding:3rem;display:flex;position:relative;overflow:hidden}.auth-visual:before{content:"";pointer-events:none;background-image:linear-gradient(#ffffff05 1px,#0000 1px),linear-gradient(90deg,#ffffff05 1px,#0000 1px);background-size:32px 32px;position:absolute;inset:0}.auth-visual-inner{gap:1rem;max-width:420px;display:grid;position:relative}.auth-visual h2{letter-spacing:-.02em;font-size:2rem;font-weight:700;line-height:1.1}.auth-visual p{color:var(--text-soft);font-size:.95rem}.auth-pills{flex-wrap:wrap;gap:.45rem;display:flex}.auth-pills span{border:1px solid var(--border-strong);color:var(--text-soft);background:var(--bg-surface);border-radius:999px;padding:.35rem .7rem;font-size:.78rem}.auth-card{justify-content:center;align-items:center;padding:3rem;display:flex}.auth-form{gap:1rem;width:100%;max-width:380px;display:grid}.auth-form h1{letter-spacing:-.01em;font-size:1.55rem;font-weight:700}.auth-form>p{color:var(--text-muted);margin-top:-.5rem;font-size:.9rem}.loading-screen{min-height:100vh;color:var(--text-soft);background:var(--bg-app);place-items:center;display:grid}.loader{border:3px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.muted{color:var(--text-muted);font-size:.88rem}.row{align-items:center;gap:.65rem;display:flex}.row-between{justify-content:space-between;align-items:center;gap:.65rem;display:flex}.stack{gap:1rem;display:grid}.stack-sm{gap:.5rem;display:grid}.flex-grow{flex:1}@media (width<=1280px){.dashboard-grid{grid-template-columns:1fr}.dashboard-side{grid-template-columns:1fr 1fr;display:grid}.stat-grid{grid-template-columns:repeat(2,1fr)}.kanban{grid-template-columns:repeat(3,1fr)}.task-detail-grid,.calendar-layout{grid-template-columns:1fr}.search-box{width:220px}}@media (width<=980px){body{overflow:auto}.app-shell{grid-template-columns:1fr;height:auto;overflow:visible}.main-area{height:auto;overflow:visible}.sidebar{border-right:none;border-bottom:1px solid var(--border);height:auto;position:static}.topbar{flex-wrap:wrap;padding:1rem}.topbar-actions{justify-content:space-between;width:100%}.search-box{flex:1;width:auto}.content{padding:1rem}.dashboard-side,.bottom-grid{grid-template-columns:1fr}.kanban{grid-template-columns:1fr 1fr}.kanban-expanded .kanban-col{min-height:320px}.auth-shell{grid-template-columns:1fr}.auth-visual{display:none}}@media (width<=640px){.stat-grid,.kanban,.calendar-grid{grid-template-columns:1fr}.calendar-grid-header{display:none}.finance-filters{gap:.45rem}.finance-filters input{min-width:100%}.overlay{padding:.45rem}}.page-tabs{border-bottom:1px solid var(--border);scrollbar-width:none;align-items:center;gap:1.5rem;margin-top:-.4rem;padding:0 .1rem;display:flex;overflow-x:auto}.page-tabs::-webkit-scrollbar{display:none}.page-tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;align-items:center;gap:.4rem;padding:.85rem .1rem;font-size:.92rem;font-weight:500;transition:color .15s;display:inline-flex;position:relative}.page-tab:hover{color:var(--text-soft)}.page-tab.active{color:var(--text);font-weight:600}.page-tab.active:after{content:"";background:linear-gradient(90deg, var(--primary), var(--primary-3));border-radius:2px;height:2px;position:absolute;bottom:-1px;left:0;right:0}.action-bar{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.55rem;display:flex}.action-bar .spacer{flex:1}.chip-btn{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-soft);cursor:pointer;border-radius:10px;align-items:center;gap:.5rem;height:38px;padding:.5rem .85rem;font-size:.85rem;font-weight:500;transition:all .15s;display:inline-flex}.chip-btn:hover{background:var(--bg-surface-2);color:var(--text)}.chip-btn .chip-icon{color:var(--text-muted);place-items:center;display:inline-grid}.chip-btn .caret{color:var(--text-muted);margin-left:.15rem}.btn-primary-lg{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:.5rem;height:38px;padding:0 1rem;font-size:.88rem;font-weight:600;transition:filter .15s,transform .15s;display:inline-flex;box-shadow:0 8px 22px -10px #8b5cf6b3}.btn-primary-lg:hover{filter:brightness(1.08)}.btn-primary-lg .caret-split{border-left:1px solid #ffffff40;place-items:center;margin-left:.25rem;padding-left:.5rem;display:inline-grid}.finance-shell{grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:1.25rem;display:grid}.finance-main{gap:1.25rem;min-width:0;display:grid}.finance-rail{gap:1rem;display:grid}@media (width<=1280px){.finance-shell{grid-template-columns:1fr}.finance-rail{grid-template-columns:repeat(3,1fr)}}@media (width<=980px){.finance-rail{grid-template-columns:1fr}}.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;display:grid}@media (width<=1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.kpi-grid{grid-template-columns:1fr}}.kpi-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);min-height:158px;box-shadow:var(--shadow-card);grid-template-rows:auto 1fr auto;gap:.4rem;padding:1.1rem 1.15rem 0;display:grid;position:relative;overflow:hidden}.kpi-card-head{align-items:center;gap:.7rem;display:flex}.kpi-icon{border-radius:10px;flex-shrink:0;place-items:center;width:38px;height:38px;display:grid}.kpi-icon.violet{background:var(--primary-soft);color:var(--primary-3)}.kpi-icon.blue{background:var(--info-soft);color:var(--info)}.kpi-icon.teal{background:var(--teal-soft);color:var(--teal)}.kpi-icon.pink{background:var(--pink-soft);color:var(--pink)}.kpi-label{color:var(--text-muted);font-size:.82rem;font-weight:500}.kpi-value{letter-spacing:-.02em;color:var(--text);font-size:1.7rem;font-weight:700}.kpi-delta{color:var(--text-muted);align-items:center;gap:.3rem;margin-top:.1rem;font-size:.78rem;display:inline-flex}.kpi-delta strong{font-size:.8rem;font-weight:600}.kpi-delta.up strong{color:var(--success)}.kpi-delta.down strong{color:var(--danger)}.kpi-spark{height:56px;margin:0 -1.15rem;position:relative}.kpi-spark svg{width:100%;height:100%;display:block}.card-pro{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.15rem 1.2rem}.card-pro-head{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.card-pro-head h3{letter-spacing:-.01em;color:var(--text);font-size:1rem;font-weight:600}.card-pro-link{color:var(--primary-3);cursor:pointer;font-size:.82rem;font-weight:500}.card-pro-link:hover{text-decoration:underline}.mini-select{background:var(--bg-surface-2);border:1px solid var(--border-strong);color:var(--text-soft);cursor:pointer;border-radius:8px;align-items:center;gap:.4rem;height:30px;padding:.35rem .65rem;font-size:.8rem;font-weight:500;display:inline-flex}.mini-select:hover{color:var(--text)}.finance-charts-row{grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:1.25rem;display:grid}@media (width<=1100px){.finance-charts-row{grid-template-columns:1fr}}.bar-chart{height:220px;padding:.5rem 0 .25rem;position:relative}.bar-chart svg{width:100%;height:100%;display:block;overflow:visible}.bar-chart-axis-label{fill:var(--text-muted);font-size:.72rem}.bar-chart-grid line{stroke:#ffffff0a;stroke-dasharray:3 4}.bar-chart-tooltip{border:1px solid var(--border-strong);color:var(--text-soft);pointer-events:none;z-index:2;background:#141423f5;border-radius:10px;min-width:130px;padding:.55rem .7rem;font-size:.75rem;position:absolute;box-shadow:0 12px 28px -10px #000000b3}.bar-chart-tooltip strong{color:var(--text);margin-bottom:.3rem;font-weight:600;display:block}.bar-chart-tooltip-row{justify-content:space-between;gap:.7rem;display:flex}.bar-chart-tooltip-row span:last-child{color:var(--text);font-weight:600}.legend-row{color:var(--text-soft);align-items:center;gap:.85rem;font-size:.78rem;display:inline-flex}.legend-dot{align-items:center;gap:.35rem;display:inline-flex}.legend-dot:before{content:"";background:var(--primary);border-radius:50%;width:8px;height:8px}.legend-dot.income:before{background:var(--primary)}.legend-dot.expense:before{background:var(--info)}.donut-wrap{grid-template-columns:160px 1fr;align-items:center;gap:1.1rem;display:grid}.donut-center{width:160px;height:160px;position:relative}.donut-center svg{width:100%;height:100%;display:block;transform:rotate(-90deg)}.donut-center-label{text-align:center;place-items:center;display:grid;position:absolute;inset:0}.donut-center-label span{color:var(--text-muted);font-size:.72rem;display:block}.donut-center-label strong{letter-spacing:-.01em;color:var(--text);font-size:1.15rem;font-weight:700}.donut-legend{gap:.5rem;display:grid}.donut-legend-item{grid-template-columns:14px 1fr auto auto;align-items:center;gap:.55rem;font-size:.82rem;display:grid}.donut-legend-item .ld-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.donut-legend-item .ld-name{color:var(--text-soft)}.donut-legend-item .ld-amount{color:var(--text);font-weight:600}.donut-legend-item .ld-pct{color:var(--text-muted);font-size:.78rem}@media (width<=600px){.donut-wrap{grid-template-columns:1fr}.donut-center{margin:0 auto}}.rail-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);gap:.75rem;padding:1rem 1.05rem;display:grid}.rail-head{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.rail-head h3{letter-spacing:-.01em;font-size:.92rem;font-weight:600}.rail-head .rail-link{color:var(--primary-3);cursor:pointer;font-size:.78rem}.rail-head .rail-icon{background:var(--bg-surface-2);border:1px solid var(--border-strong);width:28px;height:28px;color:var(--text-muted);cursor:pointer;border-radius:7px;place-items:center;display:grid}.rail-list{gap:.45rem;display:grid}.rail-row{justify-content:space-between;align-items:center;gap:.7rem;font-size:.84rem;display:flex}.rail-row .lbl{color:var(--text-soft)}.rail-row .val{color:var(--text);font-weight:600}.rail-row .val.income{color:var(--success)}.rail-row .val.expense{color:var(--danger)}.rail-divider{background:var(--border);height:1px;margin:.1rem 0}.rail-invoice{border-bottom:1px solid var(--border);grid-template-columns:1fr auto;gap:.2rem .7rem;padding:.55rem 0;display:grid}.rail-invoice:last-child{border-bottom:none}.rail-invoice .ri-id{color:var(--text-muted);letter-spacing:.04em;font-size:.72rem;font-weight:600}.rail-invoice .ri-amount{color:var(--text);text-align:right;font-size:.86rem;font-weight:700}.rail-invoice .ri-name{color:var(--text-soft);grid-column:1/2;font-size:.82rem}.rail-invoice .ri-state{grid-column:2/3;justify-self:end}.rail-budget{border-bottom:1px solid var(--border);gap:.35rem;padding:.5rem 0;display:grid}.rail-budget:last-child{border-bottom:none}.rail-budget-head{justify-content:space-between;align-items:center;font-size:.84rem;display:flex}.rail-budget-head strong{color:var(--text);font-weight:600}.rail-budget-head span{color:var(--text-muted);font-size:.78rem}.rail-budget-bar{background:var(--bg-surface-2);border-radius:999px;height:6px;overflow:hidden}.rail-budget-bar-fill{background:linear-gradient(90deg, var(--primary), var(--primary-3));border-radius:999px;height:100%}.tx-table{border-collapse:collapse;width:100%}.tx-table th{text-align:left;letter-spacing:.02em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:.7rem .85rem;font-size:.74rem;font-weight:600}.tx-table td{border-bottom:1px solid var(--border);color:var(--text-soft);padding:.85rem;font-size:.86rem}.tx-table tbody tr:last-child td{border-bottom:none}.tx-table tbody tr:hover td{background:#ffffff04}.tx-tag{border-radius:6px;align-items:center;padding:.18rem .55rem;font-size:.74rem;font-weight:600;display:inline-flex}.tx-tag.violet{background:var(--primary-soft);color:var(--primary-3)}.tx-tag.green{background:var(--success-soft);color:var(--success)}.tx-tag.red{background:var(--danger-soft);color:var(--danger)}.tx-tag.amber{background:var(--warning-soft);color:var(--warning)}.tx-tag.blue{background:var(--info-soft);color:var(--info)}.tx-tag.pink{background:var(--pink-soft);color:var(--pink)}.tx-tag.orange{background:var(--orange-soft);color:var(--orange)}.tx-tag.muted{background:var(--bg-surface-2);color:var(--text-muted)}.tx-state{align-items:center;gap:.35rem;font-size:.82rem;font-weight:500;display:inline-flex}.tx-state.paid{color:var(--success)}.tx-state.pending{color:var(--warning)}.tx-state.overdue{color:var(--danger)}.tx-state-dot{background:var(--success-soft);width:14px;height:14px;color:var(--success);border-radius:50%;place-items:center;font-size:9px;font-weight:800;display:grid}.tx-state.pending .tx-state-dot{background:var(--warning-soft);color:var(--warning)}.tx-state.overdue .tx-state-dot{background:var(--danger-soft);color:var(--danger)}.tx-table-foot{border-top:1px solid var(--border);margin-top:.5rem;padding:.95rem .85rem 0}.tx-foot-link{color:var(--text-soft);cursor:pointer;background:0 0;border:none;align-items:center;gap:.4rem;padding:0;font-size:.86rem;font-weight:500;display:inline-flex}.tx-foot-link:hover{color:var(--primary-3)}.cal-shell{grid-template-columns:minmax(0,1fr) 300px;align-items:start;gap:1.25rem;display:grid}@media (width<=1180px){.cal-shell{grid-template-columns:1fr}}.cal-main{gap:1rem;min-width:0;display:grid}.cal-rail{gap:1rem;display:grid}.cal-month-row{align-items:center;gap:.75rem;display:flex}.cal-month-row h2{letter-spacing:-.01em;color:var(--text);text-transform:capitalize;font-size:1.2rem;font-weight:700}.cal-pro{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.cal-pro-head{border-bottom:1px solid var(--border);background:#ffffff04;grid-template-columns:repeat(7,minmax(0,1fr));display:grid}.cal-pro-head div{text-align:left;letter-spacing:.02em;color:var(--text-muted);border-right:1px solid var(--border);padding:.7rem .85rem;font-size:.72rem;font-weight:600}.cal-pro-head div:last-child{border-right:none}.cal-pro-grid{grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:minmax(110px,1fr);display:grid}.cal-pro-day{border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:0 0;flex-direction:column;gap:.35rem;min-height:110px;padding:.55rem .6rem;transition:background .12s;display:flex;position:relative}.cal-pro-day:nth-child(7n){border-right:none}.cal-pro-day:hover{background:#ffffff04}.cal-pro-day.is-out{color:var(--text-muted);opacity:.45}.cal-pro-day-num{color:var(--text-soft);border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.8rem;font-weight:600;display:inline-flex}.cal-pro-day.is-today .cal-pro-day-num{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff}.cal-pro-events{align-content:start;gap:3px;display:grid}.cal-event{background:currentColor;background:var(--evt-bg,#8b5cf629);color:var(--evt-fg,var(--primary-3));white-space:nowrap;cursor:pointer;border-left:3px solid;border-radius:5px;grid-template-columns:36px 1fr;align-items:center;gap:.3rem;padding:.25rem .4rem;font-size:.72rem;display:grid;position:relative;overflow:hidden}.cal-event:before{content:"";background:var(--evt-fg,var(--primary-3));border-radius:2px 0 0 2px;width:3px;position:absolute;top:0;bottom:0;left:0}.cal-event .evt-time{color:var(--evt-fg);font-size:.7rem;font-weight:700}.cal-event .evt-title{color:var(--text);text-overflow:ellipsis;align-items:center;gap:.25rem;font-weight:500;display:inline-flex;overflow:hidden}.cal-event.violet{--evt-bg:#8b5cf62e;--evt-fg:#a78bfa}.cal-event.green{--evt-bg:#34d3992e;--evt-fg:#4ade80}.cal-event.orange{--evt-bg:#fb923c2e;--evt-fg:#fb923c}.cal-event.blue{--evt-bg:#60a5fa2e;--evt-fg:#60a5fa}.cal-event.teal{--evt-bg:#2dd4bf2e;--evt-fg:#2dd4bf}.cal-event.pink{--evt-bg:#ec48992e;--evt-fg:#f472b6}.cal-month-select{background:var(--bg-surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:10px;align-items:center;gap:.4rem;height:36px;padding:.4rem .85rem;font-size:.85rem;font-weight:500;display:inline-flex}.cal-legend{color:var(--text-soft);flex-wrap:wrap;align-items:center;gap:1rem;padding:.85rem 1.05rem;font-size:.78rem;display:inline-flex}.cal-legend-item{align-items:center;gap:.4rem;display:inline-flex}.cal-legend-item:before{content:"";background:var(--ldot,var(--primary));border-radius:50%;width:8px;height:8px}.mini-cal{padding:.95rem 1rem}.mini-cal-head{justify-content:space-between;align-items:center;margin-bottom:.7rem;display:flex}.mini-cal-head strong{text-transform:capitalize;font-size:.92rem;font-weight:600}.mini-cal-head .mini-nav{gap:.25rem;display:inline-flex}.mini-cal-head .mini-nav button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:5px;place-items:center;width:22px;height:22px;display:grid}.mini-cal-head .mini-nav button:hover{color:var(--text);background:#ffffff0a}.mini-cal-grid{grid-template-columns:repeat(7,1fr);gap:.05rem;font-size:.75rem;display:grid}.mini-cal-grid .dow{text-align:center;color:var(--text-muted);padding:.3rem 0;font-size:.7rem;font-weight:600}.mini-cal-grid .day{text-align:center;color:var(--text-soft);cursor:pointer;border-radius:6px;padding:.4rem 0;transition:background .12s}.mini-cal-grid .day:hover{background:#ffffff0d}.mini-cal-grid .day.is-out{color:var(--text-muted);opacity:.4}.mini-cal-grid .day.is-today{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff;font-weight:700}.up-events{gap:.1rem;display:grid}.up-event{border-bottom:1px solid var(--border);grid-template-columns:1fr auto;gap:.15rem .7rem;padding:.55rem 0;display:grid}.up-event:last-child{border-bottom:none}.up-event .up-title{color:var(--text);align-items:center;gap:.45rem;font-size:.86rem;font-weight:600;display:inline-flex}.up-event .up-title:before{content:"";background:var(--primary-3);border-radius:50%;width:6px;height:6px}.up-event.green .up-title:before{background:#4ade80}.up-event.orange .up-title:before{background:#fb923c}.up-event.blue .up-title:before{background:#60a5fa}.up-event.pink .up-title:before{background:#f472b6}.up-event .up-meta{color:var(--text-muted);font-size:.76rem}.up-event .up-day{color:var(--text-muted);text-align:right;font-size:.78rem}.up-event .up-time{color:var(--text);text-align:right;font-size:.78rem;font-weight:600}.btn-soft{background:var(--bg-surface-2);border:1px dashed var(--border-strong);width:100%;color:var(--text-soft);cursor:pointer;border-radius:9px;justify-content:center;align-items:center;gap:.4rem;padding:.55rem;font-size:.84rem;font-weight:500;transition:all .15s;display:inline-flex}.btn-soft:hover{border-color:var(--primary-soft-2);color:var(--text)}.settings-grid{grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);align-items:start;gap:1rem;display:grid}.settings-grid-wide{grid-template-columns:minmax(320px,.78fr) minmax(0,1.22fr)}.settings-card{gap:1rem;display:grid}.settings-narrow{max-width:560px}.settings-profile-row{align-items:center;gap:1rem;display:flex}.settings-avatar{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff;border:1px solid var(--border-strong);border-radius:50%;place-items:center;width:88px;height:88px;font-size:1.15rem;font-weight:800;display:grid;overflow:hidden}.settings-avatar img{object-fit:cover;width:100%;height:100%}.settings-kv{grid-template-columns:120px 1fr;gap:.7rem 1rem;display:grid}.settings-kv span,.settings-project-row span{color:var(--text-muted);font-size:.8rem}.settings-project-list{gap:.45rem;max-height:520px;padding-right:.2rem;display:grid;overflow-y:auto}.settings-project-row{border:1px solid var(--border);background:#ffffff04;border-radius:10px;grid-template-columns:26px 1fr auto;align-items:center;gap:.7rem;padding:.7rem;display:grid}.settings-project-row strong{margin-bottom:.1rem;display:block}.project-detail-grid{grid-template-columns:minmax(0,1fr) minmax(280px,360px)}@media (width<=980px){.settings-grid,.settings-grid-wide,.project-detail-grid{grid-template-columns:1fr}.topbar-user-copy{display:none}.main-area{border-left:none;border-radius:0}}
