@import"https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@300;400;500;600;700;800&display=swap";:root{--bg-main: #F8FAFC;--bg-card: #FFFFFF;--bg-sidebar: #0F172A;--sidebar-hover: #1E293B;--sidebar-active: #CE1E1E;--primary: #CE1E1E;--primary-light: #FEF2F2;--primary-dark: #A01818;--text-primary: #1E293B;--text-secondary: #64748B;--text-muted: #94A3B8;--border: #E2E8F0;--border-light: #F1F5F9;--success: #10B981;--success-bg: #ECFDF5;--warning: #F59E0B;--warning-bg: #FFFBEB;--info: #3B82F6;--info-bg: #EFF6FF;--danger: #EF4444;--danger-bg: #FEF2F2;--sidebar-width: 260px;--header-height: 56px;--radius: 16px;--radius-sm: 10px;--radius-lg: 20px;--gap: 24px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -2px rgba(0,0,0,.05);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.04);--shadow-xl: 0 20px 25px -5px rgba(0,0,0,.1), 0 8px 10px -6px rgba(0,0,0,.04);--ease: cubic-bezier(.4, 0, .2, 1);font-family:Be Vietnam Pro,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:var(--text-primary);background-color:var(--bg-main);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0;font-family:Be Vietnam Pro,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{margin:0;min-width:320px;min-height:100vh;font-family:Be Vietnam Pro,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-main);color:var(--text-primary)}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.page-enter{animation:fadeIn .3s var(--ease) forwards}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9 37%,#e2e8f0 63%);background-size:800px 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes toastIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.95)}}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{pointer-events:auto;padding:14px 22px;border-radius:14px;font-size:14px;font-weight:500;box-shadow:var(--shadow-lg);animation:toastIn .3s var(--ease) forwards;display:flex;align-items:center;gap:10px;max-width:400px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.toast.toast-exit{animation:toastOut .3s var(--ease) forwards}.toast-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.toast-error{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.toast-info{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.toast-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}@keyframes urgentPulse{0%,to{opacity:1}50%{opacity:.6}}.pulse{animation:urgentPulse 1.5s ease-in-out infinite}@media(max-width:768px){:root{--sidebar-width: 0px}}.sidebar-overlay{position:fixed;inset:0;background:#0f172a80;z-index:998;opacity:0;pointer-events:none;transition:opacity .3s var(--ease);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sidebar-overlay.active{opacity:1;pointer-events:auto}@keyframes saveSuccess{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.save-success{animation:saveSuccess .3s var(--ease)}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content{animation:modalIn .25s var(--ease) forwards}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.7;background-color:#fee2e2}}input:focus,textarea:focus,select:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px #ce1e1e14}:root{--bg-app: #f4f7fb;--bg-surface: #ffffff;--bg-surface-muted: #f8fafc;--bg-sidebar: #0b1220;--bg-sidebar-soft: #111b2e;--text-main: #0f172a;--text-subtle: #64748b;--text-faint: #94a3b8;--border-soft: #e2e8f0;--border-faint: #eef2f7;--primary: #c81e1e;--primary-strong: #a51818;--primary-soft: #fff1f2;--info: #2563eb;--info-soft: #eff6ff;--success: #16a34a;--warning: #d97706;--danger: #dc2626;--shadow-sm: 0 1px 3px rgba(15, 23, 42, .05);--shadow-md: 0 8px 24px rgba(15, 23, 42, .08);--shadow-lg: 0 18px 48px rgba(15, 23, 42, .16);--radius-sm: 10px;--radius-md: 16px;--radius-lg: 22px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%}body{font-family:Be Vietnam Pro,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top right,rgba(37,99,235,.06),transparent 26%),var(--bg-app);color:var(--text-main)}button,input,textarea,select{font-family:inherit}button{transition:all .18s ease}button:hover:not(:disabled){transform:translateY(-1px)}button:disabled{cursor:not-allowed}input,textarea,select{background:#fff}.app-shell{display:flex;min-height:100vh;background:var(--bg-app)}.app-content{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.app-main{flex:1;overflow-y:auto;max-height:calc(100vh - 68px);padding:28px;background:linear-gradient(180deg,#ffffff73,#fff0 180px),var(--bg-app)}.page-surface{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.page-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.toolbar-card{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.btn{border:1px solid var(--border-soft);background:var(--bg-surface);color:var(--text-main);border-radius:12px;padding:10px 14px;cursor:pointer;font-size:13px;font-weight:700}.btn-primary{border:none;background:linear-gradient(135deg,var(--primary),#e8453c);color:#fff;box-shadow:0 8px 20px #c81e1e38}.btn-soft{background:var(--bg-surface-muted);color:#475569}.btn-info{border:1px solid #bfdbfe;background:var(--info-soft);color:#1d4ed8}.btn-success{border:none;background:var(--success);color:#fff}.btn-warning{border:none;background:#7c3aed;color:#fff}.btn-danger{border:none;background:var(--danger);color:#fff}.filter-pill{padding:8px 14px;border-radius:999px;border:1px solid var(--border-soft);background:var(--bg-surface);color:#334155;font-size:13px;font-weight:700;cursor:pointer;box-shadow:0 1px 4px #0000000f}.filter-pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:800}.panel-card{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.panel-card-header{padding:16px 18px;border-bottom:1px solid var(--border-soft);font-weight:800}.inline-toolbar{display:flex;gap:8px;flex-wrap:wrap}.metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:16px}.metric-card{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:14px 16px}.metric-label{font-size:12px;color:var(--text-subtle);font-weight:700;margin-bottom:8px}.metric-value{font-size:24px;font-weight:800;color:var(--text-main)}.report-card{background:var(--bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);display:flex;overflow:hidden;transition:box-shadow .2s ease,transform .18s ease}.report-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.report-card-body{flex:1;padding:18px}.report-muted{font-size:12px;color:var(--text-subtle)}.report-modal-card{background:var(--bg-surface-muted);border:1px solid var(--border-soft);border-radius:14px;padding:14px;margin-bottom:16px}.section-title{font-size:13px;font-weight:800;color:var(--text-main);margin-bottom:10px}.section-note{font-size:12px;color:var(--text-subtle)}.task-card{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:16px;transition:box-shadow .18s ease,transform .18s ease}.task-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.board-column{min-width:300px;flex:0 0 300px;border-radius:18px;display:flex;flex-direction:column;max-height:calc(100vh - 220px);border:1px solid var(--border-soft);box-shadow:var(--shadow-sm);overflow:hidden}.board-column-header{padding:14px 16px;display:flex;justify-content:space-between;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.35)}.board-column-body{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px}.board-card{background:#fffffff2;border-radius:16px;padding:14px;cursor:pointer;box-shadow:0 1px 4px #0000000f;transition:transform .15s ease,box-shadow .15s ease}.board-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.page-title{font-size:24px;font-weight:800;letter-spacing:-.02em;color:var(--text-main)}.page-subtitle{margin-top:4px;color:var(--text-subtle);font-size:13px}.topbar{height:68px;background:#ffffffdb;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid rgba(226,232,240,.9);display:flex;align-items:center;justify-content:space-between;padding:0 28px;gap:16px;flex-shrink:0;box-shadow:0 1px #fff9}.topbar-breadcrumb{display:flex;align-items:center;gap:8px;font-size:14px}.topbar-user{display:flex;align-items:center;gap:10px;padding:5px 10px 5px 5px;background:var(--bg-surface-muted);border-radius:999px;border:1px solid var(--border-soft)}.topbar-avatar{width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,var(--primary),#e85d5d);display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:800;box-shadow:0 8px 18px #c81e1e40}.sidebar-shell{width:268px;height:100vh;background:linear-gradient(180deg,#0b1220,#0f172a);display:flex;flex-direction:column;flex-shrink:0;box-shadow:8px 0 30px #02061729;overflow:hidden}.sidebar-brand{padding:22px 20px 18px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-user{padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px}.sidebar-nav{padding:10px 12px;flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain}.sidebar-divider{font-size:10px;font-weight:800;color:#475569;letter-spacing:.12em;padding:18px 14px 8px;text-transform:uppercase}.sidebar-link{width:100%;text-align:left;padding:11px 14px;border:none;cursor:pointer;border-radius:12px;margin-bottom:3px;border-left:3px solid transparent;color:#94a3b8;font-weight:500;font-size:13px;display:flex;align-items:center;gap:10px;background:transparent}.sidebar-link:hover{background:#ffffff0d;color:#e2e8f0}.sidebar-link.active{background:#c81e1e24;border-left-color:var(--primary);color:#fecaca}.sidebar-bottom{border-top:1px solid rgba(255,255,255,.06);padding:12px 14px}.sidebar-logout{width:100%;text-align:left;padding:10px 14px;border:none;cursor:pointer;border-radius:10px;font-size:13px;display:flex;align-items:center;gap:8px;color:#94a3b8;font-weight:600;background:transparent}.sidebar-logout:hover{background:#ef44441a;color:#fca5a5}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top right,rgba(200,30,30,.14) 0%,transparent 32%),radial-gradient(circle at bottom left,rgba(59,130,246,.1) 0%,transparent 36%),linear-gradient(135deg,#0b1220,#172036 40%,#0b1220);position:relative;overflow:hidden}.auth-card{background:#fffffff5;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:28px;padding:44px 40px;width:420px;max-width:92vw;box-shadow:0 24px 70px #02061757,0 0 0 1px #ffffff14;text-align:center;position:relative;z-index:1;border:1px solid rgba(255,255,255,.25)}.auth-logo{width:72px;height:72px;border-radius:22px;margin:0 auto 18px;background:linear-gradient(135deg,var(--primary),#e8453c);display:flex;align-items:center;justify-content:center;font-size:32px;box-shadow:0 14px 30px #c81e1e47}.auth-title{font-size:24px;font-weight:800;color:var(--text-main);letter-spacing:-.03em}.auth-subtitle{font-size:13px;color:var(--text-faint);margin:6px 0 22px;line-height:1.6}.field-label{font-size:13px;font-weight:700;color:#475569;display:block;margin-bottom:8px}.field-input{width:100%;padding:13px 16px;border-radius:16px;border:1.5px solid var(--border-soft);font-size:14px;outline:none;background:var(--bg-surface-muted);transition:all .2s ease}.field-input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #c81e1e14}.primary-btn{width:100%;padding:14px;border-radius:16px;border:none;background:linear-gradient(135deg,var(--primary),#e8453c);color:#fff;font-size:15px;font-weight:800;cursor:pointer;box-shadow:0 8px 24px #c81e1e47;letter-spacing:.01em}.primary-btn:disabled{background:#cbd5e1;box-shadow:none}.toast-container{position:fixed;top:16px;right:16px;z-index:2000;display:flex;flex-direction:column;gap:10px}.toast{min-width:240px;max-width:360px;padding:12px 14px;border-radius:14px;background:#0f172aeb;color:#fff;box-shadow:var(--shadow-lg);font-size:13px;font-weight:600}.toast-success{background:#16a34af2}.toast-error{background:#dc2626f2}.toast-warning{background:#d97706f2}.toast-info{background:#2563ebf2}.admin-modal-overlay{position:fixed;inset:0;background:#02061785;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1200;padding:16px}.admin-modal{position:relative;background:var(--bg-surface);border-radius:22px;width:min(100%,860px);max-width:860px;max-height:calc(100vh - 32px);display:flex;flex-direction:column;margin:auto;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--border-soft)}.admin-modal-header{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:20px 24px 16px;border-bottom:1px solid var(--border-soft);flex-shrink:0}.admin-modal-body{padding:20px 24px;overflow-y:auto}.admin-form-grid{display:grid;gap:16px;margin-bottom:16px}.admin-form-grid-2{grid-template-columns:1fr 1fr}.admin-modal-footer{display:flex;gap:8px;padding:16px 24px 20px;border-top:1px solid var(--border-soft);background:var(--bg-surface);flex-shrink:0}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;min-width:980px}.admin-table th,.admin-table td{padding:13px 14px;border-bottom:1px solid var(--border-faint);font-size:14px;vertical-align:top;text-align:left}.admin-table th{background:var(--bg-surface-muted);color:var(--text-subtle);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}@media(max-width:1024px){.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.board-column{min-width:280px;flex-basis:280px}}@media(max-width:768px){.app-main{padding:16px}.topbar{height:62px;padding:0 16px}.topbar-user{max-width:42vw;overflow:hidden}.topbar-user span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-header{align-items:flex-start}.inline-toolbar{width:100%}.metric-grid{grid-template-columns:1fr 1fr}.toolbar-card{padding:14px}.toolbar-card>*{min-width:100%}.board-column{min-width:88vw;flex-basis:88vw}.admin-table{min-width:760px}.admin-modal-overlay{align-items:flex-start;padding:12px}.admin-modal{width:100%;max-height:calc(100vh - 24px);margin-top:8px;border-radius:16px}.admin-modal-body,.admin-modal-header{padding:16px}.admin-form-grid-2{grid-template-columns:1fr}.admin-modal-footer{flex-direction:column;padding:16px}}@media(max-width:480px){.metric-grid{grid-template-columns:1fr}.auth-card{padding:34px 22px;border-radius:22px}.page-title{font-size:22px}}
