*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0F0F11;--s1:#18181C;--s2:#222228;--s3:#2A2A35;
  --border:#2A2A33;--border2:#3A3A45;
  --text:#F0EFE8;--muted:#888790;--dim:#555560;
  --accent:#7F77DD;--accent-dark:#534AB7;
  --green:#1D9E75;--green-bg:#04342C;--green-mid:#085041;
  --amber:#EF9F27;--amber-bg:#412402;--amber-mid:#633806;
  --red:#E24B4A;--red-bg:#501313;--red-mid:#791F1F;
  --blue:#378ADD;--blue-bg:#042C53;
  --gray:#888780;
  --font-mono:'DM Mono',ui-monospace,monospace;
  --font-sans:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif
}
body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:13px;height:100vh;overflow:hidden}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit}
input,textarea,select{font-family:inherit;color:var(--text)}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* LAYOUT */
#app{display:flex;height:100vh;overflow:hidden}
.sidebar{width:210px;background:var(--s1);border-right:0.5px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{padding:12px 20px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--s1);flex-shrink:0;gap:12px}
.content{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px 20px;display:flex;flex-direction:column;gap:14px}

/* SIDEBAR */
.sidebar-logo{padding:16px;font-size:11px;letter-spacing:2px;color:var(--muted);border-bottom:0.5px solid var(--border);flex-shrink:0;font-family:var(--font-mono)}
.sidebar-logo strong{display:block;font-size:16px;letter-spacing:-0.5px;color:var(--text);margin-bottom:2px;font-family:serif;font-style:italic;font-weight:400}
.nav-section{padding:10px 0 4px}
.nav-label{padding:0 14px 5px;font-size:9px;letter-spacing:2px;color:var(--dim);font-family:var(--font-mono)}
.nav-item{padding:7px 14px;cursor:pointer;display:flex;align-items:center;gap:9px;color:var(--muted);font-size:12px;transition:all 0.12s;border-left:2px solid transparent;white-space:nowrap;overflow:hidden}
.nav-item:hover{color:var(--text);background:var(--s2)}
.nav-item.active{color:var(--text);border-left-color:var(--accent);background:var(--s2)}
.nav-item .icon{font-size:14px;flex-shrink:0;opacity:0.7}
.nav-item.active .icon{opacity:1}
.nav-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.nav-item span.label{overflow:hidden;text-overflow:ellipsis;flex:1}
.nav-badge{margin-left:auto;font-size:9px;padding:2px 6px;border-radius:10px;font-family:var(--font-mono);flex-shrink:0}
.badge-red{background:var(--red-bg);color:var(--red)}
.badge-amber{background:var(--amber-bg);color:var(--amber)}
.badge-green{background:var(--green-bg);color:var(--green)}
.badge-blue{background:var(--blue-bg);color:var(--blue)}
.sidebar-footer{margin-top:auto;border-top:0.5px solid var(--border);padding:8px 0}

/* TOPBAR */
.topbar-title{font-size:13px;font-weight:500;letter-spacing:0.3px;font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}
.topbar-chips{display:flex;gap:6px;flex-wrap:wrap;flex-shrink:0}
.chip{font-size:10px;padding:3px 9px;border-radius:12px;font-family:var(--font-mono);white-space:nowrap}
.topbar-actions{display:flex;gap:6px;align-items:center;flex-shrink:0;margin-left:auto}
.btn-icon{background:none;border:0.5px solid var(--border);border-radius:6px;color:var(--muted);padding:5px 8px;font-size:13px;transition:all 0.12s}
.btn-icon:hover{color:var(--text);border-color:var(--border2)}
.btn-primary{background:var(--accent-dark);border:none;border-radius:6px;color:var(--text);padding:6px 12px;font-size:11px;letter-spacing:0.5px;font-family:var(--font-mono);transition:background 0.12s}
.btn-primary:hover{background:var(--accent)}

/* ALERT BANNER */
.alert-banner{background:var(--amber-mid);border:0.5px solid var(--amber)33;border-radius:8px;padding:9px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;font-size:11px;color:var(--amber);flex-shrink:0}
.alert-banner:hover{background:var(--amber-bg)}
.pulse{width:6px;height:6px;border-radius:50%;background:var(--amber);flex-shrink:0;animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(0.8)}}

/* PROJECT CARDS GRID */
.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:700px){.proj-grid{grid-template-columns:1fr}}
.proj-card{background:var(--s1);border:0.5px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:all 0.18s;position:relative;overflow:hidden}
.proj-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2.5px}
.proj-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.proj-card-name{font-size:12px;font-weight:500;margin-bottom:2px;letter-spacing:0.3px;font-family:var(--font-mono)}
.proj-card-type{font-size:10px;color:var(--muted);margin-bottom:12px}
.proj-card-nums{display:flex;gap:14px}
.num-block{text-align:left}
.num-val{font-size:20px;font-family:var(--font-mono);font-weight:400;line-height:1}
.num-lbl{font-size:9px;color:var(--muted);margin-top:2px;letter-spacing:0.5px}
.prog-bar{height:2px;background:var(--border);border-radius:1px;margin-top:14px;overflow:hidden}
.prog-fill{height:100%;border-radius:1px;transition:width 0.5s}

/* KANBAN */
.kanban-header{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-bottom:4px}
.back-btn{background:none;border:none;color:var(--muted);font-size:11px;display:flex;align-items:center;gap:4px;padding:0;transition:color 0.12s;font-family:var(--font-mono)}
.back-btn:hover{color:var(--text)}
.proj-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.proj-heading{font-size:15px;letter-spacing:0.2px;font-family:var(--font-mono)}
.proj-sub{font-size:10px;color:var(--muted);font-family:var(--font-mono)}
.kanban-board{display:flex;gap:10px;flex:1;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}
.k-col{flex:0 0 230px;background:var(--s1);border:0.5px solid var(--border);border-radius:8px;display:flex;flex-direction:column;overflow:hidden}
.k-col.drag-over{border-color:var(--accent);background:var(--s2)}
.k-head{padding:9px 12px;font-size:9px;letter-spacing:2px;color:var(--muted);border-bottom:0.5px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);background:var(--s2);flex-shrink:0}
.k-count{background:var(--s3);border:0.5px solid var(--border);border-radius:10px;padding:1px 7px;font-size:10px;color:var(--text)}
.k-body{padding:8px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;min-height:80px}

/* TASK CARDS */
.task-card{background:var(--s2);border:0.5px solid var(--border);border-left:3px solid transparent;border-radius:6px;padding:10px 11px;cursor:grab;transition:all 0.12s;user-select:none}
.task-card:hover{border-color:var(--border2)}
.task-card.dragging{opacity:0.35;cursor:grabbing}
.task-card.drop-target{border-color:var(--accent)!important;box-shadow:0 0 0 1px var(--accent)44}
.task-card[data-alert="overdue"]{border-left-color:var(--gray)!important}
.task-card[data-alert="critical"]{border-left-color:var(--red)}
.task-card[data-alert="urgent"]{border-left-color:var(--amber)}
.task-card[data-alert="soon"]{border-left-color:#E6B830}
.task-card[data-alert="ok"]{border-left-color:var(--green)}
.task-card[data-alert="none"]{border-left-color:var(--border)}
.task-title{font-size:12px;font-weight:500;margin-bottom:7px;line-height:1.4;color:var(--text)}
.task-meta{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.tag{font-size:9px;padding:2px 6px;border-radius:3px;font-family:var(--font-mono);letter-spacing:0.3px}
.tag-alta{background:var(--red-bg);color:var(--red)}
.tag-media{background:var(--amber-bg);color:var(--amber)}
.tag-baja{background:var(--green-bg);color:var(--green)}
.task-date{font-size:9px;display:flex;align-items:center;gap:3px;font-family:var(--font-mono);margin-left:auto}
.date-overdue{color:var(--gray)}
.date-critical{color:var(--red)}
.date-urgent{color:var(--amber)}
.date-soon{color:#E6B830}
.date-ok{color:var(--green)}
.date-none{color:var(--dim)}
.subtask-bar{margin-top:7px;display:flex;align-items:center;gap:5px}
.subtask-prog{flex:1;height:2px;background:var(--border);border-radius:1px;overflow:hidden}
.subtask-fill{height:100%;background:var(--green);border-radius:1px;transition:width 0.3s}
.subtask-label{font-size:9px;color:var(--muted);font-family:var(--font-mono);white-space:nowrap}
.add-task-btn{font-size:10px;color:var(--dim);padding:7px 8px;border:0.5px dashed var(--border);border-radius:5px;cursor:pointer;text-align:center;transition:all 0.12s;background:none;width:100%;font-family:var(--font-mono)}
.add-task-btn:hover{color:var(--accent);border-color:var(--accent)55}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}
.modal{background:var(--s1);border:0.5px solid var(--border2);border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;padding:24px}
.modal-title{font-size:14px;font-family:var(--font-mono);margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}
.modal-close{background:none;border:none;color:var(--muted);font-size:18px;padding:0;line-height:1}
.modal-close:hover{color:var(--text)}
.field{margin-bottom:16px}
.field label{display:block;font-size:10px;letter-spacing:1.5px;color:var(--muted);margin-bottom:6px;font-family:var(--font-mono)}
.field input,.field textarea,.field select{width:100%;background:var(--bg);border:0.5px solid var(--border);border-radius:6px;padding:9px 11px;color:var(--text);font-size:12px;outline:none;transition:border-color 0.12s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent)}
.field textarea{resize:vertical;min-height:80px;font-family:var(--font-sans)}
.field select option{background:var(--s1)}
.field-row{display:flex;gap:12px}
.field-row .field{flex:1}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}
.btn-cancel{background:none;border:0.5px solid var(--border);border-radius:6px;color:var(--muted);padding:8px 16px;font-size:11px;font-family:var(--font-mono);transition:all 0.12s}
.btn-cancel:hover{color:var(--text);border-color:var(--border2)}
.btn-save{background:var(--accent-dark);border:none;border-radius:6px;color:var(--text);padding:8px 16px;font-size:11px;font-family:var(--font-mono);transition:background 0.12s}
.btn-save:hover{background:var(--accent)}
.btn-danger{background:var(--red-mid);border:none;border-radius:6px;color:var(--red);padding:8px 16px;font-size:11px;font-family:var(--font-mono);transition:background 0.12s}
.btn-danger:hover{background:var(--red-bg)}

/* SUBTASKS IN MODAL */
.subtask-list{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}
.subtask-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg);border-radius:5px;border:0.5px solid var(--border)}
.subtask-item input[type="checkbox"]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}
.subtask-item .stitle{flex:1;font-size:11px}
.subtask-item .stitle.done{text-decoration:line-through;color:var(--dim)}
.subtask-item button{background:none;border:none;color:var(--dim);font-size:12px;padding:0;line-height:1}
.subtask-item button:hover{color:var(--red)}
.subtask-add{display:flex;gap:6px}
.subtask-add input{flex:1;background:var(--bg);border:0.5px solid var(--border);border-radius:5px;padding:7px 10px;color:var(--text);font-size:11px;outline:none}
.subtask-add input:focus{border-color:var(--accent)}
.subtask-add button{background:var(--s3);border:0.5px solid var(--border);border-radius:5px;color:var(--muted);padding:7px 10px;font-size:11px;font-family:var(--font-mono);transition:all 0.12s}
.subtask-add button:hover{color:var(--text);border-color:var(--border2)}

/* LOADING */
.loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--muted);font-family:var(--font-mono);font-size:11px;letter-spacing:2px}

/* RESPONSIVE */
@media(max-width:600px){
  .sidebar{width:48px}
  .sidebar-logo strong,.sidebar-logo span,.nav-label,.nav-item span.label,.nav-badge,.proj-sub{display:none}
  .nav-item{padding:10px;justify-content:center}
  .nav-dot{display:block}
  .content{padding:12px}
  .kanban-board{gap:8px}
  .k-col{flex:0 0 200px}
}
