@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700&display=swap";:root{--bg-color:#000;--card-bg:#ffffff0d;--primary:#0f8;--primary-hover:#00cc6d;--text:#fff;--text-dim:#a0a0a0;--error:#ff4d4d;--border:#ffffff1a;--glass-border:#ffffff1a;--glass-shadow:0 8px 32px 0 #000c}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}.glass{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:12px}h1,h2,h3{letter-spacing:-.02em;font-weight:700}button{cursor:pointer;border:none;border-radius:8px;font-family:inherit;font-weight:600;transition:all .2s}.btn-primary{background-color:var(--primary);color:#000;padding:10px 20px}.btn-primary:hover{background-color:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #00ff884d}.btn-secondary{color:var(--text);border:1px solid var(--border);background-color:#0000;padding:10px 20px}.btn-secondary:hover{border-color:var(--primary);color:var(--primary)}.input-group{margin-bottom:20px}label{color:var(--text-dim);margin-bottom:8px;font-size:.9rem;display:block}input,textarea,select{border:1px solid var(--border);color:#fff;background:#ffffff0d;border-radius:8px;width:100%;padding:12px;font-family:inherit;font-size:1rem;transition:border-color .2s}input:focus,textarea:focus,select:focus{border-color:var(--primary);outline:none}.container{max-width:800px;margin:0 auto;padding:40px 20px}.navbar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 40px;display:flex}.card{margin-bottom:16px;padding:24px;transition:transform .2s}.card:hover{transform:scale(1.01)}.status-badge{text-transform:uppercase;border-radius:4px;padding:4px 8px;font-size:.75rem;font-weight:700}.status-pendiente{color:#fff;background:#ffffff1a}.status-completada{color:var(--primary);background:#0f83}.status-retrasado{color:var(--error);background:#ff4d4d33}.loading-screen{min-height:100vh;color:var(--text-dim);letter-spacing:.05em;background:#000;justify-content:center;align-items:center;font-size:1rem;display:flex}.sidebar{border-right:1px solid var(--border);background:#050505;flex-direction:column;flex-shrink:0;width:240px;height:100vh;padding:28px 16px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-logo{color:var(--text);align-items:center;gap:10px;margin-bottom:36px;padding:0 8px;font-size:1.25rem;font-weight:400;display:flex}.sidebar-logo strong{color:var(--primary);font-weight:700}.s-dot{background:var(--primary);width:9px;height:9px;box-shadow:0 0 10px var(--primary);border-radius:50%;flex-shrink:0;animation:2.5s infinite s-pulse}@keyframes s-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}.sidebar-nav{flex-direction:column;flex:1;gap:4px;display:flex}.sn-item{color:var(--text-dim);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-family:inherit;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sn-item:hover{color:var(--text);background:#ffffff0f}.sn-item.active{color:var(--primary);background:#00ff881a}.sidebar-footer{border-top:1px solid var(--border);align-items:center;gap:10px;padding-top:16px;display:flex}.sf-user{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.sf-avatar{width:34px;height:34px;color:var(--primary);background:#00ff8826;border:1px solid #00ff884d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.sf-info{flex-direction:column;min-width:0;display:flex}.sf-email{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:130px;font-size:.75rem;overflow:hidden}.sf-role{color:var(--text-dim);margin-top:1px;font-size:.7rem}.logout-btn{color:var(--text-dim);background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:6px;transition:all .15s}.logout-btn:hover{color:var(--error);background:#ff4d4d1a}.login-wrapper{background:#000;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-glow{pointer-events:none;background:radial-gradient(circle,#00ff881f 0%,#0000 70%);width:500px;height:500px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-card{z-index:1;width:100%;max-width:420px;padding:48px 40px;position:relative}.login-brand{align-items:center;gap:10px;margin-bottom:8px;display:flex}.login-brand h1{letter-spacing:-.04em;font-size:2rem}.brand-accent{color:#0f8}.login-dot{background:#0f8;border-radius:50%;width:10px;height:10px;animation:2s infinite pulse;display:inline-block;box-shadow:0 0 10px #0f8}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.4)}}.login-subtitle{color:var(--text-dim);margin-bottom:32px;font-size:.95rem}.error-msg{color:var(--error);background:#ff4d4d1a;border:1px solid #ff4d4d4d;border-radius:6px;margin-bottom:12px;padding:10px;font-size:.9rem}.admin-inner-container{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:40px;overflow-y:auto}.admin-tabs-nav{background:#ffffff08;border:1px solid #ffffff0f;border-radius:14px;gap:12px;margin-bottom:32px;padding:6px;display:inline-flex}.admin-tab-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;padding:10px 20px;font-size:.9rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.admin-tab-btn:hover{color:var(--text);background:#ffffff0d}.admin-tab-btn.active{color:var(--primary);background:#00ff881a;border-color:#0f83;box-shadow:0 4px 12px #0000001a}.admin-card{-webkit-backdrop-filter:blur(12px);background:#ffffff08;border:1px solid #ffffff0f;border-radius:16px;padding:24px;box-shadow:0 4px 24px #0003}.admin-card-header{border-bottom:1px solid #ffffff14;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;display:flex}.admin-card-header h2{margin:0;font-size:1.1rem}.admin-form{flex-direction:column;gap:20px;display:flex}.input-group label{color:var(--text-dim);margin-bottom:8px;font-size:.85rem;font-weight:500;display:block}.input-group input,.role-select-native{color:#fff;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:10px;width:100%;padding:12px 14px;font-size:.9rem;transition:all .2s}.input-group input:focus,.role-select-native:focus{border-color:var(--primary);background:#ffffff12;outline:none}.create-btn{background:var(--primary);color:#000;cursor:pointer;border:none;border-radius:12px;margin-top:10px;padding:14px;font-weight:700;transition:all .3s}.create-btn:hover{filter:brightness(1.1);transform:translateY(-2px)}.user-table-wrapper{border-radius:8px;overflow-x:auto}.user-table{border-collapse:collapse;width:100%;min-width:500px;font-size:.9rem}.user-table th{text-align:left;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #ffffff14;padding:16px 12px;font-size:.75rem;font-weight:500}.user-table td{vertical-align:middle;border-bottom:1px solid #ffffff08;padding:16px 12px}.user-table tr:last-child td{border-bottom:none}.user-row{transition:background .2s}.user-row:hover{background:#ffffff05}.user-cell-name{font-size:.95rem}.user-cell-email{color:var(--text-dim);font-size:.85rem}.role-tag{text-transform:uppercase;letter-spacing:.05em;border-radius:6px;padding:4px 10px;font-size:.7rem;font-weight:700;display:inline-block}.role-tag.admin{color:var(--primary);background:#00ff881a;border:1px solid #0f83}.role-tag.user{color:var(--text-dim);border:1px solid var(--border);background:#ffffff0d}.table-edit-input,.table-edit-select{border:1px solid var(--border);color:#fff;background:#0003;border-radius:6px;width:100%;padding:6px 10px;font-size:.85rem}.table-edit-input:focus{border-color:var(--primary);outline:none}.table-edit-select option{color:#fff;background:#111}.actions-cell{gap:8px;display:flex}.action-btn{cursor:pointer;background:#ffffff08;border:1px solid #ffffff1a;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.action-btn.edit{color:var(--text-dim)}.action-btn.edit:hover{color:var(--text);background:#ffffff0d;transform:translateY(-2px)}.action-btn.delete{color:var(--error);border-color:#ff4d4d33}.action-btn.delete:hover{background:#ff4d4d1a;transform:translateY(-2px)}.action-btn.save{color:var(--primary);border-color:#0f83}.action-btn.save:hover{background:#00ff881a;transform:translateY(-2px)}.action-btn.cancel{color:var(--text-dim)}.action-btn.cancel:hover{background:#ffffff0d;transform:translateY(-2px)}.admin-alert{border-radius:8px;margin-top:10px;padding:12px;font-size:.85rem}.admin-alert.success{color:var(--primary);background:#00ff881a;border:1px solid #0f83}.admin-alert.error{color:var(--error);background:#ff4d4d1a;border:1px solid #ff4d4d33}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-3px)}to{transform:translateY(0)}}@keyframes glow{0%{box-shadow:0 0 5px #0f83}50%{box-shadow:0 0 20px #0f86}to{box-shadow:0 0 5px #0f83}}@keyframes bounceIn{0%{opacity:0;transform:scale(.9)}50%{opacity:1;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:.6s ease-out fadeIn}.animate-slide-up{animation:.5s ease-out slideUp}.animate-bounce-in{animation:.3s ease-out bounceIn}.animated-float{animation:2s ease-in-out infinite float}.glow-on-hover:hover{animation:1.5s infinite alternate glow}@media (width<=768px){.admin-inner-container{padding:20px}.admin-tabs-nav{flex-direction:column;justify-content:space-between;width:100%}.admin-tab-btn{justify-content:center;width:100%}}.dash-root{background:#050505;min-height:100vh;display:flex}.dash-main{flex:1;max-width:860px;padding:40px 48px;overflow-y:auto}.dash-topbar{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.dash-greet{color:var(--text-dim);margin-bottom:4px;font-size:.9rem}.dash-title{letter-spacing:-.03em;text-transform:capitalize;font-size:2rem;font-weight:700}.dash-progress-wrap{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.progress-ring-label{color:var(--primary);font-size:1.5rem;font-weight:700;line-height:1}.progress-track{background:#ffffff14;border-radius:99px;width:120px;height:5px;overflow:hidden}.progress-fill{background:var(--primary);height:100%;box-shadow:0 0 8px var(--primary);border-radius:99px;transition:width .6s}.progress-hint{color:var(--text-dim);font-size:.75rem}.stats-grid{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:28px;display:grid}.stat-card{border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:4px;padding:20px 20px 16px;transition:transform .2s;display:flex}.stat-card:hover{transform:translateY(-2px)}.sc-num{font-size:2.2rem;font-weight:700;line-height:1}.sc-label{color:var(--text-dim);font-size:.8rem;font-weight:500}.sc-pending{background:#ffffff08}.sc-pending .sc-num{color:#fff}.sc-done{background:#00ff880d;border-color:#0f83}.sc-done .sc-num{color:var(--primary)}.sc-overdue{background:#ff4d4d0d;border-color:#ff4d4d33}.sc-overdue .sc-num{color:var(--error)}.quick-add-wrap{margin-bottom:24px}.quick-add-form{border-radius:12px;overflow:hidden}.qa-row{align-items:center;gap:12px;padding:14px 18px;display:flex}.qa-icon{color:var(--text-dim);flex-shrink:0}.qa-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:0;font-family:inherit;font-size:1rem}.qa-input::placeholder{color:#ffffff40}.qa-expand{color:var(--text-dim);background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;transition:all .2s;display:flex}.qa-expand:hover{color:var(--primary)}.qa-expand.open svg{transform:rotate(180deg)}.qa-expand svg{transition:transform .2s}.qa-extra{border-top:1px solid var(--border);flex-direction:column;gap:12px;padding:16px 18px;animation:.2s fadeDown;display:flex}@keyframes fadeDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.qa-textarea{border:1px solid var(--border);color:var(--text);resize:none;background:#ffffff0a;border-radius:8px;outline:none;padding:10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .2s}.qa-textarea:focus{border-color:var(--primary)}.qa-date-row{align-items:center;gap:10px;display:flex}.qa-cal-icon{color:var(--text-dim);flex-shrink:0}.qa-date{border:1px solid var(--border);color:var(--text);background:#ffffff0a;border-radius:8px;outline:none;width:auto;padding:8px 12px;font-family:inherit;font-size:.85rem;transition:border-color .2s}.qa-date:focus{border-color:var(--primary)}.qa-date-hint{color:var(--text-dim);font-size:.8rem}.qa-submit{align-self:flex-end;padding:9px 22px;font-size:.9rem}.filter-tabs{border-bottom:1px solid var(--border);gap:6px;margin-bottom:18px;padding-bottom:0;display:flex}.ftab{color:var(--text-dim);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 14px;font-family:inherit;font-size:.85rem;font-weight:500;transition:all .15s}.ftab:hover{color:var(--text)}.ftab.active{color:var(--primary);border-bottom-color:var(--primary)}.ftab.has-badge{color:var(--error)}.ftab.has-badge.active{border-bottom-color:var(--error)}.task-list{flex-direction:column;gap:8px;display:flex}.task-row{border-radius:12px;align-items:center;gap:14px;padding:16px 20px;transition:all .2s;display:flex}.task-row:hover{transform:translate(3px)}.task-row.is-done{opacity:.55}.task-row.is-overdue{border-color:#ff4d4d40}.check-btn{background:0 0;border:none;flex-shrink:0;padding:0;transition:transform .15s}.check-btn:hover{transform:scale(1.15)}.task-body{flex:1;min-width:0}.task-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.95rem;font-weight:500;overflow:hidden}.is-done .task-title{color:var(--text-dim);text-decoration:line-through}.task-sub{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:.82rem;overflow:hidden}.task-due{color:var(--text-dim);background:#ffffff0f;border-radius:99px;align-items:center;gap:5px;margin-top:4px;padding:3px 8px;font-size:.78rem;display:inline-flex}.due-late{color:var(--error);background:#ff4d4d1a}.due-soon{color:#f0b429;background:#f0b4291a}.task-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.pill{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;padding:4px 10px;font-size:.72rem;font-weight:700}.pill-pending{color:#ffffff80;background:#ffffff14}.pill-done{color:var(--primary);background:#00ff881f}.pill-overdue{color:var(--error);background:#ff4d4d1f}.del-btn{color:var(--text-dim);opacity:0;background:0 0;border:none;border-radius:6px;align-items:center;padding:6px;transition:all .15s;display:flex}.task-row:hover .del-btn{opacity:1}.del-btn:hover{color:var(--error);background:#ff4d4d1a}.empty-state{text-align:center;color:var(--text-dim);flex-direction:column;align-items:center;gap:14px;padding:60px 40px;font-size:.9rem;display:flex}.task-skeleton{flex-direction:column;gap:8px;display:flex}.skeleton-item{border-radius:12px;height:68px;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background:#ffffff0a}50%{background:#ffffff12}to{background:#ffffff0a}}@media (width<=720px){.sidebar{display:none}.dash-main{padding:24px 16px}.stats-grid{grid-template-columns:1fr 1fr}.dash-topbar{flex-direction:column;gap:16px}.dash-progress-wrap{align-items:flex-start}.progress-track{width:160px}}
