/* ════════════════════════════════════════
   BUILDBOARD DESIGN SYSTEM
   Two modes: light (default-elegant) + dark
   Generous spacing. Enterprise grade.
════════════════════════════════════════ */

/* ── Light theme (default) — Soft Sunset palette ── */
:root,[data-theme="light"] {
  --bg:         #F8F9FB;
  --bg2:        #FFFFFF;
  --s1:         #FFFFFF;
  --s2:         #F4F6F9;
  --s3:         #E6EAF0;
  --b1:         #DDE2EC;
  --b2:         #C4CCDB;
  --b3:         #9AAABB;
  --t1:         #111827;
  --t2:         #4B5A72;
  --t3:         #7B8AA8;
  --brand:      #53B9B0;
  --brand-hi:   #3DA8A0;
  --brand-lt:   #53B9B0;
  --brand-bg:   rgba(83,185,176,.10);
  --brand-bd:   rgba(83,185,176,.30);
  --brand-glow: rgba(83,185,176,.18);
  --red:        #FF7D7A;
  --red-bg:     rgba(255,125,122,.09);
  --red-bd:     rgba(255,125,122,.25);
  --amber:      #E9922A;
  --amber-bg:   rgba(233,146,42,.09);
  --blue:       #3B82F6;
  --blue-bg:    rgba(59,130,246,.09);
  --violet:     #8B5CF6;
  --violet-bg:  rgba(139,92,246,.09);
  --green:      #10B981;
  --green-bg:   rgba(16,185,129,.09);
  --coral:      #FF7D7A;
  --coral-bg:   rgba(255,125,122,.09);
  --slate:      #7B8AA8;
  --shadow-xs:  0 1px 2px rgba(17,24,39,.06);
  --shadow-sm:  0 2px 8px rgba(17,24,39,.08),0 0 0 1px rgba(17,24,39,.04);
  --shadow-md:  0 8px 24px rgba(17,24,39,.10),0 2px 6px rgba(17,24,39,.06);
  --shadow-lg:  0 24px 64px rgba(17,24,39,.14),0 8px 20px rgba(17,24,39,.07);
  --sidebar-bg: #FFFFFF;
  --topbar-bg:  #FFFFFF;
  --modal-bg:   #FFFFFF;
  --drawer-bg:  #FFFFFF;
  --scrim-bg:   rgba(17,24,39,.40);
  --input-bg:   #FFFFFF;
  --card-bg:    #FFFFFF;
  --hover-bg:   rgba(17,24,39,.03);
  --active-bg:  rgba(83,185,176,.08);
  --peach:      #FFF3E9;
}

/* ── Dark theme ── */
[data-theme="dark"] {
  --bg:         #0F1319;
  --bg2:        #161D2A;
  --s1:         #1C2438;
  --s2:         #1C243800;
  --s3:         #232E44;
  --b1:         #2C3A54;
  --b2:         #3A4D6A;
  --b3:         #546480;
  --t1:         #EEF2F8;
  --t2:         #8A9AB8;
  --t3:         #546480;
  --brand:      #53B9B0;
  --brand-hi:   #6ECDC5;
  --brand-lt:   #6ECDC5;
  --brand-bg:   rgba(83,185,176,.12);
  --brand-bd:   rgba(83,185,176,.32);
  --brand-glow: rgba(83,185,176,.20);
  --red:        #FF9A98;
  --red-bg:     rgba(255,154,152,.11);
  --red-bd:     rgba(255,154,152,.28);
  --amber:      #FBBF24;
  --amber-bg:   rgba(251,191,36,.11);
  --blue:       #60A5FA;
  --blue-bg:    rgba(96,165,250,.11);
  --violet:     #A78BFA;
  --violet-bg:  rgba(167,139,250,.11);
  --green:      #34D399;
  --green-bg:   rgba(52,211,153,.11);
  --coral:      #FF9A98;
  --coral-bg:   rgba(255,154,152,.11);
  --slate:      #8A9AB8;
  --shadow-xs:  0 1px 2px rgba(0,0,0,.3);
  --shadow-sm:  0 2px 12px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.04);
  --shadow-md:  0 8px 32px rgba(0,0,0,.5),0 2px 8px rgba(0,0,0,.3);
  --shadow-lg:  0 32px 80px rgba(0,0,0,.7),0 8px 24px rgba(0,0,0,.4);
  --sidebar-bg: #161D2A;
  --topbar-bg:  #1C2438;
  --modal-bg:   #1C2438;
  --drawer-bg:  #1C2438;
  --scrim-bg:   rgba(0,0,0,.70);
  --peach:      rgba(255,243,233,.05);
  --input-bg:   rgba(255,255,255,.04);
  --card-bg:    #1C2438;
  --hover-bg:   rgba(255,255,255,.04);
  --active-bg:  rgba(83,185,176,.10);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--t1);font-size:14px;line-height:1.5;overflow:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font:inherit;color:var(--t1)}
a{color:var(--brand-lt);text-decoration:none}
a:hover{text-decoration:underline}
::placeholder{color:var(--t3)}
:focus-visible{outline:2px solid var(--brand-lt);outline-offset:2px;border-radius:4px}
*{scrollbar-width:thin;scrollbar-color:var(--b2) transparent}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-thumb{background:var(--b2);border-radius:99px}

/* ── Typography scale ── */
.text-xs{font-size:11px;line-height:1.4}
.text-sm{font-size:13px;line-height:1.5}
.text-base{font-size:14px;line-height:1.5}
.text-md{font-size:15px;line-height:1.5}
.text-lg{font-size:17px;line-height:1.4;font-weight:600}
.text-xl{font-size:20px;line-height:1.3;font-weight:700}
.muted{color:var(--t3)}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace}

/* ── Form Controls ── */
.ctrl{
  background:var(--input-bg);
  border:1.5px solid var(--b1);
  border-radius:10px;
  padding:10px 14px;
  font-size:14px;
  color:var(--t1);
  width:100%;
  transition:border-color .15s,box-shadow .15s,background .15s;
}
.ctrl:hover{border-color:var(--b2)}
.ctrl:focus{
  border-color:var(--brand-lt);
  box-shadow:0 0 0 3px var(--brand-glow);
  outline:none;
  background:var(--bg2);
}
select.ctrl{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239ca3af' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
select.ctrl option{background:var(--s1);color:var(--t1)}
textarea.ctrl{resize:vertical;min-height:80px;line-height:1.65}
input[type=date].ctrl{color-scheme:light dark;cursor:pointer}
input[type=date].ctrl::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer}
[data-theme="dark"] input[type=date].ctrl{color-scheme:dark}
.ctrl-sm{padding:7px 11px;font-size:13px;border-radius:6px}

/* ── Searchable Select (custom) ── */
.sel-wrap{position:relative}
.sel-display{
  background:var(--input-bg);border:1.5px solid var(--b1);border-radius:8px;
  padding:10px 36px 10px 14px;font-size:14px;color:var(--t1);cursor:pointer;
  user-select:none;display:flex;align-items:center;gap:8px;min-height:42px;
  transition:border-color .15s,box-shadow .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.sel-display:hover{border-color:var(--b2)}
.sel-display.open{border-color:var(--brand-lt);box-shadow:0 0 0 3px var(--brand-glow)}
.sel-display::after{content:"";position:absolute;right:12px;top:50%;transform:translateY(-50%);width:12px;height:8px;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239ca3af' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;pointer-events:none}
.sel-dropdown{
  position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:500;
  background:var(--modal-bg);border:1.5px solid var(--b1);border-radius:10px;
  box-shadow:var(--shadow-lg);overflow:hidden;
}
.sel-search{
  padding:10px 12px;border-bottom:1px solid var(--b1);
}
.sel-search input{
  width:100%;background:var(--s2);border:1px solid var(--b1);border-radius:6px;
  padding:7px 10px;font-size:13px;color:var(--t1);
}
.sel-search input:focus{outline:none;border-color:var(--brand-lt)}
.sel-options{max-height:220px;overflow-y:auto;padding:6px}
.sel-opt{
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:6px;
  cursor:pointer;font-size:13.5px;transition:background .1s;
}
.sel-opt:hover,.sel-opt.focused{background:var(--hover-bg)}
.sel-opt.selected{background:var(--active-bg);color:var(--brand-lt);font-weight:500}
.sel-opt .check{color:var(--brand-lt);font-size:13px;margin-left:auto;opacity:0}
.sel-opt.selected .check{opacity:1}
.sel-empty{padding:16px;text-align:center;color:var(--t3);font-size:13px}

/* ── Multiselect ── */
.ms-display{
  background:var(--input-bg);border:1.5px solid var(--b1);border-radius:8px;
  padding:6px 36px 6px 10px;cursor:pointer;user-select:none;
  display:flex;align-items:center;flex-wrap:wrap;gap:5px;min-height:42px;
  transition:border-color .15s,box-shadow .15s;position:relative;
}
.ms-display:hover{border-color:var(--b2)}
.ms-display.open{border-color:var(--brand-lt);box-shadow:0 0 0 3px var(--brand-glow)}
.ms-chev{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--t3);pointer-events:none;flex:none}
.ms-tag{
  display:inline-flex;align-items:center;gap:4px;
  background:var(--brand-bg);color:var(--brand-lt);border:1px solid var(--brand-bd);
  border-radius:6px;padding:2px 5px 2px 8px;font-size:12px;font-weight:600;
}
.ms-rm{background:none;border:none;cursor:pointer;color:var(--brand-lt);padding:0 1px;font-size:14px;line-height:1;opacity:.7}
.ms-rm:hover{opacity:1}
.ms-ck{flex:none;color:var(--brand-lt);display:inline-flex;width:18px;align-items:center}
/* ── Drawer scrim ── */
.drawer-scrim{position:absolute;inset:0;z-index:44;display:none;cursor:default}
.drawer-scrim.show{display:block}
/* ── Actual date display ── */
.actual-date-val{font-size:13.5px;color:var(--t2);padding:6px 0;min-height:38px;display:flex;align-items:center}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:7px;padding:9px 18px;
  border-radius:10px;font-size:13.5px;font-weight:600;white-space:nowrap;
  cursor:pointer;border:1.5px solid transparent;transition:all .15s;
  text-decoration:none!important;letter-spacing:-.01em;
}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn-primary:hover{background:var(--brand-hi);border-color:var(--brand-hi);box-shadow:0 4px 12px var(--brand-glow)}
.btn-secondary{background:var(--s2);border-color:var(--b1);color:var(--t2)}
.btn-secondary:hover{border-color:var(--b2);color:var(--t1);background:var(--s3)}
.btn-ghost{background:transparent;border-color:var(--b1);color:var(--t2)}
.btn-ghost:hover{border-color:var(--b2);color:var(--t1);background:var(--hover-bg)}
.btn-ghost.active{background:var(--active-bg);border-color:var(--brand-bd);color:var(--brand-lt)}
.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}
.btn-danger:hover{filter:brightness(1.08)}
.btn-sm{padding:6px 13px;font-size:12.5px;border-radius:7px}
.btn-xs{padding:4px 9px;font-size:11.5px;border-radius:6px}
.btn-icon{
  width:34px;height:34px;border-radius:8px;display:grid;place-items:center;
  color:var(--t3);transition:all .15s;border:none;flex:none;
}
.btn-icon:hover{background:var(--hover-bg);color:var(--t1)}
.btn-icon.dng:hover{background:var(--red-bg);color:var(--red)}
.btn-icon-sm{width:28px;height:28px;border-radius:6px}

/* ── Auth page ── */
.auth-wrap{
  height:100dvh;display:grid;place-items:center;
  position:relative;overflow:hidden;
  background:var(--bg);
}

/* Dot-grid texture */
.auth-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,var(--b1) 1px,transparent 1px);
  background-size:30px 30px;
  opacity:.6;
}

/* Animated colour blobs */
.auth-blob{
  position:absolute;border-radius:50%;filter:blur(110px);pointer-events:none;
  transform-origin:center;
  animation:auth-blob var(--dur,10s) ease-in-out infinite alternate;
}
@keyframes auth-blob{
  from{transform:scale(1) translate(0,0);opacity:var(--from-op,.18)}
  to{transform:scale(1.18) translate(var(--tx,20px),var(--ty,-20px));opacity:var(--to-op,.32)}
}
[data-theme="dark"] .auth-blob{filter:blur(90px)}
[data-theme="dark"] .auth-blob{--from-op:.12;--to-op:.22}

/* Floating task-card elements */
.auth-float{
  position:absolute;pointer-events:none;
  animation:auth-drift var(--dur,20s) ease-in-out infinite;
  animation-delay:var(--delay,0s);
  opacity:0;
}
@keyframes auth-drift{
  0%  {opacity:0;transform:translateY(10px) rotate(var(--rot,-3deg))}
  8%  {opacity:var(--op,.5)}
  50% {transform:translateY(-14px) rotate(calc(var(--rot,-3deg) + 4deg))}
  92% {opacity:var(--op,.5)}
  100%{opacity:0;transform:translateY(10px) rotate(var(--rot,-3deg))}
}
.auth-fc{
  background:var(--bg2);
  border:1px solid var(--b1);
  border-radius:11px;padding:11px 14px;
  box-shadow:var(--shadow-sm);
  min-width:148px;max-width:200px;
  display:flex;flex-direction:column;gap:7px;
}
[data-theme="dark"] .auth-fc{
  background:rgba(255,255,255,.045);
  border-color:rgba(255,255,255,.09);
  box-shadow:none;
}
.auth-fc-top{display:flex;align-items:center;gap:6px}
.auth-fc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.auth-fc-key{font-size:9px;font-family:'JetBrains Mono',monospace;color:var(--t3);font-weight:600;letter-spacing:.4px}
.auth-fc-line{height:5px;background:var(--s3);border-radius:3px}
.auth-fc-line2{background:var(--b1)}
[data-theme="dark"] .auth-fc-line{background:rgba(255,255,255,.13)}
[data-theme="dark"] .auth-fc-line2{background:rgba(255,255,255,.07)}
.auth-fc-badge{font-size:8.5px;padding:2px 8px;border-radius:99px;font-weight:700;letter-spacing:.3px;width:fit-content}

/* Card — solid white in light, glass in dark */
.auth-card{
  position:relative;z-index:10;
  background:var(--bg2);
  border:1px solid var(--b1);
  border-radius:24px;
  box-shadow:var(--shadow-lg),0 0 0 1px var(--b1);
  width:420px;max-width:94vw;padding:44px 40px;
}
[data-theme="dark"] .auth-card{
  background:rgba(22,29,42,.72);
  border-color:rgba(255,255,255,.09);
  box-shadow:0 40px 100px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.06);
  backdrop-filter:blur(24px);
}

/* Centred branding */
.auth-brand{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:36px;text-align:center}
.auth-logo{
  width:72px;height:72px;border-radius:20px;
  background:var(--brand-bg);
  border:1.5px solid var(--brand-bd);
  display:grid;place-items:center;
  box-shadow:0 8px 32px var(--brand-glow);
}
.auth-title{
  font-size:30px;font-weight:800;letter-spacing:-.8px;
  background:linear-gradient(135deg,var(--t1) 30%,var(--brand));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1.1;
}
[data-theme="dark"] .auth-title{
  background:linear-gradient(135deg,#fff 30%,#53B9B0);
  -webkit-background-clip:text;background-clip:text;
}
.auth-tagline{font-size:12.5px;color:var(--t3);font-weight:500;letter-spacing:.8px;text-transform:uppercase}

/* Form headings */
.auth-heading{font-size:19px;font-weight:700;color:var(--t1);text-align:center;margin-bottom:6px}
.auth-sub{text-align:center;color:var(--t2);font-size:13.5px;margin-bottom:28px;line-height:1.5}

/* Gradient sign-in button */
.auth-btn{
  width:100%;margin-top:22px;
  padding:13px;border-radius:12px;
  font-size:14.5px;font-weight:700;letter-spacing:.2px;
  color:#fff;cursor:pointer;
  background:linear-gradient(135deg,#53B9B0,#3da8a0);
  border:none;
  box-shadow:0 4px 20px rgba(83,185,176,.35);
  transition:transform .15s,box-shadow .15s,filter .15s;
  display:flex;align-items:center;justify-content:center;gap:8px;
  min-height:46px;
}
.auth-btn:hover{transform:translateY(-1px);box-shadow:0 8px 28px rgba(83,185,176,.45);filter:brightness(1.08)}
.auth-btn:active{transform:translateY(0);box-shadow:0 2px 12px rgba(83,185,176,.3)}
.auth-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}
@keyframes spin{to{transform:rotate(360deg)}}
.auth-spin{animation:spin .7s linear infinite;flex-shrink:0}

/* Secure note */
.auth-secure{text-align:center;margin-top:18px;font-size:11.5px;color:var(--t3);letter-spacing:.2px}

/* Error box */
.aerr{
  background:var(--red-bg);color:var(--red);
  border:1px solid var(--red-bd);
  border-radius:9px;padding:11px 14px;font-size:13px;margin-top:14px;display:none;
}
.aerr.on{display:block}
.flabel{display:block;font-size:12px;font-weight:600;color:var(--t2);margin-bottom:6px;margin-top:18px}

/* ── Chips / Badges ── */
.chip{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;padding:3px 9px;border-radius:5px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;line-height:1.5;vertical-align:middle}
.chip svg{flex:none;opacity:.9}
.ch-Backlog     {background:var(--s3);color:var(--t3)}
.ch-Pending     {background:var(--s3);color:var(--t2)}
.ch-InProgress  {background:var(--amber-bg);color:var(--amber)}
.ch-OnHold      {background:var(--blue-bg);color:var(--blue)}
.ch-InQA        {background:var(--violet-bg);color:var(--violet)}
.ch-QAVerified  {background:var(--green-bg);color:var(--green)}
.ch-Doneonlive  {background:var(--green-bg);color:var(--green)}
.ch-Critical    {background:rgba(220,38,38,.12);color:var(--red)}
.ch-High        {background:var(--red-bg);color:var(--red)}
.ch-Medium      {background:var(--amber-bg);color:var(--amber)}
.ch-Low         {background:var(--s3);color:var(--t3)}
.ch-epic        {background:var(--violet-bg);color:var(--violet)}
.ch-story       {background:var(--blue-bg);color:var(--blue)}
.ch-task        {background:var(--s3);color:var(--t2)}
.ch-bug         {background:var(--red-bg);color:var(--red)}
.ch-subtask     {background:var(--s3);color:var(--t3)}
.pf-chip{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;padding:3px 8px;border-radius:5px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;vertical-align:middle}
.pf-chip svg{flex:none;opacity:.9}
.ch-pf-Web     {background:var(--blue-bg);color:var(--blue)}
.ch-pf-Android {background:var(--green-bg);color:var(--green)}
.ch-pf-iOS     {background:var(--s3);color:var(--t2)}
.ch-pf-Backend {background:var(--violet-bg);color:var(--violet)}
.ch-pf-All     {background:var(--amber-bg);color:var(--amber)}
/* Confirm dialog */
.cdlg-icon{width:48px;height:48px;border-radius:12px;background:var(--red-bg);display:grid;place-items:center;margin-bottom:16px;color:var(--red)}
.cdlg-icon.warn{background:var(--amber-bg);color:var(--amber)}
.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}
.btn-danger:hover{filter:brightness(1.12)}
.rb{font-family:'JetBrains Mono',monospace;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:5px}
.rb-admin   {background:var(--violet-bg);color:var(--violet)}
.rb-owner   {background:var(--amber-bg);color:var(--amber)}
.rb-member  {background:var(--s3);color:var(--t2)}
.rb-viewer  {background:var(--s2);color:var(--t3)}
.rb-invited {background:var(--blue-bg);color:var(--blue)}
.rb-disabled{background:var(--red-bg);color:var(--red)}
.rb-active  {background:var(--green-bg);color:var(--green)}

/* ── Avatar ── */
.av{
  width:30px;height:30px;border-radius:50%;flex:none;font-size:11.5px;font-weight:700;
  background:var(--brand-bg);color:var(--brand-lt);display:inline-grid;place-items:center;
  overflow:hidden;vertical-align:middle;border:2px solid var(--b1);
}
.av img{width:100%;height:100%;object-fit:cover;display:block}
.av.sm{width:22px;height:22px;font-size:9px;border-width:1.5px}
.av.md{width:34px;height:34px;font-size:12.5px}
.av.lg{width:72px;height:72px;font-size:26px;border-width:2.5px}
.av.xl{width:96px;height:96px;font-size:34px;border-width:3px}
.av.none{background:var(--s3);color:var(--t3);border-style:dashed}

/* ── App Shell ── */
.app{display:grid;grid-template-columns:260px 1fr;height:100dvh;overflow:hidden}
.side{
  background:var(--sidebar-bg);border-right:1.5px solid var(--b1);
  display:flex;flex-direction:column;overflow:hidden;z-index:40;
  box-shadow:4px 0 20px rgba(17,24,39,.07);
}
.side-brand{
  padding:20px 18px 16px;border-bottom:1.5px solid var(--b1);
  display:flex;align-items:center;gap:12px;
}
.side-brand .bb-mark{
  width:34px;height:34px;background:var(--peach);border-radius:9px;
  display:grid;place-items:center;flex:none;border:1.5px solid var(--b1);
}
.side-brand .bb-name{font-size:15px;font-weight:800;letter-spacing:-.4px;color:var(--t1)}
.side-brand .bb-sub{font-size:10px;color:var(--t3);letter-spacing:.5px;text-transform:uppercase;display:block;font-weight:400}
.nav{padding:10px 10px 4px}
.nav-section{
  padding:14px 14px 5px;font-size:10px;font-weight:700;letter-spacing:1px;
  text-transform:uppercase;color:var(--t3);
}
.ni{
  display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  padding:9px 14px;border-radius:12px;font-size:13.5px;font-weight:500;color:var(--t3);
  transition:all .15s;position:relative;margin-bottom:2px;
}
.ni svg{flex:none;color:var(--t3);transition:color .15s}
.ni:hover{background:var(--hover-bg);color:var(--t2)}
.ni:hover svg{color:var(--t2)}
.ni.on{background:var(--brand);color:#fff;font-weight:600}
.ni.on svg{color:#fff;opacity:1}
.ni .ndot{
  position:absolute;right:10px;top:50%;transform:translateY(-50%);
  background:var(--red);color:#fff;font-size:10px;font-weight:700;
  border-radius:99px;padding:1px 6px;min-width:18px;text-align:center;
}
.ni.on .ndot{background:rgba(255,255,255,.3);color:#fff}
.plist{overflow-y:auto;flex:1;padding:4px 10px 10px}
.pb{
  display:flex;align-items:center;gap:9px;width:100%;text-align:left;
  padding:8px 12px;border-radius:10px;font-size:13px;font-weight:500;
  color:var(--t3);transition:all .15s;margin-bottom:2px;
}
.pb:hover{background:var(--hover-bg);color:var(--t2)}
.pb.on{background:var(--brand-bg);color:var(--brand);font-weight:600}
.pb .pcode{font-family:'JetBrains Mono',monospace;font-size:10px;min-width:36px;opacity:.6}
.pb .pname{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pb .ptc{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--t3)}
.pb-new{
  display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:10px;
  font-size:13px;color:var(--t3);cursor:pointer;margin-bottom:2px;
  border:1.5px dashed var(--b1);transition:all .15px;background:none;width:100%;text-align:left;
}
.pb-new:hover{border-color:var(--brand-bd);color:var(--brand);background:var(--brand-bg)}
.side-foot{display:none}
.spacer{flex:1}

/* ── Mobile ── */
.mobile-bar{
  display:none;align-items:center;gap:10px;
  background:var(--topbar-bg);border-bottom:1.5px solid var(--b1);
  padding:10px 16px;position:sticky;top:0;z-index:30;flex:none;
}
.menu-btn{
  width:34px;height:34px;border:1.5px solid var(--b1);border-radius:8px;
  display:grid;place-items:center;color:var(--t2);
}
.side-scrim{display:none;position:fixed;inset:0;background:var(--scrim-bg);z-index:39;backdrop-filter:blur(3px)}

/* ── Main ── */
.main{display:flex;flex-direction:column;min-width:0;overflow:hidden;background:var(--bg);position:relative}

/* ── Global topbar ── */
.g-topbar{
  display:flex;align-items:center;gap:12px;padding:0 20px;
  background:var(--topbar-bg);border-bottom:1.5px solid var(--b1);
  height:58px;flex:none;z-index:20;
}
.g-page-area{display:flex;align-items:center;gap:10px;flex:none;min-width:0}
.g-page-area h2{font-size:16px;font-weight:700;letter-spacing:-.3px;white-space:nowrap;color:var(--t1)}
.gsearch-wrap{flex:1;max-width:380px;position:relative;display:flex;align-items:center;margin-left:auto}
.gsearch-wrap svg{position:absolute;left:10px;color:var(--t3);pointer-events:none;flex:none}
.gsearch{
  width:100%;padding:7px 12px 7px 34px;
  background:var(--s2);border:1.5px solid var(--b1);border-radius:8px;
  font-size:13.5px;color:var(--t1);transition:all .15s;
}
.gsearch:focus{background:var(--bg2);border-color:var(--brand-lt);box-shadow:0 0 0 3px var(--brand-glow);outline:none}
.gsearch::placeholder{color:var(--t3)}
.gsearch-drop{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:var(--modal-bg);border:1.5px solid var(--b1);border-radius:10px;
  box-shadow:var(--shadow-lg);z-index:60;overflow:hidden;max-height:360px;overflow-y:auto;
}
.gsearch-drop .gs-section{font-size:10.5px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--t3);padding:10px 14px 4px}
.gsearch-drop .gs-item{
  display:flex;align-items:center;gap:10px;padding:9px 14px;cursor:pointer;transition:background .1s;
  font-size:13.5px;
}
.gsearch-drop .gs-item:hover{background:var(--hover-bg)}
.gsearch-drop .gs-item .gs-key{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--t3);flex:none}
.gsearch-drop .gs-item .gs-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gsearch-drop .gs-empty{padding:20px;text-align:center;color:var(--t3);font-size:13.5px}
.g-top-right{display:flex;align-items:center;gap:6px;margin-left:auto}
/* Profile dropdown */
.g-avatar-btn{
  display:flex;align-items:center;gap:8px;padding:5px 10px 5px 6px;
  border-radius:8px;border:1.5px solid transparent;font-size:13px;font-weight:600;color:var(--t2);
  transition:all .12s;
}
.g-avatar-btn:hover{background:var(--hover-bg);border-color:var(--b1);color:var(--t1)}
.g-avatar-btn.open{background:var(--active-bg);border-color:var(--brand-bd);color:var(--brand-lt)}
.g-uname{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.g-profile-menu{
  position:absolute;top:54px;right:16px;
  background:var(--modal-bg);border:1.5px solid var(--b1);border-radius:10px;
  box-shadow:var(--shadow-lg);z-index:60;width:190px;overflow:hidden;padding:5px;
}
.g-profile-menu button{
  display:flex;align-items:center;gap:9px;width:100%;text-align:left;
  padding:9px 11px;border-radius:7px;font-size:13.5px;color:var(--t2);transition:all .1s;
}
.g-profile-menu button:hover{background:var(--hover-bg);color:var(--t1)}
.g-profile-menu button.dng:hover{background:var(--red-bg);color:var(--red)}
.g-profile-menu hr{border:none;border-top:1.5px solid var(--b1);margin:4px 0}

.topbar{display:none}/* titles merged into g-topbar */
.view-tabs{display:flex;padding:0 24px;background:var(--topbar-bg);border-bottom:1.5px solid var(--b1);flex:none}
.vtab{
  padding:11px 18px;font-size:13.5px;font-weight:600;color:var(--t3);
  border-bottom:2.5px solid transparent;margin-bottom:-1.5px;white-space:nowrap;
  transition:all .12s;
}
.vtab:hover{color:var(--t2)}
.vtab.on{color:var(--brand-lt);border-color:var(--brand-lt)}
/* List/Board view toggle bar (below filters) */
#gPageAction{display:flex;align-items:center;gap:8px}
.view-bar{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.view-tog{display:flex;align-items:center;background:var(--s2);border:1.5px solid var(--b1);border-radius:8px;overflow:hidden}
.view-tog-btn{
  display:flex;align-items:center;gap:5px;padding:6px 14px;
  font-size:12.5px;font-weight:600;color:var(--t3);cursor:pointer;
  border-right:1.5px solid var(--b1);transition:background .12s,color .12s;white-space:nowrap;
}
.view-tog-btn:last-child{border-right:none}
.view-tog-btn:hover{background:var(--hover-bg);color:var(--t2)}
.view-tog-btn.on{background:var(--brand-glow);color:var(--brand-lt)}
/* date range filter row */
.fbar2{gap:6px;margin-top:6px;margin-bottom:0}
.dr-label{font-size:12px;font-weight:600;color:var(--t3);white-space:nowrap}
.dr-sep{font-size:13px;color:var(--t3);padding:0 2px}
.fbar2 .ctrl-sm{padding:5px 9px;font-size:12.5px;width:140px}
/* pagination bar */
.pag-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;border-top:1px solid var(--b1);flex-wrap:wrap}
.pag-info{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--t3)}
.pag-nav{display:flex;align-items:center;gap:8px}
.pag-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:1.5px solid var(--b1);background:var(--bg2);color:var(--t2);cursor:pointer;transition:all .12s}
.pag-btn:hover:not([disabled]){border-color:var(--brand-lt);color:var(--brand-lt)}
.pag-btn[disabled]{opacity:.35;cursor:default}
.pag-pages{font-size:12.5px;font-weight:500;color:var(--t2);white-space:nowrap}
.pag-size{display:flex;align-items:center;gap:6px;margin-left:auto;font-size:12px;color:var(--t3)}
.pag-sz-btn{padding:3px 10px;border-radius:5px;border:1.5px solid var(--b1);background:var(--bg2);font-size:12px;font-weight:600;color:var(--t3);cursor:pointer;transition:all .12s}
.pag-sz-btn:hover{border-color:var(--brand-lt);color:var(--brand-lt)}
.pag-sz-btn.on{background:var(--brand-glow);color:var(--brand-lt);border-color:var(--brand-lt)}
.content{flex:1;overflow:auto;padding:24px 24px 80px;background:radial-gradient(ellipse 130% 80% at 0% 0%,rgba(255,243,233,.45) 0%,transparent 55%)}

/* ── Filter bar ── */
.fbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:20px}
.fbar .ctrl{width:auto;font-size:13px;padding:8px 12px;min-height:38px;border-radius:7px}
.fbar .sel-display{width:auto}
.fbar input[type=text]{width:200px}
.row-st-w{min-width:120px;max-width:155px}
.row-st-w .sel-dropdown{min-width:185px;z-index:600}
.mine-pill{
  border:1.5px solid var(--b1);border-radius:99px;padding:6px 16px;
  font-size:13px;font-weight:600;color:var(--t2);background:var(--bg2);cursor:pointer;
  transition:all .12s;white-space:nowrap;
}
.mine-pill.on{background:var(--brand);border-color:var(--brand);color:#fff}
.rcount{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--t3)}

/* ── Table ── */
.tbl{background:var(--bg2);border:1.5px solid var(--b1);border-radius:16px}
.tbl-scroll{overflow-x:auto}
.td-status-cell{position:relative}
table{border-collapse:collapse;width:100%;min-width:900px}
thead th{
  font-size:11px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;
  color:var(--t3);text-align:left;padding:11px 14px;
  border-bottom:1.5px solid var(--b1);white-space:nowrap;
  background:var(--s2);position:relative;
}
thead th:first-child{border-top-left-radius:14px}
thead th:last-child{border-top-right-radius:14px}
thead th[data-sort]{cursor:pointer;user-select:none;transition:background .12s,color .12s}
thead th[data-sort]:hover{background:var(--hover-bg);color:var(--t1)}
.th-sort-arrow{display:inline-block;margin-left:5px;font-size:11px;opacity:0;transition:opacity .1s}
thead th.th-asc .th-sort-arrow::after{content:"↑";opacity:1}
thead th.th-desc .th-sort-arrow::after{content:"↓";opacity:1}
thead th.th-asc .th-sort-arrow,thead th.th-desc .th-sort-arrow{opacity:1}
tbody td{padding:10px 14px;border-bottom:1px solid var(--b1);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr{cursor:pointer;transition:background .1s}
tbody tr:hover{background:var(--hover-bg)}
/* group section header rows */
.tbl-grp-hd{cursor:default!important}
.tbl-grp-hd:hover{background:transparent!important}
.tbl-grp-hd td{padding:10px 16px 8px;background:var(--bg2)!important;border-bottom:1.5px solid var(--b1);border-top:2px solid var(--b1)}
tbody tr.tbl-grp-hd:first-child td{border-top:none}
.grp-lbl{font-size:12px;font-weight:700;letter-spacing:.4px;display:inline-flex;align-items:center;gap:8px;color:var(--brand-lt)}
.grp-lbl.grp-done{color:var(--green)}
.grp-count{font-family:'JetBrains Mono',monospace;font-size:10.5px;padding:1px 8px;border-radius:99px;background:var(--brand-glow);color:var(--brand-lt);font-weight:700}
.grp-lbl.grp-done .grp-count{background:var(--green-bg);color:var(--green)}
/* done rows */
.tr-done{opacity:.75}
.tr-done .ttl{text-decoration:line-through;opacity:.6}
/* priority icon-only */
.td-pr{text-align:center;width:36px;white-space:nowrap}
.pr-ico{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;flex:none}
.pr-ico.ch-Critical{background:rgba(220,38,38,.12);color:var(--red)}
.pr-ico.ch-High{background:var(--red-bg);color:var(--red)}
.pr-ico.ch-Medium{background:var(--amber-bg);color:var(--amber)}
.pr-ico.ch-Low{background:var(--s3);color:var(--t3)}
/* row inline status chip */
.row-st-w .sel-display{border:none;background:transparent;padding:4px 22px 4px 8px;min-height:26px;border-radius:6px;font-size:11px;font-weight:700;font-family:'JetBrains Mono',monospace;letter-spacing:.2px;white-space:nowrap;gap:5px}
.row-st-w .sel-display:hover{filter:brightness(.88)}
.row-st-w .sel-display.open{box-shadow:0 0 0 2px var(--brand-glow)!important}
.row-st-w .sel-display::after{right:6px;width:10px;height:6px}
.td-key{font-family:'JetBrains Mono',monospace;font-size:11.5px;font-weight:600;color:var(--t3);white-space:nowrap}
.td-key a{color:var(--brand-lt)}
.td-title{max-width:340px}
.td-title .ttl{display:block;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13.5px}
.td-title .tmeta{display:flex;gap:6px;margin-top:3px;align-items:center;flex-wrap:wrap}
.badge{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--t3)}
.who-cell{display:flex;align-items:center;gap:7px;white-space:nowrap}
.who-name{font-size:12.5px}
.dc{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--t2);white-space:nowrap}
.dc.over{color:var(--red);font-weight:600}
.pc{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--t3);text-align:center}
.empty-st{padding:72px 32px;text-align:center;color:var(--t3)}
.empty-st svg{display:block;margin:0 auto 16px;opacity:.3}
.empty-st h3{font-size:16px;color:var(--t2);margin-bottom:6px;font-weight:600}
.empty-st p{font-size:14px}

/* ── Board ── */
.board-scroll{overflow-x:auto;padding-bottom:20px}
.board{display:grid;grid-auto-flow:column;grid-auto-columns:290px;gap:16px;align-items:start}
.bcol{background:var(--bg2);border:1.5px solid var(--b1);border-radius:16px;display:flex;flex-direction:column;max-height:calc(100dvh - 210px)}
.bcol-hd{display:flex;align-items:center;gap:9px;padding:14px 16px;border-bottom:1.5px solid var(--b1);font-size:12.5px;font-weight:700}
.bcol-n{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--t3);margin-left:auto;background:var(--s2);padding:2px 8px;border-radius:99px}
.bcol-body{padding:10px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;min-height:80px}
.bcol.dragover{outline:2px dashed var(--brand-lt);outline-offset:-3px}
.card{
  background:var(--card-bg);border:1.5px solid var(--b1);border-radius:14px;padding:14px;
  cursor:grab;transition:all .15s;
}
.card:hover{border-color:var(--b3);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.card.dragging{opacity:.35;cursor:grabbing;transform:rotate(1.5deg)}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:9px}
.card-key{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--t3)}
.card-title{font-size:13.5px;font-weight:500;line-height:1.45;margin-bottom:11px}
.card-meta{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.card-meta .av{margin-left:auto}
.card-pts{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--t3);background:var(--s3);padding:2px 8px;border-radius:99px}

/* ── Sprint cards ── */
.sprint-card{
  background:var(--bg2);border:1.5px solid var(--b1);border-radius:16px;
  padding:20px 24px;margin-bottom:16px;
}
.sprint-card.active{border-color:var(--brand-bd);box-shadow:0 0 0 1px var(--brand-bd)}
.sprint-hd{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.sprint-hd h3{font-size:15px;font-weight:700;flex:1;letter-spacing:-.2px}
.sprint-meta{font-size:13px;color:var(--t3);display:flex;gap:16px;margin-bottom:14px;flex-wrap:wrap}
.pbar{height:6px;background:var(--s3);border-radius:99px;overflow:hidden}
.pbar .fill{height:100%;border-radius:99px;background:var(--brand-lt);transition:width .4s ease}

/* ── Burndown ── */
.burndown-wrap{max-width:860px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:22px}
.stat-card{background:var(--bg2);border:1.5px solid var(--b1);border-radius:10px;padding:18px 20px}
.stat-card .sv{font-size:30px;font-weight:800;font-family:'JetBrains Mono',monospace;letter-spacing:-.5px}
.stat-card .sl{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--t3);font-weight:600;margin-top:4px}
.bd-canvas{width:100%;height:220px;display:block;border-radius:8px;overflow:hidden}

/* ── Roadmap ── */
.rm-wrap{overflow:auto;position:relative;border:1.5px solid var(--b1);border-radius:12px}
.rm-hdr{display:flex;border-bottom:1.5px solid var(--b1);background:var(--s2);position:sticky;top:0;z-index:5}
.rm-lbl-col{width:280px;min-width:280px;border-right:1.5px solid var(--b1);padding:12px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--t3)}
.rm-months{display:flex;flex:1}
.rm-month{flex:none;border-right:1px dashed var(--b1);padding:12px 10px;font-size:12px;font-weight:600;color:var(--t2)}
.rm-row{display:flex;align-items:center;border-bottom:1px solid var(--b1);min-height:48px;cursor:pointer}
.rm-row:last-child{border-bottom:none}
.rm-row:hover{background:var(--hover-bg)}
.rm-label{width:280px;min-width:280px;border-right:1.5px solid var(--b1);padding:10px 16px;display:flex;align-items:center;gap:9px}
.rm-rt{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.rm-timeline{flex:1;position:relative;height:48px}
.rm-bar{
  position:absolute;height:26px;top:11px;border-radius:6px;cursor:pointer;
  display:flex;align-items:center;padding:0 10px;font-size:11.5px;font-weight:600;
  color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  transition:filter .15s,transform .15s;
}
.rm-bar:hover{filter:brightness(1.12);transform:scaleY(1.05)}

/* ── Task Drawer ── */
.drawer{
  position:absolute;top:0;right:0;bottom:0;width:780px;max-width:97vw;
  background:var(--drawer-bg);border-left:1.5px solid var(--b1);
  box-shadow:var(--shadow-lg);transform:translateX(105%);
  transition:transform .22s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;z-index:45;
}
.drawer.open{transform:none}
.dr-hdr{padding:16px 20px 0;border-bottom:1.5px solid var(--b1);flex:none}
.dr-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.dr-keyline{display:flex;align-items:center;gap:6px}
.dr-key{font-family:'JetBrains Mono',monospace;font-size:11.5px;font-weight:700;color:var(--t3);letter-spacing:.3px}
.dr-sep{color:var(--b2);font-size:11px;line-height:1}
.dr-proj{font-size:11.5px;color:var(--t3);font-weight:500}
.dr-actions{display:flex;gap:4px;flex:none}
.dr-title{
  width:100%;background:transparent;border:none;
  font:700 18px/1.4 'Poppins',sans-serif;letter-spacing:-.3px;
  color:var(--t1);border-radius:7px;padding:4px 6px;margin:-4px -6px;
  transition:background .12s;display:block;margin-bottom:12px;
}
.dr-title:hover{background:var(--hover-bg)}
.dr-title:focus{background:var(--hover-bg);outline:1.5px solid var(--b2)}
.dr-meta{display:flex;align-items:center;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.dr-tabs{display:flex;overflow-x:auto;margin-top:4px}
.dtab{
  padding:10px 16px;font-size:13px;font-weight:600;color:var(--t3);
  border-bottom:2.5px solid transparent;margin-bottom:-1.5px;white-space:nowrap;
  transition:all .12s;
}
.dtab:hover{color:var(--t2)}
.dtab.on{color:var(--brand-lt);border-color:var(--brand-lt)}
.dtab .nt{font-family:'JetBrains Mono',monospace;font-size:10px;margin-left:4px;color:var(--t3)}
.dr-body{flex:1;overflow:hidden;display:flex;min-height:0}
.dl{display:grid;grid-template-columns:1fr 268px;width:100%;height:100%;overflow:hidden;min-height:0}
.dl-left{overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:24px}
.dl-right{overflow-y:auto;padding:18px;background:var(--s2);border-left:1.5px solid var(--b1)}
.ds h4{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:var(--t3);margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}
.ds h4 button{font-size:12.5px;color:var(--brand-lt);font-weight:600;text-transform:none;letter-spacing:0}
.fr{margin-bottom:14px}
.fr label{font-size:11.5px;font-weight:600;color:var(--t2);display:block;margin-bottom:5px}
.fr .ctrl{font-size:13.5px;border-radius:7px;padding:8px 12px}

/* ── Description edit ── */
.ds-hint{font-size:10px;font-weight:400;color:var(--t3);text-transform:none;letter-spacing:0}
.descr-view{
  font-size:14px;line-height:1.75;color:var(--t2);white-space:pre-wrap;word-break:break-word;
  cursor:pointer;padding:14px 16px;
  border:1.5px solid var(--b1);border-radius:10px;
  min-height:90px;background:var(--bg2);
  transition:border-color .15s,background .15s;
}
.descr-view:hover{border-color:var(--b2);background:var(--bg)}
.descr-view .mention{color:var(--brand-lt);font-weight:600}
.descr-empty{color:var(--t3);font-style:italic}
.descr-ta{font-size:14px;line-height:1.75;border-radius:10px;padding:14px 16px;min-height:120px;resize:vertical}
.descr-wrap{position:relative}
.descr-collapsed .descr-view{max-height:120px;overflow:hidden}
.descr-fade{
  position:absolute;bottom:0;left:0;right:0;height:52px;pointer-events:none;
  background:linear-gradient(to bottom,transparent,var(--bg2));
  border-radius:0 0 10px 10px;
}
.descr-toggle{
  display:block;margin-top:6px;font-size:12.5px;font-weight:600;
  color:var(--brand-lt);cursor:pointer;background:none;border:none;padding:0;
  transition:color .12s;
}
.descr-toggle:hover{color:var(--brand-hi)}

/* ── @mention popup — positioned dynamically at caret ── */
.mpop{
  position:absolute;z-index:600;
  width:260px;max-height:228px;overflow-y:auto;display:none;
  background:var(--modal-bg);border:1.5px solid var(--b1);border-radius:10px;
  box-shadow:var(--shadow-lg);
}
.mitem{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:13.5px;transition:background .1s}
.mitem:hover,.mitem.sel{background:var(--hover-bg)}
.mitem .mn{font-weight:600}
.mitem .me{font-size:11.5px;color:var(--t3)}

/* ── Comments (now inline) ── */
.comment{display:flex;gap:14px;padding:16px 0;border-bottom:1.5px solid var(--b1)}
.comment:last-child{border-bottom:none}
.comment .cb{flex:1;min-width:0}
.comment .ch{display:flex;align-items:baseline;gap:9px;margin-bottom:6px;flex-wrap:wrap}
.comment .ch b{font-size:13.5px;font-weight:600}
.comment .ch time{font-size:11.5px;color:var(--t3);font-family:'JetBrains Mono',monospace}
.comment .ch .ed{font-size:10.5px;color:var(--t3);font-style:italic}
.comment .ct{font-size:13.5px;line-height:1.65;color:var(--t2);white-space:pre-wrap;word-break:break-word}
.comment .ct .mention{color:var(--brand-lt);font-weight:600}
.comment .ca{display:flex;gap:10px;margin-top:8px}
.comment .ca button{font-size:12px;color:var(--t3);font-weight:500;transition:color .12s}
.comment .ca button:hover{color:var(--t1)}
.cm-box{background:var(--s2);border:1.5px solid var(--b1);border-radius:10px;overflow:hidden;transition:border-color .15s}
.cm-box:focus-within{border-color:var(--brand-lt);box-shadow:0 0 0 3px var(--brand-glow)}
.cm-box textarea{border:none!important;background:transparent!important;box-shadow:none!important;padding:14px 16px;resize:none;min-height:72px;font-size:14px;line-height:1.6}
.cm-box textarea:focus{outline:none;box-shadow:none}
.cm-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--s2);border-top:1px solid var(--b1)}

/* ── Links ── */
.lnk-item{
  display:flex;align-items:center;gap:10px;padding:10px 14px;
  background:var(--s2);border:1.5px solid var(--b1);border-radius:8px;margin-bottom:8px;
}
.lnk-type{font-size:11px;font-weight:700;color:var(--t3);min-width:96px;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.5px}
.lnk-key{font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--brand-lt);font-weight:600;cursor:pointer}
.lnk-key:hover{text-decoration:underline}

/* ── Files ── */
.fdrop{
  border:2px dashed var(--b2);border-radius:10px;padding:20px;text-align:center;
  cursor:pointer;color:var(--t3);font-size:13.5px;transition:all .15s;
}
.fdrop:hover,.fdrop.drag{border-color:var(--brand-lt);color:var(--brand-lt);background:var(--active-bg)}
.fgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-top:10px}
.fc{background:var(--s2);border:1.5px solid var(--b1);border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .12s}
.fc:hover{border-color:var(--b3)}
.fc .fth{width:100%;height:84px;object-fit:cover;display:block}
.fc .fic{height:84px;display:flex;align-items:center;justify-content:center;background:var(--s3);font-family:'JetBrains Mono',monospace;font-size:18px;font-weight:700;color:var(--t3)}
.fc .fi{padding:8px 10px;display:flex;align-items:center;gap:6px}
.fc .fn{flex:1;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--t2)}
.fc .fdel{width:18px;height:18px;border-radius:4px;display:grid;place-items:center;color:var(--t3);flex:none}
.fc .fdel:hover{background:var(--red-bg);color:var(--red)}

/* ── Sub-tasks ── */
.si{
  display:flex;align-items:center;gap:10px;padding:10px 14px;
  background:var(--s2);border:1.5px solid var(--b1);border-radius:8px;
  margin-bottom:8px;cursor:pointer;transition:border-color .12s;
}
.si:hover{border-color:var(--b2)}
.si .st{flex:1;font-size:13.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── History ── */
.hist{position:relative;padding-left:24px}
.hist::before{content:"";position:absolute;left:8px;top:10px;bottom:10px;border-left:2px solid var(--b1)}
.hr2{position:relative;padding:0 0 18px}
.hr2::before{content:"";position:absolute;left:-21px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--bg2);border:2.5px solid var(--brand-lt)}
.hr2 .ht{font-size:13.5px;line-height:1.45}
.hr2 .hch{display:flex;align-items:center;gap:8px;margin-top:4px;font-size:12.5px;flex-wrap:wrap;color:var(--t3)}
.hr2 .hold{text-decoration:line-through}
.hr2 .hnew{color:var(--t2);font-weight:500}
.hr2 .hwhen{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--t3);margin-top:4px}

/* ── Time entries ── */
.te{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border:1.5px solid var(--b1);border-radius:10px;margin-bottom:8px;background:var(--s2)}
.te .th{font-family:'JetBrains Mono',monospace;font-weight:700;color:var(--brand-lt);min-width:44px;font-size:14px}
.te .tb{flex:1;min-width:0}
.te .tb b{font-size:13.5px}
.te .tb p{font-size:12.5px;color:var(--t2);margin-top:3px}
.te .td{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--t3);white-space:nowrap}

/* ── Notifications panel ── */
.npanel{
  position:fixed;top:62px;right:16px;width:360px;max-height:520px;
  background:var(--modal-bg);border:1.5px solid var(--b1);border-radius:12px;
  box-shadow:var(--shadow-lg);z-index:55;display:flex;flex-direction:column;overflow:hidden;
}
.np-hd{padding:14px 18px;border-bottom:1.5px solid var(--b1);display:flex;justify-content:space-between;align-items:center}
.np-hd h3{font-size:14.5px;font-weight:700}
.np-list{overflow-y:auto;flex:1}
.np-item{display:flex;gap:12px;padding:13px 16px;border-bottom:1px solid var(--b1);cursor:pointer;transition:background .1s}
.np-item:hover{background:var(--hover-bg)}
.np-item.unread{background:var(--active-bg)}
.np-dot{width:8px;height:8px;border-radius:50%;background:var(--brand-lt);flex:none;margin-top:5px}
.np-body .np-title{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}
.np-body .np-text{font-size:12px;color:var(--t2);margin-top:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.np-body .np-when{font-size:10.5px;color:var(--t3);margin-top:4px;font-family:'JetBrains Mono',monospace}

/* ── Timesheet ── */
.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;margin-bottom:24px}
.day-card{background:var(--bg2);border:1.5px solid var(--b1);border-radius:10px;padding:14px;min-height:120px;display:flex;flex-direction:column}
.day-card.today{border-color:var(--brand-lt);box-shadow:0 0 0 1px var(--brand-lt)}
.day-card.today .dc-day{color:var(--brand-lt)}
.dc-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.dc-day{font-size:12px;font-weight:700}
.dc-date{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--t3)}
.dc-hrs{font-family:'JetBrains Mono',monospace;font-size:26px;font-weight:800;line-height:1;margin-bottom:6px;color:var(--t1)}
.dc-hrs small{font-size:13px;font-weight:400;color:var(--t3)}
.pill{font-size:10.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;border-radius:99px;padding:3px 10px;align-self:flex-start}
.pill-ok  {background:var(--green-bg);color:var(--green)}
.pill-pend{background:var(--red-bg);color:var(--red)}
.pill-off {background:var(--s3);color:var(--t3)}

/* ── Panels ── */
.pc2{background:var(--bg2);border:1.5px solid var(--b1);border-radius:12px;padding:24px;margin-bottom:16px}
.pc2 h3{font-size:15px;font-weight:700;margin-bottom:16px;letter-spacing:-.2px}
.pc2 p.hint{font-size:13px;color:var(--t3);margin-bottom:16px;line-height:1.6}

/* ── Members ── */
.mr{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1.5px solid var(--b1)}
.mr:last-child{border-bottom:none}
.mr-info{flex:1;min-width:0}
.mr-info b{display:block;font-size:13.5px;font-weight:600}
.mr-info span{font-size:12px;color:var(--t3)}

/* ── Profile ── */
.av-upload{position:relative;width:80px;height:80px;cursor:pointer;margin-bottom:20px}
.av-upload .av{width:80px;height:80px;font-size:28px;border-width:2px}
.av-ov{position:absolute;inset:0;border-radius:50%;background:rgba(0,0,0,.55);display:none;place-items:center;color:#fff;font-size:11px;font-weight:600;text-align:center;line-height:1.3}
.av-upload:hover .av-ov{display:grid}

/* ── Modal ── */
.scrim{position:fixed;inset:0;background:var(--scrim-bg);display:none;place-items:center;z-index:60;backdrop-filter:blur(4px)}
.scrim.on{display:grid}
.modal{
  background:var(--modal-bg);border:1.5px solid var(--b1);border-radius:20px;
  box-shadow:var(--shadow-lg);width:520px;max-width:96vw;
  max-height:92dvh;overflow-y:auto;padding:28px;
}
.modal h3{font-size:17px;font-weight:700;margin-bottom:20px;letter-spacing:-.3px}
.modal-ft{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:18px;border-top:1.5px solid var(--b1)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.four{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:14px}

/* ── Toast ── */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translate(-50%,90px);
  background:var(--modal-bg);border:1.5px solid var(--b2);color:var(--t1);
  font-size:13.5px;padding:12px 22px;border-radius:10px;
  transition:transform .2s cubic-bezier(.4,0,.2,1);z-index:70;max-width:94vw;
  display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-md);
  backdrop-filter:blur(8px);
}
.toast.show{transform:translate(-50%,0)}
.toast.ok{border-color:var(--brand-bd);background:var(--bg2)}
.toast.err{border-color:var(--red-bd);color:var(--red)}

/* ── Dividers / helpers ── */
.divider{border:none;border-top:1.5px solid var(--b1);margin:14px 0}
.inv-link{display:flex;gap:8px;margin-top:10px}
.inv-link input{flex:1;font-family:'JetBrains Mono',monospace;font-size:12px}

/* ── Responsive ── */
@media(max-width:900px){
  :root{--drawer:100vw}
  .app{grid-template-columns:1fr}
  .mobile-bar{display:flex}
  .side{position:fixed;top:0;left:0;bottom:0;width:270px;transform:translateX(-110%);transition:transform .22s ease;box-shadow:var(--shadow-lg)}
  .side.open{transform:none}
  .side-scrim.show{display:block}
  .dl{grid-template-columns:1fr}
  .dl-right{border-left:none;border-top:1.5px solid var(--b1)}
  .week-grid{grid-template-columns:repeat(2,1fr)}
  .board{grid-auto-columns:88vw}
  .npanel{left:12px;right:12px;width:auto;top:66px}
  .g-uname{display:none}
  .g-profile-menu{right:8px}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  table{min-width:760px}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{transition:none!important;animation:none!important}}

/* ── Dashboard ── */
.dash-page{padding:0;display:flex;flex-direction:column;gap:20px}
.dash-fbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.dash-stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.dash-stat{
  background:var(--s1);border:1.5px solid var(--b1);border-radius:12px;
  padding:16px 18px;display:flex;flex-direction:column;gap:3px;
  box-shadow:var(--shadow-xs);
}
.dash-stat-val{font-size:28px;font-weight:800;color:var(--t1);line-height:1.1}
.dash-stat-lbl{font-size:11.5px;color:var(--t3);font-weight:500}
.dash-stat.sea .dash-stat-val{color:var(--brand)}
.dash-stat.blue .dash-stat-val{color:var(--blue)}
.dash-stat.amber .dash-stat-val{color:var(--amber)}
.dash-stat.red .dash-stat-val{color:var(--red)}

.dash-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start}
.dash-widget{background:var(--s1);border:1.5px solid var(--b1);border-radius:14px;box-shadow:var(--shadow-xs);overflow:hidden}
.dash-widget.w-md{grid-column:span 2}
.dash-widget.w-lg{grid-column:span 3}
.dash-widget-hdr{
  padding:12px 14px;border-bottom:1.5px solid var(--b1);
  display:flex;align-items:center;gap:8px;background:var(--s3);
}
.dash-widget-title{font-weight:600;font-size:13px;flex:1;color:var(--t1)}
.dash-widget-rm{opacity:0;transition:opacity .15s}
.dash-widget:hover .dash-widget-rm{opacity:.5}
.dash-widget-rm:hover{opacity:1!important}
.dash-widget-body{padding:16px}

/* Donut */
.dash-chart-inner{display:flex;align-items:flex-start;gap:16px}
.dash-legend{display:flex;flex-direction:column;gap:7px;flex:1;min-width:0;justify-content:center}
.dash-leg-row{display:flex;align-items:center;gap:7px;font-size:12px;min-width:0}
.dash-leg-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.dash-leg-lbl{flex:1;color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-leg-val{font-weight:700;color:var(--t1);font-size:12px;flex-shrink:0}

/* Horizontal bar */
.dash-bars{display:flex;flex-direction:column;gap:9px}
.dash-bar-row{display:grid;grid-template-columns:88px 1fr 34px;align-items:center;gap:8px;font-size:12px}
.dash-bar-lbl{color:var(--t2);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-bar-track{height:18px;background:var(--s3);border-radius:5px;overflow:hidden}
.dash-bar-fill{height:100%;border-radius:5px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.dash-bar-num{font-weight:700;color:var(--t1);text-align:right}

/* Line trend */
.dash-leg-inline{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--t3);margin-top:6px}

/* Sprint progress */
.dash-sprint-bars{display:flex;flex-direction:column;gap:14px}
.sp-bar-row{display:flex;flex-direction:column;gap:5px}
.sp-bar-top{display:flex;align-items:center;gap:8px;font-size:12px}
.sp-name{font-weight:600;color:var(--t1);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sp-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;text-transform:capitalize;background:var(--s3);color:var(--t3)}
.sp-badge.active{background:var(--brand-bg);color:var(--brand)}
.sp-badge.done{background:var(--green-bg);color:var(--green)}
.sp-pct{font-weight:700;color:var(--t1);font-size:12px;margin-left:auto}
.sp-track{height:8px;background:var(--s3);border-radius:4px;overflow:hidden}
.sp-fill{height:100%;background:var(--b2);border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.sp-fill.active{background:var(--brand)}
.sp-fill.done{background:var(--green)}
.sp-nums{font-size:11px;color:var(--t3)}

/* Widget tag & custom filter bar */
.dash-widget-tag{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--brand);background:var(--brand-bg);border-radius:4px;padding:2px 6px}
.cw-filter-bar{display:flex;gap:6px;flex-wrap:wrap;padding:6px 14px;border-bottom:1px solid var(--b1);background:var(--s2)}
.cw-filter-tag{font-size:11px;font-weight:600;color:var(--t2);background:var(--s3);border:1px solid var(--b1);border-radius:5px;padding:2px 8px}
.dash-loading-sm{padding:24px;text-align:center;color:var(--t3);font-size:13px}

/* Add widget modal — tabs */
.dash-add-tabs{display:flex;gap:0;border-bottom:1.5px solid var(--b1);margin-bottom:16px}
.dash-add-tab{padding:9px 18px;font-size:13px;font-weight:600;color:var(--t3);border-bottom:2.5px solid transparent;margin-bottom:-1.5px;transition:all .12s;white-space:nowrap}
.dash-add-tab:hover{color:var(--t2)}
.dash-add-tab.on{color:var(--brand-lt);border-color:var(--brand-lt)}
.dash-add-panel{min-height:10px}

/* Preset grid */
.dash-pick-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:8px}
.dash-pick-btn{
  background:var(--s2);border:1.5px solid var(--b1);border-radius:10px;
  padding:13px 14px;text-align:left;cursor:pointer;transition:border-color .15s,background .15s;
  display:flex;align-items:center;gap:8px;
}
.dash-pick-btn:hover:not(.on){border-color:var(--brand);background:var(--brand-bg)}
.dash-pick-btn.on{opacity:.5;cursor:default}
.dash-pick-lbl{font-size:13px;font-weight:600;color:var(--t1);flex:1}
.dash-pick-added{font-size:10px;color:var(--brand);font-weight:600;white-space:nowrap}

/* Custom widget form */
.cw-form{display:flex;flex-direction:column;gap:14px}
.cw-row{display:flex;flex-direction:column;gap:5px}
.cw-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cw-divider{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);padding:4px 0;border-top:1.5px solid var(--b1);margin-top:2px}
.cw-divider span{font-weight:400;text-transform:none;letter-spacing:0;font-size:11px}

/* Empty / loading */
.chart-empty{padding:36px 16px;text-align:center;color:var(--t3);font-size:13px}
.dash-loading{padding:56px;text-align:center;color:var(--t3);font-size:14px}

/* ── Excel import drop zone ── */
.dz{border:2px dashed var(--b1);border-radius:12px;padding:28px 16px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;position:relative}
.dz:hover,.dz.dz-over{border-color:var(--brand);background:var(--brand-bg)}
.dz p{margin:10px 0 4px;font-size:14px;font-weight:600;color:var(--t2)}
.dz small{font-size:12px;color:var(--t3)}
.dz-file{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--s2);border:1.5px solid var(--b1);border-radius:9px;margin-top:12px;font-size:13px;font-weight:500;color:var(--t1)}
.dz-file svg{flex:none;color:var(--brand)}
.import-results{display:flex;flex-direction:column;gap:4px;max-height:240px;overflow-y:auto;margin-top:12px}
.import-row{font-size:12.5px;padding:4px 0;border-bottom:1px solid var(--b1);display:flex;gap:8px;align-items:baseline}
.import-row-ok{color:var(--green)}
.import-row-err{color:var(--red)}
.import-summary{display:flex;gap:16px;margin-bottom:8px}
.import-sum-ok{font-size:14px;font-weight:700;color:var(--green)}
.import-sum-err{font-size:14px;font-weight:700;color:var(--red)}

@media(max-width:1100px){.dash-grid{grid-template-columns:repeat(2,1fr)}.dash-widget.w-lg{grid-column:span 2}}
@media(max-width:900px){
  .dash-stats-row{grid-template-columns:repeat(2,1fr)}
  .dash-grid{grid-template-columns:1fr}
  .dash-widget.w-md,.dash-widget.w-lg{grid-column:span 1}
}
