/* BrandFather Portal — брендинг + світла/темна теми (Fedoriv brandbook) */

@font-face {
  font-family: 'FGroup';
  src: url('/static/fonts/FGroupDisplay-Heavy.ttf') format('truetype');
  font-weight: 900; font-style: normal; font-display: swap;
}

:root {
  --black:  #0A0A0A;   /* фон шапки/брендзони */
  --yellow: #FFFF00;   /* акцент-плашки/кнопки (в обох темах) */
  --white:  #FFFFFF;
}

/* Теми застосовуються до КОНТЕНТ-зони; шапка завжди темна (бренд). */
body.theme-light {
  --bg: #F7F6F2; --fg: #1A1813; --muted: #6B6862; --line: #ECEAE3;
  --hover: #F1EFE9; --input-bg: #ffffff; --input-bd: #D9D6CC;
  --accent-text: #0A0A0A;   /* жовтий на білому не читається → темний акцент-текст */
  --link: #1a1a1a;
  --surface: #FFFFFF; --card-line: #ECEAE3; --axis: #6B6862;
  /* картки дашборда тримаються на ТІНІ, не на рамці */
  --card-shadow: 0 1px 3px rgba(0,0,0,.06);
}
body.theme-dark {
  --bg: #0A0A0A; --fg: #FFFFFF; --muted: #8a8a8a; --line: #1e1e1e;
  --hover: #141414; --input-bg: #141414; --input-bd: #2a2a2a;
  --accent-text: #FFFF00;
  --link: #FFFF00;
  --surface: #141414; --card-line: #242424; --axis: #8a8a8a;
  /* на темному тіні не читаються → ледь світліша межа замість тіні */
  --card-shadow: 0 0 0 1px rgba(255,255,255,.07);
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  background: var(--bg); color: var(--fg);
  font-family: Helvetica, Arial, sans-serif;
}

h1, h2, h3, .display {
  font-family: 'FGroup', Montserrat, sans-serif;
  font-weight: 900; letter-spacing: 0.01em; color: var(--fg);
}

a { color: var(--link); text-decoration: none; }
a:hover { text-decoration: underline; }
.accent { color: var(--accent-text); }

/* --- Шапка (завжди темна) --- */
.site-header {
  display: flex; align-items: center; gap: 16px; height: 56px; padding: 0 20px;
  background: var(--black); border-bottom: 1px solid rgba(255,255,0,.15);
}
.site-header .logo-link { display: inline-flex; align-items: center; }
.site-header .logo-link img { height: 36px; width: auto; display: block; }
.site-header nav { margin-left: auto; display: flex; align-items: center; gap: 20px; }
.site-header nav a { color: var(--white); font-size: 14px; }
.site-header nav a:hover { color: var(--yellow); text-decoration: none; }
.theme-toggle {
  border: 1px solid rgba(255,255,0,.4); border-radius: 999px;
  padding: 4px 12px !important; font-size: 13px !important;
}
.nav-user { color: var(--yellow); font-size: 14px; font-weight: 700; }

.content { padding: 32px 20px; max-width: 1100px; margin: 0 auto; }

/* --- Пошук / таблиці / пагінація --- */
.search { display: flex; gap: 10px; margin: 18px 0; align-items: center; }
.search input {
  flex: 1; max-width: 460px; padding: 10px 12px;
  background: var(--input-bg); border: 1px solid var(--input-bd);
  border-radius: 6px; color: var(--fg); font-size: 14px;
}
.search input:focus { outline: none; border-color: var(--yellow); }
.search button {
  padding: 10px 18px; background: var(--yellow); color: var(--black);
  border: none; border-radius: 6px; font-weight: 700; cursor: pointer;
}
.search .clear { font-size: 13px; }
.meta { color: var(--muted); font-size: 13px; }
.meta strong { color: var(--accent-text); }

table.data { width: 100%; border-collapse: collapse; margin-top: 12px; font-size: 14px; }
table.data th, table.data td { text-align: left; padding: 9px 12px; border-bottom: 1px solid var(--line); }
table.data thead th {
  color: var(--accent-text); font-weight: 700; font-size: 12px;
  text-transform: uppercase; letter-spacing: .03em;
  border-bottom: 1px solid var(--line);
}
table.data tfoot th { border-top: 1px solid var(--line); border-bottom: none; padding-top: 10px; }
table.data tbody tr:hover { background: var(--hover); }
table.data td.num, table.data th.num { text-align: right; font-variant-numeric: tabular-nums; }
.muted { color: var(--muted); }
.muted-link { color: var(--muted); font-size: 13px; }

.badge { display: inline-block; padding: 2px 9px; border-radius: 999px; font-size: 12px; font-weight: 700; }
.badge-клієнт  { background: var(--yellow); color: #0A0A0A; }
.badge-партнер { background: transparent; color: var(--fg); border: 1px solid var(--fg); }
.badge-лід     { background: var(--hover); color: var(--muted); }

.pager { display: flex; gap: 6px; margin: 22px 0; flex-wrap: wrap; align-items: center; }
.pager a, .pager .cur, .pager .gap { min-width: 34px; text-align: center; padding: 7px 10px; border-radius: 6px; font-size: 14px; }
.pager a { background: var(--input-bg); color: var(--fg); border: 1px solid var(--line); }
.pager a:hover { border-color: var(--yellow); text-decoration: none; }
.pager .cur { background: var(--yellow); color: #0A0A0A; font-weight: 700; }
.pager .gap { color: var(--muted); }

/* --- Картка --- */
.card-head { display: flex; align-items: center; gap: 14px; margin-bottom: 6px; }
.card-head h1 { margin: 0; }
.card-summary { display: flex; flex-wrap: wrap; gap: 22px; margin: 6px 0 18px; font-size: 14px; color: var(--muted); }
.card-summary strong { color: var(--fg); }
/* Пастельні блоки картки (Fedoriv) — кожен блок свій колір, у обох темах */
.card-sec {
  border-radius: 12px; padding: 16px 20px; margin: 14px 0;
  border-left: 4px solid currentColor;
}
.card-sec h2 {
  color: inherit; text-transform: uppercase; font-size: 12px;
  letter-spacing: .05em; margin: 0 0 12px; font-weight: 900;
}
.card-sec, .card-sec p, .card-sec td, .card-sec th, .card-sec .card-summary,
.card-sec .card-summary strong, .card-sec .card-head h1 { color: inherit; }
.card-sec .card-kv th { color: inherit; opacity: .72; }
.card-sec table.data th, .card-sec table.data td { border-color: rgba(0,0,0,.14); }
.card-sec table.data thead th { color: inherit; opacity: .8; border-color: rgba(0,0,0,.22); }
.card-sec table.data tbody tr:hover { background: rgba(0,0,0,.05); }
.card-sec a { color: inherit; text-decoration: underline; }

/* Тепла брендова гама Fedoriv: жовтий/кремовий/теплий сірий + чорний.
   Жодних синіх/зелених/рожевих/мʼятних. Заголовок блоку — окремий колір. */
.sec-summary  { background:#F7F1DC; color:#4A4127; border-left-color:#E3C84E; }
.sec-summary  h2 { color:#7A6A2E; }
.sec-contacts { background:#EFEDE6; color:#56524A; border-left-color:#B0AC9C; }
.sec-contacts h2 { color:#56524A; }
.sec-circle   { background:#E8E6DF; color:#4D4A42; border-left-color:#9C9788; }
.sec-circle   h2 { color:#4D4A42; }
.sec-leads    { background:#FBF6E0; color:#5C4F22; border-left-color:#EAD24E; }
.sec-leads    h2 { color:#7A6A2E; }
.sec-payments { background:#FDF3C9; color:#5C4D14; border-left-color:#F2D024; }
.sec-payments h2 { color:#7A641A; }
.sec-correspondence { background:#33312B; color:#D8D5CC; border-left-color:#FFFF00; }
.sec-correspondence h2 { color:#FFFF00; }   /* Листування — темний блок (майбутній Gmail) */
.sec-notes    { background:#FFFFFF; color:#444444; border-left-color:#DDDDD9; }
.sec-notes    h2 { color:#666666; }
/* legacy-класи (зараз не в картці) — у нейтральний теплий сірий, без сторонніх кольорів */
.sec-wfp, .sec-customers, .sec-manual { background:#EFEDE6; color:#56524A; border-left-color:#B0AC9C; }

/* тег-селекти в «Платежах»: WFP — жовтий (системний), решта — теплий сірий */
.card-sec select.tag-wfp   { background:#E3C84E; color:#3A3000; border-color:#C9A800; }
.card-sec select.tag-other { background:#D8D2C0; color:#333333; }

/* поля вводу всередині кольорових блоків — білі, темний текст (читабельність) */
.card-sec input, .card-sec select, .card-sec textarea {
  background:#fff; color:#1a1a1a; border:1px solid rgba(0,0,0,.2);
  border-radius:6px; padding:7px 9px; font-size:13px; font-family:inherit;
}
.card-sec button {
  background: var(--yellow); color:#0A0A0A; border:none; border-radius:6px;
  font-weight:700; cursor:pointer; padding:8px 14px;
}
.card-sec button.mini { padding:6px 10px; font-size:12px; }
.card-sec button.danger { background:#7A2E2E; color:#fff; }

/* ручні платежі */
.mhead, .mrow { display:grid; grid-template-columns: 110px 130px 130px 140px 1fr 90px auto; gap:8px; align-items:center; }
.mhead { font-size:11px; text-transform:uppercase; opacity:.7; padding:4px 0; }
.mitem { display:flex; gap:8px; align-items:center; padding:4px 0; }
.mitem .mrow { flex:1; }
.mrow .amt { text-align:right; }
.mrow .who { font-size:12px; opacity:.8; }
.msum { margin-top:10px; }

/* єдиний реєстр платежів */
.phead, .prow { display:grid; grid-template-columns: 140px 110px 1fr 120px 1fr 90px; gap:8px; align-items:center; }
.phead { font-size:11px; text-transform:uppercase; opacity:.7; padding:4px 0 4px 28px; }
.pitem { display:flex; gap:8px; align-items:center; padding:3px 0; }
.pitem > input[type=checkbox] { width:18px; height:18px; }
.pitem .prow { flex:1; }
.prow .amt { text-align:right; }
.pfoot { display:flex; gap:18px; align-items:center; margin-top:12px; flex-wrap:wrap; }
.psum strong { font-size:16px; }
.add-manual { margin-top:14px; }
.add-manual summary { cursor:pointer; font-weight:700; }
.manual-form { display:flex; flex-wrap:wrap; gap:12px; align-items:end; margin-top:12px; }
.manual-form label { display:flex; flex-direction:column; gap:4px; font-size:12px; }
.card-sec.sec-notes textarea { max-width:700px; }
table.card-kv { border-collapse: collapse; }
table.card-kv th, table.card-kv td { text-align: left; padding: 6px 16px 6px 0; vertical-align: top; font-size: 14px; }
table.card-kv th { color: var(--muted); font-weight: 400; white-space: nowrap; }
.card-sec textarea {
  width: 100%; max-width: 700px; padding: 11px 13px; border-radius: 6px;
  background: var(--input-bg); border: 1px solid var(--input-bd); color: var(--fg);
  font-family: inherit; font-size: 14px; resize: vertical;
}
.note-foot { display: flex; align-items: center; gap: 14px; margin-top: 10px; }
.note-foot button {
  padding: 9px 18px; background: var(--yellow); color: #0A0A0A; border: none;
  border-radius: 6px; font-weight: 700; cursor: pointer;
}

/* --- Дашборд: фільтри (pill-кнопки на тінях, без рамок) --- */
.filters { margin: 16px 0 22px; display: flex; flex-direction: column; gap: 14px; }
.f-period { display: flex; flex-wrap: wrap; gap: 8px; }
.chip {
  padding: 8px 16px; border-radius: 20px; cursor: pointer; font-size: 13px;
  background: var(--surface); color: #6B6862; border: none;
  box-shadow: var(--card-shadow); transition: box-shadow .15s, color .15s;
}
.chip:hover { color: var(--fg); }
.chip.on {
  background: #F2D024; color: #3D3208; font-weight: 700; box-shadow: none;
}
.f-selects { display: flex; flex-wrap: wrap; gap: 14px; align-items: end; }
.f-selects label { display: flex; flex-direction: column; gap: 4px; font-size: 12px; color: var(--muted); }
.f-selects select {
  padding: 8px 12px; background: var(--surface); color: var(--fg);
  border: 1px solid var(--card-line); border-radius: 8px; font-size: 14px;
  box-shadow: var(--card-shadow);
}
.f-selects .apply {
  padding: 9px 18px; background: #F2D024; color: #3D3208; border: none;
  border-radius: 20px; font-weight: 700; cursor: pointer;
}

/* --- Дашборд: KPI (сітка 4 колонки, картки на тінях, без рамок) --- */
.kpi-grid { display: grid; gap: 14px; grid-template-columns: repeat(4, 1fr); }
.kpi {
  background: var(--surface); border: none; border-radius: 14px;
  padding: 18px 20px; min-height: 112px;
  display: flex; flex-direction: column; justify-content: center;
  box-shadow: var(--card-shadow);
}
.kpi-val { font-family: 'FGroup', Montserrat, sans-serif; font-weight: 900;
  font-size: 26px; line-height: 1.1; color: var(--fg); }
.kpi-lab { color: #8A8780; font-size: 13px; margin-top: 4px; }
/* головна — жовта смужка 3px зверху всередині картки (псевдоелемент, не рамка) */
.kpi-hero { grid-column: span 2; position: relative; overflow: hidden; }
.kpi-hero::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: #F2D024;
}
.kpi-hero .kpi-val { font-size: 40px; }

/* --- Дашборд: графіки (картки на тінях, без рамок) --- */
.charts { display: grid; gap: 14px; grid-template-columns: repeat(2, 1fr); margin-top: 22px; }
.chart-box {
  background: var(--surface); border: none; border-radius: 14px;
  padding: 20px; box-shadow: var(--card-shadow);
}
.chart-box h2 { font-size: 13px; margin: 0 0 12px; text-transform: uppercase; letter-spacing: .03em; }
.chart-wrap { position: relative; height: 240px; }

@media (max-width: 900px) {
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .kpi-hero { grid-column: span 2; }
  .charts { grid-template-columns: 1fr; }
}

/* --- Заглушки розділів («в розробці») --- */
.stub-head { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-bottom: 8px; }
.stub-head h1 { margin: 0; }
.badge-wip {
  display: inline-block; padding: 5px 14px; border-radius: 999px;
  background: var(--yellow); color: #0A0A0A; font-weight: 700;
  font-size: 13px; text-transform: uppercase; letter-spacing: .03em;
}
.stub-intro { font-size: 16px; color: var(--fg); margin: 12px 0 18px; max-width: 720px; }
.stub-sub { color: var(--muted); font-weight: 700; margin-bottom: 8px; }
.stub-list { max-width: 720px; line-height: 1.9; padding-left: 22px; }
.stub-list li { color: var(--fg); }

/* --- ClickUp: піднавігація розділу --- */
.subnav { display: flex; flex-wrap: wrap; gap: 8px; margin: 14px 0 20px; }
.subnav a, .subnav .soon {
  padding: 8px 16px; border-radius: 20px; font-size: 13px;
  background: var(--surface); box-shadow: var(--card-shadow);
}
.subnav a { color: #6B6862; }
.subnav a:hover { color: var(--fg); text-decoration: none; }
.subnav a.on { background: #F2D024; color: #3D3208; font-weight: 700; box-shadow: none; }
.subnav .soon { color: var(--muted); opacity: .55; cursor: default; }

/* текстовий пошук у панелі фільтрів (поряд із селектами) */
.f-selects input[type=text] {
  padding: 8px 12px; background: var(--surface); color: var(--fg);
  border: 1px solid var(--card-line); border-radius: 8px; font-size: 14px;
  box-shadow: var(--card-shadow); min-width: 200px;
}
.f-selects input[type=text]:focus { outline: none; border-color: var(--yellow); }
.f-selects .clear { font-size: 13px; align-self: center; }

/* --- ClickUp: зведена шапка (компактні картки на тінях) --- */
.cu-summary {
  display: grid; gap: 12px; margin: 0 0 18px;
  grid-template-columns: repeat(7, 1fr);
}
.cu-stat {
  background: var(--surface); border-radius: 14px; padding: 14px 16px;
  box-shadow: var(--card-shadow); display: flex; flex-direction: column; gap: 4px;
}
.cu-val { font-family: 'FGroup', Montserrat, sans-serif; font-weight: 900;
  font-size: 24px; line-height: 1.05; color: var(--fg); }
.cu-lab { color: #8A8780; font-size: 12px; }
.cu-hero { position: relative; overflow: hidden; }
.cu-hero::before { content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 3px; background: #F2D024; }
.cu-hero .cu-val { color: var(--accent-text); }
/* прострочені — теплий червоний акцент; порожній облік часу — жовте попередження */
.cu-stat.cu-alert .cu-val { color: #B23A3A; }
.cu-stat.cu-warn { background: #FBF6E0; }
body.theme-dark .cu-stat.cu-warn { background: #2A2718; }
.cu-stat.cu-warn .cu-val { color: #7A641A; }
body.theme-dark .cu-stat.cu-warn .cu-val { color: #E3C84E; }

/* --- ClickUp: мітки статусів (брендгама, не строкато) --- */
.badge-cu-open   { background: var(--hover); color: var(--muted); }
.badge-cu-custom { background: #F2D024; color: #3D3208; }
.badge-cu-closed { background: #4D4A42; color: #F1EFE9; }
.cu-name { max-width: 360px; }
td.cu-overdue { color: #B23A3A; font-weight: 700; }

@media (max-width: 900px) {
  .cu-summary { grid-template-columns: repeat(2, 1fr); }
}

/* --- ClickUp: Спринти --- */
.spr-kpis { grid-template-columns: repeat(4, 1fr); }
.spr-grid { display: grid; gap: 14px; grid-template-columns: 2fr 1fr; margin-top: 14px; }

.spr-row { display: flex; align-items: center; gap: 12px; margin: 9px 0; }
.spr-name {
  width: 210px; flex: none; font-size: 13px; color: var(--fg);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.spr-bar {
  flex: 1; height: 22px; border-radius: 6px; background: var(--hover);
  display: flex; overflow: hidden;
}
.spr-seg { height: 100%; }
.spr-seg.open   { background: #C9C3B0; }
.spr-seg.custom { background: #F2D024; }
.spr-seg.closed { background: #4D4A42; }
.spr-total {
  width: 40px; flex: none; text-align: right; font-size: 13px; font-weight: 700;
  font-variant-numeric: tabular-nums; color: var(--fg);
}
.spr-legend { display: flex; gap: 18px; margin-top: 16px; font-size: 12px; color: var(--muted); }
.spr-legend span { display: inline-flex; align-items: center; gap: 6px; }
.sw { width: 12px; height: 12px; border-radius: 3px; display: inline-block; flex: none; }
.sw.open { background: #C9C3B0; } .sw.custom { background: #F2D024; } .sw.closed { background: #4D4A42; }

.spr-cur-nums { display: flex; flex-direction: column; gap: 7px; margin-top: 14px; font-size: 13px; color: var(--fg); }
.spr-cur-nums span { display: inline-flex; align-items: center; gap: 8px; }
.spr-cur-nums .spr-cur-total { margin-top: 4px; border-top: 1px solid var(--line); padding-top: 8px; }

.spr-time { margin-top: 14px; }
.spr-time-row { display: flex; gap: 24px; align-items: center; flex-wrap: wrap; }
.spr-time-big {
  font-family: 'FGroup', Montserrat, sans-serif; font-weight: 900; font-size: 38px;
  color: var(--accent-text); line-height: 1;
}
.spr-time-big span { font-size: 16px; color: var(--muted); }
.spr-time-meta { font-size: 13px; color: var(--fg); }
.spr-time-meta p { margin: 4px 0; }
.spr-time-warn { color: #B85C3C; font-weight: 700; max-width: 560px; }

/* --- ClickUp: Працівники --- */
.wk-grid { display: grid; gap: 14px; grid-template-columns: 1fr 1fr; margin-top: 14px; }
.wk-note { margin: 16px 0 0; font-size: 12px; color: var(--muted); }
.wk-note strong { color: var(--accent-text); }
.wk-htotal { width: 56px; }

@media (max-width: 900px) {
  .spr-kpis { grid-template-columns: repeat(2, 1fr); }
  .spr-grid, .wk-grid { grid-template-columns: 1fr; }
  .spr-name { width: 140px; }
}

/* --- Доступи / зміна пароля --- */
.pw-form { display: flex; flex-direction: column; gap: 14px; max-width: 360px; margin-top: 18px; }
.pw-form label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--muted); }
.pw-form input {
  padding: 11px 13px; background: var(--input-bg); border: 1px solid var(--input-bd);
  border-radius: 6px; color: var(--fg); font-size: 15px;
}
.pw-form input:focus { outline: none; border-color: var(--yellow); }
.pw-form button {
  margin-top: 4px; padding: 12px; background: var(--yellow); color: #0A0A0A; border: none;
  border-radius: 6px; font-weight: 700; font-size: 15px; cursor: pointer;
}

.denied-note {
  background: rgba(184,92,60,.12); border: 1px solid #B85C3C; color: #B85C3C;
  padding: 10px 14px; border-radius: 8px; font-size: 14px; margin: 14px 0; font-weight: 700;
}
.pw-reveal {
  background: #FDF3C9; border-radius: 12px; padding: 14px 18px; margin: 14px 0;
  box-shadow: var(--card-shadow); color: #5C4D14; font-size: 14px;
}
.pw-reveal code {
  font-size: 16px; font-weight: 700; background: #fff; padding: 3px 9px;
  border-radius: 6px; margin: 0 6px; letter-spacing: .04em; color: #0A0A0A;
}
.inline-form { display: inline; margin: 0; }
.inline-form select {
  padding: 6px 10px; background: var(--surface); color: var(--fg);
  border: 1px solid var(--card-line); border-radius: 8px; font-size: 13px;
}
button.mini {
  padding: 6px 12px; background: var(--input-bg); color: var(--fg);
  border: 1px solid var(--card-line); border-radius: 8px; font-size: 13px;
  cursor: pointer; font-family: inherit;
}
button.mini:hover { border-color: var(--yellow); }
button.mini.on { background: #F2D024; color: #3D3208; border-color: #F2D024; font-weight: 700; }
.pw-pending { color: #B85C3C; font-weight: 700; font-size: 13px; }

/* --- ClickUp: форма нової задачі --- */
.cu-form-box { max-width: 640px; margin-top: 14px; }
.cu-form { display: flex; flex-direction: column; gap: 14px; margin-top: 4px; }
.cu-form label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--muted); }
.cu-form input, .cu-form select, .cu-form textarea {
  padding: 10px 12px; background: var(--input-bg); border: 1px solid var(--input-bd);
  border-radius: 8px; color: var(--fg); font-size: 14px; font-family: inherit;
}
.cu-form input:focus, .cu-form select:focus, .cu-form textarea:focus {
  outline: none; border-color: var(--yellow);
}
.cu-form textarea { resize: vertical; }
.cu-form button {
  align-self: flex-start; margin-top: 4px; padding: 11px 22px; background: var(--yellow);
  color: #0A0A0A; border: none; border-radius: 8px; font-weight: 700; font-size: 14px; cursor: pointer;
}
.cu-ok {
  background: #FDF3C9; border-radius: 12px; padding: 14px 18px; margin: 14px 0;
  box-shadow: var(--card-shadow); color: #5C4D14; font-size: 14px; line-height: 1.55;
}
.cu-ok code { background: #fff; padding: 2px 7px; border-radius: 5px; color: #0A0A0A; font-weight: 700; }
.cu-ok a { color: #5C4D14; text-decoration: underline; }

/* --- ClickUp: Динаміка --- */
.dyn-verdict { margin-top: 14px; font-size: 15px; color: var(--fg); line-height: 1.5; }
.dyn-verdict.cu-alert { border-left: 4px solid #B85C3C; }
.dyn-neg { color: #B85C3C; font-weight: 700; }

/* --- Сторінка входу (завжди темна — бренд) --- */
.login-page {
  min-height: 100vh; display: flex; flex-direction: column;
  align-items: center; justify-content: center; background: #0A0A0A; padding: 24px;
}
.login-logo { width: min(420px, 80vw); height: auto; margin-bottom: 40px; }
.login-form { display: flex; flex-direction: column; gap: 14px; width: min(340px, 90vw); }
.login-error {
  background: rgba(255,0,0,.12); border: 1px solid #b00020; color: #ff6b6b;
  padding: 10px 12px; border-radius: 6px; font-size: 13px; text-align: center;
}
.login-form label { font-size: 13px; color: #fff; }
.login-form input {
  width: 100%; padding: 12px 14px; background: #141414; border: 1px solid #2a2a2a;
  border-radius: 6px; color: #fff; font-size: 15px;
}
.login-form input:focus { outline: none; border-color: var(--yellow); }
.login-form button {
  margin-top: 8px; padding: 12px; background: var(--yellow); color: #0A0A0A;
  border: none; border-radius: 6px; font-weight: 700; font-size: 15px; cursor: pointer;
  text-transform: uppercase; letter-spacing: .04em;
}
.login-form button:hover { filter: brightness(.92); }

/* --- ClickUp: ручний діапазон дат (від/до) --- */
.f-range { display: inline-flex; flex-wrap: wrap; gap: 10px; align-items: end;
  margin: 0 0 4px; padding: 10px 12px; border-radius: 12px;
  background: var(--surface); box-shadow: var(--card-shadow); }
.f-range.on { box-shadow: var(--card-shadow), inset 0 0 0 2px #F2D024; }
.f-range label { display: flex; flex-direction: column; gap: 4px;
  font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .03em; }
.f-range input[type=date] {
  padding: 7px 10px; background: var(--bg); color: var(--fg);
  border: 1px solid var(--card-line); border-radius: 8px; font-size: 14px;
  font-family: inherit; color-scheme: light dark; }
.f-range .apply {
  padding: 8px 18px; background: #F2D024; color: #3D3208; border: none;
  border-radius: 20px; font-weight: 700; cursor: pointer; font-size: 13px; }
.f-clear { align-self: center; font-size: 12px; color: var(--muted);
  text-decoration: none; padding: 4px 8px; }
.f-clear:hover { color: var(--fg); }
.f-range-active { margin: 8px 0 0; font-size: 13px; color: var(--muted); }
.f-range-active strong { color: var(--fg); }
.f-range-hint { margin: 6px 0 0; font-size: 12px; color: #B23A3A; }

/* --- ClickUp Динаміка: розподіл по середовищах (2 кільця поряд) --- */
.env-grid { display: grid; gap: 14px; grid-template-columns: repeat(2, 1fr);
  margin-top: 14px; }
@media (max-width: 760px) { .env-grid { grid-template-columns: 1fr; } }
.env-flex { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.env-ring { position: relative; width: 150px; height: 150px; flex: none; }
.env-ring-c { position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; pointer-events: none;
  font-family: 'FGroup', Montserrat, sans-serif; font-weight: 900;
  font-size: 26px; color: var(--fg); line-height: 1; }
.env-ring-c span { font-family: Helvetica, Arial, sans-serif; font-weight: 400;
  font-size: 11px; color: var(--muted); margin-top: 3px; text-transform: uppercase;
  letter-spacing: .04em; }
.env-legend { list-style: none; margin: 0; padding: 0; flex: 1; min-width: 180px; }
.env-legend li { display: flex; align-items: center; gap: 10px; padding: 7px 0;
  border-bottom: 1px solid var(--card-line); font-size: 14px; }
.env-legend li:last-child { border-bottom: none; }
.env-sw { width: 12px; height: 12px; border-radius: 3px; flex: none; }
.env-nm { flex: 1; color: var(--fg); }
.env-pct { font-family: 'FGroup', Montserrat, sans-serif; font-weight: 900;
  font-size: 16px; color: var(--fg); min-width: 44px; text-align: right; }
.env-abs { color: var(--muted); font-size: 12px; min-width: 64px; text-align: right; }
