@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--brand: #2563eb;--brand-dark: #1d4ed8;--brand-light: #eff4ff;--brand-mid: #dbe6fd;--bg: #f6f7f9;--white: #ffffff;--border: #e5e8ee;--border-strong: #d6dae3;--text: #1a202c;--text-muted: #5f6b7c;--text-faint: #98a1b0;--danger: #dc2626;--success: #16a34a;--warning: #d97706;--radius: 14px;--radius-sm: 9px;--shadow: 0 1px 2px rgba(16,24,40,.04), 0 1px 3px rgba(16,24,40,.06);--shadow-md: 0 2px 4px rgba(16,24,40,.04), 0 6px 16px rgba(16,24,40,.07);--shadow-lg: 0 8px 24px rgba(16,24,40,.1), 0 20px 48px rgba(16,24,40,.12);--sidebar-bg: #101623;--sidebar-border: #1d2536;--sidebar-text: #9aa4b8;--sidebar-text-active: #ffffff;--sidebar-hover: rgba(255,255,255,.05);--sidebar-active: rgba(96,140,255,.14);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.55}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cdd3dd;border-radius:8px;border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background:#aeb6c4;border:2px solid transparent;background-clip:content-box}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;min-width:240px;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;overflow-y:auto}.sidebar::-webkit-scrollbar-thumb{background:#2a3447;border:2px solid transparent;background-clip:content-box}.sidebar-logo{padding:20px 18px 16px;border-bottom:1px solid var(--sidebar-border);display:flex;align-items:center;gap:10px;justify-content:space-between}.sidebar-logo img{height:40px;object-fit:contain;background:#fff;padding:5px 10px;border-radius:9px}.sidebar-logo span{font-size:13px;color:var(--sidebar-text);font-weight:500}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0d121c8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:199}.sidebar-close{display:none;background:none;border:none;padding:6px;cursor:pointer;color:var(--sidebar-text);border-radius:var(--radius-sm)}.sidebar-close:hover{background:var(--sidebar-hover);color:#fff}.hamburger-btn{display:none;background:var(--white);border:1px solid var(--border);padding:7px 9px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text);align-items:center;justify-content:center}.hamburger-btn:hover{background:var(--bg)}.sidebar-section{padding:18px 16px 6px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:#5b6679}.nav-link{display:flex;align-items:center;gap:11px;padding:9px 12px;margin:1px 10px;border-radius:8px;font-size:13.5px;font-weight:500;font-family:var(--font);color:var(--sidebar-text);text-decoration:none;cursor:pointer;border:none;background:none;width:calc(100% - 20px);text-align:left;transition:background .15s,color .15s}.nav-link:hover{background:var(--sidebar-hover);color:#dfe5ef}.nav-link.active{background:var(--sidebar-active);color:var(--sidebar-text-active);font-weight:600;box-shadow:inset 0 0 0 1px #608cff38}.nav-link.active svg{color:#7ea5ff}.nav-link svg{flex-shrink:0;opacity:.85}.sidebar-spacer{flex:1}.sidebar-user{padding:16px;border-top:1px solid var(--sidebar-border);font-size:12px;color:var(--sidebar-text)}.sidebar-user strong{display:block;color:#e7ebf2;font-size:13px;font-weight:600}.main-area{margin-left:240px;flex:1;min-height:100vh;display:flex;flex-direction:column}.top-bar{background:#ffffffd9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border);padding:0 28px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.top-bar h1{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.01em}.top-bar-actions{display:flex;align-items:center;gap:10px}.page-body{padding:28px 32px;flex:1}.content-wrap{max-width:1380px;width:100%;margin:0 auto}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow)}.card-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:16px;letter-spacing:-.01em}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;border:1px solid transparent;transition:background .15s,border-color .15s,box-shadow .15s,transform .1s;white-space:nowrap;text-decoration:none}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(180deg,var(--brand) 0%,var(--brand-dark) 100%);color:#fff;border-color:var(--brand-dark);box-shadow:0 1px 2px #1d4ed859,inset 0 1px #ffffff1f}.btn-primary:hover{background:linear-gradient(180deg,#3b76f0 0%,var(--brand) 100%);box-shadow:0 2px 8px #1d4ed859}.btn-secondary{background:var(--white);color:var(--text);border-color:var(--border-strong);box-shadow:var(--shadow)}.btn-secondary:hover{background:#f9fafc;border-color:#c3cad6}.btn-danger{background:var(--danger);color:#fff;border-color:#b91c1c;box-shadow:0 1px 2px #dc26264d}.btn-danger:hover{background:#ef3b3b}.btn-sm{padding:5px 11px;font-size:12px}.btn-ghost{background:none;border-color:transparent;color:var(--text-muted);box-shadow:none}.btn-ghost:hover{background:#eef0f4;color:var(--text)}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.form-label{font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px}.form-control{padding:8.5px 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:13.5px;font-family:var(--font);color:var(--text);background:var(--white);outline:none;transition:border-color .15s,box-shadow .15s}.form-control:hover{border-color:#c3cad6}.form-control:focus{border-color:var(--brand);box-shadow:0 0 0 3px #2563eb21}.form-control::placeholder{color:var(--text-faint)}select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:80px}.data-table{width:100%;border-collapse:collapse;font-size:13.5px}.data-table thead tr{background:#f8f9fb;color:var(--text-muted);border-bottom:1px solid var(--border)}.data-table th{padding:11px 14px;text-align:left;font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted)}.data-table td{padding:11px 14px;border-bottom:1px solid #eef0f4}.data-table tbody tr{transition:background .12s}.data-table tbody tr:hover{background:#f7f9fd}.data-table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.2px}.badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.7}.badge-draft{background:#f1f3f6;color:#5f6b7c}.badge-sent{background:#e8f0fe;color:#1d4ed8}.badge-paid{background:#e7f6ec;color:#15803d}.badge-overdue{background:#fdebea;color:#c2261d}.badge-todo{background:#f1f3f6;color:#5f6b7c}.badge-progress{background:#fdf3e3;color:#b45309}.badge-done{background:#e7f6ec;color:#15803d}.badge-low{background:#f1f3f6;color:#5f6b7c}.badge-medium{background:#fdf3e3;color:#b45309}.badge-high{background:#fdebea;color:#c2261d}.badge-admin{background:#e8f0fe;color:#1d4ed8}.badge-team{background:#e7f6ec;color:#15803d}.badge-viewer{background:#f1f3f6;color:#5f6b7c}.badge-credit{background:#e7f6ec;color:#15803d}.badge-debit{background:#fdebea;color:#c2261d}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d121c73;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .15s ease}.modal{background:var(--white);border-radius:16px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modalIn .18s cubic-bezier(.16,1,.3,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:none}}.modal-lg{max-width:780px}.modal-xl{max-width:960px}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--white);z-index:5;border-radius:16px 16px 0 0}.modal-header h2{font-size:16px;font-weight:700;letter-spacing:-.01em}.modal-body{padding:22px 24px}.modal-footer{padding:14px 24px 20px;display:flex;gap:10px;justify-content:flex-end;border-top:1px solid var(--border)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:box-shadow .18s,transform .18s}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-faint);margin-bottom:7px}.kpi-value{font-size:27px;font-weight:700;color:var(--text);line-height:1.1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.kpi-sub{font-size:12px;color:var(--text-muted);margin-top:5px}.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px}.filter-bar .form-control{padding:7px 11px}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state svg{color:#c9cfda;margin-bottom:12px}.empty-state p{font-size:15px;margin-bottom:6px;font-weight:500}.empty-state small{font-size:13px;color:var(--text-faint)}.divider{border:none;border-top:1px solid var(--border);margin:18px 0}.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start}.kanban-col{background:#f0f2f6;border-radius:var(--radius);padding:14px}.kanban-col-title{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}.kanban-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:8px;cursor:pointer;box-shadow:var(--shadow);transition:box-shadow .15s,border-color .15s,transform .15s}.kanban-card:hover{border-color:#b9c8ec;box-shadow:var(--shadow-md);transform:translateY(-1px)}.kanban-card-title{font-size:13px;font-weight:600;margin-bottom:6px}.kanban-card-meta{font-size:11px;color:var(--text-muted);display:flex;gap:8px;flex-wrap:wrap}.progress-track{background:#e8ebf0;border-radius:10px;height:6px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--brand) 0%,#4f86f5 100%);border-radius:10px;transition:width .4s}.avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#3b76f0,#1d4ed8);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;box-shadow:inset 0 1px #ffffff2e}.tab-bar{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:20px}.tab-btn{padding:9px 16px;font-size:13px;font-weight:600;font-family:var(--font);border:none;background:none;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.tab-btn.active{color:var(--brand);border-bottom-color:var(--brand)}.tab-btn:hover{color:var(--brand)}.alert{padding:11px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:14px;display:flex;align-items:center;gap:8px}.alert-warning{background:#fdf6e8;color:#92580a;border:1px solid #f3dfb4}.alert-danger{background:#fdedec;color:#b02a20;border:1px solid #f6c8c5}.alert-success{background:#ebf7ef;color:#1a7740;border:1px solid #bfe5cc}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(1100px 500px at 70% -10%,#dfe9fb 0%,var(--bg) 55%)}.login-box{background:var(--white);border:1px solid var(--border);border-radius:18px;padding:40px 40px 36px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-logo{text-align:center;margin-bottom:28px}.login-logo img{height:60px}.login-box h2{font-size:19px;font-weight:700;text-align:center;margin-bottom:6px;letter-spacing:-.01em}.login-box p{font-size:13px;color:var(--text-muted);text-align:center;margin-bottom:24px}@media print{.sidebar,.main-area>.top-bar,.no-print{display:none!important}.main-area{margin-left:0}.page-body{padding:0}}@media(max-width:900px){.sidebar{transform:translate(-100%);transition:transform .22s ease;box-shadow:4px 0 24px #0000004d}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.sidebar-close{display:inline-flex;align-items:center;justify-content:center}.hamburger-btn{display:inline-flex}.main-area{margin-left:0}.top-bar{padding:0 14px;height:54px}.top-bar h1{font-size:15px}.page-body{padding:16px 14px}.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr 1fr}.kanban{grid-template-columns:1fr}.data-table{font-size:13px}.data-table th,.data-table td{padding:8px 10px}.card{padding:16px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.card:has(>.data-table),.card:has(>table){overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0}}@media(max-width:600px){body{font-size:13.5px}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;gap:10px}.page-body{padding:12px 10px}.top-bar{padding:0 10px;height:52px}.top-bar h1{font-size:14px}.top-bar-actions .btn{padding:6px 10px;font-size:12px}.top-bar-actions .btn-sm{padding:5px 8px;font-size:11px}.card{padding:14px 12px;border-radius:10px}.kpi-value{font-size:22px}.modal-overlay{padding:0;align-items:flex-end}.modal{max-width:100%;max-height:95vh;border-radius:16px 16px 0 0}.modal-header{padding:14px 16px 12px;border-radius:16px 16px 0 0}.modal-header h2{font-size:15px}.modal-body{padding:14px 16px}.modal-footer{padding:12px 16px 16px;flex-direction:column-reverse}.modal-footer .btn{width:100%;justify-content:center}.data-table{min-width:600px}.form-group{margin-bottom:10px}.form-control{padding:9px 11px;font-size:14px}.login-box{padding:28px 22px 24px;max-width:100%;margin:16px}.filter-bar{gap:8px}.filter-bar .form-control{width:100%!important}}@supports (padding: max(0px)){.sidebar{padding-top:env(safe-area-inset-top)}.top-bar{padding-top:env(safe-area-inset-top);height:calc(60px + env(safe-area-inset-top))}@media(max-width:900px){.top-bar{height:calc(54px + env(safe-area-inset-top))}}.page-body{padding-bottom:max(28px,env(safe-area-inset-bottom))}}@media(max-width:900px){.tasks-projects{width:100%!important}}@media(hover:none)and (pointer:coarse){.btn{min-height:38px}.btn-sm{min-height:32px}.nav-link{padding:11px 14px}.data-table tbody tr:hover{background:transparent}}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.text-brand{color:var(--brand)}.fw-bold{font-weight:700}.mt-0{margin-top:0}.mb-0{margin-bottom:0}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-center{display:flex;align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}
