* { margin: 0; padding: 0; box-sizing: border-box; }
:root {
  --bg: #0c0d12; --surface: #14161e; --surface2: #1a1d28; --border: #252836; --border-hover: #3a3f55;
  --text: #e4e4e7; --text-dim: #71717a; --text-muted: #52525b;
  --accent: #8b5cf6; --accent-hover: #a78bfa;
  --backlog: #71717a; --in-progress: #3b82f6; --review: #f59e0b; --done: #22c55e;
  --idea: #fbbf24; --research: #60a5fa; --script: #34d399; --assets: #f472b6;
  --production: #fb923c; --editing: #c084fc; --c-review: #38bdf8; --published: #22c55e;
  --urgent: #ef4444; --high: #f97316; --migi: #a78bfa; --adrian: #38bdf8;
  --sidebar-w: 200px; --radius: 10px;
}
body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif; background: var(--bg); color: var(--text); min-height: 100vh; }

/* LOGIN */
.login-screen { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center; background: var(--bg); z-index: 200; }
.login-screen[hidden] { display: none; }
.login-box { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 40px; width: 360px; text-align: center; }
.login-box h1 { font-size: 3rem; margin-bottom: 8px; }
.login-box h2 { font-size: 1.2rem; margin-bottom: 24px; color: var(--text-dim); font-weight: 500; }
.login-box input { width: 100%; padding: 12px 16px; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 1rem; outline: none; margin-bottom: 16px; font-family: inherit; }
.login-box input:focus { border-color: var(--accent); }
.login-box button { width: 100%; padding: 12px; background: var(--accent); border: none; color: #fff; border-radius: 8px; font-size: 1rem; font-weight: 600; cursor: pointer; }
.login-box button:hover { background: var(--accent-hover); }
.login-error { color: var(--urgent); font-size: 0.85rem; margin-top: 8px; }
.login-error[hidden] { display: none; }

/* SIDEBAR */
#app { display: flex; min-height: 100vh; }
#app[hidden] { display: none; }
.sidebar { width: var(--sidebar-w); background: var(--surface); border-right: 1px solid var(--border); display: flex; flex-direction: column; position: fixed; top: 0; bottom: 0; z-index: 20; }
.sidebar-brand { padding: 20px 16px; display: flex; align-items: center; gap: 10px; border-bottom: 1px solid var(--border); }
.brand-icon { font-size: 1.5rem; }
.brand-text { font-weight: 700; font-size: 1rem; }
.sidebar-nav { flex: 1; padding: 12px 8px; display: flex; flex-direction: column; gap: 4px; }
.sidebar-footer { padding: 12px 8px; border-top: 1px solid var(--border); }
.nav-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: none; border: none; color: var(--text-dim); border-radius: 8px; cursor: pointer; font-size: 0.88rem; width: 100%; text-align: left; transition: all 0.15s; font-family: inherit; }
.nav-item:hover { background: var(--surface2); color: var(--text); }
.nav-item.active { background: rgba(139,92,246,0.15); color: var(--accent-hover); }
.nav-icon { font-size: 1.1rem; width: 24px; text-align: center; }

/* MAIN */
.main-area { margin-left: var(--sidebar-w); flex: 1; display: flex; flex-direction: column; }
.view { display: none; flex-direction: column; flex: 1; }
.view.active { display: flex; }
header { display: flex; justify-content: space-between; align-items: center; padding: 16px 24px; border-bottom: 1px solid var(--border); flex-wrap: wrap; gap: 12px; position: sticky; top: 0; background: var(--bg); z-index: 10; }
.header-left { display: flex; align-items: baseline; gap: 10px; }
header h1 { font-size: 1.2rem; font-weight: 700; }
.header-right { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.filters { display: flex; gap: 3px; flex-wrap: wrap; }
.filter-btn { padding: 5px 10px; border: 1px solid var(--border); background: transparent; color: var(--text-dim); border-radius: 6px; cursor: pointer; font-size: 0.75rem; transition: all 0.15s; }
.filter-btn:hover { border-color: var(--accent); color: var(--text); }
.filter-btn.active { background: var(--accent); border-color: var(--accent); color: #fff; }
.add-btn { padding: 8px 16px; background: var(--accent); border: none; color: #fff; border-radius: 8px; cursor: pointer; font-size: 0.82rem; font-weight: 600; }
.add-btn:hover { background: var(--accent-hover); }

/* BOARD */
.board { display: flex; gap: 12px; padding: 20px; overflow-x: auto; flex: 1; }
.column { min-width: 220px; width: 220px; flex-shrink: 0; background: var(--surface); border-radius: var(--radius); border: 1px solid var(--border); display: flex; flex-direction: column; }
.column-header { display: flex; align-items: center; gap: 6px; padding: 14px 12px 10px; border-bottom: 1px solid var(--border); }
.column-header h2 { font-size: 0.78rem; font-weight: 600; flex: 1; white-space: nowrap; }
.dot { width: 7px; height: 7px; border-radius: 50%; }
.dot.backlog { background: var(--backlog); } .dot.in-progress { background: var(--in-progress); } .dot.review { background: var(--review); } .dot.done { background: var(--done); }
.dot.idea { background: var(--idea); } .dot.research { background: var(--research); } .dot.script { background: var(--script); } .dot.assets { background: var(--assets); }
.dot.production { background: var(--production); } .dot.editing { background: var(--editing); } .dot.c-review { background: var(--c-review); } .dot.published { background: var(--published); }
.count { font-size: 0.7rem; color: var(--text-dim); background: var(--bg); padding: 2px 7px; border-radius: 10px; }
.card-list { flex: 1; padding: 10px; display: flex; flex-direction: column; gap: 8px; overflow-y: auto; min-height: 60px; }

/* CARDS */
.card { background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 12px; cursor: pointer; transition: border-color 0.15s, transform 0.1s; }
.card:hover { border-color: var(--accent); transform: translateY(-1px); }
.card-type { font-size: 0.65rem; margin-bottom: 4px; }
.card-title { font-size: 0.82rem; font-weight: 600; margin-bottom: 6px; line-height: 1.3; }
.card-desc, .card-excerpt { font-size: 0.72rem; color: var(--text-dim); margin-bottom: 8px; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-footer, .card-meta { display: flex; justify-content: space-between; align-items: center; }
.card-assignee { font-size: 0.68rem; padding: 2px 6px; border-radius: 4px; font-weight: 600; }
.card-assignee.migi { background: rgba(167,139,250,0.15); color: var(--migi); }
.card-assignee.adrian { background: rgba(56,189,248,0.15); color: var(--adrian); }
.card-priority { font-size: 0.62rem; text-transform: uppercase; font-weight: 600; letter-spacing: 0.4px; }
.card-priority.urgent { color: var(--urgent); } .card-priority.high { color: var(--high); }
.card-att-count { font-size: 0.65rem; color: var(--text-muted); }
.card-tags { display: flex; flex-wrap: wrap; gap: 3px; margin-top: 6px; }
.tag { font-size: 0.6rem; padding: 1px 5px; border-radius: 3px; background: rgba(139,92,246,0.1); color: var(--accent-hover); }
.card.dragging { opacity: 0.4; }
.card-list.drag-over { background: rgba(139,92,246,0.06); border-radius: 6px; }
.empty-col { display: flex; align-items: center; justify-content: center; flex: 1; color: var(--text-muted); font-size: 0.75rem; font-style: italic; }

/* TASK MODAL */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.6); display: flex; align-items: center; justify-content: center; z-index: 100; backdrop-filter: blur(4px); }
.modal-overlay[hidden] { display: none; }
.modal { background: var(--surface); border: 1px solid var(--border); border-radius: 14px; padding: 28px; width: 480px; max-width: 95vw; }
.modal h3 { margin-bottom: 20px; font-size: 1.1rem; }
.modal label, .panel-body > label, .panel-meta-row label { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; font-size: 0.78rem; color: var(--text-dim); }
.modal input, .modal textarea, .modal select, .panel-meta-row select, .panel-meta-row input, .panel-body > label input {
  padding: 9px 12px; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 0.85rem; font-family: inherit; outline: none; transition: border-color 0.15s;
}
.modal input:focus, .modal textarea:focus, .modal select:focus, .panel-meta-row select:focus, .panel-meta-row input:focus { border-color: var(--accent); }
.form-row { display: flex; gap: 12px; }
.form-row label { flex: 1; }
.form-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 20px; }
.btn-save { padding: 9px 20px; background: var(--accent); border: none; color: #fff; border-radius: 8px; cursor: pointer; font-weight: 600; font-size: 0.85rem; }
.btn-save:hover { background: var(--accent-hover); }
.btn-cancel { padding: 9px 20px; background: transparent; border: 1px solid var(--border); color: var(--text-dim); border-radius: 8px; cursor: pointer; font-size: 0.85rem; }
.btn-cancel:hover { border-color: var(--text-dim); color: var(--text); }
.btn-delete, .btn-delete-panel { padding: 9px 20px; background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.3); color: var(--urgent); border-radius: 8px; cursor: pointer; font-size: 0.85rem; margin-right: auto; }

/* CONTENT PANEL */
.panel-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.55); z-index: 100; display: flex; justify-content: flex-end; backdrop-filter: blur(3px); }
.panel-overlay[hidden] { display: none; }
.panel { width: 680px; max-width: 100vw; background: var(--surface); border-left: 1px solid var(--border); display: flex; flex-direction: column; overflow-y: auto; animation: slideIn 0.2s ease; }
@keyframes slideIn { from { transform: translateX(100%); } to { transform: translateX(0); } }
.panel-header { display: flex; justify-content: space-between; align-items: center; padding: 14px 20px; border-bottom: 1px solid var(--border); }
.panel-close { background: none; border: none; color: var(--text-dim); font-size: 1.2rem; cursor: pointer; padding: 4px 8px; border-radius: 6px; }
.panel-close:hover { background: var(--surface2); color: var(--text); }
.panel-body { padding: 20px; display: flex; flex-direction: column; gap: 14px; flex: 1; }
.panel-title-input { width: 100%; background: transparent; border: none; color: var(--text); font-size: 1.3rem; font-weight: 700; font-family: inherit; outline: none; padding: 4px 0; border-bottom: 2px solid transparent; }
.panel-title-input:focus { border-bottom-color: var(--accent); }
.panel-meta-row { display: flex; gap: 10px; flex-wrap: wrap; }

/* CONTENT TABS */
.panel-tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--border); }
.tab { padding: 7px 12px; background: none; border: none; border-bottom: 2px solid transparent; color: var(--text-dim); cursor: pointer; font-size: 0.78rem; transition: all 0.15s; font-family: inherit; }
.tab:hover { color: var(--text); }
.tab.active { color: var(--accent-hover); border-bottom-color: var(--accent); }
.ctab-content { display: none; }
.ctab-content.active { display: block; }
.ctab-content textarea { width: 100%; min-height: 280px; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 0.85rem; font-family: 'SF Mono','Fira Code','Consolas',monospace; line-height: 1.6; padding: 14px; outline: none; resize: vertical; }
.ctab-content textarea:focus { border-color: var(--accent); }

/* UPLOAD */
.upload-zone { border: 2px dashed var(--border); border-radius: 8px; padding: 20px; text-align: center; color: var(--text-dim); font-size: 0.82rem; cursor: pointer; transition: border-color 0.15s; }
.upload-zone:hover, .upload-zone.dragover { border-color: var(--accent); }
.upload-label { color: var(--accent); cursor: pointer; text-decoration: underline; }
.attachments-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 8px; margin-top: 10px; }
.att-card { background: var(--bg); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; position: relative; }
.att-card img { width: 100%; height: 90px; object-fit: cover; display: block; }
.att-card .att-file { height: 90px; display: flex; align-items: center; justify-content: center; font-size: 2rem; background: var(--surface2); }
.att-card .att-name { padding: 5px 7px; font-size: 0.65rem; color: var(--text-dim); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.att-card .att-remove { position: absolute; top: 3px; right: 3px; background: rgba(0,0,0,0.7); border: none; color: #fff; width: 20px; height: 20px; border-radius: 50%; cursor: pointer; font-size: 0.65rem; display: none; }
.att-card:hover .att-remove { display: block; }

.panel-save-row { display: flex; justify-content: space-between; align-items: center; padding-top: 10px; border-top: 1px solid var(--border); }
.save-status { font-size: 0.72rem; color: var(--text-muted); }

/* CALENDAR */
.cal-nav-btn { background: none; border: 1px solid var(--border); color: var(--text); width: 32px; height: 32px; border-radius: 6px; cursor: pointer; font-size: 1.2rem; display: flex; align-items: center; justify-content: center; }
.cal-nav-btn:hover { border-color: var(--accent); }
.cal-today-btn { padding: 5px 12px; background: var(--surface2); border: 1px solid var(--border); color: var(--text-dim); border-radius: 6px; cursor: pointer; font-size: 0.75rem; margin-left: 8px; }
.cal-today-btn:hover { color: var(--text); border-color: var(--accent); }
.cal-layout { display: flex; flex: 1; overflow: hidden; }
.cal-grid-wrap { flex: 1; padding: 20px; overflow-y: auto; }
.cal-weekdays { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; margin-bottom: 4px; }
.cal-weekdays div { text-align: center; font-size: 0.72rem; color: var(--text-dim); font-weight: 600; padding: 8px 0; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.cal-day { background: var(--surface); border: 1px solid var(--border); border-radius: 6px; min-height: 100px; padding: 6px; cursor: pointer; transition: border-color 0.15s; }
.cal-day:hover { border-color: var(--border-hover); }
.cal-day.other-month { opacity: 0.35; }
.cal-day.today { border-color: var(--accent); background: rgba(139,92,246,0.06); }
.cal-day-num { font-size: 0.75rem; font-weight: 600; margin-bottom: 4px; color: var(--text-dim); }
.cal-day.today .cal-day-num { color: var(--accent-hover); }
.cal-day-events { display: flex; flex-direction: column; gap: 2px; }
.cal-event { font-size: 0.62rem; padding: 2px 5px; border-radius: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; cursor: pointer; transition: opacity 0.15s; }
.cal-event:hover { opacity: 0.8; }
.cal-event.type-event { background: rgba(99,102,241,0.2); color: var(--accent-hover); }
.cal-event.type-cron { background: rgba(251,146,60,0.2); color: var(--production); }
.cal-event.type-reminder { background: rgba(250,204,21,0.2); color: var(--idea); }
.cal-event.type-deadline { background: rgba(239,68,68,0.2); color: var(--urgent); }
.cal-event.type-system { background: rgba(34,197,94,0.15); color: var(--done); }
.cal-event.completed { text-decoration: line-through; opacity: 0.5; }

/* Calendar Sidebar */
.cal-sidebar { width: 300px; border-left: 1px solid var(--border); padding: 20px; overflow-y: auto; background: var(--surface); }
.cal-sidebar h3 { font-size: 0.9rem; margin-bottom: 16px; color: var(--text); }
.cron-list { display: flex; flex-direction: column; gap: 10px; }
.cron-card { background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 12px; }
.cron-card .cron-name { font-size: 0.8rem; font-weight: 600; margin-bottom: 4px; }
.cron-card .cron-schedule { font-size: 0.7rem; color: var(--text-dim); font-family: 'SF Mono','Fira Code',monospace; margin-bottom: 4px; }
.cron-card .cron-meta { display: flex; justify-content: space-between; font-size: 0.65rem; }
.cron-card .cron-status { padding: 1px 6px; border-radius: 3px; font-weight: 600; }
.cron-card .cron-status.running { background: rgba(34,197,94,0.15); color: var(--done); }
.cron-card .cron-status.error { background: rgba(239,68,68,0.15); color: var(--urgent); }
.cron-card .cron-status.paused { background: rgba(113,113,122,0.15); color: var(--text-dim); }
.cron-card .cron-next { color: var(--text-dim); }
.cron-sys { font-size: 0.68rem; color: var(--text-dim); font-family: 'SF Mono','Fira Code',monospace; padding: 8px 10px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px; word-break: break-all; }

/* TEAM */
.team-container { padding: 24px; overflow-y: auto; flex: 1; }
.team-org { display: flex; flex-direction: column; gap: 32px; max-width: 1200px; margin: 0 auto; }
.dept-section { }
.dept-header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; padding-bottom: 10px; border-bottom: 2px solid var(--border); }
.dept-icon { font-size: 1.3rem; }
.dept-name { font-size: 1.05rem; font-weight: 700; }
.dept-count { font-size: 0.72rem; color: var(--text-dim); background: var(--surface); padding: 2px 8px; border-radius: 10px; }
.dept-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; }

.member-card {
  background: var(--surface); border: 1px solid var(--border); border-radius: 12px;
  padding: 20px; cursor: pointer; transition: all 0.2s; position: relative; overflow: hidden;
}
.member-card:hover { border-color: var(--accent); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.2); }
.member-card.is-lead { border-left: 3px solid var(--accent); }
.member-card.is-human { border-left: 3px solid var(--adrian); }
.member-top { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
.member-avatar { font-size: 2.2rem; width: 52px; height: 52px; display: flex; align-items: center; justify-content: center; background: var(--bg); border-radius: 12px; flex-shrink: 0; }
.member-info { flex: 1; min-width: 0; }
.member-name { font-size: 0.95rem; font-weight: 700; margin-bottom: 2px; }
.member-role { font-size: 0.72rem; color: var(--text-dim); }
.member-status { position: absolute; top: 14px; right: 14px; font-size: 0.6rem; padding: 3px 8px; border-radius: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }
.member-status.active { background: rgba(34,197,94,0.15); color: var(--done); }
.member-status.standby { background: rgba(113,113,122,0.1); color: var(--text-dim); }
.member-status.busy { background: rgba(251,146,60,0.15); color: var(--production); }
.member-desc { font-size: 0.75rem; color: var(--text-dim); line-height: 1.5; margin-bottom: 12px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.member-skills { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 10px; }
.member-skill { font-size: 0.6rem; padding: 2px 7px; border-radius: 4px; background: rgba(139,92,246,0.1); color: var(--accent-hover); }
.member-footer { display: flex; justify-content: space-between; align-items: center; padding-top: 10px; border-top: 1px solid var(--border); }
.member-model { font-size: 0.65rem; color: var(--text-muted); font-family: 'SF Mono','Fira Code',monospace; }
.member-tasks { font-size: 0.65rem; color: var(--text-dim); }

/* Lead connector line */
.member-card.is-lead::after {
  content: '★'; position: absolute; top: -1px; left: 50%; transform: translateX(-50%);
  font-size: 0.7rem; color: var(--accent); background: var(--bg); padding: 0 6px;
}

.connection-status { position: fixed; bottom: 10px; right: 10px; font-size: 0.68rem; padding: 4px 10px; border-radius: 6px; background: var(--surface); border: 1px solid var(--border); color: var(--done); z-index: 50; }
.connection-status.disconnected { color: var(--urgent); }

@media (max-width: 768px) {
  .sidebar { width: 60px; } .brand-text, .nav-label { display: none; } .main-area { margin-left: 60px; }
  .column { min-width: 180px; width: 180px; }
  .panel { width: 100vw; }
}
