/* ============================================================
   LaunchLab · Components (HTML/CSS port of ui_kit.jsx + board_kit.jsx)
   Same look, no React.
   ============================================================ */

/* ---------- Buttons ---------- */
.ll-btn {
  font: 500 13px/1.15 var(--ll-font-sans);
  border-radius: 8px;
  cursor: pointer;
  transition: background 140ms cubic-bezier(.4,.2,.2,1), border-color 140ms, color 140ms, filter 140ms, box-shadow 140ms, transform 80ms;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  padding: 7px 12px;
  border: 1px solid transparent;
}
.ll-btn--sm { padding: 6px 10px; }
.ll-btn--lg { padding: 10px 16px; }
.ll-btn--primary {
  background: var(--ll-accent); color: #fff; border: none; padding: 8px 14px;
  box-shadow: 0 1px 2px rgba(20,184,166,0.25), inset 0 1px 0 rgba(255,255,255,0.15);
}
.ll-btn--primary:hover { filter: brightness(1.05); }
.ll-btn--primary:active { transform: translateY(1px); }
.ll-btn--ghost {
  background: transparent; color: var(--ll-text-2); border: 1px solid var(--ll-border);
}
.ll-btn--ghost:hover { background: var(--ll-surface-2); border-color: var(--ll-border-strong); }
.ll-btn--danger {
  background: transparent; color: var(--ll-danger); border: 1px solid transparent;
}
.ll-btn--danger:hover { background: var(--ll-danger-bg); }
.ll-btn--subtle {
  background: var(--ll-surface-2); color: var(--ll-text); border: 1px solid transparent;
}
.ll-btn--subtle:hover { background: #E6E9F0; }

.ll-icon-btn {
  width: 36px; height: 36px; border-radius: 8px;
  border: 1px solid var(--ll-border);
  background: var(--ll-surface);
  color: var(--ll-text-2);
  display: grid; place-items: center; cursor: pointer;
  transition: background 140ms, border-color 140ms, color 140ms;
}
.ll-icon-btn:hover { background: var(--ll-surface-2); color: var(--ll-text); }
.ll-icon-btn--active { background: var(--ll-surface-2); }

/* ---------- Type pill (signature element — 6px dot) ---------- */
.ll-type-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 2px 8px 2px 6px; border-radius: 999px;
  font: 600 10.5px/1.3 var(--ll-font-sans);
  background: var(--_bg, var(--ll-type-email-bg));
  color: var(--_text, var(--ll-type-email-text));
}
.ll-type-pill::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--_color, var(--ll-type-email));
}
/* Type variants — direction-aware (extension over kit's 4 types) */
.ll-type--email     { --_color: var(--ll-type-email);    --_bg: var(--ll-type-email-bg);    --_text: var(--ll-type-email-text); }
.ll-type--announce  { --_color: var(--ll-type-announce); --_bg: var(--ll-type-announce-bg); --_text: var(--ll-type-announce-text); }
.ll-type--note      { --_color: var(--ll-type-note);     --_bg: var(--ll-type-note-bg);     --_text: var(--ll-type-note-text); }
.ll-type--landing   { --_color: var(--ll-type-landing);  --_bg: var(--ll-type-landing-bg);  --_text: var(--ll-type-landing-text); }
.ll-type--blue      { --_color: #3B82F6; --_bg: #DBEAFE; --_text: #1E40AF; }
.ll-type--slate     { --_color: var(--ll-text-3); --_bg: var(--ll-surface-2); --_text: var(--ll-text-2); }

/* ---------- Filter chip ---------- */
.ll-filter-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 11px; border-radius: 999px;
  border: 1px solid var(--ll-border);
  background: var(--ll-surface);
  color: var(--ll-text-2);
  font: 500 12px/1 var(--ll-font-sans);
  cursor: pointer;
  transition: background 140ms, color 140ms, border-color 140ms;
}
.ll-filter-chip:hover { border-color: var(--ll-border-strong); }
.ll-filter-chip--active {
  border-color: transparent; background: var(--ll-text); color: #fff;
}
.ll-filter-chip__count {
  font: 500 11px/1 var(--ll-font-mono);
  opacity: 0.7;
}

/* ---------- Today chip (with live pulse) ---------- */
.ll-today-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 9px 3px 7px; border-radius: 999px;
  background: var(--ll-accent-soft); color: var(--ll-accent-text);
  font: 700 10px/1 var(--ll-font-sans);
  letter-spacing: 0.08em; text-transform: uppercase;
}
.ll-today-chip::before {
  content: ""; width: 7px; height: 7px; border-radius: 50%;
  background: var(--ll-accent);
  animation: ll-live-pulse 1.8s ease-in-out infinite;
}
@keyframes ll-live-pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(20,184,166,0.45); }
  50%     { box-shadow: 0 0 0 6px rgba(20,184,166,0); }
}

/* ---------- Status chip (success / warn / danger / draft) + extras ---------- */
.ll-status-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 9px 3px 7px; border-radius: 999px;
  font: 600 11px/1.3 var(--ll-font-sans);
  background: var(--_sbg, var(--ll-surface-2));
  color: var(--_sfg, var(--ll-text-2));
}
.ll-status-chip::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--_sdot, var(--ll-text-3));
}
.ll-status--success { --_sbg: #D1FAE5; --_sfg: #065F46; --_sdot: var(--ll-success); }
.ll-status--warn    { --_sbg: #FEF3C7; --_sfg: #92540C; --_sdot: var(--ll-warn); }
.ll-status--danger  { --_sbg: var(--ll-danger-bg); --_sfg: #B91C1C; --_sdot: var(--ll-danger); }
.ll-status--draft   { --_sbg: var(--ll-surface-2); --_sfg: var(--ll-text-2); --_sdot: var(--ll-text-3); }
.ll-status--info    { --_sbg: #DBEAFE; --_sfg: #1E40AF; --_sdot: #3B82F6; }
.ll-status--risk    { --_sbg: var(--ll-type-landing-bg); --_sfg: var(--ll-type-landing-text); --_sdot: var(--ll-type-landing); }

/* ---------- Day-num chip (dark, mono) ---------- */
.ll-day-num-chip {
  display: inline-grid; place-items: center;
  min-width: 22px; height: 20px; padding: 0 6px;
  border-radius: 4px; background: var(--ll-text);
  color: #fff; font: 600 11px/1 var(--ll-font-mono);
  letter-spacing: 0.04em;
}
.ll-day-num-chip--accent { background: var(--ll-accent); }
.ll-day-num-chip--danger { background: var(--ll-danger); }

/* ---------- Tag (small, sunken) ---------- */
.ll-tag {
  font: 600 10.5px/1.2 var(--ll-font-sans);
  background: var(--ll-surface-2);
  border: 1px solid var(--ll-border);
  color: var(--ll-text-2);
  padding: 2px 7px; border-radius: 5px;
  display: inline-block;
}

/* ---------- Forms ---------- */
.ll-field { display: block; }
.ll-field > .ll-label { display: block; margin-bottom: 6px; }
.ll-field__hint {
  margin-top: 4px;
  font: 400 11px/1.3 var(--ll-font-sans);
  color: var(--ll-text-3);
}
.ll-input {
  width: 100%; box-sizing: border-box;
  border: 1px solid var(--ll-border);
  border-radius: 8px; padding: 9px 11px;
  font: 400 13.5px/1.4 var(--ll-font-sans);
  color: var(--ll-text); background: var(--ll-surface);
  outline: none;
  transition: border-color 140ms, box-shadow 140ms;
}
.ll-input:focus, .ll-input.is-focused {
  border-color: var(--ll-accent);
  box-shadow: 0 0 0 3px var(--ll-accent-soft);
}
.ll-input::placeholder { color: var(--ll-text-muted); }

.ll-segment {
  display: inline-flex; background: var(--ll-surface-2);
  border-radius: 7px; padding: 2px; gap: 2px;
}
.ll-segment__btn {
  border: none; cursor: pointer;
  padding: 6px 14px; border-radius: 5px;
  font: 400 12px/1 var(--ll-font-sans);
  color: var(--ll-text-2); background: transparent;
  transition: background 140ms, color 140ms;
}
.ll-segment__btn--active {
  font-weight: 500;
  color: var(--ll-text);
  background: var(--ll-surface);
  box-shadow: 0 1px 2px rgba(0,0,0,0.06);
}

/* ---------- Card (the workhorse) ---------- */
.ll-card {
  background: var(--ll-surface);
  border: 1px solid var(--ll-border);
  border-radius: var(--ll-radius);
  box-shadow: var(--ll-shadow-sm);
}
.ll-day-card {
  position: relative; overflow: hidden; padding: 12px;
  transition: background 140ms, border-color 140ms, box-shadow 140ms;
}
.ll-day-card:hover { border-color: var(--ll-border-strong); box-shadow: var(--ll-shadow-md); }
.ll-day-card__stripe {
  position: absolute; top: 0; left: 0; bottom: 0; width: 3px;
  background: var(--_stripe, var(--ll-accent));
}
.ll-day-card__head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 6px;
}
.ll-day-card__time {
  font: 600 11px/1 var(--ll-font-mono);
  color: var(--ll-text-2);
}
.ll-day-card__menu {
  color: var(--ll-text-3);
  opacity: 0;
  transition: opacity 140ms;
}
.ll-day-card:hover .ll-day-card__menu { opacity: 1; }
.ll-day-card__title {
  font: 600 13.5px/1.3 var(--ll-font-sans);
  letter-spacing: -0.01em;
  color: var(--ll-text);
  margin-bottom: 4px;
  text-wrap: pretty;
}
.ll-day-card__preview {
  font: 400 12px/1.45 var(--ll-font-sans);
  color: var(--ll-text-3);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.ll-day-card__status-row {
  margin-top: 8px; padding-top: 7px;
  border-top: 1px dashed var(--ll-border);
  display: flex; align-items: center; gap: 6px;
  font: 400 11px/1 var(--ll-font-sans);
  color: var(--ll-accent-text);
}
.ll-day-card__status-row::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--ll-accent);
}

/* dragging preview */
.ll-card.is-dragging {
  transform: rotate(1deg) scale(.98);
  opacity: .7;
  box-shadow: var(--ll-shadow-drag) !important;
  border-color: var(--ll-accent) !important;
}

/* ---------- Day column (board) ---------- */
.ll-day-column {
  flex: 0 0 280px; width: 280px;
  background: var(--ll-surface);
  border: 1px solid var(--ll-border);
  border-radius: 14px;
  display: flex; flex-direction: column;
  overflow: hidden;
  box-shadow: var(--ll-shadow-sm);
}
.ll-day-column--today {
  border-color: transparent;
  border-top: 2px solid var(--ll-accent);
}
.ll-day-column__header {
  padding: 12px 14px 10px;
  border-bottom: 1px solid var(--ll-border);
}
.ll-day-column__head-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 6px;
}
.ll-day-column__head-meta {
  display: flex; align-items: center; gap: 8px;
}
.ll-day-column__date {
  font: 500 11.5px/1 var(--ll-font-mono);
  color: var(--ll-text-3);
}
.ll-day-column__weekday {
  font: 400 11.5px/1 var(--ll-font-sans);
  color: var(--ll-text-3);
}
.ll-day-column__title {
  font: 600 15px/1.3 var(--ll-font-sans);
  letter-spacing: -0.01em;
  color: var(--ll-text);
  margin-bottom: 6px;
}
.ll-day-column__stage {
  display: flex; align-items: center; gap: 6px;
  margin-bottom: 10px;
}
.ll-day-column__stage::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--_stage, var(--ll-stage-sales));
}
.ll-day-column__stage-label {
  font: 400 11.5px/1 var(--ll-font-sans);
  color: var(--ll-text-3);
}
.ll-day-column__count-row {
  display: flex; align-items: center; justify-content: space-between;
}
.ll-day-column__count {
  font: 400 11.5px/1 var(--ll-font-sans);
  color: var(--ll-text-3);
}
.ll-day-column__count b {
  color: var(--ll-text-2);
  font-weight: 600;
}
.ll-day-column__add-btn {
  display: inline-flex; align-items: center; gap: 4px;
  font: 500 11.5px/1 var(--ll-font-sans);
  color: var(--ll-accent-text);
  background: transparent; border: none; cursor: pointer; padding: 0;
}
.ll-day-column__body {
  padding: 10px;
  display: flex; flex-direction: column; gap: 8px;
  min-height: 140px;
}

/* stage helpers */
.ll-stage--warmup { --_stage: var(--ll-stage-warmup); }
.ll-stage--sales  { --_stage: var(--ll-stage-sales);  }
.ll-stage--close  { --_stage: var(--ll-stage-close);  }

.ll-add-day-column {
  flex: 0 0 280px; min-height: 200px;
  border: 2px dashed var(--ll-border-strong); border-radius: 14px;
  display: grid; place-items: center;
  color: var(--ll-text-3); background: transparent;
  font: 500 13px/1 var(--ll-font-sans);
  cursor: pointer;
  transition: border-color 140ms, color 140ms, background 140ms;
}
.ll-add-day-column:hover {
  border-color: var(--ll-accent);
  color: var(--ll-accent-text);
  background: var(--ll-accent-soft);
}

/* ---------- Board scroll wrapper + signature fake-bar ---------- */
.ll-board-scroll {
  display: flex; gap: 14px; overflow-x: auto; padding-bottom: 12px;
}
.ll-board-scroll::-webkit-scrollbar { height: 10px; }
.ll-board-scroll::-webkit-scrollbar-thumb { background: var(--ll-border-strong); border-radius: 999px; }
.ll-fake-bar {
  height: 14px; background: var(--ll-surface-2);
  border-radius: 999px; position: relative; margin-top: 8px;
}
.ll-fake-bar::after {
  content: ""; position: absolute; left: 10%; top: 3px; bottom: 3px;
  width: 30%; background: var(--ll-border-strong); border-radius: 999px;
}

/* ---------- Timeline strip (warmup → sales → close) ---------- */
.ll-timeline {
  display: flex; gap: 2px; height: 28px; border-radius: 8px;
  overflow: hidden; border: 1px solid var(--ll-border);
}
.ll-timeline > .seg-warmup { background: var(--ll-stage-warmup); }
.ll-timeline > .seg-sales  { background: var(--ll-stage-sales); }
.ll-timeline > .seg-close  { background: var(--ll-stage-close); }
.ll-timeline-legend {
  display: flex; gap: 14px; margin-top: 8px;
  font: 500 11.5px/1.2 var(--ll-font-sans);
  color: var(--ll-text-2);
}
.ll-timeline-legend > span {
  display: inline-flex; align-items: center; gap: 6px;
}
.ll-timeline-legend > span::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--_dot, var(--ll-text-3));
}
.ll-timeline-legend .leg-warmup::before { background: var(--ll-stage-warmup); }
.ll-timeline-legend .leg-sales::before  { background: var(--ll-stage-sales); }
.ll-timeline-legend .leg-close::before  { background: var(--ll-stage-close); }
.ll-timeline-legend .leg-total {
  margin-left: auto; color: var(--ll-text-3);
}
.ll-timeline-legend .leg-total::before { display: none; }

/* ---------- Brand mark ---------- */
.ll-brand-mark {
  width: 28px; height: 28px; border-radius: 7px;
  background: linear-gradient(135deg, var(--ll-accent), var(--ll-accent-2));
  display: grid; place-items: center;
  color: #fff; font: 700 14px/1 var(--ll-font-sans);
  box-shadow: 0 1px 2px rgba(20,184,166,0.3), inset 0 1px 0 rgba(255,255,255,0.2);
  flex-shrink: 0;
}
.ll-brand-mark--lg {
  width: 44px; height: 44px; border-radius: 10px;
  font: 700 22px/1 var(--ll-font-sans);
}

/* ---------- Sidebar ---------- */
.ll-sidebar {
  width: 236px;
  background: var(--ll-sidebar-bg);
  color: var(--ll-sidebar-text);
  padding: 14px 0;
  display: flex; flex-direction: column;
  flex-shrink: 0;
}
.ll-sidebar__brand {
  display: flex; align-items: center; gap: 10px;
  padding: 0 14px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  margin-bottom: 10px;
}
.ll-sidebar__brand b {
  color: #fff; font-size: 14px; letter-spacing: -0.01em; font-weight: 700;
}
.ll-sidebar__section-label {
  font: 700 10px/1 var(--ll-font-sans);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  padding: 14px 14px 8px;
}
.ll-sidebar-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 14px;
  color: var(--ll-sidebar-text);
  background: transparent;
  border-left: 2px solid transparent;
  font: 500 13px/1 var(--ll-font-sans);
  cursor: pointer;
  transition: background 140ms, color 140ms;
  text-decoration: none;
}
.ll-sidebar-item:hover { background: var(--ll-sidebar-hover); color: #fff; }
.ll-sidebar-item--active {
  color: var(--ll-sidebar-text-active);
  background: linear-gradient(90deg, rgba(20,184,166,0.18), transparent);
  border-left-color: var(--ll-accent);
  font-weight: 600;
}
.ll-sidebar-item__icon {
  display: grid; place-items: center; width: 16px;
}
.ll-sidebar-item__label { flex: 1; }
.ll-sidebar-item__count {
  font: 500 11px/1 var(--ll-font-mono);
  opacity: 0.7;
}
.ll-sidebar-item--active .ll-sidebar-item__count { color: rgba(255,255,255,0.7); }
.ll-sidebar-item__dot {
  width: 8px; height: 8px; border-radius: 50%; display: inline-block;
}

/* ---------- Launch row ---------- */
.ll-launch-row {
  padding: 14px;
  display: flex; align-items: center; gap: 14px;
}
.ll-launch-row__mark {
  width: 40px; height: 40px; border-radius: 10px;
  background: linear-gradient(135deg, var(--ll-accent), var(--ll-accent-2));
  display: grid; place-items: center; color: #fff;
  font: 700 14px/1 var(--ll-font-sans); letter-spacing: -0.02em;
  flex-shrink: 0;
}
.ll-launch-row__body { flex: 1; min-width: 0; }
.ll-launch-row__name {
  font: 600 13.5px/1.2 var(--ll-font-sans);
  letter-spacing: -0.01em; color: var(--ll-text);
}
.ll-launch-row__head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 4px;
}
.ll-launch-row__meta {
  display: flex; align-items: center; gap: 12px;
  font: 400 11.5px/1 var(--ll-font-mono);
  color: var(--ll-text-3);
}
.ll-launch-row__meta b { color: var(--ll-text-2); font-weight: 600; }
.ll-launch-row__progress {
  width: 120px;
}
.ll-launch-row__progress-track {
  height: 6px; border-radius: 999px; background: var(--ll-surface-2); overflow: hidden;
}
.ll-launch-row__progress-fill {
  height: 100%; border-radius: 999px;
  background: var(--_stage, var(--ll-stage-sales));
}
.ll-launch-row__progress-num {
  font: 500 10.5px/1 var(--ll-font-mono);
  color: var(--ll-text-3);
  margin-top: 4px; text-align: right;
}

/* ---------- Avatar (extension over kit — not in original but needed for tasks) ---------- */
.ll-avatar {
  width: 24px; height: 24px; border-radius: 50%;
  display: inline-grid; place-items: center;
  color: #fff; font: 600 10.5px/1 var(--ll-font-sans);
  letter-spacing: 0.02em;
  flex-shrink: 0;
}
.ll-avatar--sm { width: 20px; height: 20px; font-size: 9.5px; }
.ll-avatar--lg { width: 32px; height: 32px; font-size: 12px; }
.ll-avatar--yu { background: #5B3BA8; }   /* purple — Юрий */
.ll-avatar--al { background: #0F766E; }   /* teal-deep — Александр */
.ll-avatar--sv { background: #9D1D5C; }   /* pink-deep — Светлана */
.ll-avatar--se { background: #1E40AF; }   /* blue-deep — Сергей */
.ll-avatar--ol { background: #92540C; }   /* amber-deep — Ольга */

/* ---------- Helpers ---------- */
.ll-surface  { background: var(--ll-surface); border: 1px solid var(--ll-border); border-radius: 14px; }
.ll-sunken   { background: var(--ll-surface-2); border-radius: 10px; padding: 14px; }

.ll-divider { border: none; border-top: 1px solid var(--ll-border); margin: 0; }

/* ---------- Topbar (project chrome — extension) ---------- */
.ll-topbar {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 24px;
  background: var(--ll-surface);
  border-bottom: 1px solid var(--ll-border);
  position: sticky; top: 0; z-index: 10;
}
.ll-topbar__crumbs {
  display: flex; align-items: center; gap: 8px;
  font: 400 12.5px/1 var(--ll-font-sans);
  color: var(--ll-text-3);
}
.ll-topbar__crumbs strong { color: var(--ll-text); font-weight: 600; }
.ll-topbar__search {
  display: flex; align-items: center; gap: 8px;
  background: var(--ll-surface-2);
  border: 1px solid var(--ll-border);
  padding: 7px 12px; border-radius: 8px;
  width: 280px;
  color: var(--ll-text-3);
}
.ll-topbar__search input {
  border: 0; outline: 0; background: transparent;
  font: inherit; width: 100%; color: var(--ll-text);
}
.ll-kbd {
  font: 500 10.5px/1 var(--ll-font-mono);
  color: var(--ll-text-3);
  background: var(--ll-surface);
  padding: 2px 5px; border-radius: 4px;
  border: 1px solid var(--ll-border);
}

/* ---------- Checkbox (extension — for sub-checklist) ---------- */
.ll-check {
  width: 16px; height: 16px; border-radius: 5px;
  border: 1.5px solid var(--ll-border-strong);
  background: var(--ll-surface);
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  transition: background 140ms, border-color 140ms;
}
.ll-check:hover { border-color: var(--ll-text-3); }
.ll-check--done {
  background: var(--ll-success); border-color: var(--ll-success);
}
.ll-check--done::after {
  content: ""; position: absolute; left: 4px; top: 1px;
  width: 4px; height: 8px;
  border: solid #fff; border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

/* ---------- App layout (extension) ---------- */
.ll-app {
  display: grid;
  grid-template-columns: 236px 1fr;
  min-height: 100vh;
}
.ll-app__sidebar { position: sticky; top: 0; height: 100vh; overflow-y: auto; }
.ll-app__main { display: flex; flex-direction: column; min-width: 0; }
.ll-page {
  padding: 24px 28px 40px;
  flex: 1;
}

@media (max-width: 900px) {
  .ll-app { grid-template-columns: 1fr; }
  .ll-app__sidebar { position: relative; height: auto; width: 100%; }
  .ll-sidebar { width: 100%; flex-direction: row; flex-wrap: wrap; padding: 12px; gap: 4px; }
  .ll-sidebar__brand { width: 100%; padding: 0 6px 10px; }
  .ll-sidebar__section-label { display: none; }
  .ll-sidebar-item { padding: 6px 10px; border-left: 0; border-radius: 6px; font-size: 12px; }
  .ll-sidebar-item--active { background: var(--ll-sidebar-hover); }
  .ll-page { padding: 16px; }
  .ll-topbar__search { display: none; }
}
