/* Sweat Lord · Projektboard — dark theme, responsive (desktop + iPhone). */
:root {
  --bg: #2a2a30;
  --bg-dark: #1a1a1f;
  --card: #34343b;
  --card-alt: #3d3d45;
  --border: #46464f;
  --text: #f0f0f2;
  --text2: #b0b0b8;
  --text3: #85858f;
  --coral: #ff7a4f;
  --turq: #3de8b4;
  --amber: #ffca5e;
  --violet: #a896ff;
  --danger: #ff5c6c;
  --radius: 14px;
  --radius-sm: 8px;
  --safe-t: env(safe-area-inset-top, 0px);
  --safe-b: env(safe-area-inset-bottom, 0px);
  --safe-l: env(safe-area-inset-left, 0px);
  --safe-r: env(safe-area-inset-right, 0px);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
html, body { margin: 0; height: 100%; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size: 15px;
  line-height: 1.4;
  overflow-x: hidden;
}
.boot { padding: 40px; color: var(--text3); text-align: center; }
button { font-family: inherit; cursor: pointer; }
input, select, textarea {
  font-family: inherit;
  font-size: 16px;
  background: var(--card);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  outline: none;
  max-width: 100%;
}
input:focus, select:focus, textarea:focus { border-color: var(--coral); }
label { color: var(--text2); font-size: 12px; display: block; margin-bottom: 4px; }
a { color: var(--coral); }

/* ── Buttons ── */
.btn {
  background: var(--card); color: var(--text); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 9px 14px; font-weight: 600; min-height: 40px;
}
.btn:hover { border-color: var(--text3); }
.btn.primary { background: var(--coral); color: var(--bg-dark); border-color: var(--coral); }
.btn.turq { background: var(--turq); color: var(--bg-dark); border-color: var(--turq); }
.btn.danger { color: var(--danger); border-color: var(--danger); background: transparent; }
.btn.ghost { background: transparent; }
.btn.sm { padding: 6px 10px; font-size: 13px; min-height: 34px; }

/* ── Header ── */
header.topbar {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding: calc(10px + var(--safe-t)) calc(16px + var(--safe-r)) 10px calc(16px + var(--safe-l));
  background: var(--bg-dark);
  border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: 20;
}
.brand { font-weight: 800; font-size: 18px; letter-spacing: -0.3px; white-space: nowrap; }
.brand .accent { color: var(--coral); }
.spacer { flex: 1; }
.viewtabs { display: flex; gap: 4px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 3px; }
.viewtabs button { background: transparent; border: 0; color: var(--text2); padding: 8px 14px; border-radius: 6px; font-weight: 700; min-height: 36px; }
.viewtabs button.active { background: var(--coral); color: var(--bg-dark); }

/* Gear button */
.gear-btn { font-size: 18px; padding: 8px 10px; min-height: 40px; }
.gear-btn:hover { color: var(--coral); border-color: var(--coral); }

.toolbar {
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
  padding: 12px calc(16px + var(--safe-r)) 12px calc(16px + var(--safe-l));
  border-bottom: 1px solid var(--border);
}
.toolbar .grow { flex: 1; min-width: 140px; }
.toolbar select { flex: 1; min-width: 0; }
.progress-summary { color: var(--text2); font-size: 13px; white-space: nowrap; }
.progress-summary b { color: var(--turq); }

main {
  padding: 16px calc(16px + var(--safe-r)) calc(24px + var(--safe-b)) calc(16px + var(--safe-l));
}

/* ── Chips / misc ── */
.chip { display: inline-flex; align-items: center; gap: 5px; padding: 3px 8px; border-radius: var(--radius-sm); font-size: 11px; font-weight: 700; white-space: nowrap; }
.dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex: none; }

/* ── Sort buttons in list ── */
.sort-btns { display: flex; flex-direction: column; gap: 2px; flex: none; }
.sort-btn {
  background: transparent; border: 1px solid var(--border); color: var(--text3);
  border-radius: 4px; width: 28px; height: 24px; font-size: 13px;
  display: grid; place-items: center; cursor: pointer; padding: 0;
  transition: color .1s, border-color .1s; min-height: unset;
}
.sort-btn:hover:not(:disabled) { color: var(--coral); border-color: var(--coral); }
.sort-btn:disabled { opacity: .25; cursor: default; }

/* ── List view ── */
.area-group { margin-bottom: 22px; }
.area-group h3 { display: flex; align-items: center; gap: 8px; margin: 0 0 8px; font-size: 15px; }
.area-group h3 .count { color: var(--text3); font-weight: 600; font-size: 12px; }
.task-list { display: flex; flex-direction: column; }
.task-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 6px; border-bottom: 1px solid var(--border); cursor: pointer;
}
.task-row:hover { background: var(--card); }
.row-dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.row-main { flex: 1; min-width: 0; }
.row-main .t-title { font-weight: 600; color: var(--text); }
.row-main .t-meta { color: var(--text3); font-size: 12px; }
.row-side { display: flex; align-items: center; gap: 8px; flex: none; }
.assignee { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text2); }
.avatar { width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-size: 11px; font-weight: 800; color: var(--bg-dark); flex: none; }
.bar { height: 6px; width: 80px; background: var(--bg-dark); border-radius: 3px; overflow: hidden; flex: none; }
.bar > span { display: block; height: 100%; background: var(--turq); }

/* ── Board (kanban) ── */
.board { display: flex; gap: 14px; align-items: flex-start; overflow-x: auto; padding-bottom: 10px; -webkit-overflow-scrolling: touch; scroll-snap-type: x mandatory; scroll-padding-left: 0; }
.column { background: var(--bg-dark); border: 1px solid var(--border); border-radius: var(--radius); width: 280px; min-width: 280px; padding: 10px; scroll-snap-align: start; scroll-snap-stop: always; }
.column.dragover { border-color: var(--coral); }
.column h4 { margin: 4px 6px 10px; display: flex; align-items: center; gap: 8px; font-size: 13px; }
.column h4 .count { color: var(--text3); font-weight: 600; }
.kcard { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 10px; margin-bottom: 8px; cursor: grab; }
.kcard:hover { border-color: var(--text3); }
.kcard.dragging { opacity: 0.5; }
.kcard .k-title { font-weight: 600; margin-bottom: 6px; }
.kcard .k-foot { display: flex; align-items: center; gap: 8px; margin-top: 8px; flex-wrap: wrap; }
.kstatus { font-size: 12px; padding: 5px 8px; min-height: 32px; }

/* ── Gantt controls bar ── */
.gantt-ctrls {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding: 10px 0 12px; margin-bottom: 4px;
}
.zoom-btn {
  background: var(--card); border: 1px solid var(--border); color: var(--text);
  border-radius: var(--radius-sm); width: 36px; height: 36px; font-size: 20px;
  font-weight: 700; display: grid; place-items: center; cursor: pointer;
  transition: color .1s, border-color .1s;
}
.zoom-btn:hover:not(:disabled) { border-color: var(--coral); color: var(--coral); }
.zoom-btn:disabled { opacity: .3; cursor: default; }
.zoom-display {
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 6px 12px; font-size: 13px; color: var(--text2); white-space: nowrap; min-width: 80px; text-align: center;
}
.ctrls-sep { width: 1px; height: 28px; background: var(--border); flex: none; }
.range-btn {
  background: var(--card); border: 1px solid var(--border); color: var(--text2);
  border-radius: var(--radius-sm); padding: 7px 12px; font-size: 13px; font-weight: 700;
  cursor: pointer; white-space: nowrap; transition: all .1s;
}
.range-btn:hover, .range-btn.active {
  border-color: var(--coral); color: var(--coral); background: rgba(255,122,79,.12);
}
.gantt-date-inputs { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.gantt-date-inputs input[type="date"] { width: 138px; padding: 7px 10px; font-size: 14px; }
.gantt-date-inputs .sep { color: var(--text3); font-size: 13px; }

/* ── Gantt diagram ── */
.gantt-wrap { border: 1px solid var(--border); border-radius: var(--radius); overflow: auto; background: var(--bg-dark); -webkit-overflow-scrolling: touch; }
.gantt { position: relative; }
.gantt-head { display: flex; position: sticky; top: 0; background: var(--bg-dark); z-index: 5; border-bottom: 1px solid var(--border); }
.gantt-row { display: flex; border-bottom: 1px solid var(--border); }
.gantt-row:hover { background: rgba(255,255,255,.02); }
.g-name { width: 220px; min-width: 220px; padding: 8px 12px; position: sticky; left: 0; background: var(--bg-dark); z-index: 4; border-right: 1px solid var(--border); font-size: 13px; }
.g-name.head { font-weight: 800; }
.g-name .g-sub { color: var(--text3); font-size: 11px; }
.g-track { position: relative; flex: 1; overflow: hidden; }
.g-months { display: flex; }
.g-month { border-right: 1px solid var(--border); padding: 6px 8px; font-size: 11px; color: var(--text2); font-weight: 700; }
.g-bar { position: absolute; top: 3px; bottom: 3px; border-radius: 6px; display: flex; align-items: center; padding: 0 8px; font-size: 11px; font-weight: 700; color: var(--bg-dark); overflow: hidden; white-space: nowrap; cursor: pointer; transition: filter .15s; }
.g-bar:hover { filter: brightness(1.15); }
.g-bar .g-fill { position: absolute; left: 0; top: 0; bottom: 0; background: rgba(255,255,255,.28); border-radius: 6px; }
.g-bar span { position: relative; }
.today-line { position: absolute; top: 0; bottom: 0; width: 2px; background: var(--coral); z-index: 3; opacity: .9; }
.today-line::after { content: "heute"; position: absolute; top: 4px; left: 4px; font-size: 10px; font-weight: 700; color: var(--coral); white-space: nowrap; }
.gantt-empty-note { padding: 12px; color: var(--text3); font-size: 13px; }

/* ── Modal ── */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,.55); display: flex; align-items: center; justify-content: center; z-index: 50; padding: 16px; }
.modal { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius); width: 640px; max-width: 100%; max-height: 92vh; overflow: auto; }
.modal .m-head { display: flex; align-items: center; gap: 10px; padding: 16px 18px; border-bottom: 1px solid var(--border); position: sticky; top: 0; background: var(--bg); z-index: 1; }
.modal .m-body { padding: 18px; }
.modal .m-foot { padding: 14px 18px; border-top: 1px solid var(--border); display: flex; gap: 10px; flex-wrap: wrap; position: sticky; bottom: 0; background: var(--bg); }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.grid3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.field { margin-bottom: 12px; }
.field input, .field select, .field textarea { width: 100%; }
textarea { resize: vertical; min-height: 64px; }

/* ── Settings panel ── */
.settings-modal { width: 520px; max-width: 100%; }
.settings-section { border-bottom: 1px solid var(--border); padding-bottom: 16px; margin-bottom: 16px; }
.settings-section:last-child { border-bottom: none; padding-bottom: 0; margin-bottom: 0; }
.settings-section h4 { margin: 0 0 12px; font-size: 12px; text-transform: uppercase; letter-spacing: .7px; color: var(--text3); font-weight: 700; }
.settings-row { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; flex-wrap: wrap; }
.settings-row:last-child { margin-bottom: 0; }
.settings-row label { min-width: 110px; margin: 0; font-size: 13px; color: var(--text2); }
.settings-row input[type="range"] { flex: 1; accent-color: var(--coral); min-width: 80px; }
.zoom-val { color: var(--text); font-weight: 700; min-width: 70px; font-size: 14px; }
.view-radios { display: flex; gap: 8px; flex-wrap: wrap; }
.vr {
  display: flex; align-items: center; gap: 6px; cursor: pointer;
  padding: 7px 14px; border: 1px solid var(--border); border-radius: var(--radius-sm);
  font-size: 13px; font-weight: 600; color: var(--text2); background: var(--card);
  transition: all .1s;
}
.vr input { display: none; }
.vr.checked { border-color: var(--coral); color: var(--coral); background: rgba(255,122,79,.12); }
.settings-range-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.settings-range-row .range-btn { padding: 6px 10px; font-size: 12px; }
.settings-range-row input[type="date"] { width: 130px; padding: 7px 10px; font-size: 14px; }

/* ── Attachments ── */
.attachments { margin-top: 8px; }
.att-list { display: flex; flex-direction: column; gap: 8px; margin: 6px 0 10px; }
.att-item { display: flex; align-items: center; gap: 10px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 8px 10px; }
.att-item img { width: 56px; height: 56px; object-fit: cover; border-radius: 6px; border: 1px solid var(--border); flex: none; }
.att-ico { font-size: 18px; flex: none; }
.att-name { color: var(--text); text-decoration: none; font-weight: 600; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
a.att-name:hover { color: var(--coral); text-decoration: underline; }
.att-size { flex: none; }
.att-del { background: transparent; border: 0; color: var(--text3); font-size: 14px; cursor: pointer; padding: 4px 6px; border-radius: 4px; flex: none; }
.att-del:hover { color: var(--danger); }
.att-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.att-upload { display: inline-flex; align-items: center; cursor: pointer; }
.att-link-form { display: flex; gap: 8px; margin-top: 8px; flex-wrap: wrap; }
.att-link-form input { flex: 1; min-width: 140px; }

/* ── Comments ── */
.comments { margin-top: 16px; }
.comment { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 10px; margin-bottom: 8px; }
.comment .c-head { font-size: 12px; color: var(--text3); margin-bottom: 4px; display: flex; gap: 8px; align-items: center; }
.comment .c-author { color: var(--text2); font-weight: 700; }
.c-body { white-space: pre-wrap; }
.c-act { background: transparent; border: 0; color: var(--text3); cursor: pointer; font-size: 13px; padding: 2px 6px; border-radius: 4px; }
.c-act:hover { color: var(--coral); }
.c-edit { width: 100%; min-height: 60px; }
.c-edit-actions { display: flex; gap: 8px; margin-top: 6px; }

/* ── Login ── */
.login-wrap { min-height: 100vh; display: grid; place-items: center; padding: 20px; }
.login { width: 360px; max-width: 100%; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; }
.login h1 { margin: 0 0 4px; font-size: 22px; }
.login .tag { color: var(--coral); margin-bottom: 18px; font-size: 13px; }
.login .field { margin-bottom: 12px; }
.login .err { color: var(--danger); font-size: 13px; min-height: 18px; }
.muted { color: var(--text3); font-size: 12px; }

/* FAB */
.newbtn .lbl { display: inline; }

/* ── Reorder highlight animation ── */
@keyframes rowMoved {
  0%   { background: rgba(255,122,79,.40); }
  60%  { background: rgba(255,122,79,.22); }
  100% { background: rgba(255,122,79,0); }
}
.task-row.moved { animation: rowMoved 1s ease-out; }

/* ── Color picker ── */
.color-picker { display: flex; gap: 8px; flex-wrap: wrap; }
.swatch { width: 30px; height: 30px; border-radius: 50%; border: 2px solid var(--border); cursor: pointer; padding: 0; transition: transform .1s; }
.swatch:hover { transform: scale(1.12); }
.swatch.sel { border-color: var(--text); box-shadow: 0 0 0 2px var(--bg), 0 0 0 4px var(--text); }
.swatch.none { background: var(--card); color: var(--text3); font-size: 15px; display: grid; place-items: center; }

/* ── Dependencies ── */
.dep-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.dep-chip { display: inline-flex; align-items: center; gap: 6px; background: var(--card); border: 1px solid var(--border); border-radius: 999px; padding: 4px 6px 4px 10px; font-size: 12px; }
.dep-chip button { background: transparent; border: 0; color: var(--text3); cursor: pointer; font-size: 12px; padding: 0 2px; min-height: unset; }
.dep-chip button:hover { color: var(--danger); }
.dep-hint { font-size: 12px; color: var(--text3); margin-top: 6px; }
.dep-warn { color: var(--danger); font-weight: 700; }

/* ── Filter toggle (mobile only) ── */
.filter-toggle { display: none; align-items: center; }
.filter-toggle.active { border-color: var(--coral); color: var(--coral); }
.filter-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--coral); margin-left: 5px; }
.filter-dot[hidden] { display: none; }

/* ── Gantt hover tooltip ── */
.gantt-tip {
  position: fixed; z-index: 100; display: none; pointer-events: none;
  background: var(--bg-dark); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 10px 12px; max-width: 300px; box-shadow: 0 8px 24px rgba(0,0,0,.5); font-size: 12px;
}
.gantt-tip .gtt-title { font-weight: 800; font-size: 13px; margin-bottom: 6px; display: flex; align-items: center; gap: 6px; }
.gantt-tip .gtt-dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.gantt-tip .gtt-row { display: flex; justify-content: space-between; gap: 16px; color: var(--text3); margin-top: 2px; }
.gantt-tip .gtt-row b { color: var(--text); font-weight: 600; text-align: right; }

/* ── Tablet ── */
@media (max-width: 820px) {
  .grid3 { grid-template-columns: 1fr 1fr; }
}

/* ── Phone ── */
@media (max-width: 600px) {
  .brand { font-size: 17px; }
  .viewtabs { order: 3; width: 100%; }
  .viewtabs button { flex: 1; padding: 9px 6px; }
  .progress-summary { order: 2; font-size: 12px; }

  /* Filters collapse behind the Filter button on phones */
  .filter-toggle { display: inline-flex; }
  .toolbar { display: none; }
  .toolbar.open { display: flex; }
  .toolbar .grow { flex-basis: 100%; }
  .toolbar select { flex-basis: calc(50% - 5px); }

  .task-row { flex-wrap: wrap; align-items: flex-start; padding: 10px 4px; }
  .row-side { width: 100%; padding-left: 48px; margin-top: 6px; flex-wrap: wrap; gap: 8px; }
  .bar { width: 100%; }

  .column { width: 85vw; min-width: 85vw; }

  .gantt-ctrls { gap: 6px; }
  .gantt-date-inputs input[type="date"] { width: 100%; }
  .gantt-date-inputs { width: 100%; }

  .grid2, .grid3 { grid-template-columns: 1fr; }
  .modal { max-height: 100vh; border-radius: 0; height: 100%; }
  .overlay { padding: 0; }

  .g-name, .g-name.head { width: 140px; min-width: 140px; }

  .newbtn {
    position: fixed; right: calc(16px + var(--safe-r)); bottom: calc(16px + var(--safe-b));
    z-index: 30; width: 56px; height: 56px; border-radius: 50%;
    font-size: 26px; font-weight: 700; padding: 0; box-shadow: 0 6px 18px rgba(0,0,0,.4);
    display: grid; place-items: center;
  }
  .newbtn .lbl { display: none; }

  .settings-row label { min-width: unset; }
  .settings-range-row input[type="date"] { width: 100%; }
}
