/* ===========================================================
   WEBSDADY x HDS — To-Do App
   Palette: ink #16161F · slate #2A2A38 · champagne #C9A24B /
   #E8C77E · cream #FBF8F3 · paper #FFFFFF
   Type: Fraunces (display) + Inter (body/ui)
   =========================================================== */
:root{
  --ink:#16161F; --slate:#2A2A38; --gold:#C9A24B; --gold-lt:#E8C77E;
  --cream:#FBF8F3; --paper:#FFFFFF; --line:#E7E2D8; --line-soft:#F0EBE1;
  --text:#24242C; --muted:#7C776C; --faint:#A9A297;
  --hi-bg:#F6D3CF; --hi-fg:#A32C22;
  --md-bg:#FBEBC6; --md-fg:#8A6412;
  --lo-bg:#DCE8F3; --lo-fg:#2C5A82;
  --todo-bg:#ECECF1; --todo-fg:#55555F;
  --prog-bg:#FBE6BE; --prog-fg:#8A5A00;
  --done-bg:#CFE8CF; --done-fg:#256B2E;
  --shadow:0 1px 2px rgba(20,20,30,.05), 0 8px 24px rgba(20,20,30,.06);
  --radius:14px;
  /* Recolors the black logo — tweak hue/saturation for a different tint */
  --brand-logo-filter:brightness(0) saturate(100%) invert(88%) sepia(18%) saturate(800%) hue-rotate(358deg) brightness(103%) contrast(89%);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--text); background:var(--cream); line-height:1.45;
}
button,input,select,textarea{font-family:inherit;font-size:100%}
::selection{background:var(--gold-lt);color:var(--ink)}

/* ---------- Top bar ---------- */
.topbar{
  background:linear-gradient(160deg,#1b1b26 0%, var(--ink) 60%);
  color:#fff; padding:18px clamp(16px,4vw,40px);
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
  border-bottom:3px solid var(--gold);
}
.brand{display:flex;flex-direction:column;gap:6px;min-width:0}
.brand-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.brand-logo{
  display:block;height:clamp(26px,4.2vw,36px);width:auto;max-width:min(220px,52vw);
  object-fit:contain;object-position:left center;filter:var(--brand-logo-filter);
}
.brand-partner{
  font-family:"Fraunces",Georgia,serif;font-weight:600;letter-spacing:.08em;
  font-size:clamp(15px,2.6vw,22px);color:var(--gold);white-space:nowrap;line-height:1;
}
.tagline{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#B9B2A2}

.kpis{display:flex;gap:10px}
.kpi{
  background:rgba(255,255,255,.06); border:1px solid rgba(232,199,126,.18);
  border-radius:12px; padding:8px 16px; min-width:78px; text-align:center;
}
.kpi-num{display:block;font-family:"Fraunces",serif;font-weight:600;font-size:22px;color:var(--gold-lt);line-height:1}
.kpi-label{display:block;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#B9B2A2;margin-top:4px}

/* ---------- Progress ---------- */
.progress-wrap{
  background:var(--slate); color:#fff; padding:9px clamp(16px,4vw,40px);
  display:flex;align-items:center;gap:16px;
}
.progress-bar{flex:1;height:8px;background:rgba(255,255,255,.12);border-radius:99px;overflow:hidden}
.progress-bar span{
  display:block;height:100%;width:0;border-radius:99px;
  background:linear-gradient(90deg,var(--gold),var(--gold-lt));
  transition:width .6s cubic-bezier(.4,0,.2,1);
}
.progress-pct{font-size:12px;letter-spacing:.08em;color:var(--gold-lt);white-space:nowrap;min-width:96px;text-align:right}

/* ---------- Container / toolbar ---------- */
.container{max-width:1080px;margin:0 auto;padding:clamp(18px,3vw,32px) clamp(16px,4vw,32px) 80px}
.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:22px}
.spacer{flex:1}
.search{position:relative;flex:1;min-width:220px;max-width:420px}
.search .ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;
  fill:none;stroke:var(--faint);stroke-width:2;stroke-linecap:round}
.search input{width:100%;padding:11px 14px 11px 38px;border:1px solid var(--line);border-radius:11px;
  background:var(--paper);color:var(--text);outline:none;transition:border-color .15s, box-shadow .15s}
.search input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.16)}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.filters select{padding:10px 12px;border:1px solid var(--line);border-radius:11px;background:var(--paper);color:var(--text);cursor:pointer}
.filters select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.16)}

/* ---------- Buttons ---------- */
.btn{border:1px solid transparent;border-radius:11px;padding:11px 18px;font-weight:600;font-size:14px;cursor:pointer;
  transition:transform .08s ease, box-shadow .15s, background .15s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn.gold{background:var(--gold);color:#241c07;box-shadow:0 2px 10px rgba(201,162,75,.35)}
.btn.gold:hover{background:#d4af5c}
.btn.ghost{background:var(--paper);border-color:var(--line);color:var(--text)}
.btn.ghost:hover{border-color:var(--gold);color:#6b531a}
.btn.danger-ghost{background:transparent;border-color:#E7C7C3;color:#A32C22}
.btn.danger-ghost:hover{background:#FBEEEC}

/* ---------- Board ---------- */
.board{display:flex;flex-direction:column;gap:26px}
.loading{color:var(--muted);padding:40px;text-align:center}

.day-group{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.day-head{display:flex;align-items:baseline;gap:12px;padding:14px 20px;border-bottom:1px solid var(--line-soft);
  background:linear-gradient(0deg,#fff, #fdfbf7)}
.day-head .dnum{font-family:"Fraunces",serif;font-weight:600;font-size:17px;color:var(--ink)}
.day-head .dweek{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600}
.day-head .dcount{margin-left:auto;font-size:12px;color:var(--faint)}

/* Task row */
.task{display:grid;grid-template-columns:26px 1fr auto;gap:14px;align-items:start;
  padding:14px 20px;border-top:1px solid var(--line-soft);transition:background .15s}
.day-head + .task{border-top:none}
.task:hover{background:#FCFAF5}
.task.done .t-text{text-decoration:line-through;color:var(--faint)}
.check{margin-top:2px;width:20px;height:20px;border:2px solid var(--line);border-radius:50%;cursor:pointer;
  display:grid;place-items:center;transition:.15s;background:#fff}
.check:hover{border-color:var(--gold)}
.task.done .check{background:var(--done-fg);border-color:var(--done-fg)}
.check svg{width:12px;height:12px;stroke:#fff;stroke-width:3;fill:none;opacity:0;transition:.15s}
.task.done .check svg{opacity:1}

.t-main{min-width:0}
.t-text{font-size:15px;color:var(--text);word-wrap:break-word}
.t-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:8px}
.t-note{font-size:12.5px;color:var(--muted);margin-top:6px;font-style:italic}

.who{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.who .av{width:20px;height:20px;border-radius:50%;background:var(--slate);color:var(--gold-lt);
  display:grid;place-items:center;font-size:10px;font-weight:700}
.who.empty{color:var(--faint)}
.who.empty .av{background:#EDE8DE;color:#B4AD9F}

/* Badge selects */
.badge{border:none;border-radius:99px;padding:4px 12px;font-size:11px;font-weight:700;letter-spacing:.04em;
  cursor:pointer;-webkit-appearance:none;appearance:none;text-align:center}
.badge:focus{outline:2px solid var(--gold);outline-offset:1px}
.pri-High{background:var(--hi-bg);color:var(--hi-fg)}
.pri-Medium{background:var(--md-bg);color:var(--md-fg)}
.pri-Low{background:var(--lo-bg);color:var(--lo-fg)}
.st-ToDo{background:var(--todo-bg);color:var(--todo-fg)}
.st-InProgress{background:var(--prog-bg);color:var(--prog-fg)}
.st-Done{background:var(--done-bg);color:var(--done-fg)}

.t-actions{display:flex;gap:4px;align-items:center}
.icon-btn{background:none;border:none;cursor:pointer;color:var(--faint);border-radius:8px;padding:6px;
  display:grid;place-items:center;transition:.15s;line-height:0;font-size:18px}
.icon-btn:hover{background:#F1ECE2;color:var(--text)}
.icon-btn svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}
.empty-state h3{font-family:"Fraunces",serif;color:var(--ink);margin:0 0 6px;font-weight:600}

/* ---------- Modal ---------- */
.modal-backdrop{position:fixed;inset:0;background:rgba(22,22,31,.55);backdrop-filter:blur(3px);
  display:grid;place-items:center;padding:16px;z-index:50}
.modal-backdrop[hidden]{display:none}
.modal{background:var(--paper);border-radius:18px;width:min(560px,100%);box-shadow:0 24px 60px rgba(0,0,0,.35);
  overflow:hidden;animation:pop .18s ease}
@keyframes pop{from{transform:translateY(8px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;
  background:var(--ink);color:#fff}
.modal-head h2{margin:0;font-family:"Fraunces",serif;font-weight:600;font-size:19px;color:var(--gold-lt)}
.modal-head .icon-btn{color:#C9C3B6}
.modal-head .icon-btn:hover{background:rgba(255,255,255,.1);color:#fff}
.modal-body{padding:22px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field span{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.field input,.field select,.field textarea{
  padding:11px 13px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--text);outline:none;
  transition:border-color .15s,box-shadow .15s;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.16)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.modal-foot{display:flex;align-items:center;gap:10px;padding:16px 22px;border-top:1px solid var(--line-soft);background:var(--cream)}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:#fff;padding:12px 20px;border-radius:12px;font-size:14px;
  box-shadow:0 12px 30px rgba(0,0,0,.3);opacity:0;transition:.25s;z-index:60;border:1px solid rgba(232,199,126,.25)}
.toast[hidden]{display:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast .t-accent{color:var(--gold-lt);font-weight:700;margin-right:6px}

/* ---------- Responsive ---------- */
@media (max-width:640px){
  .brand-row{gap:10px}
  .brand-logo{max-width:min(180px,48vw)}
  .kpis{width:100%;justify-content:space-between}
  .kpi{flex:1;min-width:0;padding:8px 6px}
  .task{grid-template-columns:22px 1fr;gap:10px;padding:14px}
  .t-actions{grid-column:2;justify-content:flex-end;margin-top:2px}
  .grid2{grid-template-columns:1fr}
  .progress-pct{min-width:auto}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- Tabs (team members) ---------- */
.tabs{display:flex;gap:6px;flex-wrap:wrap;max-width:1080px;margin:0 auto;
  padding:16px clamp(16px,4vw,32px) 0}
.tab{display:flex;align-items:center;gap:9px;padding:9px 15px;border-radius:11px;cursor:pointer;
  background:transparent;border:1px solid transparent;color:var(--muted);font-weight:600;font-size:14px;
  transition:.15s}
.tab:hover{background:var(--paper);border-color:var(--line)}
.tab .role{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);font-weight:600}
.tab .tcount{background:#EDE8DE;color:var(--muted);border-radius:99px;font-size:11px;font-weight:700;
  padding:1px 8px;min-width:20px;text-align:center}
.tab.active{background:var(--ink);border-color:var(--ink);color:#fff;box-shadow:0 4px 14px rgba(22,22,31,.22)}
.tab.active .role{color:var(--gold-lt)}
.tab.active .tcount{background:var(--gold);color:#241c07}

/* ---------- Media button on a task ---------- */
.media-btn{position:relative}
.media-btn .mcount{position:absolute;top:-3px;right:-3px;background:var(--gold);color:#241c07;
  font-size:10px;font-weight:800;border-radius:99px;min-width:16px;height:16px;line-height:16px;
  text-align:center;padding:0 4px;box-shadow:0 0 0 2px #fff}
.media-btn.has svg{stroke:var(--gold)}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;background:rgba(12,12,18,.86);backdrop-filter:blur(4px);
  z-index:70;display:grid;place-items:center;padding:10px}
.lightbox[hidden]{display:none}
.lb-panel{width:min(1040px,100%);height:min(94vh,920px);background:#14141c;border:1px solid rgba(232,199,126,.18);
  border-radius:16px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.55)}
.lb-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;
  background:linear-gradient(180deg,#1e1e29,#15151d);border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0}
.lb-headinfo{min-width:0;flex:1 1 auto}
.lb-title{color:#fff;font-family:"Fraunces",serif;font-weight:600;font-size:16px;line-height:1.25;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-sub{color:#948e85;font-size:12px;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-sub:empty{display:none}
.lb-tools{display:flex;align-items:center;gap:6px;flex-shrink:0;flex-wrap:nowrap}
.lb-actions{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}
.lb-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:36px;padding:0 12px;
  border-radius:9px;font-weight:600;font-size:13px;line-height:1;cursor:pointer;text-decoration:none;
  white-space:nowrap;flex-shrink:0;font-family:inherit;
  border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);color:#ECE7DC;transition:.15s}
.lb-btn:hover{background:rgba(255,255,255,.13)}
.lb-btn svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;flex:none;display:block}
.lb-btn.primary{background:var(--gold);border-color:var(--gold);color:#241c07}
.lb-btn.primary:hover{background:#d6b25f}
.lb-btn.icon{width:36px;min-width:36px;padding:0;font-size:20px;color:#C9C3B6}
.lb-btn.icon:hover{color:#fff}
.lb-btn[hidden]{display:none}

.lb-stage{flex:1 1 auto;display:flex;align-items:center;justify-content:center;padding:12px;
  overflow:hidden;background:#0e0e15;min-height:0;position:relative}
.lb-stage img,.lb-stage video{display:block;max-width:100%;max-height:100%;width:auto;height:auto;
  object-fit:contain;border-radius:8px;box-shadow:0 10px 40px rgba(0,0,0,.55);background:#fff}
.lb-stage iframe{width:100%;height:100%;border:0;border-radius:8px;background:#fff;
  box-shadow:0 10px 40px rgba(0,0,0,.5)}
.lb-file-card{text-align:center;color:#e7e2d8}
.lb-file-card .fi{width:96px;height:96px;border-radius:18px;background:#22222e;display:grid;place-items:center;
  margin:0 auto 16px;border:1px solid rgba(232,199,126,.2)}
.lb-file-card .fi svg{width:44px;height:44px;stroke:var(--gold-lt);fill:none;stroke-width:1.6}
.lb-file-card .fname{font-weight:600;max-width:420px;margin:0 auto 4px;word-break:break-word}
.lb-file-card .fmeta{color:#98928a;font-size:13px;margin-bottom:18px}
.lb-empty{color:#98928a;text-align:center}
.lb-empty strong{display:block;color:#e7e2d8;font-family:"Fraunces",serif;font-size:18px;margin-bottom:6px}

.lb-dl{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:#241c07;border:none;
  border-radius:10px;padding:10px 18px;font-weight:700;font-size:14px;cursor:pointer;text-decoration:none}
.lb-dl:hover{background:#d4af5c}
.lb-dl svg{width:16px;height:16px;stroke:#241c07;fill:none;stroke-width:2}

.lb-bar{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#101017;
  border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}
@media (max-width:600px){
  .lb-head{flex-wrap:wrap}
  .lb-headinfo{flex:1 1 100%}
  .lb-tools{margin-left:auto}
  .lb-btn span{display:none}
  .lb-btn{padding:0;width:36px;min-width:36px}
  .lb-btn.primary span{display:none}
}
.lb-nav{background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:9px;
  width:34px;height:44px;font-size:20px;cursor:pointer;flex-shrink:0}
.lb-nav:hover{background:rgba(255,255,255,.14)}
.lb-nav:disabled{opacity:.3;cursor:default}
.lb-strip{display:flex;gap:8px;overflow-x:auto;flex:1;padding:2px}
.thumb{position:relative;flex-shrink:0;width:64px;height:64px;border-radius:9px;overflow:hidden;cursor:pointer;
  border:2px solid transparent;background:#22222e}
.thumb.active{border-color:var(--gold)}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb .tkind{width:100%;height:100%;display:grid;place-items:center;color:var(--gold-lt);font-size:10px;
  font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.thumb .tdel{position:absolute;top:2px;right:2px;background:rgba(0,0,0,.6);color:#fff;border:none;
  border-radius:6px;width:18px;height:18px;font-size:12px;line-height:1;cursor:pointer;display:grid;place-items:center}
.thumb .tdel:hover{background:#A32C22}
.lb-uploading{color:var(--gold-lt);font-size:13px;padding:0 6px;white-space:nowrap}
