@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Outfit:wght@700;800;900&display=swap";:root{--brand:#e63946;--brand-dark:#d62828;--brand-light:#ff4d5a;--brand-rgb:230,57,70;--bg:#fdfdfc;--bg-secondary:#f6f6f5;--surface:#fff;--surface-hover:#f9f9f9;--border:#f0f0f0;--text-primary:#111;--text-secondary:#666;--text-muted:#999;--success:#10b981;--warning:#f59e0b;--danger:#e63946;--info:#3b82f6;--radius:20px;--radius-sm:12px;--radius-lg:28px;--shadow:0 8px 30px #0000000a;--shadow-lg:0 16px 50px #00000014;--font-body:"Inter", system-ui, sans-serif;--font-heading:"Outfit", "Inter", sans-serif;--sidebar-w:260px;--topbar-h:70px}@media (prefers-color-scheme:dark){:root{--bg:#0f0f11;--bg-secondary:#161618;--surface:#1c1c1f;--surface-hover:#242428;--border:#2a2a2e;--text-primary:#f5f5f5;--text-secondary:#a0a0a0;--text-muted:#666}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-size:14px;font-weight:500;line-height:1.6}#root{height:100%}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.sidebar-logo{align-items:center;gap:16px;padding:24px;display:flex}.sidebar-logo img{object-fit:cover;border-radius:12px;width:44px;height:44px;box-shadow:0 4px 12px #00000014}.sidebar-logo-text{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.02em;font-size:1.3rem;font-weight:900}.sidebar-logo-sub{color:var(--text-muted);margin-top:-2px;font-size:.75rem}.sidebar-nav{flex:1;padding:16px}.sidebar-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:12px 12px 6px;font-size:.7rem;font-weight:700}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;margin-bottom:4px;padding:12px 16px;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.nav-item:hover{background:var(--surface-hover);color:var(--text-primary);transform:translate(4px)}.nav-item.active{background:var(--bg-secondary);color:var(--text-primary);font-weight:800}.nav-item.active:before{content:"";background:var(--brand);border-radius:4px;width:4px;height:20px;position:absolute;left:12px}.nav-item svg{flex-shrink:0;width:20px;height:20px}.main-content{background:var(--bg);flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{height:var(--topbar-h);background:var(--bg);z-index:50;flex-shrink:0;align-items:center;gap:16px;padding:0 32px;display:flex}.topbar-title{font-family:var(--font-heading);flex:1;font-size:1.25rem;font-weight:800}.page-scroll{flex:1;padding:0 32px 32px;overflow-y:auto}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;transition:box-shadow .3s}.card:hover{box-shadow:var(--shadow-lg)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:12px;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.stat-icon-wrap{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:8px;display:flex}.stat-icon-green{color:#2e6f40;background:#2e6f401a}.stat-icon-success{color:var(--success);background:#10b9811a}.stat-icon-danger{color:var(--danger);background:#e639461a}.stat-icon-warning{color:var(--warning);background:#f59e0b1a}.stat-icon-blue{color:var(--info);background:#3b82f61a}.stat-value{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.03em;font-size:2.2rem;font-weight:900;line-height:1}.stat-label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:99px;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:700;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff;box-shadow:0 4px 12px rgba(var(--brand-rgb), .3)}.btn-primary:hover:not(:disabled){background:var(--brand-dark);box-shadow:0 6px 16px rgba(var(--brand-rgb), .4);transform:translateY(-2px)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-2px)}.btn-ghost{background:var(--surface);color:var(--text-primary);border:1px solid var(--border);box-shadow:var(--shadow)}.btn-ghost:hover:not(:disabled){background:var(--surface-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-sm{padding:6px 14px;font-size:.8rem}.icon-btn{border:1px solid var(--border);background:var(--surface);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);box-shadow:var(--shadow);border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:inline-flex}.icon-btn:hover{background:var(--surface-hover);color:var(--text-primary);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);width:100%;color:var(--text-primary);outline:none;padding:12px 16px;font-family:inherit;font-size:.9rem;font-weight:500;transition:all .2s}.input:focus{background:var(--surface);border-color:var(--brand);box-shadow:0 0 0 4px rgba(var(--brand-rgb), .1)}.input-icon-wrap{position:relative}.input-icon-wrap .icon-left{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.input-icon-wrap .input{padding-left:42px}label{color:var(--text-primary);margin-bottom:8px;font-size:.85rem;font-weight:700;display:block}.form-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.form-group{flex-direction:column;gap:4px;display:flex}.table-wrap{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);padding:10px 0;overflow-x:auto}table{border-collapse:collapse;width:100%}thead tr{border-bottom:1px solid var(--border)}th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);white-space:nowrap;padding:16px 24px;font-size:.75rem;font-weight:800}td{border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle;padding:16px 24px;font-size:.9rem;font-weight:600}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--bg-secondary)}.badge{white-space:nowrap;border-radius:99px;align-items:center;gap:6px;padding:4px 12px;font-size:.75rem;font-weight:800;display:inline-flex}.badge-success{color:var(--success);background:#10b9811a}.badge-danger{color:var(--danger);background:#e639461a}.badge-warning{color:var(--warning);background:#f59e0b1a}.badge-info{color:var(--info);background:#3b82f61a}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:32px;display:flex}.page-header h1{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.03em;font-size:2rem;font-weight:900}.page-header p{color:var(--text-muted);margin-top:4px;font-size:.9rem;font-weight:500}.page-header-left{flex-direction:column;display:flex}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;padding:32px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;overflow-y:auto;box-shadow:0 24px 60px #00000026}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-title{font-family:var(--font-heading);font-size:1.4rem;font-weight:900}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;display:flex}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.alert{border-radius:var(--radius-sm);align-items:center;gap:12px;padding:14px 20px;font-size:.9rem;font-weight:600;display:flex}.alert-danger{color:var(--danger);background:#e6394614;border:1px solid #e6394633}.alert-warning{color:#92400e;background:#f59e0b14;border:1px solid #f59e0b33}.alert-success{color:#065f46;background:#10b98114;border:1px solid #10b98133}.spinner{border:3px solid var(--border);border-top-color:var(--brand);border-radius:50%;width:24px;height:24px;animation:.8s cubic-bezier(.4,0,.2,1) infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}.page-loader{min-height:400px;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-weight:600;display:flex}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:16px;padding:60px 20px;font-size:1rem;font-weight:600;display:flex}.empty-state svg{width:48px;height:48px;color:var(--border)}.avatar{background:rgba(var(--brand-rgb), .1);width:48px;height:48px;color:var(--brand);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;font-weight:900;display:flex}.avatar-sm{width:36px;height:36px;font-size:.9rem}.toast-container{z-index:999;flex-direction:column;gap:12px;display:flex;position:fixed;bottom:32px;right:32px}.toast{color:#fff;border-radius:100px;align-items:center;gap:12px;padding:16px 24px;font-size:.9rem;font-weight:700;animation:.3s cubic-bezier(.16,1,.3,1) toastSlide;display:flex;box-shadow:0 12px 30px #00000026}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-warning{background:var(--warning);color:#000}.toast-info{background:var(--info)}@keyframes toastSlide{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.tab-bar{background:var(--bg-secondary);border-radius:99px;gap:8px;width:fit-content;margin-bottom:24px;padding:6px;display:flex}.tab-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:99px;padding:8px 24px;font-size:.9rem;font-weight:700;transition:all .2s cubic-bezier(.4,0,.2,1)}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{background:var(--surface);color:var(--text-primary);box-shadow:0 2px 8px #0000000d}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:460px;padding:48px;box-shadow:0 24px 60px #0000000f}.login-logo{text-align:center;margin-bottom:40px}.login-logo img{border-radius:20px;width:80px;height:80px;margin-bottom:16px;box-shadow:0 8px 24px #0000001a}.login-logo h1{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.04em;font-size:2.2rem;font-weight:900}.login-logo p{color:var(--text-muted);margin-top:8px;font-size:.95rem;font-weight:500}.login-input{background:var(--bg-secondary);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);border:1px solid #0000;outline:none;padding:16px 20px;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.login-input::placeholder{color:var(--text-muted);font-weight:500}.login-input:focus{background:var(--surface);border-color:var(--brand);box-shadow:0 0 0 4px rgba(var(--brand-rgb), .1)}.login-btn{background:var(--text-primary);color:#fff;cursor:pointer;border:none;border-radius:99px;justify-content:center;align-items:center;gap:12px;width:100%;margin-top:16px;padding:16px;font-size:1rem;font-weight:800;transition:all .2s;display:flex}.login-btn:hover{background:#333;transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.login-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.kanban-board{align-items:flex-start;gap:24px;padding-bottom:24px;display:flex;overflow-x:auto}.kanban-col{background:var(--bg-secondary);border-radius:var(--radius-lg);flex-direction:column;flex:0 0 300px;min-width:300px;max-width:320px;padding:8px;display:flex}.kanban-col-header{font-weight:800;font-family:var(--font-heading);justify-content:space-between;align-items:center;padding:16px;display:flex}.kanban-col-body{flex:1;min-height:150px;max-height:calc(100vh - 300px);padding:8px;overflow-y:auto}.kanban-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow);margin-bottom:16px;padding:20px;transition:all .2s}.kanban-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.entry-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:20px;padding:20px 24px;animation:.3s cubic-bezier(.16,1,.3,1) slideIn;display:flex}.entry-card.new{border-color:var(--brand);box-shadow:0 0 0 3px rgba(var(--brand-rgb), .15)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border:2px solid var(--bg);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
