:root{--bg-dark: #171A1F;--bg-card-dark: #1F2329;--bg-sidebar-dark: #111418;--primary: #F70059;--primary-hover: #d90050;--primary-light: rgba(247, 0, 89, .1);--text-primary: #FFFFFF;--text-secondary: #9CA3AF;--text-muted: #6B7280;--border-color: #2D3139;--success: #10B981;--warning: #F59E0B;--danger: #EF4444;--info: #3B82F6}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-dark);color:var(--text-primary);line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#3d4149}.app-layout{display:flex;height:100vh;width:100%;overflow:hidden}.sidebar{width:260px;background-color:var(--bg-sidebar-dark);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;animation:slideInLeft .3s ease-out}.sidebar-logo{padding:24px 20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:center}.sidebar-logo-img{height:40px;width:auto;transition:transform .3s ease}.sidebar-logo-img:hover{transform:scale(1.05)}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.sidebar-nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;border-radius:8px;position:relative;overflow:hidden}.sidebar-nav-item:before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background-color:var(--primary);transform:scaleY(0);transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar-nav-item:hover{background-color:#f700590d;color:var(--text-primary);transform:translate(4px)}.sidebar-nav-item.active{background-color:var(--primary-light);color:var(--primary)}.sidebar-nav-item.active:before{transform:scaleY(1)}.sidebar-nav-icon{flex-shrink:0;transition:transform .3s ease}.sidebar-nav-item:hover .sidebar-nav-icon{transform:scale(1.1)}.sidebar-nav-label{transition:transform .3s ease}.sidebar-footer{margin-top:auto;padding:16px;border-top:1px solid var(--border-color)}.sidebar-user{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;background-color:var(--bg-dark);margin-bottom:12px;transition:all .3s ease}.sidebar-user:hover{background-color:var(--bg-card-dark)}.sidebar-user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#c90045);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:12px;color:var(--text-secondary)}.sidebar-logout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:none;border-radius:8px;background-color:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.sidebar-logout-btn:hover{background-color:#ef44441a;color:var(--danger);transform:translate(4px)}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.header{height:70px;background-color:var(--bg-card-dark);border-bottom:1px solid var(--border-color);padding:0 32px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.header-title{font-size:24px;font-weight:600;color:var(--text-primary)}.header-actions{display:flex;align-items:center;gap:16px}.header-notification-btn{position:relative;width:40px;height:40px;border-radius:8px;background-color:var(--bg-dark);border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.header-notification-btn:hover{background-color:var(--border-color);color:var(--text-primary);transform:translateY(-2px)}.header-notification-badge{position:absolute;top:6px;right:6px;width:18px;height:18px;border-radius:50%;background-color:var(--primary);color:#fff;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-card-dark);animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.header-user{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:8px;background-color:var(--bg-dark);cursor:pointer;transition:all .3s ease}.header-user:hover{background-color:var(--border-color);transform:translateY(-2px)}.header-user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#FF1493);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.header-user-info{display:flex;flex-direction:column}.header-user-name{font-size:14px;font-weight:500;color:var(--text-primary)}.header-user-role{font-size:12px;color:var(--text-secondary)}.content{flex:1;padding:32px;overflow-y:auto;background-color:var(--bg-dark)}.card{background-color:var(--bg-card-dark);border:1px solid var(--border-color);border-radius:12px;padding:24px;margin-bottom:24px;transition:all .3s cubic-bezier(.4,0,.2,1)}.card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d;border-color:#f700594d}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-title{font-size:18px;font-weight:600;color:var(--text-primary)}.card-body{color:var(--text-secondary)}.grid{display:grid;gap:24px}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.stat-card{background-color:var(--bg-card-dark);border:1px solid var(--border-color);border-radius:12px;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;animation:fadeIn .4s ease-out}.stat-card:nth-child(1){animation-delay:.1s;opacity:0;animation-fill-mode:forwards}.stat-card:nth-child(2){animation-delay:.2s;opacity:0;animation-fill-mode:forwards}.stat-card:nth-child(3){animation-delay:.3s;opacity:0;animation-fill-mode:forwards}.stat-card:nth-child(4){animation-delay:.4s;opacity:0;animation-fill-mode:forwards}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px #0006;border-color:#f7005966}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.stat-card-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:24px}.stat-card-icon.primary{background-color:var(--primary-light);color:var(--primary)}.stat-card-icon.success{background-color:#10b9811a;color:var(--success)}.stat-card-icon.warning{background-color:#f59e0b1a;color:var(--warning)}.stat-card-icon.info{background-color:#3b82f61a;color:var(--info)}.stat-card-icon.danger{background-color:#ef44441a;color:var(--danger)}.stat-card-trend{font-size:12px;font-weight:600;padding:4px 8px;border-radius:6px}.stat-card-trend.up{background-color:#10b9811a;color:var(--success)}.stat-card-trend.down{background-color:#ef44441a;color:var(--danger)}.stat-card-label{font-size:14px;color:var(--text-secondary);margin-bottom:8px}.stat-card-value{font-size:32px;font-weight:700;color:var(--text-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-decoration:none;white-space:nowrap;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff1a;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn:hover:before{width:300px;height:300px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px)}.btn-secondary{background-color:var(--bg-dark);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--border-color)}.btn-success{background-color:var(--success);color:#fff}.btn-success:hover:not(:disabled){background-color:#0ea373}.btn-danger{background-color:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:14px 28px;font-size:16px}.btn-icon{padding:10px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.form-label-required:after{content:"*";color:var(--danger);margin-left:4px}.form-input{width:100%;padding:12px 16px;background-color:var(--bg-dark);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-input::placeholder{color:var(--text-muted)}.form-textarea{min-height:100px;resize:vertical}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239CA3AF' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.form-error{color:var(--danger);font-size:13px;margin-top:6px}.table-container{overflow-x:auto;border-radius:12px;border:1px solid var(--border-color)}.table{width:100%;border-collapse:collapse;background-color:var(--bg-card-dark)}.table thead{background-color:var(--bg-dark);border-bottom:1px solid var(--border-color)}.table th{padding:16px;text-align:left;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.table td{padding:16px;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.table tbody tr{transition:background-color .2s ease}.table tbody tr:hover{background-color:var(--bg-dark)}.table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600;white-space:nowrap}.badge-primary{background-color:var(--primary-light);color:var(--primary)}.badge-success{background-color:#10b9811a;color:var(--success)}.badge-warning{background-color:#f59e0b1a;color:var(--warning)}.badge-danger{background-color:#ef44441a;color:var(--danger)}.badge-info{background-color:#3b82f61a;color:var(--info)}.badge-gray{background-color:#9ca3af1a;color:var(--text-secondary)}.alert{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;font-size:14px;animation:fadeIn .3s ease-out}.alert-success{background-color:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--success)}.alert-danger{background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--danger)}.alert-warning{background-color:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:var(--warning)}.alert-info{background-color:#3b82f61a;border:1px solid rgba(59,130,246,.3);color:var(--info)}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background-color:var(--bg-card-dark);border:1px solid var(--border-color);border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease-out}.modal-small{max-width:480px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:24px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:20px;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:4px;line-height:1;transition:color .2s ease}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{padding:24px;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end}.modal-content{background-color:var(--bg-card-dark);border:1px solid var(--border-color);border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease-out}.modal-title{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:600;color:var(--text-primary)}.modal-select{width:100%;padding:12px 40px 12px 16px;background-color:var(--bg-dark);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;transition:all .2s ease;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239CA3AF' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer}.modal-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.modal-select option{background-color:var(--bg-dark);color:var(--text-primary);padding:12px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--bg-dark) 0%,#0D0F13 100%)}.login-card{background-color:var(--bg-card-dark);border:1px solid var(--border-color);border-radius:16px;padding:48px;width:100%;max-width:440px;box-shadow:0 20px 60px #0000004d}.login-logo{text-align:center;margin-bottom:32px}.login-logo-text{font-size:32px;font-weight:700;color:var(--text-primary)}.login-logo-accent{color:var(--primary)}.login-title{font-size:24px;font-weight:600;color:var(--text-primary);text-align:center;margin-bottom:32px}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.p-2{padding:8px}.p-4{padding:16px}.p-6{padding:24px}.rounded{border-radius:8px}.rounded-full{border-radius:9999px}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-sm{font-size:14px}.text-xs{font-size:12px}.text-lg{font-size:18px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.text-primary{color:var(--primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.header-left{display:flex;align-items:center;gap:16px}.header-menu-btn{display:none;width:44px;height:44px;border-radius:8px;background-color:var(--bg-dark);border:none;color:var(--text-secondary);cursor:pointer;align-items:center;justify-content:center;transition:all .3s ease}.header-menu-btn:hover{background-color:var(--primary);color:#fff}.sidebar-overlay{display:none;position:fixed;inset:0;background-color:#00000080;z-index:99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media(max-width:1024px){.header-user-info{display:none}.header-user{padding:8px}}@media(max-width:768px){.sidebar{position:fixed;left:-280px;top:0;bottom:0;z-index:100;transition:left .3s cubic-bezier(.4,0,.2,1);box-shadow:none}.sidebar.open{left:0;box-shadow:4px 0 24px #00000080}.sidebar-overlay{display:block}.header-menu-btn{display:flex}.header{padding:0 12px;height:60px}.header-title{display:none}.header-left{gap:8px}.header-user{display:none}.header-notification-btn{width:40px;height:40px}.header-logout-btn span{display:none}.header-logout-btn{padding:10px;min-width:auto}.header-actions{gap:8px}.content{padding:16px}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.card{padding:16px}.card-header{flex-direction:column;gap:12px;align-items:flex-start}.card-header .btn{width:100%}.modal{width:95%;max-width:none;margin:16px;max-height:calc(100vh - 32px)}.modal-body{max-height:calc(100vh - 200px)}.modal .grid-cols-2{grid-template-columns:1fr}.modal .col-span-2{grid-column:span 1}.table-container{overflow-x:auto}.table{min-width:600px}.stat-card{padding:16px}.stat-value{font-size:24px}.search-wrapper,.search-wrapper input{width:100%}}@media(max-width:480px){.header{height:60px;padding:0 12px}.header-left{gap:8px}.header-menu-btn{width:40px;height:40px}.header-title{font-size:16px}.header-actions{gap:8px}.content,.card{padding:12px}.btn{padding:8px 12px;font-size:13px}.form-input{padding:10px 12px;font-size:14px}}.action-button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.action-button:before{content:"";position:absolute;inset:0;background:currentColor;opacity:0;transition:opacity .3s ease}.action-button:hover:before{opacity:.1}.action-button-edit{background-color:transparent;color:var(--text-secondary)}.action-button-edit:hover{background-color:var(--primary-light);color:var(--primary);transform:translateY(-2px)}.action-button-delete{background-color:transparent;color:var(--text-secondary)}.action-button-delete:hover{background-color:#ef44441a;color:var(--danger);transform:translateY(-2px)}.kanban-board{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:24px}.kanban-column{background-color:var(--bg-card-dark);border-radius:12px;padding:16px;min-height:400px;border:1px solid var(--border-color)}.kanban-column-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.kanban-column-title{font-size:16px;font-weight:600;color:var(--text-primary)}.kanban-column-badge{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;font-size:13px;font-weight:600;color:#fff}.kanban-column-badge.bg-info{background-color:var(--info)}.kanban-column-badge.bg-warning{background-color:var(--warning)}.kanban-column-badge.bg-primary{background-color:var(--primary)}.kanban-column-badge.bg-success{background-color:var(--success)}.kanban-column-content{display:flex;flex-direction:column;gap:12px}.kanban-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.kanban-card{background-color:var(--bg-dark);border:1px solid var(--border-color);border-radius:10px;padding:14px;cursor:grab;transition:all .3s cubic-bezier(.4,0,.2,1)}.kanban-card:hover{border-color:var(--primary);box-shadow:0 4px 12px #f7005926;transform:translateY(-2px)}.kanban-card:active{cursor:grabbing;opacity:.7}.kanban-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.kanban-card-actions{display:flex;gap:6px;opacity:0;transition:opacity .2s ease}.kanban-card:hover .kanban-card-actions{opacity:1}.kanban-card-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:10px;line-height:1.4}.kanban-card-meta{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);margin-bottom:6px}.kanban-card-description{font-size:13px;color:var(--text-secondary);margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.kanban-card-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:500;margin-top:8px}.kanban-card-badge.danger{background-color:#ef444426;color:var(--danger)}.kanban-card-badge.warning{background-color:#f59e0b26;color:var(--warning)}.space-y-4>*+*{margin-top:16px}.alert.alert-info{background-color:#3b82f61a;border-color:#3b82f64d;color:var(--info)}.kanban-card.dragging{opacity:.5;transform:scale(.95);cursor:grabbing}.kanban-column.drag-over{background-color:#f700590d;border-color:var(--primary)}.kanban-card{will-change:transform,opacity}.kanban-column{transition:background-color .2s ease,border-color .2s ease}
