*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0f0b1a;
  --bg-2:rgba(19,16,32,0.7);
  --surface:#1c1830;
  --surface-2:#251f3d;
  --surface-3:#2d2647;
  --border:rgba(255,255,255,0.07);
  --border-strong:rgba(255,255,255,0.14);
  --text:#f4f0ff;
  --text-dim:#b6acd1;
  --muted:#7d7498;

  --content:#b48cff;
  --content-bg:linear-gradient(135deg,#b48cff,#6d5bff);
  --dev:#6ec5ff;
  --dev-bg:linear-gradient(135deg,#6ec5ff,#3b82f6);
  --social:#ff7ab6;
  --social-bg:linear-gradient(135deg,#ff7ab6,#ec4899);
  --design:#ffb547;
  --design-bg:linear-gradient(135deg,#ffb547,#f97316);
  --pr:#5eead4;
  --pr-bg:linear-gradient(135deg,#5eead4,#14b8a6);

  --green:#34d399;
  --red:#f87171;
  --yellow:#fbbf24;
  --orange:#fb923c;
}

html,body{height:100%;font-family:'Inter',-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}
body::before{content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;background:
  radial-gradient(ellipse 70% 40% at 12% 0%,rgba(180,140,255,0.18),transparent 60%),
  radial-gradient(ellipse 60% 40% at 90% 5%,rgba(255,122,182,0.14),transparent 60%),
  radial-gradient(ellipse 80% 60% at 50% 120%,rgba(110,197,255,0.12),transparent 60%)}
a{color:var(--content)}

.app-body{overflow:hidden}
.app{display:grid;grid-template-columns:240px 1fr;height:100vh}
.main-col{display:flex;flex-direction:column;overflow:hidden}

/* ===== sidebar ===== */
.sidebar{background:rgba(15,11,26,0.7);backdrop-filter:blur(20px);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;padding:14px 10px}
.sidebar .logo{padding:8px 10px 18px;display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}
.sidebar .logo .mark{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#ff7ab6,#b48cff,#6ec5ff);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:15px;box-shadow:0 6px 20px rgba(180,140,255,0.35)}
.sidebar .logo .name{font-weight:800;font-size:15px}
.sidebar .logo .name span{background:linear-gradient(90deg,#ff7ab6,#b48cff,#6ec5ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sidebar .logo .sub{color:var(--muted);font-size:11px}
.create-btn{margin:0 2px 14px;padding:10px 14px;background:linear-gradient(135deg,#b48cff,#6d5bff);color:#fff;border:none;border-radius:10px;font-size:13.5px;font-weight:700;cursor:pointer;text-align:center;text-decoration:none;display:block;box-shadow:0 6px 20px rgba(109,91,255,0.35)}
.create-btn:hover{transform:translateY(-1px)}
.section{padding:10px 12px 4px;font-size:10.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.nav a{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:9px;color:var(--text-dim);text-decoration:none;font-size:13.5px;margin-bottom:2px;font-weight:500}
.nav a:hover{background:var(--surface);color:var(--text)}
.nav a.active{background:linear-gradient(135deg,rgba(180,140,255,0.18),rgba(110,197,255,0.12));color:var(--text);border:1px solid rgba(180,140,255,0.25)}
.nav a .ic{width:16px;height:16px;flex-shrink:0;opacity:0.85}
.nav a .badge{margin-left:auto;background:var(--surface);padding:1px 8px;border-radius:999px;font-size:11px;font-weight:700}
.nav a.active .badge{background:linear-gradient(135deg,#ff7ab6,#b48cff);color:#fff}
.proj a{display:flex;align-items:center;gap:10px;padding:7px 12px;border-radius:8px;color:var(--text-dim);text-decoration:none;font-size:13px;font-weight:500}
.proj a:hover{background:var(--surface)}
.proj a.active{color:var(--text);background:var(--surface);box-shadow:inset 3px 0 0 #b48cff}
.proj a.muted{color:var(--muted)}
.proj a .sq{width:20px;height:20px;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;background:var(--surface-2)}
.proj a .sq-active{background:linear-gradient(135deg,#b48cff,#ff7ab6)}
.proj a .sq-plus{color:var(--muted)}
.sidebar-foot{margin-top:auto;padding:12px 10px 0;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}
.avatar-link{display:flex;text-decoration:none}
.avatar-link:hover .avatar{transform:translateY(-1px);transition:transform .12s}
.logout-form{margin-left:auto}
.logout-btn{background:var(--surface);border:1px solid var(--border);color:var(--muted);width:28px;height:28px;border-radius:7px;cursor:pointer;font-size:13px}
.logout-btn:hover{color:var(--text);border-color:var(--border-strong)}
.who .name{font-weight:700;font-size:13px}
.who .role{color:var(--muted);font-size:11px}

/* ===== avatar palette ===== */
.avatar,.av{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;border-radius:50%;flex-shrink:0;box-shadow:0 2px 8px rgba(0,0,0,0.25)}
.avatar{width:30px;height:30px;border-radius:9px;font-size:12px}
.av{width:24px;height:24px;font-size:11px}
.av-xs{width:18px;height:18px;font-size:9px}
.avatar-sm{width:24px;height:24px;font-size:11px;border-radius:50%}
.a1{background:linear-gradient(135deg,#b48cff,#6366f1)}
.a2{background:linear-gradient(135deg,#6ec5ff,#3b82f6)}
.a3{background:linear-gradient(135deg,#ff7ab6,#ec4899)}
.a4{background:linear-gradient(135deg,#34d399,#14b8a6)}
.a5{background:linear-gradient(135deg,#ffb547,#fb923c)}
.av.empty{background:var(--surface-2);color:var(--muted);box-shadow:none;border:1px dashed var(--border-strong)}

/* ===== topbar ===== */
.topbar{display:flex;align-items:center;gap:10px;padding:14px 26px;border-bottom:1px solid var(--border)}
.topbar .search{flex:1;max-width:440px;position:relative}
.topbar .search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted)}
.topbar .search input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:9px 14px 9px 38px;font-size:13px;font-family:inherit;color:var(--text);outline:none}
.topbar .search input:focus{border-color:var(--content)}
.spacer{flex:1}
.icon-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:10px;cursor:pointer;background:var(--surface);border:1px solid var(--border);color:var(--text-dim);position:relative;text-decoration:none}
.icon-btn:hover{color:var(--text);border-color:var(--border-strong)}
.icon-btn .dot{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;background:var(--red);border:2px solid var(--bg)}
.avatar-stack{display:flex}
.avatar-stack .avatar{border:2px solid var(--bg);margin-right:-8px}

/* ===== hero ===== */
.hero{padding:22px 26px 16px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(180,140,255,0.12),rgba(255,122,182,0.06) 50%,transparent 80%);pointer-events:none;z-index:-1}
.hero-top{display:flex;align-items:flex-start;gap:16px;margin-bottom:18px}
.hero-emoji{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,#b48cff,#ff7ab6);display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:0 10px 30px rgba(180,140,255,0.35);flex-shrink:0}
.hero h1{font-size:26px;font-weight:800;letter-spacing:-0.5px;line-height:1.2;margin-bottom:3px;display:flex;align-items:center;gap:10px}
.hero-meta{color:var(--text-dim);font-size:13.5px;display:flex;gap:16px;flex-wrap:wrap}
.hero-meta b{color:var(--text);font-weight:600}
.status-pill{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;padding:3px 10px;border-radius:999px;background:rgba(52,211,153,0.15);color:var(--green);border:1px solid rgba(52,211,153,0.3)}
.status-pill.sm{font-size:10px;padding:2px 7px}
.status-pill.status-paused{background:rgba(251,191,36,0.15);color:var(--yellow);border-color:rgba(251,191,36,0.3)}
.status-pill.status-archived{background:rgba(125,116,152,0.15);color:var(--muted);border-color:rgba(125,116,152,0.3)}
.hero-actions{margin-left:auto;display:flex;gap:8px;align-items:center}

.kpi{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:2px}
.kpi .card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;position:relative;overflow:hidden}
.kpi .card .lbl{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:4px}
.kpi .card .val{font-size:22px;font-weight:800;letter-spacing:-0.5px;line-height:1.1}
.kpi .card .sub{font-size:11.5px;color:var(--text-dim);margin-top:3px}
.kpi .card.hot{background:linear-gradient(135deg,rgba(251,146,60,0.2),rgba(251,113,133,0.12));border-color:rgba(251,146,60,0.35)}
.kpi .card.hot .val{color:#fb923c}
.kpi .card.review{background:linear-gradient(135deg,rgba(180,140,255,0.2),rgba(109,91,255,0.12));border-color:rgba(180,140,255,0.35)}
.kpi .card.review .val{color:#c4b5fd}
.kpi .card.ok{background:linear-gradient(135deg,rgba(52,211,153,0.18),rgba(20,184,166,0.1));border-color:rgba(52,211,153,0.3)}
.kpi .card.ok .val{color:var(--green)}

/* ===== tabs ===== */
.tabs-bar{padding:0 26px;border-bottom:1px solid var(--border);display:flex;gap:4px;align-items:center;margin-top:14px}
.tab{padding:11px 16px;background:transparent;border:none;color:var(--text-dim);font-size:13.5px;font-weight:600;cursor:pointer;font-family:inherit;border-bottom:2px solid transparent;margin-bottom:-1px;display:inline-flex;align-items:center;gap:6px;text-decoration:none}
.tab.active{color:var(--text);border-bottom-color:#b48cff}
.tab:hover:not(.active){color:var(--text)}
.tabs-bar .right{margin-left:auto;display:flex;gap:8px;padding-bottom:8px}
.chip-filter{background:var(--surface);border:1px solid var(--border);color:var(--text-dim);padding:5px 10px;border-radius:8px;font-size:12px;cursor:pointer;font-weight:500;font-family:inherit}
.chip-filter:hover{color:var(--text);border-color:var(--border-strong)}
.filters-form{display:flex;gap:8px;flex-wrap:wrap}

/* ===== board ===== */
.board{flex:1;min-height:0;overflow-x:auto;overflow-y:hidden;padding:18px 26px 26px;display:flex;gap:16px;align-items:stretch}
.col{background:rgba(28,24,48,0.5);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:16px;min-width:300px;width:300px;display:flex;flex-direction:column;max-height:100%}
.col-head{padding:14px 16px 10px;display:flex;align-items:center;gap:9px;border-bottom:1px solid var(--border)}
.col-head .badge{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.col-head .name{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:1px}
.col-head .cnt{font-size:12px;color:var(--text-dim);background:var(--surface);padding:2px 8px;border-radius:999px;font-weight:700}
.col-head .add{margin-left:auto;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:var(--muted);cursor:pointer;font-size:16px;line-height:1}
.col-head .add:hover{color:var(--text);background:var(--surface)}
.col-body{padding:10px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:60px}
.col-body > *{flex-shrink:0}

/* ===== task card ===== */
.tcard{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:0;position:relative;overflow:hidden;transition:transform .12s,border-color .12s;text-decoration:none;color:inherit;display:block}
.tcard:hover{transform:translateY(-2px);border-color:var(--border-strong)}
.tcard .strip{height:6px;width:100%}
.strip-content{background:var(--content-bg)}
.strip-dev{background:var(--dev-bg)}
.strip-social{background:var(--social-bg)}
.strip-design{background:var(--design-bg)}
.strip-pr{background:var(--pr-bg)}
.tcard .pad{padding:12px 14px 14px}
.tcard .top{display:flex;align-items:center;gap:6px;margin-bottom:8px;flex-wrap:wrap}
.track-chip{font-size:10.5px;padding:3px 9px;border-radius:999px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:#fff}
.track-chip.content{background:var(--content-bg)}
.track-chip.dev{background:var(--dev-bg)}
.track-chip.social{background:var(--social-bg)}
.track-chip.design{background:var(--design-bg)}
.track-chip.pr{background:var(--pr-bg)}
.track-chip.sm{font-size:9.5px;padding:2px 7px}
.tcard .id{font-family:ui-monospace,SFMono-Regular,monospace;font-size:10.5px;color:var(--muted);margin-left:auto}
.quick-status{margin-left:6px}
.qs-select{background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim);padding:2px 6px;border-radius:6px;font-size:10.5px;font-family:inherit;cursor:pointer;outline:none;max-width:90px}
.qs-select:hover,.qs-select:focus{color:var(--text);border-color:var(--border-strong)}
.qs-select:disabled{opacity:0.5}
.tcard h3{font-size:14.5px;font-weight:600;line-height:1.35;margin-bottom:12px}
.tcard .bottom{display:flex;align-items:center;gap:8px;font-size:12px}
.tcard .name{color:var(--text-dim);font-weight:500}
.tcard .due{margin-left:auto;font-weight:600;color:var(--text-dim);font-size:11.5px;display:flex;align-items:center;gap:4px}
.tcard .due.overdue{color:var(--red)}
.tcard .due.soon{color:var(--yellow)}
.pr-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;display:inline-block}
.pr-dot.high{background:var(--red);box-shadow:0 0 10px rgba(248,113,113,0.6)}
.pr-dot.med{background:var(--yellow)}
.pr-dot.low{background:var(--muted)}
.tcard .attach{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--surface-2);border-radius:8px;font-size:11.5px;color:var(--text-dim);margin-bottom:10px;border:1px solid var(--border)}
.tcard .attach .ico{width:26px;height:26px;border-radius:5px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;flex-shrink:0;background:var(--surface-3)}
.tcard .attach .ico-gdrive{background:var(--content-bg)}
.tcard .attach .ico-figma{background:var(--social-bg)}
.tcard .attach .ico-loom{background:var(--pr-bg)}
.tcard .attach .ico-youtube{background:linear-gradient(135deg,#f43f5e,#dc2626)}
.tcard .attach .attach-meta{flex:1;min-width:0}
.tcard .attach .t{color:var(--text);font-weight:600;font-size:11.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tcard .attach .url{font-family:ui-monospace,SFMono-Regular,monospace;font-size:10.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tcard .attach .arr{color:var(--content)}
.tcard.needs-review{border-color:rgba(180,140,255,0.45);box-shadow:0 0 0 1px rgba(180,140,255,0.2),0 10px 30px -10px rgba(180,140,255,0.4)}
.review-banner{background:linear-gradient(135deg,rgba(180,140,255,0.2),rgba(109,91,255,0.1));padding:6px 14px;font-size:11.5px;color:#c4b5fd;display:flex;align-items:center;gap:6px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;border-bottom:1px solid rgba(180,140,255,0.3)}

/* ===== task detail ===== */
.task-wrap{flex:1;overflow:auto;display:grid;grid-template-columns:1fr 320px;gap:24px;padding:26px;align-items:start}
.task-main{min-width:0}
.task-crumb{color:var(--muted);font-size:13px;margin-bottom:6px}
.task-crumb a{color:var(--text-dim);text-decoration:none}
.task-title{font-size:28px;font-weight:800;letter-spacing:-0.5px;line-height:1.2;margin-bottom:14px}
.task-meta-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.chip-status{background:var(--surface);border:1px solid var(--border);padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;color:var(--text-dim)}
.chip-status.sm{font-size:11px;padding:2px 8px}
.chip-pr{background:var(--surface);border:1px solid var(--border);padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}
.pr-high{color:var(--red)}
.pr-med{color:var(--yellow)}
.pr-low{color:var(--muted)}
.chip-due{background:var(--surface);border:1px solid var(--border);padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;color:var(--text-dim)}
.chip-due.overdue{color:var(--red)}
.chip-due.soon{color:var(--yellow)}
.mono{font-family:ui-monospace,SFMono-Regular,monospace}

.task-desc{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin-bottom:18px;line-height:1.7;color:var(--text-dim)}
.task-desc p{margin-bottom:6px}
.task-desc p:empty{display:none}

.section-head{display:flex;align-items:baseline;gap:10px;margin:24px 0 10px}
.section-head h2{font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim)}
.section-head .count{background:var(--surface);padding:2px 8px;border-radius:999px;font-size:11px;color:var(--text-dim);font-weight:700}
.section-head .link{margin-left:auto;font-size:12px;color:var(--content);text-decoration:none}

.submit-form,.comment-form,.review-form{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:12px}
.submit-form .lbl,.comment-form .lbl{display:block;font-size:12px;color:var(--muted);font-weight:600;margin-bottom:6px;margin-top:10px}
.submit-form .lbl:first-child,.comment-form .lbl:first-child{margin-top:0}
.input{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:13px;color:var(--text);font-family:inherit;outline:none}
.input:focus{border-color:var(--content)}
textarea.input{resize:vertical;min-height:56px}
.actions{display:flex;gap:8px;margin-top:12px;align-items:center}
.btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:7px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.btn:hover{border-color:var(--border-strong)}
.btn.sm{padding:4px 10px;font-size:12px}
.btn-primary{background:linear-gradient(135deg,#b48cff,#6d5bff);border-color:transparent;color:#fff;box-shadow:0 6px 20px rgba(109,91,255,0.3)}
.btn-primary:hover{transform:translateY(-1px)}
.btn-approve{background:linear-gradient(135deg,#34d399,#14b8a6);border-color:transparent;color:#05190c}
.btn-reject{background:rgba(248,113,113,0.12);color:var(--red);border-color:rgba(248,113,113,0.3)}
.btn-reject:hover{background:rgba(248,113,113,0.2)}
.btn-revise{background:rgba(251,191,36,0.12);color:var(--yellow);border-color:rgba(251,191,36,0.3)}

.submission{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:12px}
.submission .sub-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.sub-who{flex:1}
.sub-who .n{font-weight:600;font-size:13.5px}
.sub-who .when{color:var(--muted);font-size:11.5px}
.sub-status{font-size:11px;padding:3px 9px;border-radius:999px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px}
.sub-status-pending{background:rgba(180,140,255,0.15);color:#c4b5fd;border:1px solid rgba(180,140,255,0.3)}
.sub-status-approved{background:rgba(52,211,153,0.15);color:var(--green);border:1px solid rgba(52,211,153,0.3)}
.sub-status-rejected{background:rgba(248,113,113,0.15);color:var(--red);border:1px solid rgba(248,113,113,0.3)}
.sub-status-needs_revision{background:rgba(251,191,36,0.15);color:var(--yellow);border:1px solid rgba(251,191,36,0.3)}

.link-card{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;text-decoration:none;color:inherit}
.link-card:hover{border-color:var(--content)}
.link-card .thumb{width:44px;height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;flex-shrink:0;background:var(--surface-3)}
.link-card .thumb.thumb-gdrive{background:var(--content-bg)}
.link-card .thumb.thumb-figma{background:var(--social-bg)}
.link-card .thumb.thumb-youtube{background:linear-gradient(135deg,#f43f5e,#dc2626)}
.link-card .thumb.thumb-loom{background:var(--pr-bg)}
.link-card .info{flex:1;min-width:0}
.link-card .info .t{font-weight:600;font-size:13px;color:var(--text)}
.link-card .info .u{font-size:11.5px;color:var(--muted);font-family:ui-monospace,SFMono-Regular,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.link-card .arr{color:var(--content);font-size:18px}
.sub-notes{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text-dim);font-size:13px;line-height:1.55}

.comment-input{margin-bottom:8px}
.review-btns{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}

.comment{display:flex;gap:10px;padding:12px 0;border-bottom:1px solid var(--border)}
.comment:last-child{border-bottom:none}
.comment .c-body{flex:1}
.comment .c-top{font-size:13px;margin-bottom:4px}
.comment .c-top b{font-weight:700}
.comment .muted{color:var(--muted);font-size:11.5px;margin-left:8px}
.comment .c-text{color:var(--text-dim);font-size:13.5px}

/* side panel */
.task-side{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;position:sticky;top:20px}
.side-section{padding:8px 0;border-bottom:1px solid var(--border)}
.side-section:last-child{border-bottom:none}
.side-lbl{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px}
.side-val{font-size:13.5px;display:flex;align-items:center;gap:8px}
.side-val.small{font-size:12px;color:var(--text-dim)}
.side-val.muted{color:var(--muted)}

.inline{margin:0}

/* ===== list view ===== */
.list-wrap{flex:1;overflow:auto;padding:18px 26px 26px}
.task-list{display:flex;flex-direction:column;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.task-list.big{background:transparent;border:none}
.task-row{display:flex;align-items:center;gap:12px;padding:10px 14px;text-decoration:none;color:var(--text);border-bottom:1px solid var(--border);transition:background .1s}
.task-row:last-child{border-bottom:none}
.task-row:hover{background:var(--surface-2)}
.task-list.big .task-row{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:6px}
.id-sm{font-size:11.5px;color:var(--muted);min-width:72px}
.t-title{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.t-proj{font-size:12px}
.t-assignee{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-dim)}
.t-status{display:inline-flex;align-items:center;gap:4px}
.due.sm{font-size:11.5px;color:var(--text-dim)}
.due.sm.overdue{color:var(--red);font-weight:600}
.due.sm.soon{color:var(--yellow);font-weight:600}
.muted{color:var(--muted)}
.sm{font-size:11.5px}

.group{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:12px;overflow:hidden}
.group-head{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface-2);border-bottom:1px solid var(--border)}
.group-head .dot{width:8px;height:8px;border-radius:50%}
.group-head .g-name{font-weight:700;text-transform:uppercase;letter-spacing:0.8px;font-size:12px}
.group-head .g-cnt{background:rgba(0,0,0,0.25);padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;color:var(--text-dim)}

/* ===== dashboard ===== */
.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px;padding:18px 26px}
.dash-col{min-width:0}
@media(max-width:900px){.dash-grid{grid-template-columns:1fr}}

.proj-cards{display:grid;grid-template-columns:1fr;gap:10px}
.proj-cards.big{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.proj-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;text-decoration:none;color:inherit;display:block;transition:transform .12s,border-color .12s}
.proj-card:hover{transform:translateY(-2px);border-color:var(--border-strong)}
.proj-card-top{display:flex;gap:12px;align-items:center}
.proj-card .emoji{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,#b48cff,#ff7ab6);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.proj-card .n{font-weight:700;font-size:14.5px;margin-bottom:3px}
.proj-card .m{color:var(--text-dim);font-size:12.5px}

.empty{color:var(--muted);padding:40px 20px;text-align:center;font-size:14px;background:var(--surface);border:1px solid var(--border);border-radius:12px}
.empty-big{padding:60px 20px;text-align:center;max-width:420px;margin:0 auto}
.empty-big .emo{font-size:48px;margin-bottom:12px}
.empty-big h3{font-size:22px;margin-bottom:6px}
.empty-big p{color:var(--text-dim)}

/* ===== admin ===== */
.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.admin-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px 20px}
.admin-card h2{font-size:16px;font-weight:700;margin-bottom:14px}
.lbl{display:block;font-size:11.5px;color:var(--muted);font-weight:600;margin:10px 0 6px}
.lbl:first-child{margin-top:0}
.inv-form button{margin-top:14px}
.invite-ok{background:rgba(52,211,153,0.08);border:1px solid rgba(52,211,153,0.25);border-radius:10px;padding:12px;margin-bottom:14px}
.invite-link-box{display:flex;gap:8px;align-items:center;margin:6px 0}
.invite-link-box code{background:var(--surface-2);padding:6px 10px;border-radius:6px;font-size:12px;flex:1;word-break:break-all}
.user-list{display:flex;flex-direction:column;gap:10px}
.user-row{display:flex;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}
.user-row:last-child{border-bottom:none}
.u-info{flex:1;min-width:0}
.u-name{font-weight:600;font-size:13.5px}
.u-meta{color:var(--text-dim);font-size:11.5px;margin-top:2px}
.role-chip{background:var(--surface-2);color:var(--text-dim);padding:1px 7px;border-radius:999px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px}
.role-owner,.role-admin{background:linear-gradient(135deg,#b48cff,#6d5bff);color:#fff}
.role-manager{background:linear-gradient(135deg,#6ec5ff,#3b82f6);color:#fff}
.role-contributor{background:var(--surface-3)}
.role-viewer{background:var(--surface-2);color:var(--muted)}
.tag{background:var(--surface-2);color:var(--text-dim);padding:1px 7px;border-radius:999px;font-size:10px;font-weight:700;margin-left:6px}
.tag-ok{background:rgba(52,211,153,0.15);color:var(--green)}
.warn{color:var(--yellow)}
.row{display:flex;gap:10px}

/* ===== project members (admin) ===== */
.members-block{margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}
.members-head{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.6px;margin-bottom:10px}
.members-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;align-items:center}
.member-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px 4px 4px;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;margin:0}
.member-chip span{font-size:12.5px;font-weight:500}
.member-x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:13px;line-height:1;padding:0 2px;font-family:inherit}
.member-x:hover{color:var(--red)}
.add-member-form{display:flex;gap:6px}
.add-member-form .input{flex:1;font-size:12.5px;padding:5px 10px}

/* ===== tags ===== */
.tag-chip{font-size:11px;padding:2px 8px;border-radius:999px;background:rgba(180,140,255,0.14);color:#c4b5fd;border:1px solid rgba(180,140,255,0.25);font-weight:500;font-family:inherit}
.tag-chip.sm{font-size:10px;padding:1px 6px}
.card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}

/* ===== subtasks ===== */
.subtasks-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin-bottom:14px}
.sub-progress{margin-bottom:10px}
.sub-progress-bar{height:4px;background:var(--surface-2);border-radius:999px;overflow:hidden}
.sub-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,#34d399,#14b8a6);border-radius:999px;transition:width .3s}
.subtask-row{display:flex;align-items:center;gap:10px;padding:8px 4px;border-radius:7px;text-decoration:none;color:var(--text);transition:background .1s}
.subtask-row:hover{background:var(--surface-2)}
.subtask-row .t-title{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sub-check{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border-strong);flex-shrink:0;font-size:11px;color:var(--green)}
.sub-check.checked{background:rgba(52,211,153,0.15);border-color:var(--green)}
.add-subtask-form{display:flex;gap:8px;margin-bottom:14px}
.add-subtask-form .input{flex:1}

/* ===== workload ===== */
.workload{display:flex;flex-direction:column;gap:14px}
.wl-row{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px 18px;display:grid;grid-template-columns:240px 1fr;gap:18px;align-items:center}
@media(max-width:760px){.wl-row{grid-template-columns:1fr}}
.wl-who{display:flex;gap:12px;align-items:center}
.wl-who-meta{min-width:0}
.wl-name{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wl-stats{min-width:0}
.wl-total{font-size:13px;color:var(--text-dim);margin-bottom:8px}
.wl-total b{color:var(--text)}
.wl-total .warn{color:var(--orange)}
.wl-bar{display:flex;height:10px;background:var(--surface-2);border-radius:999px;overflow:hidden;margin-bottom:8px}
.wl-seg{display:block;height:100%}
.wl-backlog{background:#94a3b8}
.wl-progress{background:var(--dev)}
.wl-review{background:var(--content)}
.wl-approved{background:var(--green)}
.wl-rejected{background:var(--red)}
.wl-done{background:#4b5563}
.wl-legend{display:flex;gap:14px;flex-wrap:wrap;font-size:11.5px;color:var(--text-dim)}
.wl-legend span{display:inline-flex;align-items:center;gap:5px}
.wl-dot{width:8px;height:8px;border-radius:50%;display:inline-block}

/* ===== notifications dropdown ===== */
.notif-wrap{position:relative}
.notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:360px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,0.5);z-index:50;max-height:70vh;display:flex;flex-direction:column}
.notif-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border)}
.notif-head .t{font-weight:700;font-size:14px}
.notif-read-all{background:none;border:none;color:var(--content);font-size:12px;cursor:pointer;font-family:inherit;padding:4px 8px;border-radius:6px}
.notif-read-all:hover{background:var(--surface-2)}
.notif-list{overflow-y:auto;flex:1}
.notif-empty{color:var(--muted);text-align:center;padding:30px 20px;font-size:13px}
.notif-item{display:block;padding:10px 14px;border-bottom:1px solid var(--border);text-decoration:none;color:inherit;transition:background .1s}
.notif-item:last-child{border-bottom:none}
.notif-item:hover{background:var(--surface-2)}
.notif-item.unread{background:linear-gradient(90deg,rgba(180,140,255,0.08),transparent);border-left:3px solid var(--content)}
.notif-item .n-title{font-weight:600;font-size:13.5px;color:var(--text);margin-bottom:2px}
.notif-item .n-body{font-size:12.5px;color:var(--text-dim);line-height:1.4;margin-bottom:3px}
.notif-item .n-time{font-size:11px;color:var(--muted)}

/* ===== calendar ===== */
.cal-wrap{padding:18px 26px 26px;flex:1;overflow:auto}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:8px}
.cal-head{text-align:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--muted);padding:6px 0}
.cal-cell{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;min-height:120px;padding:6px 8px;display:flex;flex-direction:column;gap:4px;overflow:hidden}
.cal-cell.out{opacity:0.35}
.cal-cell.today{border-color:var(--content);box-shadow:0 0 0 1px rgba(180,140,255,0.3)}
.cal-day{font-weight:700;font-size:12.5px;color:var(--text-dim)}
.cal-cell.today .cal-day{color:var(--content)}
.cal-tasks{display:flex;flex-direction:column;gap:3px;overflow:hidden;flex:1}
.cal-task{display:flex;align-items:center;gap:5px;padding:3px 7px;border-radius:5px;background:rgba(255,255,255,0.04);font-size:11.5px;color:var(--text);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-left:3px solid var(--muted)}
.cal-task:hover{background:rgba(255,255,255,0.08)}
.cal-task.tk-content{border-left-color:var(--content)}
.cal-task.tk-dev{border-left-color:var(--dev)}
.cal-task.tk-social{border-left-color:var(--social)}
.cal-task.tk-design{border-left-color:var(--design)}
.cal-task.tk-pr{border-left-color:var(--pr)}
.cal-task.done,.cal-task.approved{opacity:0.5;text-decoration:line-through}
.cal-task .t-title{overflow:hidden;text-overflow:ellipsis}

/* ===== bulk toolbar ===== */
.bulk-toolbar{position:sticky;top:0;z-index:10;background:linear-gradient(135deg,rgba(180,140,255,0.2),rgba(110,197,255,0.12));backdrop-filter:blur(10px);border:1px solid rgba(180,140,255,0.3);border-radius:12px;padding:10px 14px;margin:14px 26px 0;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.bulk-count{font-weight:700;font-size:13px}
.bulk-count b{color:var(--content);font-size:16px}
.bulk-spacer{flex:1}
.bulk-row{display:flex;align-items:center;gap:8px}
.bulk-row .bulk-check{width:16px;height:16px;accent-color:var(--content);flex-shrink:0;cursor:pointer}
.bulk-row .row-link{flex:1;display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit;min-width:0}
.group-head .bulk-group-check{margin-right:6px;accent-color:var(--content)}

/* ===== task edit form ===== */
.task-edit-form{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin-bottom:18px}
.task-edit-form .lbl{display:block;font-size:12px;color:var(--muted);font-weight:600;margin:10px 0 6px}
.task-edit-form .lbl:first-child{margin-top:0}

/* ===== activity log ===== */
.activity-log{position:relative;padding-left:18px;margin-top:8px}
.activity-log::before{content:'';position:absolute;left:5px;top:6px;bottom:6px;width:2px;background:var(--border);border-radius:1px}
.activity-row{position:relative;padding:6px 0;font-size:13px}
.act-dot{position:absolute;left:-18px;top:11px;width:10px;height:10px;border-radius:50%;background:var(--content);box-shadow:0 0 0 3px var(--bg),0 0 8px rgba(180,140,255,0.5)}
.act-body{color:var(--text-dim)}
.act-body b{color:var(--text);font-weight:600}

/* ===== secrets vault ===== */
.secrets-group{margin-bottom:20px}
.secrets-group-head{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--text-dim);padding:8px 0;border-bottom:1px solid var(--border);margin-bottom:10px}
.secret-row{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;margin-bottom:8px;overflow:hidden}
.secret-row summary{display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer;list-style:none;font-size:13.5px}
.secret-row summary::-webkit-details-marker{display:none}
.secret-row summary::before{content:'▸';color:var(--muted);font-size:11px;transition:transform .15s;flex-shrink:0}
.secret-row[open] summary::before{transform:rotate(90deg)}
.secret-row:hover summary{background:rgba(255,255,255,0.03)}
.sec-name{font-weight:600;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sec-val-masked{font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px;color:var(--muted);letter-spacing:1px;flex-shrink:0}
.secret-body{padding:14px 16px;border-top:1px solid var(--border);background:rgba(0,0,0,0.15)}
.secret-body .field{margin-bottom:12px}
.secret-body .field:last-child{margin-bottom:0}
.sec-val-full{display:flex;gap:8px;align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 12px}
.sec-val-full code{flex:1;font-family:ui-monospace,SFMono-Regular,monospace;font-size:12.5px;color:#fbbf24;word-break:break-all;white-space:pre-wrap}
.sec-desc{color:var(--text-dim);font-size:13px;line-height:1.55;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px}
.sec-edit{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-top:14px}
.sec-edit .lbl{margin-top:0}
.sec-edit .input{margin-bottom:8px}
.sec-delete{margin-top:10px}

/* ===== modal ===== */
[hidden]{display:none !important}
.modal-shade{position:fixed;inset:0;background:rgba(15,11,26,0.75);backdrop-filter:blur(6px);z-index:50;display:flex;align-items:center;justify-content:center;padding:24px}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:560px;max-width:100%;box-shadow:0 20px 60px rgba(0,0,0,0.5);max-height:90vh;overflow:auto}
.modal-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.modal-head .small{font-size:11.5px;color:var(--muted)}
.modal-head h2{font-size:19px;font-weight:800;margin-top:3px}
.modal-head .close{margin-left:auto;width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;font-size:16px}
.modal-head .close:hover{background:var(--surface-2);color:var(--text)}
.modal-body{padding:18px 22px}

/* ===== auth ===== */
.auth-body{background:var(--bg);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;overflow-y:auto}
.auth-wrap{display:grid;grid-template-columns:420px 1fr;gap:40px;max-width:960px;width:100%;align-items:center}
@media(max-width:780px){.auth-wrap{grid-template-columns:1fr}}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:32px 28px;box-shadow:0 20px 60px rgba(0,0,0,0.4)}
.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.auth-brand .mark{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,#ff7ab6,#b48cff,#6ec5ff);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:17px;box-shadow:0 6px 20px rgba(180,140,255,0.4)}
.auth-title{font-size:20px;font-weight:800}
.auth-title span{background:linear-gradient(90deg,#ff7ab6,#b48cff,#6ec5ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.auth-sub{font-size:11.5px;color:var(--muted)}
.auth-form label{display:block;font-size:12px;color:var(--muted);font-weight:600;margin:12px 0 6px}
.auth-form input{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:10px 14px;font-size:14px;color:var(--text);font-family:inherit;outline:none}
.auth-form input:focus{border-color:var(--content)}
.auth-btn{margin-top:20px;width:100%;padding:12px;background:linear-gradient(135deg,#b48cff,#6d5bff);color:#fff;border:none;border-radius:10px;font-size:14.5px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 6px 20px rgba(109,91,255,0.35)}
.auth-btn:hover{transform:translateY(-1px)}
.auth-err{background:rgba(248,113,113,0.12);border:1px solid rgba(248,113,113,0.3);color:#fecaca;padding:10px 14px;border-radius:10px;margin-bottom:12px;font-size:13px}
.auth-hint{background:rgba(180,140,255,0.1);border:1px solid rgba(180,140,255,0.25);padding:10px 14px;border-radius:10px;margin-bottom:12px;font-size:13px;color:var(--text-dim)}
.auth-foot{text-align:center;margin-top:20px;color:var(--muted);font-size:12.5px;line-height:1.6}
.auth-tagline h1{font-size:30px;font-weight:800;letter-spacing:-0.5px;line-height:1.15;margin-bottom:10px;background:linear-gradient(90deg,#ff7ab6,#b48cff,#6ec5ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.auth-tagline p{color:var(--text-dim);font-size:14.5px;max-width:400px}

/* ===== flash ===== */
.flash{position:fixed;bottom:24px;right:24px;padding:12px 18px;border-radius:10px;font-size:13.5px;font-weight:600;z-index:100;box-shadow:0 10px 30px rgba(0,0,0,0.4)}
.flash-ok{background:var(--green);color:#05190c}
.flash-err{background:var(--red);color:#fff}

/* ===== scrollbar ===== */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:var(--surface-3)}
::-webkit-scrollbar-track{background:transparent}
