@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Montserrat:wght@600;700;800&display=swap";:root{--bg-dark:#0f1115;--bg-card:#191c2499;--border-glass:#ffffff14;--text-primary:#f0f0f5;--text-secondary:#9ba1a6;--accent-blue:#3b82f6;--accent-purple:#8b5cf6;--accent-green:#10b981;--accent-yellow:#f59e0b;--accent-red:#ef4444;--radius-lg:16px;--radius-md:12px;--radius-sm:8px;--shadow-glass:0 8px 32px 0 #0000004d;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-dark);color:var(--text-primary);background-image:radial-gradient(circle at 15%,#3b82f614 0%,#0000 25%),radial-gradient(circle at 85% 30%,#8b5cf614 0%,#0000 25%);background-attachment:fixed;min-height:100vh;font-family:Inter,sans-serif}.app-layout{max-width:1600px;height:100vh;margin:0 auto;display:flex;overflow:hidden}.sidebar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--border-glass);z-index:10;background:#0f1115d9;flex-direction:column;width:280px;min-width:280px;height:100%;padding:1.5rem;display:flex}.sidebar-header{border-bottom:1px solid var(--border-glass);margin-bottom:2rem;padding-bottom:1.5rem}.sidebar-header h1{background:linear-gradient(135deg, var(--text-primary), #a1a1aa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-family:Montserrat,sans-serif;font-size:1.5rem;font-weight:800;line-height:1.2}.main-content{flex:1;height:100vh;padding:2rem;overflow-y:auto}.tab-navigation{border-radius:var(--radius-md);background:0 0;border:none;flex-direction:column;flex:1;gap:.5rem;padding:.35rem;display:flex;overflow-y:auto}.tab-btn{color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-smooth);text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;padding:.6rem 1.25rem;font-weight:600;display:flex}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent-blue);border-left:3px solid var(--accent-blue);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:#3b82f626}.sidebar-footer{border-top:1px solid var(--border-glass);margin-top:auto;padding-top:1.5rem}.user-info-sidebar{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-smooth);background:#ffffff08;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.5rem;display:flex}.user-info-sidebar:hover{background:#ffffff14}.user-avatar{background:linear-gradient(135deg, var(--accent-blue), var(--accent-purple));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;font-weight:700;display:flex}.user-details{flex-direction:column;display:flex;overflow:hidden}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.user-role{color:var(--text-secondary);text-transform:capitalize;font-size:.75rem}.profile-dropdown{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-glass);border-radius:var(--radius-md);z-index:20;background:#0f1115f2;width:100%;margin-bottom:.5rem;animation:.2s ease-out slideUp;position:absolute;bottom:100%;left:0;overflow:hidden;box-shadow:0 10px 25px #00000080}.profile-menu-item{color:var(--text-primary);text-align:left;cursor:pointer;width:100%;transition:var(--transition-smooth);background:0 0;border:none;align-items:center;gap:.75rem;padding:.8rem 1rem;font-size:.9rem;display:flex}.profile-menu-item:hover{background:#ffffff0d}.profile-menu-item.logout{color:var(--accent-red);border-top:1px solid var(--border-glass)}.profile-menu-item.logout:hover{background:#ef44441a}.btn-logout-sidebar{width:100%;color:var(--accent-red);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-smooth);background:#ef44441a;border:1px solid #ef444433;justify-content:center;align-items:center;gap:.5rem;padding:.75rem;font-weight:600;display:flex}.btn-logout-sidebar:hover{background:#ef444433}.btn-primary{background:linear-gradient(135deg, var(--accent-blue), var(--accent-purple));color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-smooth);border:none;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;display:flex;box-shadow:0 4px 15px #6366f14d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f180}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-glass);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-smooth);background:#ffffff0d;padding:.5rem 1rem}.btn-secondary:hover{background:#ffffff1a}.glass-panel{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);box-shadow:var(--shadow-glass)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.btn-action{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-smooth);border:none;padding:.35rem .8rem;font-size:.8rem;font-weight:600}.btn-action.edit{color:var(--accent-yellow);background:#f59e0b26;border:1px solid #f59e0b4d}.btn-action.edit:hover{background:#f59e0b4d}.btn-action.delete{color:var(--accent-red);background:#ef444426;border:1px solid #ef44444d}.btn-action.delete:hover{background:#ef44444d}.table-responsive{width:100%;overflow-x:auto}.plan-table{border-collapse:collapse;text-align:left;width:100%}.plan-table th{color:var(--text-secondary);border-bottom:2px solid var(--border-glass);background:#0006;padding:1.25rem 1rem;font-weight:600}.plan-table td{border-bottom:1px solid var(--border-glass);vertical-align:middle;padding:1rem}.plan-table tbody tr{transition:var(--transition-smooth)}.plan-table tbody tr:hover{background:#ffffff08}.empty-state{color:var(--text-secondary);font-style:italic;padding:3rem!important}.filter-input{border:1px solid var(--border-glass);color:var(--text-primary);border-radius:var(--radius-md);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;transition:var(--transition-smooth);background:#0006;padding:0 1rem;font-family:Inter,sans-serif;font-size:.95rem}.filter-input:focus{border-color:var(--accent-blue);outline:none;box-shadow:0 0 0 2px #3b82f633}.form-group select{border:1px solid var(--border-glass);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:var(--transition-smooth);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background:#0000004d;padding:.8rem 1rem;font-family:inherit}.form-group select:focus{border-color:var(--accent-blue);outline:none;box-shadow:0 0 0 2px #3b82f633}.form-group select option{background:var(--bg-dark);color:var(--text-primary)}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;background:#0009;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.3s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.modal-content{background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:var(--radius-lg);width:90%;max-width:600px;padding:2rem;animation:.3s ease-out slideUp;position:relative;box-shadow:0 20px 40px #0006}.modal-header{border-bottom:1px solid var(--border-glass);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.btn-close-modal{color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;font-size:1.5rem}.btn-close-modal:hover{color:var(--accent-red)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:9999;background:#0f172ab3;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-box{text-align:center;background:#1e293bd9;border:1px solid #ffffff1a;border-radius:1rem;width:90%;max-width:400px;padding:2rem;animation:.3s cubic-bezier(.175,.885,.32,1.275) scaleUp;box-shadow:0 25px 50px -12px #00000080,0 0 20px #e11d4833}.modal-icon{margin-bottom:1rem;font-size:3rem;animation:.5s ease-in-out shake}.modal-title{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem}.modal-text{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem;line-height:1.5}.modal-actions{justify-content:center;gap:1rem;display:flex}.btn-cancel{color:var(--text-primary);cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:2rem;padding:.6rem 1.2rem;font-weight:600;transition:all .3s}.btn-cancel:hover{background:#fff3}.btn-danger{color:#fff;cursor:pointer;background:linear-gradient(135deg,#e11d48,#be123c);border:none;border-radius:2rem;padding:.6rem 1.2rem;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #e11d4866}.btn-danger:hover{background:linear-gradient(135deg,#be123c,#9f1239);transform:translateY(-2px);box-shadow:0 6px 20px #e11d4899}@keyframes scaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)rotate(-5deg)}75%{transform:translate(5px)rotate(5deg)}}.mobile-header,.mobile-overlay{display:none}@media (width<=768px){.app-layout{flex-direction:column}.sidebar{z-index:1000;width:280px;height:100vh;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.mobile-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-glass);z-index:100;background:#0f1115d9;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.mobile-menu-btn{color:var(--text-primary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.mobile-title{background:linear-gradient(135deg, var(--text-primary), #a1a1aa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-family:Montserrat,sans-serif;font-size:1.2rem;font-weight:700}.mobile-user-avatar{background:linear-gradient(135deg, var(--accent-blue), var(--accent-purple));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;font-weight:700;display:flex}.mobile-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:900;background:#00000080;animation:.2s ease-out fadeIn;display:block;position:fixed;inset:0}.main-content{padding:1rem 1rem 3rem}.form-row{flex-direction:column!important;gap:1rem!important}.um-header{flex-direction:column;gap:1rem;align-items:flex-start!important}.glass-panel{padding:1rem!important}.table-responsive{-webkit-overflow-scrolling:touch;overflow-x:auto}}.dashboard-container{padding:1.5rem}.dashboard-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.month-selector{border-radius:var(--radius-sm);border:1px solid var(--border-glass);background:#0000004d;align-items:center;gap:1rem;padding:.5rem;display:flex}.month-selector h3{text-align:center;min-width:150px;color:var(--accent-yellow);margin:0;font-size:1.1rem}.calendar-grid{background:var(--border-glass);border:1px solid var(--border-glass);border-radius:var(--radius-md);grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.calendar-header-day{text-align:center;color:var(--text-secondary);text-transform:uppercase;background:#00000080;padding:1rem .5rem;font-size:.9rem;font-weight:600}.calendar-cell{min-height:120px;transition:var(--transition-smooth);background:#191c24cc;flex-direction:column;padding:.5rem;display:flex}.calendar-cell:hover:not(.empty){background:#ffffff0d}.calendar-cell.empty{background:#0003}.day-number{color:var(--text-secondary);text-align:right;margin-bottom:.5rem;font-size:1.1rem;font-weight:700;display:block}.calendar-cell:hover .day-number{color:var(--text-primary)}.day-content{flex-direction:column;flex:1;gap:.35rem;display:flex;overflow-y:auto}.day-content::-webkit-scrollbar{width:4px}.mini-card{border-left:3px solid var(--accent-blue);white-space:nowrap;text-overflow:ellipsis;cursor:default;transition:var(--transition-smooth);background:#3b82f626;border-radius:4px;align-items:center;gap:.4rem;padding:.3rem .4rem;font-size:.75rem;display:flex;overflow:hidden}.mini-card:hover{background:#3b82f64d}.mini-platform{background:var(--accent-blue);color:#fff;text-transform:uppercase;border-radius:3px;flex-shrink:0;padding:.1rem .3rem;font-size:.65rem;font-weight:700}.mini-title{text-overflow:ellipsis;overflow:hidden}.mini-program{border-left:3px solid var(--accent-purple);white-space:nowrap;text-overflow:ellipsis;cursor:default;transition:var(--transition-smooth);color:var(--text-primary);background:#8b5cf633;border-radius:4px;align-items:center;gap:.4rem;padding:.3rem .4rem;font-size:.75rem;font-weight:600;display:flex;overflow:hidden}.mini-program:hover{background:#8b5cf666}.mini-program-icon{color:var(--accent-yellow);flex-shrink:0}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-box{text-align:center;width:100%;max-width:400px;padding:2.5rem 2rem}.login-header h1{background:linear-gradient(90deg,#60a5fa,#c084fc);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:1.8rem}.login-header p{color:var(--text-secondary);margin-bottom:2rem;font-size:.9rem}.login-form{text-align:left}.login-btn{justify-content:center;width:100%;margin-top:1rem;padding:.85rem}.error-message{color:#fca5a5;border-radius:var(--radius-sm);background:#ef44441a;border:1px solid #ef444433;margin-bottom:1.5rem;padding:.75rem;font-size:.85rem}.login-hint{border-top:1px solid var(--border-glass);color:var(--text-secondary);margin-top:2rem;padding-top:1.5rem;font-size:.85rem}.login-hint p{color:var(--text-primary);margin-bottom:.5rem;font-weight:600}.user-management{padding:2rem}.um-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.um-header p{color:var(--text-secondary);margin-top:.5rem;font-size:.9rem}.um-form{background:#0003;margin-bottom:2rem;padding:1.5rem}.user-info{align-items:center;gap:1rem;display:flex}.role-badge{color:var(--accent-green);background:#ffffff1a;border:1px solid #10b9814d;border-radius:99px;padding:.25rem .75rem;font-size:.75rem}.form-group input{border:1px solid var(--border-glass);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:var(--transition-smooth);background:#0000004d;padding:.8rem 1rem;font-family:inherit}.btn-logout{color:#fca5a5;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-smooth);background:#ef44441a;border:1px solid #ef444433;padding:.4rem 1rem;font-size:.85rem}.btn-logout:hover{background:#ef444433}.kanban-board{gap:1.5rem;padding-bottom:1rem;display:flex;overflow-x:auto}.kanban-column{flex-direction:column;flex:1;min-width:320px;min-height:70vh;padding:1.5rem;display:flex}.column-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.column-header h2{font-size:1.1rem;font-weight:600}.badge{background:#ffffff1a;border-radius:99px;padding:.25rem .75rem;font-size:.85rem}.column-content{flex-direction:column;gap:1rem;display:flex}.content-card{border:1px solid var(--border-glass);border-radius:var(--radius-md);transition:var(--transition-smooth);background:#1e212bcc;padding:1.25rem}.content-card:hover{border-color:#ffffff26;transform:translateY(-4px);box-shadow:0 8px 24px #0006}.card-header{justify-content:space-between;margin-bottom:.75rem;display:flex}.platform-badge{background:var(--accent-blue);color:#fff;border-radius:4px;padding:.1rem .5rem;font-size:.75rem;font-weight:600}.btn-delete{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:1.25rem}.btn-delete:hover{color:var(--accent-red)}.card-title{margin-bottom:.75rem;font-size:1rem;line-height:1.4}.card-body p{color:var(--text-secondary);margin-bottom:.25rem;font-size:.85rem}.card-actions{border-top:1px solid var(--border-glass);justify-content:space-between;margin-top:1rem;padding-top:.75rem;display:flex}.card-actions button{color:#fff;cursor:pointer;width:32px;height:32px;transition:var(--transition-smooth);background:#ffffff0d;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.card-actions button:hover:not(:disabled){background:#ffffff26}.card-actions button:disabled{opacity:.3;cursor:not-allowed}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{width:90%;max-width:600px;max-height:90vh;padding:2rem;overflow-y:auto}.modal-header{justify-content:space-between;margin-bottom:1.5rem;display:flex}.btn-close{color:#fff;cursor:pointer;background:0 0;border:none;font-size:1.5rem}.form-group{margin-bottom:1.25rem}.form-row{gap:1rem;display:flex}.form-row .form-group{flex:1}label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem;display:block}input,select,textarea{border:1px solid var(--border-glass);color:#fff;border-radius:var(--radius-sm);background:#0003;width:100%;padding:.75rem;font-family:inherit}input:focus,select:focus,textarea:focus{border-color:var(--accent-blue);outline:none}.modal-footer{justify-content:flex-end;gap:1rem;margin-top:2rem;display:flex}
