/*
  Tactik Task Board - https://tasks.tactik.com.au
  Tactik CRM v2.9 branding - dark mode, orange accent
*/
:root{
  --bg:#09090b;--s1:#0f0f12;--s2:#16161a;--s3:#1e1e24;
  --b1:#27272a;--b2:#33333a;--b3:#3f3f46;
  --ac:#F44302;--ac2:#ff6b3d;
  --tx:#f0f0f0;--t2:#a1a1aa;--t3:#52525b;
  --ok:#22c55e;--warn:#eab308;--err:#ef4444;
  --sam:#3b82f6;--udara:#F44302;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:Inter,-apple-system,sans-serif;background:var(--bg);color:var(--tx);min-height:100vh}
body.light{--bg:#ece6e8;--s1:#fff;--s2:#f4f0f1;--s3:#e8e2e4;--b1:#d8d2d4;--b2:#ccc5c8;--b3:#b8b0b4;--tx:#1a1a1a;--t2:#6b6b6b;--t3:#9a9a9a}

/* Login */
#login-overlay{position:fixed;inset:0;z-index:999;background:var(--bg);display:flex;align-items:center;justify-content:center}
#login-overlay.hidden{display:none}
.login-card{background:var(--s1);border:1px solid var(--b2);border-radius:16px;padding:40px;width:340px;text-align:center}
.login-card h2{font-size:20px;margin-bottom:8px}
.login-card p{color:var(--t2);font-size:13px;margin-bottom:24px}
.login-card input{width:100%;padding:12px 16px;background:var(--s2);border:1px solid var(--b2);border-radius:8px;color:var(--tx);font-size:14px;margin-bottom:12px;outline:none}
.login-card input:focus{border-color:var(--ac)}
.login-card button{width:100%;padding:12px;background:var(--ac);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}
.login-card button:hover{background:var(--ac2)}
.login-error{color:var(--err);font-size:12px;margin-top:8px;display:none}

/* Layout */
.app{display:flex;min-height:100vh}
.sidebar{width:240px;background:var(--s1);border-right:1px solid var(--b2);padding:16px 0;flex-shrink:0;display:flex;flex-direction:column}
.sidebar-logo{padding:16px 20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--b1);margin-bottom:8px;cursor:pointer}
.sidebar-logo .t-icon{width:28px;height:28px}
.sidebar-logo span{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:1px}
.nav-item{padding:10px 20px;font-size:13px;color:var(--t2);cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .15s}
.nav-item:hover,.nav-item.active{color:var(--tx);background:var(--s2)}
.nav-item.active{border-right:3px solid var(--ac);color:var(--ac)}
.nav-item .badge{margin-left:auto;background:var(--ac);color:#fff;font-size:11px;padding:1px 7px;border-radius:10px;font-weight:600}
.nav-item .badge.blue{background:var(--sam)}
.sidebar-spacer{flex:1}
.sidebar-user{padding:12px 20px;border-top:1px solid var(--b1);font-size:12px;color:var(--t3)}

/* Main */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{padding:16px 24px;border-bottom:1px solid var(--b2);display:flex;align-items:center;justify-content:space-between}
.topbar h1{font-size:18px;font-weight:600}
.topbar-actions{display:flex;gap:10px;align-items:center}
.btn{padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--b2);background:var(--s2);color:var(--tx);transition:all .15s}
.btn:hover{border-color:var(--b3)}
.btn.primary{background:var(--ac);border-color:var(--ac);color:#fff}
.btn.primary:hover{background:var(--ac2)}
.btn.sm{padding:5px 10px;font-size:12px}

/* Stats bar */
.stats-bar{display:flex;gap:12px;padding:16px 24px;overflow-x:auto}
.stat-card{background:var(--s1);border:1px solid var(--b1);border-radius:10px;padding:14px 18px;min-width:130px;flex-shrink:0}
.stat-card .label{font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px}
.stat-card .value{font-size:24px;font-weight:700;margin-top:4px}
.stat-card .value.ac{color:var(--ac)}
.stat-card .value.sam{color:var(--sam)}
.stat-card .value.ok{color:var(--ok)}
.stat-card .value.warn{color:var(--warn)}
.stat-card .value.err{color:var(--err)}

/* Board */
.board{display:flex;gap:16px;padding:16px 24px;flex:1;overflow-x:auto;align-items:flex-start}
.column{background:var(--s1);border:1px solid var(--b1);border-radius:12px;min-width:280px;max-width:320px;flex-shrink:0;display:flex;flex-direction:column;max-height:calc(100vh - 200px)}
.col-header{padding:14px 16px;font-size:13px;font-weight:600;border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between}
.col-header .count{font-size:11px;background:var(--s2);color:var(--t2);padding:2px 8px;border-radius:10px}
.col-body{padding:8px;overflow-y:auto;flex:1}

/* Task card */
.task-card{background:var(--s2);border:1px solid var(--b1);border-radius:8px;padding:12px;margin-bottom:8px;cursor:pointer;transition:all .15s}
.task-card:hover{border-color:var(--b3);transform:translateY(-1px)}
.task-card .title{font-size:13px;font-weight:500;margin-bottom:6px;line-height:1.4}
.task-card .meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tag{font-size:10px;padding:2px 8px;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.tag.cat-team{background:#1e3a5f;color:#60a5fa}
.tag.cat-projects{background:#1a332a;color:#4ade80}
.tag.cat-pm-system{background:#3b1f4e;color:#c084fc}
.tag.cat-process{background:#3b2f1a;color:#fbbf24}
.tag.cat-finance{background:#3b1a1a;color:#f87171}
.tag.cat-integrations{background:#1a2f3b;color:#38bdf8}
.tag.cat-general{background:var(--s3);color:var(--t2)}
.tag.pri-critical{background:#7f1d1d;color:#fca5a5}
.tag.pri-high{background:#713f12;color:#fde68a}
.tag.pri-medium{background:#1e3a5f;color:#93c5fd}
.tag.pri-low{background:var(--s3);color:var(--t3)}
.owner-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.owner-dot.sam{background:var(--sam)}
.owner-dot.udara{background:var(--udara)}
.owner-label{font-size:11px;color:var(--t2)}
.due{font-size:11px;color:var(--t3);margin-left:auto}
.due.overdue{color:var(--err)}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:100;display:flex;align-items:center;justify-content:center}
.modal-overlay.hidden{display:none}
.modal{background:var(--s1);border:1px solid var(--b2);border-radius:14px;width:480px;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column}
.modal-header{padding:18px 20px;border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between}
.modal-header h3{font-size:16px;font-weight:600}
.modal-body{padding:20px;flex:1}
.modal-body label{display:block;font-size:12px;color:var(--t2);margin-bottom:6px;margin-top:14px;text-transform:uppercase;letter-spacing:.5px}
.modal-body label:first-child{margin-top:0}
.modal-body input,.modal-body textarea,.modal-body select{width:100%;padding:10px 12px;background:var(--s2);border:1px solid var(--b2);border-radius:8px;color:var(--tx);font-size:13px;outline:none}
.modal-body input:focus,.modal-body textarea:focus,.modal-body select:focus{border-color:var(--ac)}
.modal-body textarea{min-height:80px;resize:vertical;font-family:inherit}
.modal-body select{cursor:pointer}
.modal-footer{padding:14px 20px;border-top:1px solid var(--b1);display:flex;gap:10px;justify-content:flex-end}
.close-btn{background:none;border:none;color:var(--t3);font-size:20px;cursor:pointer;padding:4px}

/* Memory cards */
.mem-card{background:var(--s1);border:1px solid var(--b1);border-radius:10px;padding:16px;margin-bottom:10px;cursor:pointer;transition:all .15s}
.mem-card:hover{border-color:var(--b3);transform:translateY(-1px)}
.mem-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.mem-icon{font-size:20px}
.mem-title{font-weight:600;font-size:14px;flex:1}
.mem-meta{display:flex;gap:12px;font-size:12px;color:var(--t3)}

/* Responsive */
@media(max-width:900px){
  .sidebar{display:none}
  .board{padding:12px}
  .column{min-width:260px}
}
@media(max-width:600px){
  .stats-bar{padding:12px}
  .stat-card{min-width:100px;padding:10px 12px}
  .stat-card .value{font-size:18px}
  .topbar{padding:12px 16px}
  .column{min-width:85vw}
}