:root{
  --bg:#0D0F0E;
  --surface:#15191A;
  --raised:#1C2120;
  --line:rgba(255,255,255,.08);
  --line-soft:rgba(255,255,255,.05);
  --text:#ECF1EE;
  --muted:#8A938C;
  --green:#7AC4A1;
  --green-bright:#93E0B8;
  --green-strong:#7AC4A1;        /* green used for TEXT; deepens in light mode */
  --green-dim:rgba(122,196,161,.16);
  --red:#E07A82;
  --panel-solid:rgba(255,255,255,.04);   /* text backing on solid cards */
  --chev-bg:rgba(255,255,255,.1);
  --shadow-card:0 20px 40px -22px rgba(0,0,0,.9);
  --r-card:22px;
  --r-drop:18px;
  --face-h:276px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- LIGHT THEME ---------- */
html[data-theme="light"]{
  --bg:#F3F6F4;
  --surface:#FFFFFF;
  --raised:#FFFFFF;
  --line:rgba(20,30,24,.10);
  --line-soft:rgba(20,30,24,.06);
  --text:#16201B;
  --muted:#5C665E;
  --green-strong:#2F9268;
  --green-dim:rgba(122,196,161,.20);
  --red:#D2545E;
  --panel-solid:rgba(20,30,24,.04);
  --chev-bg:rgba(20,30,24,.07);
  --shadow-card:0 18px 36px -24px rgba(20,40,30,.4);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}

/* ---------- LOADING SCREEN ---------- */
.loader{
  position:fixed;inset:0;z-index:200;display:grid;place-items:center;
  background:var(--bg);transition:opacity .3s var(--ease);
}
.loader.hide{opacity:0;pointer-events:none}
.loader-mark{width:104px;height:104px;animation:loaderPulse .65s var(--ease) infinite}
.loader-mark rect{fill:var(--green)}
@keyframes loaderPulse{0%,100%{transform:scale(1);opacity:.88}50%{transform:scale(1.07);opacity:1}}
html{scrollbar-gutter:stable both-edges}
body{
  font-family:"Outfit",system-ui,sans-serif;
  background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:hidden;
  transition:background .3s var(--ease),color .3s var(--ease);
}
button{font-family:inherit;cursor:pointer;color:inherit;background:none;border:none}
a{color:inherit;text-decoration:none}
img{display:block}

.bg-grid{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(140% 110% at 70% 0%,#000 0%,transparent 88%);
  mask-image:radial-gradient(140% 110% at 70% 0%,#000 0%,transparent 88%);
  opacity:1;
}


/* ---------- TOPBAR ---------- */
.topbar{
  position:sticky;top:0;z-index:50;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:16px 26px;background:var(--bg);
  transition:background .3s var(--ease);
}
.topbar-fade{
  position:sticky;top:68px;z-index:40;height:26px;margin-bottom:-26px;
  background:linear-gradient(var(--bg),transparent);pointer-events:none;
}
.bar-left{justify-self:start}
.bar-right{justify-self:end;display:flex;align-items:center;gap:10px}

.brand{justify-self:center;display:flex;align-items:center;gap:11px}
.logo-mark{display:block;width:28px;height:28px;flex:none}
.logo-mark rect{fill:var(--green)}
.brand-word{font-size:20px;font-weight:500;letter-spacing:-.01em}
.brand-word b{font-weight:700}

.nav-item{position:relative}
.bar-trigger{
  display:flex;align-items:center;gap:8px;font-size:14.5px;color:var(--muted);
  padding:9px 13px;border-radius:12px;transition:color .18s,background .18s;
}
.bar-trigger .caret{opacity:.7}
.nav-item:hover .bar-trigger{color:var(--text);background:rgba(127,127,127,.1)}

.dropdown{
  position:absolute;top:calc(100% + 10px);left:0;min-width:248px;
  background:var(--raised);border:1px solid var(--line);border-radius:var(--r-drop);
  padding:8px;box-shadow:0 18px 50px -12px rgba(0,0,0,.55),0 0 0 1px rgba(122,196,161,.05);
  opacity:0;visibility:hidden;transform-origin:top left;pointer-events:none;
}
.dropdown.right{left:auto;right:0;transform-origin:top right;min-width:212px}
.dropdown::before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px}
.dropdown a{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:10px 12px;border-radius:11px;font-size:14.5px;color:var(--muted);
  transition:background .15s,color .15s;
}
.dropdown a:hover{background:rgba(127,127,127,.1);color:var(--text)}
.dropdown a em{font-family:"JetBrains Mono",monospace;font-size:11px;font-style:normal;opacity:.7;color:var(--green-strong)}
.dropdown a em.late{color:var(--red)}
.dropdown a.danger:hover{color:var(--red)}

.drop-head{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 10px;margin-bottom:4px;border-bottom:1px solid var(--line-soft)}
.drop-head strong{font-size:13px;font-weight:600;letter-spacing:.01em}
.later-badge{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;color:var(--green-strong);background:var(--green-dim);padding:3px 8px;border-radius:999px}
.drop-note{font-size:12px;color:var(--muted);line-height:1.45;padding:10px 12px 6px;margin-top:4px;border-top:1px solid var(--line-soft);opacity:.85}
.drop-hint{font-size:12px;line-height:1.5;color:var(--muted);padding:8px 12px 2px;opacity:.85}
.drop-hint:last-child{padding-bottom:8px}

.acct-head{padding:10px 12px 12px;border-bottom:1px solid var(--line-soft);margin-bottom:6px}
.acct-head strong{display:block;font-weight:600;font-size:14.5px}
.acct-head span{font-size:12.5px;color:var(--muted)}

.icon-btn{
  width:40px;height:40px;border-radius:12px;display:grid;place-items:center;
  color:var(--muted);transition:color .18s,background .18s;
}
.icon-btn:hover{color:var(--text);background:rgba(127,127,127,.1)}
.theme-toggle .ico-moon{display:none}
html[data-theme="light"] .theme-toggle .ico-sun{display:none}
html[data-theme="light"] .theme-toggle .ico-moon{display:block}

.avatar-btn img{width:38px;height:38px;border-radius:50%;object-fit:cover;border:1.5px solid var(--line)}
.avatar-btn:hover img{border-color:var(--green)}

/* ---------- BOARD ---------- */
.board-wrap{position:relative;z-index:1;max-width:1664px;margin:0 auto;padding:14px 30px 120px}
.board-head{margin:14px 4px 26px}
.board-head h1{font-size:30px;font-weight:600;letter-spacing:-.02em}
.board-head .sub{color:var(--muted);font-size:15px;margin-top:4px}
.board{display:flex;gap:20px;align-items:flex-start}
.col{flex:1;min-width:0;display:flex;flex-direction:column;gap:20px}

/* ---------- CARD ---------- */
.card{
  border-radius:var(--r-card);overflow:hidden;
  background:var(--surface);border:1px solid var(--line);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);
}
.card.is-open{border-color:rgba(122,196,161,.35);box-shadow:var(--shadow-card),0 0 0 1px rgba(122,196,161,.18)}

.card-face{
  position:relative;height:var(--face-h);padding:19px;
  display:flex;flex-direction:column;justify-content:flex-end;
  background-size:cover;background-position:center;cursor:pointer;
}
.card-face.solid{
  background-image:
    radial-gradient(110% 80% at 85% 0%,rgba(122,196,161,.13),transparent 60%),
    linear-gradient(180deg,var(--surface),var(--surface));
}
.card-face::after{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,rgba(8,10,9,.04) 35%,rgba(8,10,9,.55) 100%);}
.card-face.solid::after{display:none}
.card-face>*{position:relative;z-index:1}

/* eyebrow as small backed pill */
.eyebrow{
  align-self:flex-start;margin-bottom:auto;
  font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.07em;
  text-transform:uppercase;color:var(--green-strong);
  padding:4px 9px;border-radius:999px;background:var(--panel-solid);
}
.card-face:not(.solid) .eyebrow{
  color:var(--green-bright);background:rgba(8,10,9,.4);
  backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);
}
.eyebrow.complete{color:var(--red);background:rgba(224,122,130,.16)}
.card-face:not(.solid) .eyebrow.complete{color:#FF9AA1;background:rgba(8,10,9,.4)}

/* small shaded box hugging ONLY the name + client text */
.text-box{align-self:flex-start;max-width:100%;border-radius:12px;padding:8px 11px}
.card-face:not(.solid) .text-box{
  background:rgba(8,10,9,.44);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.07);
}
.card-face.solid .text-box{background:transparent;padding:0}

.card-name{font-size:23px;font-weight:600;letter-spacing:-.015em;line-height:1.2;color:var(--text)}
.card-client{font-size:14px;color:var(--muted);margin-top:3px}
.card-face:not(.solid) .card-name{color:#fff}
.card-face:not(.solid) .card-client{color:rgba(255,255,255,.74)}

.face-foot{display:flex;align-items:center;gap:14px;margin-top:13px}
.avatars{display:flex}
.avatars img,.avatars .more{width:44px;height:44px;border-radius:50%;object-fit:cover;border:3px solid var(--bg);box-shadow:0 0 0 1px var(--line);margin-left:-13px}
.avatars img:first-child,.avatars .more:first-child{margin-left:0}
.card-face:not(.solid) .avatars img,.card-face:not(.solid) .avatars .more{border-color:rgba(8,10,9,.7);box-shadow:0 0 0 1px rgba(255,255,255,.18)}
.avatars .more{display:grid;place-items:center;background:#2A312E;color:#fff;font-family:"JetBrains Mono",monospace;font-size:13px}
.chev{margin-left:auto;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;color:var(--text);background:var(--chev-bg);transition:transform .35s var(--ease),background .2s}
.card-face:not(.solid) .chev{background:rgba(255,255,255,.16);color:#fff}
.card.is-open .chev{transform:rotate(180deg)}

.progress{margin-top:12px}
.progress-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:7px}
.progress-top .count{font-family:"JetBrains Mono",monospace;font-size:12px;font-weight:500;color:var(--text)}
.progress-top .pct{font-family:"JetBrains Mono",monospace;font-size:12px;font-weight:500;color:var(--green-strong)}
.card-face:not(.solid) .progress-top .count{color:rgba(255,255,255,.82)}
.card-face:not(.solid) .progress-top .pct{color:var(--green-bright)}
.card-face:not(.solid) .progress-top span{text-shadow:0 1px 3px rgba(0,0,0,.55)}
.bar{height:6px;border-radius:999px;background:rgba(127,127,127,.24);overflow:hidden}
.card-face:not(.solid) .bar{background:rgba(255,255,255,.3)}
.bar-fill{height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--green-bright));box-shadow:0 0 8px -1px rgba(122,196,161,.5);transition:width .7s var(--ease)}

/* ---------- DETAIL ---------- */
.card-detail{display:grid;grid-template-rows:0fr;transition:grid-template-rows .45s var(--ease);background:var(--raised)}
.card.is-open .card-detail{grid-template-rows:1fr}
.detail-inner{overflow:hidden}
.detail-pad{padding:16px 18px 18px;border-top:1px solid var(--line-soft)}
.checklist{display:flex;flex-direction:column}
.task{display:flex;align-items:center;gap:12px;padding:10px 6px;border-bottom:1px solid var(--line-soft)}
.task:last-child{border-bottom:none}
.dot{flex:none;width:17px;height:17px;border-radius:50%;border:2px solid var(--red);background:transparent;transition:.2s var(--ease);position:relative}
.task.done .dot{background:var(--green-bright);border-color:var(--green-bright);box-shadow:0 0 10px -1px var(--green-dim)}
.task.done .dot::after{content:"";position:absolute;inset:0;margin:auto;width:7px;height:4px;border-left:2px solid #0A1410;border-bottom:2px solid #0A1410;transform:translateY(-1px) rotate(-45deg)}
.task-title{flex:1;font-size:14.5px;transition:.2s}
.task.done .task-title{text-decoration:line-through;color:var(--muted)}
.assignee{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:12.5px;flex:none}
.assignee img{width:22px;height:22px;border-radius:50%;object-fit:cover}

.add-row{display:none;gap:8px;margin-top:14px;align-items:center}
.card.editing .add-row{display:flex}
.add-input{flex:1;background:rgba(127,127,127,.08);border:1px solid var(--line);border-radius:11px;padding:9px 13px;color:var(--text);font-size:14px}
.add-input::placeholder{color:var(--muted)}
.add-input:focus{outline:none;border-color:rgba(122,196,161,.45)}
.add-assignee{background:rgba(127,127,127,.08);border:1px solid var(--line);border-radius:11px;padding:9px 10px;color:var(--text);font-size:13px;max-width:130px}
.add-btn{background:var(--green-dim);color:var(--green-strong);font-weight:600;font-size:14px;padding:9px 15px;border-radius:11px;border:1px solid rgba(122,196,161,.3);transition:.18s}
.add-btn:hover{background:var(--green);color:#0A1410}

/* ---------- EDIT MODE ---------- */
.edit-btn{
  position:absolute;top:14px;right:14px;z-index:2;
  width:34px;height:34px;border-radius:10px;display:grid;place-items:center;
  color:var(--text);background:var(--chev-bg);
  transition:color .18s,background .18s;
}
.card-face:not(.solid) .edit-btn{background:rgba(8,10,9,.42);color:#fff;backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px)}
.card.editing .edit-btn{background:var(--green);color:#0A1410}

/* archive stub, always visible, sits left of the edit button */
.archive-btn{
  position:absolute;top:14px;right:56px;z-index:2;
  width:34px;height:34px;border-radius:10px;display:grid;place-items:center;
  color:var(--text);background:var(--chev-bg);transition:color .18s,background .18s;
}
.card-face:not(.solid) .archive-btn{background:rgba(8,10,9,.42);color:#fff;backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px)}

/* open project page stub, always visible, sits left of the archive button */
.open-btn{
  position:absolute;top:14px;right:98px;z-index:2;
  width:34px;height:34px;border-radius:10px;display:grid;place-items:center;
  color:var(--text);background:var(--chev-bg);transition:color .18s,background .18s;
}
.card-face:not(.solid) .open-btn{background:rgba(8,10,9,.42);color:#fff;backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px)}

/* red delete stub, sits left of the open button, only while editing */
.del-btn{
  position:absolute;top:14px;right:140px;z-index:2;
  width:34px;height:34px;border-radius:10px;display:none;place-items:center;
  color:var(--red);background:var(--chev-bg);transition:color .18s,background .18s;
}
.card.editing .del-btn{display:grid}
.card-face:not(.solid) .del-btn{background:rgba(8,10,9,.42);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px)}

/* editable title + client while in edit mode */
.card-name[contenteditable="true"],.card-client[contenteditable="true"]{
  outline:1.5px dashed rgba(122,196,161,.55);outline-offset:3px;border-radius:5px;cursor:text;
}

/* whole milestone row is clickable to toggle (outside edit mode) */
.card:not(.editing) .task{cursor:pointer;border-radius:8px;transition:background .15s}
.card:not(.editing) .task:hover{background:rgba(127,127,127,.07)}

/* background image upload (visual stub) */
.edit-img-row{display:none}
.card.editing .edit-img-row{
  display:flex;flex-direction:column;gap:7px;margin-bottom:14px;padding-bottom:14px;
  border-bottom:1px solid var(--line-soft);
}
.edit-img-row>span:first-child{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.04em;color:var(--muted);text-transform:uppercase}
.upload-btn{
  align-self:flex-start;display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  background:rgba(127,127,127,.08);border:1px dashed var(--line);border-radius:11px;
  padding:10px 16px;color:var(--text);font-size:14px;transition:.18s;
}
.upload-btn:hover{border-color:rgba(122,196,161,.5);color:var(--green-strong)}

/* editable milestone rows */
.task-edit{flex:1;min-width:0;background:rgba(127,127,127,.08);border:1px solid var(--line);border-radius:9px;padding:7px 10px;color:var(--text);font-size:14px;font-family:inherit}
.task-edit:focus{outline:none;border-color:rgba(122,196,161,.45)}
.task-who{flex:none;background:rgba(127,127,127,.08);border:1px solid var(--line);border-radius:9px;padding:7px 9px;color:var(--text);font-size:13px;font-family:inherit;max-width:120px}
.task-who:focus{outline:none;border-color:rgba(122,196,161,.45)}
.task-del{flex:none;width:28px;height:28px;border-radius:8px;display:grid;place-items:center;color:var(--muted);font-size:19px;line-height:1;transition:.15s}
.task-del:hover{background:rgba(127,127,127,.12);color:var(--red)}

/* native select popups: force opaque, legible options (was see-through) */
.task-who,.add-assignee{background-color:var(--raised)}
.task-who option,.add-assignee option{background:var(--raised);color:var(--text)}

/* ---------- FLOATING NEW PROJECT ---------- */
.fab{
  position:fixed;right:30px;bottom:28px;z-index:60;
  display:inline-flex;align-items:center;gap:10px;
  font-size:16px;font-weight:600;color:#0A1410;
  background:var(--green);padding:16px 24px;border-radius:999px;
  box-shadow:0 14px 34px -10px rgba(122,196,161,.5),0 4px 12px rgba(0,0,0,.3);
  transition:.22s var(--ease);
}
.fab:hover{background:var(--green-bright);transform:translateY(-2px);box-shadow:0 20px 44px -10px rgba(122,196,161,.6),0 6px 16px rgba(0,0,0,.35)}
.fab:active{transform:translateY(0)}

.card{opacity:0}

@media(max-width:980px){
  .board{flex-direction:column}.col{width:100%}
  .bar-trigger span{display:none}
}
@media(max-width:560px){
  .topbar{padding:14px 16px}
  .board-wrap{padding:14px 16px 110px}
  .fab{right:16px;bottom:18px;padding:14px 20px;font-size:15px}
  .bar-trigger{padding:9px}
}
@media(prefers-reduced-motion:reduce){*{transition-duration:.001ms !important;animation-duration:.001ms !important}}

/* press feedback that works on touch and never sticks (unlike :hover) */
.edit-btn:active,.archive-btn:active,.open-btn:active{background:var(--green);color:#0A1410;transform:scale(.92)}
.del-btn:active{background:var(--red);color:#fff;transform:scale(.92)}

/* make "edit mode is on" obvious on touch (where there's no hover cue) */
.card.editing .edit-btn{box-shadow:0 0 0 2px var(--green-dim)}

/* hover effects only on devices with a real pointer, so they never stick on touch */
@media(hover:hover){
  .card:hover{transform:translateY(-6px);border-color:rgba(122,196,161,.4);box-shadow:var(--shadow-card),0 0 0 1px rgba(122,196,161,.18),0 18px 40px -20px rgba(122,196,161,.35)}
  .edit-btn:hover,.archive-btn:hover,.open-btn:hover,
  .card-face:not(.solid) .edit-btn:hover,.card-face:not(.solid) .archive-btn:hover,.card-face:not(.solid) .open-btn:hover{background:var(--green);color:#0A1410}
  .del-btn:hover,.card-face:not(.solid) .del-btn:hover{background:var(--red);color:#fff}
}
